## DATA BOOK

## MICROPROCESSOR



## [MICROPROCESSOR DATA BOOK 1990/1991

## CONTENTS

1 CMOS MICROPROCESSOR LINE-UP ..... 1
2 SYSTEM CONFIGURATION (PERSONAL COMPUTER/WORD PROCESSOR) ..... 5
3 PACKAGING ..... 9
4 RELIABILITY INFORMATION ..... 19
5 DATA SHEETS ..... 29

- CPUs ..... 31
MSM80C85A RS/GS/JS 8-BIT MICROPROCESSOR ..... 33
MSM80C85A-2 RS/GS/JS 8-BIT MICROPROCESSOR ..... 50
MSM80C85AH RS/GS/JS 8-BIT MICROPROCESSOR ..... 70
MSM80C86A RS/GS/JS 16-BIT MICROPROCESSOR MSM80C86A-2 RS/GS/JS 16-BIT MICROPROCESSOR ..... 89
MSM80C86A-10 RS/GS/JS 16-BIT MICROPROCESSOR ..... 116
MSM80C88A RS/GS/JS 8-BIT MICROPROCESSOR MSM80C88A-2RS/GS/JS 8-BIT MICROPROCESSOR ..... 143
MSM80C88A-10RS/GS/JS 8-BIT MICROPROCESSOR ..... 169
- I/O. ..... 195
MSM81C55 RS/GS/JS 2048 BIT SRAM WITH I/O, TIMER MSM81C55-5 RS/GS/JS 2048 BIT SRAM WITH I/O, TIMER ..... 197
MSM81C55H RS/GS/JS 2048 BIT SRAM WITH I/O, TIMER ..... 210
MSM82C12 RS/GS 8-BIT INPUT/OUTPUT PORT ..... 223
MSM82C37A-5RS/GS/JS PROGRAMMABLE DMA CONTROLLER ..... 231
MSM82C37B-5 RS/GS/VJS PROGRAMMABLE DMA CONTROLLER ..... 255
MSM82C43 RS/GS INPUT/OUTPUT PORT EXPANDER ..... 279
MSM82C51A-2RS/GS/JS PROGRAMMABLE COMMUNICATIONS INTERFACE ..... 285
MSM82C53-2 RS/GS/JS PROGRAMMABLE INTERVAL TIMER ..... 304
MSM82C54-2 RS/GS/JS PROGRAMMABLE INTERVAL TIMER ..... 315
MSM82C55A-2 RS/GS/JS PROGRAMMABLE PERIPHERAL INTERFACE ..... 329
MSM82C59A-2 RS/GS/JS PROGRAMMABLE INTERRUPT CONTROLLER ..... 345
MSM82C84A-2RS/GS/JS CLOCK GENERATOR AND DRIVER ..... 363
MSM82C88-2 RS/GS/JS BUS CONTROLLER ..... 373
- PERIPHERALS ..... 383
MSM5832 RS REAL TIME CLOCK/CALENDAR ..... 385
MSM58321 RS REAL TIME CLOCK/CALENDAR ..... 395
MSM6242B RS/GS-VK/JS REAL TIME CLOCK/CALENDAR (BUS INTERFACE) ..... 411


## CMOS MICROPROCESSOR LINE - UP

| PRODUCTS | PART NAME | POWER SUPPLY |  | PACKAGE | REMARKS | COMPATIBILITY |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | VOLTAGE | CURRENT (MAX) |  |  | SUPPLIER | TYPE |
| 8 BIT CPU | MSM80C85A | 5 V | 22mA | $\begin{aligned} & 40 \text { DIP } \\ & 44 \text { FLAT } \\ & 44 \text { PLCC } \end{aligned}$ | 8 BIT MICROPROCESSOR $3 \mathrm{MHz}$ | Intel | 8085A |
|  | MSM80C85A-2 MSM80C85AH | 5 V | 20 mA | $\begin{aligned} & 40 \text { DIP } \\ & 44 \text { FLAT } \\ & 44 \text { PLCC } \end{aligned}$ | 8 BIT MICROPROCESSOR $5 \mathrm{MHz}$ | Intel | 8085A-2 |
| 16 BIT CPU | MSM80C86A | 5 V | 55 mA | $\begin{aligned} & 40 \text { DIP } \\ & 56 \text { FLAT } \\ & 44 \text { PLCC } \end{aligned}$ | 16 BIT MICROPROCESSOR <br> 5 MHz | Intel | 8086 |
|  | MSM80C86A-2 |  | 80 mA |  | 8 MHz | Intel | 8086-2 |
|  | MSM80C86A.10 |  | 100 mA |  | 10 MHz |  | - |
| 8 BIT CPU | MSM80C88A | 5 V | 55 mA | $\begin{aligned} & 40 \text { DIP } \\ & 56 \text { FLAT } \\ & 40 \text { PLCC } \end{aligned}$ | 8 BIT MICROPROCESSOR 5 MHz | Intel | 8088 |
|  | MSM80C88A-2 |  | 80 mA |  | 8 MHz | Intel | 8088-2 |
|  | MSM80C88A. 10 |  | 100 mA |  | 10 MHz |  | - |
| 1/0 | MSM81C55 MSM81C55-5 MSM81C55H | 5 V | 5 mA | $\begin{aligned} & 40 \text { DIP } \\ & 44 \text { FLAT } \\ & 44 \text { PLCC } \end{aligned}$ | 2048 BIT STRAM with I/O and TIMER | Intel | 8155 |
|  | MSM82C12 | 5 V | 1 mA | $\begin{aligned} & 24 \text { DIP } \\ & 24 \text { FLAT } \end{aligned}$ | 8 BIT INPUT/OUTPUT PORT | Intel | 8212 |
|  | $\begin{aligned} & \text { MSM82C37A-5 } \\ & \text { MSM82C37B-5 } \end{aligned}$ | 5 V | 10 mA | $\begin{aligned} & 40 \text { DIP } \\ & 44 \text { FLAT } \\ & 44 \text { PLCC } \end{aligned}$ | PROGRAMMABLE DMA CONTROLLER | Intel | 8237A |
|  | MSM82C43 | 5 V | 1 mA | $\begin{aligned} & 24 \text { DIP } \\ & 24 \text { FLAT } \end{aligned}$ | INPUT/OUTPUT PORT EXPANDER |  | 8243 |
|  | MSM82C51A-2 | 5 V | 5 mA | $\begin{aligned} & 28 \mathrm{DIP} \\ & 32 \mathrm{FLAT} \\ & 28 \mathrm{PLCC} \end{aligned}$ | PROGRAMMABLE COMMUNICATIONS INTERFACE | Intel | 8251A |
|  | MSM82C53-2 | 5 V | 8 mA | $\begin{aligned} & 24 \text { DIP } \\ & 32 \text { FLAT } \\ & 28 \text { PLCC } \end{aligned}$ | PROGRAMMABLE INTERVAL TIMER | Intel | 8253 |
|  | MSM82C54-2 | 5 V | 10 mA | $\begin{array}{\|l\|} \hline 24 \text { DIP } \\ 32 \text { FLAT } \\ 28 \text { PLCC } \\ \hline \end{array}$ | PROGRAMMABLE COUNTER | Intel | 8254 |
|  | MSM82C55A-2 | 5 V | 8 mA | $\begin{aligned} & 40 \text { DIP } \\ & 44 \text { FLAT } \\ & 44 \text { PLCC * } \end{aligned}$ | PROGRAMMABLE PERIPHERAL INTERFACE | Intel | 8255 |
|  | MSM82C59A-2 | 5 V | 5 mA | $\begin{aligned} & 28 \text { DIP } \\ & 32 \text { FLAT } \\ & 28 \text { PLCC } \end{aligned}$ | PROGRAMMABLE INTERRUPT CONTROLLER | Intel | 8259A-2 |
|  | MSM82C84A-2 | 5 V | 16 mA | $\begin{aligned} & 18 \text { DIP } \\ & 24 \text { FLAT } \\ & 20 \text { PLCC } \end{aligned}$ | CLOCK GENERATOR and DRIVER ( 8 MHz ) | Intel | 8284A |
|  | MSM82C88-2 | 5 V | 10 mA | $\begin{aligned} & 20 \text { DIP } \\ & 24 \mathrm{FLAT} \\ & 20 \mathrm{PLCC} \end{aligned}$ | BUS CONTROLLER | Intel | 8288 |
| PERI- <br> PHERALS | MSM5832 | 5 V | 0.1 mA | 18 DIP | REAL TIME CLOCK |  |  |
|  | MSM58321 | 5 V | 0.1 mA | 16 DIP | REAL TIME CLOCK |  |  |
|  | MSM6242 | 5 V | $10 \mu \mathrm{~A}$ | $\begin{aligned} & 18 \text { DIP } \\ & 24 \text { FLAT } \end{aligned}$ | REAL TIME CLOCK DIRECT BUS CONNECTED |  |  |

[^0]
## SYSTEM CONFIGURATION



## PACKAGING

| PRODUCTS | PART NAME | PACKAGE/PIN COUNT |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  | DIP | QFP/SOP | PLCC |
| MPU | M80C85A (Note: 1) | 40 | 44 | 44 |
|  | M80C85A-2 | 40 | 44 | 44 |
|  | M80C86A | 40 | 56 (L) | 44 |
|  | M80C86A-2/80C86A-10 | 40 | 56 (L) | 44 |
|  | M80C88A | 40 | 56 (L) | 44 |
|  | M80C88A-2/80C88A-10 | 40 | 56 (L) | 44 |
| 1/0 | M81C55/81C55-5 | 40 | 44 | 44 |
|  | M82C12 | 24 | 24 | - |
|  | M82C37A-5/M82C37B-5 | 40 | 44 | 44 |
|  | M82C43 | 24 | 24 | - |
|  | M82C51A-2 | 28 | 32 | 28 |
|  | M82C53-2 | 24 | 32 | 28 |
|  | M82C54-2 | 24 | 32 | 28 |
|  | M82C55A-2 | 40 | 44 | 44 |
|  | M82C59A-2 | 28 | 32 | 28 |
|  | M82C84A-2 | 18 | 24 | 20 |
|  | M82C88-2 | 20 | 24 | 20 |
| PERI-PHERALS | M5832 | 18 | - | - |
|  | M58321 | 16 | - | - |
|  | M6242 | 18 | 24 | - |

Note: 1. Model numbers suffixed by RS denote plastic DIP, while GS denotes plastic OFP/SOP, and JS denote PLCC . Ex. MSM80C85ARS plastic DIP
MSM80C85AGS . . . . . . . . plastic QFP/SOP
MSM80C85AJS ........ PLCC

- 16 PIN PLASTIC DIP DIP16-P-300

- 18 PIN PLASTIC DIP DIP18-P-300

- 24 PIN PLASTIC DIP DIP24-P-600

- 28 PIN PLASTIC DIP DIP-P-600


F

## - 40 PIN PLASTIC DIP DIP40-P-600



- 20 PIN PLASTIC SKINNY DIP DIP20-P-300-S1


-24 PIN PLASTIC SOP SOP24-P-430-K

- 24 PIN-V PLASTIC SOP SOP24-P-430-VK

- 32 PIN PLASTIC SOP SSOP32-P-430-K


- 44 PIN PLASTIC QFP QFP44-P-910-K

3

- 44 PIN-V PLASTIC OFP QFP44-P-910-VK

- 44 PIN-V1 PLASTIC QFP QFP44-P-910-VIK

- 56 PIN(L)-V PLASTIC QFP QFP56-P-1519-VK

- 20 PIN PLCC QFJ20-P-S350

- 28 PIN PLCC OFJ28-P-S450

- 44 PIN PLCC QFJ44-P-S650



## RELIABILITY INFORMATION

## RELIABILITY INFORMATION

## 1. INTRODUCTION

Semiconductor devices play a leading role in the explosive progress of semiconductor technology. They use some of the most advanced design and manufacturing technology developed to date. With greater integration, diversity and reliability, their applications have expanded enormously. Their use in large scale computers, control equipment, calculators, electronic games and in many other fields has increased at a fast rate.
A failure in electronic banking or telephone switching equipment, for example, could have far reaching effects and can cause incalculable losses. So, the demand, for stable hiah quality memory devices is strong.
We, at Oki are fully aware of this demand. So we have adopted a comprehensive quality assurance system based on the concept of consistency in development, manufacturing and sales.
With the increasing demand for improvement in function, capability and reliability, we will expand our efforts in the future. Our quality assurance system and the underlying concepts are outlined briefy below.

## 2. QUALITY ASSURANCE SYSTEM AND UNDERLYING CONCEPTS

The quality assurance system employed by Oki can be divided into four major stages: device planning, developmental prototype, production prototype, and mass production. This system is outlined in the following block diagram (Fig. 1).

## 1) Device planning stage

To manufacture devices that meet market demands and satisfy customer needs, we carefully consider functional and failure rate requirements, utilization form, environment and other conditions. Once we determine the proper type, material and structure, we check the design and manufacturing techniques, and the line processing capacity. Then we prepare the development planning and time schedule.

## 2) Developmental prototype stage

We determine circuits, pattern design, process settings, assembly techniques and structural requirements during this stage. At the same time, we carry out actual prototype reliability testing.
Since device quality is largely determined during the designing stage, Oki pays careful attention to quality confirmation during this stage.
This is how we do it:
(1) After completion of circuit design (or pattern design), personnel from the design, process technology, production technology, installation technology and reliability departments get together for a thorough review to ensure
design quality and to anticipate problems that may occur during mass production. Past experience and know-how guide these discussions.
(2) Since many semiconductor memories involve new concepts and employ high level manufacturing technology, the TEG evaluation test is often used during this stage.
Note: TEG (Test Element Group) refers to the device group designed for stability evaluation of MOS transistors, diodes, resistors, capacitors and other circuit component element used in LSI memories.
(3) Prototypes are subjected to repeated reliability and other special evaluation tests. In addition, the stability and capacity of the manufacturing process are checked.

## 3) Production prototype stage

During this stage, various tests check the reliability and other special features of the production prototype at the mass production factory level. After confirming the quality of a device, we prepare the various standards required for mass production, and then start production. Although reliability and other special tests performed on the production prototype are much the same as those performed on the developmental prototype, the personnel, facilities and production site differ for the two prototypes, necessitating repeated confirmation tests.

## 4) Mass production

During the mass production stage, careful management of purchased materials, parts and facilities used during the manufacturing process, measuring equipment, manufacturing conditions and environment is necessary to ensure device quality first stipulated during the designing stages. The manufacturing process (including inspection of the completed device) is followed by a lot guarantee inspection to check that the specified quality is maintained under conditions identical to those under which a customer would actually use the device. This lot guarantee inspection is performed in three different forms as shown below.
(1) Group A tests: appearance, labels, dimensions and electrical characteristics inspection
(2) Group B tests: check of durability under thermal and mechanical environmental stresses, and operating life characteristics
(3) Group C tests: performed periodically to check operational life, etc., on a long term basis.
Note: Like the reliability tests, the group B tests conform to the following standards. MIL-STD-883B, JIS C 7022, EIAJ-IC-121



Figure 2 Manufacturing Process

Devices which pass these lot guarantee inspections are stored in a warehouse awaiting shipment to customers. Standards are also set up for handling, storage and transportation during this period, thereby ensuring quality prior to delivery. Figure 2 shows the manufacturing flow of the completed device.
5) At Oki, all devices are subjected to thorough quality checks. If, by chance, a failure does occur after delivery to the customer, defective devices are processed and the problem rectified immediately to minimize the inconvenience to the customer in accordance with the following flowchart.


Figure 3 Failure report process


## 3. EXAMPLE OF RELIABILITY TEST RESULTS

We have outlined the quality assurance system and the underlying concepts employed by Oki. Now, we will give a few examples of the reliability tests performed during the developmental and production prototype stages. All reliability tests performed by Oki conform to the following standards.

MIL-STD-883B, JIS C 7022, EIAJ-IC-121
Since these reliability tests must determine performance under actual working conditions in a short period of time, they are performed under severe test conditions. For example, the $125^{\circ} \mathrm{C}$ high temperature continuous operation test performed for 1000 hours is equivalent to testing device life from 2 to 300 years of use at $\mathrm{Ta}=$ $40^{\circ} \mathrm{C}$.
By repeating these accelerated reliability tests, device quality is checked and defects analyzed. The resulting information is extremely useful in improving the manufacturing processes. Some of the more common defects in LSI elements and their analysis are described on next page.

## MICROPROCESSOR LIFE TEST RESULTS

| Punction |  | MSM80C85A-2RS |  |  | MSM81C55RS |  |  | MSM82C59A-2RS |  |  | Referred standard |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{gathered} 8 \text { BIT } \\ \text { MICROPROCESSOR } \end{gathered}$ |  |  | 2048 BIT CMOS STATIC RAM WITH I/O PORTS \& TIMER |  |  | PROGRAMMABLE INTERRUPT CONTROLLER |  |  |  |
| Test item | Test condition | Sample size (pcs) | Test hours or cycles | Failures | Sample size (pcs) | Test hours \& cycles | Failures | Sample size (pcs) | Test hours \& cycles | Failures |  |
| Operating life test | $\begin{gathered} \mathrm{Ta}=125^{\circ} \mathrm{C} \\ \mathrm{Vcc}=6 \mathrm{~V} \end{gathered}$ | 88 | $\begin{gathered} 2000 \\ (H) \end{gathered}$ | 0 | 22 | $\begin{gathered} 2000 \\ (H) \end{gathered}$ | 0 | 88 | $\begin{gathered} 2000 \\ (H) \end{gathered}$ | 0 | MIL- STD-883C METHOD 1006 |
| Temperature humidity test | $\begin{aligned} & \mathrm{Ta}=85^{\circ} \mathrm{C} \\ & \mathrm{RH}=85 \% \\ & \mathrm{Vcc}=6 \mathrm{~V} \end{aligned}$ | 100 | $\begin{gathered} 2000 \\ (\mathrm{H}) \end{gathered}$ | 0 | 25 | $\begin{gathered} 2000 \\ (H) \end{gathered}$ | 0 | 100 | $\begin{gathered} 2000 \\ (\mathrm{H}) \end{gathered}$ | 0 |  |
| Temperature cycling test | $\left\lvert\, \begin{gathered} -55^{\circ} \mathrm{C} \rightleftarrows R T \rightleftarrows 150^{\circ} \mathrm{C} \\ (30 \mathrm{~min}) \uparrow(30 \mathrm{~min}) \\ (5 \mathrm{~min}) \end{gathered}\right.$ | 100 | $\begin{aligned} & 500 \\ & \text { (cy) } \end{aligned}$ | 0 | 50 | $\begin{aligned} & 300 \\ & \text { (cy) } \end{aligned}$ | 0 | 100 | $\begin{gathered} 500 \\ \text { (cy) } \end{gathered}$ | 0 | MIL-STD- 883C METHOD 1010 |
| Pressure cooker test | $\begin{aligned} & \mathrm{Ta}=121^{\circ} \mathrm{C} \\ & \mathrm{RH}=100 \% \\ & 2 \mathrm{~atm} \end{aligned}$ | 50 | $\begin{aligned} & 200 \\ & (H) \end{aligned}$ | 0 | 50 | 200 | 0 | 50 | 200 | 0 |  |


| Part name |  | MSM80C86/88AJS |  |  | Referred standard |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Function | $\begin{gathered} 16 \text { BIT } \\ \text { MICROPROCESSOR } \\ \text { (STATIC VERSION) } \end{gathered}$ |  |  |  |
| Test item | Test condition | Sample size (pcs) | Test hours \& cycles | Failures |  |
| Operating life test | $\begin{gathered} \mathrm{Ta}=125^{\circ} \mathrm{C} \\ \mathrm{Vcc}=6 \mathrm{~V} \end{gathered}$ | 88 | $\begin{gathered} 1000 \\ (H) \end{gathered}$ | 0 | $\begin{array}{\|c\|} \hline \text { MIL- } \\ \text { STD-883C } \\ \text { METHOD } \\ 1005 \end{array}$ |
| Temperature humidity test | $\begin{aligned} \mathrm{Ta} & =85^{\circ} \mathrm{C} \\ \mathrm{RH} & =85 \% \\ \mathrm{Vcc} & =6 \mathrm{~V} \end{aligned}$ | 100 | $\begin{gathered} 1000 \\ (\mathrm{H}) \end{gathered}$ | 0 |  |
| Temperature cycling test | $\begin{gathered} -55^{\circ} \mathrm{C} \rightleftharpoons \mathrm{RT} \rightleftarrows 150^{\circ} \mathrm{C} \\ (30 \mathrm{~min}) \uparrow(30 \mathrm{~min}) \\ (5 \mathrm{~min}) \end{gathered}$ | 100 | $\begin{aligned} & 500 \\ & \text { (cy) } \end{aligned}$ | 0 | $\left\|\begin{array}{c} \text { MIL-STD- } \\ \text { 883C } \\ \text { METHOD } \\ 1010 \end{array}\right\|$ |
| Pressure cooker test | $\begin{aligned} & \mathrm{Ta}=121^{\circ} \mathrm{C} \\ & \mathrm{RH}=100 \% \\ & 2 \mathrm{~atm} \end{aligned}$ | 50 | $\begin{aligned} & 200 \\ & (H) \end{aligned}$ | 0 |  |

MICROPROCESSOR ENVIRONMENTAL TEST RESULTS

| Part name |  |  | MSM80C85A-2RS |  | MSM81C55RS |  | MSM82C59A-2RS |  | Referred standard |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Function | $\begin{gathered} 8 \text { BIT } \\ \text { MICROPROCESSOR } \end{gathered}$ |  | 2048 ITT CMOS STATIC RAM WITH I/O PORTS \& TIMER |  | PROGRAMMABLE INTERRUPT CONTROLLER |  |  |
| Tes item |  | Test condition | Sample size (pcs) | Failures | Sample size (pcs) | Failures | Sample size (pcs) | Failures |  |
| PRE-Bake |  | $\begin{gathered} \text { Bake } \\ \left(125^{\circ} \mathrm{C}, 6 \mathrm{hrs}\right) \end{gathered}$ | 22 | 0 | 22 | 0 | 22 | 0 | - |
| Soldering Heat Test |  | $\begin{gathered} 260^{\circ} \mathrm{C} \\ 10 \mathrm{SEC} \end{gathered}$ | 22 | 0 | 22 | 0 | 22 | 0 | $\begin{aligned} & \text { MIL- } \\ & \text { STD-883C } \\ & \text { METHOD } \\ & 2003 \end{aligned}$ |
| Temperature Cycling Test |  | $-55^{\circ} \mathrm{C} \Rightarrow \mathrm{RT} \rightleftharpoons 150^{\circ} \mathrm{C}$ <br> (30min) (5min) (30min) 20 cycles | 22 | 0 | 22 | 0 | 22 | 0 | $\begin{gathered} \text { MLL- } \\ \text { STD-883C } \\ \text { METHOD } \\ 1010 \end{gathered}$ |
| Thermal Shock Test |  | $\begin{aligned} & 100^{\circ} \mathrm{C} \rightleftarrows 0^{\circ} \mathrm{C} \\ & (5 \mathrm{~min})(5 \mathrm{~min}) \\ & 10 \text { cycles } \end{aligned}$ | 22 | 0 | 22 | 0 | 22 | 0 | $\begin{gathered} \text { MIL- } \\ \text { STD-883C } \\ \text { METHOD } \\ 1011 \\ \hline \end{gathered}$ |
| Lead Integrity | Tensile <br> Bending | $500 \mathrm{~g} \quad$ 10SEC $250 \mathrm{~g}{ }^{90^{\circ} \mathrm{BEND}}$ 3 TIMES | 11 | 0 | 11 | 0 | 11 | 0 | $\begin{gathered} \text { MIL- } \\ \text { STD883C } \\ \text { METHOD } \\ 2004 \\ \hline \end{gathered}$ |
| Solderability |  | $230^{\circ} \mathrm{C} 5 \mathrm{SEC}$ | 22 | 0 | 22 | 0 | 22 | 0 |  |


| Part name MSM80C86A/88AJS <br> Function 16 BIT <br> MICROPROCESSOR  <br> (STATIC VERSION)  |  |  |  |  | Referred standard |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |
|  | Test item | Test condition | Sample size (pcs) | Failures |  |
|  | PRE-Bake | Bake $\left(125^{\circ} \mathrm{C}, 6 \mathrm{hrs}\right)$ |  |  | - |
|  | Soldering Heat Test | $\begin{gathered} \text { Vapor Phase Reflow } \\ \left(215 \pm 2^{\circ} \mathrm{C}, 90+10,-0 \mathrm{sec}\right) \\ 2 \text { times } \end{gathered}$ |  |  |  |
|  | Temperature Cycling Test | $-55^{\circ} \mathrm{C} \Rightarrow \mathrm{RT} \rightleftharpoons 150^{\circ} \mathrm{C}$ $(30 \mathrm{~min})(5 \mathrm{~min})(30 \mathrm{~min})$ 20 cycles | 22 | 0 | MIL- STD-883C METHOD 1010 |
|  | Thermal Shock Test | $100^{\circ} \mathrm{C} \rightleftharpoons 0^{\circ} \mathrm{C}$ <br> ( 5 min ) $(5 \mathrm{~min})$ 10 cycles |  |  | MIL- STD-883C METHOD 1011 |
|  | Solderability | $Q$ Bake ( $125^{\circ} \mathrm{C}, 24 \mathrm{hrs}$ ) <br> OImmerse into Flux <br> into Solder <br> $1215 \pm 2^{\circ} \mathrm{C} 10 \pm 1 \mathrm{sec}$ | 22 | 0 |  |

## 4. SEMICONDUCTOR MEMORY FAILURES

The life-span characteristics of semiconductor elements in general (not only semiconductor IC devices) is described by the curve shown in the diagram below. Although semiconductor memory failures are similar to those of ordinary integrated circuits, the degree of integration (miniaturization), manufacturing complexity and other circuit element factors influence their incidence.

## Semiconductor Element Failure Rate Curve



## 1) Surge Destruction

This is destruction of the input/output stage circuits by external surge currents or static electricity. The accompanying photograph shows a point of contact between aluminum and polysilicon that has been dissolved by a surge current. A hole has formed in the substrate silicon, leading to a short circuit. This kind of failure is traceable in about 30\% of defective devices returned to the manufacturer. Despite miniaturization of semiconductor memory component elements (which means the elements themselves are less resistant), these failures usually occur during assembly and other handling operations. At Oki, all devices are subjected to static electricity intensity tests (under simulated operation-


Example of surge destruction
al conditions) in the development stage to reduce this type of failure. In addition to checking endurance against surge currents, special protective circuits are incorporated in the input and output sections.


## 2) Oxide Film Insulation Destruction (Pin Holes)

Unlike surge destruction, this kind of failure is caused by manufacturing defects. Local weakened sections are ruptured when subjected to external electrical stress. Although this problem is accentuated by the miniaturization of circuit elements, it can be resolved by maintaining an ultra-clean manufacturing environment and through 100\% burn-in screening.
3) Surface Deterioration due to lonic Impurities Under some temperature and electric field conditions, charged ionic impurities moving within the oxide film previously resulted in occasional deterioration of silicon surfaces. This problem has been eliminated by new surface stabilization techniques.

## 4) Photolithographic Defects

Integrated circuits are formed by repeated photographic etching processes. Dust and scratches on the mask (which corresponds to a photographic negative) can cause catastrophic defects. At present, component elements have been reduced in size to the order of 10 cm through miniaturization. However, the size of dust and scratches stays the same. At Oki, a high degree of automation, minimizing human intervention in the process, and unparalleled cleanliness, solves this problem.


Photolithographic Defect

## 5) Aluminum Corrosion

Aluminum corrosion is due to electrolytic reactions caused by the presence of water and minute impurities. When aluminum dissolves, lines break. This problem is unique to the plastic capsules now used widely to reduce costs. Oki has carefully studied the possible cause and effect relationship between structure and manufacturing conditions on the one hand, and the generation of aluminum corrosion on the other. Refinements incorporated in Oki LSIs permit superior endurance to even the most severe high humidity conditions.

## 6) Alpha-Particle Soft Failure

This problem occurs when devices are highly miniaturized, such as in 1 megabit RAMs. The inversion of memory cell data by alpha-particle generated by radio-active elements like uranium and thorium (present in minute quantities, measured in ppb) in the ceramic package material causes defects. Since failure is only temporary and normal operation restored quickly, this is referred to as a "soft" failure. At Oki we have eliminated the problem by coating the chip surface of 1 megabit RAMs with a resin which effectively screens out these alpha-particles.


## 7) Degradation in Performance Characteristics Due to Hot Electrons

With increased miniaturization of circuit elements, internal electric field strength in the channels increases since the applied voltage remains the same at 5 V . As a result, electrons flowing in the channels, as shown in the accompanying diagram, tend to enter into the oxide film near the drain, leading to degradation of performance. AIthough previous low-temperature operation tests have indicated an increase of this failure, we have confirmed by our low-temperature acceleration tests, including checks on test element groups, that no such problem exists in Oki LSIs.


Characteristic deterioration caused
by hot electrons

With further progress in the miniaturization of circuit components, failures related to pin hole oxide film destruction and photolithography have increased. To eliminate these defects during manufacturing, Oki has been continually improving its production processes based on reliability tests and information gained from the field. And we subject all devices to high-temperature burnin screening for 48 to 96 hours to ensure even greater reliability.

## DATA SHEETS

# OKKI semiconductor MSM80C85A RS/GS/JS 

## 8-BIT CMOS MICROPROCESSOR

## GENERAL DESCRIPTION

The MSM80C85A is a complete 8-bit parallel central processor implemented in silicon gate C-MOS technology. It is designed with the same processing speed and lower power consumption compared with MSM8085A, thereby offering a high level of system integration.

The MSM80C85A uses a multiplexed address/data bus. The address is split between the 8-bit address bus and the 8-bit data bus. The on-chip address latches of MSM81C55/MSM83C55 memory products allow a direct interface with the MSM80C85A.

## FEATURES

- Low Power Dissipation: 50 mW Typ
- Single +4 to +6 V Power Supply
- -40 to $+85^{\circ} \mathrm{C}$, Operating Temperature
- $1.3 \mu$ Instruction Cycle
- On-Chip Clock Generator (with External Crystal)
- On-Chip System Controller; Advanced Cycle Status Information Available for Large System Control
- TTL Compatible
- Four Vectored Interrupt Inputs (One is non-maskable) Plus the 8080A-compatible interrupt.
- Serial In/Serial Out Port
- Decimal, Binary and Double Precision Arithmetic
- 40pin Plastic DIP (DIP40-P-600)
- 44pin PLCC (OFJ44-P-S650)
-44pin Plastic QFP (OFP44-P-910-K)
-44pin-V Plastic QFP (QFP 44-P-910-VK)


## FUNCTIONAL BLOCK DIAGRAM



PIN CONFIGURATION


## MSM80C85A FUNCTIONAL PIN DEFINITION

The following describes the function of each pin:

| Symbol | Function |
| :---: | :---: |
| $A_{8}-A_{15}$ <br> (Output, 3-state) | Address Bus: The most significant 8-bits of the memory address or the 8-bits of the I/O address, 3 -stated during Hold and Halt modes and during RESET. |
| $\begin{aligned} & \mathrm{AD}_{0}-\mathrm{AD} \mathrm{D}_{7} \\ & \text { (Input/Output) } \\ & \text { 3-state } \end{aligned}$ | Multiplexed Address/Data Bus: Lower 8-bits of the memory address (or I/O address) appear on the bus during the first clock cycle ( $T$ state) of a machine cycle. It then becomes the data bus during the second and third clock cycles. |
| ALE (Output) | Address Latch Enable: It occurs during the first clock state of a machine cycle and enables the address to get latched into the on-chip latch of peripherals. The falling edge of ALE is set to guarantee setup and hold times for the address information. The falling edge of ALE can also be used to strobe the status information. ALE is never 3 -stated. |
| $S_{0}, S_{1}, 10 / \bar{M}$ (Output) | Machine cycle status: <br> $S_{1}$ can be used as an advanced $R / W$ status. $I O / \bar{M}, S_{0}$ and $S_{1}$ become valid at the beginning of a machine cycle and remain stable throughout the cycle. The falling edge of ALE may be used to latch the state of these lines. |
| $\overline{R D}$ (Output, 3-state) | READ control: A low level on $\overline{R D}$ indicates the selected memory or $1 / O$ device is to be read and that the Data Bus is available for the data transfer, 3 -stated during Hold and Halt modes and during RESET. |
| $\overline{W R}$ <br> (Output, 3-state) | WRITE control: A low level on $\overline{W R}$ indicates the data on the Data Bus is to be written into the selected memory or I/O location. Data is set up at the trailing edge of WR, 3 -stated during Hold and Halt modes and during RESET. |
| READY <br> (Input) | If READY is high during a read or write cycle, it indicates that the memory or peripheral is ready to send or receive data. If READY is low, the cpu will wait an integral number of clock cycles for READY to go high before completing the read or write cycle. READY must conform to specified setup and hold times. |
| HOLD <br> (Input) | HOLD indicates that another master is requesting the use of the address and data buses. The cpu, upon receiving the hold request, will relinquish the use of the bus as soon as the completion of the current bus transfer. Internal processing can continue. The processor can regain the bus only after the HOLD is removed. When the HOLD is acknowledged, the Address, Data, $\overline{R D}, \overline{W R}$, and $10 / \bar{M}$ lines are 3 -stated. |
| HiLDA (Output) | HOLD ACKNOWLEDGE: Indicates that the cpu has received the HOLD request and that it will relinquish the bus in the next clock cycle. HLDA goes low after the Hold request is removed. The cpu takes the bus one half clock cycle after HLDA goes low. |
| INTR (Input) | INTERRUPT REQUEST: Is used as a general purpose interrupt. It is sampled only during the next to the last clock cycle of an instruction and during Hold and Halt states. If it is active, the Program Counter (PC) will be inhibited from incrementing and an INTA will be issued. During this cycle a RESTART or CALL instruction can be inserted to jump to the interrupt service routine. The INTR is enabled and disabled by software. It is disabled by Reset and immediately after an interrupt is accepted. |
| $\overline{\text { INTA }}$ (Output) | INTERRUPT ACKNOWLEDGE: is used instead of (and has the same timing as) $\overline{\mathrm{RD}}$ during the instruction cycle after an INTR is accepted. |
| RST 5.5 RST 6.5 RST 7.5 (Input) | RESTART INTERRUPTS: These three inputs have the same timing as INTR except they cause an internal RESTART to be automatically inserted. <br> The priority of these interrupts is ordered as shown in Table 1. These interrupts have a higher priority than INTR. In addition, they may be individually masked out using the SIM instruction. |
| TRAP (Input) | Trap interrupt is a nonmaskable RESTART interrupt. It is recognized at the same timing as INTR or RST 5.5-7.5. It is unaffected by any mask or Interrupt Disable. It has the highest priority of any interrupt. (See Table 1.) |


| Symbol | Function |
| :--- | :--- |
| RESET IN <br> (Input) | Sets the Program Counter to zero and resets the Interrupt Enable and HLDA flip-flops. <br> The data and address buses and the control lines are 3-stated during RESET and because <br> of the asynchronous nature of RESET, the processor's internal registers and flags may be <br> altered by RESET with unpredictable results. RESET IN is a Schmitt-triggered input, <br> allowing connection to an R-C network for power-on RESET delay. The cpu is held in <br> the reset condition as long as RESET IN is applied. |
| RESET OUT <br> (Output) | Indicates cpu is being reset. Can be used as a system reset. The signal is synchronized to <br> the processor clock and lasts an integral number of clock periods. |
| $X_{1}, X_{2}$ <br> (Input) | $X_{1}$ and $X_{2}$ are connected to a crystal to drive the internal clock generator. $X_{1}$ can also <br> be an external clock input from a logic gate. The input frequency is divided by 2 to give <br> the processor's internal operating frequency. |
| CLK <br> (Output) | Clock Output for use as a system clock. The period of CLK is twice the $X_{1}, X_{2}$ input <br> period. |
| SID <br> (Input) | Serial input data line. The data on this line is loaded into accumulator bit 7 whenever <br> a RIM instruction is executed. |
| SOD <br> (Output) | Serial output data line. The output SOD is set or reset as specified by the SIM instruction. |
| $V_{C C}$ | +5 volt supply. |
| GND | Ground Reference. |

Table 1 Interrupt Priority, Restart Address, and Sensitivity

| Name | Priority | Address Branched To (1) <br> When Interrupt Occurs | Type Trigger |
| :--- | :---: | :---: | :--- |
| TRAP | 1 | 24 H | Rising edge and hịah level until <br> sampled. |
| RST 7.5 | 2 | 3 CH | Rising edge (latched). |
| RST 6.5 | 3 | 34 H | High level until sampled. |
| RST 5.5 | 4 | 2CH | High level until sampled. |
| INTR | 5 | (2) | High level until sampled. |

Notes: (1) The processor pushes the PC on the stack before branching to the indicated address.
(2) The address branched to depends on the instruction provided to the cpu when the interrupt is acknowledged.

## FUNCTIONAL DESCRIPTION

The MSM80C85A is a complete 8 -bit parallel central processor. It is designed with silicon gate C-MOS technology and requires a single +5 volt supply. Its basic clock speed is 3 MHz , thus improving on the present 8080A's performance with higher system speed. Also it is designed to fit into a minimum system of three IC's: The cpu (MSM80C85A), a RAM/IO (MSM81C55), and a ROM/IO chip (MSM83C55).

The MSM80C85A. has twelve addressable 8-bit registers. Four of them can function only as two 16-bit register pairs. Six others can be used interchangeably as 8 -bit registers or a 16 -bit register pairs. The MSM80C85A register set is as follows:

| Mnemonic | Register | Contents |
| :--- | :--- | :--- |
| ACC or A | Accumulator | 8-bits |
| PC | Program Counter | 16-bit address |
| BC, DE, HL | General-Purpose <br> Registers; <br> data pointer (HL) | 8-bit $\times 6$ or <br> 16 -bits $\times 3$ |
| SP | Stack Pointer | 16-bit address |
| Flags or F | Flag Register | 5 flags (8-bit space) |

The MSM80C85A uses a multiplexed Data Bus. The address is split between the higher 8 -bit Address Bus and the lower 8 -bit Address/Data Bus. During the first $T$ state (clock cycle) of a machine cycle the low order address is sent out on the Address/Data Bus. These lower 8-bits may be latched externally by the Address Latch Enable signal (ALE). During the rest of the machine cycle the data bus is used for memory or I/O data.

The MSM80C85A provides $\overline{R D}, \overline{W R}, S_{0}, S_{1}$ and IO/ $\bar{M}$ signals for bus control. An Interrupt Acknowledge signal (INTA) is also provided. Hold and all Interrupts are synchronized with the processor's internal clock. The MSM80C85A also provides Serial Input Data (SID) and Serial Output Data (SOD) lines for a simple serial interface.

In addition to these features, the MSM80C85A has three maskable, vector interrupt pins and one nonmaskable TRAP interrupt.

## INTERRUPT AND SERIAL I/O

The MSM80C85A has 5 interrupt inputs: INTR, RST 5.5, RST 6.5, RST 7.5, and TRAP, INTR is identical in functive to the 8080A INT. Each of the three RESTART inputs, 5.5, 6.5, and 7.5 , has a programmable mask. TRAP is also a RESTART interrupt but it is nonmaskable.

Ti.e three maskable interrupts cause the internal
execution of RESTART (saving the program counter in the stack and branching to the RESTART address) if the interrupts are enabled and if the interrupt mask is not set. The nonmaskable TRAP causes the internal execution of a RESTART vector independent of the state of the interrupt enable or masks. (See Table 1.)

There are two different types of inputs in the restart interrupts. RST 5.5 and RST 6.5 are high level-sensitive like INTR (and INT on the 8080A) and are recognized with the same timing as , INTR. RST 7.5 is rising edge-sensitive.

For RST 7.5, only a pulse is required to set an internal flip-flop which generates the internal interrupt request. The RST 7.5 request flip-flop remains set until the request is serviced. Then it is reset automatically. This flip-flop may also be reset by using the SIM instruction or by issuing a RESET IN to the MSM80C85A. The RST 7.5 internal flip-flop will be set by a pulse on the RST 7.5 pin even when the RST 7.5 interrupt is masked out.

The interrupts are arranged in a fixed priority that determines which interrupt is to be recognized if more than one is pending as follows: TRAP-highest priority, RST 7.5, RST 6.5, RST 5.5, INTR-lowest priority. This priority scheme does not take into account the priority of a routine that was started by a higher priority interrupt. RST 5.5 can interrupt an RST 7.5 routine if the interrupts are re-enabled before the end of the RST 7.5 routine.

The TRAP interrupt is useful for catastrophic events such as power failure or bus error. The TRAP input is recognized just as any other interrupt but has the highest priority. It is not affected by any flag or mask. The TRAP input is both edge and level sensitive. The TRAP input must go high and remain high until it is acknowledged. It will not be recognized again until it goes low, then high again. This avoids any false triggering due to noise or logic glitches. Figure 3 illustrates the TRAP interrupt request circuitry within the MSM80C85A. Note that the servicing of any interrupt (TRAP, RST 7.5, RST 6.5, RST 5.5, INTR) disables all future interrupts (except TRAPs) until an EI instruction is executed.

The TRAP interrupt is special in that it disables interrupts, but preserves the previous interrupt enable status. Performing the first RIM instruction following a TRAP interrupt allows you to determine whether interrupts were enabled or disabled prior to the TRAP. All'subsequent RIM instructions provide current interrupt enable status. Performing a RIM instruction following INTR or RST 5.5-7.5 will provide current interrupt Enable status, revealing that interrupts are disabled.

The serial I/O system is also controlled by the RIM and SIM instructions. SID is read by RIM, and SIM sets the SOD data.


Figure 3 Trap and $\overline{\text { RESET IN Circuit }}$

## DRIVING THE $X_{1}$ and $X_{2}$ INPUTS

You may drive the clock inputs of the MSM80C85A with a crystal, or an external clock source. The driving frequency must be at least 1 MHz , and must be twice the desired internal clock frequency; hence, the MSM80C85A is operated with a 6 MHz cyrstal (for 3 MHz clock). If a crystal is used, it must have the following characteristics:

Parallel resonance at twice the clock frequency desired
$C_{L}$ (load capacitance) $\leq 30 \mathrm{pF}$
$\mathrm{C}_{\mathrm{S}}$ (shunt capacitance) $\leq 7 \mathrm{pF}$
$R_{S}$ (equivalent shunt resistance) $\leq \mathbf{7 5}$ ohms

Drive level: 10 mW
Frequency tolerance: $\pm .005 \%$ (suggested)
Note the use of the capacitors between $X_{1}, X_{2}$ and ground. These capacitors are required to assure oscillator startup at the correct frequency.

Figure 4 shows the recommended clock driver circuits. Note in B that a pullup resistor is required to assure that the high level voltage of the input is at least 4V.

For driving frequencies up to and including 6 MHz you may supply the driving signal to $X_{1}$ and leave $X_{2}$ open-circuited (Figure 4B). To prevent self-oscillation of the MSM80C85A, be sure that $X_{2}$ is not coupled back to $X_{1}$ through the driving circuit.
A. Quartz Crystal Clock Driver


100 pF Capacitor required for crystal frequency $<4 \mathrm{MHz}$.
50 pF Capacitor required for crystal frequency $\geq 4 \mathrm{MHz}$.
B. $\quad \mathbf{1 - 6 ~ M H z}$ Input Frequency External Clock Drive Circuit
$\mathrm{VIH}>0.8 \mathrm{~V}$ CC
High time $>60 \mathrm{~ns}$
Low time $>60 \mathrm{~ns}$

* $X_{2}$ Left floating

Figure 4 Clock Driver Circuits

## BASIC SYSTEM TIMING

The MSM80C85A has a multiplexed Data Bus. ALE is used as a strobe to sample the lower 8 -bits of address on the Data Bus. Figure 5 shows an instruction fetch, memory read and I/O write cycle (as would occur during processing of the OUT instruction). Note that during the $1 / O$ write and read cycle that the $1 / O$ port address is copied on both the upper and lower half of the address.

There are seven possible types of machine cycles. Which of these seven takes place is defined by the status of the three status lines ( $10 / \mathrm{M}, \mathrm{S}_{1}, \mathrm{~S}_{0}$ ) and the
three control signals ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, and $\overline{\mathrm{INTA}}$ ). (See Table 2.) The status line can be used as advanced controls (for device selection, for example), since they become active at the $T_{1}$ state, at the outset of each machine cycle. Control lines $\overline{R D}$ and $\overline{W R}$ become active later, at the time when the transfer of data is to take place, so are used as command lines.

A machine cycle normally consists of three $T$ states, with the exception of OPCODE FETCH, which normally has either four or six $T$ states (unless WAIT or HOLD states are forced by the receipt of READY or HOLD inputs). Any $T$ state must be one of ten possible states, shown in Table 3.

Table 2 MSM80C85A Machine Cycle Chart

| Machine Cycle | Status |  |  | Control |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 10/M | $\mathrm{S}_{1}$ | $\mathrm{S}_{0}$ | $\overline{R D}$ | $\overline{W R}$ | INTA |
| Opcode Fetch (OF) | 0 | 1 | 1 | 0 | 1 | 1 |
| Memory Read (MR) | 0 | 1 | 0 | 0 | 1 | 1 |
| Memory Write (MW) | 0 | 0 | 1 | 1 | 0 | 1 |
| I/O Read (IOR) | 1 | 1 | 0 | 0 | 1 | 1 |
| I/O Write (IOW) | 1 | 0 | 1 | 1 | 0 | 1 |
| Acknowledge of INTR (INA) | 1 | 1 | 1 | 1 | 1 | 0 |
| Bus Idle <br> (BI): DAD <br> RST, TRAP HALT | $\begin{gathered} 0 \\ 1 \\ \text { TS } \end{gathered}$ | 1 1 0 | $\begin{aligned} & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{gathered} 1 \\ 1 \\ \text { TS } \end{gathered}$ | $\begin{gathered} 1 \\ 1 \\ \mathbf{T S} \end{gathered}$ | 1 |

Table 3 MSM80C85A Machine State Chart

| Machine State | Status \& Buses |  |  |  | Control |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{S}_{1}, \mathrm{~S}_{0}$ | 10/M | $A_{8}-A_{15}$ | $A D_{0}-A D_{7}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | INTA | ALE |
| $\mathrm{T}_{1}$ | X | X | X | X | 1 | 1 | $1{ }^{(1)}$ |
| $\mathrm{T}_{2}$ | X | $x$ | $x$ | X | X | x | 0 |
| TWAIT | X | X | $x$ | X | X | $x$ | 0 |
| $\mathrm{T}_{3}$ | X | X | X | X | X | X | 0 |
| $\mathrm{T}_{4}$ | 1 | 0 (2) | X | TS | 1 | 1 | 0 |
| $\mathrm{T}_{5}$ | 1 | 0 (2) | X | TS | 1 | 1 | 0 |
| $\mathrm{T}_{6}$ | 1 | 0 (2) | X | TS | 1 | 1 | 0 |
| Treset | X | TS | TS | TS | TS | 1 | 0 |
| THALT | 0 | TS | TS | TS | TS | 1 | 0 |
| THOLD | X | TS | TS | TS | TS | 1 | 0 |

$0=$ Logic " 0 "
1 = Logic " 1 "
TS = High Impedance
X = Unspecified
Notes: (1) ALE not generated during 2nd and 3rd machine cycles of DAD instruction.
(2) $10 / \bar{M}=1$ during $T_{4} \sim T_{6}$ of INA machine cycle.


Figure 5- MSM80C85A Basic System Timing

Table 4 Absolute Maximum Ratings

| Ambient Temperature under Bias | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Tempèrature | $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Supply Voltage Respect to Ground | -0.3V to + 7.0V |
| Input Voltage Respect to Ground | -0.3V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ |
| Power Dissipation | 1.0 Watt (DIP) |
|  | 0.7 Watt (FLAT) |
|  | 1.0 Watt (PLCC) |

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

## D.C. CHARACTERISTICS

( $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$; unless otherwise specified)

| Parameter | Symbol | Min. | Typ. | Max. | Units | Test Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input Low Voltage | $V_{\text {IL }}$ | -0.3 |  | +0.8 | V |  |  |
| Input High Voltage | VIH | 2.2 |  | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |  |  |
| Output Low Voltage | VOL |  |  | 0.45 | V | $\mathrm{I}^{\mathrm{OL}}=2 \mathrm{~mA}$ |  |
| utp |  | 2.4 |  |  | V | ${ }^{1} \mathrm{OH}=-400 \mu \mathrm{~A}$ |  |
|  | OH | 4.2 |  |  | V | $\mathrm{I}^{\mathrm{OH}}=-40 \mu \mathrm{~A}$ |  |
| Input Leak | ILI | -10 |  | 10 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |  |
| Output Leak | ILO | -10 |  | 10 | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}}$ |  |
| Input Low Level, RESET | VILR | -0.3 |  | +0.8 | V |  |  |
| Input High Level, RESET | $\mathrm{V}_{\text {IHR }}$ | 3.0 |  | $\mathrm{v}_{\mathrm{cc}}+0.3$ | V |  |  |
| Hysteresis, RESET | $\mathrm{V}_{\mathrm{HY}}$ | 0.25 |  |  | V |  |  |
|  |  |  | 10 | 22 | mA | $\begin{aligned} & V_{C C}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V} \\ & T_{A}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ | $\begin{aligned} & \text { tcyc = } \\ & \text { 320ns } \end{aligned}$ |
| Power Supply Current | ${ }^{\prime} \mathrm{CC}$ |  | 10 | 17 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \text { to } 5.25 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ | Reset <br> Active <br> CL=0pF |
| Power Supply Voltage | $\mathrm{v}_{\mathrm{Cc}}$ | 4 | 5 | 6 | V |  |  |

## A.C. CHARACTERISTICS

$\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $85^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

| Parameter | Symbol | 80C85A |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| CLK Cycle Period | ${ }^{\text {t }} \mathrm{CYC}$ | 320 | 2000 | ns |
| CLK Low Time | $\mathrm{t}_{1}$ | 80 |  | ns |
| CLK High Time | $\mathrm{t}_{2}$ | 120 |  | ns |
| CLK Rise and Fall Time | $t_{r}, t_{f}$ |  | 30 | ns |
| $\mathrm{X}_{1}$ Rising to CLK Rising | ${ }^{\text {t XKR }}$ | 30 | 120 | ns |
| $\mathrm{X}_{1}$ Rising to CLK Falling | tXKF | 30 | 150 | ns |
| $\mathrm{A}_{8 \sim 15}$ Valid to Leading Edge of Control (1) | ${ }^{\text {taC }}$ | 270 |  | ns |
| $A_{0 \sim 7}$ Valid to Leading Edge of Control | ${ }^{\text {t }}$ ACL | 240 |  | ns |
| $A_{0 \sim 15}$ Valid to Valid Data In | ${ }^{\text {t }}$ AD |  | 575 | ns |
| Address Float After Leading Edge of $\overline{\mathrm{RD}}$ (INTA) | ${ }^{\text {t AFR }}$ |  | 0 | ns |
| $A_{8 \sim 15}$ Valid Before Trailing Edge of ALE ${ }^{(1)}$ | ${ }^{\text {t }}$ AL | 115 |  | ns |
| $A_{0 \sim 7}$ Valid Before Trailing Edge of ALE | ${ }^{\text {t ALL }}$ | 90 |  | ns |
| READY Valid from Address Valid | ${ }^{\text {t ARY }}$ |  | 220 | ns |
| Address ( $\mathrm{A}_{8}-\mathrm{A}_{15}$ ) Valid After Control | ${ }^{\text {t }} \mathrm{CA}$ | 120 |  | ns |
| Width of Control Low ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\text { INTA }}$ ) | ${ }^{\text {t }} \mathrm{CC}$ | 400 |  | ns |
| Trailing Edge of Control to Leading Edge of ALE | ${ }^{\text {t }} \mathrm{CL}$ | 50 |  | ns |
| Data Valid to Trailing Edge of $\overline{W R}$ | ${ }^{\text {t DW }}$ | 420 |  | ns |
| HLDA to Bus Enable | thabe |  | 210 | ns |
| Bus Float After HLDA | thabF |  | 210 | ns |

## A.C. CHARACTERISTICS (cont'd)

| Parameter | Symbol | 80C85A |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| HLDA Valid to Trailing Edge of CLK | thack | 110 |  | ns |
| HOLD Hold Time | thDH | 0 |  | ns |
| HOLD Setup Time to Trailing Edge of CLK | thDS | 170 |  | ns |
| INTR Hold Time | tiNH | 0 |  | ns |
| INTR, RST, and TRAP Setup Time to Falling Edge of CLK | tINS | 160 |  | ns |
| Address Hold Time After ALE | tha | 100 |  | ns |
| Trailing Edge of ALE to Leading Edge of Control | ${ }_{\text {t }}$ C | 130 |  | ns |
| ALE Low During CLK High | thCK | 100 |  | ns |
| ALE to Valid Data During Read | tLDR |  | 460 | ns |
| ALE to Valid Data During Write | tLDW |  | 200 | ns |
| ALE Width | tll | 140 |  | ns |
| ALE to READY Stable | they |  | 110 | ns |
| Trailing Edge of $\overline{\mathrm{RD}}$ to Re-Enabling of Address | traE | 150 |  | ns |
| $\overline{\mathrm{RD}}$ (or $\overline{\text { INTA }}$ ) to Valid Data | tRD |  | 300 | ns |
| Control Trailing Edge to Leading Edge of Next Control | tr V | 400 |  | ns |
| Data Hold Time After $\overline{\text { RD }} \overline{\text { INTA }}$ (7) | tRDH | 0 |  | ns |
| READY Hold Time | tRYH | 0 |  | ns |
| READY Setup Time to Leading Edge of CLK | trys | 110 |  | ns |
| Data Valid After Trailing Edge of WR | two | 100 |  | ns |
| LEADING Edge of $\overline{W R}$ to Data Valid | tWDL |  | 40 | ns |

Notes: (1) $A_{8}-A_{15}$ address Specs apply to $10 / \bar{M}, S_{0}$, and $S_{1}$ except $A_{8}-A_{15}$ are undefined during $T_{4}-T_{6}$ of $O F$ cycle whereas $I O / \bar{M}, S_{0}$, and $S_{1}$ are stable.
(2) Test conditions: $\mathrm{t} \mathbf{C Y C}=320 \mathrm{~ns} \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$
(3) For all output timing where $C_{L}=150 \mathrm{pF}$ use the following correction factors:

$$
\begin{aligned}
& 25 \mathrm{pF} \leq C_{L}<150 \mathrm{pF}:-0.10 \mathrm{~ns} / \mathrm{pF} \\
& 150 \mathrm{pF}<\mathrm{C}_{\mathrm{L}} \leq 300 \mathrm{pF}:+0.30 \mathrm{~ns} / \mathrm{pF}
\end{aligned}
$$

(4) Output timings are measured with purely capacitive load.
(5) All timings are measured at output voltage $\mathrm{V}_{\mathrm{L}}=0.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{H}}=2.2 \mathrm{~V}$, and 1.5 V with 10 ns rise and fall time on inputs.
(6) To calculate timing specifications at other values of CYC use Table 7.
(7) Data hold time is guaranteed under all loading conditions.

Input Waveform for A.C. Tests:


Table 7 Bus Timing Specification as a TCYC Dependent

| MSM80C85A |  |  |  |
| :---: | :---: | :---: | :---: |
| ${ }^{\text {t }}$ AL | - | (1/2) T-45 | MIN |
| tLA | - | (1/2) T - 60 | MIN |
| tLL | - | (1/2) T - 20 | MIN |
| tLCK | - | (1/2)T-60 | MIN |
| t LC | - | (1/2) T-30 | MIN |
| ${ }^{\text {t }}$ AD | - | $(5 / 2+N) T-225$ | MAX |
| ${ }^{\text {tRD }}$ | - | $(3 / 2+N) T-180$ | MAX |
| $t_{\text {RAE }}$ | - | (1/2) T-10 | MIN |
| tCA | - | (1/2) T-40 | MIN |
| ${ }^{\text {t DW }}$ | - | $(3 / 2+N) T-60$ | MIN |
| twD | - | (1/2)T - 60 | MIN |
| ${ }^{\text {t CC }}$ | - | $(3 / 2+N) T-80$ | MIN |
| ${ }^{\text {t CLL }}$ | - | (1/2)T-110 | MIN |
| taRy | - | (3/2) T-260 | MAX |
| thack | - | (1/2)T-50 | MIN |
| thabF | - | $(1 / 2) T+50$ | MAX |
| thabe | - | $(1 / 2) T+50$ | MAX |
| ${ }^{t} A C$ | - | (2/2) T-50 | MIN |
| $\mathrm{t}_{1}$ | - | (1/2) T-80 | MIN |
| $\mathrm{t}_{2}$ | - | (1/2) T-40 | MIN |
| ${ }^{\text {t }} \mathrm{R} \mathrm{V}$ | - | (3/2) T-80 | MIN |
| t LDR | - | $(2+N) T-180$ | MAX |

Note: $\mathbf{N}$ is equal to the total WAIT states.
$T=t_{C Y C}$


Figure 6 Clock Timing Waveform

- CPU•MSM80C85ARS/GS/JS


## READ OPERATION



## WRITE OPERATION



Read operation with Wait Cycle (Typical) -
same READY timing applies to WRITE operation


Note: READY must remain stable during setup and hold times.
Figure 7 MSM80C85A Bus Timing, With and Without Wait

## HOLD OPERATION



Figure 8 MSM80C85A Hold Timing


Note: (1) $10 / \bar{M}$ is also floating during this time.

Figure 9 MSMBOC85A Interrupt and Hold Timing

Table 8 Instruction Set Summary

| Mnemonic | Description | Instructiun Code (1) |  |  |  |  |  |  |  | Clock (2) Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| MOVE, LOAD. AND STORE |  |  |  |  |  |  |  |  |  |  |
| MOVr1 r2 | Move register to register | 0 | 1 | D | D | D | S | S | S | 4 |
| MOV M r | Move register to memory | 0 | 1 | 1 | 1 | 0 | S | S | S | 7 |
| MOV r M | Move memory to register | 0 | 1 | D | D | D | 1 | 1 | 0 | 7 |
| MVI r | Move immediate register | 0 | 0 | D | D | D | 1 | 1 | 0 | 7 |
| MVIM | Move immediate memory | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 10 |
| LXI B | Load immediate register Pair B \& C | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 10 |
| LXI D | Load immediate register Pair D \& E | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 10 |
| LXIH | Load immediate register Pair H \& L | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 10 |
| LXISP | Load immediate stack pointer | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 10 |
| STAX B | Store A indirect | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 7 |
| STAX D | Store A indirect | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 7 |
| LDAX B | Load $A$ indirect | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 7 |
| LDAX D | Load A indirect | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 7 |
| STA | Store A direct | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 13 |
| LDA | Load A direct | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 13 |
| SHLD | Store H \& L direct | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 16 |
| LHLD | Load H \& L direct | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 16 |
| XCHG | Exchange D \& E H \& L registers | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 4 |
| STACK OPS |  |  |  |  |  |  |  |  |  |  |
| PUSH B | Push register Pair B \& C on stack | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 12 |
| PUSH D | Push register Pair D \& E on stack | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 12 |
| PUSH H | Push register Pair H \& L on stack | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 12 |
| PUSH PSW | Push A and Flags on stack | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 12 |
| POP B | Pop register Pair B \& C off stack | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 10 |
| POP D | Pop register Pair D \& E off stack | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 10 |
| POP H | Pop register Pair H \& L off stack | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 10 |
| POP PSW | Pop A and Flags off stack | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 10 |
| XTHL | Exchange top of stack H\&L | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 16 |
| SPHL | H \& L to stack pointer | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 6 |
| JUMP |  |  |  |  |  |  |  |  |  |  |
| JMP | Jump unconditional | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 10 |
| JC | Jump on carry | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 7/10 |
| JNC | Jump on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 7/10 |
| JZ | Jump on zero | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 7/10 |
| JNZ | Jump on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 7/10 |
| JP | Jump on positive | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 7/10 |
| JM | Jump on minus | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 7/10 |
| JPE | Jump on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 7/10 |
| JPO | Jump on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 7/10 |
| PCHL | H\&L to program counter | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 6 |
| CALL |  |  |  |  |  |  |  |  |  |  |
| CALL | Call unconditional | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 18 |
| CC | Call on carry | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 9/18 |
| CNC | Call on no carry | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 9/18 |
| CZ | Call on zero | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 9/18 |
| CNZ | Call on no zero | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 9/18 |
| CP | Call on positive | 1 | 1 | 1. | 1 | 0 | 1 | 0 | 0 | 9/18 |
| CM | Call on minus | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 9/18 |
| CPE | Call on parity even | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 9/18 |
| CPO | Call on parity odd | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 9/18 |

Table 8 Instruction Set Summary cont'd

| Mnemonic | Description | Instruction Code(1) |  |  |  |  |  |  |  | Clock(2) <br> Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| RETURN |  |  |  |  |  |  |  |  |  |  |
| RET | Return | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
| RC | Return on carry | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 6/12 |
| RNC | Return on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 6/12 |
| RZ | Return on zero | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 6/12 |
| RNZ | Return on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 6/12 |
| RP | Return on positive | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 6/12 |
| RM | Return on minus | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 6/12 |
| RPE | Return on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 6/12 |
| RPO | Return on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 6/12 |
| RESTART |  |  |  |  |  |  |  |  |  |  |
| INPUT/OUTPUT |  |  |  |  |  |  |  |  |  |  |
| IN | Input | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 10 |
| OUT | Output | , | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 10 |
| INCREMENT AND DECREMENT |  |  |  |  |  |  |  |  |  |  |
| INR r | Increment register | 0 | 0 | D | D | D | 1 | 0 | 0 | 4 |
| DCR r | Decrement register | 0 | 0 | D | D | D | 1 | 0 | 1 | 4 |
| INR M | Increment memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 10 |
| DCR M | Decrement memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 10 |
| INX B | Increment B \& C registers | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 6 |
| INX D | Increment D \& E registers | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 6 |
| INX H | Increment H \& L registers | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 6 |
| INX SP | Increment stack pointer | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 6 |
| DCX B | Decrement B \& C | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 6 |
| DCX D | Decrement D \& E | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 6 |
| DCX H | Decrement H\&L | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 6 |
| DCX SP | Decrement stack pointer | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 6 |
| ADD |  |  |  |  |  |  |  |  |  |  |
| ADD r | Add register to A | 1 | 0 | 0 | 0 | 0 | S | S | S | 4 |
| ADC r | Add register to $A$ with carry | 1 | 0 | 0 | 0 | 1 | S | S | S | 4 |
| ADD M | Add memory to $A$ | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 7 |
| ADC M | Add memory to A with carry | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 7 |
| ADI | Add immediate to $A$ | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 7 |
| ACI | Add immediate to A with carry | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 7 |
| DAD B | Add B \& C to H \& L | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
| DAD D | Add D \& E to H \& L | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 10 |
| DAD H | Add H \& L to H \& L | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 10 |
| DAD SP | Add stack pointer to H \& L | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 10 |
| SUBTRACT |  |  |  |  |  |  |  |  |  |  |
| SUB r | Subtract register from A | 1 | 0 | 0 | 1 | 0 | S | S | S | 4 |
| SBB r | Subtract register from A with borrow | 1 | 0 | 0 | 1 | 1 | S | S | S | 4 |
| SUB M | Subtract memory from A | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| SBB M | Subtract memory from A with borrow | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |
| SUI | Subtract immediate from A | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| SBI | Subtract immediate from $A$ with borrow | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |

Table 8 Instruction Set Summary cont'd

| Mnemonic | Description | Instruction Code (1) |  |  |  |  |  |  |  | Clock(2) Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| LOGICAL |  |  |  |  |  |  |  |  |  |  |
| ANA r | And register with A | 1 | 0 | 1 | 0 | 0 | S | S | S | 4 |
| XRA r | Exclusive Or register with $A$ | 1 | 0 | 1 | 0 | 1 | S | S | S | 4 |
| ORA $r$ | Or register with A | 1 | 0 | 1 | 1 | 0 | S | S | S | 4 |
| CMP r | Compare register with A | 1 | 0 | 1 | 1 | 1 | S | S | S | 4 |
| ANA M | And memory with A | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 7 |
| XRA M | Exclusive Or memory with A | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |
| ORA M | Or memory with A | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 7 |
| CMP M | Compare memory with $A$ | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 7 |
| ANI | And immediate with A | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 7 |
| XRI | Exclusive Or immediate with A | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |
| ORI | Or immediate with A | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 7 |
| CPI | Compare immediate with $A$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 7 |
| Rotate |  |  |  |  |  |  |  |  |  |  |
| RLC. | Rotate A left | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 4 |
| RRC | Rotate A right | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 4 |
| RAL | Rotate A left through carry | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 4 |
| RAR | Rotate A right through carry | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 4 |
|  |  |  |  |  |  |  |  |  |  |  |
| CMA STC | Set carry | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 4 |
| CMC | Complement carry | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 4 |
| DAA | Decimal adjust A | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 4 |
| CONTROL |  |  |  |  |  |  |  |  |  |  |
| EI | Enable Interrupts | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 4 |
| DI | Disable Interrupt | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 4 |
| NOP | No-operation | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 4 |
| HLT | Halt | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 5 |
| RIM | Read Interrupt Mask | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 4 |
| SIM | Set Interrupt Mask | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 4 |

B

Notes: (1) DDD or SSS. B 000. C 001. D 010. E 011. H 100. L 101. Memory 110. A 111.
(2) Two possible cycle times, $(6 / 12)$ indicate instruction cycles dependent on condition flags.

Precautions for operation
(1) When the oscillation circuit is to be used, keep the RES input low until the oscillation is sufficiently stabilized after power is turned on.
(2) When power is turned on, the output level (SOD etc.) is irregular before the equipment is reset.

## GENERAL DESCRIPTION

The MSM80C85A-2 is a complete 8-bit parallel central processor implemented in silicon gate C-MOS technology and compatible with MSM80C85A.

It is designed with higher processing speed (max. 5 MHz ) and lower power consumption compared with MSM80C85A and power down mode is provided, thereby offering a high level of system integration.

The MSM80C85A-2 uses a multiplexed address/data bus. The address is split between the 8-bit address bus and the 8-bit data bus. The on-chip address latche of a MSM81C55-5 memory product allows a direct interface with the MSM80C85A-2.

## FEATURES

- Power down mode (HALT.HOLD)
- Low Power Dissipation: 50mW Typ
- Single +3 to +6 V Power Supply
- -40 to $+85^{\circ} \mathrm{C}$, Operating Temperature
- Compatible with MSM80C85A
- $0.8 \mu$ Instruction Cycle ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ )
- On-Chip Clock Generator (with External Crystal)
- On-Chip System Controller; Advanced Cycle Status Information Available for Large System Control
- Four Vectored Interrupt Inputs (One is non-maskable) Plus the 8080A-compatible interrupt.
- Serial In/Serial Out Port
- Decimal, Binary and Double Precision Arithmetic
- Addressing Capability to 64 K Bytes of Memory
- TTL Compatible
- 40 pin Plastic DIP (DIP40-P-600)
- 44 pin PLCC (OFJ44-P-S650)
. 44 pin-V Plastic QFP(QFP44-P-910-VK)

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATION



## MSM80C85A-2 FUNCTIONAL PIN DEFINITION

The following describes the function of each pin:

| Symbol | Function |
| :---: | :---: |
| $\begin{aligned} & A_{8}-A_{15} \\ & \text { (Output, 3-state) } \end{aligned}$ | Address Bus: The most significant 8 -bits of the memory address or the 8 -bits of the I/O address, 3 -stated during Hold and Halt modes and during RESET. |
| $\begin{aligned} & \mathrm{AD}_{0}-\mathrm{AD} \\ & \text { (Input/Output) } \\ & \text { 3-state } \end{aligned}$ | Multiplexed Address/Data Bus: Lower 8-bits of the memory address (or I/O address) appear on the bus during the first clock cycle ( $T$ state) of a machine cycle. It then becomes the data bus during the second and third clock cycles. |
| ALE (Output) | Address Latch Enable: It occurs during the first clock state of a machine cycle and enables the address to get latched into the on-chip latch of peripherals. The falling edge of ALE is set to guarantee setup and hold times for the address information. The falling edge of ALE can also be used to strobe the status information ALE is never 3-stated. |
| $\begin{aligned} & \mathrm{S}_{0}, \mathrm{~S}_{1}, 10 / \overline{\mathrm{M}} \\ & \text { (Output) } \end{aligned}$ |  <br> $S_{1}$ can be used as an advanced $R / W$ status. $10 / \bar{M}, S_{0}$ and $S_{1}$ become valid at the beginning of a machine cycle and remain stable throughout the cycle. The falling edge of ALE may be used to latch the state of these lines. |
| $\overline{\mathrm{RD}}$ (Output, 3-state) | READ control: A low level on $\overline{\mathrm{RD}}$ indicates the selected memory or I/O device is to be read and that the Data Bus is available for the data transfer, 3 -stated during Hold and Halt modes and during RESET. |
| $\overline{W R}$ <br> (Output, 3-state) | WRITE control: A low level on $\overline{W R}$ indicates the data on the Data Bus is to be written into the selected memory or I/O location. Data is set up at the trailing edge of $\overline{W R}$, 3 -stated during Hold and Halt modes and during RESET. |
| READY (Input) | If READY is high during a read or write cycle, it indicates that the memory or peripheral is ready to send or receive data. If READY is low, the cpu will wait an integral number of clock cycles for READY to go high before completing the read or write cycle READY must conform to specified setup and hold times. |
| HOLD (Input) | HOLD indicates that another master is requesting the use of the address and data buses. The cpu, upon receiving the hold request, will relinquish the use of the bus as soon as the completion of the current bus transfer. Internal processing can continue. The processor can regain the bus only after the HOLD is removed. When the HOLD is acknowledged, the Address, Data, $\overline{R D}, \overline{W R}$, and $10 / \bar{M}$ lines are 3 -stated. And status of power down is controlled by HOLD. |
| HLDA (Output) | HOLD ACKNOWLEDGE: Indicates that the cpu has received the HOLD request and that it will relinquish the bus in the next clock cycle. HLDA goes low after the Hold request is removed. The cpu takes the bus one half clock cycle after HLDA goes low. |
| INTR (Input) | INTERRUPT REQUEST: Is used as a general purpose interrupt. It is sampled on during the next to the last clock cycle of an instruction and during Hold and Halt states. If it is active, the Program Counter (PC) will be inhibited from incrementing and an INTA will be issued. During this cycle a RESTART or CALL instruction can be inserted to jump to the interrupt service routine. The INTR is enabled and disabled by software. It is disabled by Reset and immediately after an interrupt is accepted. Power down mode is reset by INTR. |
| $\overline{\text { INTA }}$ (Output) | INTERRUPT ACKNOWLEDGE: Is used instead of (and has the same timing as) $\overline{\mathrm{RD}}$ during the instruction cycle after an INTR is accepted. |
| RST 5.5 RST 6.5 RST 7.5 (Input) | RESTART INTERRUPTS: These three inputs have the same timing as INTR except they cause an internal RESTART to be automatically inserted. <br> The priority of these interrupts is ordered as shown in Table 1. These interrupts have a higher priority than INTR. In addition, they may be individually masked out using the SIM instruction. Power down mode is reset by these interrupts. |
| TRAP (Input) | Trap interrupt is a nonmaskable RESTART interrupt. It is recognized at the same timing as INTR or RST 5.5-7.5. It is unaffected by any mask or Interrupt Disable. It has the highest priority of any interrupt. (See Table 1.) Power down mode is reset by input of TRAP. |


| Symbol | Function |
| :--- | :--- |
| RESET IN <br> (Input) | Sets the Program Counter to zero and resets the Interrupt Enable and HLDA flip-flops <br> and release power down mode. The data and address buses and the control lines are 3- <br> stated during RESET and because of the asynchronous nature of $\overline{\text { RESET, the processor's }}$ <br> internal registers and flags may be altered by RESET with unpredictable results. $\overline{R E S E T}$ <br> $\overline{\text { N }}$ is a Schmitt-triggered input, allowing connection to an R-C network for power-on <br> RESET delay. The cpu is held in the reset condition as long as $\overline{\text { RESET IN is applied. }}$ |
| RESET OUT <br> (Output) | Indicated cpu is being reset. Can be used as a system reset. The signal is synchronized to <br> the processor clock and lasts an integral number of clock periods. |
| $X_{1}, X_{2}$ <br> (Input) | $X_{1}$ and $X_{2}$ are connected to a crystal to drive the internal clock generator. $X_{1}$ can also <br> be an external clock input from a logic gate. The input frequency is divided by 2 to give <br> the processor's internal operating frequency. |
| CLK <br> (Output) | Clock Output for use as a system clock. The period of CLK is twice the $X_{1}, X_{2}$ input <br> period. |
| SID <br> (Input) | Serial input data line. The data on this line is loaded into accumulator bit 7 whenever <br> a RIM instruction is executed. |
| SOD <br> (Output) | Serial output data line. The output SOD is set or reset as specified by the SIM instruction. |
| VCC $^{\text {GND }}$ | +5 volt supply. |

Table 1 Interrupt Priority, Restart Address, and Sensitivity

| Name | Priority | Address Branched To (1) <br> When Interrupt Occurs | Type Trigger |
| :--- | :---: | :--- | :--- |
| TRAP | 1 | 24 H | Rising edge and high level until <br> sampled. |
| RST 7.5 | 2 | 3 CH | Rising edge (latched). |
| RST 6.5 | 3 | 34 H | High level until sampled. |
| RST 5.5 | 4 | 2 H | High level until sampled. |
| INTR | 5 | (2) | High level until sampled. |

Notes: (1) The processor pushes the PC on the stack before branching to the indicated address.
(2) The address branched to depends on the instruction provided to the cpu when the interrupt is acknowledged.

## FUNCTIONAL DESCRIPTION

The MSM80C85A-2 is a complete 8 -bit parallel central processor. It is designed with silicon gate C-MOS technology and requires a single +5 volt supply. Its basic clock speed is 5 MHz , thus improving on the present MSM80C85A's performance with higher system speed and power down mode. Also it is designed to fit into a minimum system of three IC's: The cpu (MSM80C85A-2), and a RAM/IO (MSM81C55-5)

The MSM80C85A-2 has twelve addressable 8-bit register pairs. Six others can be used interchangeably as 8 -bit registers or a 16 -bit register pairs. The MSM-80C85A-2 register set is as follows:

| Mnemonic | Register | Contents |
| :--- | :--- | :--- |
| ACC or $A$ | Accumulator | 8 -bits |
| PC | Program Counter | 16 -bit address |
| BC, DE, HL | General-Purpose <br> Registers; <br> (ata pointer (HL) | 8 -bit $\times 6$ or <br> 16 -bits $\times 3$ |
| SP | Stack Pointer | 16 -bit address |
| Flags or F | Flag Register | 5 flags (8-bit space) |

The MSM80C85A-2 uses a multiplexed Data Bus. The address is split between the higher 8-bit Address Bus and the lower 8-bit Address/Data Bus. During the first $T$ state (clock cycle) of a machine cycle the low order address is sent out on the Address/Data Bus. These lower 8 -bits may be latched externally by the Address Latch Enable signal (ALE). During the rest of the machine cycle the data bus is used for memory or I/O data.

The MSM80C85A-2 provides $\overline{R D}, \overline{W R}, \mathrm{~S}_{0}, \mathrm{~S}_{1}$ and $10 / \bar{M}$ signals for bus control. An Interrupt Acknowledge signal (INTA) is also provided. Hold and all Interrupts are synchronized with the processor's internal clock. The MSM80C85A-2 also provides Serial Input Data (SID) and Serial Output Data (SOD) lines for a simple serial interface.

In addition to these features, the MSM80C85A-2 has three maskable, vector interrupt pins, one nonmaskable TRAP interrupt and power down mode with HALT and HOLD.

## INTERRUPT AND SERIAL I/O

The MSM80C85A-2 has 5 interrupt inputs: INTR, RST 5.5, RST 6.5, RST 7.5, and TRAP. INTR is identical in function to the 8080A INT. Each of the three RESTART inputs, $5.5,6.5$, and 7.5 , has a programmable mask. TRAP is also a RESTART interrupt but it is nonmaskable.

The three maskable interrupts cause the internal
execution of RESTART (saving the program counter in the stack and branching to the RESTART address) if the interrupts are enabled and if the interrupt mask is not set. The nonmaskable TRAP causes the internal execution of a RESTART vector independent of the state of the interrupt enable or masks. (See Table 1.)

There are two different types of inputs in the restart interrupts. RST 5.5 and RST 6.5 are high level-sensitive like INTR (and INT on the 8080A) and are recognized with the same timing as INTR. RST 7.5 is rising edge-sensitive.

For RST 7.5, only a pulse is required to set an internal flip-flop which generates the internal interrupt request. The RST 7.5 request flip-flop remains set until the request is serviced. Then it is reset automatically. This flip-flop may also be reset by using the SIM instruction or by issuing a $\overline{\operatorname{RESET} I N}$ to the MSM80C85A. The RST 7.5 internal flip-flop will be set by a pulse on the RST 7.5 pin even when the RST 7.5 interrupt is masked out.

The interrupts are arranged in a flixed priority that determines which interrupt is to be recognized if more than one is pending, as follows: TRAP-highest priority, RST 7.5, RST 6.5, RST 5.5, INTR-lowest priority. This priority scheme does not take into account the priority of a routine that was started by a higher priority interrupt. RST 5.5 can interrupt an RST 7.5 routine if the interrupts are re-enabled before the end of the RST 7.5 routine.

The TRAP interrupt is useful for catastrophic events such as power failure or bus error. The TRAP input is recognized just as any other interrupt but has the highest priority. It is not affected by any flag or mask. The TRAP input is both edge and level sensitive. The TRAP input must go high and remain high until it is acknowledged. It will not be recognized again until it goes low, then high again. This avoids any false triggering due to noise or logic glitches. Figure 3 illustrates the TRAP interrupt request circuitry within the MSM80C85A-2. Note that the servicing of any interrupt (TRAP, RST 7.5, RST 6.5, RST 5.5, INTR) disables all future interrupts (except TRAPs) until an El instruction is executed.

The TRAP interrupt is special in that it disables interrupts, but preserves the previous interrupt enable status. Performing the first RIM instruction following a TRAP interrupt allows you to determine whether interrupts were enabled or disabled prior to the TRAP. All subsequent RIM instructions provide current interrupt enable status. Performing a RIM instruction following INTR or RST $5.5-7.5$ will provide current Interrupt Enable status, revealing that Interrupts are disabled.

The serial I/O system is also controlled by the RIM and SIM instructions. SID is read by RIM, and SIM sets the SOD data.


Figure 3 Trap and $\overline{\text { RESET IN }}$ Circuit

## DRIVING THE $\mathrm{X}_{1}$ and $\mathrm{X}_{2}$ INPUTS

You may drive the clock inputs of the MSM80C-85A-2 with a crystal, or an external clock source. The driving frequency must be at least 1 MHz , and must be twice the desired internal clock frequency; hence, the MSM80C85A-2 is operated with a 6 MHz crystal (for 3 MHz clockt. If a crystal is used, it must have the following characteristics:

Parallel resonance at twice the clock frequency desired
$C_{L}$ (load capacitance) $\leq 30 \mathrm{pF}$
$C_{S}$ (shunt capacitance) $\leq 7 \mathrm{pF}$
$R_{S}$ (equivalent shunt resistance) $\leq 75$ ohms

Drive level: 10 mW
Frequency tolerance: $\pm .005 \%$ (suggested)
Note the use of the capacitors between $X_{1}, X_{2}$ and ground. These capacitors are required to assure oscillator startup at the correct frequency.

Figure 4 shows the recommended clock driver circuits. Note in B that a pullup resistor is required to assure that the high level voltage of the input is at least 4 V .

For driving frequencies up to and including 6 MHz you may supply the driving signal to $X_{1}$ and leave $X_{2}$ open-circuited (Figure 4B). To prevent self-oscillation of the MSM80C85A-2, be sure that $X_{2}$ is not coupled back to $X_{1}$ through the driving circuit.

## A. Quartz Crystal Clock Driver



33pF Capacitor required for crystal frequency 10 to 6.25 MHz . 50 pF Capacitor required for crystal frequency 6.25 to 4 MHz . 100pF Capacitor required for crystal frequency $<4 \mathrm{MHz}$.
B. $\quad \mathbf{1 - 1 0} \mathbf{M H z}$ Input Frequency External Clock Drive Circuit


* $X_{2}$ Left floating

Figure 4 Clock Driver Circuits

## BASIC SYSTEM TIMING

The MSM80C85A-2 has a multiplexed Data Bus. ALE is used as a strobe to sample the lower 8 -bits of address on the Data Bus. Figure 5 shows an instruction fetch, memory read and I/O write cycle (as would occur during processing of the OUT instruction). Note that during the I/O write and read cycle that the I/O port address is copied on both the upper and lower half of the address.

There are seven possible types of machine cycles. Which of these seven takes place is defined by the status of the three status lines ( $10 / \bar{M}, S_{1}, S_{0}$ ) and the
three control signals ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, and $\overline{\mathrm{INTA}}$ ). (See Table 2.) The status line can be used as advanced controls (for device selection, for example), since they become active at the $T_{1}$ state, at the outset of each machine cycle. Control lines $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ become active later, at the time when the transfer of data is to take place, so are used as command lines.

A machine cycle normally consists of three $T$ states, with the exception of OPCODE FETCH, which normally has either four or six $T$ states (unless WAIT or HOLD states are forced by the receipt of READY or HOLD inputs). Any $T$ state must be one of ten possible states, shown in Table 3.

Table 2 MSM80C85A-2 Machine Cycle Chart


Table 3 MSM80C85A-2 Machine State Chart

| Machine State | Status \& Buses |  |  |  |  |  | Control |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{S}_{1}, \mathrm{~S}_{0}$ | $10 / \overline{\mathrm{M}}$ | $\mathrm{A}_{8}-\mathrm{A}_{15}$ | $\mathrm{AD}_{0}-\mathrm{AD}_{7}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $\overline{\mathrm{NTA}}$ | ALE |  |  |
| $\mathrm{T}_{1}$ | X | X | X | X | 1 | 1 | $1^{(1)}$ |  |  |
| $\mathrm{T}_{\mathbf{2}}$ | X | X | X | X | X | X | 0 |  |  |
| $\mathrm{~T}_{\text {WAIT }}$ | X | X | X | X | X | X | 0 |  |  |
| $\mathrm{~T}_{3}$ | X | X | X | X | X | X | 0 |  |  |
| $\mathrm{~T}_{4}$ | 1 | $0(2)$ | X | TS | 1 | 1 | 0 |  |  |
| $\mathrm{~T}_{\mathbf{5}}$ | 1 | $0(2)$ | X | TS | 1 | 1 | 0 |  |  |
| $\mathrm{~T}_{6}$ | 1 | $0(2)$ | X | TS | 1 | 1 | 0 |  |  |
| $\mathrm{~T}_{\text {RESET }}$ | X | TS | TS | TS | TS | 1 | 0 |  |  |
| $\mathrm{~T}_{\text {HALT }}$ | 0 | TS | TS | TS | TS | 1 | 0 |  |  |
| $\mathrm{~T}_{\text {HOLD }}$ | X | TS | TS | TS | TS | 1 | 0 |  |  |

[^1]Notes: (1) ALE not generated during 2nd and 3rd machine cycles of DAD instruction.
(2) $10 / \bar{M}=1$ during $T_{4} \sim T_{6}$ of INA machine cycle.


Figure 5. MSM80C85A-2 Basic System Timing

## POWER DOWN Mode (a newly added function)

The MSM80C85A-2 is compatible with the MSM80C85A in function and POWER DOWN mode. This reduces power consumption further.

There are two methods available for starting this POWER DOWN mode. One is through software control by using the HALT command and the other is under hardware control by using the pin HOLD. This mode is released by the HOLD, RESET, and interrupt pins (TRAP, RST7.5, RST6.5, RST5.5, or INTR). (See Table 4.)

Since the sequence of HALT, HOLD, RESET, and INTERRUPT is compatible with MSM80C85A, every the POWER DOWN mode can be used with no special attention.

Table 4 POWER DOWN Mode Releasing Method

| Start by means of <br> HALT command | Released by using pins RESET <br> and INTERRUPT (not by pin <br> HOLD) |
| :--- | :--- |
| Start by means of <br> HOLD pin | Released by using RESET and <br> HOLD pins (not by interrupt <br> pins) |

(1) Start by means of HALT command
(See Figures 6 and 7.)
The POWER DOWN mode can be started by executing the HALT command.
At this time, the system is put into the HOLD status and therefore the POWER DOWN mode cannot be released even when the HOLD is released later.
In this case, the POWER DOWN mode can be released by means of the RESET or interrupt.
(2) Start by means of HOLD pin (See Figure 8.)

During the execution of commands other than the HALT, the POWER DOWN mode is started when the system is put into HOLD status by means of the HOLD pin.
Since no interrupt works during the execution of the HOLD, the POWER DOWN mode cannot be released by means of interrupt pins.
In this case, the POWER DOWN mode can be released either by means of the RESET pin or by releasing the HOLD status by means of HOLD pin.


Figure 6. Started by HALT and Released by RESET IN


Figure 7. Started by HALT and Released by RST5.5


Figure 8. Started and Released by HOLD

- CPU•MSM80C85A-2RS/GS/JS


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Condition | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM80C85A-2RS | MSM80C85A-2GS | MSM80C85A-2JS |  |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | With respect to GND | $-0.5 \sim+7$ |  |  | V |
| Input Voltage | VIN |  | $-0.5 \sim V_{C C}+0.5$ |  |  | V |
| Output Voltage | VOUT |  | $-0.5 \sim V_{\text {CC }}+0.5$ |  |  | $\checkmark$ |
| Storage Temperature | Tstg |  | $-55 \sim+150$ |  |  | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | PD | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | 1.0 | 0.7 | 1.0 | W |

OPERATING RANGE

| Parameter | Symbol | Limits | Unit |
| :---: | :---: | :---: | :---: |
| Power Supply Voltage | $V_{\text {CC }}$ | $3 \sim 6$ | V |
| Operating Temperature | Top | $-40 \sim+85$ | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Supply Voltage | $V_{C C}$ | 4.5 | 5 | 5.5 | $\checkmark$ |
| Operating Temperature | TOP | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| ' L " Input Voltage | $V_{\text {IL }}$ | -0.3 |  | +0.8 | V |
| "H' Output Voltage | $\mathrm{V}_{\text {IH }}$ | 2.2 |  | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |
| $\begin{aligned} & \text { "L", RESET IN } \\ & \text { Input Voltage } \end{aligned}$ | VILR | -0.3 |  | +0.8 | V |
| $\begin{gathered} " \mathrm{H}^{\prime}, \text { RESET IN } \\ \text { Input Voltage } \\ \hline \end{gathered}$ | $V_{\text {IHR }}$ | 3.0 |  | $\mathrm{VCC}^{+} 0.3$ | V |

## D.C. CHARACTERISTICS

| Parameter | Symbol | Conditions |  | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L" Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $1 \mathrm{OL}=2 \mathrm{~mA}$ |  |  |  | 0.45 | V |
| "H' Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | ${ }^{1} \mathrm{OH}=-400 \mu \mathrm{~A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \sim 5.5 \mathrm{~V} \\ & \mathrm{Ta}=-40^{\circ} \mathrm{C} \sim+85^{\circ} \mathrm{C} \end{aligned}$ | 2.4 |  |  | V |
|  |  | $\mathrm{I}^{\mathrm{OH}}=-40 \mu \mathrm{~A}$ |  | 4.2 |  |  | V |
| Input Leak Current | ILI | $0 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Output Leak Current | ILO | $0 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Operating Supply Current | ${ }^{\prime} \mathrm{Cc}$ | $\begin{aligned} & \text { Tcyc }=200 \mathrm{~ns} \\ & C_{L}=0 \mathrm{pF} \text { at reset } \end{aligned}$ |  |  | 10 | 20 | mA |
|  |  | $\begin{aligned} & \text { Tcyc }=200 \mathrm{~ns} \\ & C_{L}=0 p F \text { at power } \\ & \text { down mode } \end{aligned}$ |  |  | 3 | 7 | mA |

## A.C. CHARACTERISTICS

| Parameter | Symbol | Condition | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CLK Cycle Period | ${ }^{t} \mathrm{CYC}$ |  | 200 | 2000 | ns |
| CLK Low Time | $t_{1}$ | $\begin{aligned} & { }^{t} C_{C Y}=200 \mathrm{~ns} \\ & C_{L}=150 \mathrm{pF} \end{aligned}$ | 40 |  | ns |
| CLK High Time | $\mathrm{t}_{2}$ |  | 70 |  | ns |
| CLK Rise and Fall Time | $t_{r}, t_{f}$ |  |  | 30 | ns |
| $X_{1}$ Rising to CLK Rising | ${ }^{t} \times K$ R |  | 25 | 120 | ns |
| $X_{1}$ Rising to CKK Falling | ${ }^{\text {t }} \times$ KK $F$ |  | 30 | 150 | ns |
| $A_{8} \sim_{1 s}$ Valid to Leading Edge of Control (1) | ${ }^{\text {t }} \mathrm{AC}$ |  | 115 |  | ns |
|  | ${ }^{t} A C L$ |  | 115 |  | ns |
| $A_{0} \sim_{1 s}$ Valid Data in | ${ }^{1}$ AD |  |  | 330 | ns |
| Address Float After Leading Edge of RD INTA | ${ }^{\text {t }}$ AFR |  |  | 0 | ns |
| $A_{8} \sim_{1 s}$ Valid Before Trailing Edge of ALE (1) | ${ }^{\text {t }} \mathrm{AL}$ |  | 50 |  | ns |
| $A_{0} \sim_{7}$, Valid Before Trailing Edge of ALE | ${ }^{t}$ ALL |  | 50 |  | ns |
| READY Valid from Address Valid | ${ }^{\text {t }}$ ARY |  |  | 100 | ns |
| Address ( $A_{8} \sim_{1 s}$ ) Valid After Control | ${ }^{\text {t }} \mathrm{CA}$ |  | 60 |  | ns |
| Width of Control Law (RD, WR, INTA) | ${ }^{t} \mathrm{CC}$ |  | 230 |  | ns |
| Trailing Edge of Control to Leading Edge of ALE | ${ }^{\text {t }} \mathrm{CL}$ |  | 25 |  | ns |
| Data Valid to Trailing Edge of WR | ${ }^{\text {t }}$ DW |  | 230 |  | ns |
| HLDA to Bus Enable | ${ }^{1}$ HABE |  |  | 150 | ns |
| Bus Float After HLDA | ${ }^{\text {t }}$ HABF |  |  | 150 | ns |
| HLDA Valid to Trailing Edge of CLK | ${ }^{\text {t }} \mathrm{HACK}$ |  | 40 |  | ns |
| HOLD Hold Time | ${ }^{t} \mathrm{HDH}$ |  | 0 |  | ns |
| HOLD Step Up Time to Trailing Edge of CLK | ${ }^{\text {t }} \mathrm{HDS}$ |  | 120 |  | ns |
| INTR Hold Time | ${ }_{\text {t }}$ INH |  | 0 |  | ns |
| INTR, RST and TRAP Setup Time to Falling Edge of CLK | ${ }^{\text {tins }}$ |  | 150 |  | ns |
| Address Hold Time After ALE | ${ }_{\text {t }}$ A |  | 50 |  | ns |
| Trailing Edge of ALE to Leading Edge of Control | ${ }^{\text {t }} \mathrm{LC}$ |  | 60 |  | ns |
| ALE Low During CLK High | ${ }^{\text {t LCK }}$ |  | 50 |  | ns |
| ALE to Valid Data During Read | ${ }^{\text {t L DR }}$ |  |  | 250 | ns |
| ALE to Valid Data During Write | ${ }^{\text {t }}$ LDW |  |  | 140 | ns |
| ALE Width | ${ }_{\text {t }}^{\text {LL }}$ |  | 80 |  | ns |
| ALE to READY Stable | ${ }_{\text {t LRY }}$ |  |  | 30 | ns |
| Trailing Edge of RD to Re-enabling of Address | ${ }^{\text {t RAE }}$ |  | 90 |  | ns |
| RD (or INTA) to Valid Data | ${ }^{t}$ RD |  |  | 150 | ns |
| Control Trailing Edge to Leading Edge of Next Control | ${ }^{\text {t R V }}$ |  | 220 |  | ns |
| Data Hold Time After RD INTA (7) | ${ }^{\text {t }} \mathrm{RDH}$ |  | 0 |  | ns |
| READY Hold Time | ${ }^{\text {t }}$ RYH |  | 0 |  | ns |
| READY Setup Time to Leading Edge of CLK | ${ }^{\text {tRYS }}$ |  | 100 |  | ns |
| Data Valid After Trailing Edge of WR | twD |  | 60 |  | ns |
| LEADING Edge of WR to Data Valid | ${ }^{\text {t }}$ WDL |  |  | 20 | ns |

Notes: (1) $A_{8} \sim A_{15}$ address Specs apply to $1 O / M, S_{0}$, and $S_{1}$ except $A_{8} \sim A_{15}$ are undefined during $T_{4} \sim T_{8}$ of $O F$ cycle whereas $10 / \mathrm{M}, \mathrm{S}_{0}$, and $\mathrm{S}_{1}$ are stable.
2) Test conditions: ${ }^{\mathrm{t}} \mathrm{CYC}=200 \mathrm{~ns} \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$
(3) For all output timing where $C_{L}=150 \mathrm{pF}$ use the following correction factors: $25 \mathrm{pF} \leq \mathrm{C}_{\mathrm{L}}<150 \mathrm{pF}:-0.10 \mathrm{~ns} / \mathrm{pF}$ $150 \mathrm{pF}<\mathrm{C}_{\mathrm{L}} \leq 300 \mathrm{pF}:+0.30 \mathrm{~ns} / \mathrm{pF}$
(4) Output timings are measured with purely capacitive load.
(5) All timings are measured at output voltage $\mathrm{V}_{\mathrm{L}}=0.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{H}}=2.2 \mathrm{~V}$, and 1.5 V with 10 ns rise and fall time on inputs.
(6) To calculate timing specifications at other values of ${ }^{\mathrm{C}} \mathrm{CYC}$ use Table 7
(7) Data hold time is guaranteed under all loading conditions.

Input Waveform for A.C. Tests:


Table 7 Bus Timing Specification as a TCYC Dependent

|  | MSM80C85A-2 |  |  |
| :---: | :---: | :---: | :---: |
| ${ }^{t} A L$ | - | (1/2)T-50 | MIN |
| tha | - | (1/2) T - 50 | MIN |
| ${ }^{\text {t L L }}$ | - | (1/2) T-20 | MIN |
| tLCK | - | (1/2)T-50 | MIN |
| ${ }_{\text {t }} \mathrm{C}$ | - | (1/2)T-40 | MIN |
| ${ }^{t} A D$ | - | $(5 / 2+N) T-170$ | MAX |
| ${ }_{\text {t }}{ }_{\text {R }}$ | - | $(3 / 2+N) T-150$ | MAX |
| $t_{\text {RAE }}$ | - | (1/2) T - 10 | MIN |
| ${ }^{t} \mathrm{CA}$ | - | (1/2)T-40 | MIN |
| tow | - | $(3 / 2+N) T-70$ | MIN |
| ${ }^{\text {t }}$ D ${ }^{\text {d }}$ | - | (1/2) T-40 | MIN |
| ${ }^{\text {t C C }}$ | - | $(3 / 2+N) T-70$ | MIN |
| ${ }^{\text {t }}$ CL | - | (1/2)T-75 | MIN |
| ${ }^{t}$ ARY | - | (3/2) T-200 | MAX |
| thack | - | $(1 / 2) T-60$ | MIN |
| thabF | - | $(1 / 2) T+50$ | MAX |
| thabe | - | $(1 / 2) T+50$ | MAX |
| ${ }^{t} A C$ | - | (2/2) T-85 | MIN |
| $\mathrm{t}_{1}$ | - | (1/2) T-60 | MIN |
| $\mathrm{t}_{2}$ | - | (1/2)T-30 | MIN |
| ${ }^{\text {t }} \mathrm{R} \mathrm{V}$ | - | (3/2) T-80 | MIN |
| tLDR | - | $(2+N) T-150$ | MAX |

Note: N is equal to the total WAIT states.
$T={ }^{\mathrm{t}} \mathrm{CY} \mathrm{C}$


Figure 6 Clock Timing Waveform

## READ OPERATION



## WRITE OPERATION



Read operation with Wait Cycle (Typical) -
same READY timing applies to WRITE operation


Note: READY must remain stable during setup and hold times:
Figure 7 MSM80C85A-2 Bus Timing, With and Without Wait


Figure 8 MSM80C85A-2 Hold Timing


Note: (1) $10 / \bar{M}$ is also floating during this time.

Figure 9 MSM80C85A-2 Interrupt and Hold Timing

Table 8 Instruction Set Summary

| Mnemonic | Description | Instruction Code (1) |  |  |  |  |  |  |  | Clock (2) Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| MOVE, LOAD, AND STORE |  |  |  |  |  |  |  |  |  |  |
| MOVr1 r2 | Move register to register | 0 | 1 | D | D | D | S | S | S | 4 |
| MOV M r | Move register to memory | 0 | 1 | 1 | 1 | 0 | S | S | S | 7 |
| MOV r M | Move memory to register | 0 | 1 | D | D | D | 1 | 1 | 0 | 7 |
| MVI r | Move immediate register | 0 | 0 | D | D | D | 1 | 1 | 0 | 7 |
| MVI M | Move immediate memory | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 10 |
| LXIB | Load immediate register Pair B \& C | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 10 |
| LXI D | Load immediate register Pair D \& E | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 10 |
| LXI H | Load immediate register Pair H \& L | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 10 |
| LXISP | Load immediate stack pointer | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 10 |
| STAX B | Store A indirect | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 7 |
| STAX D | Store A indirect | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 7 |
| LDAX B | Load $A$ indirect | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 7 |
| LDAX D | Load A indirect | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 7 |
| STA | Store A direct | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 13 |
| LDA | Load A direct | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 13 |
| SHLD | Store H \& L direct | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 16 |
| LHLD | Load H \& L direct | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 16 |
| XCHG | Exchange D \& E H \& L registers | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 4 |
| STACK OPS |  |  |  |  |  |  |  |  |  |  |
| PUSH B | Push register Pair B \& C on stack | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 12 |
| PUSH D | Push register Pair D \& E on stack | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 12 |
| PUSH H | Push register Pair H \& L on stack | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 12 |
| PUSH PSW | Push A and Flags on stack | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 12 |
| POP B | Pop register Pair B \& C off stack | 1 | 1. | 0 | 0 | 0 | 0 | 0 | 1 | 10 |
| POP D | Pop register Pair D \& E off stack | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 10 |
| POP H | Pop register Pair H \& L off stack | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 10 |
| POP PSW | Pop A and Flags off stack | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 10 |
| XTHL | Exchange top of stack H \& L | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 16 |
| SPHL | H\& L to stack pointer | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 6 |
| JUMP |  |  |  |  |  |  |  |  |  |  |
| JMP | Jump unconditional | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 10 |
| JC | Jump on carry | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 7/10 |
| JNC | Jump on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 7/10 |
| JZ | Jump on zero | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 7/10 |
| JNZ | Jump on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 7/10 |
| JP | Jump on positive | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 7/10 |
| JM | Jump on minus | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 7/10 |
| JPE | Jump on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 7/10 |
| JPO | Jump on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 7/10 |
| PCHL | H\&L to program counter | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 6 |
| CALL |  |  |  |  |  |  |  |  |  |  |
| CALL | Call unconditional | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 18 |
| CC | Call on carry | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 9/18 |
| CNC | Call on no carry | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 9/18 |
| CZ | Call on zero | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 9/18 |
| CNZ | Call on no zero | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 9/18 |
| CP | Call on positive | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 9/18 |
| CM | Call on minus | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 9/18 |
| CPE | Call on parity even | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 9/18 |
| CPO | Call on parity odd | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 9/18 |

Table 8 Instruction Set Summary cont'd

| Mnemonic | Description | Instruction Code(1) |  |  |  |  |  |  |  | Clock(2) Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| RETURN |  |  |  |  |  |  |  |  |  |  |
| RET | Return | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
| RC | Return on carry | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 6/12 |
| RNC | Return on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 6/12 |
| RZ | Return on zero | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 6/12 |
| RNZ | Return on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 6/12 |
| RP | Return on positive | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 6/12 |
| RM | Return on minus | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 6/12 |
| RPE | Return on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 6/12 |
| RPO | Return on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 6/12 |
| RESTART RST | Restart | 1 | 1 | A | A | A | 1 | 1 | 1 | 12 |
| INPUT/OUTPUT |  |  |  |  |  |  |  |  |  |  |
| IN | Input | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 10 |
| OUT | Output | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 10 |
| INCREMENT AND DECREMENT |  |  |  |  |  |  |  |  |  |  |
| INR r | Increment register | 0 | 0 | D | D | D | 1 | 0 | 0 | 4 |
| DCR r | Decrement register | 0 | 0 | D | D | D | 1 | 0 | 1 | 4 |
| INRM | Increment memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 10 |
| DCR M | Decrement memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 10 |
| INXB | Increment B \& C registers | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 6 |
| INX D | Increment D \& E registers | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 6 |
| INXH | Increment H \& L registers | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 6 |
| INX SP | Increment stack pointer | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 6 |
| DCX B | Decrement B \& C | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 6 |
| DCX D | Decrement D \& E | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 6 |
| DCX H | Decrement H \& L | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 6 |
| DCX SP | Decrement stack pointer | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 6 |
| ADD |  |  |  |  |  |  |  |  |  |  |
| ADD r | Add register to A | 1 | 0 | 0 | 0 | 0 | S | S | S | 4 |
| ADC r | Add register to A with carry | 1 | 0 | 0 | 0 | 1 | S | S | S | 4 |
| ADD M | Add memory to $A$ | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 7 |
| ADC M | Add memory to A with carry | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 7 |
| ADI | Add immediate to $A$ | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 7 |
| ACl | Add immediate to A with carry | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 7 |
| DAD B | Add B \& C to H \& L | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
| DAD D | Add D \& E to H \& L | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 10 |
| DAD H | Add H \& L to H \& L | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 10 |
| DAD SP | Add stack pointer to H \& L | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 10 |
| SUBTRACT |  |  |  |  |  |  |  |  |  |  |
| SUB r | Subtract register from A | 1 | 0 | 0 | 1 | 0 | S | S | S | 4 |
| SBB r | Subtract register from $\cdot \mathrm{A}$ with borrow | 1 | 0 | 0 | 1 | 1 | S | S | S | 4 |
| SUB M | Subtract memory from A | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| SBB M | Subtract memory from A with borrow | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |
| SUI | Subtract immediate from A | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| SBI | Subtract immediate from A with borrow | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |

Table 8 Instruction Set Summary cont'd

| Mnemonic | Description | Instruction Code(1) |  |  |  |  |  |  |  | Clock(2) Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| LOGICAL |  |  |  |  |  |  |  |  |  |  |
| ANA r | And register with $A$ | 1 | 0 | 1 | 0 | 0 | S | S | S | 4 |
| XRA $r$ | Exclusive Or register with A | 1 | 0 | 1 | 0 | 1 | S | S | S | 4 |
| ORA r | Or register with A | 1 | 0 | 1 | 1 | 0 | S | S | S | 4 |
| CMP r | Compare register with A | 1 | 0 | 1 | 1 | 1 | S | S | S | 4 |
| ANA M | And memory with A | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 7 |
| XRA M | Exclusive Or Memory with A | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |
| ORA M | Or memory with A | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 7 |
| CMP M | Compare memory with $A$ | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 7 |
| ANI | And immediate with A | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 7 |
| XRI | Exclusive Or immediate with A | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |
| ORI | Or immediate with A | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 7 |
| CPI | Compare immediate with A | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 7 |
| ROTATE |  |  |  |  |  |  |  |  |  |  |
| RLC | Rotate A left | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 4 |
| RRC | Rotate A right | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 4 |
| RAL | Rotate A left through carry | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 4 |
| RAR | Rotate A right through carry | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 4 |
| SPECIALS |  |  |  |  |  |  |  |  |  |  |
| CMA | Complement A | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 4 |
| STC | Set carry | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 4 |
| CMC | Complement carry | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 4 |
| DAA | Decimal adjust A | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 4 |
| CONTROL |  |  |  |  |  |  |  |  |  |  |
| EI | Enable Interrupts | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 4 |
| DI | Disable Interrupts | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 4 |
| NOP | No-operation | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 4 |
| HLT | Halt (Power down) | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 5 |
| RIM | Read Interrupt Mask | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 4 |
| SIM | Set Interrupt Mask | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 4 |

Notes: (1) DDD or SSS. B 000. C 001. D 010. E 011. H 100. L 101. Memory 110. A 111.
(2) Two possible cycle times, (6/12) indicate instruction cycles dependent on condition flags.

## Precautions for operation

(1) When the oscillation circuit is to be used, keep the RES input low until the oscillation is sufficiently stabilized after power is turned on.
(2) When power is turned on, the SOD output level is irregular before the equipment is reset.

## - NOTE

## Item: Precautions for operation of MSM80C85A-2

1. Error phenomenon

When the power down mode of the OKI 8-bit microprocessor MSM80C85A-2, which is activated under the conditions indicated below, is released, a malfunction occurs. Although the operation cycle is increased, the operation cycle is increased, the operation sequence is normal. If the HOLD function is not used, no problems are caused.
Condition 1: During the HALT instruction fetch, the HOLD function is activated and an interruption is simultaneously requested. (See Fig.1.)
Conditions 2: During the HALT instruction fetch, the HOLD function is activated and no intterruption is requested. (See Fig.2.) (When the HALT cycle starts after the HOLD function is released)


Fig. 1 Malfunction timing chart 1


Fig. 2 Malfunction timing chart 2

## 2. Error cause

An error occurs in the Power Down mode release circuit under the above conditions.
3. Precautions for operation

A problem caused by the above malfunction is that the bus conflict with each other because the HOLD function is accepted during the interruption (INTR) acceptance cycle. To prevent the bus from confliction, it is necessary to design so that the HOLD function is not accepted during the interruption (INTR) acceptance cycle. (See Fig.3.)

4. Others

A revised edition of MSM80C85AH which is free of the above error is under development.

## OKXI semiconductor MSM80C85AHRS/GS/JS

## 8-BIT CMOS MICROPROCESSOR

## GENERAL DESCRIPTION

The MSM80C85AH is a complete 8-bit parallel central processor implemented in silicon gate C-MOS technology and compatible with MSM80C85A.

It is designed with higher processing speed (max. 5 MHz ) and lower power consumption compared with MSM80C85A and power down mode is provided, thereby offering a high level of system integration.

The MSM80C85AH uses a multiplexed address/data bus. The address is split between the 8 -bit address bus and the 8-bit data bus. The on-chip address latche of a MSM81C55-5 memory product allows a direct interface with the MSM80C85AH

## FEATURES

- Power down mode (HALT.HOLD)
- Low Power Dissipation: 50mW Typ
- Single +3 to +6 V Power Supply
- -40 to $+85^{\circ} \mathrm{C}$, Operating Temperature
- Compatible with MSM80C85A
- $0.8 \mu$ Instruction Cycle ( $V_{C C}=5 \mathrm{~V}$ )
- On-Chip Clock Generator (with External Crystal)
- On-Chip System Controller; Advanced Cycle Status Information Available for Large System Control

Four Vectored Interrupt Inputs (One is non-maskable) Plus the 8080A-compatible interrupt

- Serial In/Serial Out Port
- Decimal, Binary and Double Precision Arithmetic
- Addressing Capability to 64 K Bytes of Memory
- TTL Compatible
- 40 pin Plastic DIP (DIP40-P-600)
- 44 pin PLCC (QFJ44-P-S650)
- 44 pin-V Plastic QFP (QFP44-P-910-VK)

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATION



## CPU•MSM80C85AHRS/GS/JS

## MSM80C85AH FUNCTIONAL PIN DEFINITION

The following describes the function of each pin:

| Symbol | Function |
| :---: | :---: |
| $A_{8}-A_{15}$ <br> (Output, 3-state) | Address Bus: The most significant 8-bits of the memory address or the 8-bits of the I/O address, 3 -stated during Hold and Halt modes and during RESET. |
| $\begin{aligned} & A D_{0}-A D_{7} \\ & \text { (Input/Output) } \\ & \text { 3-state } \end{aligned}$ | Multiplexed Address/Data Bus: Lower 8-bits of the memory address (or 1/O address) appear on the bus during the first clock cycle ( $T$ state) of a machine cycle. It then becomes the data bus during the second and third clock cycles. |
| ALE (Output) | Address Latch Enable: It occurs during the first clock state of a machine cycle and enables the address to get latched into the on-chip latch of peripherals. The falling edge of ALE is set to guarantee setup and hold times for the address information. The falling edge of ALE can also be used to strobe the status information ALE is never 3-stated. |
| $\mathrm{S}_{0}, \mathrm{~S}_{1}, \mathrm{IO} / \overline{\mathrm{M}}$ (Output) |  <br> $S_{1}$ can be used as an advanced R/W status. $I O / \bar{M}, S_{0}$ and $S_{1}$ become valid at the beginning of a machine cycle and remain stable throughout the cycle. The falling edge of ALE may be used to latch the state of these lines. |
| $\overline{R D}$ (Output, 3-state) | READ control: A low level on $\overline{R D}$ indicates the selected memory or $1 / O$ device is to be read and that the Data Bus is available for the data transfer, 3-stated during Hold and Halt modes and during RESET. |
| $\overline{W R}$ <br> (Output, 3-state) | WRITE control: A low level on $\overline{W R}$ indicates the data on the Data Bus is to be written into the selected memory or I/O location. Data is set up at the trailing edge of $\overline{W R}$, 3 -stated during Hold and Halt modes and during RESET. |
| READY <br> (Input) | If READY is high during a read or write cycle, it indicates that the memory or peripheral is ready to send or receive data. If READY is low, the cpu will wait an integral number of clock cycles for READY to go high before completing the read or write cycle READY must conform to specified setup and hold times. |
| HOLD <br> (Input) | HOLD indicates that another master is requesting the use of the address and data buses. The cpu, upon receiving the hold request, will relinquish the use of the bus as soon as the completion of the current bus transfer. Internal processing can continue. The processor can regain the bus only after the HOLD is removed. When the HOLD is acknowledged, the Address, Data, $\overline{R D}, \overline{W R}$, and $I O / \bar{M}$ lines are 3 -stated. And status of power down is controlled by HOLD. |
| HLDA (Output) | HOLD ACKNOWLEDGE: Indicates that the cpu has received the HOLD request and that it will relinquish the bus in the next clock cycle. HLDA goes low after the Hold request is removed. The cpu takes the bus one half clock cycle after HLDA goes low. |
| INTR (Input) | INTERRUPT REQUEST: Is used as a general purpose interrupt. It is sampled on during the next to the last clock cycle of an instruction and during Hold and Halt states. If it is active, the Program Counter (PC) will be inhibited from incrementing and an INTA will be issued. During this cycle a RESTART or CALL instruction can be inserted to jump to the interrupt service routine. The INTR is enabled and disabled by software. It is disabled by Reset and immediately after an interrupt is accepted. Power down mode is reset by INTR. |
| $\overline{\text { INTA }}$ (Output) | INTERRUPT ACKNOWLEDGE: Is used instead of (and has the same timing as) $\overline{R D}$ during the instruction cycle after an INTR is accepted. |
| RST 5.5 <br> RST 6.5 <br> RST 7.5 <br> (Input) | RESTART INTERRUPTS: These three inputs have the same timing as INTR except they cause an internal RESTART to be automatically inserted. <br> The priority of these interrupts is ordered as shown in Table 1. These interrupts have a higher priority than INTR. In addition, they may be individually masked out using the SIM instruction. Power down mode is reset by these interrupts. |
| TRAP (Input) | Trap interrupt is a nonmaskable RESTART interrupt. It is recognized at the same timing as INTR or RST 5.5-7.5. It is unaffected by any mask or Interrupt Disable. It has the highest priority of any interrupt. (See Table 1.) Power down mode is reset by input of TRAP. |


| Symbol | Function |
| :---: | :---: |
| RESETIN (Input) | Sets the Program Counter to zero and resets the Interrupt Enable and HLDA flip-flops and release power down mode. The data and address buses and the control lines are 3stated during RESET and because of the asy nchronous nature of RESET, the processor's internal registers and flags may be altered by RESET with unpredictable results. $\overline{R E S E T}$ $\overline{\mathrm{IN}}$ is a Schmitt-triggered input, allowing connection to an R-C network for power-on RESET delay. The cpu is held in the reset condition as long as $\overline{\text { RESET IN }}$ is applied. |
| RESET OUT (Output) | Indicated cpu is being reset. Can be used as a system reset. The signal is synchronized to the processor clock and lasts an integral number of clock periods. |
| $\begin{aligned} & X_{1}, X_{2} \\ & \text { (Input) } \end{aligned}$ | $X_{1}$ and $X_{2}$ are connected to a crystal to drive the internal clock generator. $X_{1}$ can also be an external clock input from a logic gate. The input frequency is divided by 2 to give the processor's internal operating frequency. |
| CLK <br> (Output) | Clock Output for use as a system clock. The period of CLK is twice the $X_{1}, X_{2}$ input period. |
| SID (Input) | Serial input data line. The data on this line is loaded into accumulator bit 7 whenever a RIM instruction is executed. |
| SOD <br> (Output) | Serial output data line. The output SOD is set or reset as specified by the SIM instruction. |
| $\mathrm{V}_{\text {cc }}$ | +5 volt supply. |
| GND | Ground Reference. |

Table 1 Interrupt Priority, Restart Address, and Sensitivity

| Name | Priority | Address Branched To (1) <br> When Interrupt Occurs | Type Trigger |
| :--- | :---: | :---: | :--- |
| TRAP | 1 | 24 H | Rising edge and high level until <br> sampled. |
| RST 7.5 | 2 | 3 H | Rising edge (latched). |
| RST 6.5 | 3 | 34 H | High level until sampled. |
| RST 5.5 | 4 | 2 H | High level until sampled. |
| INTR | 5 | (2) | High level until sampled. |

Notes: (1) The processor pushes the F'C on the stack before branching to the indicated address.
(2) The address branched to depends on the instruction provided to the cpu when the interrupt is acknowledged.

## FUNCTIONAL DESCRIPTION

The MSM80C85AH is a complete 8-bit parallel central processor. It is designed with silicon gate C-MOS tech nology and requires a single +5 volt supply. Its basic clock speed is 5 MHz , thus improving on the present MSM80C85A's performance with higher system speed and power down mode. Also it is designed to fit into a minimum system of two IC's: The cpu (MSM80C85AH), and a RAM/10 (MSM81C55-5)

The MSM80C85A-2 has twelve addressable 8-bit register pairs. Six others can be used interchangeably as 8 -bit registers or a 16 -bit register pairs. The MSM-80C85A-2 register set is as follows:

| Mnemonic | Register | Contents |
| :--- | :--- | :--- |
| ACC or $A$ | Accumulator | 8-bits |
| PC | Program Counter | 16-bit address |
| BC, DE, HL | General-Purpose <br> Registers; <br> data pointer (HL) | 16-bit $\times 6$ or <br> 16 -bits $\times 3$ |
| SP | Stack Pointer | 16-bit address |
| Flags or F | Flag Register | 5 flags (8-bit space) |

The MSM80C85AH uses a multiplexed Data Bus. The address is split between the higher 8-bit Address Bus and the lower 8-bit Address/Data Bus. During the first $T$ state (clock cycle) of a machine cycle the low order address is sent out on the Address/Data Bus. These lower 8 -bits may be latched externally by the Address Latch Enable signal (ALE). During the rest of the machine cycle the data bus is used for memory or I/O data.

The MSM80C85AH provides $\overline{R D}, \overline{W R}, S_{0}, S_{1}$ and $10 / \bar{M}$ signals for bus control. An Interrupt Acknowledge signal ( $\overline{\mathrm{NTA}}$ ) is also provided. Hold and all Interrupts are synchronized with the processor's internal clock. The MSM80C85AH also provides Serial Input Data (SID) and Serial Output Data (SOD) lines for a simple serial interface.

In addition to these features, the MSM80C85AH has three maskable, vector interrupt pins, one nonmaskable TRAP interrupt and power down mode with HALT and HOLD.

## INTERRUPT AND SERIAL I/O

The MSM80C85AH has 5 interrupt inputs: INTR, RST 5.5, RST 6.5, RST 7.5, and TRAP. INTR is identical in function to the 8080A INT. Each of the three RESTART inputs, $5.5,6.5$, and 7.5 , has a programmable mask. TRAP is also a RESTART interrupt but it is nonmaskable.

The three maskable interrupts cause the internal
execution of RESTART (saving the program counter in the stack and branching to the RESTART address) if the interrupts are enabled and if the interrupt mask is not set. The nonmaskable TRAP causes the internal execution of a RESTART vector independent of the state of the interrupt enable or masks. (See Table 1.)

There are two different types of inputs in the restart interrupts. RST 5.5 and RST 6.5 are high level-sensitive like INTR (and INT on the 8080A) and are recognized with the same timing as INTR. RST 7.5 is rising edge-sensitive.

For RST 7.5, only a pulse is required to set an internal flip-flop which generates the internal interrupt request. The RST 7.5 request flip-flop remains set until the request is serviced. Then it is reset automatically. This flip-flop may also be reset by using the SIM instruction or by issuing a RESET IN to the MSM80C85AH The RST 7.5 internal flip-flop will be set by a pulse on the RST 7.5 pin even when the RST 7.5 interrupt is masked out.

The interrupts are arranged in a flixed priority that determines which interrupt is to be recognized if more than one is pending, as follows: TRAP-highest priority, RST 7.5, RST 6.5, RST 5.5, INTR-lowest priority. This priority scheme does not take into account the priority of a routine that was started by a higher priority interrupt. RST 5.5 can interrupt an RST 7.5 routine if the interrupts are re-enabled before the end of the RST 7.5 routine.

The TRAP interrupt is useful for catastrophic events such as power failure or bus error. The TRAP input is recognized just as any other interrupt but has the highest priority. It is not affected by any flag or mask. The TRAP input is both edge and level sensitive. The TRAP input must go high and remain high until it is acknowledged. It will not be recognized again until it goes low, then high again. This avoids any false triggering due to noise or logic glitches. Figure 3 illustrates the TRAP interrupt request circuitry within the MSM80C85AH Note that the servicing of any interrupt (TRAP, RST 7.5, RST 6.5, RST 5.5, INTR) disables all future interrupts (except TRAPs) until an EI instruction is executed.

The TRAP interrupt is special in that it disables interrupts, but preserves the previous interrupt enable status. Performing the first RIM instruction following a TRAP interrupt allows you to determine whether interrupts were enabled or disabled prior to the TRAP. All subsequent RIM instructions provide current interrupt enable status. Performing a RIM instruction following INTR or RST 5.5-7.5 will provide current Interrupt Enable status, revealing that Interrupts are disabled.

The serial I/O system is also controlled by the RIM and SIM instructions. SID is read by RIM, and SIM sets the SOD data.


Figure 3 Trap and RESET IN Circuit

## DRIVING THE $X_{1}$ and $X_{2}$ INPUTS

You may drive the clock inputs of the MSM80C-85A-2 with a crystal, or an external clock source. The driving frequency must be at least 1 MHz , and must be twice the desired internal clock frequency; hence, the MSM80C85AH is operated with a 6 MHz crystal (for 3 MHz clockt. If a crystal is used, it must have the following characteristics:

Parallel resonance at twice the clock frequency desired
$C_{L}$ (load capacitance) $\leq 30 \mathrm{pF}$
$\mathrm{C}_{\mathrm{S}}$ (shunt capacitance) $\leq 7 \mathrm{pF}$
$R_{S}$ (equivalent shunt resistance) $\leq 75$ ohms

Drive level: 10 mW
Frequency tolerance: $\pm .005 \%$ (suggested)
Note the use of the capacitors between $X_{1}, X_{2}$ and ground. These capacitors are required to assure oscillator startup at the correct frequency.

Figure 4 shows the recommended clock driver circuits. Note in $B$ that a pullup resistor is required to assure that the high level voltage of the input is at least 4 V .

For driving frequencies up to and including 6 MHz you may supply the driving signal to $X_{1}$ and leave $X_{2}$ open-circuited (Figure 4B). To prevent self-oscillation of the MSM80C85AH, be sure that $X_{2}$ is not coupled back to $X_{1}$ through the driving circuit.
A. Quartz Crystal Clock Driver


33pF Capacitor required for crystal frequency 10 to 6.25 MHz .
50pF Capacitor required for crystal frequency 6.25 to 4 MHz .
100pF Capacitor required for crystal frequency $<4 \mathrm{MHz}$.
B. $\quad \mathbf{1 - 1 0} \mathrm{MHz}$ Input Frequency External Clock Drive Circuit


[^2]
## BASIC SYSTEM TIMING

The MSM80C85AH has a multiplexed Data Bus. ALE is used as a strobe to sample the lower 8-bits of address on the Data Bus. Figure 5 shows an instruction fetch, memory read and I/O write cycle (as would occur during processing of the OUT instruction). Note that during the I/O write and read cycle that the I/O port address is copied on both the upper and lower half of the address.

There are seven possible types of machine cycles. Which of these seven takes place is defined by the status of the three status lines $\left(10 / \bar{M}, S_{1}, S_{0}\right)$ and the
three control signals ( $\overline{R D}, \overline{W R}$, and INTA). (See Table 2.) The status line can be used as advanced controls (for device selection, for example), since they become active at the $T_{1}$ state, at the outset of each machine cycle. Control lines $\overline{R D}$ and $\overline{W R}$ become active later, at the time when the transfer of data is to take place, so are used as command lines.

A machine cycle normally consists of three $T$ states, with the exception of OPCODE FETCH, which normally has either four or six $T$ states (unless WAIT or HOLD states are forced by the receipt of READY or HOLD inputs). Any $T$ state must be one of ten possible states, shown in Table 3.

Table 2 MSM80C85AH Machine Cycle Chart


Table 3 MSM80C85A-2 Machine State Chart

| Machine State | Status \& Buses |  |  |  | Control |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{S}_{1}, \mathrm{~S}_{0}$ | $10 / \bar{M}$ | $A_{8}-A_{15}$ | $A D_{0}-A D_{7}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $\overline{\text { INTA }}$ | ALE |
| $\mathrm{T}_{1}$ | X | x | X | x | 1 | 1 | $1^{(1)}$ |
| $\mathrm{T}_{2}$ | X | X | X | X | X | X | 0 |
| TWAIT | X | X | X | X | x | X | 0 |
| $\mathrm{T}_{3}$ | X | X | X | X | X | X | 0 |
| T4 | 1 | 0 (2) | X | TS | 1 | 1 | 0 |
| $\mathrm{T}_{5}$ | 1 | 0 (2) | X | TS | 1 | 1 | 0 |
| T6 | 1 | 0 (2) | X | TS | 1 | 1 | 0 |
| Treset | X | TS | TS | TS | TS | 1 | 0 |
| THALT | 0 | TS | TS | TS | TS | 1 | 0 |
| THOLD | X | TS | TS | TS | TS | 1 | 0 |

$$
0=\text { Logic " } 0 \text { " }
$$

$1=$ Logic " 1 "
TS = High Impedance
X = Unspecified
Notes: (1) ALE not generated during 2nd and 3rd machine cycles of DAD instruction.
(2) $10 / \bar{M}=1$ during $T_{4} \sim T_{6}$ of INA machine cycle.


Figure 5. MSM80C85AH Basic System Timing

## POWER DOWN Mode

The MSM80C85AH is compatible with the MSM80C85A in function and POWER DOWN mode. This reduces power consumption further.

There are two methods available for starting this POWER DOWN mode. One is through software control by using the HALT command and the other is under hardware control by using the pin HOLD. This mode is released by the HOLD, RESET, and interrupt pins (TRAP, RST7.5, RST6.5, RST5.5, or INTR). (See Table 4.)

Since the sequence of HALT, HOLD, RESET, and INTERRUPT is compatible with MSM80C85A, every the POWER DOWN mode can be used with no special attention.

Table 4 POWER DOWN Mode Releasing Method

| Start by means of <br> HALT command | Released by using pins RESET <br> and INTERRUPT (not by pin <br> HOLD) |
| :--- | :--- |
| Start by means of <br> HOLD pin | Released by using RESET and <br> HOLD pins (not by interrupt <br> pins) |

(1) Start by means of HALT command
(See Figures 6 and 7.)
The POWER DOWN mode can be started by executing the HALT command.
At this time, the system is put into the HOLD status and therefore the POWER DOWN mode cannot be released even when the HOLD is released later.
In this case, the POWER DOWN mode can be released by means of the RESET or interrupt.
(2) Start by means of HOLD pin (See Figure 8.)

During the execution of commands other than the HALT, the POWER DOWN mode is started when the system is put into HOLD status by means of the HOLD pin.
Since no interrupt works during the execution of the HOLD, the POWER DOWN mode cannot be released by means of interrupt pins.
In this case, the POWER DOWN mode can be released either by means of the RESET pin or by releasing the HOLD status by means of HOLD pin.


Figure 6. Started by HALT and Released by RESET IN


E

Figure 7. Started by HALT and Released by RST5.5


Figure 8. Started and Released by HOLD

## - CPU•MSM80C85AHRS/GS/JS

## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Condition | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM80C85AHRS | MSM80C85AHGS | MSM80C85AHJS |  |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | With respect to GND | $-0.5 \sim+7$ |  |  | V |
| Input Voltage | VIN |  | $-0.5 \sim V_{\text {CC }}+0.5$ |  |  | V |
| Output Voltage | V OUT |  | $-0.5 \sim v_{\text {CC }}+0.5$ |  |  | V |
| Storage Temperature | Tstg |  | $-55 \sim+150$ |  |  | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $P_{\text {D }}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | 1.0 | 0.7 | 1.0 | W |

## OPERATING RANGE

| Parameter | Symbol | Limits | Unit |
| :---: | :---: | :---: | :---: |
| Power Supply Voltage | $V_{\text {CC }}$ | $3 \sim 6$ | $\vee$ |
| Operating Temperature | Top | $-40 \sim+85$ | ${ }^{\circ}$ |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{Cc}}$ | 4.5 | 5 | 5.5 | V |
| Operating Temperature | TOP | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| '"L' Input Voltage | $V_{\text {IL }}$ | -0.3 |  | +0.8 | V |
| 'H' Output Voltage | $V_{\text {IH }}$ | 2.2 |  | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |
| "L", RESET IN | VILR | -0.3 |  | +0.8 | V |
| " H " ${ }^{\text {RESET Input Voltage }}$ | VIHR | 3.0 |  | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |

## D.C. CHARACTERISTICS

| Parameter | Symbol | Conditions |  | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L' Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | ${ }^{\prime} \mathrm{OL}=2.5 \mathrm{~mA}$ |  |  |  | 0.4 | V |
| "H" Output Voltage | VOH | ${ }^{1} \mathrm{OH}=-2.5 \mathrm{~mA}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \sim 5.5 \mathrm{~V} \\ & \mathrm{Ta}=-40^{\circ} \mathrm{C} \sim+85^{\circ} \mathrm{C} \end{aligned}$ | 3.0 |  |  | V |
|  |  | ${ }^{1} \mathrm{OH}=-100 \mu \mathrm{~A}$ |  | $\begin{array}{\|l\|} \hline \mathrm{VCC} \\ -0.4 \\ \hline \end{array}$ |  |  | V |
| Input Leak Current | ${ }^{\prime} \mathrm{L}$ I | $0 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Output Leak Current | ILO | $0 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}}$ |  | $-10$ |  | 10 | $\mu \mathrm{A}$ |
| Operating Supply Current | ${ }^{1} \mathrm{CC}$ | $\begin{aligned} & \text { Tcyc }=200 \mathrm{~ns} \\ & C_{L}=0 \mathrm{pF} \text { at reset } \end{aligned}$ |  |  | 10 | 20 | mA |
|  |  | $\text { Tcyc }=200 \mathrm{~ns}$ $C_{L}=0 p F \text { at power }$ down mode |  |  | 5 | 10 | mA |

## A.C. CHARACTERISTICS

| Parameter | Symbol | Condition | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CLK Cycle Period | ${ }^{t} \mathrm{CrC}$ |  | 200 | 2000 | ns |
| CLK Low Time | $t_{1}$ | $\begin{aligned} & { }^{t} C Y C=200 \mathrm{~ns} \\ & C_{L}=150 p \mathrm{~F} \end{aligned}$ | 40 |  | ns |
| CLK High Time | $\mathrm{t}_{2}$ |  | 70 |  | ns |
| CLK Rise and Fall Time | $t_{r}, t_{f}$ |  |  | 30 | ns |
| $\mathrm{X}_{1}$ Rising to CLK Rising | ${ }^{1} \times K$ R |  | 25 | 120 | ns |
| $X_{1}$ Rising to CKK Falling | ${ }^{\text {t }} \times$ KF |  | 30 | 150 | ns |
| $A_{s} \sim_{1 s}$ Valid to Leading Edge of Control (1) | ${ }^{\text {t }}$ AC |  | 115 |  | ns |
| $A_{0} \sim$, Valid to Leading Edge of Control | ${ }^{1} \mathrm{ACL}$ |  | 115 |  | ns |
| $A_{0} \sim_{1 s}$ Valid Data In | ${ }^{t} A D$ |  |  | 350 | ns |
| Address Float After Leading Edge of RD INTA | ${ }^{\text {t }}$ AFR |  |  | 0 | ns |
| $A_{B} \sim_{1 s}$ Valid Before Trailing Edge of ALE (1) | ${ }^{\text {t }}$ AL |  | 50 |  | ns |
| $A_{0} \sim$, Valid Before Trailing Edge of ALE | ${ }^{\text {t } A L L}$ |  | 50 |  | ns |
| READY Valid from Address Valid | ${ }^{\text {t } A R Y ~}$ |  |  | 100 | ns |
| Address ( $A_{B} \sim_{1 s}$ ) Valid After Control | ${ }^{t} \mathrm{CA}$ |  | 60. |  | ns |
| Width of Control Law (RD, WR, INTA) | ${ }^{t} \mathrm{CC}$ |  | 230 |  | ns |
| Trailing Edge of Control to Leading Edge of ALE | ${ }^{t} \mathrm{CL}$ |  | 25 |  | ns |
| Data Valid to Trailing Edge of WR | ${ }^{\text {t }} \mathrm{DW}$ |  | 230 |  | ns |
| HLDA to Bus Enable | ${ }^{\text {t }}$ HABE |  |  | 150 | ns |
| Bus Float After HLDA | ${ }^{\text {t HABF }}$ |  |  | 150 | ns |
| HLDA Valid to Traiting Edge of CLK | ${ }^{\text {t HACK }}$ |  | 40 |  | ns |
| HOLD Hold Time | ${ }^{\text {t }} \mathrm{HDH}$ |  | 0 |  | ns |
| HOLD Step Up Time to Trailing Edge of CLK | ${ }^{\text {t }} \mathrm{HDS}$ |  | 120 |  | ns |
| INTR Hold Time | tiNH |  | 0 |  | ns |
| INTR, RST and TRAP Setup Time to Falling Edge of CLK | tins |  | 150 |  | ns |
| Address Hold Time After ALE | ${ }^{\text {t }}$ LA |  | 50 |  | ns |
| Trailing Edge of ALE to Leading Edge of Control | ${ }_{\text {t }} \mathrm{C}$ |  | 60 |  | ns |
| ALE Low During CLK High | ${ }^{\text {t LCK }}$ |  | 50 |  | ns |
| ALE to Valid Data During Read | ${ }^{\text {t L }}$ L ${ }^{\text {L }}$ |  |  | 270 | ns |
| ALE to Valid Data During Write | ${ }^{\text {t L DW }}$ |  |  | 140 | ns |
| ALE Width | ${ }^{\text {t }}$ LL |  | 80 |  | ns |
| ALE to READY Stable | ${ }_{\text {t LRY }}$ |  |  | 30 | ns |
| Trailing Edge of RD to Re-enabling of Address | ${ }^{\text {t RAE }}$ |  | 90 |  | ns |
| RD (or INTA) to Valid Data | ${ }^{\text {t R D }}$ |  |  | 150 | ns |
| Control Trailing Edge to Leading Edge of Next Control | ${ }^{\text {tr }}$ V |  | 220 |  | ns |
| Data Hold Time After RD INTA (7) | ${ }^{\text {t }} \mathrm{RDH}$ |  | 0 |  | ns |
| READY Hold Time | ${ }^{\text {t } R Y H}$ |  | 0 |  | ns |
| READY Setup Time to Leading Edge of CLK | ${ }^{\text {tRYS }}$ |  | 100 |  | ns |
| Data Valid After Trailing Edge of WR | ${ }^{\text {tw }}$ ( |  | 60 |  | ns |
| LEADING Edge of WR to Data Valid | ${ }^{\text {tWDL }}$ |  |  | 20 | ns |

Notes: (1) $A_{8} \sim A_{15}$ address Specs apply to $10 / M, S_{0}$, and $S_{1}$ except $A_{8} \sim A_{15}$ are undefined during $T_{4} \sim T_{8}$ of $O F$ cycle whereas $10 / \mathrm{M}, \mathrm{S}_{0}$, and $\mathrm{S}_{1}$ are stable.
(2) Test conditions: ${ }^{\mathrm{t}} \mathrm{CYC}=200 \mathrm{~ns} \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$
(3) For all output timing where $C_{L}=150 \mathrm{pF}$ use the following correction factors:

25pF $\leq C_{L}<150 \mathrm{pF}:-0.10 \mathrm{~ns} / \mathrm{pF}$
$150 \mathrm{pF}<\mathrm{C}_{\mathrm{L}} \leq 300 \mathrm{pF}:+0.30 \mathrm{~ns} / \mathrm{pF}$
(4) Output timings are measured with purely capacitive load.
(5) All timings are measured at output voltage $\mathrm{V}_{\mathrm{L}}=0.8 \mathrm{~V}, \mathrm{~V}_{H}=2.2 \mathrm{~V}$, and 1.5 V with 10 ns rise and fall time on inputs.
(6) To calculate timing specifications at other values of ${ }^{\mathrm{t}} \mathrm{CYC}$ use Table 7.
(7) Data hold time is guaranteed under all loading conditions.

## Input Waveform for A.C. Tests:



Table 7 Bus Timing Specification as a TCYC Dependent
$\left(\mathrm{Ta}=-40^{\circ} \mathrm{C} \sim+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \sim 5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}\right)$

|  | MSM80C85A-2 |  |  |
| :---: | :---: | :---: | :---: |
| ${ }^{t} A L$ | - | (1/2)T-50 | MIN |
| ${ }_{\text {t }}$ L | - | (1/2) T - 50 | MIN |
| ${ }^{\text {t L L }}$ | - | (1/2)T - 20 | MIN |
| ${ }^{\text {t LCK }}$ | - | (1/2)T - 50 | MIN |
| ${ }_{\text {t }}$ C | - | (1/2)T-40 | MIN |
| ${ }^{t} A D$ | - | $(5 / 2+N) T-150$ | MAX |
| ${ }^{\text {t }} \mathrm{RD}$ | - | $(3 / 2+N) T-150$ | MAX |
| ${ }^{\text {t RAE }}$ | - | (1/2)T-10 | MIN |
| ${ }^{\text {t }}$ CA | - | (1/2)T-40 | MIN |
| ${ }^{\text {t }}$ WW | - | $(3 / 2+N) T-70$ | MIN |
| ${ }^{\text {t }}$ WD | - | (1/2) T-40 | MIN |
| ${ }^{t} \mathrm{CC}$ | - | $(3 / 2+N) T-70$ | MIN |
| ${ }^{t} \mathrm{CL}$ | - | (1/2) T - 75 | MIN |
| ${ }^{\text {t ARY }}$ | - | (3/2) T-200 | MAX |
| ${ }^{\text {t HACK }}$ | - | (1/2) T - 60 | MIN |
| ${ }^{\text {t HABF }}$ | - | $(1 / 2) T+50$ | MAX |
| ${ }^{\text {t HABE }}$ | - | $(1 / 2) T+50$ | MAX |
| ${ }^{t} A C$ | - | (2/2) T-85 | MIN |
| $\mathrm{t}_{1}$ | - | (1/2)T-60 | MIN |
| $\mathrm{t}_{2}$ | - | (1/2)T-30 | MIN |
| ${ }^{t} \mathrm{t}_{\mathrm{V}} \mathrm{V}$ | - | (3/2) T-80 | MIN |
| t LDR | - | $(2+N) T-130$ | MAX |

Note: $N$ is equal to the total WAIT states.
$T=t_{C Y C}$


Figure 6 Clock Timing Waveform

## READ OPERATION



## WRITE OPERATION



Read operation with Wait Cycle (Typical) -
same READY timing applies to WRITE operation


Note: READY must remain stable during setup and hold times.

Figure 7 MSM80C85AH Bus Timing, With and Without Wait

## HOLD OPERATION



Figure 8 MSM80C85AH Hold Timing


Note: (1) $10 / \bar{M}$ is also floating during this time.

Figure 9 MSM80C85AH Interrupt and Hold Timing

Table 8 Instruction Set Summary

| Mnemonic | Description | Instruction Code (1) |  |  |  |  |  |  |  | Clock (2) <br> Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| MOVE, LOAD, AND STORE |  |  |  |  |  |  |  |  |  |  |
| MOVr1 r2 | Move register to register | 0 | 1 | D | D | D | S | S | S | 4 |
| MOV M r | Move register to memory | 0 | 1 | 1 | 1 | 0 | S | S | S | 7 |
| MOV r M | Move memory to register | 0 | 1 | D | D | D | 1 | 1 | 0 | 7 |
| MVI r | Move immediate register | 0 | 0 | D | D | D | 1 | 1 | 0 | 7 |
| MVI M | Move immediate memory | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 10 |
| LXI B | Load immediate register Pair B \& C | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 10 |
| LXI D | Load immediate register Pair D \& E | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 10 |
| LXI H | Load immediate register Pair H \& L | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 10 |
| LXISP | Load immediate stack pointer | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 10 |
| STAX B | Store A indirect | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 7 |
| STAX D | Store A indirect | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 7 |
| LDAX B | Load A indirect | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 7 |
| LDAX D | Load A indirect | 0 | 0 | 0 | 1. | 1 | 0 | 1 | 0 | 7 |
| STA | Store A direct | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 13 |
| LDA | Load A direct | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 13 |
| SHLD | Store H \& L direct | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 16 |
| LHLD | Load H \& L direct | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 16 |
| XCHG | Exchange D \& E H \& L registers | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 4 |
| STACK OPS |  |  |  |  |  |  |  |  |  |  |
| PUSH B | Push register Pair B \& C on stack | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 12 |
| PUSH D | Push register Pair D \& E on stack | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 12 |
| PUSH H | Push register Pair H \& L on stack | 1 | 1 | 1. | 0 | 0 | 1 | 0 | 1 | 12 |
| PUSH PSW | Push A and Flags on stack | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 12 |
| POP B | Pop register Pair B \& C off stack | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 10 |
| POP D | Pop register Pair D \& E off stack | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 10 |
| POP H | Pop register Pair H \& L off stack | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 10 |
| POP PSW | Pop A and Flags off stack | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 10 |
| XTHL | Exchange top of stack H \& L | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 16 |
| SPHL | H\&L to stack pointer | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 6 |
| JUMP |  |  |  |  |  |  |  |  |  |  |
| JMP | Jump unconditional | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 10 |
| JC | Jump on carry | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 7/10 |
| JNC | Jump on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 7/10 |
| JZ | Jump on zero | 1 | 1 | 0 | 0 | 1 | 0 | 1. | 0 | 7/10 |
| JNZ | Jump on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 7/10 |
| JP | Jump on positive | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 7/10 |
| JM | Jump on minus | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 7/10 |
| JPE | Jump on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 7/10 |
| JPO | Jump on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 7/10 |
| PCHL | H\& L to program counter | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 6 |
| CALL |  |  |  |  |  |  |  |  |  |  |
| CALL | Call unconditional | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 18 |
| CC | Call on carry | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 9/18 |
| CNC | Call on no carry | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 9/18 |
| CZ | Call on zero | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 9/18 |
| CNZ | Call on no zero | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 9/18 |
| CP | Call on positive | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 9/18 |
| CM | Call on minus | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 9/18 |
| CPE | Call on parity even | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 9/18 |
| CPO | Call on parity odd | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 9/18 |

Table 8 Instruction Set Summary cont'd

| Mnemonic | Description | Instruction Code(1) |  |  |  |  |  |  |  | Clock(2) <br> Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| RETURN |  |  |  |  |  |  |  |  |  |  |
| RET | Return | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
| RC | Return on carry | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 6/12 |
| RNC | Return on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 6/12 |
| RZ | Return on zero | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 6/12 |
| RNZ | Return on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 6/12 |
| RP | Return on positive | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 6/12 |
| RM | Return on minus | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 6/12 |
| RPE | Return on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 6/12 |
| RPO | Return on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 6/12 |
| RESTART RST | Restart | 1 | 1 | A | A | A | 1 | 1 | 1 | 12 |
| INPUT/OUTPUT |  |  |  |  |  |  |  |  |  |  |
| IN | Input | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 10 |
| OUT | Output | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 10 |
| INCREMENT AND DECREMENT |  |  |  |  |  |  |  |  |  |  |
| INR r | Increment register | 0 | 0 | D | D | D | 1 | 0 | 0 | 4 |
| DCR r | Decrement register | 0 | 0 | D | D | D | 1 | 0 | 1 | 4 |
| INR M | Increment memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 10 |
| DCR M | Decrement memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 10 |
| INX B | Increment B \& C registers | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 6 |
| INX D | Increment D \& E registers | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 6 |
| INX H | Increment H \& L registers | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 6 |
| INX SP | Increment stack pointer | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 6 |
| DCX B | Decrement B \& C | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 6 |
| DCX D | Decrement D \& E | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 6 |
| DCX H | Decrement H \& L | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 6 |
| DCX SP | Decrement stack pointer | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 6 |
| ADD |  |  |  |  |  |  |  |  |  |  |
| ADD r | Add register to A | 1 | 0 | 0 | 0 | 0 | S | S | S | 4 |
| ADC r | Add register to A with carry | 1 | 0 | 0 | 0 | 1 | S | S | S | 4 |
| ADD M | Add memory to $A$ | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 7. |
| ADC M | Add memory to A with carry | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 7 |
| ADI | Add immediate to $A$ | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 7 |
| ACI | Add immediate to A with carry | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 7 |
| DAD B | Add B \& C to H \& L | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
| DAD D | Add D \& E to H \& L | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 10 |
| DAD H | Add H\&L to H \& L | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 10 |
| DAD SP | Add stack pointer to H \& L | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 10 |
| SUBTRACT |  |  |  |  |  |  |  |  |  |  |
| SUB r | Subtract register from A | 1 | 0 | 0 | 1 | 0 | S | S | S | 4 |
| SBB r | Subtract register from'A with borrow | 1 | 0 | 0 | 1 | 1 | S | S | S | 4 |
| SUB M | Subtract memory from A | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| SBB M | Subtract memory from A with borrow | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |
| SUI | Subtract immediate from A | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| SBI | Subtract immediate from A with borrow | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |

Table 8 Instruction Set Summary cont'd

| Mnemonic | Description | Instruction Code(1) |  |  |  |  |  |  |  | Clock(2) <br> Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| LOGICAL |  |  |  |  |  |  |  |  |  |  |
| ANA r | And register with A | 1 | 0 | 1 | 0 | 0 | S | S | S | 4 |
| XRA $r$ | Exclusive Or register with A | 1 | 0 | 1 | 0 | 1 | S | S | S | 4 |
| ORA r | Or register with A | 1 | 0 | 1 | 1 | 0 | S | S | S | 4 |
| CMP r | Compare register with $A$ | 1 | 0 | 1 | 1 | 1 | S | S | S | 4 |
| ANA M | And memory with A | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 7 |
| XRA M | Exclusive Or Memory with A | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |
| ORA M | Or memory with A | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 7 |
| CMP M | Compare memory with A | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 7 |
| ANI | And immediate with A | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 7 |
| XRI | Exclusive Or immediate with A | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |
| ORI | Or immediate with A | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 7 |
| CPI | Compare immediate with $A$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 7 |
| ROTATE |  |  |  |  |  |  |  |  |  |  |
| RLC | Rotate A left | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 4 |
| RRC | Rotate A right | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 4 |
| RAL | Rotate A left through carry | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 4 |
| RAR | Rotate A right through carry | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 4 |
| SPECIALS |  |  |  |  |  |  |  |  |  |  |
| CMA | Complement A | 0 | 0 | 1 | 0 | 1 | 1 | 1 | , | 4 |
| STC | Set carry | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 4 |
| CMC | Complement carry | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 4 |
| DAA | Decimal adjust A | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 4 |
| CONTROL |  |  |  |  |  |  |  |  |  |  |
| EI | Enable Interrupts | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 4 |
| DI | Disable Interrupts | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 4 |
| NOP | No-operation | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 4 |
| HLT | Halt (Power down) | 0 | 1 | 1 | 1 | 0 | 1 | 1. | 0 | 5 |
| RIM | Read Interrupt Mask | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 4 |
| SIM | Set Interrupt Mask | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 4 |

Notes: (1) DDD or SSS. B 000. C 001. D 010. E 011. H 100. L 101. Memory 110. A 111.
(2) Two possible cycle times, (6/12) indicate instruction cycles dependent on condition flags.

Precautions for operation
(1) When the oscillation circuit is to be used, keep the RES innut !ow until the oscillation is sufficiently stabilized after power is turned on.
(2) When power is turned on, the output level (SOD etc.) is irregular before the equipment is reset.

## OIEI semiconductor

## MSM80C86ARS/GS/JS <br> MSM80C86A-2RS/GS/JS

## 16-BIT CMOS MICROPROCESSOR

## GENERAL DESCRIPTION

The MSM80C86A/MSM80C86A-2 are complete 16 -bit CPUs implemented in Silicon Gate CMOS technology. They are designed with same processing speed as the NMOS 8086/8086-2 but have considerably less power consumption. They are directly compatible with MSM80C88A/MSM80C88A-2 software and MSM80C85A/ MSM80C85A-2 hardware and peripherals.

## FEATURES

- 1 Mbyte Direct Addressable Memory Space
- Internal 14 Word by 16-bit Register Set
- 24 Operand Addressing Modes
- Bit, Byte, Word and String Operations

CIRCUIT CONFIGURATION

- 8 and 16-bit Signed and Unsigned Arithmetic Operation
- From DC to 5 MHz Clock Rate (MSM80C86A)
- From DC to 8 MHz Clock Rate (MSM80C86A-2)
- Low Power Dissipation $10 \mathrm{~mA} / \mathrm{MHz}$
- Bus Hold Circuitry Eliminates Pull-Up Resistors
- 40 pin Plastic DIP (DIP40-P-600)
- 44 pin PLCC(QFJ44-P-S650)
- 56 pin(L)-V Plastic QFP (QFP56-P-910-VK)


PIN CONFIGURATION


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MSM80C86ARS MSM80C86A-2RS | MSM80C86AGS MSM80C86A-2GS | MSM80C86AJS MSM80C86A-2JS |  |  |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.5 ~ +7 |  |  | V | With respect to GND |
| Input Voltage | $V_{\text {IN }}$ | -0.5 ~ $\mathrm{V}_{\mathrm{CC}}+0.5$ |  |  | V |  |
| Output Voltage | V OUT | $-0.5 \sim V_{C C}+0.5$ |  |  | $\checkmark$ |  |
| Storage Temperature | Tstg | -65~+150 |  |  | ${ }^{\circ} \mathrm{C}$ | - |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 1.0 | 0.7 |  | W | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ |

## OPERATING RANGE

| Parameter | Limits | Unit |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM80C86A-2 |  |
| Power Supply Voltage |  | $V_{\text {CC }}$ | $3 \sim 6$ | $4.75 \sim 5.25$ |
| Operating Temperature | TOP | $-40 \sim+85$ | $0 \sim+70$ | ${ }^{\circ}$ |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | MSM80C86A |  |  | MSM80C86A-2 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5.0 | 5.5 | 4.75 | 5.0 | 5.25 | $\checkmark$ |
| Operating Temperature | TOP | -40 | +25 | +85 | 0 | +25 | +70 | ${ }^{\circ} \mathrm{C}$ |
| '"L" Input Voltage | $V_{\text {IL }}$ | -0.5 |  | +0.8 | -0.5 |  | +0.8 | V |
| " H " Input Voltage | $\mathrm{V}_{\text {H }}{ }^{(* * 1)}$ | $\mathrm{v}_{\mathrm{CC}}{ }^{-0.8}$ |  | $\mathrm{V}_{\mathrm{CC}}+0.5$ | ${ }^{\mathrm{cc}^{-}-0.8}$ |  | $V_{\mathrm{CC}}+0.5$ | $\checkmark$ |
|  |  | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+0.5$ | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+0.5$ | $\checkmark$ |

[^3]
## DC CHARACTERISTICS

(MSM80C86A: $V_{C C}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{Ta}=-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ )
(MSM80C86A-2: $\mathrm{V}_{\mathrm{CC}}=4.75$ to $5.25 \mathrm{~V}, \mathrm{Ta}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Parameter | Symbol | MIN | TYP | MAX | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L' Output Voltage | VOL |  |  | 0.4 | V | $1 \mathrm{OL}=2.5 \mathrm{~mA}$ |
| " H " Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 3.0 |  |  | V | $1 \mathrm{OH}=-2.5 \mathrm{~mA}$ |
|  |  | VCC-0.4 |  |  |  | $1 \mathrm{OH}=-100 \mu \mathrm{~A}$ |
| Input Leak Current | ILI | -1.0 |  | +1.0 | $\mu \mathrm{A}$ | $0<\mathrm{V}_{\mathrm{I}}<\mathrm{V}_{\text {c }}$ |
| Output Leak Current | ILO | -10 |  | +10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\text {cc }}$ or GND |
| Input Leakage Current (Bus Hold Low) | IBHL | 50 |  | 400 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=0.8 \mathrm{~V}$ |
| Input Leakage Current (Bus Hold High) | IBHH | -50 |  | -400 | $\mu \mathrm{A}$ | $\begin{gathered} \mathrm{V}_{\mathrm{IN}}=3.0 \mathrm{~V} \\ { }_{4} \end{gathered}$ |
| Bus Hold Low Overdrive | IBHLO |  |  | 600 | $\mu \mathrm{A}$ | *5 |
| Bus Hold High Overdrive | $\mathrm{I}_{\mathrm{BHHO}}$ |  |  | -600 | $\mu \mathrm{A}$ | *6 |
| Operating Power Supply Current | ICC |  |  | 10 | $\mathrm{mA} / \mathrm{MHz}$ | $\begin{aligned} & V_{I L}=G N D \\ & V_{I H}=V_{C C} \end{aligned}$ |
| Standby Power Supply Current | Iccs |  |  | 500 | $\mu \mathrm{A}$ | $V_{C C}=5.5 \mathrm{~V}$ <br> Outputs Unloaded $V_{\text {IN }}=V_{C C}$ or GND |
| Input Capacitance | $\mathrm{C}_{\text {in }}$ |  |  | 10 | pF | * 7 |
| Output Capacitance | Cout |  |  | 15 | pF | * 7 |
| I/O Capacitance | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  |  | 20 | pF | *7 |

*3 Test condition is to lower $V_{I N}$ to GND and then raise $V_{I N}$ to 0.8 V on pins 2-16, and 35-39
*4 Test condition is to raise $V_{I N}$ to $V_{C C}$ and then lower $V_{I N}$ to 3.0 V on pins 2-16, 26-32, and 34-39.
*5 An external driver must source at least IBHLO to switch this node from LOW to HIGH.
*6 An external driver must sink at least I ${ }_{B H H O}$ to switch this node from HIGH to LOW.
*7 Test Conditions: a) Freq $=1 \mathrm{MHz}$.
b) Ummeasured Pins at GND.
c) $V_{I N}$ at 5.0 V or GND.

## A.C. CHARACTERISTICS

(MSM80C86A: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{Ta}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ) (MSM80C86A-2: $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ to $5.25 \mathrm{~V}, \mathrm{Ta}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ )
Minimum Mode System
Timing Requirements

| Parameter | Symbol | MSM80C86A |  | MSM80C86A-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| CLK Cycle Period | TCLCL | 200 | DC | 125 | DC | ns |
| CLK Low Time | TCLCH | 118 |  | 68 |  | ns |
| CLK High Time | TCHCL | 69 |  | 44 |  | ns |
| CLK Rise Time ( $F$ rom 1.0 V to 3.5 V ) | TCH1CH2 |  | 10 |  | 10 | ns |
| CLK Fall Time (From 3.5 V to 1.0 V ) | TCL2CL1 |  | 10 |  | 10 | ns |
| Data in Setup Time | TDVCL | 30 |  | 20 |  | ns |
| Data in Hold Time | TCLDX | 10 |  | 10 |  | ns |
| RDY Setup Time into MSM 82C84A (See Notes 1, 2) | TR1VCL | 35 |  | 35 |  | ns |
| RDY Hold Time into MSM 82C84A (See Notes 1, 2) | TCLR1X | 0 |  | 0 |  | ns |
| READY Setup Time into MSM80C86A | TRYHCH | 118 |  | 68 |  | ns |
| READY Hold Time into MSM80C86A-2 | TCHRYX | 30 |  | 20 |  | ns |
| READY inactive to CLK (See Note 3) | TRYLCL | -8 |  | -8 |  | ns |
| HOLD Setup Time | THVCH | 35 |  | 20 |  | ns |
| INTR, NMI, $\overline{\text { TEST }}$ Setup Time (See Note 2) | TINVCH | 30 |  | 15 |  | ns |
| Input Rise Time (Except CLK) (From 0.8 V to 2.0 V ) | TILIH |  | 15 |  | 15 | ns |
| Input Fall Time (Except CLK) <br> (From 2.0 V to 0.8 V ) | TIHIL |  | 15 |  | 15 | ns |

Timing Responses

| Parameter | Symbol | MSM80C86A |  | MSM80C86A-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| Address Valid Delay | TCLAV | 10 | 110 | 10 | 60 | ns |
| Address Hold Time | tclax | 10 |  | 10 |  | ns |
| Address Float Delay | TCLAZ | tclax | 80 | TCLAX | 50 | ns |
| ALE Width | TLHLL | TCLCH-20 |  | TCLCH-10 |  | ns |
| ALE Active Delay | TCLLH |  | 80 |  | 50 | ns |
| ALE Inactive Delay | TCHLL |  | 85 |  | 55 | ns |
| Address Hold Time to ALE Inactive | tLLAX | TCHCL-10 |  | TCHCL-10 |  | ns |
| Data Valid Delay | TCLDV | 10 | 110 | 10 | 60 | ns |
| Data Hold Time | TCHDX | 10 |  | 10 |  | ns |
| Data Hold Time after $\overline{W R}$ | TWHDX | TCLCH-30 |  | TCLCH-30 |  | ns |
| Control Active Delay 1 | TCVCTV | 10 | 110 | 10 | 70 | ns |
| Control Active Delay 2 | TCHCTV | 10 | 110 | 10 | 60 | ns |
| Control Inactive Delay | TCVCTX | 10 | 110 | 10 | 70 | ns |
| Address Float to $\overline{\mathrm{RD}}$ Active | TAZRL | 0 |  | 0 |  | ns |
| $\overline{\mathrm{RD}}$ Active Delay | TCLRL | 10 | 165 | 10 | 100 | ns |


| Parameter | Symbol | MSM80C86A |  | MSM80C86A-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\overline{\mathrm{RD}}$ Inactive Delay | TCLRH | 10 | 150 | 10 | 80 | ns |
| $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TRHAV | TCLCL-45 |  | TCLCL-40 |  | ns |
| HLDA Valid Delay | TCLHAV | 10 | 160 | 10 | 100 | ns |
| $\overline{\mathrm{RD}}$ Width | TRLRH | 2TCLCL-75 |  | 2TCLCL-50 |  | ns |
| $\overline{\text { WR Width }}$ | TWLWH | 2TCLCL-60 |  | 2TCLCL-40 |  | ns |
| Address Valid to ALE Low | TAVAL | TCLCH-60 |  | TCLCH-40 |  | ns |
| Output Rise Time (From 0.8 V to 2.0 V ) | TOLOH |  | 15 |  | 15 | ns |
| Output Fall Time (From 2.0 V to 0.8 V ) | TOHOL |  | 15 |  | 15 | ns |

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

Maximum Mode System (Using MSM 82C88 Bus Controller) Timing Requirements

| Parameter | Symbol | MSM80C86A |  | MSM80C86A-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| CLK Cycle Period | TCLCL | 200 | DC | 125 | DC | ns |
| CLK Low Time | TCLCH | 118 |  | 68 |  | ns |
| CLK High Time | TCHCL | 69 |  | 44 |  | ns |
| CLK Rise Time (From 1.0 V to 3.5 V ) | TCH1CH2 |  | 10 |  | 10 | ns |
| CLK Fall Time (From 3.5 V to 1.0 V ) | TCL2CL1 |  | 10 |  | 10 | ns |
| Data in Setup Time | TDVCL | 30 |  | 20 |  | ns |
| Data in Hold Time | TCLDX | 10 |  | 10 |  | ns |
| RDY Setup Time into MSM 82C84A (See Notes 1, 2) | TR1VCL | 35 |  | 35 |  | ns |
| RDY Hold Time into MSM 82C84A (See Notes 1, 2) | TCLR1X | 0 |  | 0 |  | ns |
| READY Setup Time into MSM 80C86A | TRYHCH | 118 |  | 68 |  | ns |
| READY Hold Time into MSM 80C86A | TCHRYX | 30 |  | 20 |  | ns |
| READY inactive to CLK (See Note 3) | TRYLCL | -8 |  | -8 |  | ns |
| Set up Time for Recognition (NMI, INTR, TEST) (See Note 2) | TINVCH | 30 |  | 15 |  | ns |
| $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Setup Time | TGVCH | 30 |  | 15 |  | ns |
| $\overline{\mathrm{RQ}}$ Hold Time into MSM 80C86A | TCHGX | 40 |  | 30 |  | ns |
| Input Rise Time (Except CLK) <br> (From 0.8 V to 2.0 V ) | TILIH |  | 15 |  | 15 | ns |
| Input Fall Time (Except CLK) (From 2.0 to 0.8 V ). | TIHIL |  | 15 |  | 15 | ns |

Timing Responses

| Parameter | Symbol | MSM80C86A |  | MSM80C86A-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| Command Active Delay (See Note 1) | TCLML | 5 | 45 | 5 | 35 | ns |
| Command Inactive Delay (See Note 1) | TCLMH | 5 | 45 | 5 | 45 | ns |
| READY Active to Status Passive (See Note 4) | TRYHSH |  | 110 |  | 65 | ns |
| Status Active Delay | TCHSV | 10 | 110 | 10 | 60 | ns |
| Status Inactive Delay | TCLSH | 10 | 130 | 10 | 70 | ns |
| Address Valid Delay | TCLAV | 10 | 110 | 10 | 60 | ns |
| Address Hold Time | tclax | 10 |  | 10 |  | ns |
| Address Float Delay | TCLAZ | TCLAX | 80 | TCLAX | 50 | ns |
| Status Valid to ALE High (See Note 1) | TSVLH |  | 35 |  | 25 | ns |
| Status Valid to MCE High (See Note 1) | TSVMCH |  | 35 |  | 30 | ns |
| CLK low to ALE Valid (See Note 1) | TCLLH |  | 35 |  | 25 | ns |
| CLK Low to MCE High (See Note 1) | TCLMCH |  | 35 |  | 25 | ns |
| ALE Inactive Delay (See Note 1) | TCHLL | 4 | 35 | 4 | 25 | ns |
| Data Valid Delay | TCLDV | 10 | 110 | 10 | 60 | ns |
| Data Hold Time | TCHDX | 10 |  | 10 |  | ns |


| Parameter | Symbol | MSM80C86A |  | MSM80C86A-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| Control Active Delay (See Note 1) | TCVNV | 5 | 45 | 5 | 45 | ns |
| Control Inactive Delay (See Note 1) | TCVNX | 5 | 45 | 5 | 45 | ns |
| Address Float to $\overline{\mathrm{RD}}$ Active | TAZRL | 0 |  | 0 |  | ns |
| $\overline{\mathrm{RD}}$ Active Delay | TCLRL | 10 | 165 | 10 | 100 | ns |
| $\overline{\mathrm{RD}}$ Inactive Delay | TCLRH | 10 | 150 | 10 | 80 | ns |
| $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TRHAV | TCLCL-45 |  | TCLCL-40 |  | ns |
| Direction Control Active Delay (See Note 1) | TCHDTL |  | 50 |  | 50 | ns |
| Direction Control Inactive Delay (See Note 1) | TCHDTH |  | 35 |  | 30 | ns |
| $\overline{\text { GT Active Delay }}$ | TCLGL | 0 | 85 | 0 | 50 | ns |
| $\overline{\text { GT Inactive Delay }}$ | TCLGH | 0 | 85 | 0 | 50 | ns |
| $\overline{\mathrm{RD}}$ Width | TRLRH | 2TCLCL-75 |  | 2TCLCL-50 |  | ns |
| Output Rise Time (From 0.8 V to 2.0 V ) | TOLOH |  | 15 |  | 15 | ns |
| Output Fall Time (From 2.0 V to 0.8 V ) | TOHOL |  | 15 |  | 15 | ns |

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

## TIMING CHART

Input/Output
$0.45 \longrightarrow$ TEST POINTS $\longrightarrow$ T.5
A.C. TESTING: INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC " 1 " AND 0.45V FOR A LOGIC " 0 " TIMING MEASUREMENTS ARE 1.5V FOR BOTH A LOGIC " 1 " AND " 0 "
A.C. Testing Load Circuit


CL INCLUDES JIG CAPACITANCE

Minimum Mode


## Minimum Mode (Continued)



## Maximum Mode



Maximum Mode (Continued)


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

## Asynchronous Signal Recognition



Bus Lock Signal Timing (Maximum Mode Only)


Reset Timing


## Request/Grant Sequence Timing (Maximum Mode Only)



Hold/Hold Acknowledge Timing (Minimum Mode Only)


## PIN DESCRIPTION

## AD0 - AD15

ADDRESS DATA BUS: Input/Output
These lines are the multiplexed address and data bus.

These are the address bus at the T1 cycle and the data bus at the T2, T3, TW and T4 cycles.

At the T1 cycle, AD0 low indicates Data Bus Low (D0 - D7) Enable. These lines are high impedance during interrupt acknowledge and hold acknowledge.

## A16/S3. A17/S4, A18/S5, A19/S6

ADDRESS/STATUS: Output
Tses are the four most significant addresses, at the T1 cycle. Accessing 1/O port address, these are low at T1 cycles. These lines are Status lines at T2, T3, TW and T4 cycles. S3 and S4 are encoded as shown.

| S3 | S4 | Characteristics |
| :---: | :---: | :--- |
| 0 | 0 | Alternate Data |
| 1 | 0 | Stack |
| 0 | 1 | Code or None |
| 1 | 1 | Data |

These lines are high impedance during hold acknowledge.

## BHE/S7

BUS HIGH ENABLE/STATUS: Output
This line indicates Data Bus High Enable (BHE) at the T1 cycle.

This line indicates Data Bus High Enable (BHE) at the T1 cycles.

This line is status line at T2, T3, TW and T4 cycles.

## $\overline{R D}$

## READ: Output

This line indicates that CPU is in the memory or 1/O read cycle.

This line is the read strobe signal when CPU read data from memory or I/O device.

This line is active low.
This line is high impedance during hold acknowledge.

## READY

READY: Input
This line indicates to the CPU that the addressed memory or I/O device is ready to read or write.

This line is active high.
If the setup and hold time is out of specification, illegal operation will occur.

## INTR

INTERRUPT REQUEST: Input
This line is the level triggered interrupt request signal which is sampled during the last clock cycle of instruction and string manipulation.

It can be internally masked by software.
This signal is active high and internally synchronized.

## TEST

TEST: Input
This line is examined by the WAIT instruction.
When TEST is high, the CPU enters idle cycle.
When TEST is low, the CPU exits the idle cycle.

## NMI

NON MASKABLE INTERRUPT: Input
This line causes a type 2 interrupt.
NMI is not maskable.
This signal is internally synchronized and needs 2 clock cycles of pulse width.

## RESET

RESET: Input
This signal causes the CPU to initialize immediately.

This signal is active high and must be at least four clock cycles.

## CLK

CLOCK: Input
This signal provides the basic timing for the internal circuit.

## MN/MX

MINIMUM/MAXIMUM: Input
This signal selects the CPU's operating mode.
When $V_{\text {CC }}$ is connected, the CPU operates in Minimum mode.

Whin GND is connected, the CPU orerates Maximum mode.

## $V_{C C}$

$\mathrm{V}_{\mathrm{CC}}:+3-+6 \mathrm{~V}$ supplied.

## GND

GROUND

The following pin function descriptions are maximum mode only.

Other pin functions are already described.

## $\overline{\mathrm{SO}}, \overline{\mathrm{S} 1}, \overline{\mathrm{~S} 2}$

STATUS: Output
These lines indicate bus status and they are used by the MSM82C88 Bus Controller to generate all memory and I/O access control signals.

These lines are high impedance during hold acknowledge.

These status lines are encoded as shown.

| $\overline{\mathrm{S} 2}$ | $\overline{\mathrm{~S} 1}$ | $\overline{\mathrm{SO}}$ | Characteristics |
| :--- | :---: | :---: | :--- |
| 0 (LOW) | 0 | 0 | Interrupt acknowledge |
| 0 | 0 | 1 | Read I/O Port |
| 0 | 1 | 0 | Write I/O Port |
| 0 | 1 | 1 | Halt |
| $1($ HIGH ) | 0 | 0 | Code Access |
| 1 | 0 | 1 | Read Memory |
| 1 | 1 | 0 | Write Memory |
| 1 | 1 | 1 | Passive |

## $\overline{\mathrm{RQ}} / \overline{\mathbf{G T O}}$

## $\overline{\mathrm{RQ}} / \overline{\mathrm{GT} 1}$

REQUEST/GRANT: Input/Output
These lines are used for Bus Request from other devices and Bus GRANT to other deivces.

These lines are bidirectional and active low.

## LOCK

LOCK: Output
This line is active low.
When this line is low, other devices can not gain control of the bus.

This line is high impedance during hold acknowledge.

## QS0/QS1

QUEUE STATUS: Output
These lines are Queue Status, and indicate internal instrucion queue status.

| QS1 | QS0 | Characteristics |
| :--- | :---: | :--- |
| 0 (LOW) | 0 | No Operation |
| 0 | 1 | First Byte of Op Code from <br> Queue |
| 1 (HIGH) | 0 | Empty the Queue |
| 1 | 1 | Subsequent Byte from Queue |

The following pin function descriptions are mini-. mum mode only. Other pin functions are already described.

## $\mathrm{M} / \overline{\mathrm{IO}}$

STATUS: Output
This line selects memory address space or $1 / 0$ address space.

When this line is high, the CPU selects memory address space and when it is low, the CPU selects I/O address space.

This line is high impedance during hold acknowledge.

## WR

WRITE: Output
This line indicates that the CPU is in the memory or I/O write cycle.

This line is a write strobe signal when the CPU writes data to memory or I/O device.

This line is active low.
This line is high impedance during hold acknowledge.

## INTA

INTERRUPT ACKNOWLEDGE: Output
This line is a read strobe signal for the interrupt acknowledge cycle.

This line is active low.

## ALE

ADDRESS LATCH ENABLE: Output
This line is used for latching the address into the MSM82C12 address latch, It is a possitive pulse and its trailing edge is used to strobe the address, This line is never floated.
DT/R
DATA TRANSMIT/RECEIVE: Output
This line is used to control the output enable of the bus transceiver.

When this line is high, the CPU transmits data, and when it is low, the CPU receives data.

This line is high impedance during hold acknowledge.

## $\overline{\text { DEN }}$

DATA ENABLE: Output
This line is used to control the output enable of the bus transceiver.

This line is active low. This line is high impedance during hold acknowledge.

## HOLD

HOLD REQUEST: Input
This line is used for Bus Request from other devices.
This line is active high.

## HLDA

HOLD ACKNOWLEDGE: Output
This line is used for Bus Grant to other devices.
This line is active high.

## FUNCTIONAL DESCRIPTION

## STATIC OPERATION

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

The MSM80C86A can be single stepped using only the CPU clock. This state can be maintained as long as is necessary. Sigle step clock operation allows simple interface circuitry to provice critical information for bringing up your system.

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

## GENERAL OPERATION

The internal function of the MSM80C86 consists of a Bus Interface Unit (BIU) and an Execution Unit (EU). These units operate mutually but perform as separate processors.

BIU performs instruction fetch and queueing, operand fetch, DATA read and write address relocation
while waiting for decording and execution of instruc tions. Thus, the CPU's performance is increased. Up to 6-bytes of instruction stream can be queued.

The EU receives pre-fetched instructions from the BIU queue, decodes and executes the instructions, and provides the un-relocated operand address to BIU.

## MEMORY ORGANIZATION

The MSM80C86A has a 20-bit address to memory. Each address has an 8-bit data width. Memory is organized 00000 H to FFFFFH and is logicaly divided into four segments: code, data, extra data and stack segment. Each segment contains up to 64 Kbytes and locates on a 16-byte boundary. (Fig. 3a)

All memory references are made relative to the segment register which functions in accordance with a select rule. Word operands can be located on even or odd address boundary.

The BIU automatically performs the proper number of memory accesses. Memory consists of an even address and an odd address. Byte data of even address is transfered on the D0 - D7 and byte data of odd address is transfered on the D8 - D15.

The CPU prevides two enable signals $\overline{\mathrm{BHE}}$ and AO to access either an odd address, even address or both:

Memory location FFFFOH is the start address after reset, and 00000 H through 003FFH are reserved as an interrupt pointer, where there are 256 types of interrupt pointers.

Each interrupt type has a 4-byte pointer element consisting of a 16 -bit segment address and a 16-bit offset address.
and basic bus control. Instruction pre-fetch is perfomed

Memory Organization


Reserved Memory Locations


| Memory <br> Reference Need | Segment Register <br> Used | Segment <br> Selection Rule |
| :--- | :--- | :--- |
| Instructions | CODE (CS) | Automatic with all instruction prefetch. |
| Stack | STACK (SS) | All stack pushes and pops. Memory references relative to <br> BP base register except data references. |
| Local Data | DATA (DS) | Data references when relative to stack destination of str- <br> ing operation, or explicitly overridden. |
| External (Global) Data | EXTRA (ES) | Destination of string operations: Explicitly selected us- <br> ing a segment overriden. |

## MINIMUM AND MAXIMUM MODES

The MSM80C86A has two system modes: minimum and maximum. When using maximum mode, it is easy to organize a multi-CPU system with a 82 C 88 Bus Controller which generate the bus control signal.

When using minimum mode, it is easy to organize a simple system by generating bus control signal by itself.
$\mathrm{MN} / \overline{\mathrm{MX}}$ is the mode select pin. Definition of 2431 pin changes depend on the $M N / \overline{M X}$ pin.

## BUS OPERATION

The MSM80C86A has a time multiplexed address and data bus. If a non-multiplexed bus is desired for a system, it is only to add the address latch.

A CPU bus cycle consists of at least four clock cycles: T1, T2 T3 and T4. (Fig. 4)

The address output occurs during T1 and data transfer occurs during T3 and T4. T2 is used for changing the direction of the bus at the read operation. When the device which is accessed by the CPU is not ready for The data transfer and the CPU "NOT READY", TW cycles are inserted between T3 and T4.

When a bus cycle is not needed, T1 cycles are inserted between the bus cycles for internal execution. During the T1 cycle, the ALE signal is output from the CPU or the MSM82C88 depending on MN/MX. At the trailing edge of ALE, a valid address may be latched.

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

| $\overline{\mathrm{S} 2}$ | $\overline{\mathrm{~S} 1}$ | $\overline{\mathrm{SO}}$ | Characteristics |
| :--- | :---: | :---: | :--- |
| 0 (LOW) | 0 | 0 | Interrupt acknowledge |
| 0 | 0 | 1 | Read I/O |
| 0 | 1 | 0 | Write I/O |
| 0 | 1 | 1 | Halt |
| 1 (HIGH) | 0 | 0 | Instruction Fetch |
| 1 | 0 | 1 | Read Data from Memory |
| 1 | 1 | 0 | Write Data to Memory |
| 1 | 1 | 1 | Passive (no bus cycle) |

Status bits S3 through S7 are multiplexed with $\mathrm{A} 16 \sim \mathrm{~A} 19$, and $\overline{\mathrm{BHE}}$ : therefore, they are valid during T2 through T4.

S3 and S4 indicate which segment register was selected on the bus cycle, according to the following table.

| S4 | S3 | Characteristics |
| :--- | :---: | :--- |
| 0 (LOW) | 0 | Alternate Data (Extra segment) |
| 0 | 1 | Stack |
| $1(\mathrm{HIGH})$ | 0 | Code or None |
| 1 | 1 | Data |

S5 indicates interrupt enable Flag.

## I/O ADDRESSING

The MSM80C86A has 64 Kbyte of I/O or as 32 Kwords I/O. When the CPU accesses an I/O device, addresses AO ~A15 are in the same format as a memory address, and A16 ~ A19 are low.

The I/O ports addresses are same as memory, so it is necessary to be careful when using 8-bit peripherals.

## Basic System Timing



## EXTERNAL INTERFACE

## RESET

CPU Initalization is executed by the RESET pin. The MSM80C86A's RESET High signal is required for greater than 4 clock cycles.

The Rising edge of RESET terminates present operation immediately. The Falling edge of RESET triggers an internal reset sequence for approximately 10 clock cycles. Afer the internal reset sequence is finished normal operation occurs from absolute location FFFFOH.

## INTERRUPT OPERATIONS

Interrupt operation is classified as software or hardware, and hardware interrupt is classified as nonmaskable or maskable.

An interrupt causes a new program location defined on the interrupt pointer table, according to the interrupt type. Absolute locations 00000 H through $003 F F H$ are reserved for the interrupt pointer table. The interrupt pointer table consists of 256 elements. Each element is 4 bytes in size and corresponds to an Interrupt Acknowledge Sequence

8 bit type number which is sent from an interrupt interrupt request device during the interrupt acknowledge cycle.

## NON-MASKABLE INTERRUPT (NMI)

The MSM80C86A has a Non-maskable Interrupt (NMI) which is of higher priority than the maskable interrupt request (INTR).

The NMI request pulse width needs a minimum of 2 clock cycles. The NMI will be serviced at the end of the current instruction or between string manipulations.

## MASKABLE INTERRUPT (INTR)

The MSM80C86A provides another interrupt request (INTR) which can be masked by software. INTR is level triggered, so it must be held until the interrupt request is acknowledged.

INTR will be serviced at the end of the aurrent instruction or between string manipulations.


## INTERRUPT ACKNOWLEDGE

During the interrupt acknowledge sequence, further interrupts are disabled. The interrupt enable bit is reset by any interrupt, after which the Flag register is automatically pushed onto the stack. During the acknowledge sequence, the CPU emits the lock signal from T2 of the first bus cycle to T2 of the second bus cycle. At second bus cyclees, byte is fetched from the external device as a vector which identified the type of interrupt. This vector is multiplied by four and used as a interrupt pointer address. (INTR only)

The Interrupt Return (IRET) instruction includes a Flag pop operation which returns the original interrupt enable bit when it restores the Flag.

## HALT

When a Halt instruction is executed, the CPU enters the Halt state. An interrupt request or RESET will force the MSM80C86A out of the Halt state.

## SYSTEM TIMING - MINIMUM MODE

A bus cycle begins T1 with an ALE signal. The trailing edge of $A L E$ is used to latch the address. From T 1 to T 4 the $\mathrm{M} / \overline{\mathrm{IO}}$ signal indicates a memory or $1 / \mathrm{O}$ operation. From T2 to T4, the address data bus changes the address bus to data bus.

The read ( $\overline{\mathrm{RD}}$ ), write ( $\overline{\mathrm{WR})}$ and interrupt acknowledge (INTA) signals causes the addressed device to enable data bus. These signal becomes active at the beginning of T2 and inactive at the beginning of T4.

## SYSTEM TIMING - MAXIMUM MODE

At maximum mode, the MSM82C88 Bus Controller is added to system. The CPU sends status information to the Bus Controller. Bus timing signals are generated by Bus Controller. Bus timing is almost the same as in the minimum mode.

## BUS HOLD CIRCUITRY

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


Input Buffer exists only on I/O pins

Figure 6a. Bus hold circuitry pin 2-16, 35-39.


Figure 6b. Bus hold circuitry pin 26-32, 34

## DATA TRANSFER



## ARITHMETIC.

## ADD = Add:

Reg./memory with register to either Immediate to register/memory
immediate to accumulator

## ADC = Add with carry

Reg./memory with register to either Immediate to register/memory Immediate to accumulator

## INC = Increment:

Register/memory
Register
AAA $=$ ASCII adjust for add
DAA $=$ Decimal adjust for add
SUB = subtract:
Reg./memory and register to either Immediate from register/memory Immediate from accumulator

SBB $=$ Subtract with borrow:
Reg./memory and register to either
Immediate from register/memory Immediate from accumulator

DEC $=$ Decrement:
Register/memory
Register
NEG = Change sign
CMP = Compare
Register/memory and register
Immediate with register/memory
Immediate with accumulator
AAS $=$ ASCll adjust for subtract




STRING MANIPULATION



## PROCESSOR CONTROL

CLC = Clear carry
CMC = Complement carry
STC = Set carry
CLD = Clear direction
STD = Set direction
CLI = Clear interrupt
STI = Set interrupt
HLT = Halt
WAIT = Wait
ESC = Escape (to external device)
LOCK = Bus lock prefix



## Footnotes:

$A L=8$-bit accumulator
$A X=18$-bit accumulator
$C X=$ Count register
DS = Data segment
ES = Extra segment
Above/below refers to unsigned value
Greater = more positive
Less = less positive (more negative) signed value
If $d=1$ then "to" reg: If $d=0$ then "from" reg.
If $w=1$ then word instruction: If $w=0$ then byte instruction

If $\bmod =11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field
If $\bmod =00$ then DISP $=0^{*}$, disp-low and disp-high are absent
If mod $=01$ then DISP $=$ disp-low sign-extended to 16 -bits, disp-high is absent
If $\bmod =10$ then DISP $=$ disp-high: disp-low

If $\mathrm{r} / \mathrm{m}=000$ then $E A=(B X)+(S I)+$ 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 $E A=(S I)+D I S P$
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^{*}$
If $r / m=111$ then $E A=(B X)+D I S P$
DISP follows 2 nd byte of instruction (before data if required)

* except if $\bmod =00$ and $r / m=110$ then EA-disp-high: disp-low

If $\mathrm{s}: \mathrm{w}=01$ then 16 bits of immediate data form the operand
If $\mathrm{s}: \mathrm{w}=11$ then an immediate data byte is sign extended to form the 16-bit operand If $v=0$ then "count" $=1$ : If $v=1$ then "count" in (CL)
$x=$ don't care
$z$ is used for string primitives for comparison with ZF FLAG

## SEGMENT OVERRIDE PREFIX

001 reg 110
REG is assigned according to the following table:

| $16-B i t$ | $(w=1)$ | $8-B i t$ | $(w=0)$ | Segment |
| :---: | :--- | ---: | :--- | ---: |
| 000 | AX | 000 | AL | 00 ES |
| 001 | CX | 001 | CL | 01 CS |
| 010 | DX | 010 | DL | 10 SS |
| 011 | BX | 011 | BL | 11 DS |
| 100 | SP | 100 | AH |  |
| 101 | BP | 101 | CH |  |
| 110 | SI | 110 | DH |  |
| 111 | DI | 111 | BH |  |

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

## OIEI semiconductor

## MSM80C86A-10RS/GS/JS

## 16-BIT CMOS MICROPROCESSOR

## GENERAL DESCRIPTION

The MSM80C86A-10 are complete 16-bit CPUs implemented in Silicon Gate CMOS technology. They are designed with same processing speed as the NMOS 8086-1 but have considerably less power consumption. They are directly compatible with MSM80C88A-10 software and MSM80C85A/ MSM80C85A-2 hardware and peripherals.

## FEATURES

- 1 Mbyte Direct Addressable Memory Space
- Internal 14 Word by 16-bit Register Set
- 24 Operand Addressing Modes
- Bit, Byte, Word and String Operations
- 8 and 16-bit Signed and Unsigned Arithmetic Operation
- From DC to 10 MHz Clock Rate
- Low Power Dissipation $10 \mathrm{~mA} / \mathrm{MHz}$
- Bus Hold Circuitry Eliminates Pull-Up Resistors
- 40 pin Plastic DIP (DIP40-P-600)
- 44 pin PLCC (QFJ44-P-S650)
- 56 pin(L)-V Plastic QFP (QFP56-P-910-VK)

CIRCUIT CONFIGURATION


## PIN CONFIGURATION



- CPU•MSM80C86A-10RS/GS/JS


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MSM80C86A10RS | MSM80C86A- 10GS | MSM80C86A10JS |  |  |
| Power Supply Voltage | $V_{C C}$ | -0.5~+7 |  |  | V | With respect to GND |
| Input Voltage | VIN | -0.5 ~ $\mathrm{V}_{\mathrm{CC}}+0.5$ |  |  | V |  |
| Output Voltage | VOUT | -0.5 ~ $\mathrm{V}_{\mathrm{CC}}+0.5$ |  |  | V |  |
| Storage Temperature | Tstg | $-65 \sim+150$ |  |  | ${ }^{\circ} \mathrm{C}$ | - |
| Power Dissipation | PD | 1.0 | 0.7 |  | w | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ |

## OPERATING RANGE

| Parameter | Symbol | Limits | Unit |
| :---: | :---: | :---: | :---: |
|  |  | MSM80C86A-10 |  |
| Power Supply Voltage | V $_{\text {CC }}$ | $4.75 \sim 5.25$ | V |
| Operating Temperature | TOP OP | $0 \sim+70$ | ${ }^{\circ} \mathrm{C}$ |

RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | MSM80C86A-10 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP | MAX |  |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.75 | 5.0 | 5.25 | $\checkmark$ |
| Operating Temperature | TOP | 0 | +25 | +70 | ${ }^{\circ} \mathrm{C}$ |
| "L" Input Voltage | $V_{\text {IL }}$ | -0.5 |  | +0.8 | V |
| "H" Input Voltage | $\mathrm{V}_{\text {IH }}{ }^{(* 1)}$ | $\mathrm{V}_{\mathrm{CC}}-0.8$ |  | $\mathrm{V}_{\mathrm{CC}}+0.5$ | $\checkmark$ |
|  |  | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |

*1 Only CLK, *2 Except CLK.

DC CHARACTERISTICS
(MSM80C86A-10: $\mathrm{V}_{\mathrm{CC}}=4.75$ to $5.25 \mathrm{~V}, \mathrm{Ta}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Parameter | Symbol | MIN | TYP | MAX | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L" Output Voltage | VOL |  |  | 0.4 | V | $1 \mathrm{OL}=2.5 \mathrm{~mA}$ |
| "H" Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 3.0 |  |  | V | $1 \mathrm{OH}=-2.5 \mathrm{~mA}$ |
|  |  | Vcc-0.4 |  |  |  | $1 \mathrm{OH}=-100 \mu \mathrm{~A}$ |
| Input Leak Current | ILI | -1.0 |  | +1.0 | $\mu \mathrm{A}$ | $0<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {CC }}$ |
| Output Leak Current | ILO | -10 |  | +10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\text {cc }}$ or GND |
| Input Leakage Current (Bus Hold Low) | 'BHL | 50 |  | 400 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0.8 \mathrm{~V}$ |
| Input Leakage Current (Bus Hold High) | IBHH | -50 |  | -400 | $\mu \mathrm{A}$ | $\begin{gathered} \mathrm{V}_{\mathrm{IN}}=3.0 \mathrm{~V} \\ * 4 \end{gathered}$ |
| Bus Hold Low Overdrive | IBHLO |  |  | 600 | $\mu \mathrm{A}$ | *5 |
| Bus Hold High Overdrive | IBHHO |  |  | -600 | $\mu \mathrm{A}$ | *6 |
| Operating Power Supply Current | ${ }^{1} \mathrm{CC}$ |  |  | 10 | $\mathrm{mA} / \mathrm{MHz}$ | $\begin{aligned} & V_{I L}=G N D \\ & V_{I H}=V_{C C} \end{aligned}$ |
| Standby Power Supply Current | ICCS |  |  | 500 | $\mu \mathrm{A}$ | $V_{C C}=5.5 \mathrm{~V}$ <br> Outputs Unloaded <br> $V_{\text {IN }}=V_{C C}$ or GND |
| Input Capacitance | $\mathrm{Cin}_{\text {in }}$ |  |  | 10 | pF | * 7 |
| Output Capacitance | Cout |  |  | 15 | pF | * 7 |
| 1/O Capacitance | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  |  | 20 | pF | *7 |

*3 Test condition is to lower VIN to GND and then raise VIN to 0.8 V on pins 2-16, and 35-39
*4 Test condition is to raise $V_{I N}$ to $V_{C C}$ and then lower $V_{I N}$ to 3.0 V on pins 2-16, 26-32, and 34-39.
*5 An external driver must source at least IBHLO to switch this node from LOW to HIGH.
*6 An external driver must sink at least IBHHO to switch this node from HIGH to LOW.
*7 Test Conditions: a) Freq $=1 \mathrm{MHz}$.
b) Ummeasured Pins at GND.
c) $\mathrm{V}_{\mathrm{IN}}$ at 5.0 V or GND.

## A.C. CHARACTERISTICS

(MSM80C86A-10: $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ to $5.25 \mathrm{~V}, \mathrm{Ta}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ )
Minimum Mode System
Timing Requirements

| Parameter | Symbol | MSM80C86A-10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| CLK Cycle Period | TCLCL | 100 | DC | ns |
| CLK Low Time | TCLCH | 46 |  | ns |
| CLK High Time | TCHCL | 44 |  | ns |
| CLK Rise Time (From 1.0 V to 3.5 V ) | TCH1CH2 |  | 10 | ns |
| CLK Fall Time (From 3.5 V to 1.0 V ) | TCL2CL1 |  | 10 | ns |
| Data in Setup Time | TDVCL | 20 |  | ns |
| Data in Hold Time | TCLDX | 10 |  | ns |
| RDY Setup Time into MSM 82C84A (See Notes 1, 2) | TR1VCL | 35 |  | ns |
| RDY Hold Time into MSM 82C84A (See Notes 1, 2) | TCLR1X | 0 |  | ns |
| READY Setup Time into MSM80C86A | TRYHCH | 33 |  | ns |
| READY Hold Time into MSM80C86A | TCHRYX | 20 |  | ns |
| READY inactive to CLK (See Note 3) | TRYLCL | -8 |  | ns |
| HOLD Setup Time | THVCH | 20 |  | ns |
| INTR, NMI, $\overline{\text { TEST }}$ Setup Time (See Note 2) | TINVCH | 15 |  | ns |
| Input Rise Time (Except CLK) (From 0.8 V to 2.0 V ) | TILIH |  | 15 | ns |
| Input Fall Time (Except CLK) (From 2.0 V to 0.8 V ) | TIHIL |  | 15 | ns |

Timing Responses

| Parameter | Symbol | MSM80C86A-10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| Address Valid Delay | tclav | 10 | 60 | ns |
| Address Hold Time | tclax | 10 |  | ns |
| Address Float Delay | TCLAZ | TCLAX | 50 | ns |
| ALE Width | TLHLL | TCLCH-10 |  | ns |
| ALE Active Delay | TCLLH |  | 40 | ns |
| ALE Inactive Delay | TCHLL |  | 45 | ns |
| Address Hold Time to ALE Inactive | TLLAX | TCHCL-10 |  | ns |
| Data Valid Delay | TCLDV | 10 | 60 | ns |
| Data Hold Time | TCHDX | 10 |  | ns |
| Data Hold Time after $\overline{W R}$ | TWHDX | TCLCH-25 |  | ns |
| Control Active Delay 1 | TCVCTV | 10 | 55 | ns |
| Control Active Delay 2 | TCHCTV | 10 | 50 | ns |
| Control Inactive Delay | TCVCTX | 10 | 55 | ns |
| Address Float to $\overline{\mathrm{RD}}$ Active | TAZRL | 0 |  | ns |
| $\overline{\mathrm{RD}}$ Active Delay | TCLRL | 10 | 70 | ns |


| Parameter | Symbol | MSM80C86A-10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| $\overline{\mathrm{RD}}$ Inactive Delay | TCLRH | 10 | 60 | ns |
| $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TRHAV | TCLCL-35 |  | ns |
| HLDA Valid Delay | TCLHAV | 10 | 60 | ns |
| $\overline{\mathrm{RD}}$ Width | TRLRH | 2TCLCL-40 |  | ns |
| $\overline{\text { WR Width }}$ | TWLWH | 2TCLCL-35 |  | ns |
| Address Valid to ALE Low | TAVAL | TCLCH-35 |  | ns |
| Output Rise Time (From 0.8 V to 2.0 V ) | TOLOH |  | 15 | ns |
| Output Fall Time (From 2.0 V to 0.8 V ) | TOHOL |  | 15 | ns |

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

Maximum Mode System (Using MSM 82C88 Bus Controller) Timing Requirements

| Parameter | Symbol | MSM80C86A-10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| CLK Cycle Period | TCLCL | 100 | DC | ns |
| CLK Low Time | TCLCH | 46 |  | ns |
| CLK High Time | TCHCL | 44 |  | ns |
| CLK Rise Time (From 1.0V to 3.5V) | TCH1CH2 |  | 10 | ns |
| CLK Fall Time (From 3.5 V to 1.0 V ) | TCL2CL1 |  | 10 | ns |
| Data in Setup Time | TDVCL | 20 |  | ns |
| Data in Hold Time | TCLDX | 10 |  | ns |
| RDY Setup Time into MSM 82C84A (See Notes 1, 2) | TR1VCL | 35 |  | ns |
| RDY Hold Time into MSM 82C84A (See Notes 1, 2) | TCLR1X | 0 |  | ns |
| READY Setup Time into MSM 80C86A | TRYHCH | 33 |  | ns |
| READY Hold Time into MSM 80C86A | TCHRYX | 20 |  | ns |
| READY inactive to CLK (See Note 3) | TRYLCL | -8 |  | ns |
| Set up Time for Recognition (NMI, INTR, TEST) (See Note 2) | TINVCH | 15 |  | ns |
| $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Setup Time | TGVCH | 15 |  | ns |
| $\overline{\mathrm{RO}}$ Hold Time into MSM 80C86A | TCHGX | 20 |  | ns |
| Input Rise Time (Except CLK) <br> (From 0.8 V to 2.0 V ) | TILIH |  | 15 | ns |
| Input Fall Time (Except CLK) (From 2.0 to 0.8 V ). | TIHIL |  | 15 | ns |

Timing Responses

| Parameter | Symbol | MSM80C86A-10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| Command Active Delay (See Note 1) | TCLML | 5 | 35 | ns |
| Command Inactive Delay (See Note 1) | TCLMH | 5 | 45 | ns |
| READY Active to Status Passive (See Note 4) | TRYHSH |  | 45 | ns |
| Status Active Delay | TCHSV | 10 | 45 | ns |
| Status Inactive Delay | TCLSH | 10 | 60 | ns |
| Address Valid Delay | tclav | 10 | 60 | ns |
| Address Hold Time | tclax | 10 |  | ns |
| Address Float Delay | TCLAZ | TCLAX | 50 | ns |
| Status Valid to ALE High (See Note 1) | TSVLH |  | 25 | ns |
| Status Valid to MCE High (See Note 1) | TSVMCH |  | 30 | ns |
| CLK low to ALE Valid (See Note 1) | TCLLH |  | 25 | ns |
| CLK Low to MCE High (See Note 1) | TCLMCH |  | 25 | ns |
| ALE Inactive Delay (See Note 1) | TCHLL | 4 | 25 | ns |
| Data Valid Delay | TCLDV | 10 | 60 | ns |
| Data Hold Time | TCHDX | 10 |  | ns |


| Parameter | Symbol | MSM80C86A-10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| Control Active Delay (See Note 1) | TCVNV | 5 | 45 | ns |
| Control Inactive Delay (See Note 1) | TCVNX | 5 | 45 | ns |
| Address Float to $\overline{\mathrm{RD}}$ Active | TAZRL | 0 |  | ns |
| $\overline{\mathrm{RD}}$ Active Delay | TCLRL | 10 | 70 | ns |
| $\overline{\mathrm{RD}}$ Inactive Delay | TCLRH | 10 | 60 | ns |
| $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TRHAV | TCLCL-35 |  | ns |
| Direction Control Active Delay (See Note 1) | TCHDTL |  | 50 | ns |
| Direction Control Inactive Delay (See Note 1) | TCHDTH |  | 30 | ns |
| $\overline{\text { GT Active Delay (See Note 5) }}$ | TCLGL | 0 | 38 | ns |
| $\overline{\mathrm{GT}}$ Inactive Delay | TCLGH | 0 | 45 | ns |
| $\overline{\mathrm{RD}}$ Width | TRLRH | 2TCLCL-40 |  | ns |
| Output Rise Time (From 0.8 V to 2.0 V ) | TOLOH |  | 15 | ns |
| Output Fall Time (From 2.0 V to 0.8 V ) | TOHOL |  | 15 | ns |

Notes: 1. Signal at MSM 82C84A or MSM 82C88 are shown for reference only.
2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.
3. Applies only to $T 2$ state ( 8 ns into T 3 )
4. Applies only to $T 3$ and wait states.
5. $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}\left(\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}_{0}, \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}_{1}\right)$

## TIMING CHART

Input/Output

A.C. TESTING: INPUTS ARE DRIVEN AT 2.4 V FOR A LOGIC " 1 " AND 0.45V FOR A LOGIC " 0 " TIMING MEASUREMENTS ARE 1.5V FOR BOTH A LOGIC " 1 " AND " 0 "
A.C. Testing Load Circuit


CL INCLUDES JIG CAPACITANCE

Minimum Mode


## Minimum Mode (Continued)




Maximum Mode (Continued)


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

## Asynchronous Signal Recognition



Request/Grant Sequence Timing (Maximum Mode Only)


Note : 1. The coprocessor may not drive the buses outside the region shown without risking contention.

Hold/Hold Acknowledge Timing (Minimum Mode Only)


## PIN DESCRIPTION

## ADO - AD15

ADDRESS DATA BUS: Input/Output
These lines are the multiplexed address and data bus.

These are the address bus at the T1 cycle and the data bus at the T2, T3, TW and T4 cycles.

At the T1 cycle, AD0 low indicates Data Bus Low (D0 - D7) Enable. These lines are high impedance during interrupt acknowledge and hold acknowledge.

## A16/S3. A17/S4, A18/S5, A19/S6

## ADDRESS/STATUS: Output

Tses are the four most significant addresses, at the T1 cycle. Accessing 1/O port address, these are low at T1 cycles. These lines are Status lines at T2, T3, TW and T4 cycles. S3 and S4 are encoded as shown.

| S3 | S4 | Characteristics |
| :---: | :---: | :--- |
| 0 | 0 | Alternate Data |
| 1 | 0 | Stack |
| 0 | 1 | Code or None |
| 1 | 1 | Data |

These lines are high impedance during hold acknowledge.

## BHE/S7

BUS HIGH ENABLE/STATUS: Output
This line indicates Data Bus High Enable (BHE) at the T1 cycle.

This line indicates Data Bus High Enable (BHE) at the T1 cycles.

This line is status line at T2, T3, TW and T4 cycles.

## $\overline{R D}$

## READ: Output

This line indicates that CPU is in the memory or 1/O read cycle.

This line is the read strobe signal when CPU read data from memory or I/O device.

This line is active low.
This line is high impedance during hold acknowledge.

## READY

READY: Input
This line indicates to the CPU that the addressed memory or I/O device is ready to read or write.

This line is active high.
If the setup and hold time is out of specification, illegal operation will occur.

## INTR

## INTERRUPT REQUEST: Input

This line is the level triggered interrupt request signal which is sampled during the last clock cycle of instruction and string manipulation.

It can be internally masked by software.
This signal is active high and internally synchronized.

## $\overline{\text { TEST }}$

TEST: Input
This line is examined by the WAIT instruction.
When TEST is high, the CPU enters idle cycle.
When TEST is low, the CPU exits the idle cycle.

## NMI

## NON MASKABLE INTERRUPT: Input

This line causes a type 2 interrupt.
NMI is not maskable.
This signal is internally synchronized and needs 2 clock cycles of pulse width.

## RESET

RESET: Input
This signal causes the CPU to initialize immediately.

This signal is active high and must be at least four clock cycles.

## CLK <br> CLOCK: Input

This signal provides the basic timing for the internal circuit.

## MN/ $\overline{M X}$

MINIMUM/MAXIMUM: Input
This signal selects the CPU's operating mode.
When $V_{C C}$ is connected, the CPU operates in
Minimum mode.
Whin GND is connected, the CPU orerates Maximum mode.

## vcc

$V_{C C}:+5 V$ supplied.

## GND

GROUND

The following pin function descriptions are maximum mode only.

Other pin functions are already described.

## $\overline{\mathbf{S 0}}, \overline{\mathrm{S} 1}, \overline{\mathrm{~S} 2}$

STATUS: Output
These lines indicate bus status and they are used by the MSM82C88 Bus Controller to generate all memory and I/O access control signals.

These lines are high impedance during hold acknowledge.

These status lines are encoded as shown.

| $\overline{\mathrm{S} 2}$ | $\overline{\mathrm{~S} 1}$ | $\overline{\mathrm{SO}}$ | Characteristics |
| :--- | :---: | :--- | :--- |
| 0 (LOW) | 0 | 0 | Interrupt acknowledge |
| 0 | 0 | 1 | Read I/O Port |
| 0 | 1 | 0 | Write I/O Port |
| 0 | 1 | 1 | Halt |
| 1 (HIGH) | 0 | 0 | Code Access |
| 1 | 0 | 1 | Read Memory |
| 1 | 1 | 0 | Write Memory |
| 1 | 1 | 1 | Passive |

## $\overline{\mathrm{RQ}} / \overline{\mathbf{G T O}}$

$\overline{\mathrm{RQ}} / \overline{\mathrm{GT} 1}$
REQUEST/GRANT: Input/Output
These lines are used for Bus Request from other devices and Bus GRANT to other deivces.

These lines are bidirectional and active low.

## $\overline{\text { LOCK }}$

LOCK: Output
This line is active low.
When this line is low, other devices can not gain control of the bus.

This line is high impedance during hold acknowledge.

## OSO/QS1

## QUEUE STATUS: Output

These lines are Queue Status, and indicate internal instrucion queue status.

| QS1 | QSO | Characteristics |
| :--- | :---: | :--- |
| 0 (LOW) | 0 | No Operation |
| 0 | 1 | First Byte of Op Code from <br> Queue |
| 1 (HIGH) | 0 | Empty the Queue |
| 1 | 1 | Subsequent Byte from Queue |

The following pin function descriptions are mini-. mum mode only. Other pin functions are already described.

## M/IO

STATUS: Output
This line selects memory address space or 1/O address space.

When this line is high, the CPU selects memory address space and when it is low, the CPU selects I/O address space.

This line is high impedance during hold acknowledge.

## WR

## WRITE: Output

This line indicates that the CPU is in the memory or I/O write cycle.

This line is a write strobe signal when the CPU writes data to memory or I/O device.

This line is active low.
This line is high impedance during hold acknowledge.

## INTA

INTERRUPT ACKNOWLEDGE: Output
This line is a read strobe signal for the interrupt acknowledge cycle.

This line is active low.

## ALE

ADDRESS LATCH ENABLE: Output
This line is used for latching the address into the MSM82C12 address latch, It is a possitive pulse and its trailing edge is used to strobe the address, This line is never floated.
DT//
DATA TRANSMIT/RECEIVE: Output
This line is used to control the output enable of the bus transceiver.

When this line is high, the CPU transmits data, and when it is low, the CPU receives data.

This line is high impedance during hold acknowledge.

## DEN

DATA ENABLE: Output
This line is used to control the output enable of the bus transceiver.

This line is active low. This line is high impedance during hold acknowledge.

## HOLD

HOLD REQUEST: Input
This line is used for Bus Request from other devices.
This line is active high.

## HLDA

HOLD ACKNOWLEDGE: Output
This line is used for Bus Grant to other devices.
This line is active high.

## FUNCTIONAL DESCRIPTION

## STATIC OPERATION

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

The MSM80C86A can be single stepped using only the CPU clock. This state can be maintained as long as is necessary. Sigle step clock operation allows simple interface circuitry to provice critical information for bringing up your system.

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

## GENERAL OPERATION

The internal function of the MSM80C86A consists of a Bus Interface Unit (BIU) and an Execution Unit (EU). These units operate mutually but perform as separate processors.

BIU performs instruction fetch and queueing, operand fetch, DATA read and write address relocation and basic bus control. Instruction pre-fetch is perfomed
while waiting for decording and execution of instructions. Thus, the CPU's performance is increased. Up to 6 -bytes of instruction stream can be queued.

The EU receives pre-fetched instructions from the BIU queue, decodes and executes the instructions, and provides the un-relocated operand address to BIU.

## MEMORY ORGANIZATION

The MSM80C86A has a 20-bit address to memory. Each address has an 8-bit data width. Memory is organized 00000 H to FFFFFH and is logicaly divided into four segments: code, data, extra data and stack segment. Each segment contains up to 64 Kbytes and locates on a 16-byte boundary. (Fig. 3a)

All memory references are made relative to the segment register which functions in accordance with a select rule. Word operands can be located on even or odd address boundary.

The BIU automatically performs the proper number of memory accesses. Memory consists of an even address and an odd address. Byte data of even address is transfered on the DO - D7 and byte data of odd address is transfered on the D8 - D15.

The CPU prevides two enable signals $\overline{\mathrm{BHE}}$ and AO to access either an odd address, even address or both:

Memory location FFFFOH is the start address after reset, and 00000 H through 003FFH are reserved as an interrupt pointer, where there are 256 types of interrupt pointers.

Each interrupt type has a 4-byte pointer element consisting of a 16 -bit segment address and a 16 -bit offset address.

Reserved Memory Locations


| Memory <br> Reference Need | Segment Register <br> Used | Segment <br> Selection Rule |
| :--- | :--- | :--- |
| Instructions | CODE (CS) | Automatic with all instruction prefetch. |
| Stack | STACK (SS) | All stack pushes and pops. Memory references relative to <br> BP base register except data references. |
| Local Data | DATA (DS) | Data references when relative to stack destination of str- <br> ing operation, or explicitly overridden. |
| External (Global) Data | EXTRA (ES) | Destination of string operations: Explicitly selected us- <br> ing a segment overriden. |

## MINIMUM AND MAXIMUM MODES

The MSM80C86A has two system modes: minimum and maximum. When using maximum mode, it is easy to organize a multi-CPU system with a 82 C 88 Bus Controller which generate the bus control signal.

When using minimum mode, it is easy to organize a simple system by generating bus control signal by itself.
$\mathrm{MN} / \overline{\mathrm{MX}}$ is the mode select pin. Definition of 24 31 pin changes depend on the $M N / \overline{M X}$ pin.

## BUS OPERATION

The MSM80C86A has a time multiplexed address and data bus. If a non-multiplexed bus is desired for a system, it is only to add the address latch.

A CPU bus cycle consists of at least four clock cycles: T1, T2 T3 and T4. (Fig. 4)

The address output occurs during T1 and data transfer occurs during T3 and T4. T2 is used for changing the direction of the bus at the read operation. When the device which is accessed by the CPU is not ready for The data transfer and the CPU "NOT READY", TW cycles are inserted between T3 and T4.

When a bus cycle is not needed, T1 cycles are inserted between the bus cycles for internal execution. During the T1 cycle, the ALE signal is output from the CPU or the MSM82C88 depending on MN/ $\overline{M X}$. At the trailing edge of ALE, a valid address may be latched.

Status bits $\overline{\mathbf{S 0}}, \overline{\mathrm{S} 1}$ and $\overline{\mathbf{S 2}}$ are used in the maximum mode by the bus controller to recognize the type of bus operation according to the following table.

| $\overline{\mathrm{S} 2}$ | $\overline{\mathrm{~S} 1}$ | $\overline{\mathrm{SO}}$ | Characteristics |
| :--- | :---: | :---: | :--- |
| 0 (LOW) | 0 | 0 | Interrupt acknowledge |
| 0 | 0 | 1 | Read I/O |
| 0 | 1 | 0 | Write I/O |
| 0 | 1 | 1 | Halt |
| 1 (HIGH) | 0 | 0 | Instruction Fetch |
| 1 | 0 | 1 | Read Data from Memory |
| 1 | 1 | 0 | Write Data to Memory |
| 1 | 1 | 1 | Passive (no bus cycle) |

Status bits S3 through S7 are multiplexed with A16 ~ A19, and $\overline{B H E}$ : therefore, they are valid during T2 through T4.

S3 and S4 indicate which segment register was selected on the bus cycle, according to the following table.

| S4 | S3 | Characteristics |
| :--- | :---: | :--- |
| 0 (LOW) | 0 | Alternate Data (Extra segment) |
| 0 | 1 | Stack |
| 1 (HIGH) | 0 | Code or None |
| 1 | 1 | Data |

S5 indicates interrupt enable Flag.

## I/O ADDRESSING

The MSM80C86A has 64 Kbyte of I/O or as 32 Kwords I/O. When the CPU accesses an I/O device, addresses AO ~A15 are in the same format as a memory address, and A16 ~ A19 are low.

The I/O ports addresses are same as memory, so it is necessary to be careful when using 8 -bit peripherals.

## Basic System Timing



5

## EXTERNAL INTERFACE

## RESET

CPU Initalization is executed by the RESET pin. The MSM80C86A's RESET High signal is required for greater than 4 clock cycles.

The Rising edge of RESET terminates present operation immediately. The Falling edge of RESET triggers an internal reset sequence for approximately 10 clock cycles. Afer the internal reset sequence is finished normal operation occurs from absolute location FFFFOH.

## INTERRUPT OPERATIONS

Interrupt operation is classified as software or hardware, and hardware interrupt is classified as nonmaskable or maskable.

An interrupt causes a new program location defined on the interrupt pointer table, according to the interrupt type. Absolute locations 00000 H through $003 F F H$ are reserved for the interrupt pointer table. The interrupt pointer table consists of 256 elements. Each element is 4 bytes in size and corresponds to an Interrupt Acknowledge Sequence

8 bit type number which is sent from an interrupt interrupt request device during the interrupt acknowledge cycie.

## NON-MASKABLE INTERRUPT (NMI)

The MSM80C86A has a Non-maskable Interrupt (NMI) which is of higher priority than the maskable interrupt request (INTR).

The NMI request pulse width needs a minimum of 2 clock cycles. The NMI will be serviced at the end of the current instruction or between string manipulations.

## MASKABLE INTERRUPT (INTR)

The MSM80C86A provides another interrupt request (INTR) which can be masked by software. INTR is level triggered, so it must be held until the interrupt request is acknowledged.

INTR will be serviced at the end of the aurrent instruction or between string manipulations.


## INTERRUPT ACKNOWLEDGE

During the interrupt acknowledge sequence, further interrupts are disabled. The interrupt enable bit is reset by any interrupt, after which the Flag register is automatically pushed onto the stack. During the acknowledge sequence, the CPU emits the lock signal from T2 of the first bus cycle to T2 of the second bus cycle. At second bus cyclees, byte is fetched from the external device as a vector which identified the type of interrupt. This vector is multiplied by four and used as a interrupt pointer address. (INTR only)

The Interrupt Return (IRET) instruction includes a Flag pop operation which returns the original interrupt enable bit when it restores the Flag.

## HALT

When a Halt instruction is executed, the CPU enters the Halt state. An interrupt request or RESET will force the MSM80C86A out of the Halt state.

## SYSTEM TIMING - MINIMUM MODE

A bus cycle begins T1 with an ALE signal. The trailing edge of ALE is used to latch the address. From T1 to T4 the M/ $\overline{\mathrm{IO}}$ signal indicates a memory or $1 / O$ operation. From T2 to T4, the address data bus changes the address bus to data bus.

The read ( $\overline{\mathrm{RD}})$, write $(\overline{\mathrm{WR})}$ and interrupt acknowledge (INTA) signals causes the addressed device to enable data bus. These signal becomes active at the beginning of T2 and inactive at the beginning of T4.

## SYSTEM TIMING - MAXIMUM MODE

At maximum mode, the MSM82C88 Bus Controller is added to system. The CPU sends status information to the Bus Controller. Bus timing signals are generated by Bus Controller. Bus timing is almost the same as in the minimum mode.

## BUS HOLD CIRCUITRY

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


Figure 6a. Bus hold circuitry pin 2-16, 35-39.


Figure 6b. Bus hold circuitry pin 26-32, 34


ARITHMETIC

| ADD = Add: |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Reg./memory with register to either | $\begin{array}{llllllll}0 & 0 & 0 & 0 & 0 & 0 & d & w\end{array}$ | mod reg r/m |  |  |
| Immediate to register/memory | $\begin{array}{llllllll}1 & 0 & 0 & 0 & 0 & 0 & s & w\end{array}$ | $\bmod 00000 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate to accumulator | $\begin{array}{llllllll}0 & 0 & 0 & 0 & 0 & 1 & 0 & w\end{array}$ | data | data if w=1 |  |
| ADC = Add with carry: |  |  |  |  |
| Reg./memory with register to either | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 0 & 0 & d & w\end{array}$ | $\bmod \quad \mathrm{reg} \quad \mathrm{r} / \mathrm{m}$ |  |  |
| Immediate to register/memory | $\begin{array}{llllllll}1 & 0 & 0 & 0 & 0 & 0 & s & w\end{array}$ | $\bmod 0 \begin{array}{llll}0 & 1 & 0 & \mathrm{r} / \mathrm{m}\end{array}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate to accumulator | $\begin{array}{lllllllll}0 & 0 & 0 & 1 & 0 & 1 & 0 & w\end{array}$ | data | data if $w=1$ |  |
| INC = Increment $:$ |  |  |  |  |
| Register/memory | $\begin{array}{llllllll}1 & 1 & 1 & 1 & 1 & 1 & 1 & w\end{array}$ |  |  |  |
| Register | $\begin{array}{llllll}0 & 1 & 0 & 0 & 0 & \text { reg }\end{array}$ |  |  |  |
| AAA = ASCII adjust for add | $\begin{array}{llllllll}0 & 0 & 1 & 1 & 0 & 1 & 1 & 1\end{array}$ |  |  |  |
| DAA = Decimal adjust for add | $\begin{array}{llllllll}0 & 0 & 1 & 0 & 0 & 1 & 1 & 1\end{array}$ |  |  |  |
| SUB = subtract : |  |  |  |  |
| Reg./memory and register to either | $\begin{array}{llllllll}0 & 0 & 1 & 0 & 1 & 0 & d & w\end{array}$ | mod reg r/m |  |  |
| Immediate from register/memory | $\begin{array}{llllllll}1 & 0 & 0 & 0 & 0 & 0 & s & w\end{array}$ | $\bmod 1 \begin{array}{llll} & 0 & 1\end{array}$ | data | data if s : $\mathbf{w}=01$ |
| Immediate from accumulator | $\begin{array}{llllllll}0 & 0 & 1 & 0 & 1 & 1 & 0 & w\end{array}$ | data | data if w=1 |  |
| SBB = Subtract with borrow: |  |  |  |  |
| Reg./memory and register to either | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 1 & 0 & d & w\end{array}$ | $\bmod \quad r e g \quad r / m$ |  |  |
| Immediate from register/memory | $\begin{array}{llllllll}1 & 0 & 0 & 0 & 0 & 0 & s & w\end{array}$ | $\bmod 0 \begin{array}{llll}0 & 1 & 1 & \mathrm{r} / \mathrm{m}\end{array}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate from accumulator | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 1 & 1 & 0 & w\end{array}$ | data | data if $w=1$ |  |
| DEC = Decrement: |  |  |  |  |
| Register/memory | $\begin{array}{lllllllll}1 & 1 & 1 & 1 & 1 & 1 & 1 & w\end{array}$ | $\bmod 000018$ |  |  |
| Register | $\begin{array}{lllllll}0 & 1 & 0 & 0 & 1 & \text { reg }\end{array}$ |  |  |  |
| NEG = Change sign | $\begin{array}{lllllllll}1 & 1 & 1 & 1 & 0 & 1 & 1 & w\end{array}$ | $\bmod 0 \begin{array}{llll}0 & 1 & 1 & \mathrm{r} / \mathrm{m}\end{array}$ |  |  |
| CMP = Compare: | . |  |  |  |
| Register/memory and register | $\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & 0 & d & w\end{array}$ | mod reg r/m |  |  |
| Immediate with register/memory | $\begin{array}{llllllll}1 & 0 & 0 & 0 & 0 & 0 & s & w\end{array}$ | $\bmod 1 \begin{array}{llll} & 1 & 1\end{array}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate with accumulator | $\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & 1 & 0 & w\end{array}$ | data | data if $w=1$ |  |
| AAS = ASCII adjust for subtract | $\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & 1 & 1 & 1\end{array}$ |  |  |  |



## LOGIC



## STRING MANIPULATION




## PROCESSOR CONTROL



## CONTROL TRANSFER



## Footnotes:

$A L=8$-bit accumulator
$A X=18$-bit accumulator
$C X=$ Count register
DS = Data segment
$E S=$ Extra segment
Above/below refers to unsigned value
Greater $=$ more positive
Less = less positive (more negative) signed value
If $d=1$ then "to" reg: If $d=0$ then "from" reg.
If $\mathbf{w}=1$ then word instruction: If $\mathbf{w}=0$ then byte instruction

If $\bmod =11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field
If $\mathrm{mod}=00$ then DISP $=\mathbf{0}^{*}$, disp-low and disp-high are absent
If mod $=01$ then DISP $=$ disp-low sign-extended to $\mathbf{1 6}$-bits, disp-high is absent
If $\bmod =10$ then DISP = disp-high: disp-Iow

If $\mathrm{r} / \mathrm{m}=000$ then $E A=(B X)+(S I)+$ DISP
If $r / m=001$ then $E A=(B X)+(D I)+D I S P$
If $\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)+D I S P$
If $\mathrm{r} / \mathrm{m}=101$ then $E A=(D I)+D I S P$
If $r / m=110$ then $E A=(B P)+D I S P^{*}$
If $\mathrm{r} / \mathrm{m}=111$ then $E A=(B X)+$ DISP
DISP follows 2 nd byte of instruction (before data if required)

* except if $\bmod =00$ and $r / m=110$ then EA-disp-high: disp-low

If $\mathrm{s}: \mathrm{w}=01$ then 16 bits of immediate data form the operand
If $\mathrm{s}: \mathbf{w}=11$ then an immediate data byte is sign extended to form the 16-bit operand If $v=0$ then "count" $=1$ : If $v=1$ then "count" in (CL)
$x=$ don't care
$z$ is used for string primitives for comparison with ZF FLAG

## SEGMENT OVERRIDE PREFIX

001 reg 110
REG is assigned according to the following table:

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

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

## MSM80C88ARS/GS/JS MSM80C88A-2RS/GS/JS

## 8-BIT CMOS MICROPROCESSOR

## GENERAL DESCRIPTION

The MSM80C88A/MSM80C88A-2 are internal 16-bit CPUs with 8-bit interface implemented in Silicon Gate CMOS technology. They are designed with the same processing speed as the NMOS 8088/8088-2, but with considerably less power consumption.

The processor has attributes of both 8 and 16 -bit microprocessor. It is directly compatible with MSM80C86A/MSM80C86A-2 software and MSM80C85A/MSM80C85A-2 hardware and peripherals.

## FEATURES

- 8-Bit Data Bus Interface
- 16-Bit Internal Architecture
- 1 Mbyte Direct Addressable Memory Space
- Software Compatible with MSM80C86A
- Internal 14 Word by 16-bit Register Set
- 24 Operand Addressing Modes
- Bit, Byte, Word and String Operations
- 8 and 16-bit Signed and Unsigned Arithmetic Operation
- From DC to 5 MHz Clock Rate (MSM80C88A)
- From DC to 8 MHz Clock Rate (MSM 80C88A-2)
- Low Power Dissipation ( $10 \mathrm{~mA} / \mathrm{MHz}$ )
- Bus Hold Circuitry Eliminates Pull-Up Resistors
- 40 pin Plastic DIP (DIP40-P-600)
-44pin PLCC (QFJ44-P-S650)
- 56 pin(L)-V Plastic QFP (QFP56-P-910-VK)

FUNCTIONAL BLOCK DIAGRAM


PIN CONFIGURATION


ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MSM80C88ARS MSM80C88A-2RS | MSM80C88AGS MSM80C88A-2GS | MSM80C88AJS MSM80C88A-2JS |  |  |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $-0.5 \sim+7$ |  |  | V | With respect to GND |
| Input Voltage | $V_{\text {IN }}$ | $-0.5 \sim \mathrm{~V}_{\mathrm{CC}}+0.5$ |  |  | V |  |
| Output Voltage | V OUT | -0.5 ~ $\mathrm{V}_{\mathrm{CC}}+0.5$ |  |  | $v$ |  |
| Storage Temperature | Tstg | -65~+150 |  |  | ${ }^{\circ} \mathrm{C}$ | - |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 1.0 | 0.7 |  | w | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ |

## OPERATING RANGE

| Parameter | Limits | Unit |  |  |
| :--- | :---: | :---: | :---: | :---: |
|  |  |  | MSM80C88A-2 |  |
| Power Supply Voltage | VCC | $3 \sim 6$ | $4.75 \sim 5.25$ | V |
| Operating Temperature | TOP | $-40 \sim+85$ | $0 \sim+70$ | ${ }^{\circ} \mathrm{C}$ |

RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | MSM80C88A |  |  | MSM80C88A-2 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5.0 | 5.5 | 4.75 | 5.0 | 5.25 | $\checkmark$ |
| Operating Temperature | TOP | -40 | +25 | +85 | 0 | +25 | +70 | ${ }^{\circ} \mathrm{C}$ |
| "L" Input Voltage | $V_{\text {IL }}$ | -0.5 |  | +0.8 | -0.5 |  | +0.8 | V |
| "H" Input Voltage | $V_{1 H}{ }_{(* 2)}^{(* 1)}$ | $\mathrm{v}_{\mathrm{CC}}-0.8$ |  | $\mathrm{V}_{\mathrm{CC}}+0.5$ | $v_{\text {cc }}-0.8$ |  | $v_{\text {cc }}+0.5$ | V |
|  |  | 2.0 |  | $v_{C C}+0.5$ | 2.0 |  | $v_{\text {CC }}+0.5$ | V |

*1 Only CLK, *2 Except CLK.

DC CHARACTERISTICS
(MSM80C86A: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{Ta}=-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ )
(MSM80C88A-2: $\mathrm{V}_{\mathrm{CC}}=4.75$ to $5.25 \mathrm{~V}, \mathrm{Ta}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Parameter | Symbol | MIN | TYP | MAX | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L" Output Voltage | VOL |  |  | 0.4 | V | $1 \mathrm{OL}=2.5 \mathrm{~mA}$ |
| "H" Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 3.0 |  |  | V | $1 \mathrm{OH}=-2.5 \mathrm{~mA}$ |
|  |  | vcc-0.4 |  |  |  | $1 \mathrm{OH}=-100 \mu \mathrm{~A}$ |
| Input Leak Current | ILI | -1.0 |  | +1.0 | $\mu \mathrm{A}$ | $0<\mathrm{V}_{1}<\mathrm{V}_{C C}$ |
| Output Leak Current | ILO | -10 |  | +10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{cc}}$ or GND |
| Input Leakage Current (Bus Hold Low) | 'BHL | 50 |  | 400 | $\mu \mathrm{A}$ | $\begin{gathered} \mathrm{V}_{1 \mathrm{~N}}=0.8 \mathrm{~V} \\ \mathrm{~B}_{3} \end{gathered}$ |
| Input Leakage Current (Bus Hold High) | 'в ${ }^{\text {¢ }}$ | -50 |  | -400 | $\mu \mathrm{A}$ | $\begin{gathered} \mathrm{V}_{\mathrm{IN}}=3.0 \mathrm{~V} \\ * 4 \end{gathered}$ |
| Bus Hold Low Overdrive | IBHLO |  |  | 600 | $\mu \mathrm{A}$ | *5 |
| Bus Hold High Overdrive | Ів ${ }^{\text {¢ }}$ |  |  | -600 | $\mu \mathrm{A}$ | * 6 |
| Operating Power Supply Current | ICC |  |  | 10 | mA/MHz | $\begin{aligned} & V_{I L}=G N D \\ & V_{I H}=V_{C C} \end{aligned}$ |
| StandbySupply Current | ICcs |  |  | 500 | $\mu \mathrm{A}$ | $V_{I N}=V_{C C}$ or GND Outputs Unloaded CLK=GND or $V_{C C}$ |
| Input Capacitance | $\mathrm{C}_{\text {in }}$ |  |  | 1 C | pF | *7 |
| Output Capacitance | Cout |  |  | 15 | pF | *7 |
| I/O Capacitance | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  |  | 20 | pF | *7 |

*3. Test conditions is to lower $V_{I N}$ to GND and then raise $V_{I N}$ to 0.8 V on pins 2-16 and 35-39.
*4. Test condition is to raise $V_{I N}$ to $V_{C C}$ and then lower $V_{I N}$ to 3.0 V on pins 2-16, 26-32, and 34-39.
*5. An external driver must source at least IBHLO to switch this node from LOW to HIGH.
*6. An external driver must sink at least IBHHO to switch this node from HIGH to LOW.
*7. Test Conditions: a) Freq $=1 \mathrm{MHz}$.
b) Ummeasured Pins at GND.
c) $\mathrm{V}_{\mathrm{IN}}$ at 5.0 V or GND.

## A.C. CHARACTERISTICS

(MSM80C88A: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{Ta}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )
(MSM80C88A-2: $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ to $5.25 \mathrm{~V}, \mathrm{Ta}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ )
Minimum Mode System
Timing Requirements

| Parameter | Symbol | MSM80C88A |  | MSM80C88A-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| CLK Cycle Period | TCLCL | 200 | DC | 125 | DC | ns |
| CLK Low Time | TCLCH | 118 |  | 68 |  | ns |
| CLK High Time | TCHCL | 69 |  | 44 |  | ns |
| CLK Rise Time (From 1.0 V to 3.5 V ) | TCH1CH2 |  | 10 |  | 10 | ns |
| CLK Fall Time (From 3.5 V to 1.0 V ) | TCL2CL1 |  | 10 |  | 10 | ns |
| Data in Setup Time | TDVCL | 30 |  | 20 |  | ns |
| Data in Hold Time | TCLDX | 10 |  | 10 |  | ns |
| RDY Setup Time into MSM 82C84A (See Notes 1, 2) | TR1VCL | 35 |  | 35 |  | ns |
| RDY Hold Time into MSM 82C84A (See Notes 1, 2) | TCLR1X | 0 |  | 0 |  | ns |
| READY Setup Time into MSM 80C88A | TRYHCH | 118 |  | 68 |  | ns |
| READY Hold Time into MSM 80C88A | TCHRYX | 30 |  | 20 |  | ns |
| READY inactive to CLK (See Note 3) | TRYLCL | -8 |  | -8 |  | ns |
| HOLD Setup Time | THVCH | 35 |  | 20 |  | ns |
| INTR, NMI, $\overline{T E S T}$ Setup Time (See Note 2) | TINVCH | 30 |  | 15 |  | ns |
| Input Rise Time (Except CLK) (From 0.8 V to 2.0 V ) | TILIH |  | 15 |  | 15 | ns |
| Input Fall Time (Except CLK) (From 2.0 V to 0.8 V ) | TIHIL |  | 15 |  | 15 | ns |

Timing Responses

| Parameter | Symbol | MSM80C88A |  | MSM80C88A-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| Address Valid Delay | TCLAV | 10 | 110 | 10 | 60 | ns |
| Address Hold Time | tclax | 10 |  | 10 |  | ns |
| Address Float Delay | TCLAZ | TCLAX | 80 | tclax | 50 | ns |
| ALE Width | TLHLL | TCLCH-20 |  | TCLCH-10 |  | ns |
| ALE Active Delay | TCLLH |  | 80 |  | 50 | ns |
| ALE Inactive Delay | TCHLL |  | 85 |  | 55 | ns |
| Address Hold Time to ALE Inactive | tllax | TCHCL-10 |  | TCHCL-10 |  | ns |
| Data Valid Delay | TCLDV | 10 | 110 | 10 | 60 | ns |
| Data Hold Time | TCHDX | 10 |  | 10 |  | ns |
| Data Hold Time after $\bar{W}$ R | TWHDX | TCLCH-30 |  | TCLCH-30 |  | ns |
| Control Active Delay 1 | TCVCTV | 10 | 110 | 10 | 70 | ns |
| Control Active Delay 2 | TCHCTV | 10 | 110 | 10 | 60 | ns |
| Control Inactive Delay | tCVCTX | 10 | 110 | 10 | 70 | ns |
| Address Float to $\overline{\mathrm{RD}}$ Active | TAZRL | 0 |  | 0 |  | ns |
| $\overline{\mathrm{RD}}$ Acrive Ḋelay | TCLRL | 10 | 165 | 10 | 100 | ns |


| Parameter | Symbol | MSM80C88A |  | MSM80C88A-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\overline{\mathrm{RD}}$ Inactive Delay | TCLRH | 10 | 150 | 10 | 80 | ns |
| $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TRHAV | TCLCL-45 |  | TCLCL-40 |  | ns |
| HLDA Valid Delay | TCLHAV | 10 | 160 | 10 | 100 | ns |
| $\overline{\mathrm{RD}}$ Width | TRLRH | 2TCLCL-75 |  | 2TCLCL-50 |  | ns |
| $\overline{\text { WR Width }}$ | TWLWH | 2TCLCL-60 |  | 2TCLCL-40 |  | ns |
| Address Valid to ALE Low | TAVAL | TCLCH-60 |  | TCLCH-40 |  | ns |
| Output Rise Time (From 0.8 V to 2.0) | TOLOH |  | 15 |  | 15 | ns |
| Output Fall Time (From 2.0 V to 0.8 V ) | TOHOL |  | 15 |  | 15 | ns |

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

Maximum Mode System (Using MSM 82C88 Bus Controller)
Timing Requirements

| Parameter | Symbol | MSM80C88A |  | MSM80C88A-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| CLK Cycle Period | TCLCL | 200 | DC | 125 | DC | ns |
| CLK Low Time | TCLCH | 118 |  | 68 |  | ns |
| CLK High Time | TCHCL | 69 |  | 44 |  | ns |
| CLK Rise Time (From 1.0 V to 3.5 V ) | TCH1CH2 |  | 10 |  | 10 | ns |
| CLK Fall Time (From 3.5 V to 1.0 V ) | TCL2CL1 |  | 10 |  | 10 | ns |
| Data in Setup Time | TDVCL | 30 |  | 20 |  | ns |
| Data in Hold Time | TCLDX | 10 |  | 10 |  | ns |
| RDY Setup Time into MSM 82C84A (See Notes 1, 2) | TR1VCL | 35 |  | 35 |  | ns |
| RDY Hold Time into MSM 82C84A (See Notes 1, 2) | TCLR1X | 0 |  | 0 | . | ns |
| READY Setup Time into MSM 80C88A | TRYHCH | 118 |  | 68 |  | ns |
| READY Hold Time into MSM 80C88A | TCHRYX | 30 |  | 20 |  | ns |
| READY inactive to CLK (See Note 3) | TRYLCL | -8 |  | -8 |  | ns |
| Set up Time for Recognition (NMI, INTR, TEST) (See Note 2) | TINVCH | 30 |  | 15 |  | n's |
| $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Setup Time | TGVCH | 30 |  | 15 |  | ns |
| $\overline{\mathrm{RQ}}$ Hold Time into MSM 80C88A | TCHGX | 40 |  | 30 |  | ns |
| Input Rise Time (Except CLK) (From 0.8 V to 2.0 V ) | TILIH |  | 15 |  | 15 | ns |
| Input Fall Time (Except CLK) (From 2.0 V to 0.8 V ) | TIHIL |  | 15 |  | 15 | ns |

Timing Responses

| Parameter | Symbol | MSM80C88A |  | MSM80C88A-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| Command Active Delay (See Note 1) | TCLML | 5 | 45 | 5 | 35 | ns |
| Command Inactive Delay (See Note 1) | TCLMH | 5 | 45 | 5 | 45 | ns |
| READY Active to Status Passive (See Note 4) | TRYHSH |  | 110 |  | 65 | ns |
| Status Active Delay | TCHSV | 10 | 110 | 10 | 60 | ns |
| Status Inactive Delay | TCLSH | 10 | 130 | 10 | 70 | ns |
| Address Valid Delay | TCLAV | 10 | 110 | 10 | 60 | ns |
| Address Hold Time | tclax | 10 |  | 10 |  | ns |
| Address Float Delay | TCLAZ | tclax | 80 | tclax | 50 | ns |
| Status Valid to ALE High (See Note 1) | TSVLH |  | 35 |  | 25 | ns |
| Status Valid to MCE High (See Note 1) | TSVMCH |  | 35 |  | 30 | ns |
| CLK low to ALE Valid (See Note 1) | TCLLH |  | 35 |  | 25 | ns |
| CLK Low to MCE High (See Note 1) | TCLMCH |  | 35 |  | 25 | ns |
| ALE Inactive Delay (See Note 1) | TCHLL | 4 | 35 | 4 | 25 | ns |
| Data Valid Delay | tclov | 10 | 110 | 10 | 60 | ns |
| Data Hold Time | TCHDX | 10 |  | 10 |  | ns |
| Control Active Delay (See Note 1) | TCVNV | 5 | 45 | 5 | 45 | ns |
| Control Inactive Delay (See Note 1) | tCVNX | 5 | 45 | 5 | 45 | ns |
| Address Float to $\overline{\mathrm{RD}}$ Active | TAZRL | 0 |  | 0 |  | ns |
| $\overline{\mathrm{RD}}$ Active Delay | TCLRL | 10 | 165 | 10 | 100 | ns |
| $\overline{\mathrm{RD}}$ Inactive Delay | TCLRH | 10 | 150 | 10 | 80 | ns |
| $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TRHAV | TCLCL-45 |  | TCLCL-40 |  | ns |
| Direction Control Active Delay (See Note 1) | TCHDTL |  | 50 |  | 50 | ns |
| Direction Control Inactive Delay (See Note 1) | TCHDTH |  | 35 |  | 30 | ns |
| $\overline{\text { GT Active Delay }}$ | TCLGL | 0 | 85 | 0 | 50 | ns |
| $\overline{\text { GT Inactive Delay }}$ | TCLGH | 0 | 85 | 0 | 50 | ns |
| $\overline{\mathrm{RD}}$ Width | TRLRH | 2TCLCL-75 |  | 2TCLCL-50 |  | ns |
| Output Rise Time (From 0.8 V to 2.0 V ) | TOLOH |  | 15 |  | 15 | ns |
| Output Fall Time (From 2.0 V to 0.8 V ) | TOHOL |  | 15 |  | 15 | ns |

Notes: 1. Signals at MSM 82C84A or MSM 82C88 are shown for reference only.
2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.
3. Applies only to T2 state ( 8 ns into T 3 )
4. Applies only to $T 3$ and wait states.
A.C. TESTING INPUT, OUTPUT WAVEFORM

A.C. TESTING LOAD CIRCUIT


TIMING CHART
Minimum Mode



## NOTES:

1. All signals switch between $\mathrm{VOH}_{\mathrm{OH}}$ and $\mathrm{VOL}_{\mathrm{OL}}$ unless otherwise specified.
2. RDY is sampled near the end of $T 2, T 3, T W$ to deterrnine if TW machines states are to be inserted.

3 Two INTA cycles run back-to-back. The MSM80C88A LOCAL ADDR/DATA BUS is floating during both INTA cycles. Control signals shown for second INTA cycle.
4. Signals at MSM 82C84A shown for reference only.
5. All timing measurements are made at 1.5 V unless otherwise noted.


## Maximum Mode (Çontinued)



## NOTES:

1. All signals switch between $\mathrm{V}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ unless otherwise specified
2. RDY is sampled near the end of $T 2, T 3, T W$ to determine if $T W$ machines states are to be inserted.
3. Cascade address is valid between first and second INTA cycle.
4. Two INTA cycles run back-to-back. The MSM 80C88A LOCAL ADDR/DATA BUS is floating during both INTA cycles Control for pointer address is shown for second INTA cycle.
5. Signal at MSM 82C84A and MSM82C88 shown for reference only.

6 The issuance of the MSM 82C88 command and control signals $\overline{\text { IMRDC }}, \overline{M W T C}, \overline{A M W C}, \overline{\text { IORC, IOWC, }} \overline{\text { AIOWC }}, \overline{\text { INTA }}$ and DEN) lags the active high MSM 82C88 CEN
7. All timing measurements are made at 1.5 V unless otherwise noted

8 Status inactive in state just prior to $T 4$

## Asynchronous Signal Recognition



Bus Lock Signal Timing (Maximum Mode Only)


Reset Timing


## Request/Grant Sequence Timing (Maximum Mode Only)



Hold/Hold Acknowledge Timing (Minimum Mode Only)


## PIN DESCRIPTION

AD0-AD7
ADDRESS DATA BUS: Input/Output
These lines are the multiplexed address and data bus.
These are the address bus at T1 cycle and the data bus at T2, T3, TW and T4 cycle.
T2, T3, TW and T4 cycle.
These lines are high impedance during interrupt acknowledge and hold acknowledge.

## A8-A15

ADDRESS BUS: Output
These lines are the address bus bits 8 thru 15 at all cycles.
These lines do not have to be latched by an ALE signal.
These lines are high impedance during interrupt acknowledge and hold acknowledge.

A16/S3, A17/S4, A18/S5, A19/S6
ADDRESS/STATUS: Output
These are the four most significant address as at the T1, cycle.
Accessing I/O port address, these are low at T1 Cycles.
These lines are Status lines at the T2, T3, TW and T4 Cycle.
S5 indicate interrupt enable Flag.
S3 and S4 are encoded as shown.

| S3 | S4 | Characteristics |
| :---: | :---: | :--- |
| 0 | 0 | Alternate Data |
| 1 | 0 | Stack |
| 0 | 1 | Code or None |
| 1 | 1 | Data |

These lines are high impedance during hold acknowledge.

## $\overline{\mathbf{R D}}$

READ: Output
This lines indicates that the CPU is in a memory or I/O read cycle.
This line is the read strobe signal when the CPU reads data from a memory or I/O device.
This line is active low.
This line is high impedance during hold acknowledge.

## READY

READY: Input
This line indicates to the CPU that an addressed memory or I/O device is ready to read or write.
This line is active high.
IF the setup and hold time are outof specification, an illegal operation will occur.

## INTR

INTERRUPT REQUEST: Input
This line is a level triggered interrupt request signal which is sampled during the last clock cycle of instruction and string manipulations.
It can be internally masked by software.
This signal is active high and internally synchronized.

## TEST

TEST: Input
This line is examined by a "WAIT" instruction. When TEST is high, the CPU enters an idle cycle. When TEST is low, the CPU exits an idle cycle.

## NMI

NON MASKABLE INTERRUPT: Input
This line causes a type 2 interrupt. NMI is not maskable.
This signal is internally synchronized and needs a 2 clock cycle pulse width.

## RESET

RESET: Input
This signal causes the CPU to initialize immediately. This signal is active high and must be at least four clock cycles.

## CLK

CLOCK: Input
This signal provide the basic timing for an internal circuit.

## MN/ $\overline{M X}$

MINIMUM/MAXIMUM: Input
This signal selects the CPU's operate mode.
When $V_{C C}$ is connected, the CPU operates in minimum mode.
When GND is connected, the CPU operates in maximum mode.

## $v_{c c}$

$\mathrm{V}_{\mathrm{CC}}+3-+6 \mathrm{~V}$ supplied.

GND
GROUND

The following pin function descriptions are for maximum mode only.
Other pin functions are already described.

## $\overline{\mathbf{s} 0}, \overline{\mathbf{s} 1}, \overline{\mathbf{s} 2}$

STATUS: Output
These lines indicate bus status and they are used by the MSM82C88 Bus Controller to generate all memory and I/O access control signals.
These lines are high impedance during hold acknowledge.
These status lines are encoded as shown.

| $\overline{\mathrm{S} 2}$ | $\overline{\mathrm{~S} 1}$ | $\overline{\mathrm{~S} 0}$ | Characteristics |
| :---: | :---: | :---: | :--- |
| 0 (LOW) | 0 | 0 | Interrupt acknowledge |
| 0 | 0 | 1 | Read I/O Port |
| 0 | 1 | 0 | Write I/O Port |
| 0 | 1 | 1 | Halt |
| 1 (HIGH) | 0 | 0 | Code Access |
| 1 | 0 | 1 | Read Memory |
| 1 | 1 | 0 | Write Memory |
| 1 | 1 | 1 | Passive |

## $\overline{\mathbf{R Q} / \mathbf{G T O}}$

$\overline{\mathrm{RQ}} / \overline{\mathrm{GT} 1}$
REQUEST/GRANT: Input/Output
These lines are used for Bus Request from other devices and Bus GRANT to other devices.
These lines are bidirectional and active low.

## LOCK

LOCK: Output
This line is active low.
When this line is low, other devices can not gain control of the bus.
This line is high impedance during hold acknowledge.

## OSO/QS1

QUEUE STATUS: Output
These are Queue Status Lines that indicate internal instruction queue status.

| QS1 | QS0 | Characteristics |
| :---: | :---: | :--- |
| 0 (LOW) | 0 | No Operation |
| 0 | 1 | First Byte of Op Code from <br> Queue |
| 1 (HIGH) | 0 | Empty the Queue |
| 1 | 1 | Subsequent Byte from Queue |

The following pin function descriptions are minimum mode only. Other pin functions are already described.

## $10 / \mathrm{M}$

STATUS: Output
This line selects memory address space or 1/O address space.

When this line is low, the CPU selects memory address space and when it is high, the CPU selects I/O address space.
This line is high impedance during hold acknowledge.

## $\overline{W R}$ <br> WRIȚE: Output

This line indicates that the CPU is in a memory or I/O write cycle.
This line is a write strobe signal when the CPU writes data to memory or an I/O device.
This line is active low.
This line is high impedance during hold acknowledge.

## $\overline{\text { INTA }}$

INTERRUPT ACKNOWLEDGE: Output
This line is a read strobe signal for the interrupt accknowledge cycle.
This line is active low.

## ALE

ADDRESS LATCH ENABLE: Output
This line is used for latching an address into the MSM82C12 address latch it is a positive pulse and the trailing edge is used to strobe the address. This line in never floated.

## DT/R

DATA TRANSMIT/RECEIVE: Output
This line is used to control the direction of the bus transceiver.
When this line is high, the CPU transmits data, and when it is low, the CPU receive data.
This line is high impedance during hold acknowledge:

## $\overline{\text { DEN }}$

DATA ENABLE: Output
This line is used to control the output enable of the bus transceiver.
This line is active low. This line is high impedance during hold acknowledge.

## HOLD

HOLD REQUEST: Input
This line is used for a Bus Request from an other device.
This line is active high.

## HLDA

HOLD ACKNOWLEDGE: Output
This line is used for a Bus Grant to an other device.
This line is active high.

## $\overline{\text { SSO }}$

STATUS: Output
This line is logically equivalent to $\overline{\mathrm{SO}}$ in the maximum mode.

## STATIC OPERATION

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

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

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

The BIU performs instruction fetch and queueing, operand fetch, DATA read and write address relocation and basic bus control. By performing instruction prefetch while waiting for decoding and execution of instruction, the CPU's performance is increased. Up to 4-bytes fo instruction stream can be queued.

EU receives pre-fetched instructions from the BIU queue, decodes and executes instructions and provides an un-relocated operand address to the BIU.

## MEMORY ORGANIZATION

The MSM80C88A has a 20-bit address to memory. Each address has 8-bit data width. Memory is organized 00000 H to FFFFFH and is logically divided into four segments: code, data, extra data and stack segment Each segment contains up to 64 Kbytes and locates on a 16 -byte boundary. (Fig. 3a)

All memory references are made relative to a segment register according to a select rule. Memory location FFFFOH is the start address after reset, and 00000H through 003 FFH are reserved as an interrupt pointer. There are 256 types of interrupt pointer;

Each interrupt type has a 4-byte pointer element consisting of a 16 -bit segment address and a 16-bit offset address.

## FUNCTIONAL DESCRIPTION

## GENERAL OPERATION

The internal function of the MSM80C88A consist of a Bus Interface Unit (BIU) and an Execution Unit (EU). These units operate mutually but perform as separate processors.

## Memory Organization



Reserved Memory Locations


CPU•MSM80C88ARS/GS/JS MSM80C88A-2RS/GS/JS

| Memory Reference Need | Segment Register Used | Segment Selection Rule |
| :--- | :---: | :--- |
| Instructions | CODE (CS) | Automatic with all instruction prefetch. |
| Stack | STACK (SS) | All stack pushes and pops. Memory references <br> relative to BP base register except data references. |
| Local Data | DATA (DS) | Data references when relative to stack, destination <br> of string operation, or explicitly overridden. |
| External (Global) Data | EXTRA (ES) | Destination of string operations: Explicitly selected <br> using a segment override. |

## MINIMUM AND MAXIMUM MODES

The MiSM80C88A has two system modes: minimum and maximum. When using the maximum mode, it is easy to organize a multiple-CPU system with the MSM 82C88 Bus Controller which generates the bus control signal.

When using the minimum mode, it is easy to organize a simple system by generating the bus control signal itself. $M N / \overline{M X}$ is the mode select pin. Definition of 24-31, 34 pin changes depends on the MN/MX pin.

## BUS OPERATION

The MSM80C88A has a time multiplexed address and data bus. If a non-multiplexed bus is desired for the system, it is only needed to add the address latch.

A CPU bus cycle consists of at least four clock cycles: T1, T2, T3 and T4. (Fig. 4)

The address output occurs during T 1 , and data transfer occurs during T3 and T4. T2 is used for changing the direction of the bus during read operation. When the device which is accessed by the CPU is not ready to data transfer and send to the CPU "NOT READY"' is indicated TW cycles are inserted between T3 and T4.

When a bus cycle is not needed, T1 cycles are inserted between the bus cycles for internal execution. At the T1 cycle an ALE signal is output from the CPU or the MSM82C88 depending in MN/ $\overline{M X}$. at the trailing edge of an ALE, a valid address may be latched. Status bits S0, S1 and S2 are uased, in maximum mode, by the bus controller to recognize the type of bus operation according to the following table.

| $\overline{\mathrm{S} 2}$ | $\overline{\mathrm{~S} 1}$ | $\overline{\mathrm{SO}}$ | Characteristics |
| :---: | :---: | :---: | :--- |
| 0 (LOW) | 0 | 0 | Interrupt acknowledge |
| 0 | 0 | 1 | Read I/O |
| 0 | 1 | 0 | Write I/O |
| 0 | 1 | 1 | Halt |
| 1 (HIGH) | 0 | 0 | Instruction Fetch |
| 1 | 0 | 1 | Read Data from Memory |
| 1 | 1 | 0 | Write Data to Memory |
| 1 | 1 | 1 | Passive (no bus cycle) |

Status bit S3 through S6 are multiplexed with A16-A19, and therefore they are valid during T2 through T4. S3 and S4 indicate which segment register was selected on the bus cycle, according to the following table.

| S4 | S3 | Characteristics |
| :---: | :---: | :--- |
| $0($ LOW ) | 0 | Alternate Data (Extra Segment) |
| 0 | 1 | Stack |
| $1(\mathrm{HIGH})$ | 0 | Code or None |
| 1 | 1 | Data |

S5 indicates interrupt enable Flag.

## I/O ADDRESSING

The MSM80C88A has a 64 Kbyte I/O. When the CPU accesses an I/O device, address AO-A15 are in same format as a memory access, and A16-A19 are low. I/O ports address are same as four memory.

## Basic System Timing



## EXTERNAL INTERFACE

## RESET

CPU initialization is executed by the RESET pin. The MSM80C88A's RESET High signal is required for greater than 4 clock cycles.

The rising edge of RESET terminates the present operation immediately. The falling edge of RESET triggers an internal reset requence for approximately 10 clock cycles. After internal reset sequence is finished, normal operation begins from absolute location FFFFOH.

## INTERRUPT OPERATIONS

The interrupt operation is classified as software or hardware, and hardware interrupt is classified as nonmarkable or maskable.

An interrupt causes a new program location which is defined by the interrupt pointer table, according to the interrupt type. Absolute location 00000 H through $003 F F H$ is reserved for the interrupt pointer table. The interrupt pointer table consists of 256-elements. Each element is 4 bytes in size and corresponds to an 8-bit type number which is sent from an interrupt request device during the interrupt acknowledge cycle.

## NON-MASKABLE INTERRUPT (NMI)

The MSM80C88A has a non-maskable Interrupt (NM1) which is of higher priority than a maskable interrupt request (INTR).

An NM1 request pulse width needs minimum of 2 clock cycles. The NM1 will be serviced at the end of the current instruction or between string manipulations.

## MASKABLE INTERRUPT (INTR)

The MSM80C88A provides another interrupt request (INTR) which can be masked by software. INTR is level triggered, so it must be held until interrupt request is acknowledged.

The INTR will be serviced at the end of the current instruction or between string manipulations.

## INTERRUPT ACKNOWLEDGE

During the interrupt acknowledge sequence, further interrupts are disabled. The interrupt enable bit is reset by any interrupt, after which the Flag register is automatically pushed onto the stack. During an acknowledge sequence, the CPU emits the lock signal from T2 of first bus cycle to T2 of second bus cycle. At the second bus cycle, a byte is fetched from the external device as a vector which identifies the type of interrupt. This vector is multiplied by four and used as an interrupt pointer address (INTR only).

The Interrupt Return (IRET) instruction includes a Flag pop operation which returns the original interrupt enable bit when it restores the Flag.

## HALT

When a Halt instruction is executed, the CPU enter Halt state. An interrupt request or RESET will force the MSM80C88A out of the Halt state.

## SYSTEM TIMING-MINIMUM MODE

A bus cycle begins at T1 with an ALE signal. The trailing edge of $A L E$ is used to latch the address. From T1 to T 4 the $10 / \bar{M}$ signal indicates a memory or $1 / O$ operation. From T2 to T4, the address data bus changes the address bus to the data bus.
 edge (INTA) signals caused the addressed device to enable the data bus. These signals become active at the beginning of T2 and inactive at the beginning of T4.

## SYSTEM TIMING - MAXIMUM MODE

In maximum mode, the MSM82C88 Bus Controller is added to system. The CPU sends status information to the Bus Controller. Bus timing signals are generated by the Bus Controller. Bus timing is almost the same as in minimum mode.

Interrupt Acknowledge Sequence


## BUS HOLD CIRCUITRY

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


Figure 6a. Bus hold circuitry pin 2-16, 35-39.
"PULL-UP"


Input Buffer exists only on I/O pins

Figure 6b. Bus hold circuitry pin 26-32, 34

DATA TRANSFER


## ARITHMETIC

ADD = Add:
Reg./memory with register to eithe

Reg./memory with register to either
Immediate to register/memory Immediate to register/memory Immediate to accumulator

## ADC $=$ Add with carry:

Reg./memory with register to either Immediate to register/memory Immediate to accumulator

INC = Increment:

## Register/memory

## Register

AAA = ASCII adjust for add
DAA $=$ Decimal adjust for add
SUB $=$ subtract:
Reg./memory and register to either Immediate from register/memory Immediate from accumulator

SBB $=$ Subtract with borrow:
Reg./memory and register to either Immediate from register/memory Immediate from accumulator

DEC $=$ Decrement:
Register/memory
Register
NEG $=$ Change sign
CMP = Compare:
Register/memory and register
Immediate with register/memory Immediate with accumulator AAS = ASCII adjust for subtract

5


## LOGIC



## TRING MANIPULATION

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



## PROCESSOR CONTROL



## CONTROL TRANSFER



## Footnotes:

$A L=8$-bit accumulator
$A X=18$-bit accumulator
$C X=$ Count register
DS = Data segment
ES = Extra segment
Above/below refers to unsigned value
Greater = more positive
Less $=$ less positive (more negative) signed value
If $d=1$ then "to" reg: If $d=0$ then "from" reg.
If $\mathbf{w}=1$ then word instruction: If $\mathbf{w}=0$ then byte instruction
If $\bmod =11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field
If $\bmod =00$ then DISP $=\mathbf{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 $\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 $r / 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=(D I)+D I S P$
If $r / 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 $r / m=110$ then EA-disp-high: disp-low

If $\mathrm{s}: \mathrm{w}=01$ then 16 bits of immediate data form the operand
If $\mathrm{s}: \mathrm{w}=11$ then an immediate data byte is sign extended to form the 16-bit operand
If $v=0$ then "count" $=1$ : If $v=1$ then "count" in (CL)
$x=$ don't care
$z$ is used for string primitives for comparison with ZF FLAG

## SEGMENT OVERRIDE PREFIX

001 reg 110
REG is assigned according to the following table:

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

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

## OIKI <br> semiconductor

## MSM80C88A-10RS/GS/JS

## 8-BIT CMOS MICROPROCESSOR

## GENERAL DESCRIPTION

The MSM80C88A-10 are internal 16-bit CPUs with 8-bit interface implemented in Silicon Gate CMOS technology. They are designed with the same processing speed as the NMOS8088-1, but with considerably less power consumption.

The processor has attributes of both 8 and 16 -bit microprocessor. It is directly compatible with MSM80C86A-10 software and MSM80C85A/MSM80C85A-2 hardware and peripherals.

## FEATURES

- 8-Bit Data Bus Interface
- 16-Bit Internal Architecture
- 1 Mbyte Direct Addressable Memory Space
- Software Compatible with MSM80C86A
- Internal 14 Word by 16-bit Register Set
- 24 Operand Addressing Modes

FUNCTIONAL BLOCK DIAGRAM

- Bit, Byte, Word and String Operations
- 8 and 16-bit Signed and Unsigned Arithmetic Operation
- From DC to 10 MHz Clock Rate
- Low Power Dissipation ( $10 \mathrm{~mA} / \mathrm{MHz}$ )
- Bus Hold Circuitry Eliminates Pull-Up Resistors
- 40 pin Plastic DIP (DIP40-P-600)
- 44 pin PLCC (QFJ44-P-S650)
- 56 pin(L)-V Plastic QFP (OFP56-P-910-VK)


PIN CONFIGURATION


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MSM80C88A10RS | MSM80C88A10GS | $\begin{gathered} \text { MSM80C88A- } \\ \text { 10JS } \end{gathered}$ |  |  |
| Power Supply Voltage | $V_{\text {cc }}$ | -0.5~+7 |  |  | V | With respect to GND |
| Input Voltage | VIN | $-0.5 \sim \mathrm{~V}_{\text {CC }}+0.5$ |  |  | V |  |
| Output Voltage | VOUT | $-0.5 \sim \mathrm{~V}_{\mathrm{CC}}+0.5$ |  |  | $\checkmark$ |  |
| Storage Temperature | Tstg | $-65 \sim+150$ |  |  | ${ }^{\circ} \mathrm{C}$ | - |
| Power Dissipation | $P_{\text {D }}$ | 1.0 | 0.7 |  | W | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ |

## OPERATING RANGE

| Parameter | Symbol | Limits | Unit |
| :---: | :---: | :---: | :---: |
|  |  | MSM80C88A-10 |  |
| Power Supply Voltage | V CC | $4.75 \sim 5.25$ | $V$ |
| Operating Temperature | TOP | $0 \sim+70$ | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | MSM80C88A-10 |  |  | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP | MAX |  |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.75 | 5.0 | 5.25 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | 0 | +25 | +70 | ${ }^{\circ} \mathrm{C}$ |
| "L" Input Voltage | $\mathrm{V}_{\text {IL }}$ | -0.5 |  | +0.8 | V |
| "'H" Input Voltage | $\mathrm{V}_{\text {IH }}$ (*1) $^{*}$ | $\mathrm{~V}_{\mathrm{CC}}-0.8$ |  | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |
|  |  | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |

*1 Only CLK, *2 Except CLK

## DC CHARACTERISTICS

(MSM80C88A-10: $\mathrm{V}_{\mathrm{CC}}=4.75$ to $5.25 \mathrm{~V}, \mathrm{Ta}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Parameter | Symbol | MIN | TYP | MAX | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L" Output Voltage | VOL |  |  | 0.4 | V | $1 \mathrm{OL}=2.5 \mathrm{~mA}$ |
| " H " Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 3.0 |  |  | V | $1 \mathrm{OH}=-2.5 \mathrm{~mA}$ |
|  |  | VCC-0.4 |  |  |  | $1 \mathrm{OH}=-100 \mu \mathrm{~A}$ |
| Input Leak Current | ILI | -1.0 |  | +1.0 | $\mu \mathrm{A}$ | $0<V_{\text {IN }}<V_{C C}$ |
| Output Leak Current | ILO | -10 |  | +10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\text {cc }}$ or GND |
| Input Leakage Current (Bus Hold Low) | IBHL | 50 |  | 400 | $\mu \mathrm{A}$ | $\begin{gathered} V_{I N}=0.8 \mathrm{~V} \\ { }_{3} \end{gathered}$ |
| Input Leakage Current (Bus Hold High) | IBHH | -50 |  | -400 | $\mu \mathrm{A}$ | $\begin{gathered} \mathrm{V}_{\mathrm{IN}}=3.0 \mathrm{~V} \\ * 4 \end{gathered}$ |
| Bus Hold Low Overdrive | IBHLO |  |  | 600 | $\mu \mathrm{A}$ | *5 |
| Bus Hold High Overdrive | Івнно |  |  | -600 | $\mu \mathrm{A}$ | *6 |
| Operating Power Supply Current | ${ }^{\prime} \mathrm{CC}$ |  |  | 10 | $\mathrm{mA} / \mathrm{MHz}$ | $\begin{aligned} & V_{I L}=G N D \\ & V_{I H}=V_{C C} \end{aligned}$ |
| StandbySupply Current | I ccs |  |  | 500 | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{C C}$ or GND Outputs Unloaded CLK=GND or VCC |
| Input Capacitance | $\mathrm{C}_{\text {in }}$ |  |  | 10 | pF | * 7 |
| Output Capacitance | Cout |  |  | 15 | pF | *7 |
| I/O Capacitance | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  |  | 20 | pF | * 7 |

*3. Test conditions is to lower $\mathrm{V}_{\mathrm{IN}}$ to GND and then raise $\mathrm{V}_{\mathrm{IN}}$ to 0.8 V on pins 2-16 and 35-39.
*4. Test condition is to raise $V_{I N}$ to $V_{C C}$ and then lower $V_{I N}$ to 3.0 V on pins 2-16, 26-32, and 34-39.
*5. An external driver must source at least IBHLO to switch this node from LOW to HIGH.
*6. An external driver must sink at least IBHHO to switch this node from HIGH to LOW.
*7. Test Conditions: a) Freq $=1 \mathrm{MHz}$.
b) Ummeasured Pins at GND.
c) $\mathrm{V}_{\mathrm{IN}}$ at 5.0 V or GND.

## A.C. CHARACTERISTICS

(MSM80C88A-10: $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ to $5.25 \mathrm{~V}, \mathrm{Ta}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ )
Minimum Mode System
Timing Requirements

| Parameter | Symbol | MSM80C88A-10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| CLK Cycle Period | TCLCL | 100 | DC | ns |
| CLK Low Time | TCLCH | 46 |  | ns |
| CLK High Time | TCHCL | 44 |  | ns |
| CLK Rise Time (From 1.0 V to 3.5 V ) | TCH1CH2 |  | 10 | ns |
| CLK Fall Time (From 3.5 V to 1.0 V ) | TCL2CL1 |  | 10 | ns |
| Data in Setup Time | TDVCL | 20 |  | ns |
| Data in Hold Time | TCLDX | 10 |  | ns |
| RDY Setup Time into MSM 82C84A (See Notes 1, 2) | TR1VCL | 35 |  | ns |
| RDY Hold Time into MSM 82C84A (See Notes 1, 2) | TCLR1X | 0 |  | ns |
| READY Setup Time into MSM 80C88A | TRYHCH | 33 |  | ns |
| READY Hold Time into MSM 80C88A | TCHRYX | 20 |  | ns |
| READY inactive to CLK (See Note 3) | TRYLCL | -8 |  | ns |
| HOLD Setup Time | THVCH | 20 |  | ns |
| INTR, NMI, TEST Setup Time (See Note 2) | TINVCH | 15 |  | ns |
| Input Rise Time (Except CLK) (From 0.8V to 2.0 V ) | TILIH |  | 15 | ns |
| Input Fall Time (Except CLK) (From 2.0 V to 0.8 V ) | TIHIL |  | 15 | ns |

Timing Responses

| Parameter | Symbol | MSM80C88A-10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| Address Valid Delay | TCLAV | 10 | 60 | ns |
| Address Hold Time | TCLAX | 10 |  | ns |
| Address Float Delay | TCLAZ | tCLAX | 50 | ns |
| ALE Width | TLHLL | TCLCH-10 |  | ns |
| ALE Active Delay | TCLLH |  | 40 | ns |
| ALE Inactive Delay | TCHLL |  | 45 | ns |
| Address Hold Time to ALE Inactive | TLLAX | TCHCL-10 |  | ns |
| Data Valid Delay | TCLDV | 10 | 60 | ns |
| Data Hold Time | TCHDX | 10 |  | ns |
| Data Hold Time after $\overline{W R}$ | TWHDX | TCLCH-25 |  | ns |
| Control Active Delay 1 | TCVCTV | 10 | 55 | ns |
| Control Active Delay 2 | TCHCTV | 10 | 50 | ns |
| Control Inactive Delay | TCVCTX | 10 | 55 | ns |
| Address Float to $\overline{\mathrm{RD}}$ Active | TAZRL | 0 |  | ns |
| $\overline{\mathrm{RD}}$ Acrive Delay | TCLRL | 10 | 70 | ns |


| Parameter. | Symbol | MSM80C88A-10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| $\overline{\mathrm{RD}}$ Inactive Delay | TCLRH | 10 | 60 | ns |
| $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TRHAV | TCLCL-35 |  | ns |
| HLDA Valid Delay | TCLHAV | 10 | 60 | ns |
| $\overline{\mathrm{RD}}$ Width | TRLRH | 2TCLCL-40 |  | ns |
| $\overline{W R}$ Width | TWLWH | 2TCLCL-35 |  | ns |
| Address Valid to ALE Low | TAVAL | TCLCH-35 |  | ns |
| Output Rise Time (From 0.8 V to 2.0) | TOLOH |  | 15 | ns |
| Output Fall Time (From 2.0 V to 0.8 V ) | TOHOL |  | 15 | ns |

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

Maximum Mode System (Using MSM 82C88 Bus Controller) Timing Requirements

| Parameter | Symbol | MSM80C88A-10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| CLK Cycle Period | TCLCL | 100 | DC | ns |
| CLK Low Time | TCLCH | 46 |  | ns |
| CLK High Time | TCHCL | 44 |  | ns |
| CLK Rise Time (From 1.0 V to 3.5 V ) | TCH1CH2 |  | 10 | ns |
| CLK Fall Time (From 3.5 V to 1.0 V ) | TCL2CL1 |  | 10 | ns |
| Data in Setup Time | TDVCL | 20 |  | ns |
| Data in Hold Time | TCLDX | 10 |  | ns |
| RDY Setup Time into MSM 82C84A (See Notes 1, 2) | TR1VCL | 35 |  | ns |
| RDY Hold Time into MSM 82C84A (See Notes 1, 2) | TCLR1X | 0 |  | ns |
| READY Setup Time into MSM 80C88A | TRYHCH | 33 |  | ns |
| READY Hold Time into MSM 80C88A | TCHRYX | 20 |  | ns |
| READY inactive to CLK (See Note 3) | TRYLCL | -8 |  | ns |
| Set up Time for Recognition (NMI, INTR, TEST) (See Note 2) | TINVCH | 15 |  | ns |
| $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Setup Time | TGVCH | 15 |  | ns |
| $\overline{\mathrm{RQ}}$ Hold Time into MSM 80C88A | TCHGX | 20 |  | ns |
| Input Rise Time (Except CLK) (From 0.8 V to 2.0 V ) | TILIH |  | 15 | ns |
| Input Fall Time (Except CLK) (From 2.0 V to 0.8 V ) | TIHIL |  | 15 | ns |

Timing Responses

| Parameter | Symbol | MSM80C88A-10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| Command Active Delay (See Note 1) | TCLML | 5 | 35 | ns |
| Command Inactive Delay (See Note 1) | TCLMH | 5 | 45 | ns |
| READY Active to Status Passive (See Note 4) | TRYHSH |  | 45 | ns |
| Status Active Delay | TCHSV | 10 | 45 | ns |
| Status Inactive Delay | TCLSH | 10 | 60 | ns |
| Address Valid Delay | TCLAV | 10 | 60 | ns |
| Address Hold Time | TCLAX | 10 |  | ns |
| Address Float Delay | TCLAZ | TCLAX | 50 | ns |
| Status Valid to ALE High (See Note 1) | TSVLH |  | 25 | ns |
| Status Valid to MCE High (See Note 1) | TSVMCH |  | 30 | ns |
| CLK low to ALE Valid (See Note 1) | TCLLH |  | 25 | ns |
| CLK Low to MCE High (See Note 1) | TCLMCH |  | 25 | ns |
| ALE Inactive Delay (See Note 1) | TCHLL | 4 | 25 | ns |
| Data Valid Delay | TCLDV | 10 | 60 | ns |
| Data Hold Time | TCHDX | 10 |  | ns |
| Control Active Delay (See Note 1) | TCVNV | 5 | 45 | ns |
| Control Inactive Delay (See Note 1) | TCVNX | 5 | 45 | ns |
| Address Float to $\overline{\mathrm{RD}}$ Active | TAZRL | 0 |  | ns |
| $\overline{\mathrm{RD}}$ Active Delay | TCLRL | 10 | 70 | ns |
| $\overline{R D}$ Inactive Delay | TCLRH | 10 | 60 | ns |
| $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TRHAV | TCLCL-35 |  | ns |
| Direction Control Active Delay (See Note 1) | TCHDTL |  | 50 | ns |
| Direction Control Inactive Delay (See Note 1) | TCHDTH |  | 30 | ns |
| $\overline{\mathrm{GT}}$ Active Delay (See Note 5) | TCLGL | 0 | 38 | ns |
| $\overline{\mathrm{GT}}$ Inactive Delay | TCLGH | 0 | 45 | ns |
| $\overline{\mathrm{RD}}$ Width | TRLRH | 2TCLCL-40 |  | ns |
| Output Rise Time (From 0.8 V to 2.0 V ) | TOLOH |  | 15 | ns |
| Output Fall Time (From 2.0 V to 0.8 V ) | TOHOL |  | 15 | ns |

Notes: 1. Signals at MSM 82C84A or MSM 82C88 are shown for reference only.
2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.
3. Applies only to $T 2$ state ( 8 ns into T 3 )
4. Applies only to $T 3$ and wait states.
5. $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}\left(\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}_{0}, \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}_{1}\right)$
A.C. TESTING INPUT, OUTPUT WAVEFORM


## A.C. TESTING LOAD CIRCUIT



C includes Jig capacitance

## TIMING CHART

## Minimum Mode



## Minimum Mode (Continued)



## NOTES:

1. All signals switch between $\mathrm{VOH}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ unless otherwise specified.
2. RDY is sampled near the end of T2, T3, TW to determine if TW machines states are to be inserted.

3 Two INTA cycles run back-to-back. The MSM80C88A LOCAL ADDR/DATA BUS is floating during both INTA cycles. Control signals shown for second INTA cycle.
4. Signals at MSM 82C84A shown for reference only.
5. All timing measurements are made at 1.5 V unless otherwise noted.


Maximum Mode (Continued)


## NOTES:

1. All signals switch between $\mathrm{V}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ unless otherwise specified

2 RDY is sampled near the end of T2, T3, TW to determine if TW machines states are to be inserted
3 Cascade address is valid between first and second INTA cycle.
4. Two INTA cycles run back-to-back. The MSM 80C88A LOCAL ADDR/DATA BUS is floating during both INTA cycles Control for pointer address is shown for second INTA cycle.
5. Signal at MSM 82C84A and MSM82C88 shown for reference only
6. The sssuance of the MSM $82 C 88$ command and control signals $\overline{\text { MRDC }}, \overline{M W T C}, \overline{A M W C}, \overline{\text { IORC }}, \overline{\text { IOWC }}, \overline{\mathrm{AIOWC}}, \overline{\text { INTA }}$ and DEN) lags the active high MSM 82C88 CEN.
7 All timing measurements are made at 1.5 V unless otherwise noted
8 Status inactive in state just prior to T4

Asynchronous Signal Recognition


Request/Grant Sequence Timing (Maximum Mode Only)


Hold/Hold Acknowledge Timing (Minimum Mode Only)


## PIN DESCRIPTION

## AD0-AD7

ADDRESS DATA BUS: Input/Output
These lines are the multiplexed address and data bus.
These are the address bus at T1 cycle and the data bus at T2, T3, TW and T4 cycle.
T2, T3, TW and T4 cycle.
These lines are high impedance during interrupt acknowledge and hold acknowledge.

## A8-A15

## ADDRESS BUS: Output

These lines are the address bus bits 8 thru 15 at all cycles.
These lines do not have to be latched by an ALE signal.
These lines are high impedance during interrupt acknowledge and hold acknowledge.

## A16/S3, A17/S4, A18/S5, A19/S6

ADDRESS/STATUS: Output
These are the four most significant address as at the T1, cycle.
Accessing I/O port address, these are low at T1 Cycles.
These lines are Status lines at the T2, T3, TW and T4 Cycle.
S5 indicate interrupt enable Flag.
S3 and S4 are encoded as shown.

| S3 | S4 | Characteristics |
| :---: | :---: | :--- |
| 0 | 0 | Alternate Data |
| 1 | 0 | Stack |
| 0 | 1 | Code or None |
| 1 | 1 | Data |

These lines are high impedance during hold acknowledge.

## $\overline{\mathrm{RD}}$

READ: Output
This lines indicates that the CPU is in a memory or I/O read cycle.
This line is the read strobe signal when the CPU reads data from a memory or I/O device.
This line is active low.
This line is high impedance during hold acknowledge.

## READY

READY: Input
This line indicates to the CPU that an addressed memory or I/O device is ready to read or write.
This line is active high.
IF the setup and hold time are outof specification, an illegal operation will occur.

## INTR

INTERRUPT REQUEST: Input
This line is a level triggered interrupt request signal which is sampled during the last clock cycle of instruction and string manipulations.
It can be internally masked by software.
This signal is active high and internally synchronized.

## $\overline{T E S T}$

TEST: Input
This line is examined by a "WAIT" instruction. When TEST is high, the CPU enters an idle cycle. When TEST is low, the CPU exits an idle cycle.

## NMI

NON MASKABLE INTERRUPT: Input
This line causes a type 2 interrupt. NMI is not maskable.
This signal is internally synchronized and needs a 2 clock cycle pulse width.

## RESET

RESET: Input
This signal causes the CPU to initialize immediately. This signal is active high and must be at least four clock cycles.

## CLK

CLOCK: Input
This signal provide the basic timing for an internal circuit.

## MN/ $\overline{M X}$

## MINIMUM/MAXIMUM: Input

This signal selects the CPU's operate mode.
When $V_{\text {CC }}$ is connected, the CPU operates in minimum mode.
When GND is connected, the CPU operates in maximum mode.

## $v_{c c}$

$\mathrm{V}_{\mathrm{CC}}+5 \mathrm{~V}$ supplied.

## GND

GROUND

The following pin function descriptions are for maximum mode only.
Other pin functions are already described.

## $\overline{\mathbf{s} 0}, \overline{\mathbf{s} 1}, \overline{\mathbf{s} 2}$

STATUS: Output
These lines indicate bus status and they are used by the MSM82C88 Bus Controller to generate all memory and I/O access control signals.
These lines are high impedance during hold acknowledge.
These status lines are encoded as shown.

| $\overline{\mathrm{S} 2}$ | $\overline{\mathrm{~S} 1}$ | $\overline{\mathrm{SO}}$ | Characteristics |
| :---: | :---: | :---: | :--- |
| 0 (LOW) | 0 | 0 | Interrupt acknowledge |
| 0 | 0 | 1 | Read I/O Port |
| 0 | 1 | 0 | Write I/O Port |
| 0 | 1 | 1 | Halt |
| 1 (HIGH) | 0 | 0 | Code Access |
| 1 | 0 | 1 | Read Memory |
| 1 | 1 | 0 | Write Memory |
| 1 | 1 | 1 | Passive |

## $\overline{\mathbf{R Q}} / \overline{\mathbf{G T O}}$

$\overline{\mathrm{RQ}} / \overline{\mathbf{G T} 1}$
REQUEST/GRANT: Input/Output
These lines are used for Bus Request from other devices and Bus GRANT to other devices.
These lines are bidirectional and active low.

## $\overline{\text { LOCK }}$

LOCK: Output
This line is active low.
When this line is low, other devices can not gain control of the bus.
This line is high impedance during hold acknowledge.

## OSO/OS1

QUEUE STATUS: Output
These are Queue Status Lines that indicate internal instruction queue status.

| QS1 | QS0 | Characteristics |
| :---: | :---: | :--- |
| 0 (LOW) | 0 | No Operation |
| 0 | 1 | First Byte of Op Code from <br> Queue |
| 1 (HIGH) | 0 | Empty the Queue |
| 1 | 1 | Subsequent Byte from Queue |

The following pin function descriptions are minimum mode only. Other pin functions are already described.

## $10 / \bar{M}$

STATUS: Output
This line selects memory address space or 1/O address space.

When this line is low, the CPU selects memory address space and when it is high, the CPU selects I/O address space.
This line is high impedance during hold acknowledge.

## $\overline{W R}$

WRITE: Output
This line indicates that the CPU is in a memory or 1/O write cycle.
This line is a write strobe signal when the CPU writes data to memory or an I/O device.
This line is active low.
This line is high impedance during hold acknowledge.

## $\overline{\text { INTA }}$

INTERRUPT ACKNOWLEDGE: Output
This line is a read strobe signal for the interrupt accknowledge cycle.
This line is active low.

## ALE

## ADDRESS LATCH ENABLE: Output

This line is used for latching an address into the MSM82C12 address latch it is a positive pulse and the trailing edge is used to strobe the address. This line in never floated.

## DT/R

DATA TRANSMIT/RECEIVE: Output
This line is used to control the direction of the bus transceiver.
When this line is high, the CPU transmits data, and when it is low, the CPU receive data.
This line is high impedance during hold acknowledge.

## $\overline{\text { DEN }}$

DATA ENABLE: Output
This line is used to control the output enable of the bus transceiver.
This line is active low. This line is high impedance during hold acknowledge.

## HOLD

HOLD REQUEST: Input
This line is used for a Bus Request from an other device.
This line is active high.

## HLDA

HOLD ACKNOWLEDGE: Output
This line is used for a Bus Grant to an other device.
This line is active high.

## $\overline{\mathbf{S S O}}$

STATUS: Output
This line is logically equivalent to $\overline{\mathrm{SO}}$ in the maximum mode.

## STATIC OPERATION

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

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

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

The BIU performs instruction fetch and queueing, operand fetch, DATA read and write address relocation and basic bus control. By performing instruction prefetch while waiting for decoding and execution of instruction, the CPU's performance is increased. Up to 4-bytes fo instruction stream can be queued.

EU receives pre-fetched instructions from the BIU queue, decodes and executes instructions and provides an un-relocated operand address to the BIU.

## MEMORY ORGANIZATION

The MSM80C88A has a 20-bit address to memory. Each address has 8-bit data width. Memory is organized 00000 H to FFFFFH and is logically divided into four segments: code, data, extra data and stack segment. Each segment contains up to 64 Kbytes and locates on a 16-byte boundary. (Fig. 3a)

All memory references are made relative to a segment register according to a select rule. Memory location FFFFOH is the start address after reset, and 00000 H through 003 FFH are reserved as an interrupt pointer. There are 256 types of interrupt pointer;

Each interrupt type has a 4-byte pointer element consisting of a 16 -bit segment address and a 16 -bit offset address.

## FUNCTIONAL DESCRIPTION

## GENERAL OPERATION

The internal function of the MSM80C88A consist of a Bus Interface Unit (BIU) and an Execution Unit (EU). These units operate mutually but perform as separate processors.

## Memory Organization



Reserved Memory Locations


| Memory Reference Need | Segment Register Used | Segment Selection Rule |
| :--- | :---: | :--- |
| Instructions | CODE (CS) | Automatic with all instruction prefetch. |
| Stack | STACK (SS) | All stack pushes and pops. Memory references <br> relative to BP base register except data references. |
| Local Data | DATA (DS) | Data references when relative to stack, destination <br> of string operation, or explicitly overridden. |
| External (Global) Data | EXTRA (ES) | Destination of string operations: Explicitly selected <br> using a segment override. |

## MINIMUM AND MAXIMUM MODES

The MiSM80C88A has two system modes: minimum and maximum. When using the maximum mode, it is easy to organize a multiple-CPU system with the MSM 82C88 Bus Controller which generates the bus control signal.

When using the minimum mode, it is easy to organize a simple system by generating the bus control signal itself. $\mathrm{MN} / \overline{\mathrm{MX}}$ is the mode select pin. Definition of 24-31, 34 pin changes depends on the MN/MX pin.

## BUS OPERATION

The MSM80C88A has a time multiplexed address and data bus. If a non-multiplexed bus is desired for the system, it is only needed to add the address latch.

A CPU bus cycle consists of at least four clock cycles: T1, T2, T3 and T4. (Fig. 4)

The address output occurs during T 1 , and data transfer occurs during T3 and T4. T2 is used for changing the direction of the bus during read operation. When the device which is accessed by the CPU is not ready to data transfer and send to the CPU "NOT READY" is indicated TW cycles are inserted between T3 and T4.

When a bus cycle is not needed, T1 cycles are inserted between the bus cycles for internal execution. At the T1 cycle an ALE signal is output from the CPU or the MSM82C88 depending in MN/ $\overline{M X}$. at the trailing edge of an ALE, a valid address may be latched. Status bits S0, S1 and S2 are uased, in maximum mode, by the bus controller to recognize the type of bus operation according to the following table.

| $\overline{\mathrm{S} 2}$ | $\overline{\mathrm{~S} 1}$ | $\overline{\mathrm{SO}}$ | Characteristics |
| :---: | :---: | :---: | :--- |
| 0 (LOW) | 0 | 0 | Interrupt acknowledge |
| 0 | 0 | 1 | Read I/O |
| 0 | 1 | 0 | Write I/O |
| 0 | 1 | 1 | Halt |
| $1(\mathrm{HIGH})$ | 0 | 0 | Instruction Fetch |
| 1 | 0 | 1 | Read Data from Memory |
| 1 | 1 | 0 | Write Data to Memory |
| 1 | 1 | 1 | Passive (no bus cycle) |

Status bit S3 through S6 are multiplexed with A16-A19, and therefore they are valid during T2 through T4. S3 and S4 indicate which segment register was selected on the bus cycle, according to the following table.

| S4 | S3 | Characteristics |
| :---: | :---: | :--- |
| $0($ LOW ) | 0 | Alternate Data (Extra Segment) |
| 0 | 1 | Stack |
| $1(\mathrm{HIGH})$ | 0 | Code or None |
| 1 | 1 | Data |

S5 indicates interrupt enable Flag.

## I/O ADDRESSING

The MSM80C88A has a 64 Kbyte I/O. When the CPU accesses an I/O device, address A0-A15 are in same format as a memory access, and A16-A19 are low.

1/O ports address are same as four memory.

## Basic System Timing



## EXTERNAL INTERFACE

## RESET

CPU initialization is executed by the RESET pin. The MSM80C88A's RESET High signal is required for greater than 4 clock cycles.

The rising edge of RESET terminates the present operation immediately. The falling edge of RESET triggers an internal reset requence for approximately 10 clock cycles. After internal reset sequence is finished, normal operation begins from absolute location FFFFOH.

## INTERRUPT OPERATIONS

The interrupt operation is classified as software or hardware, and hardware interrupt is classified as nonmarkable or maskable.

An interrupt causes a new program location which is defined by the interrupt pointer table, according to the interrupt type. Absolute location 00000 H through 003 FFH is reserved for the interrupt pointer table. The interrupt pointer table consists of 256 elements. Each element is 4 bytes in size and corresponds to an 8-bit type number which is sent from an interrupt request device during the interrupt acknowledge cycle.

## NON-MASKABLE INTERRUPT (NMI)

The MSM80C88A has a non-maskable Interrupt (NM1) which is of higher priority than a maskable interrupt request (INTR).

An NM1 request pulse width needs minimum of 2 clock cycles. The NM1 will be serviced at the end of the current instruction or between string manipulations.

## MASKABLE INTERRUPT (INTR)

The MSM80C88A provides another interrupt request (INTR) which can be masked by software. INTR is level triggered, so it must be held until interrupt request is acknowledged.

The INTR will be serviced at the end of the current instruction or between string manipulations.

## INTERRUPT ACKNOWLEDGE

During the interrupt acknowledge sequence, further interrupts are disabled. The interrupt enable bit is reset by any interrupt, after which the Flag register is automatically pushed onto the stack. During an acknowledge sequence, the CPU emits the lock signal from T2 of first bus cycle to T2 of second bus cycle. At the second bus cycle, a byte is fetched from the external device as a vector which identifies the type of interrupt. This vector is multiplied by four and used as an interrupt pointer address (INTR only).

The Interrupt Return (IRET) instruction includes a Flag pop operation which returns the original interrupt enable bit when it restores the Flag.

## HALT

When a Halt instruction is executed, the CPU enter Halt state. An interrupt request or RESET will force the MSM80C88A out of the Halt state.

## SYSTEM TIMING-MINIMUM MODE

A bus cycle begins at $T 1$ with an ALE signal. The trailing edge of ALE is used to latch the address. From T 1 to T 4 the $10 / \overline{\mathrm{M}}$ signal indicates a memory or $1 / 0$ operation. From T2 to T4, the address data bus changes the address bus to the data bus.

The read ( $\overline{R D}$ ), write ( $\overline{W R}$ ), and interrupt acknowledge (INTA) signals caused the addressed device to enable the data bus. These signals become active at the beginning of T 2 and inactive at the beginning of T 4 .

## SYSTEM TIMING-MAXIMUM MODE

In maximum mode, the MSM82C88 Bus Controller is added to system. The CPU sends status information to the Bus Controller. Bus timing signals are generated by the Bus Controller. Bus timing is almost the same as in minimum mode.

Interrupt Acknowledge Sequence


## BUS HOLD CIRCUITRY

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


Figure 6a. Bus hold circuitry pin 2-16, 35-39.


Figure 6b. Bus hold circuitry pin 26-32, 34

| MOV = Move: | 7 | 6 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 |  | 543 | 210 |  | $\begin{array}{llllllll}6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$ |  | 6 |  | 43 | 210 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Register/memory to/from register |  | 0 |  | 0 | 0 | 1 | 0 | d | w | mod |  | reg | $\mathrm{r} / \mathrm{m}$ |  |  |  |  |  |  |  |
| Immediate to register/memory |  | 1 |  | 0 | 0 |  |  | 1 | w | mod |  | 000 | r/m |  | data |  |  |  | data if | $w=1$ |
| Immediate to register |  | 0 |  | 1 | 1 | w |  | reg |  |  |  | data |  |  | data if $w=1$ |  |  |  |  |  |
| Memory to accumulator |  | 0 |  | 1 | 0 | 0 | 0 | 0 | w |  |  | addr-low |  |  | addr-high |  |  |  |  |  |
| Accumulator to memory |  | 0 |  | 1 | 0 | 0 | 0 | - 1 | w |  |  | addr-low |  |  | addr-high |  |  |  |  |  |
| Register/memory to segment register |  | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | mod |  | 0 reg | $\mathrm{r} / \mathrm{m}$ |  |  |  |  |  |  |  |
| Segment register to register/memory |  | 0 | 0 | 0 | 0 | 1. | 1 | 0 | 0 | mod |  | 0 reg | r/m |  |  |  |  |  |  |  |
| PUSH = Push: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Register/memory |  |  |  | 1 | 1 | 1 |  | 1 |  | mod | d | 110 | r/m |  |  |  |  |  |  |  |
| Register |  |  |  | 0 | 1 | 0 |  | reg |  |  |  |  |  |  |  |  |  |  |  |  |
| Segment register |  |  |  | 0 |  | eg | 1 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| POP = Pop : |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Register/memory |  | 0 |  | 0 | 0 | 1 | 1 | 1 | 1 | mod | d | 000 | r/m |  |  |  |  |  |  |  |
| Register |  |  |  | 0 | 1 | 1 |  | reg |  |  |  |  |  |  |  |  |  |  |  |  |
| Segment register |  |  |  | 0 |  | eg | 1 | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |
| XCHG = Exchange: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Register/memory with register |  |  |  | 0 | 0 | 0 | 1 | 1 | w | mod | d | reg | r/m |  |  |  |  |  |  |  |
| Register with accumulator |  | 0 | 0 | 0 | 1 | 0 |  | reg |  |  |  |  |  |  |  |  |  |  |  |  |
| IN = Input from: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Fixed port |  | 1 |  | 1 | 0 | 0 | 1 | 0 | $w$ |  |  | port |  |  |  |  |  |  |  |  |
| Variable port |  | 1 |  | 1 |  | 1 | 1 | 0 | w |  |  |  |  |  |  |  |  |  |  |  |
| OUT = Output to: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Fixed port |  | 1 |  | 1 | 0 | 0 | 1 | 1 | w |  |  | port |  |  |  |  |  |  |  |  |
| Variable port |  | 1 |  | 1 | 0 | 1 | 1 | 1 | w |  |  |  |  |  |  |  |  |  |  |  |
| XLAT = Translate byte to AL |  | 1 |  | 0 | 1 | 0 | 1 | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |
| LEA = Load EA to register |  | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | mod |  | reg |  |  |  |  |  |  |  |  |
| LDS = Load pointer to DS |  | 1 |  | 0 | 0 | 0 | 1 | 0 | 1 | mod |  | reg | $\mathrm{r} / \mathrm{m}$ |  |  |  |  |  |  |  |
| LES = Load pointer to ES |  | 1 |  | 0 | 0 | 0 | 1 | 0 | 0 | mod |  | reg | $r / m$ |  |  |  |  |  |  |  |
| LAHF = Load AH with flags |  | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |
| SAHF = Store AH into flags |  | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| PUSHF = Push flags |  | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| POPF = Pop flags |  |  |  | 0 | 1 | 1 | 1 | 0 | 1 |  |  |  |  |  |  |  |  |  |  |  |

## ARITHMETIC

| ADD = Add: |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Reg./memory with register to either | $\begin{array}{lllllllll}0 & 0 & 0 & 0 & 0 & 0 & d & w\end{array}$ | $\bmod \quad \mathrm{reg} \quad \mathrm{r} / \mathrm{m}$ |  |  |
| Immediate to register/memory | $\begin{array}{cccccccc}1 & 0 & 0 & 0 & 0 & 0 & s & w\end{array}$ | $\bmod 000000 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate to accumulator | $\begin{array}{llllllll}0 & 0 & 0 & 0 & 0 & 1 & 0 & w\end{array}$ | data | data if $w=1$ |  |
| ADC = Add with carry: |  |  |  |  |
| Reg./memory with register to either | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 0 & 0 & d & w\end{array}$ | mod reg r/m |  |  |
| Immediate to register/memory | $\begin{array}{llllllll}1 & 0 & 0 & 0 & 0 & 0 & s & w\end{array}$ | $\bmod 0010008 / m$ | data | data if $\mathrm{s}: \mathbf{w}=01$ |
| Immediate to accumulator | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 0 & 1 & 0 & w\end{array}$ | data | data if $w=1$ |  |
| INC = Increment : |  |  |  |  |
| Register/memory | $\begin{array}{lllllllll}1 & 1 & 1 & 1 & 1 & 1 & 1 & w\end{array}$ |  |  |  |
| Register | $\begin{array}{llllll}0 & 1 & 0 & 0 & 0 & \text { reg }\end{array}$ |  |  |  |
| AAA $=$ ASCII adjust for add | $\begin{array}{llllllll}0 & 0 & 1 & 1 & 0 & 1 & 1 & 1\end{array}$ |  |  |  |
| DAA $=$ Decimal adjust for add | $\begin{array}{llllllll}0 & 0 & 1 & 0 & 0 & 1 & 1 & 1\end{array}$ |  |  |  |
| SUB = subtract: |  |  |  |  |
| Reg./memory and register to either | $\begin{array}{lllllllll}0 & 0 & 1 & 0 & 1 & 0 & d & w\end{array}$ | mod reg r/m |  |  |
| Immediate from register/memory | $\begin{array}{cccccccc}1 & 0 & 0 & 0 & 0 & 0 & s & w\end{array}$ | $\bmod 1{ }^{1}$ | data | data if s:w $=01$ |
| Immediate from accumulator | $\begin{array}{llllllll}0 & 0 & 1 & 0 & 1 & 1 & 0 & w\end{array}$ | data | data if $w=1$ |  |
| SBB $=$ Subtract with borrow: |  |  |  |  |
| Reg./memory and register to either | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 1 & 0 & d & w\end{array}$ | $\bmod \quad \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  |
| Immediate from register/memory | $1 \begin{array}{llllllll}1 & 0 & 0 & 0 & 0 & 0 & s & w\end{array}$ | $\bmod 00181 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate from accumulator | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 1 & 1 & 0 & w\end{array}$ | data | data if $w=1$ |  |
| DEC = Decrement : |  |  |  |  |
| Register/memory | $\begin{array}{lllllllll}1 & 1 & 1 & 1 & 1 & 1 & 1 & w\end{array}$ | $\bmod 000018$ |  |  |
| Register | $\begin{array}{llllll}0 & 1 & 0 & 0 & 1 & \text { reg }\end{array}$ |  |  |  |
| NEG = Change sign | $\begin{array}{lllllllll}1 & 1 & 1 & 1 & 0 & 1 & 1 & w\end{array}$ |  |  |  |
| CMP = Compare : |  |  |  |  |
| Register/memory and register | $\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & 0 & d & w\end{array}$ | mod reg r/m |  |  |
| Immediate with register/memory | $\begin{array}{llllllll}1 & 0 & 0 & 0 & 0 & 0 & s & w\end{array}$ | $\bmod 1 \begin{array}{llll}1 & 1 & 1\end{array}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |
| Immediate with accumulator | $\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & 1 & 0 & w\end{array}$ | data | data if $\mathbf{w}=1$ |  |
| AAS = ASCII adjust for subtract | $\begin{array}{lllllllll}0 & 0 & 1 & 1 & 1 & 1 & 1 & 1\end{array}$ |  |  |  |

190


## LOGIC



STRING MANIPULATION


| CJMP = Conditional JMP |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JE/JZ = Jump on equal/zero |  |  |  |  |  |  | 0 | 1 | 0 | 0 |  | disp |  |  |  |  |
| JZ/JNGE = Jump on less/not greater or equal |  |  |  | 1 | 1 |  | 1 | 1 |  | 0 |  | disp |  |  |  |  |
| JLE/JNG = Jump on less or equal/not greater |  |  | 1 | 1 | 1 |  | 1 | 1 |  | 0 |  | disp |  |  |  |  |
| JB/JNAE = Júmp on below/not above or equal |  |  | 1 | 1 | 1 |  | 0 | 0 | 1 | 0 |  | disp |  |  |  |  |
| JBE/JNA = Jump on below or equal/not above |  |  | 1 | 1 | 1 |  | 0 | 1 | 1 | 0 |  | disp |  |  |  |  |
| JP/JPE = Jump on parity/parity even |  |  | 1 | 1 | 1 |  | 1 | 0 | 1 | 0 |  | disp |  |  |  |  |
| JO = Jump on over flow |  |  |  | 1 | 1 |  | 0 | 0 | 0 | 0 |  | disp |  |  |  |  |
| JS = Jump on sign |  |  | 1 | 1 | 1 |  | 1 | 0 | 0 | 0 |  | disp |  |  |  |  |
| JNE/JNZ = Jump on not equal/not zero |  |  | 1 | 1 | 1 |  | 0 | 1 | 0 | 1 |  | disp |  |  |  |  |
| JNL/JGE = Jump on not less/greater or equal |  |  | 1 | 1 | 1 |  | 1 | 1 | 0 | 1 |  | disp |  |  |  |  |
| JNLE/JG = Jump on not less or equal/greatei |  |  | 1 | 1 | 1 |  | 1 | 1 | 1 | 1 |  | disp |  |  |  |  |
| JNB/JAE = Jump on not below/above or equal |  |  | 1 | 1 | 1 |  | 0 | 0 | 1 | 1 |  | disp |  |  |  | : |
| JNBE/JA = Jump on not below or equal/above |  |  | 1 | 1 | 1 |  | 0 | 1 | 1 | 1 |  | disp |  |  |  |  |
| JNP/JPO = Jump on not parity/parity odd |  |  | 1 | 1 | 1 |  | 1 | 0 | 1 | 1 |  | disp |  |  |  |  |
| JNO = Jump on not overflow |  |  |  | 1 | 1 |  | 0 | 0 | 0 | 1 |  | disp |  |  |  |  |
| JNS = Jump on not sign |  |  | 1 | 1 | 1 |  | 1 | 0 | 0 | 1 |  | disp |  |  |  |  |
| LOOP = Loop CX times |  |  | 1 | 1 | 0 |  | 0 | 0 | 1 | 0 |  | disp |  |  |  |  |
| LOOPZ/LOOPE = Loop while zero/equal |  |  | 1 | 1 | 0 |  | 0 | 0 | 0 |  |  | disp |  |  |  |  |
| LOOPNZ/LOOPNE = Loop while not zero/equal |  |  | 1 | 1 | 0 |  | 0 | 0 | 0 | 0 |  | disp |  |  |  |  |
| JCXZ = Jump on CX zero |  |  | 1 | 1 | 0 |  | 0 | 0 | 1 | 1 |  | disp |  |  |  |  |
| INT = Interrupt: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type specified |  |  | 1 |  | 0 |  | 1 |  | 0 | 1 |  | type |  |  |  |  |
| Type 3 |  |  | 1 | 0 | 0 |  |  | 1 |  |  |  |  |  |  |  |  |
| INTO = Interrupt on overflow |  |  | 1 | 0 | 0 |  |  | 1 | 1 |  |  |  |  |  |  |  |
| IRET = Interrupt return |  |  |  |  |  |  |  |  |  | 1 |  |  |  |  |  |  |

## PROCESSOR CONTROL



## CONTROL TRANSFER



## Footnotes:

AL $=8$-bit accumulator
$A X=18$-bit accumulator
$C X=$ Count register
DS = Data segment
$E S=$ Extra segment
Above/below refers to unsigned value
Greater = more positive
Less = less positive (more negative) signed value
If $d=1$ then "to" reg: If $d=0$ then "from" reg.
If $\mathbf{w}=\mathbf{1}$ then word instruction: If $\mathbf{w}=\mathbf{0}$ then byte instruction
If $\mathrm{mod}=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field
If mod $=00$ then DISP $=\mathbf{0}^{*}$, disp-low and disp-high are absent
If mod $=01$ then DISP $=$ disp-low sign-extended to 16 -bits, disp-high is absent
If $\bmod =10$ then DISP $=$ disp-high: disp-low
If $\mathrm{r} / \mathrm{m}=000$ then $E A=(B X)+(S I)+D I S P$
If $\mathrm{r} / \mathrm{m}=001$ then $E A=(B X)+(D I)+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 $r / m=101$ then $E A=(D I)+D I S P$
If $r / m=110$ then $E A=(B P)+D I S P^{*}$
If $r / m=111$ then $E A=(B X)+D I S P$
DISP follows 2 nd byte of instruction (before data if required)

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

If $s: w=01$ then 16 bits of immediate data form the operand
If $\mathrm{s}: \mathrm{w}=11$ then an immediate data byte is sign extended to form the 16-bit operand
If $v=0$ then "count" $=1$ : If $v=1$ then "count"' in (CL)
$x=$ don't care
$z$ is used for string primitives for comparison with ZF FLAG
SEGMENT OVERRIDE PREFIX
001 reg 110
REG is assigned according to the following table:

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

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


## MSM81C55RS/GS/JS MSM81C55-5RS/GS/JS

## GENERAL DESCRIPTION

The MSM81C55/81C55-5 have 2 k bits of static RAM ( 256 byte) with parallel I/O ports and a timer. It uses silicon gate CMOS technology and consumes a standby current of 100 micro ampere, maximum, while the chip is not selected. Featuring a maximum access time of 400 ns , the MSM81 C55/81C55-5 can be used in an 80C85A/80C85A-2 system without using wait states. The parallel $1 / O$ consists of two 8 -bit ports and one 6-bit port (both general purpose). The MSM81C55/81C55-5 also contains a 14-bit programmable counter/timer which may be used for sequencewave generation or terminal count-pulsing.

## FEATURES

- High speed and low power achieved with silicon gate CMOS technology.
- 256 words $\times 8$ bits RAM
- Single power supply, 3 to 6V
- Completely static operation
- On-chip address latch
- 8-bit programmable I/O ports (port A and B)
- TTL Compatible

FUNCTIONAL BLOCK DIAGRAM

- RAM data hold characteristic at 2V
- 6-bit programmable I/O port (port C)
- 14-bit programmable binary counter/timer
- Multiplexed address/data bus
- Direct interface with MSM80C85A
- Direct interface with MSM80C85A-2 (MSM81 C55-5)
- 40 pin Plastic DIP (DIP40-P-600)
- 44 pin PLCC (QFJ44-P-S650)
- 44 pin Plastic QFP(QFP44-P-910-K)
- 44 pin-V Plastic QFP(QFP44-P-910-VK)


PIN CONFIGURATION


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Conditions | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM81C55RS MSM81C55-5RS | MSM81C55GS MSM81C55-5GS | MSM81C55JS MSM81C55-5JS |  |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | Referenced to GND | -0.5 to +7 |  |  | V |
| Input Voltage | $V$ IN |  | -0.5 to $V_{C C}+0.5$ |  |  | V |
| Output Voltage | VOUT |  | -0.5 to $V_{C C}+0.5$ |  |  | $V$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ |  | -55 to +150 |  |  | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $P_{D}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | 1.0 | 0.7 | 1.0 | W |

## OPERATING CONDITION

| Parameter | Symbol | Limits | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | VCC | 3 to 6 | V |
| Operating Temperature | TOP | -40 to +85 | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage (81C55) | $V_{\text {CC }}$ | 4.5 | 5 | 5.5 | V |
| Operating Temperature <br> (81C55) | TOP $^{\prime \prime}$ | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| "L'Level Input | $\mathrm{V}_{\text {IL }}$ | -0.3 |  | +0.8 | V |
| "H"Level Input | $\mathrm{V}_{\text {IH }}$ | 2.2 |  | $\mathrm{~V}_{\mathrm{CC}}+0.3$ | V |
| Supply Voltage (81C55-5) | $\mathrm{V}_{\mathrm{CC}}$ | 4.75 | 5 | 5.25 | V |
| Operating Temperature <br> (81C55-5) | $\mathrm{T}_{\mathrm{OP}}$ | -40 | +25 | +70 | ${ }^{\circ} \mathrm{C}$ |

DC CHARACTERISTICS

| Parameter | Symbol | Conditions |  | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L" Level Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}^{\mathrm{OL}}=2 \mathrm{~mA}$ | $\begin{aligned} & V_{C C}=4.5 \mathrm{~V} \text { to } \\ & 5.5 \mathrm{~V} \\ & T_{a}=-40^{\circ} \mathrm{C} \text { to } \\ & 85^{\circ} \mathrm{C} \end{aligned}$ |  |  | 0.45 | V |
| "H" Level Output Voltage | VOH | $1 \mathrm{OH}=-400 \mu \mathrm{~A}$ |  | 2.4 |  |  | V |
|  |  | $\mathrm{I}_{\mathrm{OH}}=-40 \mu \mathrm{~A}$ |  | 4.2 |  |  | V |
| Input Leak Current | ILI | $0 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Output Leak Current | ILO | $0 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Standby Current | I'ccs | $\begin{aligned} & \mathrm{CE} \geqq \mathrm{~V}_{\mathrm{CC}}-0.2 \mathrm{~V} \\ & \mathrm{~V}_{1 \mathrm{H}} \geqq \mathrm{~V}_{\mathrm{CC}}-0.2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}} \leq 0.2 \mathrm{~V} \\ & \hline \end{aligned}$ |  |  | 0.1 | 100 | $\mu \mathrm{A}$ |
| Mean Operating Current | ${ }^{\prime} \mathrm{CC}$ | Memory cycle time: $1 \mu \mathrm{~s}$ |  |  |  | 5 | mA |

## AC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=4.5\right.$ to $5.5 \mathrm{~V}, \mathrm{Ta}=-40$ to $\left.+80^{\circ} \mathrm{C}\right) \mathrm{MSM81C55H}$
$\left(\mathrm{V}_{\mathrm{CC}}=4.75\right.$ to $5.25 \mathrm{~V}, \mathrm{Ta}=-40$ to $+70^{\circ} \mathrm{C}$ ) MSM81C55-5

| Parameter | Symbol | MSM81C55 |  | MSM81C55-5 |  | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| Address/latch Set-up Time | ${ }^{\text {t }}$ AL | 50 |  | 37 |  | ns | Load capacitance: 150pF |
| Latch/address Holt Time | tha | 30 |  | 30 |  | ns |  |
| Latch/read (write) Delay Time | $t \mathrm{LC}$ | 100 |  | 40 |  | ns |  |
| Read/output Delay Time | trD |  | 170 |  | 140 | ns |  |
| Address/output Delay Time | ${ }^{\text {t }}$ D |  | 400 |  | 330 | ns |  |
| Latch Width | ${ }_{\text {t }}^{\text {LL }}$ | 100 |  | 70 |  | ns |  |
| Read/data Bus Floating Time | tric | 0 | 100 | 0 | 80 | ns |  |
| Read (write)/latch Delay Time | ${ }^{\text {t CL }}$ | 20 |  | 20 |  | ns |  |
| Read (write) Width | ${ }^{\text {t CC }}$ | 250 |  | 200 |  | ns |  |
| Data $\mathrm{In} / \mathrm{write}$ Set-up Time | tow | 150 |  | 100 |  | ns |  |
| Write/data-in Holt Time | tWD | 0 |  | 25 |  | ns |  |
| Recovery Time | trv | 300 |  | 200 |  | ns |  |
| Write/port Output Delay Time | tWP |  | 400 |  | 300 | ns |  |
| Port Input/read Set-up Time | tPR | 70 |  | 50 |  | ns |  |
| Read/port Input Hold Time | tRP | 50 |  | 10 |  | ns |  |
| Strobe/buffer Full Delay Time | tSBF |  | 400 |  | 300 | ns |  |
| Strobe Width | tSS | 200 |  | 150 |  | ns |  |
| Strobe/buffer Empty Delay Time | trBE |  | 400 |  | 300 | ns |  |
| Strobe/interrupt-on Delay Time | ${ }_{\text {t }} \mathrm{I}$ |  | 400 |  | 300 | ns |  |
| Read/interrupt-off Delay Time | tRDI |  | 400 |  | 300 | ns |  |
| Port Input/strobe Set-up Time | tPSS | 50 |  | 20 |  | ns |  |
| Strobe/port-input Hold Time | tPHS | 120 |  | 100 |  | ns |  |
| Strobe/buffer-empty Delty Time | ${ }^{\text {t SBE }}$ |  | 400 |  | 300 | ns |  |
| Write/buffer-full Delay Time | tWBF |  | 400 |  | 300 | ns |  |
| Write/interrupt-off Delay Time | tWI |  | 400 |  | 300 | ns |  |
| Time Output Delay Time Low | tTL |  | 400 |  | 300 | ns |  |
| Time Output Delay Time High | tTH |  | 400 |  | 300 | ns |  |
| Read/data Buse Enable Delay Time | tRDE | 10 |  | 10 |  | ns |  |
| Timer Cycle Time | ${ }^{\text {t }} \mathrm{CYC}$ | 320 |  | 320 |  | ns |  |
| Timer Input Rise and Fall Times | $t_{r}, t_{f}$ |  | 80 |  | 80 | ns |  |
| Timer Input Low Level Time | $t_{1}$ | 80 |  | 40 |  | ns |  |
| Timer Input High Level Time | $t_{2}$ | 120 |  | 70 |  | ns |  |
| WRITE to TIMER-IN for writes which start counting | ${ }^{\text {t }}$ WT | 200 |  | 200 |  | ns |  |
| TIMER-IN to WRITE for wites which start counting | tTW | 0 |  | 0 |  | ns |  |

Note: Timing are measured with $V_{L}=0.8 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{H}}=2.2 \mathrm{~V}$ for both input and output.

TIMING
Read Cycle


Write Cycle


Strobe Input Mode


## Strobe Output Mode



## Basic Input Mode



## Basic Output Mode



Timer Waveforms 1


Note: Periodically output according to the output mode $(\mathrm{m} 1=1)$ programming contents.

Timer Waveforms 2


RAM DATA HOLD CHARACTERISTICS AT LOW SUPPLY VOLTAGE

| Item | Symbol | Condition | Specification |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. | Max. |  |
| Data Holding Supply Voltage | $\mathrm{V}_{\mathrm{CCH}}$ | $\mathrm{V}_{\text {IN }}=O \mathrm{~V}$ or $\mathrm{V}_{\text {CC }}, \mathrm{ALE}=0 \mathrm{~V}$ | 2.0 | - | - | V |
| Data Holding Supply Current | ${ }^{\mathbf{I} C \mathrm{CH}}$ | $\begin{aligned} & V_{C C}=V_{C C H}, A L E=0 \\ & V_{\text {IN }}=0 V \text { or } V_{C C} \end{aligned}$ | - | 0.05 | 20 | $\mu$ |
| Set-up Time | tsu |  | 30 | - | - | ns |
| Hold Time | ${ }^{\text {t }}$ R |  | 20 | - | - | ns |

Two ways to place device in standby mode:
(1) Method using $\overline{\mathrm{CE}}$

(2) Method using RESET


Note: In this case, the C/S register is reset, the port is set into the input mode, and the timer stops.

## PIN FUNCTIONS

| Symbol | Function |
| :---: | :---: |
| RESET | A high level input to this pin resets the chip, places all three $I / O$ ports in the input mode, resets all output latches and stops timer. |
| ALE | Negative going edge of the ALE (Address Latch Enable) input latches $A D_{0 \sim 7}, 10 / \bar{M}$, and $C E$ signals into the respective latches. |
| $A D_{0 \sim 7}$ | Three-state, bi-directional address/data bus. Eight-bit address information on this bus is read into the internal address latch at the negative going edge of the ALE. Eight bits of data can be read from or written to the chip using this bus depending on the state of the WRITE or READ input. |
| $\overline{\mathrm{CE}}$ | When the CE input is high, both read and write operations to the chip are disabled. |
| 10/M | A high level input to this pin selects the internal I/O functions, and a low level selects the memory. |
| $\overline{\mathrm{RD}}$ | If this pin is low, data from either the memory or ports is read onto the $A D_{0 \sim 7}$ lines depending on the state of the $10 / \bar{M}$ line. |
| $\overline{W R}$ | If this pin is low, data on lines $A D_{0 \sim 7}$ is written into either the memory or into the selected port depending on the state of the $10 / \bar{M}$ line. |
| $\begin{gathered} \mathrm{PA}_{0 \sim 7} \\ \left(\mathrm{~PB}_{0 \sim 7}\right) \end{gathered}$ | General-purpose I/O pins. Input/output directions can be determined by programming the command/status (C/S) register. |
| $\mathrm{PC}_{0 \sim 5}$ | Three pins are usable either as general-purpose I/O pins or control pins for the PA and PB ports. When used as control pins, they are assigned to the following functions: <br> PCO: A INTR (port A interrupt) <br> PC1: A BF (port A full) <br> PC2: $\bar{A}$ STB (port A strobe) <br> PC3: B INTR (port B interrupt) <br> PC4: B BF (port B buffer full) <br> PC5: $\bar{B}$ STB (port B strobe) |
| TIMER IN | Input to the counter/timer |
| TIMER OUT | Timer output. When the present count is reached during timer operation, this pin provides a square-wave or pulse output depending on the programmed control status. |
| $V_{\text {CC }}$ | 3-6V power supply |
| GND | GND |

## OPERATION

## Description

The MSM81C55 has three functions as described below.

- 2K bit static RAM ( 256 words $\times 8$ bits)
- Two 8-bit I/O ports (PA and PB) and a 6-bit I/O port (PC)
- 14-bit timer counter

The internal register is shown in the figure below, and the I/O addresses are described in the table below.

$x$ : Don't care.
(1) Programming the Command/Status (C/S) Register The contents of the command register can be written during an I/O cycle by addressing it with
an I/O address of $\times x \times x \times 000$. Bit assignments for the register are shown below:


Port Control Assignment Table

| Pin | ALT1 | ALT2 | ALT3 | ALT4 |
| :---: | :---: | :---: | :---: | :---: |
| PC $_{0}$ | Input port | Output port | A INTR | A INTR |
| PC $_{1}$ | Input port | Output port | A BF | A BF |
| PC $_{2}$ | Input port | Output port | A STB | A STB |
| PC $_{3}$ | Input port | Output port | Output port | B INTR |
| PC $_{4}$ | Input port | Output port | Output port | B BF |
| PC $_{5}$ | Input port | Output port | Output port | B STB |

(2) Reading the C/S Register

The I/O and timer status can be accessed by reading the contents of the Status register located
at $1 / O$ address $\times x \times x x 000$. The status word format is shown below:

(3) PA and PB Registers

These registers may be used as either input or output ports depending on the programmed contents of the C/S register. They may also be used either in the basic mode or in the strobe mode.
I/O address of the PA register: $x \times x \times x 001$
I/O address of the PB register: $\times x \times x \times 010$
(4) PC Register

The PC register may be used as an input port, output port or control register depending on the programmed contents of the $\mathrm{C} / \mathrm{S}$ register. The I/O address of the PC register is $\times \times \times \times \times 011$.
(5) Timer

The timer is a 14 -bit down counter which counts TIMER IN pulses.
The low order byte of the timer register has an I/O address of $x \times x \times x 100$, and the high order byte of the register has an I/O address of $\times x \times x \times 101$.
The count length register (CLR) may be preset with two bytes of data. Bits 0 through 13 are assigned to the count length and bits 14 and 15 specify the timer output mode. A read operation of the CLR reads the contents of the counter and the pertinent output mode. The initial value range which can initially be loaded into the counter is 2 through 3FFF hex. Bit assignments to the timer counter and possible output modes are shown in the following.

$M_{2} M_{1}$
00 Outputs a low-level signal in the latter half (Note 1) of a count period.
01 Outputs a low-level signal in the latter half of a count period, automatically loads the programmed count length, and restarts counting when the TC value is reached.
10 Outputs a pulse when the TC value is reached.
11 Outputs a pulse each time the preset TC value is reached, automatically loads the programmed count length, and restarts from the beginning.
Note 1: When counting an asymmetrical value such as (9), a high level is output during the first period of five, and a low level is output during the second period of four.
Note 2: If an internal counter of the MSM81C55RS/GS receives a reset signal, count operation stops but the counter is not set to a specific initial value or output mode. When restarting count operation after reset, the START command must be executed again through the $\mathrm{C} / \mathrm{S}$ register.
Note that while the counter is counting, you may load a new count and mode into the CLR. Before the new count and mode will be used by the counter, you must issue a START command to the counter.
Please note the timer circuit on the 81C55 is designed to be a square-wave timer, not a event counter. To achieve this, it counts down by twos twice in completing one cycle. Thus, its registers do not contain values directly representing the number of TIMER IN pulse received. After the timer has started counting down, the values residing in the count registers can be used to calculate the actual number of TIMER IN pulse required to complete the timer cycle if desired. To obtain the remaining count, perform the following operations in order:

1. STOP the counter
2. Read in the 16 bit value from the count registers.
3. Reset the upper two mode bits
4. Reset the carry and rotate right one position all 16 bits through carry
5. If carry is set, add $1 / 2$ of the full original count ( $1 / 2$ full count- 1 if full count is odd).

Note: If you started with an odd count and you read the count registers before the third count pulse occurs, you will not be able to recognize whether one or two counts have occurred. Regardless of this, the 81 C 55 always counts out the right number of pulses in generating the TIMER OUT waveforms.


Note: n is the value set in the CLR.
Figures in the diagram refer to counter value.
(6) Standby Mode (see page 7)

The MSM81C55 is placed in standby mode when the high level at the CE input is latched during the negative going edge of ALE. All input ports and the timer input should be pulled up or down to either $\mathrm{V}_{\mathrm{CC}}$ or GND potential.
When using battery back-up, all ports should be set low or in input port mode. The timer output
should be set low. Otherwise, a buffer should be added to the timer output and the battery should be connected to the power supply pins of the buffer.
By setting the reset input to a high level, the standby mode can be selected. In this case, the command register is reset, so the ports automatically set to the input mode and the timer stops.

## 2048 BIT CMOS STATIC RAM WITH I/O PORTS AND TIMER

## GENERAL DESCRIPTION

The MSM81C55/H have $2 k$ bits of static RAM (256 byte) with parallel I/O ports and a timer. It uses silicon gate CMOS technology and consumes a standby current of 100 micro ampere, maximum, while the chip is not selected. Featuring a maximum access time of 400 ns , the MSM81C55/H can be used in an 80C85A/80C85A-2 system without using wait states. The parallel I/O consists of two 8-bit ports and one 6-bit port (both general purpose). The MSM81C55/H also contains a 14-bit programmable counter/timer which may be used for sequencewave generation or terminal count-pulsing.

## FEATURES

- High speed and low power achieved with silicon gate CMOS technology.
- 256 words $x 8$ bits RAM
- Single power supply, 3 to 6V
- Completely static operation
- On-chip address latch
- 8-bit programmable I/O ports (port A and B)
- TTL Compatible
- RAM data hold characteristic at 2V
- 6-bit programmable I/O port (port C)
- 14-bit programmable binary counter/timer
- Multiplexed address/data bus
- Direct interface with MSM80C85AH (MSM81C55H)
- Direct intcrfau nith MSM80C51F (16MHZ)
- 40 pin Plastic DIP (DIP40-P-600)
- 44 pin PLCC (QFJ44-P-S650)
- 44 pin-V Plastic QFP (QFP44-P-910-VK)


## FUNCTIONAL BLOCK DIAGRAM



PIN CONFIGURATION


## - I/O•MSM81C55HRS/GS/JS

## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Conditions | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM81C55HS | MSM81C55HGS | MSM81C55HJS |  |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | Referenced to GND | -0.5 to +7 |  |  | V |
| Input Voltage | VIN |  | -0.5 to $\mathrm{V}_{\mathrm{CC}}+0.5$ |  |  | V |
| Output Voltage | VOUT |  | -0.5 to $V_{C C}+0.5$ |  |  | V |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ |  | -55 to +150 |  |  | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $P_{\text {D }}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | 1.0 | 0.7 | 1.0 | W |

## OPERATING CONDITION

| Parameter | Symbol | Limits | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\text {CC }}$ | 3 to 6 | V |
| Operating Temperature | TOP | -40 to +85 | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{\text {CC }}$ | 4.5 | 5 | 5.5 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| 'L' Level Input | $\mathrm{V}_{\text {IL }}$ | -0.3 |  | +0.8 | V |
| "H"Level Input | $\mathrm{V}_{\text {IH }}$ | 2.2 |  | $\mathrm{~V}_{\mathrm{CC}}+0.3$ | V |

## DC CHARACTERISTICS

| Parameter | Symbol | Conditions |  | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L" Level Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}^{\prime} \mathrm{OL}=2.5 \mathrm{~mA}$ | $\begin{aligned} & V_{C C}=4.5 \mathrm{~V} \text { to } \\ & 5.5 \mathrm{~V} \\ & \mathrm{Ta}=-40^{\circ} \mathrm{C} \text { to } \\ & 85^{\circ} \mathrm{C} \end{aligned}$ |  |  | 0.4 | V |
| "H" Level Output Voltage | VOH | $\mathrm{I}^{\mathrm{OH}}=-2.5 \mathrm{~mA}$ |  | 3.0 |  |  | V |
|  |  | $\mathrm{I}^{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |  | $\begin{array}{r} \mathrm{VCC} \\ -0.4 \end{array}$ |  |  | $V$ |
| Input Leak Current | ILI | $0 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Output Leak Current | ILO | $0 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Standby Current | ${ }^{1} \mathrm{CCS}$ | $\begin{aligned} & \overline{\mathrm{CE}} \geqq \mathrm{~V}_{\mathrm{CC}}-0.2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IH}} \geqq \mathrm{~V}_{\mathrm{CC}}-0.2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}} \leq 0.2 \mathrm{~V} \end{aligned}$ |  |  | 0.1 | 50 | $\mu \mathrm{A}$ |
| Mean Operating Current | ${ }^{1} \mathrm{CC}$ | Tcyc $=200 \mathrm{nS}$ |  |  |  | 10 | mA |

## AC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=4.5\right.$ to $5.5 \mathrm{~V}, \mathrm{Ta}=-40$ to $\left.+80^{\circ} \mathrm{C}\right) \mathrm{MSM} 81 \mathrm{C} 55 \mathrm{H}$

| Parameter | Symbol | MSM81C55H |  | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| Address/latch Set-up Time | ${ }^{t}$ AL | 28 |  | ns | Load capacitance: 150pF |
| Latch/address Holt Time | $t$ LA | 27 |  | ns |  |
| Latch/read (write) Delay Time | $t$ LC | 40 |  | ns |  |
| Read/output Delay Time | tr |  | 140 | ns |  |
| Address/output Delay Time | tAD |  | 330 | ns |  |
| Latch Width | ${ }^{\text {t L L }}$ | 58 |  | ns |  |
| Read/data Bus Floating Time | tRDF | 10 | 80 | ns |  |
| Read (write)/latch Delay Time | ${ }^{t} \mathrm{CL}$ | 20 |  | ns |  |
| Read (write) Width | ${ }^{\text {t }} \mathrm{CC}$ | 200 |  | ns |  |
| Data In/write Set-up Time | tDW | 100 |  | ns |  |
| Write/data-in Holt Time | tWD | 12 |  | ns |  |
| Recovery Time | tr V | 200 |  | ns |  |
| Write/port Output Delay Time | tWP |  | 300 | ns |  |
| Port Input/read Set-up Time | tPR | 50 |  | ns |  |
| Read/port Input Hold Time | ${ }^{\text {t R P }}$ | 10 |  | ns |  |
| Strobe/buffer Full Delay Time | ${ }^{\text {t }}$ SBF |  | 300 | ns |  |
| Strobe Width | ${ }^{\text {t }}$ SS | 150 |  | ns |  |
| Strobe/buffer Empty Delay Time | trBE |  | 300 | ns |  |
| Strobe/interrupt-on Delay Time | ${ }_{\text {t }} \mathrm{S}$ |  | 300 | ns |  |
| Read/interrupt-off Delay Time | tRDI |  | 300 | ns |  |
| Port Input/strobe Set-up Time | tPSS | 20 |  | ns |  |
| Strobe/port-input Hold Time | tPHS | 100 |  | ns |  |
| Strobe/buffer-empty Delty Time | ${ }^{\text {t }}$ SBE |  | 300 | ns |  |
| Write/buffer-full Delay Time | tWBF |  | 300 | ns |  |
| Write/interrupt-off Delay Time | tWI |  | 300 | ns |  |
| Time Output Delay Time Low | $\mathrm{t}_{\mathrm{TL}}$ |  | 300 | ns |  |
| Time Output Delay Time High | tTH |  | 300 | ns |  |
| Read/data Buse Enable Delay Time | tRDE | 10 |  | ns |  |
| Timer Cycle Time | ${ }^{\text {t }}$ CYC | 200 |  | ns |  |
| Timer Input Rise and Fall Times | $t_{r}, t_{f}$ |  | 80 | ns |  |
| Timer Input Low Level Time | $\mathrm{t}_{1}$ | 40 |  | ns |  |
| Timer Input High Level Time | $\mathrm{t}_{2}$ | 70 |  | ns |  |
| WRITE to TIMER-IN for writes which start counting | ${ }^{t}$ WT | 100 |  | ns |  |
| TIMER-IN to WRITE for wites which start counting | ${ }^{\text {t }}$ TW | 0 |  | ns |  |

Note: Timing are measured with $V_{L}=0.8 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{H}}=2.2 \mathrm{~V}$ for both input and output.

- I/O•MSM81C55HRS/GS/JS


## TIMING

Read Cycle


## Write Cycle



## Strobe Input Mode



## Strobe Output Mode



## Basic Input Mode



## Basic Output Mode



Note: The DATA BUS timing is the same as the read and write cycles.

Timer Waveforms 1


Note: Periodically output according to the output mode $(\mathrm{m} 1=1)$ programming contents.

Timer Waveforms 2


RAM DATA HOLD CHARACTERISTICS AT LOW SUPPLY VOLTAGE

| Item | Symbol | Condition | Specification |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. | Max. |  |
| Data Holding Supply Voltage | $\mathrm{V}_{\mathrm{CCH}}$ | $V_{\text {IN }}=O V$ or $V_{\text {CC }}, A L E=O V$ | 2.0 | - | - | V |
| Data Holding Supply Current | ${ }^{1} \mathrm{CCH}$ | $\begin{aligned} & V_{C C}=V_{C C H}, A L E=0 \\ & V_{\text {IN }}=0 V \text { or } V_{C C} \end{aligned}$ | - | 0.05 | 20 | $\mu$ |
| Set-up Time | ${ }^{\text {t }}$ SU |  | 30 | - | - | ns |
| Hold Time | ${ }^{t} \mathrm{R}$ |  | 20 | - | - | ns |

Two ways to place device in standby mode:
(1) Method using $\overline{C E}$

(2) Method using RESET


Note: In this case, the C/S register is reset, the port is set into the input mode, and the timer stops.

## PIN FUNCTIONS

| Symbol | Function |
| :---: | :---: |
| RESET | A high level input to this pin resets the chip, places all three I/O ports in the input mode, resets all output latches and stops timer. |
| ALE | Negative going edge of the ALE (Address Latch Enable) input latches $A D_{0 \sim 7}, 10 / \bar{M}$, and CE signals into the respective latches. |
| $A D_{0 \sim 7}$ | Three-state, bi-directional address/data bus. Eight-bit address information on this bus is read into the internal address latch at the negative going edge of the ALE. Eight bits of data can be read from or written to the chip using this bus depending on the state of the WRITE or READ input. |
| $\overline{C E}$ | When the CE input is high, both read and write operations to the chip are disabled. |
| 10/M | A high level input to this pin selects the internal I/O functions, and a low level selects the memory. |
| $\overline{\mathrm{RD}}$ | If this pin is low, data from either the memory or ports is read onto the $A D_{0 \sim 7}$ lines depending on the state of the $10 / \bar{M}$ line. |
| $\overline{W R}$ | If this pin is low, data on lines $A D_{0 \sim 7}$ is written into either the memory or into the selécted port depending on the state of the $10 / \mathrm{M}$ line. |
| $\begin{aligned} & \mathrm{PA}_{0 \sim 7} \\ & \left(\mathrm{~PB}_{0 \sim 7}\right) \end{aligned}$ | General-purpose I/O pins. Input/output directions can be determined by programming the command/status (C/S) register. |
| $\mathrm{PC}_{0 \sim 5}$ | Three pins are usable either as general-purpose I/O pins or control pins for the PA and PB ports. When used as control pins, they are assigned to the following functions: <br> PCO: A INTR (port A interrupt) <br> PC1: A BF (port A full) <br> PC2: $\bar{A}$ STB (port A strobe) <br> PC3: B INTR (port B interrupt) <br> PC4: B BF (port B buffer full) <br> PC5: $\overline{B S T B}$ (port B strobe) |
| TIMER IN | Input to the counter/timer |
| TIMER OUT | Timer output. When the present count is reached during timer operation, this pin provides a square-wave or pulse output depending on the programmed control status. |
| $V_{\text {cc }}$ | 3-6V power supply |
| GND | GND |

## OPERATION

## Description

The MSM81C55H has three functions as described below.

- Two 8-bit I/O ports (PA and PB) and a 6-bit I/O port (PC)
- 14-bit timer counter

The internal register is shown in the figure below, d the I/O addresses are described in the table below.

- 2 K bit static RAM ( 256 words $\times 8$ bits)


| I/O Address |  |  |  |  |  | Selecting Register |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A7 | A6 | A5 | A4 | A3 | A2 |  | A0 |  |
| x | x | x | x | x | 0 | 0 | 0 | Internal command/status register |
| x | x | x | x | x | 0 | 0 | 1 | Universal I/O port A (PA) |
| x | x | x | x | x | 0 | 1 | 0 | Universal I/O port B (PB) |
| x | x | x | x | x | 0 | 1 | 1 | I/O port C (PC) |
| $\mathbf{x}$ | x | x | x | x | 1 | 0 | 0 | Timer count lower position 8 bits (LSB) |
| x | x | x | x | x | 1 | 0 | 1 | Timer count upper position 6 bits and timer mode 2 bits <br> (MSB) |

[^4](1) Programming the Command/Status (C/S) Register The contents of the command register can be written during an I/O cycle by addressing it with
an $1 / 0$ address of $x \times x \times x 000$. Bit assignments for the register are shown below:


Port Control Assignment Table

| Pin | ALT1 | ALT2 | ALT3 | ALT4 |
| :---: | :---: | :---: | :---: | :---: |
| PC $_{0}$ | Input port | Output port | A INTR | A INTR |
| PC $_{1}$ | Input port | Output port | A BF | A BF |
| PC $_{2}$ | Input port | Output port | A STB | A STB |
| PC $_{3}$ | Input port | Output port | Output port | B INTR |
| PC $_{4}$ | Input port | Output port | Output port | B BF |
| PC $_{5}$ | Input port | Output port | Output port | B STB |

(2) Reading the C/S Register

The 1/O and timer status can be accessed by reading the contents of the Status register located
at $1 / O$ address $\times x \times \times \times 000$. The status word format is shown below:


## (3) PA and PB Registers

These registers may be used as either input or output ports depending on the programmed contents of the C/S register. They may also be used either in the basic mode or in the strobe mode.
1/O address of the PA register: $x \times x \times x 001$
I/O address of the PB register: $x \times x \times x 010$
(4) PC Register

The PC register may be used as an input port, output port or control register depending on the programmed contents of the $\mathrm{C} / \mathrm{S}$ register. The $1 / \mathrm{O}$ address of the PC register is $\times \times \times \times \times 011$.
(5) Timer

The timer is a 14 -bit down counter which counts TIMER IN pulses.
The low order byte of the timer register has an 1/O address of $x \times x \times \times 100$, and the high order byte of the register has an $1 / O$ address of $\times \times \times \times \times 101$.
The count length register (CLR) may be preset with two bytes of data. Bits 0 through 13 are assigned to the count length and bits 14 and 15 specify the timer output mode. A read operation of the CLR reads the contents of the counter and the pertinent output mode. The initial value range which can initially be loaded into the counter is 2 through 3FFF hex. Bit assignments to the timer counter and possible output modes are shown in the following.

$M_{2} \quad M_{1}$
00 Outputs a low-level signal in the latter half (Note 1) of a count period.
01 Outputs a low-level signal in the latter half of a count period, automatically loads the programmed count length, and restarts counting when the TC value is reached.
10 Outputs a pulse when the TC value is reached.
11 Outputs a pulse each time the preset TC value is reached, automatically loads the programmed count length, and restarts from the beginning.
Note 1: When counting an asymmetrical value such as (9), a high level is output during the first period of five, and a low level is output during the second period of four.
Note 2: If an internal counter of the MSM81C55RS/GS receives a reset signal, count operation stops but the counter is not set to a specific initial value or output mode. When restarting count operation after reset, the START command must be executed again through the C/S register.
Note that while the counter is counting, you may load a new count and mode into the CLR. Before the new count and mode will be used by the counter, you must issue a START command to the counter.
Please note the timer circuit on the 81C55 is designed to be a square-wave timer, not a event counter. To achieve this, it counts down by twos twice in completing one cycle. Thus, its registers do not contain values directly representing the number of TIMER IN pulse received. After the timer has started counting down, the values residing in the count registers can be used to calculate the actual number of TIMER IN pulse required to complete the timer cycle if desired. To obtain the remaining count, perform the following operations in order:

1. STOP the counter
2. Read in the 16 bit value from the count registers.
3. Reset the upper two mode bits
4. Reset the carry and rotate right one position all 16 bits through carry
5. If carry is set, add $1 / 2$ of the full original count $(1 / 2$ full count- 1 if full count is odd).

Note: If you started with an odd count and you read the count registers before the third count pulse occurs, you will not be able to recognize whether one or two counts have occurred. Regardless of this, the 81C55 always counts out the right number of pulses in generating the TIMER OUT waveforms.


Note: n is the value set in the CLR.
Figures in the diagram refer to counter value.
(6) Standby Mode (see page 7)

The MSM81C55 is placed in standby mode when the high level at the CE input is latched during the negative going edge of ALE. All input ports and the timer input should be pulled up or down to either $\mathrm{V}_{\mathrm{CC}}$ or GND potential.
When using battery back-up, all ports should be set low or in input port mode. The timer output
should be set low. Otherwise, a buffer should be added to the timer output and the battery should be connected to the power supply pins of the buffer.
By setting the reset input to a high level, the standby mode can be selected. In this case, the command register is reset, so the ports automatically set to the input mode and the timer stops.

# OKKI semiconductor MSM82C12RS/GS 

8-BIT INPUT/OUTPUT PORT

## GENERAL DESCRIPTION

The MSM82C12 is an 8 bit input output port employing $3 \mu$ silicon gate CMOS technology. It insures low operating power. This device incorporates a service request flip-flop for generation and control of interrupts for a CPU, in addition to an 8 -bit latch circuit having a three-state output buffer.

It is effective when used as an address latch device to separate the time division bus line outputs in systems employing the MSM80C85A CPU or similar processors using multiplexed address/data bus line.

## FEATURES

- Operated on low power consumption due to silicon gate CMOS.
- $3 \mathrm{~V} \sim 6 \mathrm{~V}$ single power supply
- Full static operation
- Parallel 8 -bit data register and buffer
- Provided with an interrupt generating function through the adoption of a service request flip-flop
- Equipped with a clear terminal which operates asynchronously
- TTL compatible
- Functionally compatible with the 8212
- 24 pin Plastic DIP (DIP24-P-600)
- 24 pin Plastic SOP (SOP24-P-430-K)
- 24 pin-V Plastic SOP (SOP24-P-430-VK)


## CIRCUIT CONFIGURATION



## PIN CONFIGURATION

MSM82C12RS (Top View) 24 pin Plastic DIP
MSM82C12GS (Top View) 24 pin Plastic Small Oufline Package


PIN DESCRIPTION

| Pin Name | Item | Input/Output | Function |
| :--- | :--- | :--- | :--- |
| $\mathrm{DI}_{\mathbf{1}} \sim \mathrm{DI}_{\mathbf{8}}$ | Data input | Input | These pins are 8-bit data inputs. The data input is connected <br> to the input D pins of the 8-bit data latch circuit built inot <br> the device. |
| $\mathrm{DO}_{1} \sim \mathrm{DO}_{\mathbf{8}}$ | Data output | Output | These pins are 8-bit data outputs. Each bit is composed of 3- <br> state output buffers. <br> These buffers can be made into enable or disable (high imped- <br> ance status). |
| MD | Mode input | Input | This pin is a clock input for the data latch. It is also used to <br> reset the internal service request flip-flop at the same time. |
| STB | Strobe input | Input | This pin is a clock input for the data latch. It is also used to <br> reset the internal service request flip-flop at the same time. |
| $\overline{\mathrm{DS1}, \mathrm{DS2}}$ | Device select <br> input | Input | The AND of these two input functions make the status <br> control of output buffers or becomes a clock input to the <br> data latch. It also functions to perform set/reset of the <br> internal service request flip-flop. |
| $\overline{\mathrm{CLR}}$ | Clear input | Input | This pin clears the internal data latch in low level. It also sets <br> the internal service request flip-flop at this time. The clear is <br> operated asynchronously to the clock. |
| $\overline{\mathrm{INT}}$ | Interrupt <br> output | Output | This pin is the ouput of the internal service request flip-flop, <br> but is inverted to ouptut it in low level operation. |
| VCC |  | +5V power supply <br> GND | GND |

## FUNCTIONAL DESCRIPTION

## Output Buffer Status Control and Data Latch Clock

 InputWhen the input MD is at high level, the ouptut buffer is enabled and the device select input (DS1.DS2) becomes the clock input to the data latch. When the input MD is in low level, the status of the output buffer is determined by the device select input (DS1.DS2) (the output buffer is enabled when (DS1.DS2) is in high level). At this time, the input STB becomes the clock input to the data latch.

| MD | $\overline{(D S 1} \cdot \mathrm{DS} 2)$ | STB | $\mathrm{DO}_{1} \sim \mathrm{DO}_{\mathbf{8}}$ |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | High impedance status |
| 0 | 0 | 1 | High impedance status |
| 1 | 0 | 0 | Data latch |
| 1 | 0 | 1 | Data latch |
| 0 | 1 | 0 | Data latch |
| 0 | 1 | 1 | Data in |
| 1 | 1 | 0 | Data in |
| 1 | 1 | 1 | Data in |

## Service Request Flip-flop

The service request flip-flop is used to generate and control the interrupt for the CPU when the MSM82C12 is used as an input/output port in a microcomputer system. The flip-flop is set asynchronously by input CLR. When the flip-flop is set, the system is in noninterrupt status.

| $\overline{C L R}$ | $(\overline{\mathrm{DS} 1} \cdot \mathrm{DS} 2)$ | STB | 0 | $\overline{\text { INT }}$ |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 | 0 |
| 1 | 1 | 7 | 1 | 0 |
| 1 | 1 | 0 | 1 | 0 |
| 1 | 0 | 0 | 1 | 1 |
| 1 | 0 | 7 | 0 | 0 |

## Clear

When the clear input becomes low level, the internal data latch is cleared irrespective of the clock and becomes low level.

## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Conditions | Limits |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM82C12RS | MSM82C12GS |  |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | With respect to GND | -0.5 to +7 |  | V |
| Input Voltage | VIN |  | -0.5 to $\mathrm{VCC}^{+0.5}$ |  | V |
| Output Voltage | VOUT |  | -0.5 to $\mathrm{VCC}^{+0.5}$ |  | V |
| Storage Temperature | Tstg |  | -55 to +150 |  | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | PD | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | 0.9 | 0.7 | W |

## OPERATING RANGE

| Parameter | Symbol | Limits | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | V $C C$ | 3 to 6 | $V$ |
| Operating Temperature | TOP | -40 to +85 | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED OPERATING CONDITION

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5 | 5.5 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| '" C " Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 |  | +0.8 | V |
| " H " Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.2 |  | $\mathrm{~V}_{\mathrm{CC}}+0.3$ | V |

## DC CHARACTERISTICS

| Parameter | Symbol | Conditions |  | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L" Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}^{\mathrm{OL}}=4 \mathrm{~mA}$ | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=-4.5 \mathrm{~V} \\ \text { to } 5.5 \mathrm{~V} \\ \mathrm{Ta}=-40^{\circ} \mathrm{C} \\ \text { to }+85^{\circ} \mathrm{C} \end{gathered}$ |  |  | 0.4 | V |
| 'H'H' Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}^{\mathrm{OH}}=-4 \mathrm{~mA}$ |  | 3.7 |  |  | V |
| Input Leak Current | $\mathrm{I}_{\mathrm{LI}}$ | $0 \leqq \mathrm{~V}_{\text {IN }} \leqq \mathrm{V}_{\text {CC }}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Output Leak Current | ILO | $0 \leqq \mathrm{~V}_{\text {OUT }} \leqq \mathrm{V}_{\text {CC }}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Supply Current (Standby) | ${ }^{7} \mathrm{CcS}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}} \leqq \mathrm{~V}_{\mathrm{CC}}-0.2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}} \leqq 0.2 \mathrm{~V} \end{aligned}$ |  |  | 0.1 | 100 | $\mu \mathrm{A}$ |
| Average Supply Current (active) | ${ }^{\prime} \mathrm{Cc}$ | $\mathrm{f}=1 \mathrm{MHz}$ |  |  |  | 1 | mA |

## AC CHARACTERISTICS

$\left(V_{\mathrm{CC}}=4.5 \sim 5.5 \mathrm{~V}, \mathrm{Ta}=-40^{\circ} \mathrm{C}+85^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Min. | Tур. | Max. | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pulse Width | tPW | 30 |  |  | ns | Load 30pF |
| Data to Output Delay | tPD |  | 20 | 45 | ns |  |
| Write Enable to Output Delay | tWE |  | 31 | 60 | ns |  |
| Data Set Up Time | ${ }^{\text {t }}$ SET | 15 |  |  | ns |  |
| Data Hold Time | ${ }_{\text {t }}^{\mathrm{H}}$ | 30 |  |  | ns |  |
| Clear to Output Delay | ${ }^{t} \mathrm{C}$ |  | 19 | 40 | ns |  |
| Reset to Output Delay | ${ }^{t}$ R |  | 21 | 45 | ns |  |
| Set to Output Delay | ${ }^{\text {t }}$ |  | 25 | 45 | ns |  |
| Output Enable Time | ${ }^{t}$ E |  | 52 | 90 | ns | $\begin{aligned} & \text { Load 20pF + } \\ & 1 \mathrm{k} \Omega \end{aligned}$ |
| Output Disable Time | ${ }^{t}$ D |  | 30 | 55 | ns |  |

Note: TYP is measured where $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and $\mathrm{Ta}=25^{\circ} \mathrm{C}$.
Timing is measured where VL $=\mathrm{VH}=1.5 \mathrm{~V}$ in both input and output.
$\mathrm{t}_{\mathrm{E}}$ and $\mathrm{t}_{\mathrm{D}}$ are measured at $\mathrm{V}_{\mathrm{OL}}+0.5 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{OH}}-0.5 \mathrm{~V}$ when the two are made into high impedance status.

## OUTPUT CHARACTERISTICS (DC Characteristics Reference Value)

(1) Output " H " voltage $\left(\mathrm{V}_{\mathrm{OH}}\right)$ vs. output current ( ${ }^{(\mathrm{OH} \text { ) }}$

(2) Output "L" voltage ( $\mathrm{V}_{\mathrm{OL}}$ ) vs. output current (loL)


Note: The direction of flow in is taken as positive for output current.

## OUTPUT CHARACTERISTICS (AC Characteristics Reference Value)

(1) tPD vs. load capacitance

(2) tPD and tWE vs. supply voltage


## TIMING CHART

Data Latch Operation


## Gate Buffer Operation



Interrupt Operation


## Clear Operation



Output Buffer Enable/Disable (High Impedance Status) Operation


## EXAMPLE OF APPLICATION OF MSM82C12

## Address Latch of MSM80C85A

Used to separate the time division data bus (8) low order bits of the address bus and 8 -bit data bus) into
the address bus and data bus by means of the ALE (Address Latch Enable) signal.


# OKXI semiconductor <br> MSM82C37A-5RS/GS/JS 

## PROGRAMMABLE DMA CONTROLLER

## GENERAL DESCRIPTION

The MSM82C37A-5RS/GS/JS, DMA (Direct Memory Access) controller is capable of high-speed data transfer without CPU intervention and is used as a peripheral device in microcomputer systems. The device features four independent programmable DMA channels.

Due to the use of silicon gate CMOS technology, standby current is $10 \mu \mathrm{~A}$ (max.), and power consumption is as low as 10 mA (max.) when a 5 MHz clock is generated.

All items of $A C$ characteristics are compatible with intel 8237A-5.

## FEATURES

- Maximum operating frequency of $5 \mathrm{MHz}\left(\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 10 \%\right)$ - DREQ and DACK input/output logic inversion
- High-speed operation at very low power consumption - DMA address increment/decrement selection
due to silicon gate CMOS technology
- Wide power supply voltage range of 3 to 6 V
- Wide operating temperature range from $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$
- 4-channels independent DMA control
- DMA request masking and programming
- DMA request priority function

PIN CONNECTIONS

- Memory-to-Memory Transfers
- Channel extension by cascade connection
- DMA transfer termination by $\overline{\mathrm{EOP}}$ input
- Intel 8237A-5 compatibility
- TTL Compatible
- 40 pin Plastic DIP (DIP40-P-600)
- 44 pin PLCC (QFJ44-P-S650)
- 44 pin-V Plastic QFP (QFP44-P-910-VK)
- 44 pin-VI Plastic QFP (QFP44-P-910-VIK)


Note: N.C. (No Connection)


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Conditions | Rating |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM82C37A-5RS | MSM82C37A5GS | MSM82C37A-5JS |  |
| Power supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | with respect to GND | $-0.5 \sim+7$ |  |  | V |
| Input voltage | $\mathrm{V}_{\text {IN }}$ |  | $-0.5 \sim v_{c c}+0.5$ |  |  | V |
| Output voltage | V OUT |  | $-0.5 \sim V_{c c}+0.5$ |  |  | V |
| Storage temperature | $\mathrm{T}_{\text {stg }}$ |  | $-55 \sim+150$ |  |  | ${ }^{\circ} \mathrm{C}$ |
| Power dissipation | $P_{D}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | 1.0 | 0.7 | 1.0 | W |

## OPERATING RANGES

| Parameter | Symbol | Range | Unit |
| :---: | :---: | :---: | :---: |
| Power supply voltage | $V_{\text {CC }}$ | $3 \sim 6$ | V |
| Operating temperature | TOP | $-40 \sim 85$ | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Maximum | Typical | Minimum | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power supply voltage | $V_{\mathrm{CC}}$ | 4.5 | 5.0 | 5.5 | V |
| Operating temperature | $\mathrm{T}_{\mathrm{OP}}$ | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| " $\mathrm{L}^{\prime}$ input voltage | $\mathrm{V}_{\text {IL }}$ | -0.5 | - | V |  |
| "H" input voltage | $\mathrm{V}_{\text {IH }}$ | 2.2 | - | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |

## DC CHARACTERISTICS

| Parameter | Symbol | Conditions |  | Maximum | Typical | Minimum | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L' output voltage | $\mathrm{V}_{\mathrm{OL}}$ | $1 \mathrm{OL}=3.2 \mathrm{~mA}$ | $\begin{aligned} \mathrm{V}_{\mathrm{CC}} & =4.5 \mathrm{~V} \\ & \sim 5.5 \mathrm{~V} \\ \mathrm{Ta} & =-40^{\circ} \mathrm{C} \\ & \sim+85^{\circ} \mathrm{C} \end{aligned}$ | - | - | 0.4 | $\checkmark$ |
| "H' output voltage | $\mathrm{VOH}^{\text {OH}}$ | $1 \mathrm{OH}=-1.0 \mathrm{~mA}$ |  | 3.7 | - | - | V |
| Input leak current | ILI | $0 \mathrm{~V} \leqq \mathrm{~V}_{\text {IN }} \leqq \mathrm{V}_{\mathrm{CC}}$ |  | -10 | - | 10 | $\mu \mathrm{A}$ |
| Output leak current | ILO | $0 \mathrm{~V} \leqq \mathrm{~V}_{\text {OUT }} \leqq \mathrm{V}_{\mathrm{CC}}$ |  | $-10$ | - | 10 | $\mu \mathrm{A}$ |
| Average power supply current during operations | ICC | Input frequency 5 MHz , whenRESET $\begin{aligned} & V_{I N}=0 \mathrm{~V} / \mathrm{V} \mathrm{CC} \\ & \mathrm{C}_{\mathrm{L}}=0 \mathrm{pF} \end{aligned}$ |  | - | - | 10 | mA |
| Power supply current in standby mode | ICCS | $\begin{aligned} \mathrm{HLDA} & =0 \mathrm{~V} \\ \mathrm{VIL} & =0 \mathrm{~V}, \\ \mathrm{VIH} & =\mathrm{VCC} \end{aligned}$ |  | - | - | 10 | $\mu \mathrm{A}$ |

## AC CHARACTERISTICS

DMA (MASTER) MODE
$\left(\mathrm{Ta}=-40 \sim+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.5 \sim 5.5 \mathrm{~V}\right)$

| Symbol | Item | MIN | MAX | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TAEL | Delay time from CLK falling edge up to AEN leading edge | - | 200 | ns | - |
| TAET | Delay time from CLK rising edge up to AEN trailing edge | - | 130 | ns | - |
| TAFAB | Delay time from CLK rising edge up to address floating status | - | 90 | ns | - |
| TAFC | Delay time from CLK rising edge up to read/write signal floating status | - | 120 | ns | - |
| TAFDB | Delay time from CLK rising edge up to data bus floating status | - | 170 | ns | - |
| TAHR | Address valid hold time to read signal trailing edge | TCY-100 | - | ns | - |
| TAHS | Data valid hold time to ADSTB trailing edge | 30 | - | ns | - |
| TAHW | Address valid hold time to write signal trailing edge | TCY-50 | - | ns | -- |
| TAK | Delay time from CLK falling edge up to active DACK | - | 170 | ns | (Note 3) |
|  | Delay time from CLK rising edge up to $\overline{E O P}$ leading edge | - | 170 | ns | (Note 5) |
|  | Delay time from CLK rising edge up to $\overline{\mathrm{EOP}}$ trailing edge | - | 170 | ns | - |
| TASM | Time from CLK rising edge up to address valid | - | 170 | ns | - |
| TASS | Data set-up time to ADSTB trailing edge | 100 | - | ns | - |
| TCH | Clock high-level time | 68 | - | ns | (Note 6) |


| Symbol | Item | MIN | MAX | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Clock low-level time | 68 | - | ns | (Note 6) |
| TCL | Clock low-level time | 115 | - | ns | (Note 8) |
| TCY | CLK cycle time | 200 | - | ns |  |
| TDCL | Delay time from CLK rising edge to read/write signal leading edge | - | 190 | ns | (Note 2) |
| TDCTR | Delay time from CLK rising edge to read signal trailing edge | - | 190 | ns | (Note 2) |
| TDCTW | Delay time from CLK rising edge to write signal trailing edge | - | 130 | ns | (Note 2) |
| TDO | Delay time from CLK rising edge to $H R Q$ valid | - | 120 | ns | - |
| TEPS | $\overline{\mathrm{EOP}}$ leading edge set-up time to CLK falling edge | 40 | - | ns | - |
| TEPW | $\overline{\text { EOP }}$ pulse width | 220 | - | ns | - |
| TFAAB | Delay time from CLK rising edge to address valid | - | 170 | ns | - |
| TFAC | Time from CLK rising edge up to active read/write signal | - | 150 | ns | - |
| TFADB | Delay time from CLK rising edge to data valid | - | 200 | ns | - |
| THS | HLDA valid set-up time to CLK rising edge | 75 | - | ns | - |
| TIDH | Input data hold time to MEMR trailing edge | 0 | - | ns | - |
| TIDS | Input data set-up time to $\overline{\text { MEMR }}$ trailing edge | 170 | - | ns | - |
| TODH | Output data hold time to $\overline{\text { MENW }}$ trailing edge | 10 | - | ns | - |
| TODV | Time from output data valid to $\overline{M E M W}$ trailing edge | 125 | - | ns | - |
| TOS | DREQ set-up time to CLK falling edge | 0 | - | ns | (Note 3) |
| TRH | READY hold time to CLK falling edge | 20 | - | ns | - |
| TRS | READY set-up time to CLK falling edge | 60 | - | ns | - |
| TSTL | Delay time from CLK rising edge to ADSTB leading edge | - | 130 | ns | - |
| TSTT | Delay time from CLK rising edge to ADSTB trailing edge | - | 90 | ns | - |

SLAVE MODE
$\left(\mathrm{Ta}=-40 \sim+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.5 \sim 5.5 \mathrm{~V}\right)$

| Symbol | Item | MIN | MAX | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TAR | Time from address valid or $\overline{\mathrm{CS}}$ leading edge to $\overline{\overline{O R}}$ leading edge | 50 | - | ns. | - |
| TAW | Address valid set-up time to $\overline{\mathrm{OW}}$ trailing edge | 130 | - | ns | - |
| TCW | $\overline{\mathrm{CS}}$ leading edge set-up time to $\overline{\mathrm{IOW}}$ trailing edge | 130 | - | ns | - |
| TDW | Data valid set-up time to $\overline{\mathrm{IOW}}$ trailing edge | 130 | - | ns | - |
| TRA | Address or $\overline{\mathrm{CS}}$ hold time to $\overline{\mathrm{OR}}$ trailing edge | 0 | - | ns | - |
| TRDE | Data access time to $\overline{O R}$ leading edge | - | 140 | ns | - |
| TRDF | Delay time to data floating status from $\overline{\mathrm{OR}}$ trailing edge | 0 | 70 | ns | - |
| TRSTD | Supply power leading edge set-up time to RESET trailing edge | 500 | - | ns | - |
| TRSTS | Time to first active $\overline{\overline{O R}}$ or $\overline{\text { IOW }}$ from RESET trailing edge | 2TCY | - | ns | - |
| TRSTW | RESET pulse width | 300 | - | ns | - |
| TRW | $\overline{\mathrm{OR}}$ pulse width | 200 | - | ns | - |
| TWA | Address hold time to $\overline{\mathrm{OW}}$ trailing edge | 20 | - | ns | - |
| TWC | $\overline{\mathrm{CS}}$ trailing edge hold time to $\overline{\mathrm{IOW}}$ trailing edge | 20 | - | ns | - |
| TWD | Data hold time to $\overline{\overline{O W}}$ trailing edge | 30 | - | ns | - |
| TWWS | $\overline{\text { IOW }}$ pulse width | 160 | - | ns | - |

## Note:

1. Output load capacitance of $150(\mathrm{pF})$.
2. $\overline{\text { IOW }}$ and $\overline{\mathrm{MEMW}}$ pulse widths of TCY-100 (ns) for normal writing, and $2 T C Y-100$ (ns) for extended writing. $\overline{I O R}$ and $\overline{M E M R}$ pulse widths of 2 TCY-50 (ns) for normal timing, and TCY-50 (ns) for compressed timing.
3. DREQ and DACK signal active level can be set to either low or high. In the timing chart, the DREQ signal has been set to active-high, and the DACK signal to active-low.
4. When the CPU executes continuous read or write in programming mode, the interval during which the read or write pulse becomes active must be set to at least 400 ns .
5. EOP is an open drain output. The value given is obtained when a 2.2 kohm pull-up resistance is connected to VCC.
6. Rise time and fall time is less than 10 ns .
7. Waveform measurement points for both input and output signals are 2.2 V for HIGH and 0.8 V for LOW, unless otherwise noted.
8. When auto initialize is enabled.

TIME CHART
RESET TIMING


## SLAVE MODE WRITE TIMING



## SLAVE MODE READ TIMING



## DMA TRANSFER TIMING



## MEMORY TO MEMORY TRANSFER TIMING



## READY TIMING



- I/O•MSM82C37A-5RS/GS/JS


## COMPRESSED TRANSFER TIMING



## PIN FUNCTIONS

| Symbol | Pin name | Input/ output | Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ | Power |  | +5 V power supply. |
| GND | Ground |  | Ground ( 0 V ) connection. |
| CLK | Clock | Input | Control of MSM82C37A-5 internal operations and data transfer speed. |
| $\overline{\text { CS }}$ | Chip select | Input | $\overline{\mathrm{CS}}$ is active-low input signal used for the CPU to select the MSM82C37A-5 as an I/O device in an idle cycle. |
| RESET | Reset | Input | RESET is active-high asynchronous input signal used to clear command, status, request, temporary registers, and first/last F/F, and to set mask register. The MSM82C37A-5 enters an idle cycle following a RESET. |
| READY | Ready | Input | The read or write pulse width can be extended to accomodate slow access memories and I/O devices when this input is switched to low level. Note this input must not change within the prescribed set-up/hold time. |
| HLDA | Hold acknowledge | Input | HLDA is active-high input signal used to indicate that system bus control has been released when a hold request is received by the CPU. |
| DREQ ~ DREQ3 | DMA request $0 \sim 3$ channels | Input | DREQ is asychronous DMA transfer request input signals. Although these pins are switched to active-high by reset, they can be programmed to become active-low. DMA requests are received in accordance with a prescribed order of priority. DREQ must be held until DACK becomes active. |
| DBO ~ DB7 | Data bus 0~7 | Input/ output | DB is bidirectional three-state signals connected to the system data bus, and which is used as an input/output of MSM82C37A-5 internal registers during idle cycles, and as an output of the eight higher order bits of transfer addresses during active cycles. Also used as input and output of transfer data during memory-memory transfers. |
| $\overline{\text { IOR }}$ | 1/O read | Input/ output | $\overline{I O R}$ is active-low bidirectional three-state signal used as an input control signal for CPU reading of MSM82C37A-5 internal registers during idle cycles, and as an output control signal for reading I/O device transfer data in writing transfers during active cycles. |
| IOW | I/O write | Input/ output | $\overline{\mathrm{IOW}}$ is active-low bidirectional three-state signal used as an input control signal for CPU writing of MSM82C37A-5 internal registers during idle cycles, and as an output control signal for writing $1 / O$ device transfer data in writing transfers during active cycles. |


| Symbol | Pin name | Input/ output | Function |
| :---: | :---: | :---: | :---: |
| $\overline{\text { EOP }}$ | End of process | Input/ output | $\overline{\mathrm{EOP}}$ is active-low bidirectional three-state signal. Unlike other pins, this pin is an N-channel open drain. During DMA operations, a low-level output pulse is obtained from this pin if the channel word count changes from 0000 H to FFFFH. <br> And DMA transfers can be terminated by pulling the $\overline{E O P}$ input to low level. Both of these actions are called terminal count (TC). <br> When an internal or external $\overline{E O P}$ is generated, the MSM82C37A-5 terminates the transfer and resets the DMA request. <br> When the $\overline{E O P}$ pin is not used, it is necessary to hold the pin at high level by pull-up resistance to prevent the input of an $\overline{E O P}$ by error. Also note that the $\overline{E O P}$ function cannot be satisfied in cascade mode. |
| AO ~ A3 | Address $0 \sim 3$ | Input/ output | $A 0 \sim A 3$ is bidirectional three-state signals used as input signals for specifying the MSM82C37A-5 internal register to be accessed by the CPU during idle cycles, and as an output the four lower order bits of the transfer address during active cycles. |
| A4 ~ A7 | Address $4 \sim 7$ | Output | A4~A7 is three-state signals used as an output the four higher order bits of the transfer address during active cycles. |
| HRO | Hold request | Output | HRQ is active-high signal used as an output of hold request to the CPU for system data bus control purposes. After HRQ has become active, at least one clock cycle is required before HLDA becomes active. |
| DACK0 ~ DACK 3 | DMA acknowledge $0 \sim 3$ channels | Output | DACK is output signals used to indicate that DMA transfer co peripheral devices has been permitted. (Available in each channel.) <br> Although these pins are switched to active-low when reset, they can be programmed to become active-high. <br> Note that there is no DACK output signal during memory-memory transfers. |
| AEN | Address enable | Output | AEN is active-high output signal used to indicate that output signals sent from the MSM82C37A-5 to the system are valid. And in addition to enabling external latch to hold the eight higher order bits of the transfer address, this signal is also used to disable other system bus buffers. |


| Symbol | Pin name | Input/ <br> output | Function |
| :--- | :--- | :--- | :--- |
| ADSTB | Address strobe | Output | ADSTB is active-high signal used to strobe <br> the eight higher order bits of the transfer address <br> by external latch. |
| $\overline{\text { MEMR }}$ | Memory read | Output | $\overline{\text { MEMR is active-low three-state output signal }}$ <br> used as a control signal in reading data from <br> memory during read transfers and memory- <br> memory transfers. |
| $\overline{\text { MEMW }}$ | Memory write | Output | $\overline{\text { MEMW is active-low three-state output signal }}$ <br> used as a control signal in writing data into <br> memory during write transfers and memory- <br> memory transfers. |



Fig. 1 DMA operation state transition diagram

## OUTLINE OF FUNCTIONS

The MSM82C37A-5 consists of five blocks = three logic sections, an internal register section, and a counter section.

The logic sections include a timing control block where the internal timing and external control signals are generated, a command control block where each instruction from the CPU is decoded, and a priority decision block where the order of DMA channel priority is determined. The purpose of the internal register section is to hold internal states and instructions from the CPU, while the counter section computes addresses and word counts.

## DESCRIPTION OF OPERATIONS

The MSM82C37A-5 operates in two cycles (called the idle and active cycles) which are divided into independent states. Each state is commenced by a clock falling edge and continues for a single clock cycle. The transition from one state to the next in DMA operations is outlined in Figure 1.

## IDLE CYCLE

The idle cycle is entered from the SI state when there is no valid DMA request on any MSM82C37A- 5 channel. During this cycle, DREQ and $\overline{\mathrm{CS}}$ inputs are monitored during each cycle. When a valid DMA request is then received, an active cycle is commenced. And if the HLDA and CS inputs are at low level, a programming state is started with MSM82C37A-5 reading or writing executed by $\overline{\overline{O R}}$ or $\overline{O W W}$. Programming details are described later.

## ACTIVE CYCLE

If a DMA request is received in an unmasked channel while the MSM82C37A-5 is in an idle cycle, or if a software DREQ is generated, the HRO is changed to high level to commence an active cycle. The initial state of an active cycle is the SO state which is repeated until the HLDA input from the CPU is changed to high level. (But because of internal operational reasons, a minimum of one clock cycle is required for the HLDA is be changed to high level by the CPU after the HRQ has become high level. That is, the SO state must be repeated at least twice.)

After the HLDA has been changed to high level, the S0 state proceeds to operational states S1 thru S4 during I/O-memory transfers, or to operational states S11 thru S14 and S21 thru S24 during memory-memory transfers.

If the memory or I/O device cannot be accessed within the normal timing, an SW state (wait state) can be inserted by a READY input to extend the timing.

## DESCRIPTION OF TRANSFER TYPES

MSM82C37A-5 transfers between an I/O and memory devices, or transfers between memory devices. The three types of transfers between I/O and memory devices are read, write, and verify.

## I/O-MEMORY TRANSFERS

The operational states during an I/O-memory transfer are S1, S2, S3, and S4.
In the S1 state, an AEN output is changed to high level to indicate that the control signal from the MSM82C37A-5 is valid. The eight lower order bits of the transfer address are obtained from A0 thru A7, and the eight higher order bits are obtained from DBO thru DB7. The ADSTB output is changed to high level at this time to set the eight higher order bits in an external address latch, and the DACK output is made active for the channel where the DMA request is acknowledged. Where there is no change in the eight higher bit transfer address during demand and block mode transfers, however, the S1 state is omitted.

In the S2 state, the $\overline{\mathrm{OR}}$ or $\overline{\mathrm{MEMR}}$ output is changed to low level.
In the S3 state, $\overline{\text { IOW }}$ or MEMW is changed to low level. Where compressed timing is used, however, the S3 state is omitted.

The S2 and S3 states are I/O or memory input/output timing control states.
In the S4 state, $\overline{\mathrm{OR}}, \overline{\mathrm{IOW}}, \overline{\mathrm{MEMR}}$, and $\overline{\mathrm{MEMW}}$ are changed to high level, and the word count register is decremented by 1 while the address register is incremented (or decremented) by 1 . This completes the DMA transfer of one word.

Note that in I/O-memory transfers, data is transferred directly without being taken in by the MSM82C37A-5. The differences in the three types of I/O-memory transfers are indicated below.

## READ TRANSFER

Data is transferred from memory to the $1 / O$ device by changing $\overline{M E M R}$ and $\overline{I O W}$ to low level. $\overline{M E M W}$ and $\overline{I O R}$ are kept at high level during this time.

## WRITE TRANSFER

Data is transferred from the $1 / O$ device to memory by changing $\overline{M E M W}$ and $\overline{I O R}$ to low level. $\overline{M E M R}$ and $\overline{I O W}$ are kept at high level during this time.

Note that writing and reading in these write and read transfers are with respect to the memory.

## VERIFY TRANSFER

Although verify transfers involve the same operations as write and read transfers (such as transfer address generation and $\overline{\text { EOP }}$ input responses), they are in fact pseudo transfers where all $1 / O$ and memory reading/writing control signals are kept inactive. READY inputs are disregarded in verify transfers.

## MEMORY-MEMORY TRANSFERS

Memory-memory transfers are used to transfer data blocks from one memory area to another.
Memory-memory transfers require a total of eight states to complete a single transfer four states (S11 thru S14) for reading from memory, and four states (S21 thru S24) for writing into memory. These states are similar to I/O-memory transfer states, and are distinguished by using two-digit numbers.

In memory-memory transfers, channel 0 is used for reading data from the source area, and channel 1 is used for writing data into the destination area. During the initial four states, data specified by the channel 0 address is read from the memory when MEMR is made active, and is taken in the MSM82C37A- 5 temporary register. Then during the latter four states, the data in the temporary register is written in the address specified by channel 1. This completes the transfer of one byte of data. With channel 0 and channel 1 addresses subsequently incremented (or decremented) by 1 , and channel 0,1 word count decremented by 1 , this operation is repeated. The transfer is terminated when the word count reaches $\operatorname{FFFF}(\mathrm{H})$ from $\mathrm{OOOO}(\mathrm{H})$, or when an $\overline{E O P}$ input is applied from an external source. Note that there is no DACK output signal during this transfer.

The following preparations in programming are requiring to enable memory-memory transfers to be started.

## COMMAND REGISTER SETTING

Memory-memory transfers are enabled by setting bit 0 . Channel 0 address can be held for all transfers by setting bit 1 . This setting can be used to enable 1 -word contents of the source area to be written into the entire destination area.

## MODE REGISTER SETTING

The transfer type destination is disregarded in channels 0 and 1. Memory-memory transfers are always executed in block transfer mode.

## REQUEST REGISTER SETTING

Memory-memory transfers are started by setting the channel 0 request bit.

## MASK REGISTER SETTING

Mask bits for all channels are set to prevent selection of any other channel apart from channel 0.

## WORD COUNT REGISTER SETTING

The channel 1 word count is validated, while the channel 0 word count is disregarded.
In order to autoinitialize both channels, it is necessary to write the same values into both word count registers.

## DESCRIPTION OF OPERATION MODES

## SINGLE TRANSFER MODE

In single transfer mode, only one word is transferred, and the addresses are incremented (or decremented) by 1 while the word count is decremented by 1 . The HRQ is then changed to low level to return the bus control to the CPU. If DREQ remains active after completion of a transfer, the HRQ is changed to low level. After the HLDA is changed to low level by the CPU, and then changes the HRQ back to high level to commence a fresh DMA cycle. For this reason, a machine cycle can be inserted between DMA cycles by the CPU.

## BLOCK TRANSFER MODE

Once a DMA transfer is started in block mode, the transfer is continued until terminal count (TC) status is reached.

If DREQ remains active until DACK becomes active, the DMA transfer is continued even if DREQ becomes inactive.

## DEMAND TRANSFER MODE

The DMA transfer is continued in demand transfer mode untiL DREQ is no longer active, or until TC status is reached.

During a DMA transfer, intermediate address and word count values are held in the current address and current word count registers. Consequently, if the DMA transfer is suspended as a result of DREQ becoming inactive before TC status is reached, and the DREQ for that channel is then made active again, the suspended DMA transfer is resumed.

## CASCADE TRANSFER MODE

When DMA transfers involving more than four channels are required, connecting a multiple number of MSM82C37A-5 devices in a cascade connection (see Figure 2) enables a simple system extension. This mode is set by setting the first stage MSM82C37A-5 channel to cascade mode. The DREQ and DACK lines for the first stage MSM82C37A-5 channel set to cascade mode are connected to the HRQ and HLDA lines of the respective MSM82C37A-5 devices in the second stage. The first stage MSM82C37A-5 DACK signal must be set to active-high, and the DREQ signal to active-low.

Since the first stage MSM82C37A-5 is only used functionally in determining the order of priority of each channel when cascade mode is set, only DREQ and DACK are used - all other inputs are disregarded. And since the system may be hung up if the DMA transfer is activated by software DREQ, do not set a software DREQ for channels where cascade mode has been set.

In addition to the dual stage cascade connection shown in Figure 2, triple stage cascade connections are possible with the second stage also set to cascade mode.


Stage 2
MSM82C37A-5
Fig. 2 MSM82C37A-5 cascade connection system

## AUTOINITIALIZE MODE

Setting bit 4 of the mode register enables autoinitialization of that channel. Following TC generation, autoinitialize involves writing of the base address and the base word count register values in the respective current address and current word count registers. The same values as in the current registers are written in the base registers by the CPU, and are not changed during DMA transfers.

When a channel has been set to autoinitialize, that channel may be used in a second transfer without involving the CPU and without the mask bit being reset after the TC generation.

## PRIORITY MODES

The MSM82C37A-5 makes use of two priority decision modes, and acknowledges the DMA channel of highest priority among the DMA requesting channels.

## FIXED PRIORITY MODE

In fixed priority mode, channel 0 has the highest priority, followed by channel 1, 2, and 3 in that order.

## ROTATING PRIORITY MODE

In rotating priority mode, the order of priority is changed so that the channel where the current DMA transfer has been completed is given lowest priority. This is to prevent any one channel from monopolizing the system. The fixed priority is regained immediately after resetting.

Table 1 MSM82C37A-5 priority decision modes

| Priority mode |  | Fixed | Rotating |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Service terminated channel |  | - | CHO | CH 1 | CH 2 | CH 3 |
|  | Highest | CHO | CH 1 | CH 2 | CH 3 | CHO |
| Order of priority |  |  | CH 1 | CH 2 | CH 3 | CH |
| for next DMA |  | CH 2 | CH 3 | CH | CH 1 |  |
|  |  | Lowest | CH 3 | CH 1 | CH 1 | CH 2 |
| CH 2 |  |  |  |  |  |  |
|  |  | CH 3 |  |  |  |  |

## COMPRESSED TIMING

Setting the MSM82C37A-5 to compressed timing mode enables the S3 state used in extension of the read pulse access time to be omitted (if permitted by system structure) for two or three clock cycle DMA transfers. If the S3 state is omitted, the read pulse width becomes the same as the write pulse width with the address updated in S2 and the read or write operation executed in S4. This mode is disregarded if the transfer is a memory-memory transfer. transfer.

## EXTENDED WRITING

When this mode is set, the $\overline{\mathrm{OW}}$ or $\overline{\mathrm{MEMW}}$ signal which normally appears during the S 3 state is obtained during the S2 state, thereby extending the write pulse width. The purpose of this extended write pulse is to enable the system to accomodate memories and $1 / O$ devices where the access time is slower. Although the pulse width can also be extended by using READY, that involves the insertion of a SW state to increase the number of states.

## DESCRIPTION OF INTERNAL REGISTERS.

## CURRENT ADDRESS REGISTER

Each channel is equipped with a 16-bit long current address register where the transfer address is held during DMA transfers. The register value is incremented (or decremented) in each DMA cycle. Although this register is 16 bits long, the CPU is accessed by the MSM82C37A-5 eight bits at a time, therefore necessitating two successive 8 -bit (lower and higher order bits) reading or writing operations using internal first/last flip-flops.

When autoinitialize has been set, the register is automatically initialized to the original value after TC.

## CURRENT WORD COUNT REGISTER

Each channel is also equipped with a 16 bit-long current word count register where the transfer count is held during DMA transfers. The register value is decremented in each DMA cycle. When the word count value reaches $\operatorname{FFFF}(\mathrm{H})$ from $\mathrm{OOOO}(\mathrm{H})$, a TC is generated. Therefore, a word count vaue which is one less than the actual number of transfers must be set.

Since this register is also 16 bits long, it is accessed by first/last flip-flops control in the same way as the address register. And if autoinitialize has been set, the register is automatically initialized to the original value after TC.

## BASE ADDRESS REGISTER AND BASE WORD COUNT REGISTER

Each channel is equipped with a 16 -bit long base address register and base word count register where the initial value of each current register is held. The same values are written in each base register and the current register by the CPU. The contents of the current register can be made ready by the CPU, but the content of the base register cannot be read.

## COMMAND REGISTER

This 8-bit write-only register prescribes DMA operations for all MSM82C37A-5 channels. An outline of all bits is given in Figure 3. When the controller is disabled by setting DB2, there is no HRQ output even if DMA request is active.

DREQ and DACK signals may be active high or active low by setting DB6 and DB7.


## MODE REGISTER

Each channel is equipped with a 6-bit write-only mode register, which is decided by setting DBO, DB1 which channel is to be written when writing from the CPU is programming status. The bit description is outlined in Figure 4.

This register is not cleared by Reset or Master Clear instruction.


## REQUEST REGISTER

In addition to using the DREO signal, the MSM82C37A-5 can request DMA transfers by software means. This involves setting the request bit of request register. Each channel has a corresponding request bit in the request register, and the order of priority of these bits is determined by the priority decision circuit irrespective of the mask register. DMA transfers are acknowledged in accordance with the decided order of priority.

All request bits are reset when the TC is reached, and when the request bit of a certain channel has been received, all other request bits are cleared. When a memory-memory transfer is commenced, the channel 0 request bit is set. The bit description is outlined in Figure 5.


Fig. 5 Request register

## MASK REGISTER

This register is used in disabling and enabling of DMA transfers in each channel. Each channel includes a corresponding mask bit in the mask register, and each bit is set when the TC is reached if not in autoinitialize mode. This mask register can be set in two different ways.

The method for setting/resetting the register for each channel is outlined in Figure 6(a), while the method for setting/resetting the register for all channels at once is outlined in Figure 6(b).

(a) Single mask register (setting/resetting for each channel)

$\{0$ : Channel 0 mask bit cleared
$\{1$ : Channel 0 mask bit set
$\{0$ : Channel 1 mask bit cleared
1 : Channel 1 mask bit set
$\{0$ : Channel 2 mask bit cleared
1 : Channel 2 mask bit set
$\{0$ : Channel 3 mask bit cleared 11 : Channel 3 mask bit set

Not used
(b) All mask register (setting/resetting of all channels at once)

Fig. 6 Mask register

## STATUS REGISTER

This register is a read-only register used in CPU reading of the MSM82C37A-5 status. The four higher order bits indicate the DMA transfer request status for each channel, ' 1 ' being set when the DREQ input signal is active.

The four lower order bits indicate whether the corresponding channel has reached the TC or not, '1' being set when the TC status is reached. These four lower order bits are reset by status register reading, or RESET input and master clearing. A description of each bit is outlined in Figure 7.

$\left\{\begin{array}{l}0: \text { Channel } 0 \text { has not reached TC } \\ 1: \text { Channel } 0 \text { has reached TC }\end{array}\right.$
$\left\{\begin{array}{l}0: \text { Channel } 1 \text { has not reached TC } \\ 1: \text { Channel } 1 \text { has reached TC }\end{array}\right.$
$\left\{\begin{array}{l}0: \text { Channel } 2 \text { has not reached TC } \\ 1: \text { Channel } 2 \text { has reached TC }\end{array}\right.$
$\left\{\begin{array}{l}0: \text { Channel } 3 \text { has not reached TC } \\ 1: \text { Channel } 3 \text { has reached TC }\end{array}\right.$
$\left\{\begin{array}{l}0: \text { Channel } 0 \text { is not requesting } \\ 1: \text { Channel } 0 \text { is requesting }\end{array}\right.$
$\left\{\begin{array}{l}0: \text { Channel } 1 \text { is not requesting } \\ 1: \text { Channel } 1 \text { is requesting }\end{array}\right.$
$\left\{\begin{array}{l}0: \text { Channel } 2 \text { is not requesting } \\ 1: \text { Channel } 2 \text { is requesting }\end{array}\right.$
$\left\{\begin{array}{l}0: \text { Channel } 3 \text { is not requesting } \\ 1: \text { Channel } 3 \text { is requesting }\end{array}\right.$

Fig. 7 Status register

## TEMPORARY REGISTER

The temporary register is a register where transfer data is held temporarily during memory-memory transfers. Since the last item of data to be trànsferred is held after completion of the transfer, this item can be read by the CPU.

## SOFTWARE COMMAND

The MSM82C37A-5 is equipped with software commands for executing special operations to ensure proper programming. Software command is irrespective of data bus contents.

## CLEAR FIRST/LAST FLIP-FLOP

16-bit address and word count registers are read or written in two consecutive operations involving eight bits each (higher and lower order bits) under data bus port control. The fact that the lower order bits are accessed first by the MSM82C37A-5, followed by accessing of the higher order bits, is discerned by the internal first/last flip-flop. This command resets the first/last flip-flop with the eight lower order bits being accessed immediately after execution.

## MASTER CLEAR

The same operation as when the hardware RESET input is applied. This command clears the contents of the command, status (for lower order bits), request, and temporary registers, also clears the first/last flip-flop, and sets the mask register. This command is followed by an idle cycle.

## CLEAR MASK REGISTER

When this command is executed, the mask bits for all channels are cleared to enable reception of DMA transfers.

## PROGRAMMING

The MSM82C37A-5 is switched to programming status when the HLDA input and $\overline{\mathrm{CS}}$ are both at low level. In this state, $\overline{I O R}$ is changed to low level with $\overline{I O W}$ held at high level to enable reading by the CPU, or else $\overline{\overline{I O W}}$ is changed to low level while $\overline{\mathrm{OR}}$ is held at high level to enable writing by the CPU.

A list of command codes for reading from the MSM82C37A-5 is given in Table 2, and a list of command codes for writing in the MSM82C37A-5 is given Table 3.

Note: If a DMA transfer request is received from an I/O device during MSM82C37A-5 programming, that DMA transfer may be commenced to prevent proper programming.
To prevent this interference, the DMA channel must be masked, or the controller disabled by the command register, or the system set so as to prevent DREQ becoming active during the programming.

Table 2 List of MSM82C37A-5 read commands

| $\overline{\mathrm{CS}}$ | IOR | A3 | A2 | A1 | A0 | Internal first/last flip/flop | Read out data |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | Channel 0 | Current address register | 8 lower order bits |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 |  | Current word count register | 8 lower order bits |
| 0 | 0 | 0 | 0 | 0 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | Channel 1 | Current address register | 8 lower order bits |
| 0 | 0 | 0 | 0 | 1 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 0 | 1 | 1 | 0 |  | Current word count register | 8 lower order bits |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | Channel 2 | Current address register | 8 lower order bits |
| 0 | 0 | 0 | 1 | 0 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 0 | 1 | 0 |  | Current word count register | 8 lower order bits |
| 0 | 0 | 0 | 1 | 0 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 1 | 0 | 0 | Channel 3 | Current address register | 8 lower order bits |
| 0 | 0 | 0 | 1 | 1 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 1 | 1 | 0 |  | Current word count register | 8 lower order bits |
| 0 | 0 | 0 | 1 | 1 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 1 | 0 | 0 | 0 | x | Status register |  |  |
| 0 | 0 | 1 | 1 | 0 | 1 | x | Temporary register |  |  |
| 0 | 0 | Other combinations |  |  |  | X | Output data invalid |  |  |

Table 3 List of MSM82C37A-5 write commands

| $\overline{\mathrm{CS}}$ | IOW | A3 | A2 | A1 | A0 | Internal first/last flip-flop | Written data |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | Channel 0 | Current and base address registers | 8 lower order bits |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 |  | Current and base word count registers | 8 lower order bits |
| 0 | 0 | 0 | 0 | 0 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | Channel 1 | Current and base address registers | 8 lower order bits |
| 0 | 0 | 0 | 0 | 1 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 0 | 1 | 1 | 0 |  | Current and base word count registers | 8 lower order bits |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | Channel 2 | Current and base address registers | 8 lower order bits |
| 0 | 0 | 0 | 1 | 0 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 0 | 1 | 0 |  | Current and base word count registers | 8 lower order bits |
| 0 | 0 | 0 | 1 | 0 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 1 | 0 | 0 | Channel 3 | Current and base address registers | 8 lower order bits |
| 0 | 0 | 0 | 1 | 1 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 1 | 1 | 0 |  | Current and base word count registers | 8 lower order bits |
| 0 | 0 | 0 | 1 | 1 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 1 | 0 | 0 | 0 | x | Command register |  |  |
| 0 | 0 | 1 | 0 | 0 | 1 | x | Request register |  |  |
| 0 | 0 | 1 | 0 | 1 | 0 | x | Single mask register |  |  |
| 0 | 0 | 1 | 0 | 1 | 1 | x | Mode register |  |  |
| 0 | 0 | 1 | 1 | 0 | 0 | x | Clear first/last flip-flop (software command) |  |  |
| 0 | 0 | 1 | 1 | 0 | 1 | $x$ | Master clear (software command) |  |  |
| 0 | 0 | 1 | 1 | 1 | 0 | $x$ | Clear mask register (software command) |  |  |
| 0 | 0 | 1 | 1 | 1 | 1 | x | All mask register |  |  |

## OIXI semiconductor

MSM82C37B-5RS/GS/VJS

## PROGRAMMABLE DMA CONTROLLER

## GENERAL DESCRIPTION

The MSM82C37B-5RS/GS/JS, DMA (Direct Memory Access) controller is capable of high-speed data transfer without CPU intervention and is used as a peripheral device in microcomputer systems. The device features four independent programmable DMA channels.

Due to the use of silicon gate CMOS technology, standby current is $10 \mu \mathrm{~A}$ (max.), and power consumption is as low as 10 mA (max.) when a 5 MHz clock is generated.

All items of AC characteristics are compatible with intel 8237B-5.

## FEATURES

- Maximum operating frequency of $5 \mathrm{MHz}\left(\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 10 \%\right)$ - DMA address increment/decrement selection
- High-speed operation at very low power consumption due to silicon gate CMOS technology
- Wide operating temperature range from $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$
- 4-channels independent DMA control
- DMA request masking and programming
- DMA request priority function
- DREQ and DACK input/output logic inversion
- Memory-to-Memory Transfers
- Channel extension by cascade connection
- DMA transfer termination by $\overline{E O P}$ input
- Intel 8237A-5 compatibility
- TTL Compatible
- 40 pin Plastic DIP (DIP40-P-600)
- 44 pin PLCC (QFJ44-P-S650)
- 44 pin-V Plastic QFP (QFP44-P-910-VK)
- 44 pin-VI Plastic QFP (QFP44-P-910-VIK)

PIN CONNECTIONS


Note: N.C. (No Connection)


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Conditions | Rating |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM82C378-5RS | MSM82C37B5GS | MSM82C37B-5VJS |  |
| Power supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | with respect to GND | $-0.5 \sim+7$ |  |  | V |
| Input voltage | VIN |  | $-0.5 \sim V_{\text {cc }}+0.5$ |  |  | V |
| Output voltage | VOUT |  | $-0.5-v_{c c}+0.5$ |  |  | V |
| Storage temperature | $\mathrm{T}_{\text {stg }}$ |  | $-55 \sim+150$ |  |  | ${ }^{\circ} \mathrm{C}$ |
| Power dissipation | $P_{\text {D }}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | 1.0 | 0.7 | 1.0 | W |

RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Maximum | Typical | Minimum | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Power supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5.0 | 5.5 | V |
| Operating temperature | $\mathrm{T}_{\mathrm{OP}}$ | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| ' L " input voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.5 | - | +0.8 | V |
| " H " input voltage | $\mathrm{V}_{I H}$ | 2.2 | - | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |

## DC CHARACTERISTICS

| Parameter | Symbol | Conditions |  | Maximum | Typical | Minimum | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L' output voltage | $\mathrm{V}_{\mathrm{OL}}$ | $1 \mathrm{OL}=3.2 \mathrm{~mA}$ | $\begin{aligned} \mathrm{VCC} & =4.5 \mathrm{~V} \\ & \sim 5.5 \mathrm{~V} \\ \mathrm{Ta} & =-40^{\circ} \mathrm{C} \\ & \sim+85^{\circ} \mathrm{C} \end{aligned}$ | - | - | 0.4 | V |
| "H" output voltage | $\mathrm{V}_{\mathrm{OH}}$ | $1 \mathrm{OH}=-1.0 \mathrm{~mA}$ |  | 3.7 | - | - | V |
| Input leak current | ILI | $0 \mathrm{~V} \leqq \mathrm{~V}_{\text {IN }} \leqq \mathrm{V}_{\text {CC }}$ |  | -10 | - | 10 | $\mu \mathrm{A}$ |
| Output leak current | ILO | $0 \mathrm{~V} \leqq \mathrm{~V}_{\text {OUT }} \leqq \mathrm{V}_{\text {CC }}$ |  | -10 | - | 10 | $\mu \mathrm{A}$ |
| Average power supply current during operations | ICC | Input frequency 5 MHz , whenRESET $\begin{aligned} & V_{I N}=0 \mathrm{~V} f V_{C C} \\ & C_{L}=0 \mathrm{pF} \end{aligned}$ |  | - | - | 10 | mA |
| Power supply current in standby mode | ICCS | $\begin{aligned} & \text { HLDA }=0 \mathrm{~V}, \\ & \mathrm{VIL}=0 \mathrm{~V}, \\ & \mathrm{VIH}=\mathrm{VCC} \end{aligned}$ |  | - | - | 10 | $\mu \mathrm{A}$ |

## AC CHARACTERISTICS

DMA (MASTER) MODE

| Symbol | Item | MIN | MAX | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TAEL | Delay time from CLK falling edge up to AEN leading edge | - | 200 | ns | - |
| TAET | Delay time from CLK rising edge up to AEN trailing edge | - | 130 | ns | - |
| TAFAB | Delay time from CLK rising edge up to address floating status | - | 90 | ns | - |
| TAFC | Delay time from CLK rising edge up to read/write signal floating status | - | 120 | ns | - |
| TAFDB | Delay time from CLK rising edge up to data bus floating status | - | 170 | ns | - |
| TAHR | Address valid hold time to read signal trailing edge | TCY-100 | - | ns | - |
| TAHS | Data valid hold time to ADSTB trailing edge | 30 | - | ns | - |
| TAHW | Address valid hold time to write signal trailing edge | TCY-50 | - | ns | - |
| TAK | Delay time from CLK falling edge up to active DACK | - | 170 | ns | (Note 3) |
|  | Delay time from CLK rising edge up to $\overline{E O P}$ leading edge | - | 170 | ns | (Note 5) |
|  | Delay time from CLK rising edge up to EOP trailing edge | - | 170 | ns | - |
| TASM | Time from CLK rising edge up to address valid | - | 170 | ns | - |
| TASS | Data set-up time to ADSTB trailing edge | 100 | - | ns | - |
| TCH | Clock high-level time | 68 | - | ns | (Note 6) |


| Symbol | Item | MIN | MAX | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCL | Clock low-level time | 68 | - | ns | (Note 6) |
| TCY | CLK cycle time | 200 | - | ns |  |
| TDCL | Delay time from CLK rising edge to read/write signal leading edge | - | 190 | ns | (Note 2) |
| TDCTR | Delay time from CLK rising edge to read signal trailing edge | - | 190 | ns | (Note 2) |
| TDCTW | Delay time from CLK rising edge to write signal trailing edge | - | 130 | ns | (Note 2) |
| TDO | Delay time from CLK rising edge to HRQ valid | - | 120 | ns | - |
| TEPS | $\overline{E O P}$ leading edge set-up time to CLK falling edge | 40 | - | ns | - |
| TEPW | $\overline{E O P}$ pulse width | 220 | - | ns | - |
| TFAAB | Delay time from CLK rising edge to address valid | - | 170 | ns | - |
| TFAC | Time from CLK rising edge up to active read/write signal | - | 150 | ns | - |
| TFADB | Delay time from CLK rising edge to data valid | - | 200 | ns | - |
| THS | HLDA valid set-up time to CLK rising edge | 75 | - | ns | - |
| TIDH | Input data hold time to $\overline{\text { MEMR }}$ trailing edge | 0 | - | ns | - |
| TIDS | Input data set-up time to $\overline{\text { MEMR }}$ trailing edge | 170 | - | ns | - |
| TODH | Output data hold time to $\overline{\text { MENW }}$ trailing edge | 10 | - | ns | - |
| TODV | Time from output data valid to $\overline{M E M W}$ trailing edge | 125 | - | ns | - |
| TOS | DREQ set-up time to CLK falling edge | 0 | - | ns | (Note 3) |
| TRH | READY hold time to CLK falling edge | 20 | - | ns | - |
| TRS | READY set-up time to CLK falling edge | 60 | - | ns | - |
| TSTL | Delay time from CLK rising edge to ADSTB leading edge | - | 130 | ns | - |
| TSTT | Delay time from CLK rising edge to ADSTB trailing edge | - | 90 | ns | - |

SLAVE MODE

$$
\left(\mathrm{Ta}=-40 \sim+85^{\circ} \mathrm{C}, \mathrm{~V}_{\mathrm{CC}}=4.5 \sim 5.5 \mathrm{~V}\right)
$$

| Symbol | Item | MIN | MAX | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TAR | Time from address valid or $\overline{\mathrm{CS}}$ leading edge to $\overline{\overline{O R}}$ leading edge | 50 | - | ns | - |
| TAW | Address valid set-up time to $\overline{I O W}$ trailing edge | 130 | - | ns | - |
| TCW | $\overline{\mathrm{CS}}$ leading edge set-up time to $\overline{\mathrm{IOW}}$ trailing edge | 130 | - | ns | - |
| TDW | Data valid set-up time to $\overline{\overline{O W}}$ trailing edge | 130 | - | ns | - |
| TRA | Address or $\overline{\mathrm{CS}}$ hold time to $\overline{\mathrm{OR}}$ trailing edge | 0 | - | ns | - |
| TRDE | Data access time to $\overline{O R}$ leading edge | - | 140 | ns | - |
| TRDF | Delay time to data floating status from $\overline{\mathrm{OR}}$ trailing edge | 0 | 70 | ns | - |
| TRSTD | Supply power leading edge set-up time to RESET trailing edge | 500 | - | ns | -- |
| TRSTS | Time to first active $\overline{I O R}$ or $\overline{I O W}$ from RESET trailing edge | 2TCY | - | ns | - |
| TRSTW | RESET pulse width | 300 | - | ns | - |
| TRW | $\overline{\text { IOR }}$ pulse width | 200 | - | ns | - |
| TWA | Address hold time to $\overline{\mathrm{OW}}$ trailing edge | 20 | - | ns | - |
| TWC | $\overline{\mathrm{CS}}$ trailing edge hold time to $\overline{\mathrm{IOW}}$ trailing edge | 20 | - | ns | - |
| TWD | Data hold time to $\overline{10 W}$ trailing edge | 30 | - | ns | - |
| TWWS | $\overline{\text { IOW }}$ pulse width | 160 | - | ns | - |

## Note:

1. Output load capacitance of $150(\mathrm{pF})$.
2. $\overline{10 W}$ and MEMW pulse widths of TCY-100 (ns) for normal writing, and $2 T C Y-100$ (ns) for extended writing. $\overline{10 R}$ and MEMR pulse widths of 2TCY-50 (ns) for normal timing, and TCY-50 (ns) for compressed timing.
3. DREQ and DACK signal active level can be set to either low or high. In the timing chart, the DREQ signal has been set to active-high, and the DACK signal to active-low.
4. When the CPU executes continuous read or write in programming mode, the interval during which the read or write pulse becomes active must be set to at least 400 ns .
5. EOP is an open drain output. The value given is obtained when a 2.2 kohm pull-up resistance is connected to VCC.
6. Rise time and fall time is less than 10 ns .
7. Waveform measurement points for both input and output signals are 2.2 V for HIGH and 0.8 V for LOW, unless otherwise noted.

TIME CHART
RESET TIMING


## SLAVE MODE WRITE TIMING



SLAVE MODE READ TIMING


## DMA TRANSFER TIMING



## MEMORY TO MEMORY TRANSFER TIMING



READY TIMING


## COMPRESSED TRANSFER TIMING



PIN FUNCTIONS

| Symbol | Pin name | Input/ output | Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ | Power |  | +5 $V$ power supply. |
| GND | Ground |  | Ground ( 0 V ) connection. |
| CLK | Clock | Input | Control of MSM82C37B-5 internal operations and data transfer speed. |
| $\overline{\mathrm{CS}}$ | Chip select | Input | $\overline{\mathrm{CS}}$ is active-low input signal used for the CPU to select the MSM82C37B-5 as an I/O device in an idle cycle. |
| RESET | Reset | Input | RESET is active-high asynchronous input signal used to clear command, status, request, temporary registers, and first/last F/F, and to set mask register. The MSM82C37B-5 enters an idle cycle following a RESET. |
| READY | Ready | Input | The read or write pulse width can be extended to accomodate slow access memories and I/O devices when this input is switched to low level. Note this input must not change within the prescribed set-up/hold time. |
| HLDA | Hold acknowledge | Input | HLDA is active-high input signal used to indicate that system bus control has been released when a hold request is received by the CPU. |
| DREQO ~ DREQ3 | DMA request 0 ~ 3 channels | Input | DREQ is asychronous DMA transfer request input signals. Although these pins are switched to active-high by reset, they can be programmed to become active-low. DMA requests are received in accordance with a prescribed order of priority. DREQ must be held until DACK becomes active. |
| DBO ~ DB7 | Data bus $0 \sim 7$ | Input/ output | DB is bidirectional three-state signals connected to the system data bus, and which is used as an input/output of MSM82C37B-5 internal registers during idle cycles, and as an output of the eight higher order bits of transfer addresses during active cycles. Also used as input and output of transfer data during memory-memory transfers. |
| $\overline{\text { IOR }}$ | 1/O read | Input/ output | $\overline{I O R}$ is active-Iow bidirectional three-state signal used as an input control signal for CPU reading of MSM82C37B-5 internal registers during idle cycles, and as an output control signal for reading I/O device transfer data in writing transfers during active cycles. |
| Iow | 1/O write | Input/ output | $\overline{\text { IOW }}$ is active-low bidirectional three-state signal used as an input control signal for CPU writing of MSM82C37B-5 internal registers during idle cycles, and as an output control signal for writing I/O device transfer data in writing transfers during active cycles. |


| Symbol | Pin name | Input/ output | Function |
| :---: | :---: | :---: | :---: |
| $\overline{\text { EOP }}$ | End of process | Input/ output | $\overline{\mathrm{EOP}}$ is active-low bidirectional three-state signal. Unlike other pins, this pin is an N-channel open drain. During DMA operations, a low-level output pulse is obtained from this pin if the channel word count changes from 0000 H to FFFFH. <br> And DMA transfers can be terminated by pulling the $\overline{E O P}$ input to low level. Both of these actions are called terminal count (TC). <br> When an internal or external $\overline{\mathrm{EOP}}$ is generated, the MSM82C37B-5 terminates the transfer and resets the DMA request. <br> When the $\overline{E O P}$ pin is not used, it is necessary to hold the pin at high level by pull-up resistance to prevent the input of an $\overline{E O P}$ by error. Also note that the $\overline{E O P}$ function cannot be satisfied in cascade mode. |
| AO ~ A3 | Address $0 \sim 3$ | Input/ output | AO~A3 is bidirectional three-state signals used as input signals for specifying the MSM82C37B-5 internal register to be accessed by the CPU during idle cycles, and as an output the four lower order bits of the transfer address during active cycles. |
| A4 ~ A7 | Address $4 \sim 7$ | Output | A4~A7 is three-state signals used as an output the four higher order bits of the transfer address during active cycles. |
| HRO | Hold request | Output | HRQ is active-high signal used as an output of hold request to the CPU for system data bus control purposes. After HRQ has become active, at least one clock cycle is required before HLDA becomes active. |
| DACK0 ~ DACK3 | DMA <br> acknowledge <br> $0 \sim 3$ channels | Output | DACK is output signals used to indicate that DMA transfer io peripheral devices has been permitted. (Available in each channel.) <br> Although these pins are switched to active-low when reset, they can be programmed to become active-high. <br> Note that there is no DACK output signal during memory-memory transfers. |
| AEN | Address enable | Output | AEN is active-high output signal used to indicate that output signals sent from the MSM82C37B-5 to the system are valid. And in addition to enabling external latch to hold the eight higher order bits of the transfer address, this signal is also used to disable other system bus buffers. |


| Symbol | Pin name | Input/ <br> output | Function |
| :--- | :--- | :--- | :--- |
| ADSTB | Address strobe | Output | ADSTB is active-high signal used to strobe <br> the eight higher order bits of the transfer address <br> by external latch. |
| $\overline{\text { MEMR }}$ | Memory read | Output | $\overline{\text { MEMR is active-low three-state output signal }}$ <br> used as a control signal in reading data from <br> memory during read transfers and memory- <br> memory transfers. |
| $\overline{\text { MEMW }}$ | Memory write | Output | $\overline{\text { MEMW is active-low three-state output signal }}$ <br> used as a control signal in writing data into <br> memory during write transfers and memory- <br> memory transfers. |



Fig. 1 DMA operation state transition diagram

## OUTLINE OF FUNCTIONS

The MSM82C37B-5 consists of five blocks = three logic sections, an internal register section, and a counter section.

The logic sections include a timing control block where the internal timing and external control signals are generated, a command control block where each instruction from the CPU is decoded, and a priority decision block where the order of DMA channel priority is determined. The purpose of the internal register section is to hold internal states and instructions from the CPU, while the counter section computes addresses and word counts.

## DESCRIPTION OF OPERATIONS

The MSM82C37B-5 operates in two cycles (called the idle and active cycles) which are divided into independent states. Each state is commenced by a clock falling edge and continues for a single clock cycle. The transition from one state to the next in DMA operations is outlined in Figure 1.

## IDLE CYCLE

The idle cycle is entered from the SI state when there is no valid DMA request on any MSM82C37B-5 channel. During this cycle, DREQ and $\overline{\mathrm{CS}}$ inputs are monitored during each cycle. When a valid DMA request is then received, an active cycle is commenced. And if the HLDA and $\overline{\mathrm{CS}}$ inputs are at low level, a programming state is started with MSM82C37B-5 reading or writing executed by $\overline{\mathrm{IOR}}$ or $\overline{\mathrm{IOW}}$. Programming details are described later.

## ACTIVE CYCLE

If a DMA request is received in an unmasked channel while the MSM82C37B-5 is in an idle cycle, or if a software DREQ is generated, the HRQ is changed to high level to commence an active cycle. The initial state of an active cycle is the SO state which is repeated until the HLDA input from the CPU is changed to high level. (But because of internal operational reasons, a minimum of one clock cycle is required for the HLDA is be changed to high level by the CPU after the HRQ has become high level. That is, the SO state must be repeated at least twice.)

After the HLDA has been changed to high level, the SO state proceeds to operational states S1 thru S4 during I/O-memory transfers, or to operational states S11 thru S14 and S21 thru S24 during memory-memory transfers.

If the memory or $1 / 0$ device cannot be accessed within the normal timing, an SW state (wait state) can be inserted by a READY input to extend the timing.

## DESCRIPTION OF TRANSFER TYPES

MSM82C37B-5 transfers between an I/O and memory devices, or transfers between memory devices. The three types of transfers between I/O and memory devices are read, write, and verify.

## I/O-MEMORY TRANSFERS

The operational states during an 1/O-memory transfer are S1, S2, S3, and S4.
In the S1 state, an AEN output is changed to high level to indicate that the control signal from the MSM82C37B-5 is valid. The eight lower order bits of the transfer address are obtained from AO thru A7, and the eight higher order bits are obtained from DBO thru DB7. The ADSTB output is changed to high level at this time to set the eight higher order bits in an external address latch, and the DACK output is made active for the channel where the DMA request is acknowledged. Where there is no change in the eight higher bit transfer address during demand and block mode transfers, however, the S1 state is omitted.

In the S2 state, the $\overline{\mathrm{OR}}$ or $\overline{\mathrm{MEMR}}$ output is changed to low level.
In the S3 state, $\overline{\text { IOW }}$ or MEMW is changed to low level. Where compressed timing is used, however, the S3 state is omitted.

The S2 and S3 states are I/O or memory input/output timing control states.
In the S4 state, $\overline{\overline{O R}, ~} \overline{\mathrm{OWW}}, \overline{\mathrm{MEMR}}$, and $\overline{M E M W}$ are changed to high level, and the word count register is decremented by 1 while the address register is incremented (or decremented) by 1 . This completes the DMA transfer of one word.

Note that in 1/O-memory transfers, data is transferred directly without being taken in by the MSM82C37B-5. The differences in the three types of 1/O-memory transfers are indicated below.

## READ TRANSFER

Data is transferred from memory to the $1 / O$ device by changing $\overline{M E M R}$ and $\overline{\mathrm{IOW}}$ to low level. $\overline{M E M W}$ and $\overline{\mathrm{IOR}}$ are kept at high level during this time.

## WRITE TRANSFER

Data is transferred from the I/O device to memory by changing $\overline{M E M W}$ and $\overline{\overline{O R}}$ to low level. $\overline{M E M R}$ and $\overline{\mathrm{IOW}}$ are kept at high level during this time.

Note that writing and reading in these write and read transfers are with respect to the memory.

## VERIFY TRANSFER

Although verify transfers involve the same operations as write and read transfers (such as transfer address generation and $\overline{\mathrm{EOP}}$ input responses), they are in fact pseudo transfers where all I/O and memory reading/writing control signals are kept inactive. READY inputs are disregarded in verify transfers.

## MEMORY-MEMORY TRANSFERS

Memory-memory transfers are used to transfer data blocks from one memory area to another.
Memory-memory transfers require a total of eight states to complete a single transfer four states (S11 thru S14) for reading from memory, and four states (S21 thru S24) for writing into memory. These states are similar to I/O-memory transfer states, and are distinguished by using two-digit numbers.

In memory-memory transfers, channel 0 is used for reading data from the source area, and channel 1 is used for writing data into the destination area. During the initial four states, data specified by the channel 0 address is read from the memory when MEMR is made active, and is taken in the MSM82C37B-5 temporary register. Then during the latter four states, the data in the temporary register is written in the address specified by channel 1. This completes the transfer of one byte of data. With channel 0 and channel 1 addresses subsequently incremented (or decremented) by 1 , and channel 0,1 word count decremented by 1 , this operation is repeated. The transfer is terminated when the word count reaches $\operatorname{FFFF}(\mathrm{H})$ from $\mathrm{OOOO}(\mathrm{H})$, or when an $\overline{E O P}$ input is applied from an external source. Note that there is no DACK output signal during this transfer.

The following preparations in programming are requiring to enable memory-memory transfers to be started.

## COMMAND REGISTER SETTING

Memory-memory transfers are enabled by setting bit 0 . Channel 0 address can be held for all transfers by setting bit 1 . This setting can be used to enable 1 -word contents of the source area to be written into the entire destination area.

## MODE REGISTER SETTING

The transfer type destination is disregarded in channels 0 and 1 . Memory-memory transfers are always executed in block transfer mode.

## REQUEST REGISTER SETTING

Memory-memory transfers are started by setting the channel 0 request bit.

## MASK REGISTER SETTING

Mask bits for all channels are set to prevent selection of any other channel apart from channel 0 .

## WORD COUNT REGISTER SETTING

The channel 1 word count is validated, while the channel 0 word count is disregarded.
In order to autoinitialize both channels, it is necessary to write the same values into both word count registers.

## DESCRIPTION OF OPERATION MODES

## SINGLE TRANSFER MODE

In single transfer mode, only one word is transferred, and the addresses are incremented (or decremented) by 1 while the word count is decremented by 1 . The HRQ is then changed to low level to return the bus control to the CPU. If DREQ remains active after completion of a transfer, the HRQ is changed to low level. After the HLDA is changed to low level by the CPU, and then changes the HRQ back to high level to commence a fresh DMA cycle. For this reason, a machine cycle can be inserted between DMA cycles by the CPU.

## BLOCK TRANSFER MODE

Once a DMA transfer is started in block mode, the transfer is continued until terminal count (TC) status is reached.

If DREQ remains active until DACK becomes active, the DMA transfer is continued even if DREQ becomes inactive.

## DEMAND TRANSFER MODE

The DMA transfer is continued in demand transfer mode untiL DREQ is no longer active, or until TC status is reached.

During a DMA transfer, intermediate address and word count values are held in the current address and current word count registers. Consequently, if the DMA transfer is suspended as a result of DREQ becoming inactive before TC status is reached, and the DREQ for that channel is then made active again, the suspended DMA transfer is resumed.

## CASCADE TRANSFER MODE

When DMA transfers involving more than four channels are required, connecting a multiple number of MSM82C37A-5 devices in a cascade connection (see Figure 2) enables a simple system extension. This mode is set by setting the first stage MSM82C37B-5 channel to cascade mode. The DREQ and DACK lines for the first stage MSM82C37B-5 channel set to cascade mode are connected to the HRQ and HLDA lines of the respective MSM82C37B-5 devices in the second stage. The first stage MSM82C37B-5 DACK signal must be set to active-high, and the DREQ signal to active-low.

Since the first stage MSM82C37B-5 is only used functionally in determining the order of priority of each channel when cascade mode is set, only DREO and DACK are used - all other inputs are disregarded. And since the system may be hung up if the DMA transfer is activated by software DREQ, do not set a software DREQ for channels where cascade mode has been set.

In addition to the dual stage cascade connection shown in Figure 2, triple stage cascade connections are possible with the second stage also set to cascade mode.


Stage 2
MSM82C37B-5
Fig. 2 MSM82C37B-5 cascade connection system

## I/O•MSM82C37B-5RS/GS/VJS

## AUTOINITIALIZE MODE

Setting bit 4 of the mode register enables autoinitialization of that channel. Following TC generation, autoinitialize involves writing of the base address and the base word count register values in the respective current address and current word count registers. The same values as in the current registers are written in the base registers by the CPU, and are not changed during DMA transfers.

When a channel has been set to autoinitialize, that channel may be used in a second transfer without involving the CPU and without the mask bit being reset after the TC generation.

## PRIORITY MODES

The MSM82C37B-5 makes use of two priority decision modes, and acknowledges the DMA channel of highest priority among the DMA requesting channels.

## FIXED PRIORITY MODE

In fixed priority mode, channel 0 has the highest priority, followed by channel 1,2, and 3 in that order.

## ROTATING PRIORITY MODE

In rotating priority mode, the order of priority is changed so that the channel where the current DMA transfer has been completed is given lowest priority. This is to prevent any one channel from monopolizing the system. The fixed priority is regained immediately after resetting.

Table 1 MSM82C37B-5 priority decision modes

| Priority mode |  | Fixed | Rotating |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Service terminated channel |  | - | CHO | CH 1 | CH 2 | CH 3 |
|  | Highest | CHO | CH 1 | CH 2 | CH 3 | CH |
| Order of priority |  |  |  |  |  |  |
| for next DMA |  | CH 1 | CH 2 | CH 3 | CHO | CH 1 |
|  |  | CH 2 | CH 3 | CH 0 | CH 1 | CH 2 |
|  | Lowest | CH 3 | CHO | CH 1 | CH 2 | CH 3 |

## COMPRESSED TIMING

Setting the MSM82C37B-5 to compressed timing mode enables the S3 state used in extension of the read pulse access time to be omitted (if permitted by system structure) for two or three clock cycle DMA transfers. If the S3 state is omitted, the read pulse width becomes the same as the write pulse width with the address updated in S2 and the read or write operation executed in S4. This mode is disregarded if the transfer is a memory-memory transfer. transfer.

## EXTENDED WRITING

When this mode is set, the $\overline{\mathrm{OW}}$ or $\overline{\mathrm{MEMW}}$ signal which normally appears during the $\mathrm{S3}$ state is obtained during the S2 state, thereby extending the write pulse width. The purpose of this extended write pulse is to enable the system to accomodate memories and I/O devices where the access time is slower. Although the pulse width can also be extended by using READY, that involves the insertion of a SW state to increase the number of states.

## DESCRIPTION OF INTERNAL REGISTERS.

## CURRENT ADDRESS REGISTER

Each channel is equipped with a 16-bit long current address register where the transfer address is held during DMA transfers. The register value is incremented (or decremented) in each DMA cycle. Although this register is 16 bits long, the CPU is accessed by the MSM82C37B-5 eight bits at a time, therefore necessitating two successive 8-bit (lower and higher order bits) reading or writing operations using internal first/last flip-flops.

When autoinitialize has been set, the register is automatically initialized to the original value after TC.

## CURRENT WORD COUNT REGISTER

Each channel is also equipped with a 16 bit-long current word count register where the transfer count is held during DMA transfers. The register value is decremented in each DMA cycle. When the word count value reaches $\operatorname{FFFF}(\mathrm{H})$ from $\mathrm{OOOO}(\mathrm{H})$, a TC is generated. Therefore, a word count vaue which is one less than the actual number of transfers must be set.

Since this register is also 16 bits long, it is accessed by first/last flip-flops control in the same way as the address register. And if autoinitialize has been set, the register is automatically initialized to the original value after TC.

## BASE ADDRESS REGISTER AND BASE WORD COUNT REGISTER

Each channel is equipped with a 16-bit long base address register and base word count register where the initial value of each current register is held. The same values are written in each base register and the current register by the CPU. The contents of the current register can be made ready by the CPU, but the content of the base register cannot be read.

## COMMAND REGISTER

This 8-bit write-only register prescribes DMA operations for all MSM82C37B-5 channels. An outline of all bits is given in Figure 3. When the controller is disabled by setting DB2, there is no HRQ output even if DMA request is active.

DREQ and DACK signals may be active high or active low by setting DB6 and DB7.


## MODE REGISTER

Each channel is equipped with a 6-bit write-only mode register, which is decided by setting DBO, DB1 which channel is to be written when writing from the CPU is programming status. The bit description is outlined in Figure 4.

This register is not cleared by Reset or Master Clear instruction.


Fig. 4 Mode register

## REQUEST REGISTER

In addition to using the DREQ signal, the MSM82C37B-5 can request DMA transfers by software means. This involves setting the request bit of request register. Each channel has a corresponding request bit in the request register, and the order of priority of these bits is determined by the priority decision circuit irrespective of the mask register. DMA transfers are acknowledged in accordance with the decided order of priority.

All request bits are reset when the TC is reached, and when the request bit of a certain channel has been received, all other request bits are cleared. When a memory-memory transfer is commenced, the channel 0 request bit is set. The bit description is outlined in Figure 5.


Fig. 5 Request register

## MASK REGISTER

This register is used in disabling and enabling of DMA transfers in each channel. Each channel includes a corresponding mask bit in the mask register, and each bit is set when the TC is reached if not in autoinitialize mode. This mask register can be set in two different ways.

The method for setting/resetting the register for each channel is outlined in Figure 6(a), while the method for setting/resetting the register for all channels at once is outlined in Figure 6 (b).

(a) Single mask register (setting/resetting for each channel)

(b) All mask register (setting/resetting of all channels at once)

Fig. 6 Mask register

## STATUS REGISTER

This register is a read-only register used in CPU reading of the MSM82C37B-5 status. The four higher order bits indicate the DMA transfer request status for each channel, ' 1 ' being set when the DREQ input signal is active.

The four lower order bits indicate whether the corresponding channel has reached the TC or not, ' 1 ' being set when the TC status is reached. These four lower order bits are reset by status register reading, or RESET input and master clearing. A description of each bit is outlined in Figure 7.


Fig. 7 Status register

## TEMPORARY REGISTER

The temporary register is a register where transfer data is held temporarily during memory-memory transfers. Since the last item of data to be trànsferred is held after completion of the transfer, this item can be read by the CPU.

## SOFTWARE COMMAND

The MSM82C37B-5 is equipped with software commands for executing special operations to ensure proper programming. Software command is irrespective of data bus contents.

## CLEAR FIRST/LAST FLIP-FLOP

16-bit address and word count registers are read or written in two consecutive operations involving eight bits each (higher and lower order bits) under data bus port control. The fact that the lower order bits are accessed first by the MSM82C37B-5, followed by accessing of the higher order bits, is discerned by the internal first/last flip-flop. This command resets the first/last flip-flop with the eight lower order bits being accessed immediately after execution.

## MASTER CLEAR

The same operation as when the hardware RESET input is applied. This command clears the contents of the command, status (for lower order bits), request, and temporary registers, also clears the first/last flip-flop, and sets the mask register. This command is followed by an idle cycle.

## CLEAR MASK REGISTER

When this command is executed, the mask bits for all channels are cleared to enable reception of DMA transfers.

## PROGRAMMING

The MSM82C37B-5 is switched to programming status when the HLDA input and $\overline{\mathrm{CS}}$ are both at low level. In this state, $\overline{I O R}$ is changed to low level with $\overline{I O W}$ held at high level to enable reading by the CPU, or else $\overline{I O W}$ is changed to low level while $\overline{\mathrm{OR}}$ is held at high level to enable writing by the CPU.

A list of command codes for reading from the MSM82C37B-5 is given in Table 2, and a list of command codes for writing in the MSM82C37B-5 is given Table 3.

Note: If a DMA transfer request is received from an I/O device during MSM82C37B-5 programming, that DMA transfer may be commenced to p,revent proper programming.
To prevent this interference, the DMA channel must be masked, or the controller disabled by the command register, or the system set so as to prevent DREQ becoming active during the programming.

Table 2 List of MSM82C37B-5 read commands

| $\overline{\mathrm{CS}}$ | $\overline{I O R}$ | A3 | A2 | A1 | A0 | Internal first/last flip/flop | Read out data |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | Channel 0 | Current address register | 8 lower order bits |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 |  | Current word count register | 8 lower order bits |
| 0 | 0 | 0 | 0 | 0 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | Channel 1 | Current address register | 8 lower order bits |
| 0 | 0 | 0 | 0 | 1 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 0 | 1 | 1 | 0 |  | Current word count register | 8 lower order bits |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | Channel 2 | Current address register | 8 lower order bits |
| 0 | 0 | 0 | 1 | 0 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 0 | 1 | 0 |  | Current word count register | 8 lower order bits |
| 0 | 0 | 0 | 1 | 0 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 1 | 0 | 0 | Channel 3 | Current address register | 8 lower order bits |
| 0 | 0 | 0 | 1 | 1 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 1 | 1 | 0 |  | Current word count register | 8 lower order bits |
| 0 | 0 | 0 | 1 | 1 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 1 | 0 | 0 | 0 | x | Status register |  |  |
| 0 | 0 | 1 | 1 | 0 | 1 | x | Temporary register |  |  |
| 0 | 0 | Other combinations |  |  |  | x | Output data invalid |  |  |

Table 3 List of MSM82C37B-5 write commands

| $\overline{\mathrm{CS}}$ | IOW | A3 | A2 | A1 | A0 | Internal first/last flip-flop | Written data |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | Channel 0 | Current and base address registers | 8 lower order bits |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 |  | Current and base word count registers | 8 lower order bits |
| 0 | 0 | 0 | 0 | 0 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | Channel 1 | Current and base address registers | 8 lower order bits |
| 0 | 0 | 0 | 0 | 1 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 0 | 1 | 1 | 0 |  | Current and base word count registers | 8 lower order bits |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | Channel 2 | Current and base address registers | 8 lower order bits |
| 0 | 0 | 0 | 1 | 0 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 0 | 1 | 0 |  | Current and base word count registers | 8 lower order bits |
| 0 | 0 | 0 | 1 | 0 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 1 | 0 | 0 | Channel 3 | Current and base address registers | 8 lower order bits |
| 0 | 0 | 0 | 1 | 1 | 0 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 0 | 1 | 1 | 1 | 0 |  | Current and base word count registers | 8 lower order bits |
| 0 | 0 | 0 | 1 | 1 | 1 | 1 |  |  | 8 higher order bits |
| 0 | 0 | 1 | 0 | 0 | 0 | x | Command register |  |  |
| 0 | 0 | 1 | 0 | 0 | 1 | X | Request register |  |  |
| 0 | 0 | 1 | 0 | 1 | 0 | x | Single mask register |  |  |
| 0 | 0 | 1 | 0 | 1 | 1 | x | Mode register |  |  |
| 0 | 0 | 1 | 1 | 0 | 0 | $\times$ | Clear first/last flip-flop (software command) |  |  |
| 0 | 0 | 1 | 1 | 0 | 1 | x | Master clear (software command) |  |  |
| 0 | 0 | 1 | 1 | 1 | 0 | x | Clear mask register (software command) |  |  |
| 0 | 0 | 1 | 1 | 1 | 1 | x | All mask register |  |  |

## DIEI semiconductor

MSM82C43RS/GS

## INPUT/OUTPUT PORT EXPANDER

## GENERAL DESCRIPTION

The MSM82C43 is an input/output port expander device based on $3 \mu$ silicon gate CMOS technology and designed to operate at low power consumption levels.

In systems employing the MSM80C48/49 8-bit 1-chip microcomputers, 4-bit data can be expanded by dividing between four I/O lines by executing the MOVDPp. A, MOVDA, Pp, ANLDPp, A and ORLDPp, A instructions.

## FEATURES

- $3 \mu$ silicon gate CMOS technology for low power consumption
- 2.5 to 6 V single power supply (dependeht on MSM80C 48/49 operating frequency.)
- Fully static operation
- Bidirectional I/O ports
- TTL compatible (ports 4 thru 7)
- Functional compatibility with Intel i8243
- 24 pin Plastic DIP (DIP24-P-600)
- 24 pin Plastic SOP (SOP24-P-430-K)
- 24 pin-V Plastic SOP (SOP24-P-430-VK)



## ELECTRIC CHARACTERISTICS

- Absolute Maximum Ratings

| Parameter | Symbol | Conditions | Rating | Unit |
| :--- | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | $-0.5 \sim 7$ | V |
| Input Voltage | $\mathrm{V}_{1}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | $-0.3 \sim \mathrm{~V}_{\mathrm{CC}}$ | V |
| Storage Temperature | Tstg | - | $-65 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

## - Operating Conditions

| Parameter | Symbol | Conditions | Rating | Unit |
| :--- | :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{C C}$ | - | $2.5 \sim 6^{* 1}$ | V |
| Ambient Temperature | $T_{A}$ | - | $-40 \sim+85$ | ${ }^{\circ} \mathrm{C}$ |
| Fan-out | N | MOS load | 10 | - |
|  |  | TTL load | $3^{* 2}$ | - |

## - DC Characteristics

$\left(\mathrm{V}_{\mathrm{CC}}=4.0 \mathrm{~V} \sim 6.0 \mathrm{~V}, \mathrm{Ta}=-40^{\circ} \mathrm{C} \sim+85^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L" Input Voltage | $V_{\text {IL }}$ |  | -0.5 | - | 0.13 Vcc | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ |
| " H " Input Voltage | $\mathrm{V}_{1 \mathrm{H}}$ |  | 0.4Vcc | - | $\mathrm{V}_{\mathrm{Cc}}$ | $\begin{aligned} & v \\ & v \end{aligned}$ |
| "L" Output Voltage Ports 4-7. | $\mathrm{V}_{\mathrm{OL} 1}$ | $1 \mathrm{OL}=5 \mathrm{~mA}$ | - | - | 0.45 | V |
| '"L' Output Voltage Port 7 | VOL2 | $1 \mathrm{OL}=20 \mathrm{~mA}$ | - | - | 1 | V |
| "L' Output Voltage Port 2 | $\mathrm{V}_{\text {OL3 }}$ | $1 \mathrm{OL}=0.9 \mathrm{~mA}$ | - | - | 0.45 | V |
| "L' Total Output Current from Ports 4-7*3 | IOL | $5 \mathrm{~mA} / 1 \mathrm{PIN}$ | - | - | 80 | mA |
| "H" Output Voltage Ports 4-7 | $\mathrm{V}_{\mathrm{OH} 1}$ | $\mathrm{I}^{\mathrm{OH}}=-240 \mu \mathrm{~A}$ | $0.75 \mathrm{~V}_{\text {cc }}$ | - | - | V |
| " H " Output Voltage Port 2 | $\mathrm{V}_{\mathrm{OH} 2}$ | $1 \mathrm{OH}=-100 \mu \mathrm{~A}$ | $0.75 \mathrm{~V}_{\mathrm{CC}}$ | - | - | V |
| "H" Output Voltage Ports 4-7 | $\mathrm{V}_{\mathrm{OH} 1}$ | $\mathrm{IOH}^{\prime}=-40 \mu \mathrm{~A}$ | 0.93 V cc | - | - | V |
| " H " Output Voltage Port 2 | $\mathrm{V}_{\mathrm{OH} 2}$ | $\mathrm{IOH}^{\prime}=-20 \mu \mathrm{~A}$ | 0.93 V CC | - | - | V |
| Input Leak Current*3 | IIL1 | $0 \leqq \mathrm{~V}_{\text {IN }} \leqq \mathrm{V}_{\text {CC }}$ | -10 | - | 20 | $\mu \mathrm{A}$ |
| Input Leak Current* ${ }^{*}$ | IIL2 | $0 \leqq \mathrm{~V}_{\text {IN }} \leqq \mathrm{V}_{\text {CC }}$ | -10 | - | 10 | $\mu \mathrm{A}$ |
|  |  | Standby stop No accessing | - | 5 | 100 | $\mu \mathrm{A}$ |
| Power Supply Current | ${ }^{\prime} \mathrm{Cc}$ | For continuous MSM80C49 accessing at 11 MHz | - | 1 | 2 | mA |

NOTE: *1 The supply voltage during operation is dependent on MSM80C49 operating frequency.
*2 Except P20 thru P23.
*3 P40 thru P43, P50 thru P53, P60 thru P63, P70 thru P73.
*4 P70 thru P73.
*5 P20 thru P23.
*6 P20 thru P23, CS, PROG.

- AC Characteristics $\quad\left(V_{C C}=4.0 \mathrm{~V} \sim 6.0 \mathrm{~V}, \mathrm{Ta}=-40^{\circ} \mathrm{C} \sim+85^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Conditions | MIN | MAX | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Port Control Setting Time (up to PROG Falling Edge) | ${ }^{\text {t }}$ A | 80pF LOAD | 50 | - | ns |
| Port Control Holding Time (From PROG Falling Edge) | ${ }^{\text {t }}$ B | 20pF LOAD | 60 | - | ns |
| Output Data Setting Time | ${ }^{\text {t }}$ C | 80pF LOAD | 200 | - | ns |
| Output Data Holding Time | ${ }^{\text {t }}$ | 20pF LOAD | 20 | - | ns |
| Input Data Holding Time | ${ }^{\text {t }} \mathrm{H}$ | 20pF LOAD | 0 | 150 | ns |
| PROG Pulse Width | $\mathrm{t}_{\mathrm{K}}$ | - | 700 | - | ns |
| $\overline{\text { CS }}$ Valid Time (before and after PROG) | ${ }^{\text {t }} \mathrm{C}$ | - | 50 | - | ns |
| Output Data Valid Time (at Ports 4-7) | tpo | 100pF LOAD | - | 700 | ns |
| Input Data Holding Time (at Ports 4-7) | t LP1 | - | 100 | - | ns |
| Input Data Valid Time (from PROG Falling Edge) | ${ }^{t} \mathrm{ACC}$ | 80pF LOAD | - | 650 | ns |

TIMING CHART


## PIN FUNCTIONS

| Pin | Function |
| :---: | :--- |
| PROG | Clock input from MSM80C49. When PROG is changed from " H " to " L ", MSM82C43 STARTS <br> operating in accordance with an order from MSM80C49. |
| $\overline{\mathrm{CS}}$ | Input for chip select. Outputs and internal status cannot be changed when $\overline{\mathrm{CS}}$ is " H ". |
| P20 - P23 | 4-bit bidirectional I/O ports. When connected to P20 thru P23 of MSM80C49, direct data <br> transfer from port to accumulator and from accumulator to port is possible. |
| P40 - P43 | 4-bit bidirectional I/O ports. <br> P50 - P53 <br> P60 - P63 <br> P70 - P73 latched statistically when output to ports, but is only valid while PROG is at "L" level <br> when input. |
| VCC | +5V power supply |
| GND | GROUND |

## FUNCTIONS

## - Write mode

Execution of MOVDPp, A, ORLDPp, A, ANLDPp, and $A$ by MSM80C49 enables direct output of accumulator contents to ports 4 thru 7, and output to the ports after ORing or ANDing with port data. The port data is latched statistically at this time and remains unchanged until execution of the next instruction.

## - Read mode

Execution of MOVDA and Pp results in data of ports 4 thru 7 being accepted by the accumulator. Note that port data is valid only while PROG is at " $L$ "'
level. When at " H " level, ports 4 thru 7 are switched to tristate and port 2 is switched to input mode.

- Address and instruction code

| Instruction | P23 | P22 | Port | P21 | P20 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | 0 | 0 | Port 4 | 0 | 0 |
| Write | 0 | 1 | Port 5 | 0 | 1 |
| OR | 1 | 0 | Port 6 | 1 | 0 |
| AND | 1 | 1 | Port 7 | 1 | 1 |

## - MSM82C43 Multiple connection example



## OUTPUT CHARACTERISTICS

## - Standard DC characteristics

Output "H" voltage ( $\mathrm{V}_{\mathrm{OH}}$ ) vs. output current ( $\mathrm{I}_{\mathrm{OH}}$ )


Output " L " voltage ( $\mathrm{VOL}_{\mathrm{OL}}$ ) vs. output current ( $\mathrm{OLL}^{\prime}$ )


Operating frequency vs. power supply voltage ( ${ }^{\mathrm{CC}}$ )


## - Standard AC characteristics

${ }^{\mathrm{t} P O},{ }^{t_{H}}$, and $\mathrm{t}_{\mathrm{ACC}}$ vs. power supply voltage ( $\mathrm{V}_{\mathrm{CC}}$ )


Note:
The direction which the output current flows through the device is taken as the positive direction.

## gUARANTEED MSM82C43 OPERATING RANGE



## OIKI semiconductor <br> MSM82C51A-2RS/GS/JS

UNIVERSAL SYNCHRONOUS ASYNCHRONOUS RECEIVER TRANSMITTER

## GENERAL DESCRIPTION

The MSM82C51A is a USART (Universal Synchronous Asynchronous Receiver Transmitter) for serial data communication.

As a peripheral device of a microcomputer system, the MSM82C51A receives parallel data from the CPU and transmits serial data after conversion. This device also receives serial data from the outside and transmits parallel data to the CPU after conversion.

The MSM82C51A configures a fully static circuit using silicon gate CMOS technology. Therefore, it operates on extremely low power at $100 \mu \mathrm{~A}$ (max) of standby current by suspending all operations.

## FEATURES

- Wide power supply voltage range from 3 V to 6 V .
- Wide temperature range from $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$.
- Synchronous communication upto 64 K baud.
- Asvnchronous communication upto 38.4 K baud.
- Transmitting/receiving operations under double buf-
fered configuration.
- Error detection (parity, overrun and framing)
- 28 pin Plastic DIP (DIP28-P-600)
- 28 pin PLCC (QFJ28-P-S450)
- 32 pin-V Plastic SOP (SSOP32-P430-VK)

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATION



## FUNCTION

## Outline

The MSM82C51A's functional configuration is programed by software.

Operation between the MSM82C51A and a CPU is executed by program control. Table 1 shows the operation between a CPU and the device.

Table 1 Operation between MSM82C51A and CPU

| $\overline{\mathrm{CS}}$ | $\mathrm{C} / \overline{\mathrm{D}}$ | $\overline{\mathrm{RD}}$ | $\overline{\mathrm{WR}}$ |  |
| :---: | :---: | :---: | :---: | :--- |
| 1 | X | x | X | Data bus 3-state |
| 0 | X | 1 | 1 | Data bus 3-state |
| 0 | 1 | 0 | 1 | Status $\rightarrow$ CPU |
| 0 | 1 | 1 | 0 | Control word $\leftarrow \mathrm{CPU}$ |
| 0 | 0 | 0 | 1 | Data $\rightarrow$ CPU |
| 0 | 0 | 1 | 0 | Data $\leftarrow \mathrm{CPU}$ |

It is necessary to execute a function-setting sequence after resetting the MSM82C51A. Fig. 1 shows the function-setting sequence.

If the function was set, the device is ready to receive a command, thus enabling the transfer of data.
by setting a necessary command, reading a status and reading/writing data.


Fig. 1 Function-Setting Sequence (Mode Instruction Sequence)

## Control Words

There are two types of control word.

1. Mode instruction (setting of function)
2. Command (setting of operation)

## 1) Mode Instruction

Mode instruction is used for setting the function of the MSM82C51A. Mode instruction will be in "wait for write" at either internal reset or external reset. That is, the writing of, a control word after resetting will be recognized as a 'mode instruction."

Items set by mode instruction are as follows:

- Synchronous/asynchronous mode
- Stop bit length (asynchronous mode)
- Character length
- Parity bit
- Baud rate factor (asynchronous mode)
- Internal/external synchronization (synchronous mode)
- No. of synchronous characters (synchronous mode)

The bit configuration of mode instruction is shown in Fig.'s 2 and 3. In the case of synchronous mode, it is necessary to write one- or twobyte sync characters.

If sync characters were written, a function will be set because the writing of sync characters constitutes part of mode instruction.

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathrm{~S}_{2}$ | $\mathrm{~S}_{1}$ | EP | PEN | $\mathrm{L}_{2}$ | $\mathrm{~L}_{1}$ | $\mathrm{~B}_{2}$ | $\mathrm{~B}_{1}$ |



Baud rate factor

| 0 | 1 | 0 | 1 |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | 1 |
| Refer to <br> Fig. 3 <br> SYNC | $1 \times$ | $16 \times$ | $64 \times$ |

Character length


Parity check

| 0 | 1 | 0 | 1 |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | 1 |
| Disable | Odd <br> parity | Disable | Even <br> parity |

Fig. 2 Bit Configuration of Mode Instruction (Asynchrnous)


Fig. 3 Bit Configuration of Mode Instruction (Synchronous)
2) Command

Command is used for setting the operation of the MSM82C51A.

It is possible to write a command whenever necessary after writing a mode instruction and sync characters.

Items to be set by command are as follows:

- Transmit Enable/Disable
- Receive Enable/Disable
- $\overline{\mathrm{DTR}}, \overline{\mathrm{RTS}}$ Output of data.
- Resetting of error flag.
- Sending of break characters
- Internal resetting
- Hunt mode (synchronous mode)

The bit configuration of a command is shown in Fig. 4.

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EH | IR | RTS | ER | SBRK | RXE | DTR | TXEN |


(Note) Search mode for synchronous characters in synchronous mode.

Fig. 4 Bit Configuration of Command

## Status Word

It is possible to see the internal status of MSM82C51 A by reading a status word.

The bit configuration of status word is shown in Fig. 5.


Fig. 5 Bit Configuration of Status Word

## Standby Status

It is possible to put the MSM82C51A in "standby status".

When the following conditions have been satisfied the MSM82C51A is in "standby status."
(1) $\overline{C S}$ terminal is fixed at Vcc level.
(2) Input pins other than $\overline{\mathrm{CS}}, \mathrm{D}_{0}$ to $\mathrm{D}_{7}, \overline{\mathrm{RD}}$, $\overline{W R}$ and $C / \bar{D}$ are fixed at Vcc or GND level (including SYNDET in external synchronous mode).
Note When all output currents are 0, ICCS specification is applied.

## Pin Description

$\mathrm{D}_{0}$ to $\mathrm{D}_{7}$ (I/O terminal)
This is bidirectional data bus which receive control words and transmits data from the CPU and sends status words and received data to CPU.

RESET (Input terminal)
A "High" on this input forces the MSM82C51A into "reset status."

The device waits for the writing of "mode instruction."

The min. reset width is six clock inputs during the operating status of CLK.

CLK (Input terminal)
CLK signal is used to generate internal device timing.

CLK signal is independent of $\overline{\mathrm{RXC}}$ or $\overline{\mathrm{TXC}}$.
However, the frequency of CLK must be greater than 30 times the $\overline{\mathrm{RXC}}$ and $\overline{\mathrm{TXC}}$ at Synchronous mode and Asynchronous ' $x 1$ '' mode, and must be greater than 5 times at Asynchronous " $\times 16$ ' and ' $x 64$ " mode.

## $\overline{\mathbf{W R}}$ (Input terminal)

This is the "active low" input terminal which receives a signal for writing transmit data and contro! words from the CPU into the MSM82C51A.

## $\overline{\mathbf{R D}}$ (Input terminal)

This is the "active low" input terminal which receives a signal for reading receive data and status words from the MSM82C51A.
$\mathbf{C} / \overline{\mathbf{D}}$ (Input terminal)
This is an input terminal which receives a signal for selecting data or command words and status words when the MSM82C51A is accessed by the CPU.

If $C / \bar{D}=$ low, data will be accessed.
If $C / \bar{D}=$ high, command word or status word will be accessed.
$\overline{\mathbf{C S}}$ (Input terminal)
This is the "active low" input terminal which selects the MSM82C51A at low level when the CPU accesses.

Note The device won't be in "standby status"; only setting $\overline{\mathrm{CS}}=$ High.
Refer to "Explanation of Standby Status."

TXD (Output terminal)
This is an output terminal for transmitting data from which serial-converted data is sent out.

The device is in "mark status" (high level) after resetting or during a status when transmit is disabled. It is also possible to set the device in "break status" (low level) by a command.

## TXRDY (Output terminal)

This is an output terminal which indicates that the MSM82C51A is ready to accept a transmitted data character. But the terminal is always at low level if CTS = high or the device was set in "TX disable status" by a command.

Note TXRDY status word indicates that transmit data character is receivable, regardless of CTS or command.
IF the CPU writes a data character, TXRDY will be reset by the leading edge or $\overline{W R}$ signal.

## TXEMPTY (Output terminal)

This is an output terminal which indicates that the MSM82C51A has transmitted all the characters and had no data character.

In "synchronous mode," the terminal is at high level, if transmit data characters are no longer remaining and sync characters are automatically transmitted.

If the CPU writes a data character, TXEMPTY will be reset by the leading edge of WR signal.

Note As the transmitter is disabled by setting CTS "High" or command, data written before disable will be sent out. Then TXD and TXEMPTY will be "High".
Even if a data is written after disable, that data is not sent out and TXE will be "High". After the transmitter is enabled, it sent out. (Refer to Timing Chart of Transmitter Control and Flag Timing)
$\overline{\text { TXC }}$ (Input terminal)
This is a clock input signal which determines the transfer speed of transmitted data.

In "synchronous mode," the baud rate will be the same as the frequency of TXC.

In "asynchronous mode", it is possible to select the baud rate factor by mode instruction.

It can be $1,1 / 16$ or $1 / 64$ the TXC.
The falling edge of TXC sifts the serial data out of the MSM82C51A.

RXD (Input terminal)
This is a terminal which receives serial data.
RXRDY (Output terminal)
This is a terminal which indicates that the MSM82C51A contains a character that is ready to READ.

If the CPU reads a data character, RXRDY will be reset by the leading edge of $\overline{\mathrm{RD}}$ signal.

Unless the CPU reads a data character before the next one is received completely, the preceding data will be lost. In such a case, an overrun error flag status word will be set.
$\overline{\text { RXC }}$ (Input terminal)
This is a clock input signal which determines the transfer speed of received data.

In "synchronous mode," the baud rate is the same as the frequency of RXC.

In "asynchronous mode," it is possible to select the baud rate factor by mode instruction.

It can be 1, 1/16, 1/64 the RXC.
SYNDET/BD (Input or output terminal)
This is a terminal whose function changes according to mode.

In 'internal synchronous mode," this terminal is at high level, if sync characters are received and synchronized. If a status word is read, the terminal will be reset.

In "external synchronous mode," this is an input terminal.

A "High" on this input forces the MSM82C51A to start receiving data characters.

In "asynchronous mode,' this is an output terminal which generates "high level" output upon the detection of a "break" character if receiver data contains a "low-level" space between the stop bits of two continuous characters. The terminal will be reset, if RXD is at high level.
$\overline{\text { DSR }}$ (Input terminal)
This is an input port for MODEM interface. The input status of the terminal can be recognized by the CPU reading status words.
DTR (Output terminal)
This is an output port for MODEM interface. It is possible to set the status of DTR by a command.

## $\overline{\text { CTS }}$ (Input terminal)

This is an input terminal for MODEM interface which is used for controlling a transmit circuit. The terminal controls data transmission if the device is set in "'TX Enable" status by a command. Data is transmitable if the terminal is at low level.
$\overline{\mathrm{RTS}}$ (Output terminal)
This is an output port for MODEM interface. It is possible to set the status of $\overline{\mathrm{RTS}}$ by a command.

## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MSM82C51A-2RS | MSM82C51A-2GS | MSM82C51A-2JS |  |  |
| Power supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | $-0.5 \sim+7$ |  |  | V | With respect to GND |
| Input voltage | $V_{\text {IN }}$ | $-0.5 \sim \mathrm{~V}_{\mathrm{cc}}+0.5$ |  |  | V |  |
| Output voltage | $V_{\text {OUT }}$ | $-0.5 \sim v_{c c}+0.5$ |  |  | $\checkmark$ |  |
| Storage temperature | $\mathrm{T}_{\text {stg }}$ | $-55 \sim+150$ |  |  | ${ }^{\circ} \mathrm{C}$ | - |
| Power dissipation | $P_{\text {D }}$ | 0.9 | 0.7 | 0.9 | W | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ |

## OPERATING RANGE

| Parameter | Symbol | Limits | Unit |
| :---: | :---: | :---: | :---: |
| Power supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | $3 \sim 6$ | V |
| Operating temperature | TOP | $-40 \sim 85$ | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Power supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5 | 5.5 | V |
| Operating temperature | TOP | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| '" L " input voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 |  | +0.8 | V |
| " H ' input voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.2 |  | $\mathrm{~V}_{\mathrm{CC}}+0.3$ | V |

## DC CHARACTERISTICS

$\left(\mathrm{Vcc}=4.5 \sim 5.5 \mathrm{~V} \mathrm{Ta}=-40^{\circ} \mathrm{C} \sim+85^{\circ} \mathrm{C}\right.$ )

| Parameter | Symbol | Min. | Typ. | Max. | Unit | Measurement Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| '"L' output voltage | $\mathrm{V}_{\mathrm{OL}}$ |  |  | 0.45 | V | $1 \mathrm{OL}=2.5 \mathrm{~mA}$ |
| " H " output voltage | $\mathrm{V}_{\mathrm{OH}}$ | 3.7 |  |  | V | $\mathrm{I}^{\mathrm{OH}}=-2.5 \mathrm{~mA}$ |
| Input leak current | $\mathrm{I}_{\mathrm{LI}}$ | -10 |  | 10 | $\mu \mathrm{A}$ | $0 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |
| Output leak current | ILO | -10 |  | 10 | $\mu \mathrm{A}$ | $0 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ |
| Operating supply current | Ícoo |  |  | 5 | mA | Asynchronous X64 during transmitting/receiving |
| Standby supply current | I'ccs |  |  | 100 | $\mu \mathrm{A}$ | All input voltage shall be fixed at $V_{\text {CC }}$ or GND level. |

## AC CHARACTERISTICS

( $\mathrm{Vcc}=4.5 \sim 5.5 \mathrm{~V}, \mathrm{Ta}=-40 \sim 85^{\circ} \mathrm{C}$ )

## CPU Bus Interface Part

| Parameter | Symbol | Min. | Max. | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Address stable before $\overline{\mathrm{RD}}$ | ${ }^{\text {t }}$ AR | 20 |  | NS | Note 2 |
| Address hold time for $\overline{\mathrm{RD}}$ | ${ }^{\text {tRA }}$ | 20 |  | NS | Note 2 |
| $\overline{\mathrm{RD}}$ pulse width | trR | 130 |  | NS |  |
| Data delay from $\overline{\mathrm{RD}}$ | tr ${ }^{\text {d }}$ |  | 100 | NS |  |
| $\overline{\mathrm{RD}}$ to data float | ${ }^{\text {t }} \mathrm{DF}$ | 10 | 75 | NS |  |
| Recovery time between $\overline{\mathrm{RD}}$ | tr VR | 6 |  | $\mathrm{T}_{\mathrm{cy}}$ | Note 5 |
| Address stable before $\overline{W R}$ | ${ }_{\text {t }}$ AW | 20 |  | NS | Note 2 |
| Address hold time for $\overline{\text { WR }}$ | tWA | 20 |  | NS | Note 2 |
| $\overline{\text { WR }}$ pulse width | tww | 100 |  | NS |  |
| Data set-up time for $\overline{W R}$ | t DW | 100 |  | NS |  |
| Data hold time for $\overline{W R}$ | twD | 0 |  | NS |  |
| Recovery time between WR | $t_{\text {r }}$ VW | 6 |  | $\mathrm{T}_{\text {cy }}$ | Note 4 |
| RESET pulse width | tresw | 6 | . | $\mathrm{T}_{\mathrm{cy}}$ |  |

Serial Interface Part

| Parameter |  | Symbol | Min. | Max. | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Main clock period |  | $\mathrm{t}_{\mathrm{c}} \mathrm{l}$ | 160 |  | NS | Note 3 |
| Clock low time |  | $\mathbf{t}_{\bar{\phi}}$ | 50 |  | NS |  |
| Clock high time |  | ${ }^{\text {t }}$ ${ }_{\text {¢ }}$ | 70 | $\mathrm{t}_{\mathrm{cy}} \mathbf{- 5 0}$ | NS |  |
| Clock rise/fall time |  | $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}$ |  | 20 | NS |  |
| TXD delay from falling edge of $\overline{\text { TXC }}$ |  | tDTX |  | 1 | $\mu \mathrm{S}$ |  |
| Transmitter clock frequency | 1X Baud | ${ }^{\text {f }}$ TX | DC | 64 | kHz | Note 3 |
|  | 16X, Baud | ${ }^{\text {f }}$ TX | DC | 615 | kHz |  |
|  | 64X, Baud | ${ }^{\text {f }}$ TX | DC | 615 | kHz |  |
| Transmitter clock low time | 1 X Baud | ${ }^{\text {t TPW }}$ | 13 |  | $\mathrm{T}_{\mathrm{cy}}$ |  |
|  | 16X, 64X Baud | ${ }^{\text {t TPW }}$ | 2 |  | $\mathrm{T}_{\mathrm{cy}}$ |  |
| Transmitter clock high time | 1X Baud | ${ }^{\text {t TPD }}$ | 15 |  | $\mathrm{T}_{\mathrm{cy}}$ |  |
|  | 16X, 64X Baud | ${ }^{\text {t TPD }}$ | 3 |  | $\mathrm{T}_{\mathrm{cy}}$ |  |
| Receiver clock frequency | 1X Baud | ${ }^{\text {fr }}$ X | DC. | 64 | kHz | Note 3 |
|  | 16X Baud | $f_{R X}$ | DC | 615 | kHz |  |
|  | 64X Baud | ${ }_{\text {frx }}$ | DC | 615 | kHz |  |
| Receiver clock low time | 1X Baud | $t_{\text {R P W }}$ | 13 |  | $\mathrm{T}_{\mathrm{cy}}$ |  |
|  | 16X, 64X Baud | $t_{\text {RPW }}$ | 2 |  | $\mathrm{T}_{\text {cy }}$ |  |
| Receiver clock high time | 1X Baud | $t_{\text {RPD }}$ | 15 |  | $\mathrm{T}_{\text {cy }}$ |  |
|  | 16X, 64X Baud | $t_{\text {RPD }}$ | 3 |  | $\mathrm{T}_{\mathrm{cy}}$ |  |
| Time from the center of last bit to the rise of TXRDY |  | ${ }^{\text {t }}$ TXRD ${ }^{\text {l }}$ |  | 8 | $T_{c y}$ |  |
| Time from the leading edge of $\overline{W R}$ to the fall of TXRDY |  | t'XRRDY CLEAR |  | 400 | NS |  |
| Time from the center of last bit to the rise of RXRDY |  | trXRDY |  | 26 | $\mathrm{T}_{\mathrm{cy}}$ |  |


| Parameter | Symbol | Min. | Max. | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Time from the leading edge of $\overline{\mathrm{RD}}$ to the fall of RXRDY | ${ }^{\text {t RXXRDY CLEAR }}$ |  | 400 | NS |  |
| Internal SYNDET delay time from rising edge of $\overline{R X C}$ | tis |  | 26 | $\mathrm{T}_{\mathrm{cy}}$ |  |
| SYNDET setup time for $\overline{\mathrm{RXC}}$ | ${ }^{\text {teS }}$ | 18 |  | $\mathrm{T}_{\mathrm{cy}}$ |  |
| TXE delay time from the center of last bit | ${ }^{\text {t }}$ 'XEMPTY | 20 |  | $\mathrm{T}_{\mathrm{cy}}$ |  |
| MODEM control signal delay time from rising edge of $\overline{W R}$ | twC | 8 |  | $\mathrm{T}_{\mathrm{c}} \mathrm{y}$ |  |
| MODEM control signal setup time for falling edge of $\overline{R D}$ | ${ }^{t} \mathrm{CR}$ | 20 |  | $\mathrm{T}_{\text {cy }}$ |  |
| RXD setup time for rising edge of $\overline{\mathrm{RXC}}$ (1X Baud) | ${ }^{\text {tr X }}$ (DS | 11 |  | $\mathrm{T}_{\text {cy }}$ |  |
| RXD hold time for falling edge of $\overline{\mathrm{RXC}}$ (1X Baud) | ${ }^{\text {tRXDH }}$ | 17 |  | $\mathrm{T}_{\mathrm{c}} \mathrm{y}$ |  |

Caution 1) AC characteristics are measured at 150 pF capacity load as an output load based on 0.8 V at low level and 2.2 V at high level for output and 1.5 V for input.
2) Addresses are $\overline{\mathrm{CS}}$ and $\bar{C} / \overline{\mathrm{D}}$.
3) $f_{T X}$ or $f_{R X} \leq 1 /(30 \mathrm{Tcy}) \quad 1 \times$ baud
$\mathrm{f}_{\mathrm{TX}}$ or $\mathrm{f}_{\mathrm{RX}} \leq 1 /(5 \mathrm{Tcy}) \quad 16 \times 64 \times$ Baud
4) This recovery time is mode Initialization only. Recovery time between command writes for Asynchronous Mode is $8 \mathrm{t}_{\mathrm{C}} \mathrm{C}$ and for Synchronous Mode is $18 \mathrm{t}_{\mathrm{C}} \mathrm{C}$.
Write Data is allowed only when TXRDY $=1$.
5) This recovery time is Status read only.

Read Data is allowed only when RXRDY $=1$.
6) Status update can have a maximum delay of 28 clock periods from event affecting the status.

## TIMING CHART

System Clock Input


## Transmitter Clock and Data



## Receiver Clock and Data

Write Data Cycle (CPU $\rightarrow$ USART)


Read Data Cycle (CPU $\leftarrow$ USART)


Write Control or Output Port Cycle (CPU $\rightarrow$ USART)


Read Control or Input Port (CPU $\leftarrow$ USART)


Transmitter Control and Flag Timing (ASYNC Mode)


(Note) The wave-form chart is based on the case of 7 data bit length + parity bit + 2 stop bit

(Note) The wave-form chart is based on the case of 5 data bit length + parity bit and 2 synchronous characters.

300
Receiver Control and Flag Timing (SYNC Mode)


## NOTE

1. Half-bit processing for the start bit

When the 82C51A is used in the asynchronous mode, some problems are caused in the processing for the start bit whose length is smaller than the 1 -data bit length. (See Fig. 1.)

| Start bit length | Mode | Operation |
| :--- | :---: | :--- |
| Smaller than 7-receiver clock length | $\times 16$ | The short start bit is ignored. (Normal) |
| Smaller than 31-receiver clock length | $\times 64$ | The short start bit is ignored. (Normal) |
| 8-receiver clock length | $\times 16$ | Data cannot be received correctly due to a malfunction. |
| 32-receiver clock length | $\times 64$ | Data cannot be received correctly due to a malfunction. |
| 9 to 16-receiver clock length | $\times 16$ | The bit is regarded as a start bit. (Normal) |
| 33 to 64-receiver clock legth | $\times 64$ | The bit is regarded as a start bit. (Normal) |

## 2. Parity flag after a break signal is received (See Fig. 2.)

When the 82C51A is used in the asynchrous mode, a parity flag may be set when the next normal data is read after a break signal is received. (This occurs when odd parity is set.)
A parity flag is set when the rising edge of the break signal (end of the break signal) is changed between the final data bit and the parity bit, though a RXRDY signal may not be outputted.
If this occurs, the parity flag is left set when the next normal dats is received, and the received data seems to be a parity error.

## Half-bit processing timing chart for the start bit (Fig.1)

## Normal operation

RXD


RXRDY


The start bit is shorter than a $1 / 2$ data bit.

RXD


RXRDY


The start bit is a $1 / 2$ data bit. (A problem of $\mathbf{8 2 C 5 1 A}$ )

RXD


RXRDY
 reception due to a malfunction.
The start bit is longer than a $\mathbf{1 / 2}$ data bit.


[^5]
## Break signal reception timing and parity flag (Fig.2)

## Normal operation




RXD


5 rXRDY
 is outputted.

# OKKI <br> semiconductor <br> MSM82C53-2RS/GS/JS 

CMOS PROGRAMMABLE INTERVAL TIMER

## GENERAL DESCRIPTION

The MSM82C53-2RS/GS/JS are programmable universal timers designed for use in microcomputer systems . Based on silicon gate CMOS technology, it requires a standby current of only $100 \mu \mathrm{~A}$ (max.) when the chip is in the nonselected state. During timer operation, power consumption is still very low with only 8 mA (max.) at 8 MHz of current required.

The devices consist of three independent counters, and can count up to a maximum of 8 MHz (MSM82C53-2) The timer features six different counter modes, and binary count/BCD count functions. Count values can be set in byte or word units, and all functions are freely programmable.

## FEATURES

- Maximum operating frequency of 8 MHz (MSM82C53-2) - Six counter modes available for each counter
- High speed and low power consumption achieved through silicon gate CMOS technology.
- Completely static operation
- Binary and decimal counting possible
- 24 pin Plastic DIP (DIP24-P-600)
- 28 pin PLCC (OFJ28-P-S450)
- Three independent 16-bit down-counters
- 32 pin-V Plastic SOP (SSOP32-P-430-VK)
- 3 V to 6 V single power supply

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATION

MSM82C53-2RS (Top View)
24 pin Plastic DIP

MSM82C53-2GS (Top View)
32 pin Plastic Small Outine Package

MSM82C53-2JS (Top View)
28 pin Plastic Leaded Chip Carrier


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Conditions | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM82C53-2RS | MSM82C53-2GS | MSM82C53-2JS |  |
| Ssupply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | Respect to GND | -0.5 to +7 |  |  | V |
| Input Voltage | VIN |  | -0.5 to $\mathrm{V}_{\mathrm{cc}}+0.5$ |  |  | V |
| Output Voltage | V OUT |  | -0.5 to $\mathrm{V}_{\mathrm{cc}}+0.5$ |  |  | V |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ |  | -55 to +150 |  |  | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | PD | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | 0.9 | 0.7 | 0.9 | W |

## OPERATING RANGES

| Parameter | Symbol | Limits | Conditions | Unit |
| :--- | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 3 to 6 | $\mathrm{V}_{\mathrm{IL}}=0.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-0.2 \mathrm{~V}$, <br> operating frequency 2.6 MHz | V |
| Operating Temperature | TOP | -40 to +85 |  | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5 | 5.5 | V |
| Operating Temperature | $\mathrm{TOP}_{\mathrm{OP}}$ | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| " L " Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 |  | +0.8 | V |
| " H " Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.2 |  | $\mathrm{~V}_{\mathrm{CC}}+0.3$ | V |

## DC CHARACTERISTICS

| Parameter | Symbol | Conditions |  | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L' Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}$ | $\begin{aligned} & V_{C C}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{a}}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ |  |  | 0.45 | V |
| 'H' Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}^{\mathrm{OH}}=-1 \mathrm{~mA}$ |  | 3.7 |  |  | V |
| Input Leak Current | ILI | $0 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Output Leak Current | 'LO | $0 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Standby Supply Current | Iccs | $\begin{aligned} & \overline{\mathrm{CS}} \geqq \mathrm{~V}_{\mathrm{CC}}-0.2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IH}} \geqq \mathrm{~V}_{\mathrm{CC}}-0.2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}} \leqq 0.2 \mathrm{~V} \end{aligned}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| Operating Supply Current | I'c | ${ }^{\text {t }} \mathrm{CLK}^{\prime}=125 \mathrm{~ns} \mathrm{C}_{\mathrm{L}}=0 \mathrm{pF}$ |  |  |  | 8 | mA |

## AC CHARACTERISTICS

$\left(V_{C C}=4.5 \mathrm{~V} \sim 5.5 \mathrm{~V}, \mathrm{Ta}=-40 \sim+85^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | MSM82C53-2 |  | Unit | Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |  |
| Address Set-up Time before reading | TAR | 30 |  | ns | Read cycle | $C_{L}=150 \mathrm{pF}$ |
| Address Hold Time after reading | TRA | 0 |  | ns |  |  |
| Read Pulse Width | TRR | 150 |  | ns |  |  |
| Read Recovery Time | TRVR | 200 |  | ns |  |  |
| Address Set-up Time before writing | TAW | 0 |  | ns | Write cycle |  |
| Address Hold Time after writing | TWA | 20 |  | ns |  |  |
| Write Pulse Width | TWW | 150 |  | ns |  |  |
| Data Input Set-up Time before writing | TDW | 100 |  | ns |  |  |
| Data Input Hold Time after writing | TWD | 20 |  | ns |  |  |
| Write Recovery time | TRVW | 200 |  | ns |  |  |
| Clock Cycle Time | TCLK | 125 | D.C. | ns | Clock <br> and <br> gate <br> timing |  |
| Clock "H" Pulse Width | TPWH | 60 |  | ns |  |  |
| Clock "L' Pulse Width | TPWL | 60 |  | ns |  |  |
| "'H" Gate Pulse Width | TGW | 50 |  | ns |  |  |
| "L" Gate Pulse Width | TGL | 50 |  | ns |  |  |
| Gate Input Set-up Time before clock | TGS | 50 |  | ns |  |  |
| Gate Input Hold Time after clock | TGH | 50 |  | ns |  |  |
| Output Delay Time after reading | TRD |  | 120 | ns | Delay time |  |
| Output Floating Delay Time after reading | TDF | 5 | 90 | ns |  |  |
| Output Delay Time after gate | TODG |  | 120 | ns |  |  |
| Output Delay Time after clock | TOD |  | 150 | ns |  |  |
| Output Delay Time after address | TAD |  | 180 | ns |  |  |

Note: Timing measured at $\mathrm{V}_{\mathrm{L}}=0.8 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{H}}=2.2 \mathrm{~V}$ for both inputs and outputs.

## time chart

Write Timing


## Read Timing




## DESCRIPTION OF PIN FUNCTIONS

| Pin Symbol | Name | Input/output | Function |
| :---: | :---: | :---: | :---: |
| D7 ~ D0 | Bidirectional data bus | Input/output | Three-state 8-bit bidirectional data bus used when writing control words and count values, and reading count values upon reception of $\overline{W R}$ and $\overline{R D}$ signals from CPU. |
| $\overline{\mathrm{CS}}$ | Chip select input | Input | Data transfer with the CPU is enabled when this pin is at low level. When at high level, the data bus ( $D_{0}$ thru $D_{7}$ ) is switched to high impedance state where neither writing nor reading can be executed. Internal registers, however, remain unchanged. |
| $\overline{\mathrm{RD}}$ | Read input | Input | Data can be transferred from MSM82C53 to CPU when this pin is at low level. |
| $\overline{W R}$ | Write input | Input | Data can be transferred from CPU to MSM82C53 when this pin is at low level. |
| A0, A1 | Address input | Input | One of the three internal counters or the control word register is selected by A0/A1 combination. These two pins are normally connected to the two lower order bits of the address bus. |
| CLKO~2 | Clock input | Input | Supply of three clock signals to the three counters incorporated in MSM82C53. |
| GATEO~2 | Gate input | Input | Control of starting, interruption, and restarting of counting in the three respective counters in accordance to the set control word contents. |
| OUTO~2 | Counter output | Output | Output of counter output waveform in accordance with the set mode and count value. |

## SYSTEM INTERFACING



## DESCRIPTION OF BASIC OPERATIONS

Data transfers between the internal registers and the external data bus is outlined in the following table.

| $\overline{\mathrm{CS}}$ | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | A1 | AO | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | 0 | Data bus to counter \# O Writing |
| 0 | 1 | 0 | 0 | 1 | Data bus to counter \# 1 Writing |
| 0 | 1 | 0 | 1 | 0 | Data bus to counter \# 2 Writing |
| 0 | 1 | 0 | 1 | 1 | Data bus to control word register Writing |
| 0 | 0 | 1 | 0 | 0 | Data bus from counter \# 0 Reading |
| 0 | 0 | 1 | 0 | 1 | Data bus from counter \# 1 Reading |
| 0 | 0 | 1 | 1 | 0 | Data bus from counter \# 2 Reading |
| 0 | 0 | 1 | 1 | 1 |  |
| 1 | x | $\times$ | $x$ | $x$ | \} Data bus in high impedance status |
| 0 | 1 | 1 | x | $\times$ | $J$ |

x denotes "not specified".

## DESCRIPTION OF OPERATION

82C53 functions are selected by a control word from the CPU. In the required program sequence, the control word setting is followed by the count value setting and execution of the desired timer operation.

## Control Word and Count Value Program

Each counter operation mode is set by control word programming. The control word format is outlined below.

| D7 | DG | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC1 | SCO | RL1 | RLO | M2 | M1 | M0 | BCD |
| Select Counter |  | Read $=0$, | Load | = 1,1 | Mode | 1, | BCD R $=0$ ) |

- Select Counter (SCO, SC1): Selection of set counter

| SC1 | SCO | Set Contents |
| :---: | :---: | :--- |
| 0 | 0 | Counter \# 0 selection |
| 0 | 1 | Counter \# 1 selection |
| 1 | 0 | Counter \# 2 selection |
| 1 | 1 | Illegal combination |

- Read/Load (RL1, RLO): Count value Reading/ Loading format setting

| RL1 | RLO | Set Contents |
| :---: | :---: | :--- |
| 0 | 0 | Counter Latch operation |
| 0 | 1 | Reading/Loading of Least Significant <br> byte (LSB) |
| 1 | 0 | Reading/Loading of Most Significant <br> byte (MSB) |
| 1 | 1 | Reading/Loading of LSB followed by <br> MSB |

- Mode (M2, M1, M0): Operation waveform mode setting

| M2 | M1 | M0 | Set Contents |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Mode 0 (Interrupt on Terminal Count) |
| 0 | 0 | 1 | Mode 1 (Programmable One-Shot) |
| $\mathbf{x}$ | 1 | 0 | Mode 2 (Rate Generator) |
| $\mathbf{x}$ | 1 | 1 | Mode 3 (Square Wave Generator) |
| 1 | 0 | 0 | Mode 4 (Software Triggered Strobe) |
| 1 | 0 | 1 | Mode 5 (Hardware Triggered Strobe) |

x denotes "not specified".

- BCD: Operation count mode setting

| BCD | Set Contents |
| :---: | :--- |
| 0 | Binary Count (16-bits Binary) |
| 1 | BCD Count (4-decades Binary Coded <br> Decimal) |

After setting Read/Load, Mode, and BCD in each counter as outlined above, next set the desired count value. (In some Modes, counting is started immediately after the count value has been written). This count value setting must conform with the Read/Load format set in advance. Note that the internal counters are reset to OOOOH during control word setting. The counter value ( OOOOH ) can.t be read.

If the two bytes (LSB and MSB) are written at this stage (RLO and RL1 = 1,1), take note of the following precaution.

Although the count values may be set in the three counters in any sequence after the control word has been set in each counter, count values must be set consecutively in the LSB - MSB order in any one counter.

## - Example of control word and count value setting



| $\begin{aligned} & \text { MVI A, 1EH } \\ & \text { OUT n3 } \end{aligned}$ | Counter \#0 control word setting |
| :---: | :---: |
| $\left.\begin{array}{l} \text { MVI A, } 6 \text { AH } \\ \text { OUT n3 } \end{array}\right]$ | Counter \#1 control word setting |
| $\begin{aligned} & \text { MVI A, B1H } \\ & \text { OUT n3 } \end{aligned}$ | Counter \#2 control word setting |
| $\begin{aligned} & \text { MVI A, 03H } \\ & \text { OUT nO } \end{aligned}$ | Counter \#0 count value setting |
| $\begin{aligned} & \text { MVI A, AAH } \\ & \text { OUT } n 1 \end{aligned}$ | Counter \#1 count value setting |
| MVI A, 34H $]$ |  |
| OUT $n 2$ | Counter \#2 count value setting |
| $\text { MVI A, } 12 \mathrm{H}$ | (LSB then MSB) |

Note: n0: Counter \#0 address
n1: Counter \#1 address
n2: Counter \#2 address
n3: Control word register address

- The minimum and maximum count values which can be counted in each mode are listed below.

| Mode | Min. | Max. | Remarks |
| :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 executes 10000 H count <br> (ditto in other modes) |
| 1 | 1 | 0 |  |
| 2 | 2 | 0 | 1 cannot be counted |
| 3 | 2 | 1 | 1 executes 10001 H count |
| 4 | 1 | 0 |  |
| 5 | 1 | 0 |  |

## Mode Definition

## - Mode $\mathbf{O}$ (terminal count)

The counter output is set to " L " level by the mode setting. If the count value is then written in the counter with the gate input at " H " level (that is, upon completion of writing the MSB when there are two bytes), the clock input counting is started. When the terminal count is reached, the output is switched to " H " level and is maintained in this status until the control word and count value are set again.
Counting is interrupted if the gate input is switched to " $L$ " level, and restarted when switched back to " H " level.
When Count Values are written during counting, the operation is as follows:

1 byte Read/Load.... When the new count value is written, counting is stopped immediately, and then restarted at the new count value by the next clock.
2-byte Read/Load.... When byte 1 (LSB) of the new count value is written, counting is stopped immediately. Counting is restarted at the new count value when byte 2 (MSB) is written.

- Mode 1 (programmable one-shot)

The counter output is switched to " H " level by the mode setting. Note that in this mode, counting is not started if only the count value is written. Since counting has to be started in this mode by using the leading edge of the gate input as a trigger, the counter output is switched to " $L$ " level by the next clock after the gate input trigger. This " $L$ " level status is maintained during the set count value, and is switched back to " H " level when the terminal count is reached.
Once counting has been started, there is no interruption until the terminal count is reached, even if the gate input is switched to " $L$ " level in the meantime. And although counting continues even if a new count value is written during the counting. counting is started at the new count value if another trigger is applied by the gate input.

## - Mode 2 (rate generator)

The counter output is switched to " H " level by the mode setting. When the gate input is at " H " level, counting is started by the next clock after the count value has been written. And if the gate input is at " $L$ " level, counting is started by using the rising edge of the gate input as a trigger after the count value has been set.
An " $L$ " level output pulse appears at the counter output during a single clock duration once every n clock inputs where n is the set count value. If a new count value is written during while counting is in progress, counting is started at the new count value following output of the pulse currently being counted. And if the gate input is switched to " $L$ " level during counting, the counter output is forced to switch to " H " level, the counting being restarted by the rising edge of the gate input.

- Mode 3 (square waveform rate generator)

The counter output is switched to " H " level by the mode setting. Counting is started in the same way as described for mode 2 above.
The repeated square wave output appearing at the counter output contains half the number of counts as the set count value. If the set count value ( $n$ ) is an odd number, the repeated square wave output consists of only $(n+1) / 2$ clock inputs at " $H$ " level and $(n-1) / 2$ clock inputs at " $L$ " level.
If a new count value is written during counting, the new count value is reflected immediately after the
change (" $H$ " to " $L$ " or " $L$ " to " $H$ ") in the next counter output to be executed. The counting operation at the gate input is done the same as in mode 2.

- Mode 4 (software trigger strobe)

The counter output is switched to " H " level by the mode setting. Counting is started in the same way as described for mode 0 . A single " $L$ " pulse equivalent to one clock width is generated at the counter output when the terminal count is reached.
This mode differs from 2 in that the " $L$ " level output appears one clock earlier in mode 2, and that pulses are not repeated in mode 4. Counting is
stopped when the gate input is switched to " $L$ " level, and restarted from the set count value when switched back to " H " level.

- Mode 5 (hardware trigger strobe)

The counter output is switched to " H " level by the mode setting. Counting is started, and the gate input used, in the same way as in mode 1.
The counter output is identical to the mode 4 output.
The various roles of the gate input signals in the above modes are summarized in the following table.

|  | "L" Level Falling Edge | Rising Edge | "H" Level |
| :---: | :---: | :---: | :---: |
| 0 | Counting not possible |  | Counting possibile |
| 1 |  | (1) Start of counting <br> (2) Retriggering |  |
| 2 | (1) Counting not possible <br> (2) Counter output forced to " H " level | Start of counting | Counting possible |
| 3 | (1) Counting not possible <br> (2) Counter output forced to " H " level | Start of counting | Counting possible |
| 4 | Counting not possible |  | Counting possible |
| 5 |  | (1) Start of counting <br> (2) Retriggering |  |

Mode 0


Mode 1


## Mode 2



Mode 3


Mode 4


Mode 5


Note: " $n$ " is the value set in the counter.
Figures in these diagrams refer to counter values.

## Reading of Counter Values

All 82C53 counting is down-counting, the counting being in steps of 2 in mode 3. Counter values can be read during counting by (1) direct reading, and (2) counter latching ("read on the fly").

## - Direct reading

Counter values can be read by direct reading operations.
Since the counter value read according to the timing of the $\overline{R D}$ and CLK signals is not guaranteed, it is necessary to stop the counting by a gate input signal, or to interrupt the clock input temporarily by an external circuit to ensure that the counter value is correctly read.

- Counter latching

In this method, the counter value is latched by writing a counter latch command, thereby enabling a stable value to be read without effecting the counting in any way at all. An example of a counter latching program is given below.
Counter latching executed for counter \#1 (Read/ Load 2-byte setting)


MOV B, A
IN n1 $\qquad$ Reading of MSB from counter MOV C, A \#1

Example of Practical Application

- 82C53 used as a 32-bit counter.


Use counter \#1 and counter \#2
Counter \#1: mode 0, upper order 16-bit counter value
Counter \#2: mode 2, lower order 16-bit counter value
This setting enables counting up to a maximum of $2^{32}$.

# OKKI semiconductor <br> MSM82C54-2RS/GS/JS 

CMOS PROGRAMMABLE INTERVAL TIMER

## GENERAL DESCRIPTION

The MSM82C54-2RS/GS/JS is a programmable universal timer designed for use in microcomputer systems. Based on silicon gate CMOS technology, it requires a standby current of only $10 \mu \mathrm{~A}$ (max.) when the chip is in the nonselected state. And during timer operation, the power consumption is still very low with only 10 mA (max.) of current required.
It consists of three independent counters, and can count up to a maximum of 10 MHz . The timer features six different counter modes, and binary count/BCD count functions. Count values can be set in byte or word units, and all functions are freely programmable.

## FEATURES

- Maximum operating frequency of $10 \mathrm{MHz}\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}\right)$
- High speed and low power consumption achieved by silicon gate CMOS technology.
- Completely static operation
- Three independent 16-bit down-counters
- Status Read Back Commound
- Six counter modes available for each counter
- Binary and decimal counting possible
- 24 pin Plastic DIP (DIP24-P-600)
- 28 pin PLCC (QFJ28-P-S450)
- 32 pin-V Plastic SOP (SSOP32-P-430-VK)


## FUNCTIONAL BLOCK DIAGRAM



PIN CONFIGURATION

MSM82C54-2RS (TOP VIEW)
24 pin Plastic DIP

MSM82C54-2GS (TOP VIEW)
32 pin Plastic Small Outline Package

MSM82C54-2JS (TOP VIEW)
28 pin Plastic Leaded Chip Carrier


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Conditions | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM82C54-2RS | MSM82C54-2GS | MSM82C54-2JS |  |
| Supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | Respect to GND | -0.5 to +7 |  |  | V |
| Input Voltage | $\mathrm{V}_{\text {IN }}$ |  | -0.5 to $V_{c c}+0.5$ |  |  | V |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ |  | -0.5 to $V_{c c}+0.5$ |  |  | V |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ |  | -55 to +150 |  |  | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | PD | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | 0.9 | 0.7 | 0.9 | W |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5 | 5.5 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| " L " Input Voltage | $\mathrm{V}_{\text {IL }}$ | -0.5 |  | +0.8 | V |
| " H " Input Voltage | $\mathrm{V}_{\text {IH }}$ | 2.2 |  | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |

## DC CHARACTERISTICS

| Parameter | Symbol | Cond | ions | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L" Output Voltage | $\mathrm{v}_{\mathrm{OL}}$ | $\mathrm{I}^{\mathrm{OL}}=2.5 \mathrm{~mA}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V} \\ & \mathrm{Ta}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ |  |  | 0.40 | V |
| " H " Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}^{\mathrm{OH}}=-2.5 \mathrm{~mA}$ |  | 3.0 |  |  | V |
|  |  | $\mathrm{I}^{\prime} \mathrm{OH}^{=}-100 \mu \mathrm{~A}$, |  | $\mathrm{V}_{\mathrm{C}} \mathrm{c}-0.4$ |  |  |  |
| Input Leak Current | ILI | $0 \leqq \mathrm{~V}_{\text {IN }} \leqq \mathrm{V}_{\text {CC }}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Output Leak Current | 'LO | $0 \leqq \mathrm{~V}_{\text {OUT }} \leqq \mathrm{V}_{\text {CC }}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Standby Supply Current | I'ccs | $\begin{aligned} & \overline{\mathrm{CS}} \geqq \mathrm{~V}_{\mathrm{CC}}-0.2 \mathrm{~V} \\ & \mathrm{~V}_{I H} \geqq \mathrm{~V}_{\mathrm{CC}}-0.2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}} \leqq 0.2 \mathrm{~V} \end{aligned}$ |  |  |  | 10 | $\mu \mathrm{A}$ |
| Operating Supply Current | ${ }^{\text {I C }}$ | ${ }^{\text {t }}$ CLK $=100 \mathrm{~ns} \mathrm{CL=0pF}$ |  |  |  | 10 | mA |

## AC CHARACTERISTICS

$\left(V_{C C}=4.5 \mathrm{~V} \sim 5.5 \mathrm{~V}, \mathrm{Ta}=-40 \sim+85^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | 82C54-2 |  | Unit | Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |  |
| Address set-up time to falling edge of $\overline{\mathrm{RD}}$ | tAR | 30 |  | nS |  | $C L=150 \mathrm{pF}$ |
| Chip select input set-up time to falling edge of $\overline{\mathrm{RD}}$ | tSR | 0 |  | nS |  |  |
| Address hold time from rising edge of $\overline{\mathrm{RD}}$ | tRA | 0 |  | nS |  |  |
| $\overline{\mathrm{RD}}$ pulse width | tRR | 95 |  | nS |  |  |
| Data access time from falling edge of $\overline{\mathrm{RD}}$ | tRD |  | 94 | nS |  |  |
| Data access time after address determination | tAD |  | 185 | nS |  |  |
| Delay time from rising edge of $\overline{\mathrm{RD}}$ to data floating state | tDF | 5 | 65 | nS |  |  |
| $\overline{\mathrm{RD}}$ recovery time | tRV | 165 |  | nS |  |  |
| Address set-up time to falling edge of $\overline{W R}$ | tAW | 0 |  | nS |  |  |
| Chip select input set-up time to falling edge of $\overline{W R}$ | tSW | 0 |  | nS |  |  |
| Address hold time from rising edge of $\overline{W R}$ | tWA | 0 |  | nS |  |  |
| $\overline{\text { WR pulse width }}$ | tWW | 95 |  | nS |  |  |
| Data determination set-up time to rising edge of $\overline{W R}$ | tDW | 85 |  | nS |  |  |
| Data hold time after rising edge of $\overline{W R}$ | tWD | 0 |  | nS |  |  |
| WR recovery time | tRV | 165 | , | nS |  |  |
| CLK cycle time | tCLK | 100 | D.C. | nS |  |  |
| CLK "H' level width | tPWH | 30 |  | nS |  |  |
| CLK '"L' level width | tPWL | 50 |  | nS |  |  |
| CLK rise time | tR |  | 25 | nS |  |  |
| CLK fall time | tF |  | 25 | nS |  |  |
| GATE "H' level width | tGW | 50 |  | nS |  |  |
| GATE "L' level width | tGL | 50 |  | nS |  |  |
| GATE input set-up time before rising edge of CLK | tGS | 40 |  | nS |  |  |
| GATE input hold time before rising edge of CLK | tGH | 50 |  | nS |  |  |
| Output delay time after falling edge of CLK | tOD |  | 100 | ns |  |  |
| Output delay time after falling edge of GATE | tODG |  | 100 | nS |  |  |
| CLK rise delay time after rising edge of $\overline{W R}$ for count value loading | tWC | 0 | 55 | nS |  |  |
| GATE sam:pling delay time after rising edge of $\overline{W R}$ for count valueloading | tWG | -5 | 40 | nS |  |  |
| Output delay time after falling edge of $\overline{W R}$ for mode set | two |  | 240 | nS |  |  |
| CLK fall set-up time to falling edge of for counter latch command | tCL | -40 | 40 | ns |  |  |

Note: Timing measured at $\mathrm{V}_{\mathrm{L}}=0.8 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{H}}=2.2 \mathrm{~V}$ for both inputs and outputs.
TIME CHART
Write Timing


## Read Timing



## Clock \& Gate Timing



## DESCRIPTION OF PIN FUNCTIONS

| Pin Symbol | Name | Input/output | Function |
| :---: | :---: | :---: | :--- |
| D7 ~ DO | Bidirectional <br> data bus | Input/output | Three-state 8-bit bidirectional data bus used when writing <br> control words and count values, and reading count values <br> upon reception of $\overline{W R}$ and $\overline{\text { RD signals from CPU. }}$ |
| $\overline{\mathrm{CS}}$ | Chip select <br> input | Input | Data transfer with the CPU is enabled when this pin is at low <br> level. When at high level, the data bus ( $\mathrm{D}_{0}$ thru $\mathrm{D}_{7}$ ) is <br> switched to high impedance state where neither writing nor <br> reading can be executed. Internal registers, however, remain <br> unchanged. |
| $\overline{\mathrm{RD}}$ | Read input | Input | Data can be transferred from MSM82C54-2 to CPU when <br> this pin is at low level. |
| $\overline{\mathrm{WR}}$ | Write input | Input | Data can be transferred from CPU to MSM82C54-2 when <br> this pin is at low level. |
| AO, A1 | Address input | Input | One of the three internal counters or the control word regis- <br> ter is selected by A0/A1 combination. These two pins are <br> normally connected to the two lower order bits of the <br> address bus. |
| CLKO~2 | Clock input | Input | Supply of three clock signals to the three counters incorpo- <br> rated in MSM82C54-2. |
| GATEO~2 | Gate input | Input | Control of starting, interruption, and restarting of counting <br> in the three respective counters in accordance to the set con- <br> trol word contents. |
| OUTO~2 | Counter output | Output | Output of counter output waveform in accordance with the <br> set mode and count value. |

## SYSTEM INTERFACING



## DESCRIPTION OF BASIC OPERATIONS

Data transfers between the internal registers and the external data bus is outlined in the following table.

x denotes "not specified".

## DESCRIPTION OF OPERATION

82C54-2 functions are selected by control words from the CPU. In the required program sequence, the control word setting is followed by the count value setting and execution of the desired timer operation.

## Control Word and Count Value Program

Each counter operating mode is set by control word programming. The control word format is outlined below.

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC1 SC0 RL1 RL0 | M2 | M1 | M0 | BCD |  |  |  |
| Select <br> Counter | Read/Load |  | Mode |  | BCD |  |  |

- Select Counter (SC0, SC1): Selection of set counter

| SC1 | SCO | Set Contents |
| :---: | :---: | :--- |
| 0 | 0 | Counter \# 0 selection |
| 0 | 1 | Counter \# 1 selection |
| 1 | 0 | Counter \# 2 selection |
| 1 | 1 | READ BACK COMMAND |

- Read/Load (RL1, RLO): Count value Reading/ Loading format setting

| RL1 | RLO | Set Contents |
| :---: | :---: | :--- |
| 0 | 0 | Counter Latch operation |
| 0 | 1 | Reading/Loading of Least Significant <br> byte (LSB) |
| 1 | 0 | Reading/Loading of Most Significant <br> byte (MSB) |
| 1 | 1 | Reading/Loading of LSB followed by <br> MSB |

- Mode (M2, M1, M0): Operation waveform mode setting

| M2 | M1 | M0 | Set Contents |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Mode $0 \quad$ (Interrupt on Terminal Count) |
| 0 | 0 | 1 | Mode $1 \quad$ (Programmable One-Shot) |
| $\times$ | 1 | 0 | Mode 2 (Rate Generator) |
| $x$ | 1 | 1 | Mode 3 (Square Wave Generator) |
| 1 | 0 | 0 | Mode 4 (Software Triggered Strobe) |
| 1 | 0 | 1 | Mode 5 (Hardware Triggered Strobe) |

$x$ denotes "not specified".

- BCD: Operation count mode setting

| BCD | Set Contents |
| :---: | :--- |
| 0 | Binary Count (16-bits Binary) |
| 1 | BCD Count (4-decades Binary Coded <br> Decimal) |

After setting Read/Load, Mode, and BCD in each counter as outlined above, next set the desired count value. (In some Modes, the count value is set first. In next clock, loading is performed, then counting starts.) This count value setting must conform with the Read/Load format set in advance. Note that the internal counters are reset to OOOOH during control word setting. The counter value $(\mathrm{OOOOH})$ can't be read.

The program sequence of the 82C54-2 is flexible. Free sequence programming is possible as long as the two following rules are observed:
(i) Write the control word before writing the initial count value in each counter.
(ii) Write the initial count value according to the count value read/write format specified by the control word.
(Note) Unlike the 82C53-5, the 82C54-2 allows count value setting for another counter between LSB and MSB settings.

- Example of control word and count value setting
$\left[\begin{array}{rlrl}\text { Counter \# 0: } & \text { Read/Load LSB only, Mode 3, } \\ & \text { Binary count, count value 3H } \\ \text { Counter \# 1: } & \text { Read/Load MSB only, Mode 5, } \\ & \text { Binary count, count value AAOOH } \\ \text { Counter \# 2: } & \begin{array}{l}\text { Read/Load LSB and MSB, Mode } 0, \\ \\ \\ \text { BCD count, count value } 1234\end{array}\end{array}\right.$

MVI A, 1EH]
Counter \#0 control word setting OUT n3
MVI A, 6AH $]$
OUT n3 MVI A, B1H OUT n3 Counter \#1 control word setting MVI A, 03H OUT no Counter \#O count value setting

MVI A, AAH] OUT n1 $\quad$ Counter \#1 count value setting MVI A, 34H OUT n2 Counter \#2 count value setting MVI A, 12H (LSB then MSB)

Note: n0: Counter \#0 address
n1: Counter \#1 address
n2: Counter \#2 address
n3: Control word register address

- The minimum and maximum count values which can be counted in each mode are listed below.

| Mode | Min | Max | Remarks |
| :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 executes 10000 H count <br> (ditto in other modes) |
| 1 | 1 | 0 |  |
| 2 | 2 | 0 | 1 cannot be counted |
| 3 | 2 | 0 | 1 cannot be counted |
| 4 | 1 | 0 |  |
| 5 | 1 | 0 |  |

INTERNAL BLOCK DIAGRAM OF A COUNTER


NOTE CRM : Count Register MSB
CRM : Count Register MSB
CRL : Count Register LSB
CRL: Count Register LSB
CE : Counter Element
CE : Counter Element
OLM: Output Latch MSB
OLL : Output Latch LSB

## Mode definition

## Mode 0

- Use: Event counter
- Output operation: The output is set to "L" level by the control word setting, and kept at " $L$ " level until the counter value becomes 0 .
- Gate function: "H" level validates the count operation, and " $L$ " level invalidates it. The gate does not affect the output.
- Count value load timing: after the control word and initial count value are written, the count value is loaded to the CE at the falling edge of the next clock pulse. The first clock pulse does not cause the count value to be decremented. In other words, if the initial count value is $N$, the output is not set to " $\mathrm{H}^{\prime \prime}$ level until the input of ( $\mathrm{N}+1$ ) the clock pulse after the initial count value writing.
- Count value writing during counting:

The count value is loaded in the CE at the falling edge of the next clock, and counting with the new count value continues. The operation for 2-byte count is as follows:

1) The counting operation is suspended when the first byte is written. The output is immediately set to "L" level. (no clock pulse is required.)
2) After the scond byte is written, the new count value is loaded to the CE at the falling edge of the next clock.
For the output to go to " H " level again, $\mathrm{N}+1$ clock pulses are necessary after new count value N is written.

- Count value writing when the gate signal is "L" level:
The count value is also loaded to the CE at the falling edge of the next clock pulse in this case. When the gate signal is set to " H " level, the output is set to " H " level after the lapse of N clock pulses. Since the count value is already loaded in the CE, no clock pulse for loading in the CE is necessary.


## Mode 1

- Use: Digital one-shot
- Output operation: The output is set to " H " level by the control word setting. It is set to " $L$ " level at the falling edge of the clock succeeding the gate trigger, and kept at " $L$ " level until the counter value becomes 0 . Once the output is set to " H " level, it is kept at " H " level until the clock pulse succeeding the next trigger pulse.
- Count value load timing:

After the control word and initial count value are written, the count value is loaded to the CE at the falling edge of the clock pulse succeeding the gate trigger and set the output to "L" level. The one-shot pulse starts in this way. If the initial count value is $N$, the one-shot pulse interval equals N clock pulses. The one-shot pulse is not repetitive.

- Gate function: The gate signal setting to "L" level after the gate trigger does not affect the output. When it is set to " $H$ " level again from " $L$ " level, gate retriggering occurs, the $C R$ count value is loaded again, and counting continues.
- Count value writing during counting

It does not affect the one-shot pulse being counted until retriggering occurs.

## Mode 2

- Use: Rate generator, real-time interrupt clock.
- Output operation: The output is set to "H" level by control word setting. When the initial count value is decremented to 1 , the output is set to " $L$ " level during one clock pulse, and is then set to " H " level again. The initial count value is reloaded, and the above sequence repeats. In mode 2, the same sequence is repeated at intervals of N clock pulses if the initial count value is N for example.
- Gate function: " $H$ " level validates counting, and " $L$ " level invalidates it. If the gate signal is set to " $L$ " level when the output pulse is " $L$ " level, the output is immediately set to " H " level. At the falling edge of the clock pulse succeeding the trigger, the count value is reloaded and counting starts. The gate input can be used for counter synchronization in this way
- Count value load timing:

After the control word and initial count value is written, the count value is loaded to the CE at the falling edge of the next clock pulse. The output is set to " $L$ " level upon lapse of $N$ clock pulses after writing the initial count value N . Counter synchronization by software is possible in this way.

- Count value writing during counting:

Count value writing does not affect the current counting operation sequence. If new count value writing completes and the gate trigger arrives before the end of current counting operation, the count value is loaded to the CE at the falling edge of the next clock pulse and counting continues from the new count value. If no gate trigger arrives, the new count value is loaded to the CE at the end of the current counting operation cycle. In mode 2, count value of 1 is prohibited.

## Mode 3

- Use: Baud rate generator, square wave generator
- Output operation: Same as mode 2 except that the output duty is different.
The output is set to " $H$ " level by control word setting. When the count becomes half the initial count value, the output is set to " $L$ " level and kept at " $L$ " level during the remainder of the count.
Mode 3 repeats the above sequence periodically. If the initial count value is $N$, the output becomes a square wave with a period of N .
- Gate operation: " H " level validates counting, and " $L$ " level invalidates it. If the gate signal is set to " $L$ " level when the output is "' $L$ " level, the output is immediately set to " H " level.
The initial count value is reloaded at the falling edge of the clock pulse succeeding the next gate trigger. The gate can be used for counter synchronization in this way.
- Count value load timing:

After the control word and initial count value are written, the count value is loaded to the CE at the falling edge of the next clock pulse. Counter synchronization by software is possible in this way.

- Count value writing during counting:

The count value writing does not affect the current counting operation. When the gate trigger input arrives before the end of a half cycle of the square wave after writing the new count value, the new count value is loaded in the CE at the falling edge of the next clock pulse, and counting continues using the new count value. If there is no gate trigger, the new count value is loaded at the end of the half cycle and counting continues.

- Even number counting operation:

The output is initially set to " $H$ " level. The initial count value is loaded to the CE at the falling edge of the next clock pulse, and is decremented by 2 by consecutive clock pulses. When the counter value becomes 2 , the output is set to " $L$ " level, the initial value is reloaded and then the above operation is repeated.

- Odd number counting operation:

The output is initially set to " H " level. At the falling edge of the next clock pulse, the initial count value minus one is loaded in the $C E$, and then the value is decremented by 2 by consecutive clock pulses. When the counter value becomes 0 , the output is set to "L" level, and then the initial count value minus 1 is reloaded to the CE. The value is then decremented by 2 by consecutive clock pulses. When the counter value becomes 2, the output is again set to " H " level and the initial count value minus 1 is again reloaded. The above operations are repeated. In other words, the output is set to " $H$ " level during $(N+1) / 2$ counting and to " $L$ " level during $(N-1) / 2$ counting in the case of odd number counting.

## Mode 4

- Use: Software trigger strobe
- Output operation: The output is initially set to " $H$ " level. When the counter value becomes 0 , the output goes to "L" level during one clock pulse, and then restores " $H$ " level again.
The count sequence starts when the initial count value is writter.
- Gate function: " H " level validates counting, and "L" level invalidates counting. The gate signal does not affect the output.
- Count value load timing:

After the control word and initial count value are written, the count value is loaded to the CE at the falling edge of the next clock pulse. The clock pulse does not decrement the initial count value. If the initial count value is $N$, the strobe is not output unless $N+1$ clock pulses are input after the initial count value is written.

- Count value writing during counting:

The new count value is written to the CE at the falling edge of the next clock pulse, and counting continues using the new count value. The operation for 2-byte count is as follows:

1) First byte writing does not affect the counting operation.
2) After the second byte is written, the new count value is loaded to the CE at the falling edge of the next clock pulse.
This means that the counting operation is retriggered by software. The output strobe is set to " $L$ " level upon input of $N+1$ clock pulses after the new count value N is written.

## Mode 5

- Use: Hardware trigger strobe
- Output operation: The output is initially set to " H " level. When the counter value becomes 0 after triggering by the rising edge of the gate pulse, the output goes to " $L$ " level during one clock pulse, and then restores " H " level.
- Count value load timing:

Even after the control word and initial count value are written, loading to the CE does not occur until the input of the clock pulse succeeding the trigger. For the clock pulse for CE loading, the count value is not decremented. If the initial count value is $N$, therefore, the output is not set to "L" level until $\mathrm{N}+1$ clock pulses are input after triggering.

- Gate function:

The initial count value is loaded to the CE at the falling edge of the clock pulse succeeding gate triggering. The count sequence can be retriggered. The gate pulse does not affect the output.

- Count value writing during counting:

The count value writing does not affect the current counting sequence. If the gate trigger is generated after the new count value is written and before the current counting ends, the new count value is loaded to the CE at the falling edge of the next clock pulse, and counting continues using the new count value. The various roles of the gate input signals in the above modes are summarized in the following table.

| Mode Gate | "L" Level Falling Edge | Rising Edge | "H" Level |
| :---: | :---: | :---: | :---: |
| 0 | Counting not possible |  | Counting possible |
| 1 |  | (1) Start of counting <br> (2) Retriggering |  |
| 2 | (1) Counting not possible <br> (2) Counter output forced to " H " level | Start of counting | Counting possible |
| 3 | (1) Counting not possible <br> (2) Counter output forced to " H " level | Start of counting | Counting possible |
| 4 | Counting not possible |  | Counting possible |
| 5 |  | (1) Start of counting <br> (2) Retriggering |  |

Mode 0


Mode 1


Mode 2


Mode 3


Mode 4


Mode 5


Note: " $n$ " is the value set in the counter.
Figures in these diagrams refer to counter values.

## Reading Counter Values

All 82C54-2 counting is down-counting, the counting being in steps of 2 in mode 3 . Counter values can be read during counting by. (1) direct reading, (2) counter latching ('read on the fly'), and (3) read back command.
(1) Direct reading

Counter values can be read by direct reading operations.
Since the counter value read according to the timing of the $\overline{R D}$ and CLK signals is not guaranteed, it is necessary to stop the counting by a gate input signal, or to interrupt the clock input temporarily by an external circuit to ensure that the counter value is correctly read.

## (2) Counter latching

In this method, the counter value is latched by writing a counter latch command, thereby enabling a stable value to be read without effecting the counting in any way at all. The output latch (OL) of the selected counter latches the count value when a counter latch command is written. The count value is held until it is read by the CPU or the control word is set again.
If a counter latch command is written again before reading while a certain counter is latched, the second counter latch command is ignored and the value latched by the first counter latch command is maintained.
The 82C54-2 features independent reading and writing from and to the same counter.
When a counter is programmed for the 2-byte counter value, the following sequence is possible:

1. Count value (LSB) reading
2. New count value (LSB) writing
3. Count value (MSB) reading
4. New count value (MSB) writing

An example of a counter latching program is given below.

Counter latching executed for counter \#1 (Read/ Load 2-byte setting)

MVIA $01 \underset{1}{00} \times \times \times x$
Denotes counter latching
OUT n3 Write in control word address (n3)
The counter value at this point is latched


MOV B, A
IN 11 $\qquad$ Reading of MSB from counter MOV C, A
(3) Read Back Command Operation

Use of the read back command enables the user to check the count value, program mode, output pin state and null count flag of the selected counter.
The command is written in the control word register, and the format is as shown below. For this command, the counter selection occurs according to bits D3, D2 and D1.

| D7 | D6 | D5 | D4 | D3 | D2 | 01 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | COUNT | STATUS | CNT2 | CNT1 | CNTO | 0 |
| $(C S=0, A 0, A 1=1, R D=1, W R=0)$ |  |  |  |  |  |  |  |
| D5: $0=$ Selected counter latch operation |  |  |  |  |  |  |  |
| D4: $0=$ Selected counter status latch operation |  |  |  |  |  |  |  |
| D3: 1 = Counter \#2 selection |  |  |  |  |  |  |  |
| D2: 1 = Counter \#1 selection |  |  |  |  |  |  |  |
| D1: 1 = Counter \#0 selection |  |  |  |  |  |  |  |
| D0: 0 Fixed |  |  |  |  |  |  |  |

It is possible to latch multiple counters by using the read back command. Latching of a read counter is automatically cancelled but other counters are kept latched. If multiple read back commands are written for the same counter, commands other than the first one are ignored.
It is also possible to latch the status information of each counter by using the read back command. The status of a certain counter is read when the counter is read.
The counter status format is as follows:
Bits D5 to D0 indicates the mode programmed by the most recently written control word.
Bit D7 indicates the status of the output pin.
Use of this bit makes it possible to monitor the counter output, so the corresponding hardware may be omitted.

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OUTPUT | NULL |  |  |  |  |  |  |
| COUNT | RL1 | RLO | M2 | M1 | M0 | BCD |  |

D7: $1=$ Output pin status is 1.
$0=$ Output pin status is 0 .
D6: 1 = Null count
$0=$ Count value reading is effective
D5 - D0: Programmed mode of counter (See the control word format.)

Null count indicates the count value finally written in the counter register (CR) has been loaded in the counter element (CE). The time when the count value was loaded in the CE depends on the mode of each counter, and it cannot be known by reading the counter value because the count value does not tell the new count value if the counter is latched. The null count operation is shown below.

## Operation

A. Control word register writing
B. Count register (CR) writing
C. New count loading to $C E(C R \rightarrow C E)$

## Result

Null count $=1$
Null count $=1$
Null count $=0$
(Note) The null count operation for each counter is independent. When the 2 byte count is programmed, the null count is set to 1 when the count value of the second byte is written.

If status latching is carried out multiple times before status reading, other than the first status latch is ignored.
Simultaneous latching of the count and status of the selected counter is also possible. For this purpose, set bits D4 and D3, $\overline{\text { COUNT }}$ and STATUS bits, to 00 . This is functionally the same as writing two separate read back commands at the same time. If counter/status latching is carried out multiple times before each reading, other than the first one is ignored here again. The example is shown below.

| Command |  |  |  |  |  |  |  |  | Contents | Counter 0 |  | Counter 1 |  | Counter 2 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D7 | D6 | D5 | D4 | D3 | D2 | 2 D | D1 | D0 |  | Count | Status | Count | Status | Count | Status |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | Read back status and count (counter 0) | L | L | - | - | - | - |
| 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | Read back status (counter 1) | L | L | - | L | - | - |
| 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | Read back status (counters 1 and 2) | L | L | - | $\left(\mathrm{L}_{\mathrm{LT}} \mathrm{~L}\right)$ | - | L |
| 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | Read back count (counter 2) | L | L | - | L | L | L |
| 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | Read back status and count (counter 1) | L | L | L | (NOTE) | L | L |
| 1 | 1 | 1 | 0 | 0 | 0 | 01 | 1 | 0 | Read back status (counter 0) | L | ( NOTE$)^{\text {L }}$ | L | L | L | L |

(Note) The latch command at this time point is ignored, and the first latch command is valid.

If both the count and status are latched, the status latched in the first counter read operation is read. The order of count latching and status latching is irrelevant.
The count(s) of the next one or two reading operations is or are read.

Example of Practical Application

- 82C54-2 used as a 32-bit counter.


Use counter \#1 and counter \#2
Counter \#1: mode 0, upper order 16-bit counter
value
Counter \#2: mode 2, lower order 16-bit counter
value
This setting enables countinq up to a maximum of $\mathbf{2}^{32}$.

# OKZI semiconductor MSM82C55A-2RS/GS/VJS 

CMOS PROGRAMMABLE PERIPHERAL INTERFACE

## GENERAL DESCRIPTION

The MSM82C55A is a programmable universal I/O interface device which operates as high speed and on low power consumption due to $3 \mu$ silicon gate CMOS technology. It is the best fit as an I/O port in a system which employs the 8 -bit parallel processing MSM80C85A CPU. This device has 24-bit I/O pins equivalent to three 8 -bit I/O ports and all inputs/outputs are TTL interface compatible.

## FEATURES

- High speed and low power consumption due to $3 \mu$ silicon gate CMOS technology
- 3 V to 6 V single power supply
- Full static operation
- Programmable 24-bit I/O ports
- Bidirectional bus operation (Port A)
- Bit set/reset function (Port C)
- TTL compatible
- Compatible with 8255A-5
- 40 pin Plastic DIP (DIP40-P-600)
- 44 pin PLCC (OFJ44-P-S650)
- 44 pin-V Plastic QFP (QFP44-P-910-VK)
- 44 pin-VI Plastic QFP (QFP44-P-910-VIK)


## CIRCUIT CONFIGURATION



## PIN CONFIGURATION



## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Conditions | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM82C55A-2RS | MSM82C55A-2GS | MSM82C55A-2VJS |  |
| Ssupply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & \mathrm{Ta}=25^{\circ} \mathrm{C} \\ & \text { with } \\ & \text { respect } \\ & \text { to GND } \end{aligned}$ | -0.5 to +7 |  |  | V |
| Input Voltage | $V_{\text {IN }}$ |  | -0.5 to $\mathrm{V}_{\mathrm{cc}}+0.5$ |  |  | V |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ |  | -0.5 to $\mathrm{V}_{\mathbf{c c}}+0.5$ |  |  | V. |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | - | -55 to +150 |  |  | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $P_{\text {D }}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | 1.0 | 0.7 | 1.0 | W |

## OPERATING RANGE

| Parameter | Symbol | Limits | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | VCC $_{\text {CO }}$ | 3 to 6 | V |
| Operating Temperature | TOP | -40 to 85 | ${ }^{\circ} \mathrm{C}$ |

RECOMMENDED OPERATING RANGE

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5 | 5.5 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| " L " Input Voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 |  | +0.8 | V |
| " H " Input Voltage | $\mathrm{V}_{1 \mathrm{H}}$ | 2.2 |  | $\mathrm{~V}_{\mathrm{CC}}+0.3$ | V |

## DC CHARACTERISTICS

| Parameter | Symbol | Conditions |  | MSM82C55A-2 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Typ. | Max. |  |
| "L" Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{IOL}=2.5 \mathrm{~mA}$ | $\begin{aligned} & V_{C C}=4.5 \mathrm{~V} \text { to } \\ & 5.5 \mathrm{~V} \\ & \mathrm{Ta}=-40^{\circ} \mathrm{C} \text { to } \\ & +85^{\circ} \mathrm{C} \\ & \left(\mathrm{C}_{\mathrm{L}}=0 \mathrm{OF}\right) \end{aligned}$ |  |  | 0.4 | V |
| "H" Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{IOH}^{\prime}=-40 \mu \mathrm{~A}$ |  | 4.2 |  |  | $\checkmark$ |
|  |  | $1 \mathrm{IOH}=-2.5 \mathrm{~mA}$ |  | 3.7 |  |  | $\checkmark$ |
| Input Leak Current | ILI | $0 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |  | -1 |  | 1 | $\mu \mathrm{A}$ |
| Output Leak Current | ILO | $0 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Supply Current (standby) | Iccs | $\begin{aligned} & \overline{\mathrm{CS}} \geqq V_{\mathrm{CC}}-0.2 \mathrm{~V} \\ & \mathrm{~V}_{\text {IH }} \geqq V_{C C}-0.2 \mathrm{~V} \\ & V_{\text {IL }} \leqq 0.2 \mathrm{~V} \end{aligned}$ |  |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| Average Supply Current (active) | ICC | 1/O wire cycle 82C55A-2 $\ldots$.. 8MHzCPU timing |  |  |  | 8 | mA |

## AC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=4.5\right.$ to $5.5 \mathrm{~V}, \mathrm{Ta}=-40$ to $+80^{\circ} \mathrm{C}$ )

| Parameter | Symbol | MSM82C55A-2 |  | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| Setup Time of address to the falling edge of $\overline{\mathrm{RD}}$ | ${ }^{t}$ AR | 20 |  | ns |  |
| Hold Time of address to the rising edge of $\overline{\mathrm{RD}}$ | ${ }^{\text {tRA }}$ | 0 |  | ns |  |
| $\overline{R D}$ Pulse Width | tRR | 100 |  | ns |  |
| Delay Time from the falling edge of $\overline{\mathrm{RD}}$ to the output of defined data | tRD |  | 120 | ns |  |
| Delay Time from the rising edge of $\overline{\mathrm{RD}}$ to the floating of data bus | ${ }^{t}$ DF | 10 | 75 | ns |  |
| Time from the rising edge of $\overline{R D}$ or $\overline{W R}$ to the next falling edge of $\overline{R D}$ or $\overline{W R}$ | tRV | 200 |  | ns |  |
| Setup Time of address before the falling edge of $\overline{\mathrm{WR}}$ | ${ }^{\text {t }}$ AW | 0 |  | ns |  |
| Hold Time of address after the rising edge or $\overline{W R}$ | tWA | 20 |  | ns |  |
| $\overline{\text { WR Pulse Width }}$ | ${ }^{\text {t W W }}$ | 150 |  | ns |  |
| Setup Time of bus data before the rising edge of $\overline{W R}$ | tDW | 50 |  | ns |  |
| Holt Time of bus data after the rising edge of $\overline{W R}$ | twD | 30 |  | ns |  |
| Delay Time from the rising edge of $\overline{W R}$ to the output of defined data | tWB |  | 200 | ns |  |
| Setup Time of port data before the falling edge of $\overline{R D}$ | tIR | 20 |  | ns |  |
| Hold Time of port data after the rising edge of $\overline{\mathrm{RD}}$ | tHR | 10 |  | ns |  |
| $\overline{\text { ACK }}$ Pulse Width | ${ }^{t}$ AK | 100 |  | ns |  |
| $\overline{\text { STB Pulse Width }}$ | ${ }^{\text {t }}$ S $T$ | 100 |  | ns | Load |
| Setup Time of port data before the rising edge of $\overline{\text { STB }}$ | tPS | 20 | . | ns | 150 pF |
| Hold Time of port data after the rising edge of $\overline{\text { STB }}$ | tPH | 50 |  | ns |  |
| Delay Time from the falling edge of $\overline{\mathrm{ACK}}$ to the output of defined data | ${ }^{t} A D$ |  | 150 | ns |  |
| Delay Time from the rising edge of $\overline{\mathrm{ACK}}$ to the floating of port (Port A in mode 2) | ${ }^{\text {t }} \mathrm{KD}$ | 20 | 250 | ns |  |
| Delay Time from the rising edge of WR to the falling edge of $\overline{\mathrm{OBF}}$ | tWOB |  | 150 | ns |  |
| Delay Time from the falling edge of ACK to the rising edge of $\overline{\text { OBF }}$ | ${ }^{\text {t }} \mathrm{AOB}$ |  | 150 | ns |  |
| Delay Time from the falling edge of STB to the rising edge of IBF | ${ }^{\text {t }}$ SIB |  | 150 | ns |  |
| Delay Time from the rising edge of $\overline{\mathrm{RD}}$ to the falling edge of IBF | ${ }^{\text {t R IB }}$ |  | 150 | ns |  |
| Delay Time from the falling edge of $\overline{R D}$ to the falling edge of INTR | ${ }^{\text {t R I }}$ T |  | 200 | ns |  |
| Delay Time from the rising edge of $\overline{\text { STB }}$ to the rising edge of INTR | ${ }^{\text {t SIT }}$ |  | 150 | ns |  |
| Delay Time from the rising edge of $\overline{\mathrm{ACK}}$ to the rising edge of INTR | ${ }^{\text {t }}$ AIT |  | 150 | ns |  |
| Delay Time from the falling edge of $\overline{W R}$ to the falling edge of INTR | ${ }^{\text {tW W }}$ T |  | 250 | ns |  |

Note: Timing is measured at $\mathrm{V}_{\mathrm{L}}=0.8 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{H}}=2.2 \mathrm{~V}$ for both input and outputs.

## Basic Input Operation (Mode 0)



## Basic Output Operation (Mode 0)



## Strobe Input Operation (Mode 1)



## Strobe Output Operation (Mode 1)



Bidirectional Bus Operation (Mode 2)


## OUTPUT CHARACTERISTICS (REFERENCE VALUE)

1 Output " $\mathrm{H}^{\prime \prime}$ Voltage $\left(\mathrm{VOH}_{\mathrm{OH}}\right)$ vs. Output Current ( $\mathrm{I}_{\mathrm{OH}}$ )


2 Output "L" Voltage (VOL) vs. Output Current (IOL)


Note: The direction of flowing into the device is taken as positive for the output current.

## FUNCTIONAL DESCRIPTION OF PIN

| Pin No. | Item | Input/Output | Function |
| :---: | :---: | :---: | :---: |
| D7 ~ D0 | Bidirectional data bus | Input and output | These are three-state 8 -bit bidirectional buses used to write and read data upon receipt of the $\overline{W R}$ and $\overline{\mathrm{RD}}$ signals from CPUand also used when control words and bit set/reset data are transferred from CPU to MSM82C55A. |
| RESET | Reset input | Input | This signal is used to reset the control register and all internal registers when it is in high level. At this time, ports are all made into the input mode (high impedance status). <br> all port latches are cleared to O . and all ports groups are set to mode O . |
| $\overline{\text { cs }}$ | Chip select input | Input | When the $\overline{\mathrm{CS}}$ is in low level, data transmission is enabled with CPU. When it is in high level, the data bus is made into the high impedance status where no write nor read operation is performed. Internal registers hold their previous status, however. |
| $\overline{\mathrm{RD}}$ | Read input | Input | When RD is in low level, data is transferred from MSM82C55A to CPU. |
| $\overline{W R}$ | Write input | Input | $\dot{W}$ hen WR is in low level, data or control words are transferred from CPU to MSM82C55A. |
| A0, A1 | Port select input (address) | Input | By combination of AO and A1, either one is selected from among port A, port B, port C, and control register. These pins are usually connected to low order 2 bits of the address bus. |
| PA7 ~ PAO | Port A | Input and output | These are universal 8 -bit $1 / O$ ports. The direction of inputs/outputs can be determined by writing a control word. Especially, port A can be used as a bidirectional port when it is set to mode 2. |
| PB7 ~ PBO | Port B | Input and output | These are universal 8-bit I/O ports. The direction of inputs/outputs can be determined by writing a control word. |
| PC7 ~ PCO | Port C | Input and output | These are universal 8 -bit $1 / O$ ports. The direction of inputs/outputs can be determined by writing a control word as 2 ports with 4 bits each. When port A or port $B$ is used in mode 1 or mode 2 (port A only), they become control pins. Especially when port C is used as an output port, each bit can be set/reset independently. |
| VCC |  |  | +5 V power supply. |
| GND |  |  | GND |

## BASIC FUNCTIONAL DESCRIPTION

## Group A and Group B

When setting a mode to a port having 24 bits, set it by dividing it into two groups of 12 bits each.

Group A: Port A (8 bits) and high order 4 bits of port C (PC7 ~ PC4)
Group B: Port B ( 8 bits) and low order 4 bits of port C (PC3 ~ PCO)

## Mode 0, 1, 2

There are 3 types of modes to be set by grouping as follows:

Mode 0: Basic input operation/output operation (Available for both groups $A$ and $B$ )
Mode 1: Strobe input operation/output operation (Available for both groups $A$ and $B$ )
Mode 2: Bidirectional bus operation
(Available for group $A$ only)

When used in mode 1 or mode 2, however, port C has bits to be defined as ports for control signal for operation ports (port A for group A and port B for group B) of their respective groups.

## Port A, B, C

The internal structure of 3 ports is as follows:
Port A: One 8-bit data output latch/buffer and one 8-bit data input latch
Port B: One 8-bit data input/output latch/buffer and one 8 -bit data input buffer
Port C: One 8-bit data output latch/buffer and one 8-bit data input buffer (no latch for input)

## Single bit set/reset function for port C

When port C is defined as an output port, it is possible to set (to turn to high level) or reset (to turn to low level) any one of 8 bits individually without affecting other bits.

## OPERATIONAL DESCRIPTION

## Control Logic

Operations by addresses and control signals, e.g., read and write, etc. are as shown in the table below:

| Operation | A 1 | AO | $\overline{\mathrm{CS}}$ | $\overline{\mathrm{WR}}$ | $\overline{\mathrm{RD}}$ |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
|  | 0 | 0 | 0 | 1 | 0 | Port A $\rightarrow$ Data Bus |
|  | 0 | 1 | 0 | 1 | 0 | Port B $\rightarrow$ Data Bus |
|  | 1 | 0 | 0 | 1 | 0 | Port $\mathrm{C} \rightarrow$ Data Bus |
| Output | 0 | 0 | 0 | 0 | 1 | Data Bus $\rightarrow$ Port A |
|  | 0 | 1 | 0 | 0 | 1 | Data Bus $\rightarrow$ Port B |
|  | 1 | 0 | 0 | 0 | 1 | Data Bus $\rightarrow$ Port C |
|  | 1 | 1 | 0 | 0 | 1 | Data Bus $\rightarrow$ Control Register |
| Others | 1 | 1 | 0 | 1 | 0 | Ilegal Condition |
|  | x | x | 1 | x | x | Data bus is in the high impedance status. |

## Setting of Control Word

The control register is composed of 7 -bit latch circuit and 1 -bit flag as shown below.


## Precaution for mode selection

The output registers for ports $A$ and $C$ are cleared to $\phi$ each time data is written in the command register and the mode is changed, but the port $B$ state is undefined.

## Bit Set/Reset Function

When port $C$ is defined as output port, it is possible to set (set output to 1 ) or reset (set output to 0 ) any one of 8 bits without affecting other bits as shown next page.


## Interrupt Control Function

When the MSM82C55A is used in mode 1 or mode 2, the interrupt signal for the CPU is provided. The interrupt request signal is output from port C . When the internal flip-flop INTE is set beforehand at this time, the desired interrupt request signal is output. When it is reset beforehand, however, the interrupt request signal is not output. The set/reset of the internal flip-flop is made by the bit set/reset operation for port C virtually.

Bit set $\rightarrow$ INTE is set $\rightarrow$ Interrupt allowed
Bit reset $\rightarrow$ INTE is reset $\rightarrow$ Interrupt inhibited

## Operational Description by Mode

1. Mode $\mathbf{0}$ (Basic input/output operation)

Mode 0 makes the MSM82C55A operate as a basic input port or output port. No control signals such as interrupt request, etc. are required in this mode. All 24 bits can be used as two-8-bit ports and two 4-bit ports. Sixteen combinations are then possible for inputs/outputs. The inputs are not latched, but the outputs are.

| Type |  |  |  |  |  |  |  | Control Word |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ | Port A | High Order 4 Bits <br> of Port C | Port B | Low Order 4 Bits <br> of Port C |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Output | Output | Output | Output |
| 2 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Output | Output | Output | Input |
| 3 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | Output | Output | Input | Output |
| 4 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | Output | Output | Input | Input |
| 5 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | Output | Input | Output | Output |
| 6 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | Output | Input | Output | Input |
| 7 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | Output | Input | Input | Output |
| 8 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | Output | Input | Input | Input |
| 9 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | Input | Output | Output | Output |
| 10 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | Input | Output | Output | Input |
| 11 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | Input | Output | Input | Output |
| 12 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | Input | Output | Input | Input |
| 13 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | Input | Input | Output | Output |
| 14 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | Input | Input | Output | Input |
| 15 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | Input | Input | Input | Output |
| 16 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | Input | Input | Input | Input |

Note: When used in mode 0 for both groups $A$ and $B$

## 2. Mode 1 (Strobe input/output operation)

In mode 1, the strobe, interrupt and other control signals are used when input/output operations are made from a specified port. This mode is available for both groups A and B. In group A at this time, port $A$ is used as the data line and port $C$ as the control signal.
Following is a descrption of the input operation in mode 1.
STB (Strobe input).

- When this signal is low level, the data output from terminal to port is fetched into the internal latch of the port. This can be made independent from the CPU, and the data is not output to the data bus until the RD signal arrives from the CPU.
IBF (Input buffer full flag output)
- This is the response signal for the STB. This signal when turned to high level indicates that data is fetched into the input latch. This signal turns to high level at the falling edge of $\overline{\text { STB }}$ and to low level at the rising edge of $\overline{\mathrm{RD}}$.
INTR (Interrupt request output)
- This is the interrupt request signal for the CPU of the data fetched into the input latch. It is indicated by high level only when the internal INTE flip-flop is set. This signal turns to high level at the rising edge of the $\overline{\text { STB }}$ (IBF $=1$ at this time)

Mode 1 Input


Note: Although belonging to group $\mathrm{B}, \mathrm{PC}_{3}$ operates as the control signal of group A functionally.
and low level at the falling edge of the $\overline{\mathrm{RD}}$ when the INTE is set.
INTE $_{A}$ of group $A$ is set when the bit for $\mathrm{PC}_{4}$ is set, while $I N T E_{B}$ of group $B$ is set when the bit for $\mathrm{PC}_{2}$ is set.
Following is a description of the output operation of mode 1.

## $\overline{O B F}$ (Output buffer full flag output)

- This signal when turned to low level indicates that data is written to the specified port upon receipt of the $\overline{W R}$ signal from the CPU. This signal turns to low level at the rising edge of the WR and high level at the falling edge of the ACK.


## $\overline{\text { ACK }}$ (Acknowledge input)

- This signal when turned to low level indicates that the terminal has received data.


## INTR (Interrupt request output)

- This is the signal used to interrupt the CPU when a terminal receives data from the CPU via the MSM82C55A-5. It indicates the occurrence of the interrupt in high level only when the internal INTE flip-flop is set. This signal turns to high level at the rising edge of the $\overline{A C K}(O B F=1$ at this time) and low level at the falling edge of $\overline{W R}$ when the $\mathrm{INTE}_{B}$ is set.
INTE $_{A}$ of group $A$ is set when the bit for $\mathrm{PC}_{6}$ is set, while $\operatorname{INTE}_{B}$ of group $B$ is set when the bit for $P C_{2}$ is set.
Mode 1 output



## Port C Function Allocation in Mode 1

| Combination of Input/Output <br> Port C | Group A: Input Group B: Input | Group A: Input <br> Group B: Output | Group A: Output Group B: Input | Group A: Output <br> Group B: Output |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{PC}_{0}$ | INTR $_{\text {B }}$ | $\mathrm{INTR}_{\text {B }}$ | INTR $_{\text {B }}$ | INTR $_{\text {B }}$ |
| $\mathrm{PC}_{1}$ | $\mathrm{IBF}_{B}$ | $\overline{\mathrm{OBF}}_{\mathrm{B}}$ | $\mathrm{IBF}_{\mathrm{B}}$ | $\overline{\mathrm{OBF}}_{\mathrm{B}}$ |
| $\mathrm{PC}_{2}$ | $\overline{S T B}_{B}$ | $\overline{\mathrm{ACK}}_{\mathrm{B}}$ | $\overline{S T B}_{B}$ | $\overline{\mathrm{ACK}}_{\mathrm{B}}$ |
| $\mathrm{PC}_{3}$ | INTRA $^{\text {a }}$ | INTRA $^{\text {a }}$ | $\mathrm{INTR}_{\text {A }}$ | INTR $_{\text {A }}$ |
| $\mathrm{PC}_{4}$ | $\overline{\text { STBA }}$ | $\overline{S T B}_{\text {S }}$ | 1/O | 1/0 |
| $\mathrm{PC}_{5}$ | $\mathrm{IBF}_{\text {A }}$ | $\mathrm{IBF}_{\text {A }}$ | 1/0 | 1/0 |
| $\mathrm{PC}_{6}$ | 1/O | I/O | $\overline{\mathrm{ACK}}_{\mathrm{A}}$ | $\overline{\text { ACK }}_{\text {A }}$ |
| $\mathrm{PC}_{7}$ | 1/0 | 1/0 | $\overline{O B F}_{A}$ | $\overline{O B F}_{A}$ |

Note: $\quad I / O$ is a bit not used as the control signal, but it is available as a port of mode 0 .

Examples of the relation between the control words and pins when used in mode 1 is shown below: (a) When group $A$ is mode 1 output and group $B$ is mode 1 input.

(b) When group $A$ is mode 1 input and group $B$ is mode 1 output.


## 3. Mode 2 (Strobe bidirectional bus I/O operation)

In mode 2, it is possible to transfer data in 2 directions through a single 8 -bit port. This operation is akin to a combination between input and output operations. Port C waits for the control signal in this case, too. Mode 2 is available only for group A, however.
Next, a description is made on mode 2.

## OBF (Output buffer full flag output)

- This signal when turned to low level indicates that data has been written to the internal output latch upon receipt of the $\overline{W R}$ signal from the CPU. At this time, port A is still in the high impedance status and the data is not yet output to the outside. This signal turns to low level at the rising edge of the $\overline{W R}$ and high level at the falling edge of the $\overline{A C K}$.


## $\overline{A C K}$ (Acknowledge input)

- When a low level signal is input to this pin, the high impedance status of port $A$ is cleared, the buffer is enabled, and the data written to the internal output latch is output to port $A$. When the input returns to high level, port A is made into the high impedance status.


## $\overline{\text { STB }}$ (Strobe input)

- When this signal turns to low level, the data output to the port from the pin is fetched into the internal input latch. The data is output to the data bus upon receipt of the RD signal from the CPU, but it remains in the high impedance status until then.


## IBF (Input buffer full flag output)

- This signal when turned to high level indicates that data from the pin has been fetched into the input latch. This signal turns to high level at the falling edge of the STB and low level at the rising edge of the $\overline{R D}$.


## INTR (Interrupt request output)

- This signal is used to interrupt the CPU and its operation in the same as in mode 1. There are two INTE flip-flops internally available for input and output to select either interrupt of input or output operation. The INTE1 is used to control the interrupt request for output operation and it can be reset by the bit set for PC6. INTE2 is used to control the interrupt request for the input operation and it can be set by the bit set for PC4.

Mode 2 I/O Operation


Port C Function Allocation in Mode 2

| Port C | Function |
| :---: | :---: |
| $\mathrm{PC}_{0}$ | Confirmed to the group B mode |
| $\mathrm{PC}_{1}$ |  |
| $\mathrm{PC}_{2}$ |  |
| $\mathrm{PC}_{3}$ | INTR $_{\text {A }}$ |
| $\mathrm{PC}_{4}$ | $\overline{\text { STB }}{ }_{\text {A }}$ |
| $\mathrm{PC}_{5}$ | $\mathrm{IBF}_{\text {A }}$ |
| $\mathrm{PC}_{6}$ | $\overline{\mathbf{A C K}}_{\mathbf{A}}$ |
| $\mathrm{PC}_{7}$ | $\overline{\mathrm{OBF}}_{\mathrm{A}}$ |

Following is an example of the relation between the control word and the pin when used in mode 2. When input in mode 2 for group $A$ and in mode 1 for group B.

4. When Group $A$ is Different in Mode from Group B Group A and group B can be used by setting them in different modes each other at the same time. When either group is set to mode 1 or mode 2, it is
possible to set the one not defined as a control pin in port C to both input and output as a port which operates in mode 0 at the 3rd and Oth bits of the control word.
(Mode combinations that define no control bit at port C)

|  | Group A | Group B | Port C |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathrm{PC}_{7}$ | $\mathrm{PC}_{6}$ | $\mathrm{PC}_{5}$ | $\mathrm{PC}_{4}$ | $\mathrm{PC}_{3}$ | $\mathrm{PC}_{2}$ | $\mathrm{PC}_{1}$ | $\mathrm{PC}_{0}$ |
| 1 | Mode 1 input | Mode 0 | 1/0 | 1/O | $\mathrm{IBF}_{\text {A }}$ | $\overline{S T B}_{A}$ | $\mathrm{INTR}_{\text {A }}$ | 1/0 | 1/0 | 1/0 |
| 2 | Mode 0 output | Mode 0 | $\overline{O B F}_{A}$ | $\overline{\text { ACK }}^{\text {A }}$ | 1/0 | 1/0 | INTRA $_{\text {A }}$ | 1/0 | 1/0 | 1/0 |
| 3 | Mode 0 | Mode 1 input | 1/0 | 1/0 | 1/0 | 1/0 | 1/0 | $\overline{S T B}_{B}$ | $\mathrm{IBF}_{B}$ | $\mathrm{INTR}_{B}$ |
| 4 | Mode 0 | Mode 1 output | 1/0 | 1/0 | 1/0 | 1/0 | 1/0 | $\overline{\mathrm{ACK}}_{\mathrm{B}}$ | $\overline{\text { OBF }}_{\text {B }}$ | INTR $_{\text {B }}$ |
| 5 | Mode 1 <br> input | Mode 1 <br> input | 1/0 | 1/0 | IBFA | $\overline{S T B}_{A}$ | INTRA $^{\text {A }}$ | $\overline{S T B}_{B}$ | $\mathrm{IBF}_{B}$ | $\mathrm{INTR}_{B}$ |
| 6 | Mode 1 input | Mode 1 output | 1/0 | 1/0 | $\mathrm{IBF}_{\text {A }}$ | $\overline{S T B}_{A}$ | INTR $_{\text {A }}$ | $\overline{\mathrm{ACK}}_{\mathrm{B}}$ | $\overline{O B F}_{B}$ | INTR $_{B}$ |
| 7 | Mode 1 output | Mode 1 input | $\overline{O B F}_{A}$ | $\overline{\mathrm{ACK}}_{\mathbf{A}}$ | 1/0 | 1/0 | $\mathrm{INTR}_{\text {A }}$ | $\overline{S T B}_{B}$ | $\mathrm{IBF}_{\mathrm{B}}$ | INTR $_{\text {B }}$ |
| 8 | Mode 1 output | Mode 1 output | $\overline{\mathrm{OBF}}_{\mathrm{A}}$ | ${\overline{\mathrm{A}} \overline{C K}_{\mathrm{A}}}$ | 1/0 | 1/0 | INTRA | $\overline{\mathrm{ACK}}_{\mathrm{B}}$ | $\overline{O B F}_{B}$ | $\mathrm{INTR}_{B}$ |
| 9 | Mode 2 | Mode 0 | $\overline{O B F}_{\text {A }}$ | $\overline{\mathrm{ACK}}_{\mathrm{A}}$ | $\mathrm{IBF}_{\text {A }}$ | $\overline{\text { STB }}^{\text {A }}$ | INTR $_{\text {A }}$ | 1/0 | 1/0 | 1/0 |

Controlled at the 3rd bit (D3) of the control word

Controlled at the Oth bit (DO) of the control word

When the $\mathrm{I} / \mathrm{O}$ bit is set to input in this case, it is possible to access data by the normal port C read operation.
When set to output, PC7 ~ PC4 bits can be accessed by the bit set/reset function only. Meanwhile, 3 bits from PC2 to PCO can be accessed by normal write operation.

The bit set/reset function can be used for all of PC3 ~ PCO bits. Note that the status of port C varies according to the combination of modes like this.
5. Port C Status Read

When port C is used for the control signal, that is, in either mode 1 or mode 2, each control signal and
bus status signal can be read out by reading the content of port C.
The status read out is as follows:

|  | Group A | Group B | Status read on the data bus |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| 1 | Mode 1 input | Mode 0 | 1/O | 1/0 | $\mathrm{IBF}_{\text {A }}$ | INTEA | INTRA | 1/0 | 1/0 | 1/0 |
| 2 | Mode 1 output | Mode 0 | $\overline{O B F}_{A}$ | INTEA | 1/0 | 1/0 | INTRA $_{\text {A }}$ | 1/0 | 1/0 | 1/0 |
| 3 | Mode 0 | Mode 1 input | 1/0 | 1/0 | 1/0 | I/O | 1/0 | INTE $_{\text {B }}$ | $\mathrm{IBF}_{B}$ | $\mathrm{INTR}_{B}$ |
| 4 | Mode 0 | Mode 1 output | 1/0 | 1/0 | 1/0 | 1/0 | 1/0 | INTE $_{\text {B }}$ | $\overline{O B F}_{B}$ | $\mathrm{INTR}_{B}$ |
| 5 | Mode 1 input | Mode 1 input | 1/0 | 1/0 | $\mathrm{IBF}_{\text {A }}$ | INTEA $_{\text {A }}$ | INTR $_{\text {A }}$ | INTE $_{\text {B }}$ | $\mathrm{IBF}_{\mathrm{B}}$ | $\mathrm{INTR}_{\text {B }}$ |
| 6 | Mode 1 input | Mode 1 output | 1/0 | 1/0 | $\mathrm{IBF}_{\text {A }}$ | INTE $_{\text {A }}$ | $\mathrm{INTR}_{\text {A }}$ | INTE $_{\text {B }}$ | $\overline{\mathrm{OBF}}_{\mathrm{B}}$ | $\mathrm{INTR}_{B}$ |
| 7 | Mode 1 output | Mode 1 input | $\overline{\mathrm{OBF}}_{\mathrm{A}}$ | INTEA $_{\text {A }}$ | 1/0 | 1/0 | INTR $_{\text {A }}$ | $\mathrm{INTE}_{\text {B }}$ | $\mathrm{IBF}_{B}$ | $\mathrm{INTR}_{B}$ |
| 8 | Mode 1 output | Mode 1 output | $\overline{O B F}_{A}$ | INTE $_{\text {A }}$ | 1/0 | 1/0 | INTR $_{\text {A }}$ | INTE $_{\text {B }}$ | $\overline{\mathrm{OBF}}_{\mathrm{B}}$ | $\mathrm{INTR}_{\text {B }}$ |
| 9 | Mode 2 | Mode 0 | $\overline{O B F}_{A}$ | $\mathrm{INTE}_{1}$ | $\mathrm{IBF}_{\text {A }}$ | $\mathrm{INTE}_{2}$ | $\mathrm{INTR}_{\text {A }}$ | 1/0 | 1/0 | 1/0 |
| 10 | Mode 2 | Mode 1 input | $\overline{O B F}_{A}$ | $\mathrm{INTE}_{1}$ | IBFA | $\mathrm{INTE}_{2}$ | INTR ${ }_{\text {A }}$ | INTE $_{\text {B }}$ | $\mathrm{IBF}_{B}$ | $\mathrm{INTR}_{\mathbf{B}}$ |
| 11 | Mode 2 | Mode 1 output | $\overline{O B F}_{A}$ | $\mathrm{INTE}_{1}$ | IBFA | $\mathrm{INTE}_{2}$ | INTRA | INTE $_{\text {B }}$ | $\overline{O B F}_{B}$ | $\mathrm{INTR}_{B}$ |

## 6. Reset of MSM82C55A

Be sure to keep the RESET signal at power ON in the high level at least for $50 \mu \mathrm{~s}$. Subsequently, it
becomes the input mode at a high level pulse above 500 ns .

## Note:

## MSM82C55A-5

After a write command is executed to the command register, the internal latch is cleared in PORTA PORTC. For instance, 00 H is output at the beginning of a write command when the output port is assigned. However, if PORTB is not cleared at this time, PORTB is unstable. In other words, PORTB only outputs ineffective data (unstable value according to the device) during the period from after a write command is executed till the first data is written to PORTB.

MSM82C55A-2
After a write command is executed to the command register, the internal latch is cleared in All Ports(PORTA,PORTB, PORTC). OOH is ontput at the beginning of a write command when the output port is assigned.

## OIEI semiconductor

## MSM82C59A-2RS/GS/JS

PROGRAMMABLE INTERRUPT CONTROLER

## GENERAL DESCRIPTION

The MSM82C59A-2 is a programmable interrupt controller for use in MSM80C85A/A-2 and MSM80C86/88 microcomputer systems.

Based on CMOS silicon gate technology, this device features an extremely low standby current of $100 \mu \mathrm{~A}$ (max.) in chip non-selective status. During interrupt control status, the power consumption is very low with only 5 mA (max.) being required.

Internally, the MSM82C59A-2 can control priority interrupts up to 8 levels, and can be expanded up to 64 levels by cascade connection of a number of devices.

## FEATURES

- Silicon gate CMOS technology for high speed and low power consumption.
- 3 V to 6 V single power supply
- 80C85A system compatibility (MAX5MHz)
- 80C86/88 system compatibility (MAX8MHz)
- 8-level priority interrupt control
- Interrupt levels expandable up to 64 levels

Programmable interrupt mode

- Maskable interrupt
- Automatically generated CALL code (85 mode)
- TTL compatible
- 28 pin Plastic DIP (DIP28-P-600)
- 28 pin PLCC (QFJ28-P-S450)
- 32 pin Plastic SOP (SSOP32-P-430-K)
- 32 pin-V Plastic SOP (SSOP32-P-430-VK)


## CIRCUIT CONFIGURATION



INTERNAL BUS (8 bit)

## PIN CONNECTIONS



## ELECTRICAL CHARACTERISTICS

## Absolute Maximum Ratings

| Parameter | Symbol | Conditions | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM82C59A-2RS | MSM82C59A-2GS | MSM82C59A-2JS |  |
| Power supply voltage | $V_{\text {cc }}$ | Respect to GND | $-0.5 \sim+7$ |  |  | V |
| Input voltage | $\mathrm{V}_{\text {IN }}$ |  | $-0.5 \sim v_{c c}+0.5$ |  |  | V |
| Output voltage | $\mathrm{V}_{\text {OUT }}$ |  | $-0.5 \sim v_{c c}+0.5$ |  |  | V |
| Storage temperature | $\mathrm{T}_{\text {stg }}$ | - | $-55 \sim+150$ |  |  | ${ }^{\circ} \mathrm{C}$ |
| Power dissipation | $P_{\text {D }}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | 0.9 | 0.7 | 0.9 | W |

Operating Ranges

| Parameter | Symbol | Range | Unit |
| :--- | :---: | :---: | :---: |
| Power supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | $3 \sim 6$ | V |
| Operating temperature | TOP | $-40 \sim+85$ | ${ }^{\circ} \mathrm{C}$ |

## Recommended Operating Conditions

| Parameter | Symbol | Max. | Typ. | Min. | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Power supply voltage | $V_{C C}$ | 4.5 | 5 | 5.5 |  |
| Operating temperature | Top | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| " $L^{\prime}$ level input voltage | $V_{I L}$ | -0.5 |  | +0.8 | $V$ |
| "H" level input voltage | $V_{I H}$ | 2.2 |  | $V_{C C}+0.5$ | $V$ |

## DC Characteristics

| Parameter | Symbol | Conditions |  | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "L" level output voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}^{\mathrm{OL}}=2.5 \mathrm{~mA}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \sim 5.5 \mathrm{~V} \\ & \mathrm{Ta}=-40^{\circ} \mathrm{C} \sim+85^{\circ} \mathrm{C} \end{aligned}$ |  |  | 0.4 | V |
| "H" level output voltage | $\mathrm{V}_{\mathrm{OH}}$ | ${ }^{1} \mathrm{OH}=-2.5 \mathrm{~mA}$ |  | 3.0 |  |  | V |
|  |  | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |  | $\mathrm{v}_{\mathrm{cc}}-0.4$ |  |  |  |
| Input leak current | ILI | $0 V_{\leqq} \mathrm{V}_{\text {IN }} \leqq \mathrm{V}_{\text {CC }}$ |  | -1 |  | 1 | $\mu \mathrm{A}$ |
| IR Input leak current | ILIR |  |  | -300 |  | 10 | $\mu \mathrm{A}$ |
| Output leak current | ILO | OV§ $\mathrm{V}_{\text {OUT }} \leqq \mathrm{V}_{\text {CC }}$ |  | -10 |  | 10 | $\mu \mathrm{A}$ |
| Standby power supply current | Iccs | $\begin{aligned} & \overline{C S}=V_{C C}, I R=V_{C C} \\ & V_{I L}=0 V, V_{I H}=V_{C C} \end{aligned}$ |  |  | 0.1 | 100 | $\mu \mathrm{A}$ |
| Average operation power supply current | ${ }^{\prime} \mathrm{Cc}$ | $\begin{aligned} & V_{I N}=0 \mathrm{~V} / V_{C C} \\ & C_{L}=0 \mathrm{pF} \end{aligned}$ |  |  |  | 5 | mA |

AC Characteristics
$\mathrm{Ta}=-40^{\circ} \mathrm{C} \sim+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Parameter | Symbol | Min. | Max. | Unit | TEST | onditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address setup time (to $\overline{\mathrm{RD}}$ ) | TAHRL | 10 |  | nS |  | Read $\overline{\text { INTA }}$ timing |
| Address hold time (after $\overline{\mathrm{RD}}$ ) | TRHAX | 5 |  | nS |  |  |
| $\overline{\mathrm{RD}} / \overline{\mathrm{NT} T A}$ pulse width | TRLRH | 160 |  | nS |  |  |
| Address setup time (to $\overline{\mathrm{WR}}$ ) | TAHWL | 0 |  | nS |  | Write timing |
| - Address hold time (after $\overline{W R}$ ) | TWHAX | 0 |  | nS |  |  |
| WR pulse width | TWLWH | 190 |  | nS |  |  |
| Data setup time (to $\overline{W R}$ ) | TDVWH | 160 |  | nS |  |  |
| Data hold time (after $\overline{\text { WR }}$ ) | TWHDX | 0 |  | nS |  |  |
| IR input width (Low) | TJLJH | 100 |  | nS |  | $\overline{\text { INTA }}$ sequence |
| CAS input setup time (to $\overline{\text { INTA) (slave) }}$ | TCVIAL | 40 |  | nS |  |  |
| End of $\overline{R D}$ to Next $\overline{R D}$ <br> End of $\overline{\text { INTA }}$ to Next $\overline{\text { INTA }}$ | TRHRL | 160 |  | nS |  | Other timing |
| End of $\overline{W R}$ to. Next $\overline{W R}$ | TWHWL | 190 |  | nS |  |  |
| End of Command to Next command | TCHCL | 400 |  | nS |  |  |
| Data valid following $\overline{\mathrm{RD}} / \overline{\mathrm{INTA}}$ | TRLDV |  | 120 | nS | 1 | Delay times |
| Data floating following $\overline{\mathrm{RD}} / \overline{\mathrm{INTA}}$ | TRHDZ | 10 | 85 | nS | 2 |  |
| INT output delay time | TJHIH |  | 300 | nS | 1 |  |
| CAS valid following 1st. $\overline{\text { INTA }}$ (master) | TIALCV |  | 360 | nS | 1 |  |
| $\overline{E N}$ active following $\overline{\mathrm{RD}} / \overline{\mathrm{NTTA}}$ | TRLEL |  | 100 | nS | 1 |  |
| $\overline{\mathrm{EN}}$ inactive following $\overline{\mathrm{RD}} / \overline{\mathrm{NTTA}}$ | TRHEH |  | 150 | nS | 1 |  |
| Data valid after address | TAHDV |  | 200 | nS | 1 |  |
| Data valid after CAS | TCVDV |  | 200 | nS | 1 |  |

## AC TEST CIRCUITS

| TEST CONDITION | V 1 | R 1 | R 2 | $\mathrm{C1}$ |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 1.7 V | $523 \Omega$ | OPEN | 100 pf |
| 2 | 4.5 V | $1.8 \mathrm{~K} \Omega$ | $1.8 \mathrm{~K} \Omega$ | 30 pf |

TEST CONDITION DEFINITION TABLE
A.C. TESTING INPUT, OUTPUT WAVEFORM

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

TIME CHART
Write Timing


## Read/INTA Timing



Other Timing


## $\overline{\text { INTA }}$ Sequence ( 85 mode)


$\overline{\text { INTA }}$ Sequence ( 86 mode)


## PIN FUNCTION DESCRIPTION

| Pin Symbol | Name | Input/output | Function |
| :---: | :---: | :---: | :---: |
| D7 ~ DO | Bidirectional data bus | Input/output | This 3 -state 8 -bit bidirectional data bus is used in reading status registers and writing command words through the $\overline{\operatorname{RD}} / \overline{\mathrm{WR}}$ signal from the CPU, and also in reading the CALL instruction code by the $\overline{\mathrm{NTA}}$ signal from the CPU. |
| $\overline{\text { CS }}$ | Chip select input | Input | Data transfer with the CPU is enabled by $\overline{\operatorname{RD}} \overline{N R}$ when this pin is at low level. The data bus (D0 thru D7) is switched to high impedance when the pin is at high level. Note that $\overline{\mathrm{CS}}$ does not effect INTA. |
| $\overline{\mathrm{RD}}$ | Read input | Input | Data is transferred from the 82C59A to the CPU when this pin is at low level. IRR (Interrupt Request Register), ISR (In-Service Register), IMR (Interrupt Mask Register), or a Poll word is selected by OCW3 and AO. |
| $\overline{W R}$ | Write input | Input | Commands are transferred from the CPU to the 82C59A when this pin is at low level. |
| AO | Address input | Input | This pin is used together with the $\overline{\mathrm{CS}}, \overline{\mathrm{WR}}$, and $\overline{\mathrm{RD}}$ signals to write commands in the command registers, and to select and read status registers. This is normally connected to the least significant bit of the address bus. (A0 for 80C85A, and A1 for 80C86/88). |
| CASO ~ 2 | Cascade address | Input/output | These pins are outputs when the 82C59A is used as the master, and inputs when used as a slave (in cascade mode). These pins are outputs when in single mode. |
| $\overline{S P} / \overline{E N}$ | Slave program input/enable buffer output | Input/output | This dual function pin is used as an output to enable the data bus buffer in Buffered mode, and as an input for deciding whether the 82C59A is to be master $(\overline{\mathrm{SP}} / \overline{\mathrm{EN}}=1)$ or a slave ( $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}=0$ ) during Non-buffered mode. |
| INT | Interrupt output | Output | When an interrupt request is made to the 82C59A, the INT output is switched to high level, and INT interrupt is sent to the CPU. |
| $\overline{\text { INTA }}$ | Interrupt acknowledge input | Input | When this pin is at low level, the CALL instruction code or the interrupt vector data is enabled onto the data bus. When the CPU acknowledges the INT Interrupt, $\overline{\text { NTA }}$ is sent to the 82C59A. (Interrupt acknowledge sequence). |
| IRO ~ 7 | Interrupt request input | Input | These interrupt request input pins for the 82C59A can be set to edge trigger mode or level trigger mode (by ICW1). In edge trigger mode, interrupt request is executed by the rising edge of the IR input and holds it until that input is acknowledged by the CPU. In level trigger mode, interrupt requests are executed by high level IR inputs and holds them until that input is acknowledged by the CPU. These pins have a pull up resistor. |

## SYSTEM INTERFACE



## BASIC OPERATION DESCRIPTION

Data transfers between the 82C59A internal registers and the data bus are listed below.

| A0 | D4 | D3 | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{\mathrm{CS}}$ | Function | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $x$ | X | 0 | 1 | 0 | IRR, ISR, or Poll word $\rightarrow$ Data bus | Read |
| 1 | $x$ | $x$ | 0 | 1 | 0 | IMR $\rightarrow$ Data bus | Read |
| 0 | 0 | 0 | 1 | 0 | 0 | Data bus $\rightarrow$ OCW2 | Write |
| 0 | 0 | 1 | 1 | 0 | 0 | Data bus $\rightarrow$ OCW3 | Write |
| 0 | 1 | $x$ | 1 | 0 | 0 | Data bus $\rightarrow$ ICWI | Write |
| ${ }^{1}$ | $x$ | $x$ | 1 | 0 | 0 | Data bus $\rightarrow$ OCW 1, ICW2, ICW3, ICW4 | Write |
| $x$ | X | X | 1 | 1 | 0 | bus set to high impedance (when INTA $=1$ ) | - |
| $x$ | $x$ | $x$ | $x$ | $x$ | 1 |  |  |
| X | X | X | 0 | 0 | X | Combinations prohibited | - |

## OPERATION DESCRIPTION

The 82C59A has been designed for real time interrupt driven microcomputer systems. The 82C59A is capable of handling up to 8 levels of interrupt requests, and can be expanded to cover a maximum of 64 levels when connected to other 82C59A devices.

Programming involves the use of system software in the same way as other microcomputer peripheral I/O
devices. Selection of priority mode involves program execution, and enables the method of requesting interrupts to be processed by the 82C59A to be suitably configured for system requirements. That is, the priority mode can be dynamically updated or reconfigured during the main program at any time. A complete interrupt structure can be defined as required, based on the entire system environment.

## (1) Functional Description of Each Block

| Block name | Description of function |
| :--- | :--- |
| IRR, ISR | IR input line interrupts are processed by a cascaded interrupt request register <br> (IRR) and the in-service register (ISR). The IRR stores all request levels where <br> interrupt service is requested, and the ISR stores all interrupt levels being <br> serviced. |
| Priority resolver | This logic block determines the priority level of the bits set in the IRR. The <br> highest priority level is selected, and the corresponding ISR bit is set during <br> INTA pulses. |
| Read/write logic | This block is capable of receiving commands from the CPU. These command <br> words (ICW) and the operation command words (OCW) store the various <br> control formats for 82C59A operations. This block is also used to transfer <br> the status of the 82C59A to the Data Bus. |
| Cascade buffer comparator | This functional block is involved in the output and comparison of all 82C59A <br> IDs used in the system. These three I/O pins (CASO thru CAS2) are outputs <br> when the 82C59A operates as a master, and inputs when it operates as a slave. <br> When operating as a master, the 82C59A sends a slave ID output to the slave <br> where an interrupt has been applied. <br> Furthermore, the selected slave sends the preprogrammed subroutine address <br> onto the data bus during next one or two INTA pulses from the CPU. |

## (2) Interrupt Sequence

The major features of the 82C59A used in microcomputer systems are the programmability and the addressing capability of interrupt routines. This latter feature enables direct or indirect jumping to specific interrupt routines without polling the interrupt devices. The operational sequence during an interrupt varies for different CPUs. The procedure for the 85 system (8085A/80C85A) is outlined below.
(i) One or more interrupt requests (IRO thru IR7) becomes high, and the corresponding IRR bit is set.
(ii) The 82C59A evaluates these requests, and sends an INT signal to the CPU if the request is judged to be suitable.
(iii) The CPU issues an INTA output pulse upon reception of the INT signal.
(iv) Upon reception of the INTA signal from the CPU, the 82C59A releases the CALL instruction code ( 11001101 ) to the 8 -bit data bus.
(v) A further two INTA pulses are then sent to the 82C59A from the CPU by this CALL instruction.
(vi) These two $\overline{\text { INTA }}$ pulses result in a preprogrammed subroutine address being sent from the 82C59A to the data bus. The lower 8bit address is released by the first INTA pulse, and the higher 8 -bit address is released by the second pulse.
The Falling Edge of the second INTA signal sets the ISR bit with the highest priority, and the Rising Edge of it resets the IRR bit.
(vii) 3-byte CALL instructions are thus released by the 82C59A. In Automatic End Of Interrupt (AEOI) mode, the ISR bit is reset at the end of the third INTA pulse. In other cases, the ISR bit remains set until reception of a suitable EOI command at the end of the interrupt routine.
The procedure for the 86 system ( $80 C 86 / 88$ ) is identical to the first three steps of the 85 system. The subsequent steps are described below.
(iv) Upon reception of the INTA signal from the CPU, the ISR bit with the highest priority is set, and the corresponding IRR bit is reset. In this cycle, the 82C59A sets the data bus to high impedance without driving the Data Bus.
(v) The CPU generates a second INTA output pulse, resulting in an 8 -bit pointer to the data bus by the 82C59A.
The Falling Edge of the $\overline{\text { INTA }}$ signal sets the ISR bit with the highest priority, and the Rising Edge of it resets the IRR bit.
(vi) This completes the interrupt cycle. In AEOI mode, the ISR bit is reset at the end of the second INTA pulse. In other cases, the ISR bit remains set until reception of a suitable EOI command at the end of the interrupt routine.
If the interrupt request is cancelled prior to step (iv), that is, before the first $\overline{1 N T A}$ pulse has been received, the 82C59A operates as if a level 7 interrupt has been received, and the vector byte and CAS line operate as if a level 7 interrupt has been requested.
(3) Interrupt Sequence Output 85 Mode (80C85A)
The sequence in this case consists of three INTA pulses. A CALL operation code is released to the data bus by the first $\overline{I N T A}$ pulse.

Contents of the first interrupt
vector byte

CALL code

| $D 7$ | $D 6$ | $D 5$ | $D 4$ | $D 3$ | $D 2$ | $D 1$ | $D 0$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 |

The lower address of the interrupt service routine is released to the data bus by the second INTA pulse. If $A 5 \sim A 7$ is programmed with an address interval of 4, AO ~A4, is automatically inserted. And if A6 and A7 are programmed at an address interval of $8, A 0 \sim A 5$ is automatically inserted.

Contents of the second interrupt vector byte

| IR | Interval $=4$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| 7 | A7 | A6 | A5 | 1 | 1 | 1 | 0 | 0 |
| 6 | A7 | A6 | A5 | 1 | 1 | 0 | 0 | 0 |
| 5 | A7 | A6 | A5 | 1 | 0 | 1 | 0 | 0 |
| 4 | A7 | A6 | A5 | 1 | 0 | 0 | 0 | 0 |
| 3 | A7 | A6 | A5 | 0 | 1 | 1 | 0 | 0 |
| 2 | A7 | A6 | A5 | 0 | 1 | 0 | 0 | 0 |
| 1 | A7 | A6 | A5 | 0 | 0 | 1 | 0 | 0 |
| 0 | $A 7$ | $A 6$ | $A 5$ | 0 | 0 | 0 | 0 | 0 |


| IR | Interval $=8$ |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---: |
|  | D7 | D6 | $D 5$ | $D 4$ | $D 3$ | $D 2$ | $D 1$ | $D 0$ |  |
| 7 | $A 7$ | $A 6$ | 1 | 1 | 1 | 0 | 0 | 0 |  |
| 6 | $A 7$ | $A 6$ | 1 | 1 | 0 | 0 | 0 | 0 |  |
| 5 | $A 7$ | $A 6$ | 1 | 0 | 1 | 0 | 0 | 0 |  |
| 4 | $A 7$ | $A 6$ | 1 | 0 | 0 | 0 | 0 | 0 |  |
| 3 | $A 7$ | $A 6$ | 0 | 1 | 1 | 0 | 0 | 0 |  |
| 2 | $A 7$ | $A 6$ | 0 | 1 | 0 | 0 | 0 | 0 |  |
| 1 | $A 7$ | $A 6$ | 0 | 0 | 1 | 0 | 0 | 0 |  |
| 0 | $A 7$ | $A 6$ | 0 | 0 | 0 | 0 | 0 | 0 |  |

The higher address of the interrupt service routine programmed by the second byte (A8 ~A15) of the initialization sequence is released to the data bus.

Contents of the third interrupt vector byte

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 |

## 86 Mode (80C86/88)

Apart from the two interrupt acknowledge cycles and the absence of a CALL operation code, the 86 mode is the same as the 85 mode. The first INTA cycle freezes interrupt status to resolve the priority internally in the same way as in 85 mode. When the device is used as a master, an interrupt code is issued to the cascade line at the end of the INTA pulse. During this first cycle, the data bus buffer is kept at high impedance without any data to the CPU. During the second $\overline{I N T A}$ cycle, the 82C59A sends a byte of interrupt code to the CPU. Note that in 86 mode, the Address Interval (ADI) control status is ignored and A5 $\sim$ A10 is not used.

Contents of interrupt vector byte in 86 system mode

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IR7 | T7 | T6 | T5 | T4 | T3 | 1 | 1 | 1 |
| IR6 | T7 | T6 | T5 | T4 | T3 | 1 | 1 | 0 |
| IR5 | T7 | T6 | T5 | T4 | T3 | 1 | 0 | 1 |
| IR4 | T7 | T6 | T5 | T4 | T3 | 1 | 0 | 0 |
| IR3 | T7 | T6 | T5 | T4 | T3 | 0 | 1 | 1 |
| IR2 | T7 | T6 | T5 | T4 | T3 | 0 | 1 | 0 |
| IR1 | T7 | T6 | T5 | T4 | T3 | 0 | 0 | 1 |
| IR0 | T7 | T6 | T5 | T4 | T3 | 0 | 0 | 0 |

(4) Programming the 82C59A

The 82C59A receives two types of command words generaed by the CPU.
(i) Initialization Command Words (ICW1 thru ICW4)
Before commencing normal operations, each 82C59A in the system must be initialized by two to four $\overline{W R}$ pulse sequence.

(ii) Operation Command Words (OCW1 thru OCW3)
These commands are used in operating the 82C59A in the following modes.
a. Fully Nested Mode
b. Rotating Priority Mode
c. Special Mask Mode
d. Polled Mode

The OCW can be written into the 82C59A any time after initialization has been completed.
(5) Initialization Command Words (ICW1 thru ICW4)

When a command is issued with D4 = 1 and AO
$=0$, it is always regarded as an Initialization Command Word 1 (ICW1). Starting of the initialization sequence by ICW1 results in auțomatic execution of the following steps.
a. The edge sense circuit is reset, and a low to high transition is necessary to generate an interrupt.
b. The interrupt mask register is cleared.
c. The IR7 input is assigned priority 7 (lowest priority)
d. Slave mode address is set to 7.
e. The Special Mask Mode is cleared, and the Status Read is set to IRR.
f. All ICW4 functions are cleared if IC4 $=0$, resulting in a change to Non-Buffered mode, no-Auto EOI, and 85 mode.

Note: Master/slave in ICW4 can only be used in buffered mode.
(i) Initialization Command Words 1 and 2 (ICW1 and ICW2) A4 thru (Starting address of interrupt A15: service routines)

In 85 mode, 8 request levels CALL 8 locations at equivalent intervals in the memory. The memory location interval can be set at this stage to 4 or 8 by program. $(\rightarrow$ ADI) Hence, either 32 or 64 bytes/page respectively are used in the 8 routines.
The address format is 2 bytes long (AO thru A15). When the routine interval is 4, A0 thru A4 is inserted automatically by the 82C59A, and A5 thru A15 is programmed externally. When the interval is 8 , on the other hand, AO thru A5 are inserted automatically by the 82C59A, and A6 thru A15 are programmed externally. In 86 mode, T3 thru T7 are inserted in the 5 most significant bits of the vector type, and the 82C59A sets the 3 least significant bits according to the interrupt level. A0 thru A10 are ignored, and the ADI (address interval) has no effect.

LTIM: The 82C59A is operated in level triggered mode when LTIM $=1$, and the interrupt input edge circuit becomes disabled.
ADI: Designation of the CALL address interval. Interval $=4$ when $A D I=1$, and interval $=8$ when $A D I=0$.
SNGL: $\quad$ SNGL $=1$ indicates the existence of only one 82C59A in the system. ICW3 is not required when SNGL $=1$.
IC4: ICW4 is required when this bit is set, but not required when IC4 $=0$.
(ii) Initialization Command Word 3 (ICW3)

This command word is written when there is more than one 82C59A used in cascade connections in the system, and is loaded into an 8 -bit slave register. The functions of this slave register are listed below.
a. In a master mode system (BUF = 1 and $\mathrm{M} /$
$S=1$ in ICW4 or $\overline{S P} / \overline{E N}=1$ ). " 1 " is set in each bit where a slave has been connected.
In 85 mode, the master 82C59A releases byte 1 of the CALL sequence to enable the corresponding slave to release byte 2 or 3 (only byte 2 in 86 mode) through the cascade line.
b. In slave $\operatorname{mode}(B U F=1$ and $M / S=0$ in ICW4 or $\overline{S P} / \overline{E N}=0$ ). Bits 0 thru 2 identify the slave. The slave compares these bits with the cascade input, and releases bytes 2 and 3 of the CALL sequence (only byte 2 in 86 mode) if a matching result is obtained.
(iii) Initialization Command Word 4 (ICW4)

SFNM: Special Fully Nested Mode is programmed when SFNM $=1$.
BUF: Buffered mode is programmed when BUF $=1$. In Buffered mode, $\overline{S P} / \overline{E N}$ is an output, and Master/ slave is selected by the M/S bit.
M/S: If buffered mode is selected, the 82C59A is programmed as the master when $M / S=1$, and as a slave when $M / S=0 . M / S$ is ignored, however, when BUF $=0$.
AEOI: Automatic End Of Interrupt mode is programmed by AEOI $=1$.
$\mu$ PM: (Microprocessor mode)
The 82C59A is set to 85 system operation when $\mu \mathrm{PM}=0$, and to 86 system operation when $\mu \mathrm{PM}=1$.


| ICW3 |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (slave) | A0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| 1 | 0 | 0 | 0 | 0 | 0 | ID2 | ID1 | ID0 |  |

Slave ID

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |

Note: Slave ID indicates the IR input of the corresponding master.

ICW4

| A0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 | SFNM | BUF | M/S | AEOI | $\mu$ PM |


| 0 | $x$ | Non-buffered mode |
| :---: | :---: | :--- |
| 1 | 0 | Buffered mode (slave) |
| 1 | 1 | Buffered mode (master) |

1: 86 mode
0: 85 mode
1: Automatic EOI mode 0: Normal EOI mode

Note: X denotes not specified

1: Special Fully Nested mode O: Not Special Fully Nested mode

[^6](6) Operation Command Words (OCW1 thru OCW3) When Initialization Command Words (ICW) are programmed in the 82C59A, the interrupt input line is ready to receive interrupt requests. The Operation Command Words (OCWs) enable the 82C59A to be operated in various modes while the device is in operation.
(i) Operation Command Word 1 (OCW1)

OCW1 sets and resets the mask bits of the Interrupt Mask Register (IMR). M0 thru M7 represent 8 mask bits. The channel is masked when $M=1$, but is enabled when $\mathrm{M}=0$.
(ii) Operation Command Word 2 (OCW2)

R, SL, The Priority Rotation and the End EOI: of Interrupt mode plus combinations of the two are controlled by combinations of these 3 bits. These
combinations are listed in the operation command word format table.
L2, Li, These bits indicate the specified LO: interrupt level when $\mathrm{SL}=1$.
(iii) Operation Command Word 3 (OCW3)

ESMM: This enables the Special Mask Mode. The special mask mode can be set and reset by the SMM bit when $E S M M=1$. The SMM bit is ignored when ESMM $=0$.
SMM: (Special Mask Mode)
The 82C59A is set to Special Mask Mode when ESMM = 1 and SMM = 1 , and is returned to normal mask mode when ESMM $=1$ and $S M M=$ 0 . $S M M$ is ignored when $E S M M=0$.


OCW2 | AO | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | R | SL | EO1 | 0 | 0 | L2 | L1 | L0 |



| 0 | 0 | 1 | Non-Specific EOI command | End of Interrupt |
| :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 1 | Specific EOI command (Note) |  |
| 1 | 0 | 1 | Rotate on Non-Specific EOI command | Automatic Rotation |
| 1 | 0 | 0 | Rotate in Automatic EOI mode (set) |  |
| 0 | 0 | 0 | Rotate in Automatic EOI mode (clear) |  |
| 1 | 1 | 1 | Rotate on Specific EOI command (Note) | Specific Rotation |
| 1 | 1 | 0 | Set Priority command |  |
| 0 | 1 | 0 | No operation |  |

Note: LO thru L2 used.


Operation Command Words (OCW1 thru OCW3)

## (7) Fully Nested Mode

As long as the 82C59A has not been programmed to another mode, this Fully Nested mode is set automatically after initialization. The interrupt requests are ordered in priority sequentially from 0 to $\mathbf{7}$ (where 0 represents highest priority). If an interrupt is then requested and is acknowledged highest priority, a corresponding vector address is released, and the corresponding bit in the in-service register (ISR) is set. The IS bit remains set until an End of Interrupt (EOI) command is issued from the microprocessor before returning from the interrupt service routine, or until the rising edge of the last INTA pulse arrives when the AEOI bit has been set.
When the IS bit is set, interrupts of the same or lower priority are inhibited - only interrupts of higher priority can be generated. In this case, interrupts can be ackowledged only when the internal interrupt enable $F / F$ in the microprocessor has been enabled again through software. Following the initialization sequence, IRO has the highest priority, and IR7 has the lowest. This priority can be changed by rotating priority mode in OCW2.
(8) End of Interrupt (EOI)

When the AEOI bit in ICW4 is set, the in-service (IS) bit is automatically reset by the rising edge of the last INTA pulse, or else is reset only when an EOI command is issued to the 82C59A prior to returning from the interrupt service routine.
And in cascade mode, the EOI command must be issued twice - once for the master, and once for the corresponding slave.
EOI commands are classified into specific EOI commands and Non-Specific EOI commands. When the 82C59A is operated in Fully Nested mode, the IS bit to be reset can be determined on EOI. If the Non-Specific EOI command is issued, the highest IS bit of those that are set is reset automatically, because the highest IS level is always the last servicing level in the Fully Nested mode. If, however, it is not in the fully Nested mode, the 82C59A will no longer be able to determine the last acknowledged level. In this case, it will be necessary to issue a Specific EOI which includes the IS level to be reset as part of the command. When the 82C59A is in Special Mask mode, care must be taken to ensure that IS bits masked by the IMR bit can not reset by the Non-Specific EOI.

## (9) Automatic End of Interrupt (AEOI) Mode

When AEOI = 1 in ICW4, the 82C59A continues to operate in AEOI mode until programmed again by ICW4. In this mode, the 82C59A automatically performs Non-Specific EOI operation at the rising edge of the last INTA pulse (the third pulse in 85 systems, and the second pulse in 86 systems). In terms of systems, this mode is best used in nested multiple level interrupt configurations. It is not necessary when there is only one 82C59A. AEOI mode is only used in a master 82C59A device, not in a slave.
(10) Automatic Rotation (Devices with Equal Priority) In some applications, there is often a number of devices with equal priority. In this mode, the device where an interrupt service has just been completed is set to the lowest priority. At worst, therefore, a particular interrupt request device may have to wait for seven other devices to be serviced at least once each. There are two methods for Automatic Rotation using OCW2 - Rotation on Non-Specific EOI command, and Rotation in Automatic EOI mode.

Before Rotation (IR4 the highest priority requesting service)


After Rotation (IR4 was serviced, all other priorities rotated correspondingly)


## (11) Specific Rotation (Specific Priority)

All priority levels can be changed by programming the lowest priority level (Set Priority Command in OCW2). For example, if IR5 is programmed as the device of lowest priority, IR6 will have the highest priority. In this mode, the internal status can be updated during OCW2 by software control. This is unrelated, however, to the EOI command in the same OCW2.
Priority level can also be changed by using the OCW2 Rotate On Specific EOI command.

## (12) Interrupt Mask

Interrupt inputs can be masked individually by Interrupt Mask Registers (IMR) programmed through the OCW1. Each interrupt channel is masked (disabled) when the respective IMR bit is set to " 1 ". IRO is masked by bit 0 , and IR1 is masked by bit 1. Masking of any particular channel has no effect on other channels.

## (13) Special Mask Mode

In some applications, there is a need for dynamic updating of the system's priority level structure by software control during execution of an interrupt service routine. For example, it may be necessary to inhibit the lower priority requests for part of the execution of a certain routine while enabling for another part. In this case, it is difficult to enable all lower priority requests if the IS bit has not yet been reset by the EOI command after an interrupt request has been acknowledged (during execution of a service routine). All of these requests would normally be disabled.
Hence the use of the Special Mask mode. When a mask bit is set by OCW1 in this mode, the corresponding interrupt level requests are disabled. And all other unmasked level requests (at both higher and lower priority levels) are enabled. Interrupts can thus be enabled selectively by loading the mask register.
In this mode, the specific EOI Command should be used.
This Special Mask mode is set by OCW3 ESMM = 1 and $S M M=1$, and reset by $E S M M=1$ and $S M M=$ 0.

## (14) POLL Command

In this mode, the INT output in not used, the internal interrupt enable F/F of the microprocessor is reset, and interrupt inputs are disabled. Servicing the I/O device is executed by software using the Poll command.
The Poll command is issued by setting $P$ in OCW3 to " 1 ". The 82C59A regards the next $\overline{R D}$ puise as reception of an interrupt, and if there is a request, the corresponding IS bit is set and the priority level is read out. Interrupts are frozen between $\overline{W R}$ and $\overline{\mathrm{RD}}$.

Poll word

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 | 0 | W2 | W1 | W0 |

W0 thru W2: Binary coded highest priority level of service being requested.
1: Set to " 1 " when there is an interrupt.
This mode is useful when there is a common routine for a number of levels, and the INTA sequence is not required. ROM space can thus be saved.
(15) Reading 82C59A Status

The status of a number of internal registers can be read out for updating user information on the system. The following registers can be read by means of OCW3 (IRR and ISR) and OCW1 (IMR).
a. IRR: (Interrupt Request Register) 8-bit register for storing interrupt requesting levels.
b. ISR: (In-Service Register) 8-bit register for storing priority levels being serviced.
c. IMR: (Interrupt Mask Register) 8-bit register for storing interrupt request lines to be masked.
The IRR can be read when a Read Register Command is issued with OCW3 (RR = 1 and RIS = 0) prior to the $\overline{R D}$ pulse, and the ISR can be read when a Read Register Command is issued with OCW3 (RR = 1 and RIS = 1) prior to the $\overline{R D}$ pulse. And as long as the read status does not change, OCW3 is not required each time before the status is read. This is because the 82C59A remembers whether IRR or ISR was selected by the previous OCW3. But this is not true when poll is used.
The 82C59A is set to IRR after initialization. OCW3 is not required to read IMR. IMR is issued to the data bus if $\overline{R D}=0$ and $A 0=1$ (OCW1).
Reading status is disabled by polling when $P=1$ and $R R=1$ in OCW3.
(16) Edge and Level Trigger Mode

This mode is programmed by using bit 3 (LTIM) in ICW1. When LTIM $=0$, the interrupt request is recognized by the IR input transition from Low to High. As long as the IR input is kept at High, no other interrupt is generated. Since interrupt requests are recognized by the IR input " H ' level when LTIM $=1$, edge detection is not required.
The interrupt request must be cancelled before output of the EOI command, and before the interrupt is enabled in order to prevent the generation of a second interrupt by the CPU.
The IR input must be held at High level until the falling edge of the first INTA pulse, irrespective of whether edge sense or level sense is employed. If the IR input is switched to Low level before the first INTA pulse, the default IR7 is generated when the interrupt is acknowledged by the CPU. This can be an effective safeguard to be adopted to detect interrupts generated by the noise glitches on the IR inputs. To take advantage of this feature, the IR7 routine is used as a "clean up" routine where the routine is simply executing a return instruction and the interrupt is subsequently ignored. When the IR7 is required for other purposes, the default IR7 can be detected by reading the ISR. Although correct IR7 interrupts involve setting of the corresponding ISR bit, the default IR7 is not set.


## (17) Special Fully Nested Mode

This mode is used in large systems where the cascade mode is used and the respective Interrupt Requests within each slave have to be given priority levels. In this case, the Special Fully Nested mode is programmed to the master by using ICW4. This mode is practically identical to the normal Fully Nested mode, but differs in the following two respects.
a. When an interrupt request is received from a particular slave during servicing, a new interrupt request from an IR with a higher priority level than the interrupt level of the slave being serviced is recognized by the master and the interrupt is applied to the processor without the master priority logic being inhibited by the slave. In normal Fully Nested mode, if the request is in service, a slave is masked and no other requests can be recognized from the same slave.
b. When exiting from an interrupt service routine, it is first necessary to check whether or not the interrupt which has just been serviced by software was the only interrupt from that slave. This is done by sending a Non-Specific EOI command to that slave, followed by reading of the In-Service Register (ISR) to see whether that register has become all ' 0 '. A Non-Specific EOI is sent to the master too if the ISR is empty, and if not no EOI should be sent.
(18) Buffered Mode

Control for buffer enabling is required when the 82C59A is used in a large system where a data bus drive buffer is needed and cascade mode is used. When buffered mode is selected, the 82C59A sends an enable signal on the $\overline{S P} / \overline{E N}$ pin to enable the buffer. In this mode, the $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ output always becomes active while the 82C59A's data bus output is enabled. Therefore, the 82C59A requires programming to enable it to distinguish master from slave. Buffered mode is programmed by bit 3 in ICW4, and the ability to distinguish master from slave is programmed by bit 2 in ICW4.
(19) Cascade Mode

To enable the 82C59A to handle up to 64 priority levels, a maximum of 8 slaves can be easily connected to one master device.
The master controls the slaves through three cascade lines, the cascade bus executes like a slave chip select during the INTA sequence.
In cascade configuration, slave interrupt outputs (INT) are connected to master interrupt request inputs (IR). When a slave IR becomes active and is acknowledged, the master enables the corresponding slave to release the routine address for that device during bytes 2 and 3 (only byte 2 in 86 mode) of the INTA sequence.
The cascade bus line is normally kept at low level, and holds the slave address during the period from the rising edge of the first INTA pulse up to the rising edge of the third INTA pulse (or the second INTA pulse in 86 mode).
Each 82C59A device in the system can operate in different modes in accordance with their initialization sequences. EOI commands must be issued twice, once for the master once for the corresponding slave. Each 82C59A requires an address decoder to activate the respective chip select (CS) inputs.
Since the cascade line is normally kept at low level, note that slaves must be connected to the master IRO only after all slaves have been connected to the other IRs.


## Precautions for operation

Contents: In the case of a cascade edge trigger, the low level width (TILIH) of a slave INT signal may be less than the low level width (TJLJH:100 nS min.) of a master IR input signal.
This occurs when an interruption request with high order priority is provided to the slave unit before the INTA cycle ends. Fig. 1 shows a system configuration, Fig. 2 a bug operation timing chart, and Fig. 3 a normal operation timing chart. TILIH is not specified.


Fig. 1 System configuration


Fig. 2 Bug operation timing chart


Fig. 3 Normal operation timing chart

# OKXI semiconductor <br> MSM82C84A-2RS/GS/JS 

CLOCK GENERATOR AND DRIVER

## GENERAL DESCRIPTION

The MSM82C84A-2RS/GS is a clock generator designed to generate MSM80C86 and MSM80C88 system clocks.
Due to the use of silicon gate CMOS technology, standby current is only $40 \mu \mathrm{~A}$ (MAX.), and the power consumption is very low with 16 mA (MAX.) when a 8 MHz clock is generated.

## FEATURES

- Operating frequency of 6 to 24 MHz (CLK output 2 - Built-in synchronized circuit for MSM80C86 and to 8 MHz )
- $3 \mu$ silicon gate CMOS technology for low power consumption MSM80C88 READY and RESET
- TTL compatible
- Built-in Schmitt trigger circuit ( $\overline{R E S}$ input)
- 18 pin Plastic DIP (DIP18-P-300)
- $3 \mathrm{~V} \sim 6 \mathrm{~V}$ single power supply
- 20 pin PLCC (QFJ20-P-S350)
- 24 pin-V Plastic SOP (SOP24-P-430-VK)

FUNCTIONAL BLOCK DIAGRAM


PIN CONFIGURATION


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Limits |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MSM82C84A-2RS/JS | MSM82C84A-2GS |  |  |
| Supply Voltage | $V_{\text {CC }}$ | $-0.5 \sim+7$ |  | V |  |
| Input Voltage | $V$ IN | $-0.5 \sim V_{\mathrm{CC}}+0.5$ |  | V | Respect to GND |
| Output Voltage | VOUT | $-0.5 \sim V_{\mathrm{CC}}+0.5$ |  | $\checkmark$ |  |
| Storage Temperature | Tstg | $-55 \sim+150$ |  | ${ }^{\circ} \mathrm{C}$ | - |
| Power Dissipation | PD | 0.8 | 0.7 | W | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ |

## OPERATING RANGES

| Parameter | Symbol | Limits | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | V $_{\text {CC }}$ | $3 \sim 6$ | V |
| Operating Temperature | T'OP $^{\prime}$ | $-40 \sim+85$ | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | MIN | TYP | MAX | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5 | 5.5 | $V$ |
| Operating Temperature | TOP | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| "L" Level Input Voltage | VIL | -0.5 |  | +0.8 | V |
| "H" Level Input Voltage (except $\overline{\mathrm{RES}}$ ) | VIH | 2.2 |  | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |
| "'H' Level Input Voltage ( $\overline{\mathrm{RES}}$ ) |  | $0.6{ }^{*} V_{\text {CC }}$ |  |  |  |

## DC CHARACTERISTICS <br> $$
\left(V_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{Ta}=-40 \sim 85^{\circ} \mathrm{C}\right)
$$

| Parameter | Symbol | MIN | MAX | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| "'L" Level Output Voltage (CLK) | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}$ |
| "L'" Level Output Voltage (OTHERS) | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $1 \mathrm{OL}=2.5 \mathrm{~mA}$ |
| " H " Level Output Voltage (CLK) | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{CC}}-0.4$ | - | V | $1 \mathrm{OH}=-4 \mathrm{~mA}$ |
| " H " Level Output Voltage (OTHERS) | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{CC}}-0.4$ |  | V | $\mathrm{IOH}^{\prime}=-1 \mathrm{~mA}$ |
| $\overline{\mathrm{RES}}$ Input Hysteresis | $\begin{aligned} & V_{I H R} \\ & -V_{I L R} \end{aligned}$ | $0.2{ }^{*} V_{\text {cc }}$ |  | V |  |
| Input Leak Current (EXCEPT $\overline{\text { ASYNC }}$ ) | ${ }^{\prime} \mathrm{LI}$ | -1 | +1 | $\mu \mathrm{A}$ | $0 \leq \mathrm{V}_{\text {in }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| Input Current ( $\overline{\text { ASYNC }}$ ) | ILIA. | -100 | +10 | $\mu \mathrm{A}$ | $0 \leq \mathrm{V}_{\text {in }} \leq \mathrm{V}_{\text {cc }}$ |
| Standby Supply Current | I'cs |  | 40 | $\mu \mathrm{A}$ | NOTE 1 |
| Operating Supply Current | ${ }^{\prime} \mathrm{CC}$ |  | 16 | mA | $f=24 \mathrm{MHz}, \mathrm{C}_{\mathrm{L}}=\mathrm{O}_{\mathrm{pF}}$ |
| Input Capacitance | $\mathrm{C}_{\text {in }}$ |  | 7 | pF | $\mathrm{f}=1 \mathrm{MHz}$ |

NOTE 1: $\mathrm{X}_{1} \geqq \mathrm{~V}_{\mathrm{CC}}-0.2 \mathrm{~V}, \mathrm{X} 2 \leqq 0,2 \mathrm{~V}$
$F / \overline{\mathrm{C}} \geqq \mathrm{V}_{\mathrm{CC}}-0.2 \mathrm{~V}, \overline{\mathrm{ASYNC}}=V_{C C}$ or open
$\mathrm{VIH} \geqq \mathrm{V} \mathrm{CC}-0.2 \mathrm{~V}, \mathrm{VIL} \leq 0,2 \mathrm{~V}$

## AC CHARACTERISTICS

( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{Ta}=-40 \sim 85^{\circ} \mathrm{C}$ )
(1)

| Parameter | Symbol | MIN | MAX | Unit | Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EFI "H' Pulse Width | tehel | 13 |  | ns | 90\%-90\% | Output load capacitance CLK output $C_{L}=100 \mathrm{pF}$ Others 30pF |
| EFI "L" Pulse Width | ${ }^{\text {t ELEH }}$ | 17 |  | ns | 10\%-10\% |  |
| EFI Cycle Time | ${ }^{\text {t ELEL }}$ | 36 |  | ns |  |  |
| Crystal Oscillator Frequency |  | 6 | 24 | MHz |  |  |
| Set Up Time of RDY1 or RDY2 to CLK Falling Edge (Active) | tR1VCL | 35 |  | ns | $\begin{gathered} \overline{\text { ASYNC }} \\ =\text { High } \end{gathered}$ |  |
| Set Up Time of RDY1 or RDY2 to CLK Rising Edge (Active) | ${ }^{\text {t } R 1 V C H ~}$ | 35 |  | ns | $\begin{aligned} & \overline{\text { ASYNC }} \\ & =\text { Low } \end{aligned}$ |  |
| Set Up Time of RDY1 or RDY2 to CLK Falling Edge (Inactive) | tr1VCL | 35 |  | ns |  |  |
| Hold Time of RDY1 or RDY2 to CLK Falling Edge | ${ }^{\text {t CLR }} 1 \times$ | 0 |  | ns |  |  |
| Set Up Time of $\overline{\text { ASYNC }}$ to CLK Falling Edge | ${ }^{t} \mathrm{~A} Y \mathrm{VCL}$ | 50 |  | ns |  |  |
| Hold Time of $\overline{\text { ASYNC }}$ to CLK Falling Edge | ${ }^{\text {t CLA }}$ Y | 0 |  | ns |  |  |
| Set Up Time of $\overline{\text { AEN1 }}$ ( $\overline{\text { AEN2 }}$ ) to RDY1 (RDY2) Rising Edge | ${ }^{\text {t }}$ A1.R1V | 15 |  | ns |  |  |
| Hold Time of $\overline{\text { AEN1 }}$ ( $\overline{\text { AEN2 }}$ ) to CLK Falling Edge | ${ }^{\text {t CLA }}$ ( X | 0 |  | ns |  |  |
| Set Up Time of CSYNC to EFI Rising Edge | tYHEH | 20 |  | ns |  |  |
| Hold Time of CSYNC to EFI Rising Edge | ${ }^{\text {tEHYL}}$ | 10 |  | ns |  |  |
| CSYNC Pulse Width | ${ }^{\text {t Y HYL }}$ | $2 \times \mathrm{tELEL}$ |  | ns |  |  |
| Set Up Time of $\overline{\text { RES }}$ to CLK Falling Edge | $\mathrm{t}_{11 \mathrm{HCL}}$ | 65 |  | ns |  |  |
| Hold Time of $\overline{\text { RES }}$ to CLK Falling Edge | ${ }^{\text {t CLII }}$ H | 20 |  | ns |  |  |
| Input Rising Edge Time | tILIH |  | 15 | ns |  |  |
| Input Falling Edge Time | tIHIL |  | 15 | ns |  |  |

Note: Parameters where timing has not been indicated in the above table are measured at $V_{L}=1.5 \mathrm{~V}$ and $V_{H}=1.5 \mathrm{~V}$ for both inputs and outputs.

## AC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{Ta}=-40 \sim 85^{\circ} \mathrm{C}\right)$
(2)

| Parameter | Symbol | MIN | MAX | Unit | Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CLK Cycle Time | ${ }^{\text {t CLCL }}$ | 125 |  | ns |  | Output load capacitance CLK output $C_{L}=100 \mathrm{pF}$ Others 30pF |
| CLK " $\mathrm{H}^{\prime}$ P Pulse Width | ${ }^{\text {t }} \mathrm{CHCL}$ | $\frac{1}{3} \mathrm{~T}_{\text {CLCL }}+2$ |  | ns |  |  |
| CLK "L" Pulse Width | ${ }^{\text {t CLCH }}$ | $\frac{2}{3} \mathrm{~T}_{\text {CLCL }}-15$ |  | ns |  |  |
| CLK Rising and Falling Edge Times | ${ }^{\mathrm{t}} \mathrm{CH}_{1 \mathrm{CH}} 2$ <br> ${ }^{\text {t CL2CL1 }}$ |  | 10 | ns | 1.0V-3.5V |  |
| PCLK " ${ }^{\prime \prime}$ " Pulse W.idth | tPHPL | TCLCL - 20 |  | ns |  |  |
| PCLK "L" Pulse Width | tPLPH | TCLCL-20 |  | ns |  |  |
| Time from READY Falling Edge to CLK Falling Edge | $\mathrm{t}_{\text {RYLCL }}$ | -8 |  | ns |  |  |
| Time from READY Rising Edge to CLK Rising Edge | ${ }^{\text {tryHCH }}$ | $\frac{2}{3} \mathrm{~T}_{\text {CLCL }}-15$ |  | ns |  |  |
| Delay from CLK Falling Edge to RESET Falling Edge | ${ }^{\text {t CLIL }}$ |  | 40 | ns |  |  |
| Delay from CLK Falling Edge to PCLK Rising Edge | ${ }^{\text {t CLPH }}$ |  | 22 | ns |  |  |
| Delay from CLK Falling Edge to PCLK Falling Edge | ${ }^{\text {t CLPL }}$ |  | 22 | ns |  |  |
| Delay from OSC Falling Edge to CLK Rising Edge | tolch | -5 | 22 | ns |  |  |
| Delay from OSC Falling Edge to CLK Falling Edge | tolcl | 2 | 35 | ns |  |  |
| Output Rising Edge Time (Except CLK) | toloh |  | 15 | ns | $0.8 \mathrm{~V} \sim 2.2 \mathrm{~V}$ |  |
| Output Falling Edge Time (Except CLK) | tohol |  | 15 | ns | 2.2V $\sim 0.8 \mathrm{~V}$ |  |

Note: Parameters where timing has not been indicated in the above table are measured at $\mathrm{V}_{\mathrm{L}}=1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{H}}=1.5 \mathrm{~V}$ for both inputs and outputs.

PIN DESCRIPTION

| Pin symbol | Name | Input/ output | Function |
| :---: | :---: | :---: | :---: |
| CSYNC | Clock synchronization singal | Input | Synchronizing signal for output of in-phase CLK signals when more than one MSM82C84A-2 is used. <br> The internal counter is reset when this signal is at high level, and a high level CLK output is generated. The internal counter is subseqently activated and a $33 \%$ duty CLK output is generated when this signal is switched to low level. <br> When this signal is used, external synchronization of EFI is necessary. When the internal oscillator is used, it is necessary for this pin to be kept to be low level. |
| PCLK | Peripheral clock output | Output | This peripheral circuit clock signal is output in a $50 \%$ duty cycle at a frequency half that of the clock signal. |
| $\begin{aligned} & \overline{\text { AEN1 }} \\ & \overline{\text { AEN2 }} \end{aligned}$ | Address enable signals | Input | The $\overline{\mathrm{AEN} 1}$ signal enables $\overline{\mathrm{RDY} 1}$, and the $\overline{\mathrm{AEN} 2}$ signal enables RDY2. The respective RDY inputs are activated when the level applied to these pins is low. <br> Although two separate inputs are used in multi-master systems, only the $\overline{A E N}$ which enables the RDY input to be used is to be switched to low level in the case of not using multi-master systems. |
| $\begin{aligned} & \text { RDY1 } \\ & \text { RDY2 } \end{aligned}$ | Bus ready signals | Input | Completion of data bus reading and writing by the device connected to the system data bus is indicated when one of these signals is switched to high level. <br> The relevant RDY input is enables only when the corresponding $\overline{\operatorname{AEN}}$ is at low level. |
| READY | Ready output | Output | This signal is obtained by synchronizing the bus ready signal with CLK. <br> This signal is output after guaranteeing the hold time for the CPU in phase with the RDY input. |
| CLK | Clock output | Output | This signal is the clock used by the CPU and peripheral devices connected to the CPU system data bus. The output waveform is generated in a $33 \%$ duty cycle at a frequency $1 / 3$ the oscillating frequency of the crystal oscillator connected to the X 1 and X 2 pins, or at a frequency $1 / 3$ the EFI input frequency. |
| $\overline{R E S}$ | Reset in | Input | This low-level active input is used to generate a CPU reset signal. Since a Schmitt trigger is included in the input circuit for this signal, '"power on resetting" can be achieved by connection of a simple RC circuit. |
| RESET | Reset output | Output | This signal is obtained by CLK synchronization of the input signal applied to $\overline{\mathrm{RES}}$ and is output in opposite phase to the $\overline{\mathrm{RES}}$ input. This signal is applied to the CPU as the system reset signal. |
| F/C | Clock select signal | Input | This signal selects the fundamental signal for generation of the CLK signal. The CLK is generated from the crystal oscillator output when this signal is at low level, and from the EFI input signal when at high level. |
| EFI | External clock signal | Input | The signal applied to this input pin generates the CLK signal when $\mathrm{F} / \overline{\mathrm{C}}$ is at high level. The frequency of the input signal needs to be three times greater than the desired CLK frequency. |
| x1, $\times 2$ | Crystal oscillator connecting pins | Input | Crystal oscillator connections. <br> The crystal oscillator frequency needs to be three times greater than the desired CLK frequency. |
| OSC | Crystal resonator output | Output | Crystal oscillator output. This output frequency is the same as the oscillating frequency of the oscillator connected to the X1 and X2 pins. As long as a $X$ tal oscillator is connected to the $X 1$ and $X 2$ pins, this output signal can be obtained independently even if $F / C$ is set to high level to enable the EFI input to be used for CLK generation purposes. |


| Pin symbol | Name | Input/ <br> output | Function |
| :---: | :---: | :---: | :--- |
| $\overline{\text { ASYNC }}$ | Ready <br> synchronization <br> select signal | Input | Signal for selection of the synchronization mode of the READY <br> signal generator circuit. When this signal is at low level, the READY <br> signal is generated by double synchronization. And When at high <br> level, the READY signal is generated by single synchronization. <br> This pin is equipped with internal pull-up resister. |
| VCC |  |  | +5V power supply |
| GND |  |  | GND |

## TIMING CHART

## CLK P PCLK • OSC waveforms



READY waveform ( $\overline{\text { ASYNC }}=\mathrm{L}$ )


READY waveform $(\overline{\operatorname{ASYNC}}=H)$


## DESCRIPTION OF OPERATION

## (1) Oscillator Circuit

The MSM82C84A-2 internal oscillator circuit can be driven by connecting a crystal oscillator to the $\times 1$ and $X 2$ pins.

The frequency of the crystal oscillator in this case needs to be three times greater than the desired CLK frequency.

Since the oscillator circuit output (the same output as for the crystal resonator frequency) appears at the OSC pin, independent use of this output is also possible.

## Recommended Oscillator Circuit



## (2) Clock Generator Circuit

This circuit generates two clock outputs-CLK obtained by dividing the input external clock or crystal oscillator circuit output by three, and PCLK obtained by halving CLK. CLK and PCLK are generated from the external clock applied to the EFI pin when F/C is at high level, and are generated from the crystal oscillator circuit when at low level.

## (3) Reset Circuit

Since a Schmitt trigger circuit is used in the $\overline{\text { RES }}$ input, the MSM82C84A-2 can be reset by "power on" by connection to a simple RC circuit. If the $80 C 86$ or 80 C 88 is used as the CPU in this case, it is necessary to keep the $\overline{\operatorname{RES}}$ input at low level for at least 50 ms after $\mathrm{V}_{\mathrm{CC}}$ reaches the 4.5 V level.
(4) Ready Circuit

The READY signal generator circuit can be set to synchronization mode by $\overline{\mathrm{ASYNC}}$.
(i) When $\overline{A S Y N C}$ is at low level

The RDY input is output as the READY signal by double synchronization.
The high-level RDY input is synchronized once by the rising edge of the CLK of the first stage flipflop (F1 in the circuit diagram), and then synchronized again by the falling edge of the CLK of the next stage flip-flop (F2 in the circuit diagram), resulting in output of a high-level READY output signal (see diagram below).

- The low-level RDY input is synchronized directly by the falling•edge of the CLK of the next stage flip-flop, resulting in output of a low-level READY output signal (see diagram below).

(ii) When $\overline{\text { ASYNC }}$ is at high level

The RDY input is output as the READY signal by single synchronization.

- Both low-level and high-level RDY inputs are
synchronized by the falling edge of the CLK of the next stage flip-flop, resulting in output of respective low-level and high-level READY output signals (see diagram below).



## EXAMPLE OF USE (CSYNC)

The 82C84A-2 $1 / 3$ frequency divider counter is unsettled when the power is switched on. Therefore, the CSYNC pin has been included to synchronize CLK with another signal. When CSYNC is at high level, both CLK and PCLK are high-level outputs. If CSYNC is then
switched to low level, CLK is output from the next input clock rising edge, and is divided by 3.

If CSYNC has not been synchronized with the input clock, use the following circuit to achieve the required synchronization


When an external clock EFI is used as the clock source


## OIKI semiconductor

MSM82C88-2RS/GS/JS

## BUS CONTROLLER

## GENERAL DESCRIPTION

The MSM82C88 is a bus controller for the MSM80C86 and the MSM80C88 CPUs. Based on silicon gate CMOS technology, a low-power 16 -bit microprocessor system can be realized.

The MSM82C88 generates commands contol timing signals on reception of status signals from the CPU.

## FEATURES

- Silicon gate CMOS technology for low power consumption
- 3 to 6 V wide voltage range and single power supply
- -40 to $85^{\circ} \mathrm{C}$ wide guaranteed operating temperature range
- Advanced write control output
- Three-state command output driver
- System bus mode \& I/O bus mode
- 20 pin Plastic Skinny DIP (DIP20-P-300-SI)
- 20 pin PLCC (QFJ20-P-S350)
- 24 pin Plastic SOP (SOP24-P)
- 24 pin-V Plastic SOP (SOP24-P-430-VK)


## CIRCUIT CONFIGURATION



## PIN CONFIGURATION



## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Conditions | Limits |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MSM82C88-2RS/JS | MSM82C88-2GS |  |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | With respect to GND | -0.5~+7 |  | V |
| Input Voltage | $V_{\text {IN }}$ |  | -0.5 ~ $\mathrm{V}_{\mathrm{CC}}+0.5$ |  | V |
| Output Voltage | VOUT |  | -0.5 ~ $\mathrm{V}_{\mathrm{CC}}+0.5$ |  | $\checkmark$ |
| Storage Temperature | Tstg | - | -55 ~ 150 |  | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | 0.7 | 0.7 | w |

## OPERATING RANGES

| Parameter | Symbol | Limits | Unit |
| :---: | :---: | :---: | :---: |
| Power Supply Voltage | $V_{\text {CC }}$ | $4.5 \sim 5.5$ | $\vee$ |
| Operating Temperature | TOP | $-40 \sim 85$ | ${ }^{\circ} \mathrm{C}$ |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5 | 5.5 | V |
| Operating Temperature | $\mathrm{TOP}_{\mathrm{OP}}$ | -40 | +25 | +85 | ${ }^{\circ} \mathrm{C}$ |
| "L" Input Voltage | $\mathrm{V}_{\text {IL1 }}$ | -0.3 | - | +0.8 | V |
| " H " Input Voltage | $\mathrm{V}_{\text {IH1 }}$ | 3.0 | - | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |
| "L" Input Voltage | $\mathrm{V}_{\text {IL2 }}$ | -0.3 | - | +0.8 | V |
| "H" Input Voltage | $\mathrm{V}_{\text {IH2 }}$ | 2.2 | - | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |

Note: $V_{I L 1}$ and $V_{I H 1}$ are input voltages for CLK, $\overline{s_{0}}, \overline{s_{1}}$, and $\overline{s_{2}}$.
$V_{\text {IL2 }}$ and $V_{1 H 2}$ are input voltages for $\overline{A E N}, C E N$, and IOB.

DC CHARACTERISTICS
$\left(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}\right.$ to $5.5 \mathrm{~V}, \mathrm{Ta}=-40^{\circ} \mathrm{C}$ to $\left.+85^{\circ} \mathrm{C}\right)$

| Parameter | Symboi | Conditions | Min. | Typ. | Max. | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 'L' Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | Command output $\mathrm{IOL}=20 \mathrm{~mA}$ | - | - | 0.5 | V |  |
|  |  | Control output $1 \mathrm{OL}=8 \mathrm{~mA}$ | - | - | 0.45 | V |  |
| 'H' Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | Command output $\mathrm{I}_{\mathrm{OH}}=-8 \mathrm{~mA}$ | 3.7 | - | - | V |  |
|  |  | Control output $\mathrm{I}_{\mathrm{OH}}=-4 \mathrm{~mA}$ | 3.7 | - | - | V |  |
| Input Leak Current | ILI | $0 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ | -10 | - | 10 | $\mu \mathrm{A}$ | Note 1 |
| Output Leak Current | ILO | $0 \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ | -10 | - | 10 | $\mu \mathrm{A}$ |  |
| Status Input Current | ILIS | $0 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ | -100 | - | 10 | $\mu \mathrm{A}$ | Note 2 |
| Operation Power Supply Current | I'cco | $\begin{aligned} C_{L} & =0 p F \\ { }^{C} C L C L & =200 \mathrm{~ns} \end{aligned}$ | - | - | 10 | mA |  |
| Standby Power Supply Current | I'css | Note 3 | - | - | 100 | $\mu \mathrm{A}$ |  |

Note 1. This input leak current is the leak current on input pins except status inputs ( $\bar{s}_{0}, \bar{s}_{1}$, and $\overline{s_{2}}$ ).
Note 2. The status input leak current is the leak current at the status inputs ( $\overline{s_{0}}, \overline{s_{1}}$, and $\overline{s_{2}}$ ).
Note 3. The measuring conditions for the standby power supply current include the $\overline{s_{0}}, \overline{s_{1}}$, and $\overline{s_{2}}$ status inputs being at $V_{\mathrm{CC}}$ potential, and the other inputs being at $\mathrm{V}_{\mathrm{CC}}$ or $G N D$. All output pins are left open.

## AC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}\right.$ to $5.5 \mathrm{~V}, \mathrm{Ta}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

## Timing conditions

| Parameter | Symbol | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Clock Cycle | ${ }^{t} \mathrm{CLCL}$ | 125 | - | nS |
| Clock Low Time | ${ }^{\mathrm{t}} \mathrm{CLCH}$ | 66 | - | nS |
| Clock High Time | ${ }^{\text {t }} \mathrm{CHCL}$ | 40 | - | nS |
| Status Active Setup Time | ${ }^{\text {t SVCH }}$ | 35 | - | nS |
| Status Inactive Hold Time | ${ }^{\text {t }} \mathrm{CHSV}$ | 10 | - | nS |
| Status Inactive Setup Time | ${ }^{\text {t }}$ SHCL | 35 | - | nS |
| Status Active Hold Time | ${ }^{\mathrm{t}} \mathrm{CLSH}$ | 10 | - | nS |

Timing response

| Parameter | Symbol | Min. | Max. | Unit | Test Circuit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Delay from CLK Leading Edge to DEN, PDEN Active | ${ }^{\text {t }} \mathrm{CVNV}$ | 5 | 45 | nS | 4 |  |
| Delay from CLK Trailing Edge to DEN, $\overline{\text { PDEN Inactive }}$ | ${ }^{\text {t CVN }}$ ( | 5 | 45 | nS | 4 |  |
| Delay from CLK Trailing to ALE Active | ${ }^{t} \mathrm{CLLH}$ | - | 25 | nS | 4 |  |
| Delay from CLK Trailing Edge to MCE Active | ${ }^{\text {t }} \mathrm{CLMMCH}$ | - | 25 | nS | 4 |  |
| Delay from Status Input Falling Edge to ALE Active | ${ }^{\text {t SVLH }}$ | - | 25 | nS | 4 |  |
| Delay from Status Input Falling Edge to MCE Active | ${ }^{\text {t }}$ SVMCH | - | 30 | nS | 4 |  |
| Delay from CLK Leading Edge to ALE Inactive | ${ }^{t} \mathrm{CHLL}$ | 4 | 25 | nS | 4 |  |
| Delay from CLK Trailing Edge to Command Output Active | ${ }^{\text {t }}$ CLML | 5 | 35 | nS | 3 |  |
| Delay from CLK Trailing Edge to Command Output Inactive | ${ }^{\text {t CLM }}$ | 5 | 45 | nS | 3 |  |
| Delay from CLK Leading Edge to DT/R Active | ${ }^{\text {t }}$ CHDTL | - | 50 | nS | 4 |  |
| Delay from CLK Leading Edge to DT/R Inactive | ${ }^{\text {t }}$ CHDTH | - | 30 | nS | 4 |  |
| Delay from $\overline{\text { AEN }}$ Leading Edge to Command Enable | ${ }^{\text {t }} \mathrm{AELCH}$ | - | 40 | nS | 2 |  |
| Delay from $\overline{A E N}$ Trailing Edge to Command Disable | ${ }^{\text {t AEHCZ }}$ | - | 40 | nS | 1 |  |
| Delay from $\overline{\text { AEN }}$ Leading Edge to Command Output Active | ${ }^{\text {t }}$ AELCV | 100 | 250 | nS | 3 |  |
| Delay from $\overline{\text { AEN }}$ to DEN | taEVNV | - | 35 | nS | 4 |  |
| Delay from CEN to DEN, PDEN | tcevnv | - | 35 | nS | 4 |  |
| Delay from CEN to Command Output | ${ }^{\text {t }}$ CELR ${ }^{\text {ch }}$ | - | ${ }^{\text {t }}$ CLML +10 | nS | 3 |  |
| Output Rise Time | ${ }^{\text {t }} \mathrm{OLOH}$ | - | 15 | nS | 3, 4 | From 0.8 V to 2.2 V |
| Output Fall Time | ${ }^{\text {toHOL }}$ | - | 15 | nS | 3,4 | From 2.2 V to 0.8 V |

Note: AC timing measurements are made at 1.5 V for both logic " 1 " and " 0 ". Input rise and fall times are
$5 \pm 2 \mathrm{nS}$ between 0.8 V and 2.2 V for $\overline{\mathrm{AEN}}, \mathrm{CEN}$ and IOB.
$8 \pm 2 \mathrm{nS}$ between 0.8 V and 3.0 V for $\overline{\mathrm{s}_{0}}, \overline{s_{1}}, \overline{s_{2}}$ and CLK.

## Test Circuit



| Test Circuit | $\mathrm{V}_{(\mathrm{V})}$ | $\mathrm{R}_{(\Omega)}$ | $\mathrm{C}_{(\mathrm{PF})}$ |
| :---: | :---: | :---: | :---: |
| 1 | 1.5 | 187 | 50 |
| 2 | 1.5 | 187 | 150 |
| 3 | 2.29 | 91 | 150 |
| 4 | 2.13 | 220 | 80 |

## TIME CHARTS



Note 1. The ADDRESS/DATA bus signal is shown for reference purposes.
Note 2. The ALE and MCE leading edges are synchronized with the falling edge of CLK or status going active, whichever occurs last.
Note 3. All timing measurements are made at 1.5 V unless specified otherwise.

DEN, $\overline{\text { PDEN }}$ Timing

$\overline{\text { AEN }}$ Timing


## PIN DESCRIPTION

| Pin Name | Input/output | Function |
| :---: | :---: | :---: |
| $\overline{s_{0}}, \overline{s_{1}}, \overline{s_{2}}$ | Input | These pins are input pins for status signals ( $\overline{s_{0}}, \overline{s_{1}}$, and $\overline{s_{2}}$ ), output from the CPU (MSM80C86, 80C88). The MSM82C88 generates commands and control signals after decoding these status signals. Since these pins are connected to an internal pull-up resistor, they are set to high level when the CPU status output is at high impedance. |
| CLK | Input | This pin is the input pin for clock signal output from the clock generator (MSM82C84A). The timing of all MSM82C88 output signals is controlled by this clock signal. |
| ALE | Output | Strobe signal for latching output address from the CPU to address latch. Address latching occurs on the trailing edge of ALE. |
| DEN | Output | Control signal for setting the data bus transceiver to data enable. The local bus or system bus transceiver is enabled when this signal is high. <br> DEN is switched to low when the CEN input is low. |
| DT/ $\bar{R}$ | Output | Control of the direction of data flow in the data bus transceiver. When the CPU is switched to write mode, this signal is high, and when switched to read mode, this signal is low. |
| $\overline{\text { AEN }}$ | Input | Address enable signal. <br> - IOB = L (SYSTEM BUS MODE) <br> When the $\overline{A E N}$ input is switched to high level, all command outputs are switched to high impedance status. <br> - $1 O B=H$ (I/O BUS MODE) <br> When the $\overline{A E N}$ input is switched to high level, only the MRDC, $\overline{M W T C}$, and $\overline{\text { AMWC }}$ command outputs are switched to high impedance status. <br> When $\overline{\mathrm{AEN}}$ is switched from high to low level, high impedance command outputs are not switched to active status (low level) for at least 90 nS , irrespective of the $I O B$ input status. |
| CEN | Input | Command enable signal. <br> All command outputs, DEN and $\overline{\text { PDEN }}$ outputs are switched to inactive status when a low level input is applied to CEN. All command outputs, DEN and PDEN outputs are switched to active status when a high level input is applied to CEN. |
| IOB | Input | I/O bus mode signal. <br> The MSM82C88 is switched to I/O bus mode when a high level input is applied to IOB, and to system bus mode when a low level input is applied. |
| IOWC | 3-state output | This pin is active-low, and three-state output. This signal is for writing data into the I/O device. |
| AIOWC | 3-state output | This pin is active-low and three-state output. Although this signal is also used for writing into I/O devices like the I/O write command (IOWC), it is made active one clock earlier than IOWC. |
| $\overline{\text { IORC }}$ | 3-state output | This pin is active-low and three-state output. This signal is for reading data from I/O devices. |
| $\overline{\text { MWTC }}$ | 3-state output | This pin is active-low and three-state output. This signal is for writing data into memory. |
| AMWC | 3-state output | This pin is active-low and three-state output. Although this signal is also used for writing into memory like the memory write command (MWTC), it is made active one cycle earlier than MWTC. |
| $\overline{\text { MRDC }}$ | 3-state output | This pin is active-low and three-state output. This signal is for reading data from memory. |
| $\overline{\text { INTA }}$ | 3-state output | This pin is active-low and three-state output. This signal informs the interrupt controller that the interrupt has been accepted, and then requests output of a vector address onto the data bus. |


| Pin Name | Input/output | Function |
| :---: | :---: | :--- |
| MCE/PDEN | Output | This pin has two functions. <br> MCE (IOB = Low) master cascade enable function. <br>  <br>  <br>  <br>  <br>  <br>  <br>  <br>  <br>  <br>  <br>  <br>  <br>  <br> this is an active-high signal and is used to enable a slave PIC (priority in- <br> the master PIC during an interrupt sequence. <br> PDEN (IOB = High) peripheral data enable function. <br> This is an active-low signal and is used to enable the data bus transceiver <br> on the I/O bus. |

## FUNCTION

## Command Logic

The command output is decided by decoding status signals ( $\overline{s_{0}}, \overline{s_{1}}, \overline{s_{2}}$ ) output from the CPU.

These status signals have the following meanings.

| $\overline{s_{2}}$ | $\overline{s_{1}}$ | $\overline{s_{0}}$ | CPU status | Command <br> output |
| :---: | :---: | :---: | :--- | :---: |
| 0 | 0 | 0 | Interrupt acknowledge | $\overline{\text { INTA }}$ |
| 0 | 0 | 1 | l/O read | $\overline{\text { IORC }}$ |
| 0 | 1 | 0 | l/O write | $\overline{\text { IOWC }, ~ \overline{A I O W C ~}}$ |
| 0 | 1 | 1 | Halt | - |
| 1 | 0 | 0 | Instruction fetch | $\overline{\text { MRDC }}$ |
| 1 | 0 | 1 | Memory read | $\overline{\text { MRDC }}$ |
| 1 | 1 | 0 | Memory write | $\overline{\text { MWTC }, \overline{\text { AMWC }}}$ |
| 1 | 1 | 1 | Passive | - |

## I/O Bus Mode (IOB = High $)$

When an 1/O access status signal is received from the CPU in I/O bus mode, one of the I/O commands ( $\overline{\text { ORCC }}, \overline{\text { IOWC }}, \overline{\text { AIOWC, }}, \overline{\text { INTA }}$ ) corresponding to the status signal becomes active irrespective of the $\overline{\mathrm{AEN}}$ status. At the same time, the $\overline{\mathrm{PDEN}}$ and $D T / \overline{\mathrm{R}}$ outputs which control the data bus transceiver are generated.

As in system bus mode, the memory commands ( $\overline{M R D C}, \overline{M W T C}$, and $\overline{A M W C}$ ) are not switched to low level for at least 90 ns after $\overline{\text { AEN }}$ is switched to low level.

## System Bus Mode (IOB = Low)

When the bus is usable, the MSM82C88 is enabled by the $\overline{A E N}$ signal from the bus arbiter. Conseuqnetly, no command output becomes active unless the $\overline{\text { AEN }}$ signal becomes low. Also note that there is a delay of at least 90 ns before any command output becomes active after the $\overline{\text { AEN }}$ signal is switched to low level.

System bus mode is used when more than one CPU is connected to a single bus, and the bus $1 / O$, memory, etc. are used in common.

## Command Outputs

The advanced write commands ( $\overline{\text { AIOWC }}$ and $\overline{\mathrm{AM} W \mathrm{C}}$ ) become active one cycle earlier than normal
write commands ( $\overline{\mathrm{OWC}}$ and $\overline{\mathrm{MWTC}}$ ). This prevents the CPU from being switched to an additional period of wait status.
$\overline{\text { INTA }}$ (interrupt acknowledge) is output during the interrupt acknowledge cycle in the same way as $\overline{M R D C}$ in the read cycle. The purpose of this signal is to inform the device which has requested the interrupt that the interrupt has been accepted, and requests a vector address output on the data bus.
$\overline{M R D C}$ - Memory read command
MWTC - Memory write command
$\overline{\text { IORC }}$ - I/O read command
$\overline{\text { IOWC }}$ - I/O write command
$\overline{\text { AMWC }}$ - Advanced memory write command
$\overline{\text { AIOWC }}$ - Advanced I/O write command
INTA - Interrupt acknowledge

## Control Output

The control output signals are DEN (Data Enable), $\mathrm{DT} / \overline{\mathrm{R}}$ (Transmit/Receive), and MCE/ $\overline{\text { PDEN }}$ (Master Cascade Enable/Peripheral Data Enable).

The DEN signal enables the local bus or system bus, when it is high.

The $\mathrm{DT} / \overline{\mathrm{R}}$ signal determines the direction of the data on the local bus or system bus.

The function of the MCE/PDEN pin is switched according to IOB. The PDEN function is selected in I/O bus mode (IOB = high) to provide the I/O or peripheral/ system bus data enable signal. When the MCE function is selected in system bus mode (IOB = low), the MCE signal is active (high) level at an interrupt acknowledge status.

The MCE signal is used when a master and slave interrupt controller exists in the system.

## ALE (Address Latch Enable)

ALE is generated in each machine cycle to latch the current address to the address latch.

## CEN (Command Enable)

This signal is used to enable command outputs. All command outputs become inactive if a low level input is applied to the CEN pin.


## OIEI semiconductor

## MSM5832RS

## REAL TIME CLOCK/CALENDAR

## GENERAL DESCRIPTION

The MSM5832RS is a metal-gate CMOS Real Time Clock/Calendar for use in bus-oriented microprocessor applications. The on-chip 32.768 Hz crystal controlled oscillator time base is divided to provide addressable 4-bit I/O data of SECONDS, MINUTES, HOURS, DAY-OF-WEEK, DATE, MONTH, and YEAR. Data access is controlled by 4-bit address, chip select, read, write and hold inputs. Other functions include $12 \mathrm{H} / 24 \mathrm{H}$ format selection, leap year identification and manual $\pm 30$ second correction.

The MSM5832RS normally operates from a $5 \mathrm{~V} \pm 5 \%$ supply. Battery backup operation down to 2.2 V allows continuation of time keeping when main power is off. The MSM5832RS is offered in an 18-lead dual-in-line plastic (RS suffix) package.

## FEATURES

- 7 Function - SECOND, MINUTE, HOUR, DAY, DAY-OF-WEEK, MONTH, YEAR
- Automatic leap year calendar
- 12 or 24 hour format
$\pm 30$ second error correction
- 4-BIT DATA BUS
-4-BIT ADDRESS
- READ, WRITE, HOLD, and CHIP SELECT inputs
- Reference signal outputs - 1024, 1, 1/60, $1 / 3600 \mathrm{~Hz}$
- 32.768 kHz crystal controlled operation
- Single 5V power supply
- Back-up battery operation to $V_{D D}=2.2 \mathrm{~V}$
- Low power dissipation
$90 \mu \mathrm{~W}$ Max. at $\mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V}$
2.5 mW Max. at $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$
- 18 pin plastic DIP (DIP18-P-300)

FUNCTIONAL BLOCK DIAGRAM


## PIN CONFIGURATION

| A0 to A3 | Address Inputs |
| :---: | :---: |
| WRITE | Write Enable |
| READ | Read Enable |
| HOLD | Count Hold |
| CS | Chip Select |
| D0 to D3 | Data Input Output |
| TEST | Test Input |
| $\pm 30$ ADJ | $\pm 30$ Second Correction Input |
| XT \& $\overline{\mathrm{XT}}$ | xtal oscillator connections |
| VDD | +5V Supply |
| GND | Ground |

18 pin Plastic DIP (Top View)


## REGISTER TABLE

| Address Input |  |  |  | Register Name | Data Input/Output |  |  |  | Data Limit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{A}_{0}$ | $\mathrm{A}_{1}$ | $\mathrm{A}_{2}$ | $\mathrm{A}_{3}$ |  | $\mathrm{D}_{0}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{3}$ |  |  |
| 0 | 0 | 0 | 0 | S1 | * | * | * | * | $0 \sim 9$ | S1 or S10 are reset to zero irrespective of input data D0-D3 when write instruction is executed with address selection. |
| 1 | 0 | 0 | 0 | S10 | * | * | * |  | $0 \sim 5$ |  |
| 0 | 1 | 0 | 0 | MI1 | * | * | * | * | $0 \sim 9$ |  |
| 1 | 1 | 0 | 0 | MI10 | * | * | * |  | $0 \sim 5$ |  |
| 0 | 0 | 1 | 0 | H1 | * | * | * | * | $0 \sim 9$ |  |
| 1 | 0 | 1 | 0 | H10 | * | * | $\dagger$ | $\dagger$ |  | $\begin{aligned} D 2=" 1 " \text { for PM D3 }= & " 1 " \text { for } \\ & 24 \text { hour format } \\ D 2=" 0 " \text { for AM D3 }= & " 0 " \text { for } \\ & 12 \text { hour format } \end{aligned}$ |
| 0 | 1 | 1 | 0 | W | * | * | * |  | $0 \sim 6$ |  |
| 1 | 1 | 1 | 0 | D1 | * | * | * | * | $0 \sim 9$ |  |
| 0 | 0 | 0 | 1 | D10 | * | * | $\dagger$ |  | $0 \sim 3$ | $\begin{align*} & \text { D2 }=\text { " } 1 \text { " for } 29 \text { days in month } 2 \\ & \text { D2 }=\text { " } 0 \text { " for } 28 \text { days in month } 2 \tag{2} \end{align*}$ |
| 1 | 0 | 0 | 1 | MO1 | * | * | * | * | $0 \sim 9$ |  |
| 0 | 1 | 0 | 1 | MO10 | * |  |  |  | $0 \sim 1$ |  |
| 1 | 1 | 0 | 1 | Y1 | * | * | * | * | $0 \sim 9$ |  |
| 0 | 0 | 1 | 1 | Y10 | * | * | * | * | $0 \sim 9$ |  |

(1) *data valid as " 0 " or "1".

Blank does not exist (unrecognized during a write and held at " 0 " during a read)
tdata bits used for AM/PM, 12/24 HOUR and leap year.
(2) If D2 previously set to "1", upon completion of month 2 day $29, \mathrm{D} 2$ will be internally reset to " 0 ".

## OSCILLATOR FREQUENCY DEVIATIONS

Frequency Deviation vs Temperature


Figure 1

Frequency Deviation vs Supply Voltage


Figure 2

## ABSOLUTE MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply voltage | $V_{D D}$ | $-0.3 \sim 7.0$ | V |
| Input voltage | $\mathrm{V}_{1}$ | $-0.3 \sim \mathrm{~V}_{\mathrm{DD}}+0.3$ | V |
| Data I/O voltage | $\mathrm{V}_{\mathrm{O}}$ | $-0.3 \sim \mathrm{~V}_{\mathrm{DD}}+0.3$ | V |
| Storage Temperature | Tstg | $-55 \sim 150$ | ${ }^{\circ} \mathrm{C}$ |

## OPERATING CONDITIONS

| Parameter | Symbol | Min. | Typ. | Max. | Unit | Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{DD}}$ | 4.5 | 5 | 7 | V |  |
| Standby Supply Voltage | $\mathrm{V}_{\mathrm{DH}}$ | 2.2 | - | 7 | V |  |
| Input Signal Level | $\mathrm{V}_{\mathrm{IH}}$ | 3.6 | - | $\mathrm{V}_{\mathrm{DD}}$ | V | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 5 \%$ |
|  |  |  |  |  |  |  |
|  | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | - | 0.8 | V |  |
| Operating Temperature | $\mathrm{f}(\mathrm{XT})$ | - | 32.768 | - | kHz |  |

## DC CHARACTERISTICS

$\left(V_{C C}=5 V \pm 5 \% ; T_{A}=-30\right.$ to $+85^{\circ} \mathrm{C}$ )

| Parameter | Symbol | Min. | Typ. | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input Current ${ }^{(1)}$ | $\mathrm{IIH}^{\text {H }}$ | 10 | 25 | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 \mathrm{~N}}=5 \mathrm{~V}, \mathrm{~V}_{\text {DD }}=5 \mathrm{~V}$ |
|  | ${ }_{1 / L}$ | - | - | -1 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0 V$ |
| Data I/O Leakage Current | ILD | -10 | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I / O}=0 \text { to } V_{D D} \\ & C S={ }^{\prime \prime \prime} \end{aligned}$ |
| Output Low Voltage | VOL | - | - | 0.4 | V | $\begin{aligned} & \mathrm{I} O=1.6 \mathrm{~mA}, \mathrm{CS}=" 1 ", \\ & \mathrm{READ}=" 1 " \end{aligned}$ |
| Output Low Current | ${ }^{\prime} \mathrm{OL}$ | 1.6 | - | - | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}, \mathrm{CS}=" 1 ", \\ & \text { READ }=" 1 " \end{aligned}$ |
| Operating Supply Current | IDDS | - | 15 | 30 | $\mu \mathrm{A}$ | $V_{C C}=3 \mathrm{~V}, \mathrm{Ta}=25^{\circ} \mathrm{C}$. |
|  | IDD | - | 100 | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{Ta}=25^{\circ} \mathrm{C}$ |

(1) $X T, \overline{X T}$ and $D_{0} \sim D_{3}$ excluded.

## SWITCHING CHARACTERISTICS

(1) READ mode

| $\left(\mathrm{V}_{\text {DD }}=5 \mathrm{~V} \pm 5 \%, \mathrm{Ta}=25^{\circ} \mathrm{C}\right)$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Condition | MIN | TYP | MAX | Unit |
| HOLD Set-up Time | ${ }^{\text {thS }}$ | -_ | 150 | - | - | $\mu \mathrm{s}$ |
| HOLD Hold Time | ${ }^{\text {t }} \mathrm{H} \mathrm{H}$ | $\underline{-}$ | 0 | - | - | $\mu \mathrm{s}$ |
| HOLD Pulse Width | ${ }^{\text {t HW }}$ | - | - | - | 990 | ms |
| HOLD "L' Hold Time | ${ }^{\text {t }} \mathrm{HL}$ | $\underline{\square}$ | 130 | - | - | $\mu \mathrm{s}$ |
| READ Hold Time | ${ }^{\text {t }} \mathrm{RH}$ | - | 0 | - | - | $\mu \mathrm{s}$ |
| READ Set-up Time | ${ }^{\text {t }}$ RS | - | 0 | - | - | $\mu \mathrm{s}$ |
| READ Access Time | ${ }^{\text {t RA }}$ | $\begin{aligned} & \text { RPULL-UP }=5 K \Omega \\ & C_{L}=15 \mathrm{pF} \end{aligned}$ | - | - | 6 | $\mu \mathrm{s}$ |
| ADDRESS Set-up Time | ${ }^{t}$ AS | $\underline{-}$ | 3 | - | - | $\mu \mathrm{s}$ |
| ADDRESS Hold Time | ${ }^{t} \mathrm{AH}$ | - | 0.2 | - | - | $\mu \mathrm{S}$ |
| READ Pulse Width | ${ }^{t}$ RW | $\begin{aligned} & R_{P U L L-U P}=5 K \Omega \\ & C_{L}=15 \mathrm{pF} \end{aligned}$ | 2 | - | - | $\mu \mathrm{s}$ |
| DARA Access Time | ${ }^{t} A C$ | $\begin{aligned} & R_{P U L L-U P}=5 K \Omega \\ & C_{L}=15 \mathrm{pF} \end{aligned}$ | - | - | 0.6 | $\mu \mathrm{s}$ |
| OUTPUT Disable Time | toFF | $\begin{aligned} & \text { RPULL-UP }=5 K \Omega \\ & C_{L}=15 \mathrm{pF} \end{aligned}$ | - | - | 0.6 | $\mu \mathrm{s}$ |
| CS Enable Delay Time | ${ }^{\text {t CS }} 1$ | - | - | - | 0.6 | $\mu \mathrm{s}$ |
| CS Disable Delay Time | ${ }^{\text {t }} \mathrm{CS} 2$ | - | - | - | 0.6 | $\mu \mathrm{s}$ |

READ CYCLE


Figure 3 Read Cycle
Notes:1. A Read occurs during the overlap of a high CS and a high READ.
2. CS may be a permanent " 1 ", or may be coincident with HOLD pulse.

## SWITCHING CHARACTERISTICS

(2) WRITE mode

| $\left(V_{\text {DD }}=5 \mathrm{~V} \pm 5 \%, \mathrm{Ta}=25^{\circ} \mathrm{C}\right.$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Condition | MIN | TYP | MAX | Unit |
| HOLD Set-up Time | ${ }_{\text {t }} \mathrm{HS}$ | $\longrightarrow$ | 150 | - | - | $\mu \mathrm{s}$ |
| HOLD Bold Time | ${ }^{\text {t }} \mathrm{HH}$ | $\square$ | 0 | - | - | $\mu \mathrm{s}$ |
| HOLD Pulse Width | thw | - | - | - | 990 | ms |
| HOLD "L" Hoid Time | ${ }^{t} \mathrm{HL}$ | - | 130 | - | - | $\mu \mathrm{s}$ |
| ADDRESS Pulse Width | taw | $\square$ | 1.7 | - | - | $\mu \mathrm{s}$ |
| Data Pulse Width | tow | $\square$ | 1.7 | - | - | $\mu \mathrm{s}$ |
| DATA Set-up Time | tos | $\square$ | 0.5 | - | - | $\mu \mathrm{s}$ |
| DATA Hold Time | ${ }^{t} \mathrm{DH}$ | $\square$ | 0.2 | - | - | $\mu \mathrm{s}$ |
| WRITE Pulse Width | twW | $\square$ | 1.0 | - | - | $\mu \mathrm{s}$ |
| CS Enable Delay Time | ${ }^{t}$ CS 1 | - | - | - | 0.6 | $\mu \mathrm{s}$ |
| CS Disoble Delay Time | ${ }^{\text {t CS } 2}$ | - | - | - | 0.6 | $\mu \mathrm{s}$ |



Notes: 1. A WRITE occurs during the overlap of a high CS, a high HOLD and a high WRITE.
2. CS may be permanent "1", or may be coincident with HOLD pulse.

## PIN DESCRIPTION

| Name | Pin No. | Description |
| :---: | :---: | :---: |
| VDD | 1 | Power supply pin. Application circuits for power supply are described in Figure 9. |
| WRITE | 2 | Data write pin. Data write cycle is described in Figure 4. |
| READ | 3 | Data read pin. Data read cycle is described in Figure 3. |
| $A_{0} \sim A_{3}$ | 4~7 | Address input pins used to select internal counters for read/write operations. The address is specified by 4-bit binary code as shown in Table 1. |
| C S | 8 | Chip slect pin which is required to interface with the external circuit. HOLD, WRITE, READ, $\pm 30$ ADJ, TEST, $D_{0} \sim D_{3}$ and $A_{0} \sim A_{3}$ pins are activated if CS is set at H level, while atl of these pins are disabled if CS is set at $L$ level. |
| $D_{0} \sim D_{3}$ | $9 \sim 12$ | Data input/output pins (bidirectional bus). <br> As shown in Figure 5, external pull-up registers of $4.7 \mathrm{k} \Omega \sim 10 \mathrm{k} \Omega$ are required by the open-drain NMOS output. $D_{3}$ is the MSB, while $D_{0}$ is the LSB <br> Figure 5 |


| Name | Pin No. | Description |
| :---: | :---: | :---: |
| GND | 13 | Ground pin. |
| TEST | 14 | Test pin. Normally this pin should be left open or should be set at ground level. With CS at $\mathrm{V}_{\mathrm{DD}}$, pulses to $\mathrm{V}_{\mathrm{DD}}$ on the TEST input will directly clock the $\mathrm{S}_{1}$, $\mathrm{MI}_{10}, \mathrm{~W}, \mathrm{D}_{1}$ and $\mathrm{Y}_{1}$ counters, depending on which counter is addressed ( W and $D_{1}$ are selected by $D_{1}$ address in this mode only). Roll-over to next counter is enabled in this mode. |
| $\pm 30$ ADJ | 15 | This pin is used to adjust the time within the extent of $\pm 30$ seconds. If this pin is set at H level when the seconds digits are $0 \sim 29$, the seconds digits are cleared to 0 . If this pin is set at H level when the seconds digits are $30 \sim 59$, the second digits will be cleared to 0 and the minutes digits will be increased by +1 . To enable this function, 31.25 ms or more width's pulse should be input to this pin. |
| XT | 16 | Oscillator pin. 32.768 kHz crystal, capacitor and trimmer condensor for frequency adjustment connected to these pins. See Figure 6. As for oscillator frequency deviation, refer to Figure 1 and Figure 2. <br> If an external clock is to be used for the MSM5832RS's oscillation source, the external clock is to be input to XT , and $\overline{\mathrm{XT}}$ should be left open. <br> Figure 6 |
| $\bar{X} T$ | 17 |  |
|  |  |  |
| HOLD | 18 | Switching this input to $V_{D D}$ inhibits the internal 1 Hz clock to the S 1 counter. After the specified HOLD set-up time ( $150 \mu \mathrm{~s}$ ), all counters will be in a static state, thus allowing error-free read or write operations. So long as the HOLD pulse width is less than 990 ms , real time accuracy will be undisturbed. Pull-down to GND is provided by an internal resistor. |

## REFERENCE SIGNAL OUTPUT PIN

| Condition | Output | Reference Frequency | Pulse Width |
| :---: | :---: | :---: | :---: |
| $H O L D=L$ | $D_{0}\left({ }_{1}\right)$ | 1024 Hz | duty $50 \%$ |
|  |  |  |  |
| READ $=H$ | $D_{1}$ | 1 Hz | $122.1 \mu \mathrm{~S}$ |
|  |  |  |  |
| $A_{0} \sim A_{3}=H$ | $D_{2}$ | $1 / 60 \mathrm{~Hz}$ | $122.1 \mu \mathrm{~S}$ |
|  | $D_{3}$ | $1 / 3600 \mathrm{~Hz}$ | $122.1 \mu \mathrm{~S}$ |

(1) 1024 Hz signal at $D_{0}$ not dependent on HOLD input level.

## APPLICATION EXAMPLE



## APPLICATION CIRCUIT - POWER SUPPLY CIRCUIT

Open or ground unused pins (pins other than the $X T, \overline{X T}, D 0-D 3$, and BUSY pins).


Note: Use the same diodes for D1 and D2 to reduce the level difference between +5 V and VDD of the MSM5832RS.

## OIKI semiconductor <br> MSM58321RS

REAL TIME CLOCK/CALENDAR

## GENERAL DESCRIPTION

The MSM58321RS is a metal gate CMOS Real Time Clock/Calendar with a battery backup function for use in bus-oriented microprocessor applications.

The 4-bit bidirectional bus line method is used for the data I/O circuit; the clock is set, corrected, or read by accessing the memory.

The time is read with 4-bit DATA I/O, ADDRESS WRITE, READ, and BUSY; it is written with 4-bit DATA I/O, ADDRESS WRITE, WRITE, and BUSY.

## FEATURES

- 7 Function-Second, Minute, Hour, Day, Day-of-Week,

Month, Year

- Automatic leap year calender
- 12/24 hour format
- Frequency divider 5-poststage reset
- Reference signal output
- 32.768 kHz crystal controlled operation
- Single 5V power supply
- Back-up battery operation to $\mathrm{V}_{\mathrm{DD}}=2.2 \mathrm{~V}$
- Low power dissipation
$90 \mu \mathrm{~W}$ max. at $\mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V}$
2.5 mW max. at $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$
- 16 pin plastic DIP (DIP16-P-300)


## FUNCTIONAL BLOCK DIAGRAM



## PIN CONFIGURATION

16 pin Plastic DIP (Top View)


## REGISTER TABLE

| Address | Address input |  |  |  | Register Name | Data input/ output |  |  |  | Count value |  |  | Remarks |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} \mathrm{D}_{0} \\ \left(\mathrm{~A}_{0}\right) \end{gathered}$ | $\begin{aligned} & D_{1} \\ & \left(A_{1}\right) \end{aligned}$ | $\begin{gathered} \mathrm{D}_{2} \\ \left(\mathrm{~A}_{2}\right) \end{gathered}$ | $\begin{aligned} & D_{3} \\ & \left(A_{3}\right) \end{aligned}$ |  | $\mathrm{D}_{0}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{3}$ |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | $\mathrm{S}_{1}$ | * | * | * | * | 0 | $\sim$ | 9 |  |  |  |  |
| 1 | 1 | 0 | 0 | 0 | $\mathrm{S}_{10}$ | * | * | * |  | 0 | $\sim$ | 5 |  |  |  |  |
| 2 | 0 | 1 | 0 | 0 | $\mathrm{MI}_{1}$ | * | * | * | * | 0 | $\sim$ | 9 |  |  |  |  |
| 3 | 1 | 1 | 0 | 0 | $\mathrm{MI}_{10}$ | * | * | * |  | 0 | $\sim$ | 5 | . |  |  |  |
| 4 | 0 | 0 | 1. | 0 | $\mathrm{H}_{1}$ | * | * | * | * | 0 | $\sim$ | 9 |  |  |  |  |
| 5 | 1 | 0 | 1 | 0 | $\mathrm{H}_{10}$ | * | * | * | (*) |  | or 0 |  | $\mathrm{D} 2=1$ specifies PM , D3 $=0$ specifies 12 -h When D3 $=1$ is writte | $\begin{aligned} & =0 \\ & \text { time } \\ & \text { he } \mathrm{C} \end{aligned}$ |  | AM, D3 $=1$ specifies 24 -hour timer, and eset inside the IC. |
| 6 | 0 | 1 | 1 | 0 | W | * | * | * |  | 0 | $\sim$ | 6 |  |  |  |  |
| 7 | 1 | 1 | 1 | 0 | $\mathrm{D}_{1}$ | * | * | * | * | 0 | $\sim$ | 9 |  |  |  |  |
| 8 | 0 | 0 | 0 | 1 | $\mathrm{D}_{1}$ | * | * | O | $\bigcirc$ | 0 | $\sim$ | 3 | The D2 and D3 bits in | 10 | used | select a leap year. |
| 9 | 1 | 0 | 0 | 1 | $\mathrm{MO}_{1}$ | * | * | * | * | 0 | $\sim$ | 9 | Calendar | $\mathrm{D}_{2}$ | $\mathrm{D}_{3}$ | Remainder obtained by dividing the year number by 4 |
| A | 0 | 1 | 0 | 1 | $\mathrm{MO}_{10}$ | * |  |  |  | 0 | $\sim$ | 1 | Gregorian calendar | 0 | 0 | 0 |
| B | 1 | 1 | 0 | 1 | $Y_{1}$ | * | * | * | * | 0 | $\sim$ | 9 | Showa | 1 | 0 | 3 |
| C | 0 | 0 | 1 | 1 | $Y_{10}$ | * | * | * | * |  | $\sim$ | 9 |  | 1 | 1 | 1 |
| D | 1 | 0 | 1 | $1$ |  |  |  |  |  |  |  |  | A selector to reset 5 circuit. They are re and the WRITE inpu | tsta wh s to | in this | $1 / 2^{15}$ frequency divider and the BUSY ode is latched with ADDRESS LATCH |
| E~F | 0/1 | 1 | 1 | 1 |  |  | . |  |  |  |  |  | A selector to obtain D0 - D3 when this goes to 1 . | is | sign <br> hed | output. Reference signals are output to with ADDRESS LATCH and READ input |

Notes: (1) There are no bits in blank fields for data input/output. 0 signals are output by reading and data is not stored by writing because there are no bits.
(2) The bit with marked ${ }^{(+)}$is used to select the $12 / 24$-hour timer and the bits marked $\mathcal{O}$ are used to select a leap year. These three bits can be read or written.
(3) When signals are input to bus lines DO - D3 and ADDRESS WRITE goes to 1 for address input, ADDRESS information is latched with ADDRESS LATCH.

## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Condition | Rating | Unit |
| :--- | :---: | :---: | :---: | :---: |
| Power voltage | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | $-0.3 \sim 7$ | V |
| Input voltage | $\mathrm{V}_{1}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | $\mathrm{GND}-0.3 \sim \mathrm{~V}_{\mathrm{DD}}+0.3$ | V |
| Output voltage | $\mathrm{V}_{\mathrm{O}}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | $\mathrm{GND}-0.3 \sim \mathrm{~V}_{\mathrm{DD}}+0.3$ | V |
| Storage temperature | Tstg | - | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

## OPERATING CONDITIONS

| Parameter | Symbol | Condition | Rating | Unit |
| :--- | :---: | :---: | :---: | :---: |
| Power voltage | VDD | - | $4.5 \sim 7$ | V |
| Date hold voltage | VDH | - | $2.2 \sim 7$ | V |
| Crystal frequency | $f(X T)$ | - | 32.768 | kHz |
| Operating temperature | Top | - | $-30 \sim+85$ | ${ }^{\circ} \mathrm{C}$ |

Note: The data hold voltage guarantees the clock operations, though it does not guarantee operations outside the IC and data input/output.

## DC CHARACTERISTICS

$\left(V_{D D}=5 \vee \pm 5 \%, \mathrm{Ta}=-30 \sim+85^{\circ} \mathrm{C}\right.$ )

| Parameter | Symbol |  | dition | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Hinput voltage | $\mathrm{V}_{1 \mathrm{H}_{1}}$ | - | Note 1 | 3.6 | - | - | V |
|  | $\mathrm{V}_{1 \mathrm{H}_{2}}$ | - | Note 2 | $\mathrm{V}^{\text {DD }}{ }^{-0.5}$ | - | - |  |
| Linput voltage | $V_{\text {IL }}$ |  |  | - | - | 0.8 | V |
| L output voltage | $\mathrm{V}_{\mathrm{OL}}$ |  | 1.6 mA | - | - | 0.4 | V |
| L output current | ${ }^{1} \mathrm{OL}$ |  | 0.4 V | 1.6 | - | - | mA |
| Hinput current | ${ }_{1 / H_{1}}$ | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{D}}$ | $V$ Note 3 | 10 | 30 | 80 | $\mu \mathrm{A}$ |
|  | ${ }_{1 / H_{2}}$ | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{D}}$ | V Note 4 | - | - | 1 |  |
| L input current | IIL | $\mathrm{V}_{1}=$ |  | - | - | -1 | $\mu \mathrm{A}$ |
| Input capacity | $\mathrm{Cl}_{1}$ | $f=1$ | MHz | - | 5 | - | pF |
| Current consumption | IDD | $\begin{array}{r} f=32.7 \\ V_{D D}=5 V \end{array}$ | $\begin{aligned} & 38 \mathrm{kHz} \\ & \mathrm{~V}_{\mathrm{DD}}=3 \mathrm{~V} \end{aligned}$ | - | 100/15 | 500/30 | $\mu \mathrm{A}$ |

Note: 1. $\mathrm{CS}_{2}$, WRITE, READ, ADDRESS WRITE, STOP, TEST, $\mathrm{D}_{0} \sim \mathrm{D}_{3}$
2. $\mathrm{CS}_{1}$
3. $\mathrm{CS}_{1}, \mathrm{CS}_{2}$, WRITE, READ, ADDRESS WRITE, STOP, TEST
4. $D_{0} \sim D_{3}$

## SWITCHING CHARACTERISTICS

(1) WRITE mode
$\left(V_{D D}=5 V \pm 5 \%, T a=25^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Condition | Min. | Typ. | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| CS setup time | $\mathrm{t}_{\mathrm{CS}}$ | - | 0 | - | - | $\mu_{\mathrm{s}}$ |
| CS Hold time | $\mathrm{t}_{\mathrm{CH}}$ | - | 0 | - | - | $\mu_{\mathrm{s}}$ |
| Address setup time | $\mathrm{t}_{\mathrm{AS}}$ | - | 0 | - | - | $\mu_{\mathrm{s}}$ |
| Address write pulse width | $\mathrm{t}_{\mathrm{AW}}$ | - | 0.5 | - | - | $\mu_{\mathrm{s}}$ |
| Address hold time | $\mathrm{t}_{\mathrm{AH}}$ | - | 0.1 | - | - | $\mu_{\mathrm{s}}$ |
| Data setup time | $\mathrm{t}_{\mathrm{DS}}$ | - | 0 | - | - | $\mu_{\mathrm{s}}$ |
| Write pulse width | $\mathrm{t}^{\mathrm{WW}}$ | - | 2 | - | - | $\mu_{\mathrm{s}}$ |
| Data hold time | $-\mathrm{t}_{\mathrm{DH}}$ | - | 0 | - | - | $\mu_{\mathrm{s}}$ |



Note: ADDRESS WRITE and WRITE inputs are activated by the level, not by the edge.

## (2) READ mode

$\left(V_{D D}=5 \mathrm{~V} \pm 5 \%, \mathrm{Ta}=25^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Condition | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CS setup time | ${ }^{\text {t }} \mathrm{CS}$ | - | 0 | - | - | $\mu_{s}$ |
| CS Hold time | ${ }^{t} \mathrm{CH}$ | - | 0 | - | - | $\mu \mathrm{s}$ |
| Address setup time | ${ }^{\text {t }}$ AS | - | 0 | - | - | $\mu \mathrm{s}$ |
| Address write pulse width | tAW | - | 0.5 | - | - | $\mu \mathrm{s}$ |
| Address hold time | ${ }^{t} \mathrm{AH}$ | - | 0.1 | - | - | $\mu \mathrm{s}$ |
| Read access time | ${ }^{\text {tRA }}$ | - | - | - | see Note 1 | $\mu \mathrm{s}$ |
| Read delay time | tDD | - | - | - | 1 | $\mu \mathrm{s}$ |
| Read inhibit time | tRI | - | 0 | - | - | $\mu \mathrm{s}$ |

Note 1. $t_{R A}=1 \mu_{S}+C R \ln \left(\frac{V_{D D}}{V_{D D}-V_{I H} \min }\right)$


Note: ADDRESS WRITE and READ inputs are activated by the level, not by the edge.
(3) WRITE \& READ mode

| Parameter | Symbol | Condition | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CS setup time | ${ }^{\text {t }}$ CS | - | 0 | - | - | $\mu \mathrm{s}$ |
| CS hold time | ${ }^{\text {t }} \mathrm{CH}$ | - | 0 | - | - | $\mu \mathrm{s}$ |
| Address setup time | ${ }^{\text {t }}$ AS | - | 0 | - | - | $\mu \mathrm{s}$ |
| Address write pulse width | ${ }^{\text {t AW }}$ | - | 0.5 | - | - | $\mu_{s}$ |
| Address hold time | ${ }^{\text {t }}$ A H | - | 0.1 | - | - | $\mu \mathrm{s}$ |
| Data setup time | tDS | - | 0 | - | - | $\mu_{\mathrm{s}}$ |
| Write pulse width | tww | - | 2 | - | - | $\mu \mathrm{s}$ |
| Data hold time | ${ }^{\text {t }} \mathrm{H}$ | - | 0 | - | - | $\mu \mathrm{s}$ |
| Read access time | trA | - | - | - | see Note 1 | $\mu_{\mathrm{s}}$ |
| Read delay time | ${ }^{\text {t }}$ D ${ }^{\text {d }}$ | - | - | - | 1 | $\mu \mathrm{s}$ |
| Read inhibit time | $\mathrm{t}_{\mathrm{R}} \mathrm{I}$ | - | 0 | - | - | $\mu_{\mathrm{s}}$ |

Note 1. $t_{R A}=1 \mu_{S}+C R \ln \left(\frac{V_{D D}}{V_{D D}-V_{I H} \min }\right)$


## PIN DESCRIPTION



| Name | Pin No. | Descrip |
| :---: | :---: | :---: |
| READ | 3 | READ pin is used to read data; it is activated when it is at the H level. Address contents are latched with ADDRESS LATCH inside the IC at the DO - D3 and ADDRESS WRITE pins to select the object digit, then an $H$-level signal is input to the READ pin to read data. <br> If a count operation is continued by setting the STOP input to the $L$ level, read operation must be performed, in principle, while the BUSY output is at the H level. While the BUSY output is at the L level, count operations are performed by digit counters and read data is not guaranteed, therefore, read operations are inhibited in this period. Figure 3 shows a time chart of the BUSY output, 1 Hz signal inside the IC, and READ input. <br> A read operation is stopped temporarily within a period of $244 \mu$ s from the BUSY output trailing edge and it is restarted when the BUSY output goes to the H level again. |
|  |  | Figure 3 <br> If the counter operation is stopped by setting the STOP input to the H level, read operations are enabled regardless of the BUSY output. <br> A read operation is enabled by microcomputer software regardless of the BUSY output during the counter operation by setting the STOP input to the L level. In this method, read operations are performed two or more times continuously and data that matches twice is used as guaranteed data. |


| Name | Pin No. | Description |
| :---: | :---: | :---: |
| $D_{0} \sim D_{3}$ | 4~7 | Data input/output pins. (Bidirectional bus). The output is a open-drain type and $4.7 \mathrm{k} \Omega \sim 10 \mathrm{k} \Omega$ pull-up registers are required utilize these pins as output pins. |
| GND | 8 | Ground pin. |
| ADDRESS WRITE | 9 | ADDRESS WRITE pin is used to load address information from the DO - D3 I/O bus pins to the ADDRESS LATCH inside the IC; it is activated when it is at the H level. This input is activated by the level, not by the edge. Figure 4 shows the relationships between the DO address input, ADDRESS WRITE input, and ADDRESS LATCH input/output. <br> Figure 4 |
| BUSY | 10 | BUSY pin outputs the IC operation state. It is N -channel MOSFET open-drain output. An external pull-up resistor of $4.7 \mathrm{k} \Omega$ or more must be connected (see Figure 5) to use the BUSY output. The signals are output in negative logics. If the oscillator oscillates at 32.768 kHz , the frequency is always 1 Hz regardless of the CS1 and CS2 unless the D output of the ADDRESS DECODER inside the IC is $\mathrm{H}(\mathrm{CODE}=\mathrm{H} \cdot \mathrm{L} \cdot \mathrm{H} \cdot \mathrm{H})$ and CS1 $=\mathrm{CS} 2=$ WRITE $=\mathrm{H}$. <br> Figure 6 shows the BUSY output time chart. <br> Read/write-inhibited period <br> Figure 6 |


| Name | Pin No. | Description |
| :---: | :---: | :---: |
| STOP | 11 | The STOP pin is used to input on/off control for a 1 Hz signal. When this pin goes to the H level, 1 Hz signals are inhibited and counting for all digits succeeding the S1 digit is stopped. When this pin goes to the L level, normal operations are performed; the digits are counted up. This STOP input controls stopping digit counting. Writing of external data in digits can be assured by setting the STOP input to the $H$ level to stop counting, then writing sequentially from the low-order digits. |
| TEST | 12 | The TEST pin is used to test this IC; it is normally open or connected to GND. It is recommended to connect it to GND to safeguard against malfunctions from noise. <br> The TEST pulse can be input to the following nine digits: <br> S1, S10, M110, H1, D1 (W), M01, Y1 and Y10 <br> When a TEST pulse is input to the D1 digit, the $\mathbf{W}$ digit is alsc counted up simultaneously. <br> Input a TEST pulse as follows: <br> Set the address to either digit explained above, then input a pulse to the TEST pin while CS1 $=$ CS2 $=$ STOP $=H$ and WRITE $=\mathrm{L}$. The specified and succeeding digits are counted up. (See Figure 7) <br> Figure 7 <br> A digit is counted up at the leading edge (changing point from $L$ to $H$ ) of a TEST pin input pulse. The pulse condition for TEST pin input at $V_{D D}=5 \mathrm{~V} \pm 5 \%$ is described in Figure 8 below. <br> Figure 8 |



## REFERENCE SIGNAL OUTPUT

Reference signals are output from the DO - D3 pins under the following conditions:

| Conditions | Output pin | Reference signal frequency | Pulse width | Output logic |
| :---: | :---: | :---: | :---: | :---: |
| WRITE $=$ L | $\mathrm{D}_{0}$ | 1024 Hz | $488.3 \mu_{\text {s }}$ | Positive logic |
| READ $=\mathrm{H}$ | $\mathrm{D}_{1}$ | 1 Hz | $122.1 \mu_{\mathrm{s}}$ | Negative logic |
| CS1 = CS2 $=\mathrm{H}$ | $\mathrm{D}_{2}$ | $1 / 60 \mathrm{~Hz}$ | $122.1 \mu_{\mathrm{s}}$ | Negative logic |
| ADDRESS $=E$ or $F$ | $\mathrm{D}_{3}$ | $1 / 3600 \mathrm{~Hz}$ | $122.1 \mu_{\mathrm{s}}$ | Negative logic |



$$
\begin{aligned}
122.1 \mu \mathrm{~S} & =\frac{10^{-3}}{32,768} \times 4 \\
488.3 \mu \mathrm{~S} & =\frac{10^{-3}}{32,768} \times 16
\end{aligned}
$$

Figure 10

## APPLICATION NOTES

## - WRITE and STOP

Note that the timing relationships between the STOP and WRITE inputs vary by the related digit when counting is stopped by the STOP input to write data. The time ( $\mathrm{t} \mathrm{SH}^{\prime}$ ) between the STOP input leading edge and WRITE input trailing edge for each digit is limited to the minimum value. (See Figure 11)


Write-inhibited period

Figure 11

[^7]
## PERIPHERALS•MSM58321RS

If a count operation is continued by setting the STOP input to the L level, write operation must be performed, in principle, while the $\overline{B U S Y}$ output is at the $H$ level. While the BUSY output is at the L level, count operations are performed by the digit counters and write operation is inhibited, but there is a marginal period of $244 \mu$ from the $\overline{B U S Y}$ output trailing edge. If the $\overline{B U S Y}$ output goes to the $L$ level during a write operation, the write operation is stopped temporarily within $244 \mu_{\mathrm{s}}$ and it is restarted when the BUSY output goes to the H level again. Figure 12 shows a time chart of BUSY output, 1 Hz signal inside the IC, and WRITE.input.


## - Frequency divider and $\overline{B U S Y}$ circuit reset

If $A 0-A 3=H \cdot L \cdot H \cdot H$ is input to ADDRESS DECODER, the DECODER output ( $D$ ) goes to the $H$ level. If $\mathrm{CS} 1=\mathrm{CS} 2=\mathrm{H}$ and WRITE $=\mathrm{H}$ in this state, the 5 poststages in the 15 -stage frequency divider and the BUSY circuit are reset.

In this period, the BUSY output remains at the H level and the 1 Hz signal inside the IC remains at the L level, and counting is stopped. If this reset is inactivated while the oscillator operates, the BUSY output goes to the L level after $1000.1221 \pm 31.25 \mathrm{~ms}$ and the 1 Hz signal inside the IC goes to the H level after $1000.3663 \pm 31.25 \mathrm{~ms}$. These times are not the same because the first ten stages in the 15 -stage frequency divider are not reset. (See Figure 13)


Figure 13

## PERIPHERALS• MSM58321RS

## - Selection of leap year

This IC is designed to select leap year automatically.
Four types of leap years can be selected by writing a select signal in the D2 and D3 bits of the D10 digit (CODE $=L \cdot L \cdot L \cdot H$ ). (See Table 1 for the functions.)

Gregorian calendar, Japanese Showa, or other calendars can be set arbitrarily in the Y1 and Y2 digits of this IC. There is a leap year every four years and the year number varies according to whether the Gregorian calendar or Showa is used. There are four combinations of year numbers and leap years. (See the Table below).
No. 1: Gregorian calendar year. The remainder obtained by dividing the leap year number by 4 is 0 .
No. 2: Showa year. The remainder obtained by dividing the leap year number by 4 is 3 .
No. 3: The remainder obtained by dividing the leap year number by 4 is 2 .
No. 4: The remainder obtained by dividing the leap year number by 4 is 1 .

| No. 1 | Calendar | D10 digit |  | Remainder obtained by dividing the leap year number by 4 | Leap years (examples) |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | D2 | D3 |  |  |
| 1 | Gregorian | L | L | 0 | $\begin{aligned} & \text { 1980, 1984, 1988, 1992, } \\ & 1996,2000,2004 \end{aligned}$ |
| 2 | Showa | H | L | 3 | $\begin{array}{lllll} (83) & (87) & (91) & (95) & (99) \\ 55, & 59, & 63, & 67, & 71, \\ 75, & 79 & & & \end{array}$ |
| 3 |  | L | H | 2 | $\begin{aligned} & 82, ~ 86,90,94,98, \\ & 102,106 \end{aligned}$ |
| 4 |  | H | H | 1 | $\begin{aligned} & 81,85,89,93,97, \\ & 101,105 \end{aligned}$ |

## APPLICATION EXAMPLE - POWER SUPPLY CIRCUIT



Note: Use the same diodes for D1 and D2 to reduce the level difference between +5 V and VDD of the MSM58321RS.

## QIEI semiconductor

MSM6242BRS/GS-VK/JS

## DIRECT BUS CONNECTED CMOS REAL TIME CLOCK/CALENDAR

## GENERAL DESCRIPTION

The MSM6242B is a silicon gate CMOS Real Time Clock/Calendar for use in direct bus-connection Microprocessor/Microcomputer applications. An on-chip 32.768 K Hz crystal oscillator time base is divided to provide addressable 4 -bit I/O data for SECONDS, MINUTES, HOURS, DAY OF WEEK, DATE, MONTH and YEAR. Data access is controlled by 4 -bit address, chip selects ( $\overline{\mathrm{CSO}}, \mathrm{CS} 1$ ), $\overline{\text { WRITE }}, \overline{\mathrm{READ}}$, and ALE. Control Registers D, E and F provide for 30 SECOND error adjustment, INTERRUPT REQUEST (IRQ FLAG) and BUSY status bits, clock STOP, HOLD, and RESET FLAG bits, 4 selectable INTERRUPTS rates are available at the STD.P (STANDARD PULSE) output utilizing Control Register inputs TO, T1 and the ITRPT/STND (INTERRUPT/STANDARD). Masking of the interrupt output (STD.P) can be accomplished via the MASK bit. The MSM6242B can operate in a $12 / 24$ hour format and Leap Year timing is automatic.

The MSM6242B normally operates from a $5 \mathrm{~V} \pm 10 \%$ supply at -30 to $85^{\circ} \mathrm{C}$. Battery backup operation down to 2.0 V allows continuation of time keeping when main power is off. The MSM6242B is offered in a 18 -pin plastic DIP, a 24-pin plastic Small Outline package, and a 18-pin PLCC package.

## FEATURES

DIRECT MICROPROCESSOR/MICROCONTROLLER BUS CONNECTION

| TIME | MONTH | DATE | YEAR |
| :--- | :---: | :---: | :---: | DAY OF WEEK

1 second, 1 minute, 1 hour

- Interrupt masking
- 32.768 KHz crystal controlled operation
- 12/24 hour format
- Auto leap year
$\pm 30$ second error correction
- Battery backup down to $V_{D D}=2.0 \mathrm{~V}$
- Low power dissipation:
$20 \mu \mathrm{~W}$ max at $\mathrm{V}_{\mathrm{DD}}=2 \mathrm{~V}$
$150 \mu \mathrm{~W}$ max at $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$
- 18 pin Plastic DIP (DIP18-P-300)
- 18 pin PLCC (OFJ18-P-R290)
. 24 pin-V Plastic SOP (SOP24-P-430-VK)

FUNCTIONAL BLOCK DIAGRAM


PIN CONFIGURATION


## REGISTER TABLE

| Address Input | Address Input |  |  |  | Register Name | Data |  |  |  | Count value | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{A}_{3}$ | $\mathrm{A}_{2}$ | $A_{1}$ | $A_{0}$ |  | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | D |  |  |
| 0 | 0 | 0 | 0 | 0 | $\mathrm{S}_{1}$ | $\mathrm{S}_{8}$ | $\mathrm{S}_{4}$ | $\mathrm{S}_{2}$ | $\mathrm{S}_{1}$ | $0 \sim 9$ | 1 -second digit register |
| 1 | 0 | 0 | 0 | 1 | $\mathrm{S}_{10}$ | * | $\mathrm{S}_{40}$ | $\mathrm{S}_{20}$ | $\mathrm{S}_{10}$ | $0 \sim 5$ | 10-second digit register |
| 2 | 0 | 0 | 1 | 0 | $\mathrm{Ml}_{1}$ | $\mathrm{mi}_{5}$ | $\mathrm{mi}_{4}$ | $\mathrm{mi}_{2}$ | $\mathrm{mi}_{1}$ | $0 \sim 9$ | 1-minute digit register |
| 3 | 0 | 0 | 1 | 1 | $\mathrm{Ml}_{10}$ | * | $\mathrm{mi}_{4} 0$ | $\mathrm{mi}_{20}$ | $\mathrm{mi}_{10}$ | $0 \sim 5$ | 10-minute digit register |
| 4 | 0 | 1 | 0 | 0 | $\mathrm{H}_{1}$ | $\mathrm{h}_{8}$ | $\mathrm{h}_{4}$ | $\mathrm{h}_{2}$ | $\mathrm{h}_{1}$ | $0 \sim 9$ | 1-hour digit register |
| 5 | 0 | 1 | 0 | 1 | $\mathrm{H}_{10}$ | * | $\begin{aligned} & \text { PM/ } \\ & \text { AM } \end{aligned}$ | $\mathrm{h}_{20}$ | $\mathrm{h}_{10}$ | $\begin{aligned} & 0 \sim 2 \\ & \text { or } 0 \sim 1 \end{aligned}$ | PM/AM, 10-hour digit register |
| 6 | 0 | 1 | 1 | 0 | $\mathrm{D}_{1}$ | $\mathrm{d}_{8}$ | $\mathrm{d}_{4}$ | $\mathrm{d}_{2}$ | $\mathrm{d}_{1}$ | $0 \sim 9$ | 1 -day digit register |
| 7 | 0 | 1 | 1 | 1 | $\mathrm{D}_{10}$ | * | * | $\mathrm{d}_{20}$ | $\mathrm{d}_{10}$ | $0 \sim 3$ | 10-day digit register |
| 8 | 1 | 0 | 0 | 0 | $\mathrm{MO}_{1}$ | $\mathrm{mo}_{8}$ | $\mathrm{mo}_{4}$ | $\mathrm{mo}_{2}$ | $\mathrm{mo}_{1}$ | $0 \sim 9$ | 1-month digit register |
| 9 | 1 | 0 | 0 | 1 | $\mathrm{MO}_{10}$ | * | * | * | $\mathrm{MO}_{10}$ | $0 \sim 1$ | 10-month digit register |
| A | 1 | 0 | 1 | 0 | $Y_{1}$ | $\mathrm{y}_{8}$ | $y_{4}$ | $\mathrm{V}_{2}$ | $\mathrm{y}_{1}$ | $0 \sim 9$ | 1 -year digit register |
| B | 1 | 0 | 1 | 1 | $\mathrm{Y}_{10}$ | $\mathrm{Y}_{80}$ | $y_{40}$ | $y_{20}$ | $y_{10}$ | $0 \sim 9$ | 10-year digit register |
| C | 1 | 1 | 0 | 0 | W | * | $\mathrm{w}_{4}$ | $\mathrm{w}_{2}$ | $\mathrm{w}_{1}$ | $0 \sim 6$ | Week register |
| D | 1 | 1 | 0 | 1 | $C_{D}$ | $\begin{array}{\|r\|} \hline 30 \\ \text { sec. } \end{array}$ ADJ | $\begin{aligned} & \text { IRQ } \\ & \text { FLAG } \end{aligned}$ | BUSY | HOLD | - | Control Register D |
| E | 1 | 1 | 1 | 0 | $\mathrm{C}_{\mathrm{E}}$ | $\mathrm{t}_{1}$ | $\mathrm{t}_{0}$ | ITRPT /STND | MASK | - | Control Register E |
| F | 1 | 1 | 1 | 1 | $C_{F}$ | TEST | 24/12 | STOP | REST | - | Control Register F |

REST = RESET
ITRPT/STND = INTERRUPT/STANDARD
Note 1) - Bit * does not exist (unrecognized during a write and held at " 0 " during a read).
Note 2) - Be sure to mask the AM/PM bit when processing 10's of hour's data.
Note 3) - BUSY bit is read only. The IRQ FLAG bit can only be set to a " 0 ". Setting the IRQ FLAG to a " 1 " is done by hardware.

## OSCILLATOR FREQUENCY DEVIATIONS



Figure 2. Frequency Deviation (PPM) vs Temperature
Figure 3. Frequency Deviation (PPM) vs Voltage

Note: 1. The graphs above showing frequency deviation vs temperature/voltage are primarily characteristic of the MSM6242B with the oscillation circuit described below.


Crystal: Type $\mathrm{N}_{\mathbf{0}}, \mathrm{P}_{\mathbf{3}}$ by kinseki $(32.768 \mathrm{KHz})$
$C_{G}, C_{D}: 22 p F($ Temperature Characteristics: 0 )

## ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Condition | Rating | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Power Supply Voltage | $\mathrm{V}_{\text {DD }}$ | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | -0.3~7 | V |
| Input Voltage | $V_{1}$ |  | GND - 0.3~VDD +0.3 | V |
| Output Voltage | Vo |  | GND $-0.3 \sim V_{D D}+0.3$ | $\checkmark$ |
| Storage Temperature | ${ }_{\text {TSTG }}$ |  | $-55 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

## OPERATING CONDITIONS

| Parameter | Symbol | Condition | Rating | Unit |
| :--- | :---: | :---: | :---: | :---: |
| Power Supply Voltage | VDD $^{\prime}$ | - | $4 \sim 6$ |  |
| Standby Supply Voltage | V $_{\text {BAK }}$ | - | $2 \sim 6$ | V |
| Crystal Frequency | $\mathrm{f}(\mathrm{XT})$ | - | 32.768 | kHz |
| Operating Temperature | TOP $_{\text {OP }}$ | - | $-30 \sim+85$ | ${ }^{\circ} \mathrm{C}$ |

## D.C. CHARACTERISTICS

$V_{D D}=5 V \pm 10 \%, T_{A}=-30 \sim+85$

| Parameter | Symbol | Condition |  | Min. | Typ. | Max. | Unit | Applicable Terminal |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "H" Input Voltage | $\mathrm{V}_{1 \mathrm{H}^{1}}$ | - |  | 2.2 | - | - | V | All input terminals except $\mathrm{CS}_{1}$ |
| "L" Input Voltage | $\mathrm{V}_{\text {IL }}{ }^{1}$ | - |  | - | - | 0.8 |  |  |
| Input Leak Current | 'LK'1 | $V_{1}=V_{D D} / 0 \mathrm{~V}$ |  | - | - | 1/-1 | $\mu \mathrm{A}$ | Input terminals other than $D_{0} \sim D_{3}$ |
| Input Leak Current | ${ }^{\prime} \mathrm{LK}^{2}$ |  |  | - | - | 10/-10 |  | $\mathrm{D}_{0} \sim \mathrm{D}_{3}$ |
| "L' Output Voltage | $\mathrm{V}_{\mathrm{OL}}{ }^{1}$ | $\mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA}$ |  | - | - | 0.4 | V | $\mathrm{D}_{0} \sim \mathrm{D}_{3}$ |
| "H" Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{IOH}^{\prime}=-400 \mu \mathrm{~A}$ |  | 2.4 | - | - |  |  |
| "L" Output Voltage | $\mathrm{V}_{\mathrm{OL}}{ }^{2}$ | $\mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA}$ |  | - | - | 0.4 | V | STD.P |
| OFF Leak Current | IOFFLK | $\mathrm{V}=\mathrm{V}_{\mathrm{DD}} / 0 \mathrm{~V}$ |  | - | - | 10 | $\mu \mathrm{A}$ |  |
| Input Capacitance | $C_{1}$ | Input frequency 1 MHz |  | - | 5 | - | PF | All input terminals |
| Current Consumption | IDD1 | $\begin{aligned} & f(x t)= \\ & 32.768 \\ & \mathrm{KHz} \\ & \mathrm{~T}_{\mathrm{a}}=25^{\circ} \mathrm{C} \end{aligned}$ | $\begin{aligned} & \begin{array}{l} V_{D D}= \\ 5 \mathrm{~V} \end{array} \\ & \hline \begin{array}{l} V_{D D}= \\ 2 \mathrm{~V} \end{array} \\ & \hline \end{aligned}$ | - | - | 30 | $\mu \mathrm{A}$ | $V_{\text {DD }}$ |
| Current Consumption | ${ }^{1} \mathrm{DD}^{2}$ |  |  | - | - | 10 |  |  |
| "H" Input Voltage | $\mathrm{V}_{1 \mathrm{H}^{2}}$ | $V_{D D}=2 \sim 5.5 \mathrm{~V}$ |  | $4 / 5 V_{\text {DD }}$ | - | - | V | $\mathrm{CS}_{1}$ |
| "L" Input Voltage | $\mathrm{V}_{\mathrm{IL}}{ }^{2}$ |  |  | - | - | 1/5V ${ }^{\text {DD }}$ |  |  |

## SWITCHING CHARACTERISTICS

(1) WRITE mode ( $\mathrm{ALE}=\mathrm{V}_{\mathrm{DD}}$ )
$\left(V_{D D}=5 V \pm 10 \%=\mathrm{Ta}=-30 \sim+85^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Condition | Min. | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| CS $_{1}$ Set up Time | ${ }^{\text {t}} \mathrm{C1S}$ | - | 1000 | - |  |
| CS $_{1}$ Hold Time | ${ }^{\mathrm{t}} \mathrm{C1H}$ | - | 1000 | - |  |
| Address Stable Before <br> WRITE | tAW | - | 20 | - |  |
| Address Stable After <br> WRITE | tWA | - | 10 | - |  |
| WRITE Pulse Width | tWW | - | 120 | - |  |
| Data Set up Time | tDS | - | 100 | - |  |
| Data Hold Time | tDH |  | 10 | - |  |



$$
\begin{aligned}
& V_{1 H 1}=2.2 \mathrm{~V} \\
& V_{I L 1}=0.8 \mathrm{~V} \\
& V_{I H 2}=4 / 5 V_{D D} \\
& V_{I L 2}=1 / 5 V_{D D}
\end{aligned}
$$

Figure 4. Write Cycle - (ALE = VDD)
(2) WRITE mode (With use of ALE)
$\left(V_{D D}=5 \mathrm{~V} \pm 10 \%, \mathrm{Ta}=-3 \mathrm{C}\right)$

| Parameter | Symbol | Condition | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{CS}_{1}$ Set up Time | ${ }^{\text {t }} \mathrm{CIS}$ | - | 1000 | - | ns |
| Address Set up Time | ${ }^{\text {t }}$ AS | - | 25 | - |  |
| Address Hold Time | ${ }^{t} \mathrm{AH}$ | - | 25 | - |  |
| ALE Pulse Width | ${ }^{\text {t AW }}$ | - | 40 | - |  |
| ALE Before WRITE | t ALW | - | 10 | - |  |
| WRITE Pulse Width | twW | - | 120 | - |  |
| ALE After WRITE | tWAL | - | 20 | - |  |
| DATA Set up Time | ${ }^{\text {t }}$ DS | - | 100 | - |  |
| DATA Hold Time | ${ }^{\text {t }} \mathrm{DH}$ | - | 10 | - |  |
| $\mathrm{CS}_{1}$ Hold Time | ${ }^{t} \mathrm{C} 1 \mathrm{H}$ | - | 1000 | - |  |



Figure 5. Write Cycle - (With Use of ALE)
(3) READ mode ( $A L E=V_{D D}$ )

$$
\left(V_{D D}=5 \mathrm{~V} \pm 10 \%, \mathrm{Ta}=-30 \sim+85^{\circ} \mathrm{C}\right)
$$

| Parameter | Symbol | Condition | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{CS}_{1}$ Set up Time | ${ }^{t} \mathrm{C} 1 \mathrm{~S}$ | - | 1000 | - | ns |
| $\mathrm{CS}_{1}$ Hold Time | ${ }^{t} \mathrm{C} 1 \mathrm{H}$ | - | 1000 | - |  |
| Address Stable Before READ | ${ }^{\text {t }}$ AR | - | 20 | - |  |
| Address Stable After READ | trA | - | 0 | - |  |
| $\overline{\mathrm{RD}}$ to Data | ${ }^{\text {t }}$ RD | $C_{L}=150 \mathrm{pF}$ | - | 120 |  |
| Data Hold | ${ }^{t}$ DR | - | 0 | - |  |

[^8](4) READ mode (With use of ALE)
$\left(V_{D D}=5 \mathrm{~V} \pm 10 \%, \mathrm{Ta}=-30 \sim+85^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Condition | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{CS}_{1}$ Set up Time | ${ }^{\text {c }}$ c1s | - | 1000 | - | ns |
| Address Set up Time | ${ }^{t}$ AS | - | 25 | - |  |
| Address Hold Time | ${ }^{\text {t }}$ A ${ }^{\text {H }}$ | - | 25 | - |  |
| ALE Pulse Width | taw | - | 40 | - |  |
| ALE Before READ | ${ }^{\text {t ALR }}$ | - | 10 | - |  |
| ALE after READ | traL | - | 10 | - |  |
| RD to Data | ${ }^{\text {tRD }}$ | $C_{L}=150 \mathrm{pF}$ | - | 120 |  |
| DATA Hold | ${ }^{\text {t }}$ DR | - | 0 | - |  |
| $\mathrm{CS}_{1}$ Hold Time | ${ }^{t} \mathrm{C} 1 \mathrm{H}$ | - | 1000 | - |  |



Figure 7. Read Cycle - (With Use of ALE)

## PIN DESCRIPTION

| Name | Pin No. |  | Description |
| :---: | :---: | :---: | :---: |
|  | RS | GS |  |
| $\mathrm{D}_{0}$ | 14 | 19 | Data Input/Output pins to be directly connected to a microcontroller bus for reading and writing of the clock/calendar's registers and control registers. DO $=$ LSB and D3 $=$ MSB . |
| $\mathrm{D}_{1}$ | 13 | 16 |  |
| $\mathrm{D}_{2}$ | 12 | 15 |  |
| $\mathrm{D}_{3}$ | 11 | 14 |  |
| $\mathrm{A}_{0}$ | 4 | 5 | Address input pin for use by a microcomputer to select internal clock/calendar's registers and control registers for Read/Write operations (See Function Table Figure 1). Address input pins AO-A3 are used in combination with ALE for addressing registers. |
| $\mathrm{A}_{1}$ | 5 | 7 |  |
| $\mathrm{A}_{2}$ | 6 | 9 |  |
| $\mathrm{A}_{3}$ | 7 | 10 |  |
| ALE | 3 | 4 | Address Latch Enable pin. This pin enables writing of address data when $A L E=1$ and $\overline{C S O}=0$; address data is latched when ALE $=0$ Microcontroller/Microprocessors having an ALE output should connect to this pin; otherwise it should be connected at $V_{\text {DD }}$. |
| WR | 10 | 13 | Writing of data is performed by this pin. <br> When $\mathrm{CS}_{1}=1$ and $\overline{\mathrm{CS}_{0}}=0, \mathrm{D}_{0} \sim \mathrm{D}_{3}$ data is written into the register at the rising edge of WR. |
| $\overline{\mathrm{RD}}$ | 8 | 11 | Reading of register data is accomplished using this pin. When $\mathrm{CS}_{1}=1, \mathrm{CS}_{0}=0$ and $\overline{R D}=0$, the data of the register is output to $D_{0} \sim D_{3}$. If both $R D$ and $W R$ are set at 0 simaltanuously, $\overline{R D}$ is to be inhibited. |
| $\overline{\mathrm{CS}_{0}}$ | 2 | 2 | Chip Select Pins. These pins enable/disable ALE, $\overline{R D}$ and $\overline{W R}$ operation. $\overline{\mathrm{CS}_{0}}$ and ALE work in combination with one another, while $\mathrm{CS}_{1}$ work independent with ALE. CS ${ }_{1}$ must be connected to power failure detection as shown in Figure 18. |
| $\mathrm{CS}_{1}$ | 15 | 20 |  |
| STD.P | 1 | 1 | Output pin of N-CH OPEN DRAIN type. The output data is controlled by the $\mathrm{D}_{1}$ data content of $\mathrm{C}_{\mathrm{E}}$ register. This pin has a priority to $\overline{\mathrm{CS}_{0}}$ and $\mathrm{CS}_{1}$. <br> Refer to Figure 9 and FUNCTIONAL DESCRIPTION OF REGISTERS. |
| XT | 16 | 22 | 32.768 kHz crystal is to be connected to these pins. <br> When an external clock of 32.768 kHz is to be used for MSM6242's oscillation source, either CMOS output or pull-up TTL output is to be input from XT , while $\overline{\mathrm{XT}}$ should be left open. |
| $\bar{X} \mathbf{T}$ | 17 | 23 |  |
| VDD | 18 | 24 | Power supply pin. $+2 \sim+6 \mathrm{~V}$ power is to be applied to this pin. |
| GND | 9 | 12 | Ground pin. |
|  |  |  | The impedance of the crystal should be less than $30 \mathrm{k} \Omega$ <br> Figure 9. |

## FUNCTIONAL DESCRIPTION OF REGISTERS

- $S_{1}, S_{10}, M I_{1}, M I_{10}, H_{1}, H_{10}, D_{1}, D_{10}, M \bar{O}_{1}, M \bar{O}_{10}, Y_{1}, Y_{10}, W$
a) These are abbreviations for SECOND1, SECOND10, MINUTE1, MINUTE10, HOUR1, HOUR10, DAY1, DAY10, MONTH1, MONTH10, YEAR1, YEAR10, and WEEK. These values are in BCD notation.
b) All registers are logically positive. For example, (S8, S4, S2, S1) $=1001$ which means 9 seconds.
c) If data is written which is out of the clock register data limits, it can result in erroneous clock data being read back.
d) PM/AM, $h_{20}, h_{10}$

In the mode setting of 24 -hour mode, PM/AM bit is ignored, while in the setting of 12 -hour mode $h_{20}$ is to be set. Otherwise it causes a discrepancy.In reading out the PM/AM bit in the 24 -hour mode, it is continuously read out as 0 . In reading out $h_{20}$ bit in the 12 -hour mode, $\mathbf{0}$ is written into this bit first, then it is continuously read out as 0 unless 1 is being written into this bit.
e) Registers Y1, Y10, and Leap Year. The MSM6242B is designed exclusively for the Christian Era and is capable of identifying a leap year automatically. The result of the setting of a non-existant day of the month is shown in the following example: If the date February 29 or November 31, 1985, was written, it would be changed automatically to Match 1, or December 1, 1985 at the exact time at which a carry pulse occurs for the day's digit.
f) The Register $\mathbf{W}$ data limits are 0-6 (Table 1 shows a possible data definition).

| TABLE 1 |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| $\qquad$$w_{4}$ $w_{2}$ $w_{1}$ Day of Week <br> 0 0 0 Sunday <br> 0 0 1 Monday <br> 0 1 0 Tuesday <br> 0 1 1 Wednesday <br> 1 0 0 Thursday <br> 1 0 1 Friday <br> 1 1 0 Saturday |  |  |  |  |




## - CD REGISTER (Control D Register)

a) HOLD (DO) - Setting this bit to a " 1 " inhibits the 1 Hz clock to the $\mathbf{S 1}$ counter, at which time the Busy status bit can be read. When Busy $=0$, register's $S_{1} \sim \bar{W}$ can be read or written. During this procedure if a carry occurs the S1 counter will be incremented by 1 second after HOLD $=0$ (this condition is guaranteed as long as HOLD $=1$ does not exceed 1 second in duration). If CS1 $=0$ then HOLD $=0$ irrespective of any condition.
b) BUSY (D1) - Status bit which shows the interface condition with microcontroller/microprocessors. As for the method of writing into and reading from $S_{1} \sim W$ (address $\phi \sim C$ ), refer to the flow chart described in Figure 10.
c) IRQ FLAG (D2) - This status bit corresponds to the output level of the STD.P output. When STD.P = 0, then $\operatorname{IRQ}=1$; when $S T D . P=1$, then $I R Q=0$. The IRQ FLAG indicates that an interrupt has occurred to the microcomputer if $I R Q=1$. When DO of register $C_{E}($ MASK $)=0$, then the STD.P output changes according to the timing set by D3 $\left(t_{1}\right)$ and $D 2\left(t_{0}\right)$ of register $E$. When D1 of register $E$ (ITRPT/STND) $=1$ (interrupt mode), the STD.P output remains low until the IRQ FLAG is written to a " 0 ". When IRQ = 1 and timing for a new interrupt occurs, the new interrupt is ignored. When ITRPT/STND $=0$ (Standard Pulse Output mode) the STD.P output remains low until either " 0 " is written to the IRQ FLAG; otherwise, the IRQ FLAG automatically goes to " 0 " after 7.8125 ms .
When writing the HOLD or 30 second adjust bits of register $D$, it is necessary to write the IRQ FLAG bit to a " 1 ".
d) $\pm 30$ ADJ (D3) - When 30 -second adjustment is necessary, a " 1 " is written to bit D3 during which time the internal clock registers should not be read from or written to $125 \mu$ s after bit D3 $=1$ it will automatically return to a " 0 ", and at that time reading or writing of registers can occur.


Figure 11. Writing 30-Second Adj. bit (Two Ways A, B)

## - CE REGISTER (Control E Register)

a) MASK (DO) - This bit controls the STD.P output. When MASK = 1, then STD.P = 1 (open); when MASK $=0$, then STD.P = output mode. The relationship between the MASK bit and STD.P output is shown Figure 12.
b) INTRPT/STND (D1) - The INTRPT/STND input is used to switch the STD.P output between its two modes of operation, interrupt and Standard timing waveforms. When INTRPT/STND 0 a fixed cycle waveform with a low-level pulse width of 7.8125 ms is present at the STD.P output. At this time the MASK bit must equal 0 , while the period in either mode is determined by TO(D2) and T1 (D3) of Register $E$.
c) T0 (D2), T1 (D3) - These two bits determine the period of the STD.P output in both Interrupt and Fixed timing waveform modes. The tables below show the timing associated with the T0, T1 inputs as well as their relationship to INTRPT/STND and STD.P.


Figure 12.

| $\mathrm{t}_{1}$ | $\mathrm{t}_{0}$ | Period | Duty CYCLE of ' 0 '' level when <br> ITRPT/STND bit is " 0 "'. |
| :---: | :---: | :--- | :--- |
| 0 | 0 | $1 / 64$ second | $1 / 2$ |
| 0 | 1 | 1 second | $1 / 128$ |
| 1 | 0 | 1 minute | $1 / 7680$ |
| 1 | 1 | 1 hour | $1 / 460800$ |

TABLE 2

The timing of the STD.P output designated by T 1 and TO occurs the moment that a carry occurs to a clock digit.

d) The low-level pulse width of the fixed cycle waveform (ITRPT/STND $=0$ ) is 7.8125 ms independent of $\mathrm{TO} / \mathrm{T} 1$ inputs.
e) The fixed cycle waveform mode can be used for adjustment of the oscillator frequency time base. (See Figure 14).
f) During $\pm 30$ second adjustment a carry can occur that will cause the STD.P output to go low when TO/T1 $=1,0$ or 1,1 . However, when $T 1 / T 0=0,0$ and ITRPT/STND $=0$, carry does not occur and the STD.P output resumes normal operation.
g) The STD.P output is held (frozen) at the point at which STOP $=1$ while ITRPT/STND $=0$.
h) No STD.P output change occurs as a result of writing data to registers S1 $\sim \mathrm{H} 1$.

## - CF REGISTER (Control F Register)

a) REST (DO) - This bit is used to clear the clock's internal divider/counter of less than a second. When "RESET" REST $=1$, the counter is Reset for the duration of REST. In order to release this counter from Reset, a " 0 " must be written to the REST bit. If CSI = 0 then REST = 0 automatically.
b) STOP (D1) - The STOP FLAG Only inhibits carries into the 8192 Hz divider stage. There may be up to $122 \mu_{\mathrm{s}}$ delay before timing starts or stops after changing this flag; $1=\mathrm{STOP} / 0=$ RUN.

c) $24 / 12$ (D2) - This bit is for selection of $24 / 12$ hour time modes. If $D 2=1-24$ hour mode is selected and the $P M / A M$ bit is invalid. If D2 $=0-12$ hour mode is selected and the PM/AM bit is valid.
" 24 HOUR/ Setting of the 24/12 hour bit is as follows:
12 HOUR" $^{\prime \prime}$ 1) REST bit $=1$
2) $24 / 12$ hour bit $=0$ or 1
3) REST bit $=0$

* REST bit must $=1$ to write to the $24 / 12$ hour bit.
d) TEST (d3) - When the TEST flag is a " 1 ", the input to the SECONDS counter comes from the counter/divider stage instead of the 15 th divider stage. This makes the SECONDS counter count at 5.4163 KHz instead of 1 Hz . When TEST $=1$ (Test Mode) the STOP \& REST (Reset) flags do not inhibit internal counting. When Hold $=1$ during Test (Test $=1$ ) internal counting is inhibited; however, when the HOLD FLAG goes inactive $(\mathrm{Hold}=0)$ counter updating is not guaranteed.

TYPICAL APPLICATION INTERFACE WITH MSM6242B AND MICROCONTROLLERS


Figure 15.


Figure 16.


Figure 17.

## TYPICAL APPLICATIONS - INTERFACE WITH MSM80C49



Figure 18.

## APPLICATION NOTE

## 1. Power Supply



## 2. Adjustment of Frequency


$C_{D} \sim C_{F}$ are to be set at as described in the figure and the capacitor is to be adjusted to meet the settle frequency of $t_{0}$ and $t_{1}$. If the right oscillation can not be obtained,

1. Check the waveform of XT
2. Check $C_{D} \sim C_{F}$ content
3. Check the noise.


## 3. $\mathrm{CH}_{1}$ (Chip Select)

$\mathrm{V}_{\mathrm{IH}}$ and $\mathrm{V}_{\mathrm{IL}}$ of $\mathrm{CH}_{1}$ has 3 functions.
a) To accomplish the interface with a microcontroller/microprocessor.
b) To inhibit the control bus, data bus and address bus and to reduce input gate pass current in the stand-by mode.
c) To protect internal data when the mode is moved to and from standby mode.

To realize the above functions:
a) More than $4 / 5 V_{D D}$ should be applied to the MSM6242B for the interface with a microcontroiler/microprocessor in 5 V operation.
b) In moving to the standby mode, $1 / 5 \mathrm{~V}_{\mathrm{DD}}$ should be applied so that all data buses should be disabled. In the standby mode, approx. OV should be applied.
c). To and from the standby mode, obey following Timing chart.

4. Set STD.P at arlarm mode

Set alarm at 9:00


## TYPICAL APPLICATION - POWER SUPPLY CIRCUIT



## SUPPLEMENTARY DESCRIPTION

O When " 0 '" is written to the IRQ FLAG bit, the IRQ FLAG bit is cleared. However, if " 0 ' is assigned to the IRO FLAG bit when written to the other bits, the $30-\mathrm{sec}$ ADJ bit and the HOLD bit, the IRO FLAG $=1$ and was generated before the writing and IRQ FLG $=1$ generated in a moment then will be cleared. To avoid this, always set " 1 " to the IRQ FLAG unless " 0 " is written to it intentionally. By writing " 1 " to it, the IRQ FLAG bit does not become " 1 ".

- Since the IRQ FLAG bit becomes " 1 " in some cases when rewriting either of the $t_{1}$, $t_{0}$, or ITRPT/STND bit of register $C_{E}$, be sure to write " 0 ' to the IRQ FLAG bit after writing to make valid the IRQ FLAG $=1$ to be generated after it.
- The relationship between SDT. P OUT and IRO FLAG bit is shown below:

STD. P OUT
IRO FLAG bit


## NOTICE

1. The information contained herein can change without notice owing to product and/or technical improvements. Please make sure before using the product that the information you are referring to is up-to-dated.
2. The outline of action and examples of application circuits described herein have been chosen as an explanation of the standard action and performance of the product. When you actually plan to use the product, please ensure that the outside conditions are reflected in the actual circuit and assembling designs.
3. NO RESPONSIBILITY IS ASSUMED BY US FOR ANY CONSEQUENCE RESULTING FROM ANY WRONG OR IMPROPER USE OR OPERATION, ETC. OF THE PRODUCT.
4. Neither indemnity against nor license of a third party's industrial and intellectual property right, etc. is granted by us in connection with the use of the product and/or the information and drawings contained herein. No responsibility is assumed by us for any infringement of a third party's right which may result from the use thereof.
5. Certain product described herein falls within the category of strategical goods, etc. under Foreign Exchange and Foreign Trade Control Law. Accordingly, before exporting such product, you are required under the Law to file the application for the export license by the Japanese Government.
6. No part of the contents contained herein may be reprinted or reproduced without our prior permission.
7. MS-DOS is a registered trademark of Microsoft Corporation.

## Copyright 1990 OKI SEMICONDUCTOR

## Oki Semiconductor

785 North Mary Avenue. Sunnyvale, CA 94086, U.S.A. Tel: 408-720-1900 Fax: 408-720-1918
For further information please contact:


## Oki Semiconductor

785 North Mary Avenue. Sunnyvale, CA 94086, U.S.A. Tel: 408-720-1900 Fax: 408-720-1918

For further information please contact:


Oki Electric Industry Co., Ltd. Head Office Annex 7-5-25 Nishishinjuku, Shinjuku-ku. Tokyo 160. Japan Tel 3-5386-8100 Fax 3-5386-8110 Telex: J27662 OKIDENED Electronic Devices Group Overseas Marketing Dept

## Oki Semiconductor

785 North Mary Avenue
Sunnyvale, CA 94086. U S A
Tel 408-720-1900
Fax: 408-720-1918
Telex 296687 OKI SNTA

Oki Electric Europe GmbH
Hellersbergstralie 2
D-4040 Neuss
Fed Rep of Germany
Tel 2101-15960
Fax 2101-103539
Telex 8517427 OKI D

Oki Electronics (Hong Kong) Lid.
Suite 1801-4. Tower 1 .
China Hong Kong City,
33 Canton Road Tsim Sha Tsui,
Kowloon, Hong Kong
Tel 3-7362336
Fax: 3-7362395
Telex: 45999 OKIHK HX


[^0]:    NOTE: MSM80C85AH and MSM81C55H are under development.

[^1]:    0 = Logic " 0 "
    $1=$ Logic " 1 "
    TS= High Impedance
    $X=$ Unspecified

[^2]:    * $X_{2}$ Left floating

[^3]:    *1 Only CLK, *2 Except CLK.

[^4]:    x: Don't care.

[^5]:    ST: : Start bit
    SP: : Stop bit
    P: : Parity bit
    D0-D7: Data bits

[^6]:    Initialization Command Words (ICW1 thru ICW4)

[^7]:    ${ }^{\mathrm{t}} \mathrm{SHS} 1=1 \mu \mathrm{~s}, \mathrm{t} \mathrm{SHS} 10=2 \mu \mathrm{~s}, \mathrm{t}$ SHMI1 $=3 \mu \mathrm{~s}, \mathrm{tSHM} 10=4 \mu \mathrm{~s}, \mathrm{tSHH} 1=5 \mu \mathrm{~s}$
    
    ${ }^{\text {t }} \mathrm{SHMO10}=10 \mu \mathrm{~s}, \mathrm{t}_{\mathrm{SHY}}=11 \mu \mathrm{~s}, \mathrm{t} \mathrm{SHY} 10=12 \mu \mathrm{~s}$.

[^8]:    Figure 6. Read Cycle - (ALE = VDD)

