## WM

Western Microtechnology 12900 Saratoga Avenue Saratoga, CA 95070 Phone (408) 725-1660 FAX\# (408) 255-6491

## Microprocessors <br> 8/16-Bit Microcomputers Peripherals

## 8 / 16-Bit <br> Microprocessors <br> Microcomputers <br> Peripherals

## Fujitsu Limited

Fujitsu Microelectronics, Inc.
Fujitsu Mikroelektronik GmbH
Fujitsu Microelectronics Pacific Asia Ltd.
Worldwide Suppliers of Communications and Electronics Equipment

Copyright ${ }^{\oplus} 1986$ by Fujitsu Limited and Fujitsu Microelectronics, Inc.

Copyright ${ }^{\circledR} 1986$ Fujitsu Limited, Tokyo, Japan, and Fujlitsu Microelectronics, Inc.
All Rights Reserved.

Circuit diagrams utilizing Fujitsu products are included as a means of illustrating typical semiconductor applications. Consequently, complete information sufficient for construction purposes is not necessarily given.

The information contained in this document has been carefully checked and is believed to be entirely reliable. However, Fujitsu Limited and its subsidiaries assume no responsibility for inaccuracies.

The information conveyed in this document does not convey any license under the copyrights, patent rights or trade marks claimed and owned by Fujitsu Limited or its subsidiaries.

Fujitsu Limited and its subsidiaries reserve the right to change products or specifications without notice.
This document is published by the Technical Publications Department, Fujitsu Microelectronics, Inc., 3320 Scott Blvd., Santa Clara, California, U.S.A. 95054-3197.

Printed in the U.S.A.
Edition 1.0

## Fujitsu Limited

Fujitsu Limited, headquartered near Tokyo, Japan, is Japan's largest supplier of computers and ranks in the top ten companies operating in Japan. Fujitsu is also one of the world's largest suppliers of telecommunications equipment and semiconductor devices.

Established in 1935 as the Communications Division spinoff of Fuji Electric Company Limited, Fujitsu Limited, in 1985, celebrated 50 years of service to the world through the development and manufacture of state-of-the-art products in data processing, telecommunications and semiconductors. Fujitsu operates subsidiaries worldwide in two dozen countries and employs over 80,000 people to generate annual sales in excess of nine billion US dollars. (Year ended March 31, 1986 consolidated base.)

Fujitsu has five plants in key industrial regions in Japan covering all steps of semiconductor production. Five wholly owned Japanese subsidiaries provide additional capacity for production of advanced semiconductor devices. Two additional facilities operate in the U.S. and Europe to help meet the growing worldwide demand for Fujitsu semiconductor products. In all, Fujitsu operations occupy over 1.6 million square meters of manufacturing space worldwide.

In 1975, Fujitsu developed 8-bit microcomputers. In 1977, Fujitsu introduced proprietary 4-bit microcomputers. Today, their 4-bit microcomputer family is the largest 4-bit product line in the world. With the development of the high performance 16-bit micropcocessors, Fujitsu offers a full line of microprocessors, microcomputers, and peripherals to provide designers with a total of 150 products, including 90 products in CMOS families, 50 products in NMOS families and 10 products in bipolar peripherals.

In 1983, Fujitsu introduced the world's first CMOS single-chip Digital Signal Processor, the MB8764. Fujitsu's DSP provides telecommunication designers with high-speed signal processing capabilities and at a cost-effective solution.

Other Fujitsu industry standard products include GaAs FETs, GaAs FET amplifiers, Si microwave transistors and light wave semiconductors. Discrete products include power-switching transistors and Darlington Array transistors.

Fujitsu's custom product lines include application-specific gate arrays and standard-cell arrays using high-speed Bipolar and ECL technologies and advanced CMOS technologies. Gate arrays ranging in size from 350 to 20,000 gates are available in up to 8,000 gate equivalents and include on-chip memory and program logic array.

Virtually every major type of electronics equipment on the globe utilizes Fujitsu technology in integrated circuits. Fujitsu's leadership position in worldwide integrated circuit development and manufacturing assures equipment manufacturers that they will always be able to design with the latest in technology utilizing the highest standards of quality and reliability.

Fujitsu Microelectronics, Inc.
Established in 1979, Fujitsu Microelectronics, Inc., headquartered in Santa Clara, California, markets Fujitsu semiconductors through representatives located throughout the U.S. and North America.

The Component Division, Fujitsu Component of America, Inc., markets bubble memories, keyboards, plasma displays, relay switches and hybrid ICs.

FMI's San Diego manufacturing facility provides capacity for manufacturing of many high-technology devices for the U.S. and North American market.

Customer support for custom designs is available through Fujtsu's design centers in Santa Clara, Dallas and Boston. Technology Centers offering on-site customer training, CAE design facilities and design assistance are planned.

## Fujitsu Mikroelektronik GmbH (European Sales Center)

Fujitsu Mikroelektronick GmbH (FMG) was established in June, 1980, in Frankfurt, West Germany, and is a totally owned subsidiary of Fujitsu Limited, Tokyo. FMG is the sole representative of the Fujitsu Electronic Device Group in Western Europe. The wide range of IC products, LSI memories and, in particular, gate arrays are noted throughout Western Europe for design excellence and unmatched reliability. Five branch offices to support Fujitsu's semiconductor operations are located in Munich, London, Paris, Stockholm, and Milan.

## Fujitsu Microelectronics Ireland, Ltd (European Production Center)

Fujitsu Microelectronics Ireland, Ltd. (FME) was established in 1980 in the suburbs of Dublin as Fujitsu's European Production Center for integrated circuits. FME supplies 64K/256K DRAMs, 64K CMOS/NMOS EPROMs, 256 K EPROMs, and other LSI memory products.

Fujitsu Microelectronics, Ltd (European Design Center)
Fujitsu Microelectronics, Ltd., Fujitsu's European VLSI Design Center, opened in October of 1983 in Manchester, England. The Design Center is equipped with a highly-sophisticated CAD system to ensure fast and reliable processing of input data. An experienced staff of engineers is available to assist in all phases of the design process.

Fujitsu Microelectronics Pacific Asia Ltd. (Asian/Oceanian Sales Centre)
Fujitsu Microelectronics Pacific Asia Ltd. (FMP) opened in August 1986 in Hong Kong as a wholly-owned Fujitsu subsidiary for sales of electronic devices to Asian and Southwest Pacific markets.

Fujitsu MCU/MPU Development History
August 1986


Production

## Table of Contents

| Section 1 | Microprocessors and Peripherals |  |  |
| :---: | :---: | :---: | :---: |
|  | MBL80286 Microprocessor Family |  |  |
|  | 1-2 | MBL80286-8 | NMOS High-Performance 16-Bit Microprocessor with Memory Management and Protection |
|  | 1-2 | MBL80286-6 | NMOS High-Performance 16-Bit Microprocessor with Memory Management and Protection |
|  | 1-59 | MBL82284-8 | Bipolar Block Generator and Ready Interface for MBL 80286 Processors |
|  | 1-59 | MBL82284-6 | Bipolar Block Generator and Ready Interface for MBL80286 Processors |
|  | 1-70 | MBL82288-8 | NMOS Bus Controller for MBL80286 Processors |
|  | 1-70 | MBL82288-6 | NMOS Bus Controller for MBL80286 Processors |
|  | MBL8086/8088/80186/80188 Microprocessor Family and Peripherals |  |  |
|  | 1-90 | MBL80186 | NMOS High-Integration 16-Bit Microprocessor |
|  | 1-90 | MBL80186-6 | NMOS High-Integration 16-Bit Microprocessor |
|  | 1-144 | MBL8086 | NMOS 16-blt Microprocessor |
|  | 1-144 | MBL8086-2 | NMOS 16-bit Microprocessor |
|  | 1-144 | MBL8086-1 | NMOS 16-bit Microprocessor |
|  | 1-172 | MBL80188 | NMOS High-Integration 8-Bit Microprocessor |
|  | 1-172 | MBL80188-6 | NMOS High-Integration 8-Bit Microprocessor |
|  | 1-226 | MBL8088 | NMOS 8-Bit Microprocessor |
|  | 1-226 | MBL8088-2 | NMOS 8-Bit Microprocessor |
|  | 1-226 | MBL8088-1 | NMOS 8-Bit Microprocessor |
|  | 1-256 | MBL8089 | NMOS 8 \& 16-Bit I/O Processor |
|  | 1-256 | MBL8089-2 | NMOS 8 \& 16-Bit I/O Processor |
|  | 1-272 | MBL8259A | NMOS Programmable Interrupt Controller |
|  | 1-272 | MBL8259A-2 | NMOS Programmable Interrupt Controller |
|  | 1-294 | MBL8282 | Bipolar Octal Latch |
|  | 1-294 | MBL8283 | Bipolar Octal Latch |
|  | 1-300 | MBL8284A | Blpolar Clock Generator/Driver for MBL8086/ MBL8088/MBL8089 |
|  | 1-300 | MBL8284A-1 | Bipolar Clock Generator/Driver for MBL8086/ MBL8088/MBL8089 |
|  | 1-311 | MBL8286 | Bipolar Octal Bus Transceiver |
|  | 1-311 | MBL8287 | Bipolar Octal Bus Transceiver |
|  | 1-317 | MBL8288 | Bus Controller for MBL8086/MBL8088/MBL8089 Processors |
|  | 1-326 | MBL8289 | Bus Arbiter |

## Section 2 Microcomputers and Peripherals

## 8-Bit Microcomputers and Peripherals

| $2-2$ | MBL8048N/E/H | NMOS Single-Chip 8-Bit Microcomputer |
| :--- | :--- | :--- |
| $2-2$ | MBL0035N/E/H | NMOS Single-Chip 8-Bit Microcomputer |
| $2-22$ | MBL8049N/E/H | NMOS Single-Cip 8-Bit Microcomputer |
| $2-22$ | MBL8039N/E/H | NMOS Single-Chip 8-Bit Microcomputer |
| $2-42$ | MBL8749H/N | NMOS Single-Chip 8-Bit Microcomputer |
| $2-67$ | MBL8051AH | NMOS Single-Chip 8-Bit Microcomputer |
| $2-67$ | MBL8031AH | NMOS Single-Chip 8-Bit Microcomputer |
| $2-86$ | MBL80C49H/N | CMOS Single-Chip 8-Bit Microcomputer |
| $2-86$ | MBL80C39H/N | CMOS Single-Chip 8-Bit Microcomputer |
| $2-114$ | MBL8243 | NMOS Input/Output Expander |
| $2-124$ | MBL82C43 | CMOS Input/Output Expander |





Section $7 \quad$\begin{tabular}{c}
ROM <br>
<br>
<br>
<br>
$7-2$ <br>
$7-3$

 

Code Development Procedure <br>
Flowchart
\end{tabular}

Section $8 \quad \underset{8-2}{\text { Quality }} \underset{\substack{\text { Assurance } \\ \text { Flowchart }}}{ }$ and Reliability

Section $9 \quad$ Ordering Information

| 9-2 | Product Marking |
| :--- | :--- |
| $9-2$ | Ordering Codes |

## Alphanumeric Index

| Part Number | Page |
| :---: | :---: |
| MB Prefix |  |
| MB502A | 5-2 |
| MB1412A | 3-23 |
| MB1422A | 3-2 |
| MB1426 | 3-39 |
| MB1430 | 3-22 |
| MB4107 | 4-57 |
| MB4111 | 4-65 |
| MB4112 | 4-65 |
| MB4113 | 4-65 |
| MB4316 | 4-76 |
| MB8764 | 6-2 |
| MB8795B | 5-22 |
| MB8867 | 4-194 |
| MB8867E | 4-194 |
| MB8868A | 4-183 |
| MB8876A | 4-27 |
| MB8877A | 4-27 |
| MB87030 | 4-122 |
| MB87064 | 6-21 |
| MB87067 | 6-33 |
| MB87068 | 6-33 |
| MB87069 | 6-38 |
| MB88301A | 2-160 |
| MB88303 | 4-81 |
| MB88304 | 2-171 |
| MB88305 | 2-171 |
| MB88306 | 2-192 |
| MB88307 | 2-192 |
| MB88308 | 2-192 |
| MB88309 | 2-192 |
| MB88310 | 2-181 |
| MB88311 | 2-181 |


| Part Number | Page | Part Number | Page |
| :---: | :---: | :---: | :---: |
| MB88313 | 4-98 | MBL8086-1 | 1-144 |
| MB89237A | 4-207 | MBL8086-2 | 1-144 |
| MB89251A | 4-208 | MBL8088 | 1-226 |
| MB89254 | 4-209 | MBL8088-1 | 1-226 |
|  |  | MBL8088-2 | 1-226 |
| MB89255A | 4-210 |  |  |
| MB89259A | 4-211 | MBL8089 | 1-256 |
|  |  | MBL8089-2 | 1-256 |
| MB89282 | 4-212 |  |  |
| MB89283 | 4-212 | MBL8243 | 2-114 |
| MB89284A | 4-213 | MBL82C43 | 2-124 |
| MB89286 | 4-214 |  |  |
| MB89287 | 4-214 | MBL8259A | 1-272 |
| MB89288 | 4-215 | MBL8259A-2 | 1-272 |
| MB89289 | 4-216 |  |  |
|  |  | MBL8282 | 1-294 |
| MB89311 | 4-44 | MBL8283 | 1-294 |
| MB89321A | 4-2 |  |  |
| MB89321B | 4-25 | MBL8284A | 1-300 |
| MB89322A | 4-2 | MBL8284A-1 | 1-300 |
| MB89322B | 4-25 | MBL8286 | 1-311 |
| MB89341 | 4-26 | MBL8287 | 1-311 |
|  |  | MBL8288 | 1-317 |
| MBL Prefix |  | MBL8289 | 1-326 |
| MBL8031AH | 2-67 | MBL8742H/N | 4-164 |
| MBL8035N/E/H | 2-2 | MBL8749H/N | 2-42 |
| MBL8039N/E/H | 2-22 |  |  |
| MBL80C39H/N | 2-86 | MBL80186 | 1-90 |
|  |  | MBL80186-6 | $1-90$ |
| MBL8041AH/E/N | - $4-130$ | MBL80188 | 1-172 |
| MBL8042H/N | 4-147 | MBL80188-6 | 1-172 |
| MBL8048N/E/H | 2-2 |  |  |
| MBL8049N/E/H | 2-22 | MBL80286-6 | 1-2 |
|  |  | MBL80286-8x | 1-2 |
| MBL80C49H/N | 2-86 |  |  |
|  |  | MBL82284-6 | 1-59 |
| MBL8051AH | 2-67 | MBL82284-8 | 1-59 |
|  |  | MBL82288-6 | 1-70 |
| MBL8086 | $1-144$ | MBL82288-8 | $1-70$ |

## Section 1

## Microprocessors and Peripherals

| MBL80286 Microprocessor Family |  |  |
| :---: | :---: | :---: |
| 1-2 | MBL80286-8 | NMOS High-Performance 16-Bit Microprocessor with Memory Management and Protection |
| 1-2 | MBL80286-6 | NMOS High-Performance 16-Bit Microprocessor with Memory Management and Protection |
| 1-59 | MBL82284-8 | Bipolar Block Generator and Ready Interface for MBL80286 Processors |
| 1-59 | MBL82284-6 | Bipolar Block Generator and Ready Interface for MBL80286 Processors |
| 1-70 | MBL82288-8 | NMOS Bus Controller for MBL80286 Processors |
| 1-70 | MBL82288-6 | NMOS Bus Controller for MBL80286 Processors |
| MBL8086/8088/80186/80188 Microprocessor Family and Peripherals |  |  |
| 1-90 | MBL80186 | NMOS High-Integration 16-Bit Microprocessor |
| 1-90 | MBL80186-6 | NMOS High-Integration 16-Bit Microprocessor |
| 1-144 | MBL8086 | NMOS 16-bit Microprocessor |
| 1-144 | MBL8086-2 | NMOS 16-bit Microprocessor |
| 1-144 | MBL8086-1 | NMOS 16-bit Microprocessor |
| 1-172 | MBL80188 | NMOS High-Integration 8-Blt Microprocessor |
| 1-172 | MBL80188-6 | NMOS High-Integration 8-Bit Microprocessor |
| $1-226$ | MBL8088 | NMOS 8-Bit Microprocessor |
| 1-226 | MBL8088-2 | NMOS 8-Bit Microprocessor |
| 1-226 | MBL8088-1 | NMOS 8-Bit Microprocessor |
| 1-256 | MBL8089 | NMOS 8 \& 16-Bit I/O Processor |
| 1-256 | MBL8089-2 | NMOS 8 \& 16-Bit I/O Processor |
| 1-272 | MBL8259A | NMOS Programmable Interrupt Controller |
| 1-272 | MBL8259A-2 | NMOS Programmable Interrupt Controller |
| 1-294 | MBL8282 | Bipolar Octal Latch |
| 1-294 | MBL8283 | Bipolar Octal Latch |
| 1-300 | MBL8284A | Bipolar Clock Generator/Driver for MBL8086/ MBL8088/MBL8089 |
| 1-300 | MBL8284A-1 | Bipolar Clock Generator/Driver for MBL8086/ MBL8088/MBL8089 |
| 1-311 | MBL8286 | Bipolar Octal Bus Transceiver |
| 1-311 | MBL8287 | Bipolar Octal Bus Transceiver |
| 1-317 | MBL8288 | Bus Controller for MBL8086/MBL8088/MBL8089 Processors |
| 1-326 | MBL8289 | Bus Arbiter |

## FUJITSU

## NMOS HIGH PERFORMANCE 16-BIT MICROPROCESSOR WITH MEMORY MANAGEMENT AND PROTECTION

The Fujitsu MBL 80286 is an advanced, high-performance 16 -bit microprocessor with specially optimized capabilities for multiple user and multi-tasking systems. The MBL 80286 has built-in memory protection that supports operating system and task isolation as well as program and data privacy within tasks. An 8 MHz MBL 80286 provides up to six times greater throughout than the standard 5 MHz MBL 8086. The MBL 80286 includes memory management capabilities that map up to $2^{30}$ (one gigabyte) of virtual address space per task into $2^{24}$ bytes ( 16 megabytes) of physical memory.

The MBL 80286 is upward compatible with MBL 8086 and 88 software. Using MBL 8086 real address mode, the MBL 80286 is object code compatible with existing MBL 8086, 88 software. In protected virtual address mode, the MBL 80286 is source code compatible with MBL 8086, 88 software and may require upgrading to use virtual addresses supported by the MBL 80286's integrated memory management and protection mechanism. Both modes operate at full MBL 80286 performance and execute a superset of the MBL 8086 and 88 's instructions.

The MBL 80286 provides special operations to support the efficient implementation and execution of operating systems. For example, one instruction can end execution of one task, save its state, switch to a new task, load its state, and start execution of the new task. The MBL 80286 also supports virtual memory systems by providing a segment-not-present exception and restartable instructions.

The MBL 80286 is housed in a 68 -pad ceramic LCC (Leadless Chip Carrier: JEDEC Type A) or a 68 -pin ceramic PGA (Pin Grid Array) package.

- High Performance Processor (Up to six times MBL 8086)
- Large Address Space:
- 16 Megabytes Physical
- 1 Gigabyte Virtual per Task
- Integrated Memory Management, Four-Level Memory Protection and Support for Virtual Memory and Operating Systems
- Two MBL 8086 Upward Compatible Operating Modes:
- MBL 8086 Real Address Mode
- Protected Virtual Address Mode
- Two Ranges of Clock Rates:
- 8 MHz for MBL 80286-8
- 6 MHz for MBL 80286-6
- Optional Processor Extension:
- MBL 80286 and Intel 80287 High Performance 80-bit Numeric Data Processor
- High Bandwidth Bus Interface (8 Megabyte/Sec)
- Two Package Options:
- 68-Pad Ceramic LCC (Suffix - CV) (JEDEC Type A)
- 68-Pin Ceramic PGA (Suffix - CR)


Portions Reprinted by Permission of Intel Corporation
(c) Intel Corporation, 1985
© FUJITSU LIMITED, 1986

Fig. 2 - PIN CONFIGURATIONS


68-PIN PGA
TOP VIEW
BOTTOM VIEW


NOTE: N.C. pads and pins must not be connected.

## PIN DESCRIPTION

The following pin function descriptions are for the MBL 80286 microprocessor:

Table 1 - PIN DESCRIPTION

| Symbol | Type | Name and Function |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CLK | 1 | System Clock provides the fundamental timing for MBL 80286 systems. It is divided by two inside the MBL 80286 to generate the processor clock. The internal divide-by-two circuitry can be synchronized to an external clock generator by a LOW to HIGH transition on the RESET input. |  |  |  |  |
| D15-D0 | 1/0 | Data Bus inputs data during memory, I/O, and interrupt acknowledge read cycles; outputs data during memory and I/O write cycles. The data bus is active HIGH and floats to 3 -state OFF during bus hold acknowledge. |  |  |  |  |
| A23-A0 | 0 | Address Bus outputs physical memory and I/O port addresses. AO is LOW when data is to be transferred on pins D7-D0. A23-A16 are LOW during I/O transfers. The address bus is active HIGH and floats to 3 -state OFF during bus hold acknowledge. |  |  |  |  |
| $\overline{\mathrm{BHE}}$ | 0 | Bus High Enable indicates transfer of data on the upper byte of the data bus, D15-D8. Eightbit oriented devices assigned to the upper byte of the data bus would normally use $\overline{\mathrm{BHE}}$ to condition chip select functions. $\overline{\mathrm{BHE}}$ is active LOW and floats to 3 -state OFF during bus hold acknowledge. |  |  |  |  |
|  |  | $\overline{\text { BHE Value }}$ | A0 |  |  | Function |
|  |  | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ |  |  | Word tr Byte tr Byte tr Reserv | on upper half of data bus (D15-D8) on lower half of data bus (D7-D0) |
| $\overline{\mathrm{S} 1}, \overline{\mathrm{~S} 0}$ | 0 | Bus Cycle Status indicates initiation of a bus cycle and, along with M/IO and COD/ $\overline{\mathrm{INTA}}$, defineds the type of bus cycle. The bus is in a TS state whenever one or both are LOW. $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{SO}}$ are active LOW and float to 3 -state OFF during bus hold acknowledge. |  |  |  |  |
|  |  | MBL 80286 Bus Cycle Status Definition |  |  |  |  |
|  |  | cod/İNTA | M/ $\overline{\mathbf{O}}$ | $\overline{\text { s1 }}$ | so | Bus cycle initiated |
|  |  | 0 (LOW) | 0 | 0 | 0 | Interrupt acknowiedge |
|  |  | 0 | 0 | 0 | 1 | Reserved |
|  |  |  | 0 | 1 | 0 | Reserved |
|  |  | 0 | 0 | 1 | 1 | None: not a status cycle |
|  |  | 0 | 1 | 0 | 0 | If $\mathrm{A} 1=1$ then halt; else shutdown |
|  |  |  | 1 | 0 | 1 | Memory data read |
|  |  | 0 | 1 | 1 | 0 | Memory data write |
|  |  |  | 1 | 1 | 1 | None: not a status cycle |
|  |  | 1 (HIGH) | 0 | 0 | 0 | Reserved |
|  |  | 1 | 0 | 0 | 1 | I/O read |
|  |  | 1 | 0 | 1 | 0 | 1/O write |
|  |  | 1 | 0 | 1 | 1 | None: not a status cycle |
|  |  | 1 | 1 | 0 | 0 | Reserved |
|  |  | 1 | 1 | 0 | 1 | Memory instruction read |
|  |  | 1 | 1 | 1 | 0 | Reserved |
|  |  | 1 | 1 | 1 | 1 | None: not a status cycle |

FUJITSU MBL 80286-8


Table 1 - PIN DESCRIPTION (Cont.)

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\mathrm{M} / \overline{\mathrm{IO}}$ | 0 | Memory/IO Select distinguishes memory access from I/O access. If HIGH during TS, a memory cycle or a halt/shutdown cycle is in progress. If LOW, an I/O cycle or an interrupt acknowl: edge cycle is in progress. $\mathrm{M} / \overline{\mathrm{IO}}$ floats to 3 -state OFF during bus hold acknowledge. |
| COD/INTA | 0 | Code/Interrupt Acknowledge distinguishes instruction fetch cycles from memory data read cycles. Also distinguishes interrupt acknowledge cycles from I/O cycles. COD/ $\overline{\mathrm{INTA}}$ floats to 3 -state OFF during bus hold acknowledge. Its timing is the same as $\mathrm{M} / \overline{\mathrm{IO}}$. |
| $\overline{\text { LOCK }}$ | 0 | Bus Lock indicates that other system bus masters are not to gain control of the system bus following the current bus cycle. The $\overline{\text { LOCK }}$ signal may be activated explicitly by the "LOCK" instruction prefix or automatically by MBL 80286 hardware during memory XCHG instructions, interrupt acknowledge, or descriptor table access. $\overline{\text { LOCK }}$ is active LOW and floats to 3 -state OFF during bus hold acknowledge. |
| READY | 1 | Bus Ready terminates a bus cycle. Bus cycles are extended without limit until terminated by READY LOW. $\overline{\text { READY }}$ is an active LOW synchronous input requiring setup and hold times relative to the system clock be met for correct operation. $\overline{\text { READY }}$ is ignored during bus hold acknowledge. |
| $\begin{aligned} & \text { HOLD } \\ & \text { HLDA } \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Bus Hold Request and Hold Acknowledge control ownership of the MBL 80286 local bus. The HOLD input allows another local bus master to request control of the local bus. When control is granted, the MBL 80286 will float its bus drivers to 3 -state OFF and then activate HLDA, thus entering the bus hold acknowledge condition. The local bus will remain granted to the requesting master until HOLD becomes inactive which results in the MBL 80286 deactivating HLDA and regaining control of the local bus. This terminates the bus hold acknowledge condition. HOLD may be asynchronous to the system clock. These signals are active HIGH. |
| INTR | 1 | Interrupt Request requests the MBL 80286 to suspend its current program execution and service a pending external request. Interrupt requests are masked whenever the interrupt enable bit in the flag word is cleared. When the MBL 80286 responds to an interrupt request, it performs two interrupt acknowledge bus cycles to read an 8 -bit interrupt vector that identifies the source of the interrupt. To assure program interruption, INTR must remain active until the first interrupt acknowledge cycle is completed. INTR is sampled at the beginning of each processor cycle and must be active HIGH at least two processor cycles before the current instruction ends in order to interrupt before the next instruction. INTR is level sensitive, active HIGH, and may be asynchronous to the system clock. |
| NMI | 1 | Non-maskable Interrupt Request interrupts the MBL 80286 with an internally supplied vector value of 2. No interrupt acknowledge cycles are performed. The interrupt enable bit in the MBL 80286 flag word does not affect this input. The NMI input is active HIGH, may be asynchronous to the system clock, and is edge triggered after internal synchronization. For proper recognition, the input must have been previously LOW for at least four system clock cycles and remain HIGH for at least four system clock cycles. |
| $\frac{\text { PEREQ }}{\text { PEACK }}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Processor Extension Operand Request and Acknowledge extend the memory management and protection capabilities of the MBL 80286 to processor extensions. The PEREQ input requests the MBL 80286 to perform a data operand transfer for a processor extension. The PEACK output signals the processor extension when the requested operand is being transferred. PEREQ is active HIGH and floats to 3 -state OFF during bus hold acknowledge. $\overline{\text { PEACK }}$ may be asynchronous to the system clock. PEACK is active LOW. |

Table 1 - PIN DESCRIPTION (Cont.)

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\frac{\overline{\text { BUSY }}}{\overline{\text { ERROR }}}$ | $1$ | Processor Extension Busy and Error indicate the operating condition of a processor extension to the MBL 80286. An active BUSY input stops MBL 80286 program execution on WAIT and some ESC instructions until $\overline{\text { BUSY }}$ becomes inactive (HIGH). The MBL 80286 may be interrupted while waiting for $\overline{B U S Y}$ to become inactive. An active $\overline{E R R O R}$ input causes the MBL 80286 to perform a processor extension interrupt when executing WAIT or some ESC instructions. These inputs are active LOW and may be asynchronous to the system clock. |
| RESET | 1 | System Reset clears the internal logic of the MBL 80286 and is active HIGH. The MBL 80286 may be reinitialized at any time with a LOW to HIGH transition on RESET which remains active for more than 16 system clock cycles. During RESET active, the output pins of the MBL 80286 enter the state shown below: <br> Operation of the MBL 80286 begins after a HIGH to LOW transition on RESET. The HIGH to LOW transition of RESET must be synchronous to the system clock. Approximately 50 system clock cycles are required by the MBL 80286 for internal initializations before the first bus cycle to fetch code from the power-on execution address is performed. <br> A LOW to HIGH transition of RESET synchronous to the system clock will end a processor cycle at the second HIGH to LOW transition of the system clock. The LOW to HIGH transition of RESET may be asynchronous to the system clock; however, in this case it cannot be predetermined which phase of the processor clock will occur during the next system clock period. Synchronous LOW to HIGH transitions of RESET are required only for systems where the processor clock must be phase synchronous to another clock. |
| $\mathrm{V}_{\text {SS }}$ | 1 | System Ground: 0 Volts. |
| $\mathrm{V}_{\mathrm{cc}}$ | 1 | System Power: +5 Volt Power Supply. |
| CAP | 1 | Substrate Filter Capacitor: a $0.047 \mu \mathrm{~F} \pm 20 \% 12 \mathrm{~V}$ capacitor must be connected between this pin and ground. This capacitor filters the output of the internal substrate bias generator. A maximum DC leakage current of $1 \mu \mathrm{~A}$ is allowed through the capacitor. <br> For correct operation of the MBL 80286, the substrate bias generator must charge this capacitor to its operating voltage. The capacitor chargeup time is 5 milliseconds (max.) after $\mathrm{V}_{\mathrm{CC}}$ and CLK reach their specified AC and DC parameters. RESET may be applied to prevent spurious activity by the CPU during this time. After this time, the MBL 80286 processor clock can be phase synchronized to another clock by pulsing RESET LOW synchronous to the system clock. |

## FUNCTIONAL DESCRIPTION

## Introduction

The MBL 80286 is an advanced, high-performance microprocessor with specially optimized capabilities for multiple user and multi-tasking systems. Depending on the application, the MBL 80286's performance is up to six times faster than the standard 5 MHz MBL 8086's, while providing complete upward software compatibility with Fujitsu's MBL 8086, 88, and 186 family of CPU's.
The MBL 80286 operates in two modes: MBL 8086 real address mode and protected virtual address mode. Both modes execute a superset of the MBL 8086 and 88 instruction set.

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

The following Functional Description describes first, the base MBL 80286 architecture common to both modes, second, MBL 8086 real address mode, and third, protected mode.

## MBL 8086 BASE ARCHITECTURE

The MBL 8086, 88, 186, and 286 CPU family all contain
the same basic set of registers, instructions, and addressing modes. The MBL 80286 processor is upward compatible with the MBL 8086, 8088, and 80186 CPU's.

## Register Set

The MBL 80286 base architecture has fifteen registers as shown in Fig. 3. These registers are grouped into the following four categories:

General Registers: Eight 16 -bit general purpose registers used to contain arithmetic and logical operands. Four of these ( $A X, B X, C X$, and $D X$ ) can be used either in their entirety as 16 -bit words or split into pairs of separate 8 -bit registers.

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

Base and Index Registers: Four of the general purpose registers may also be used to determine offset addresses of operands in memory. These registers may contain base addresses or indexes to particular locations within a segment. The addressing mode determines the specific registers used for operand address calculations.
Status and Control Registers: The 316 -bit special purpose registers in Fig. 3a record or control certain aspects of the MBL 80286 processor state including the Instruction Pointer, which contains the offset address of the next sequential instruction to be executed.

Fig. 3 - REGISTER SET



Fig. 3a - STATUS AND CONTROL REGISTER BIT FUNCTIONS


## Flags Word Description

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

## Instruction Set

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

An MBL 80286 instruction can reference zero, one, or two operands; where an operand resides in a register, in the instruction itself, or in memory. Zero-operand instructions (e.g. NOP and HLT) are usually one byte long. One-operand instructions (e.g. INC and DEC) are usually two bytes long but some are encoded in only one byte. One-operand instructions may reference a register or memory location. Two-operand instructions permit the following six types of instruction operations:

- Register to Register
- Memory to Register
- Immediate to Register
- Memory to Memory
- Register to Memory
- Immediate to Memory

Table 2 - FLAGS WORD BIT FUNCTIONS

| Bit <br> Position | Name | Function |
| :---: | :---: | :--- |
| 0 | CF | Carry Flag - Set on high-order bit <br> carry or borrow; cleared otherwise |
| 2 | PF | Parity Flag - Set if low-order 8 bits <br> of result contain an even number of <br> 1-bits; cleared otherwise |
| 4 | AF | Set on carry from or borrow to the <br> low order four bits of AL; cleared <br> otherwise |
| $\mathbf{7}$ | ZF | Zero Flag - Set if result is zero; <br> cleared otherwise |
| 8 | SF | Sign Flag - Set equal to high-order <br> bit or result (0 if positive, 1 if nega- <br> tive) |
| 9 | IF | Single Step Flag - Once set, a sin- <br> gle step interrupt occurs after the <br> next instruction executes. TF is <br> cleared by the single step interrupt. |
| 10 | Interrupt-enable Flag - When set, <br> maskable interrupts will cause the <br> CPU to transfer control to an inter- <br> rupt vector specified location. |  |
| 11 | DF | Direction Flag - Causes string <br> instructions to auto decrement the <br> appropriate index registers when set. <br> Clearing DF causes auto increment. |
| OF | Overflow Flag - Set if result is a <br> too-large positive number or a too- <br> small negative number (excluding <br> sign-bit) to fit in destination oper- <br> and; cleared otherwise |  |
| 10 |  |  |

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

For detailed operation and usage of each instruction, see Appendix of MBL 80286 Programmer's Reference Manual.

Fig. 4a - DATA TRANSFER INSTRUCTIONS

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

Fig. $\mathbf{4 c} \mathbf{-}$ STRING INSTRUCTIONS

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

Fig. 4b - ARITHMETIC INSTRUCTIONS

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

Fig. 4d - SHIFT/ROTATE/LOGICAL INSTRUCTIONS

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

Fig. 4e - PROGRAM TRANSFER INSTRUCTIONS

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

Fig. 4f - PROCESSOR CONTROL INSTRUCTIONS

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

Fig. 4 g - HIGH LEVEL INSTRUCTIONS

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

## Memory Organization

Memory is organized as sets of variable length segments. Each segment is a linear contiguous sequence of up to $64 \mathrm{~K}\left(2^{16}\right) 8$-bit bytes. Memory is addressed using a twocomponent address (a pointer) that consists of a 16 -bit segment selector, and a 16 -bit offset. The segment selector indicates the desired segment in memory. The offset component indicates the desired byte address within the segment.


Table 3 - SEGMENT REGISTER SELECTION RULES

| Memory Reference <br> Needed | Segment Register <br> Used | Implicit Segment Selection Rule |
| :--- | :--- | :--- |
| Instructions | Code (CS) | Automatic with instruction prefetch |
| Stack | Stack (SS) | All stack pushes and pops. Any memory reference which uses BP as a <br> base register. |
| Local Data | Data (DS) | All data references except when relative to stack or string destination |
| External (Global) Data | Extra (ES) | Alternate data segment and destination of string operation |

All instructions that address operands in memory must specify the segment and the offset. For speed and compact instruction encoding, segment selectors are usually stored in the high speed segment registers. An instruction need specify only the desired segment register and an offset in order to address a memory operand.
Most instructions need not explicitly specify which segment register is used. The correct segment register is automatically chosen according to the rules of Table 3. These rules follow the way programs are written (see Fig. 6) as independent modules that require areas for code and data, a stack, and access to external data areas.

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

## Addressing Modes

The MBL 80286 provides a total of eight addressing modes for instructions to specify operands. Two addressing modes are provided for instructions that operate on register or immediate operands:
Register Operand Mode: The operand is located in one of the 8 or 16 -bit general registers.

Immediate Operand Mode: The operand is included in the instruction.

Six modes are provided to specify the location of an operand in a memory segment. A memory operand address consists of two 16 -bit components: segment selector and offset. The segment selector is supplied by a segment register either implicitly chosen by the addressing mode or explicitly chosen by a segment override prefix. The offset is calculated by summing any combination of the following three address elements:

Fig. 6 - SEGMENTED MEMORY HELPS STRUCTURE SOFTWARE

the displacement (an 8 or 16 -bit immediate value contained in the instruction)
the base (contents of either the BX or BP base registers) the Index (contents of either the SI or DI index registers)
Any carry out from the 16 -bit addition is ignored. Eightbit displacements are sign extended to 16 -bit values.

Combinations of these three address elements define the six memory addressing modes, described below.
Direct Mode: The operand's offset is contained in the instruction as an 8 or 16 -bit displacement element.

Register Indirect Mode: The operand's offset is in one of the registers SI, DI, BX, or BP.

Based Mode: The operand's offset is the sum of an 8 or 16 -bit displacement and the contents of a based register (BX or BP).
Indexed Mode: The operand's offset is the sum of an 8 or 16 -bit displacement and the contents of an index register (SI or DI).
Based Indexed Mode: The operand's offset is the sum of the contents of a base register and an index register.
Based Indexed Mode with Displacement: The operand's offset is the sum of a base register's contents, an index register's contents, and an 8 or 16-bit displacement.

## Data Types

The MBL 80286 directly supports the following data types: Integer: A signed binary numeric value contained in an 8 -bit byte or a 16 -bit word. All operations assume a 2 's complement representation. Signed 32 and 64 -bit integers are supported using the MBL 80286 and Intel 80287 Numeric Data Processor.
Ordinal: An unsigned binary numeric value contained in an 8 -bit byte or 16 -bit word.
Pointer: A 32-bit quantity, composed of a segment selector component and an offset component. Each component is a 16 -bit word.

String: A contiguous sequence of bytes or words. A string may contain from 1 byte to 64 K bytes.
ASCII: A byte representation of alphanumeric and control characters using the ASCII standard of character representation.
BCD: A byte (unpacked) representation of the decimal digits 0-9.
Packed BCD: A byte (packed) representation of two decimal digits $0-9$ storing one digit in each nibble of the byte.
Floating Point: A signed 32,64 , or 80 -bit real number representation. (Floating point operands are supported using the MBL 80286 and Intel 80287 Numeric Processor configuration.)
Fig. 7 graphically represents the data types supported by the MBL 80286.

## I/O Space

The I/O space consists of 64 K 8 -bit or 32 K 16 -bit ports.

Fig. 7 - MBL 80286 SUPPORTED DATA TYPES


- Supported by MBL 80286 and Intel 80287 Numeric Data Processor Configuration

I/O instructions address the I/O space with either an 8-bit port address, specified in the instruction, or a 16-bit port address in the DX register. 8-bit port addresses are zero extended such that A15-A8 are LOW. I/O port addresses $00 F 8(\mathrm{H})$ through $00 \mathrm{FF}(\mathrm{H})$ are reserved.

Table 4 - INTERRUPT VECTOR ASSIGNMENTS

| Function | Interrupt <br> Number | Related Instructions | Does Return Address <br> Point to Instruction <br> Causing Exception? |
| :--- | :--- | :--- | :---: |
| Divide error exception | 0 | DIV, IDIV | Yes |
| Single step interrupt | 1 | AlI |  |
| NMI Interrupt | 2 | INT 2 or NMI pin |  |
| Breakpoint interrupt | 3 | INT 3 |  |
| INTO detected overflow exception | 4 | INTO | No |
| BOUND range exceeded exception | 5 | BOUND | Yes |
| Invalid opcode exception | 6 | Any undefined opcode | Yes |
| Processor extension not available exception | 7 | ESC or WAIT | Yes |
| Reserved - do not use | $8-15$ |  |  |
| Processor extension error interrupt | 16 | ESC or WAIT |  |
| Reserved - do not use | $17-31$ |  |  |
| User defined | $32-255$ |  |  |

## Interrupts

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

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

## MASKABLE INTERRUPT (INTR)

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

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

## NON-MASKABLE INTERRUPT REQUEST (NMI)

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

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

## SINGLE STEP INTERRUPT

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

## Interrupt Priorities

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

Table 5 - INTERRUPT PROCESSING ORDER

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

## Initialization and Processor Reset

Processor initialization or start up is accomplished by driving the RESET input pin HIGH. RESET forces the MBL 80286 to terminate all execution and local bus activity. No instruction or bus activity will occur as long as RESET is active. After RESET becomes inactive and an internal processing interval elapses, the MBL 80286 begins execution in real address mode with the instruction at physical location $\operatorname{FFFFFO}(\mathrm{H})$. RESET also sets some registers to predefined values as shown as shown in Table 6.

Table 6 - MBL 80286 INITIAL REGISTER STATE

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

## Machine Status Word Description

The machine status word (MSW) records when a task switch takes place and controls the operating mode of the MBL 80286. It is a 16 -bit register of which the lower four bits are used. One bit places the CPU into protected mode, while the other three bits, as shown in Table 7, control the processor extension interface. After RESET, this register contains $\operatorname{FFFO}(\mathrm{H})$ which places the MBL 80286 in MBL 8086 real address mode.

Table 7 - MSW BIT FUNCTIONS

| Bit <br> Position | Name | Function |
| :---: | :---: | :--- |
| 0 | PE | Protected mode enable places the <br> MBL 80286 into protected mode and <br> can not be cleared except by RESET. |
| 1 | MP | Monitor processor extension allows <br> WAIT instructions to cause a proces- <br> sor extension not present exception <br> (number 7). |
| 2 | EM | Emulate processor extension causes <br> a processor extension not present <br> exception (number 7) on ESC in- <br> structions to allow emulating a <br> processor extension. |
| 3 | TS | Task switched indicates the next <br> instruction using a processor exten- <br> sion will cause exception 7, allowing <br> software to test whether the current <br> processor extension context belongs <br> to the current task. |

Table 8 - RECOMMENDED MSW ENCODINGS FOR PROCESSOR EXTENSION CONTROL

| TS | MP | EM | Recommended Use | Instructions <br> Causing <br> Exception 7 |
| :---: | :---: | :---: | :--- | :---: |
| 0 | 0 | 0 | Initial encoding after RESET. MBL 80286 operation is identical to <br> MBL 8086, 88. | None |
| 0 | 0 | 1 | No processor extension is available. Software will emulate its function. | ESC |
| 1 | 0 | 1 | No processor extension is available. Software will emulate its function. <br> The current processor extension context may belong to another task. | ESC |
| 0 | 1 | 0 | A processor extension exists. | None |
| 1 | 1 | 0 | A propessor extension exists. The current processor extension context <br> may belong to another task. The Exception 7 on WAIT allows software to <br> test for an error pending from a previous processor extension operation. | ESC or WAIT |

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

## Halt

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

## MBL 8086 REAL ADDRESS MODE

The MBL 80286 executes a fully upward-compatible superset of the MBL 8086 instruction set in real address mode. In real address mode the MBL 80286 is object code compatible with MBL 8086 and 8088 software. The real address mode architecture (registers and addressing modes) is exactly as described in the MBL 80286 Base Architecture section of this Functional Description.

## Memory Size

Physical memory is a contiguous array of up to $1,048,576$ bytes (one megabyte) addressed by pins A0 through A19 and $\overline{\mathrm{BHE}}$. A20 through A23 may be ignored.

## Memory Addressing

In real address mode physical memory is a contiguous array of up to $1,048,576$ bytres (one megabyte) addressed by pins AO through A19 and $\overline{\mathrm{BHE}}$. A20 through A23 may be ignored.
The selector portion of a pointer is interpreted as the upper 16 bits of a 20 -bit segment address. The lower four bits of the 20 -bit segment address are always zero. Segment addresses, therefore, begin on multiples of 16 bytes. See Fig. 8 for a graphic representation of address formation.

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

## Reserved Memory Locations

The MBL 80286 reserves two fixed areas of memory in real address mode (see Fig. 9); system initialization area and interrupt table area. Locations from addresses FFFFO(H) through $\operatorname{FFFFF}(\mathrm{H})$ are reserved for system initialization. Initial execution begins at location FFFFO(H). Locations

Fig. 8 - MBL 8086 REAL ADDRESS MODE ADDRESS CALCULATION


Fig. 9 - MBL 8086 REAL ADDRESS MODE INITIALLY RESERVED MEMORY LOCATIONS


INITIAL CS:IP VALUE IS F000:FFFO.
$00000(\mathrm{H})$ through $003 \mathrm{FF}(\mathrm{H})$ are reserved for interrupt vectors.

Table 9 - REAL ADDRESS MODE ADDRESSING INTERRUPTS

| Function | Interrupt <br> Number | Related Instructions | Return Address <br> Before Instruction? |
| :--- | :---: | :---: | :---: |
| Interrupt table limit too small exception | 8 | INT vector is not within table limit. | Yes |
| Processor extension segment overrun <br> interrupt | 9 | ESC with memory operand extending <br> beyond offset FFFF(H). | No |
| Segment overrun exception | 13 | Word memory reference with offset <br> =FFFF(H) or an attempt to execute <br> past the end of a segment. | Yes |

## Interrupts

Table 9 shows the interrupt vectors reserved for exceptions and interrupts which indicate an addressing error. The exceptions leave the CPU in the state existing before attempting to execute the failing instruction (except for PUSH, POP, PUSHA, or POPA). Refer to the next section on protected mode initialization for a discussion on exception 8.

## Protected Mode Initialization

To prepare the MBL 80286, for protected mode, the LIDT instruction is used to load the 24 -bit interrupt table base and 16 -bit limit for the protected mode interrupt table. This instruction can also set a base and limit for the inter rupt vector table in real address mode. After reset, the interrupt table base is initialized to $000000(\mathrm{H})$ and its size set to $03 F F(H)$. These values are compatible with MBL 8086, 88 software. LIDT should only be executed in preparation for protected mode.

## Shutdown

Shutdown occurs when a severe error is detected that prevents further instruction processing by the CPU. Shutdown and halt are externally signalled via a halt bus operation. They can be distinguished by A1 HIGH for halt and A1 LOW for shutdown. In real address mode, shutdown can occur under two conditions.

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

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

## PROTECTED VIRTUAL ADDRESS MODE

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

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

All registers, instructions, and addressing modes described in the MBL 80286 Base Architecture section of this Functional Description remain the same. Programs for the MBL 8086, 88, 186, and real address mode MBL 80286 can be run in protected mode; however, embedded constants for segment selectors are different.

## Memory Size

The protected mode MBL 80286 provides a 1 gigabyte virtual address space per task mapped into a 16 megabyte physical address space defined by the address pins A23AO and $\overline{\mathrm{BHE}}$. The virtual address space may be larger than the physical address space since any use of an address that does not map to a physical memory location will cause a restartable exception.

## Memory Addressing

As in real address mode, protected mode uses 32 -bit pointers, consisting of 16 -bit selector and offset components. The selector, however, specifies an index into a memory resident table rather than the upper 16 -bits of a real memory address. The 24 -bit base address of the
desired segment is obtained from the tables in memory. The 16 -bit offset is added to the segment base address to form the physical address as shown in Fig. 10. The tables are automatically referenced by the CPU whenever a segment register is loaded with a selector. All MBL 80286 instructions which load a segment register will reference the memory based tables without additional software. The memory based tables contain 8 byte values called descriptors.

Fig. 10 - PROTECTED MODE MEMORY ADDRESSING


## DESCRIPTORS

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

## CODE AND DATA SEGMENT DESCRIPTORS ( $\mathrm{S}=1$ )

Besides segment base addresses, code and data descriptors contain other segment attributes including segment size (1 to 64 K bytes), access rights (read only, read/write, execute only, and execute/read), and presence in memory (for virtual memory systems) (See Fig. 11). Any segment usage violating a segment attribute indicated by the segment descriptor will prevent the memory cycle and cause an exception or interrupt.


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

Data segments ( $S=1, E=0$ ) may be either read-only or read-write as controlled by the W bit of the access rights byte. Read-only ( $\mathrm{W}=0$ ) data segments may not be written into. Data segments may grow in two directions, as determined by the Expansion Direction (ED) bit: upwards ( $E D=0$ ) for data segments, and downwards ( $E D=1$ ) for a segment containing a stack. The limit field for a data segment descriptor is interpreted differently depending on the ED bit (see Fig. 11).
A code segment ( $S=1, E=1$ ) may be execute-only or execute/read as determined by the Readable (R) bit. Code segments may never be written into and executeonly code segments ( $R=0$ ) may not be read. A code segment may also have an attribute called conforming (C). A conforming code segment may be shared by programs that execute at different privilege levels. The DPL of a conforming code segment defines the range of privilege levels at which the segment may be executed (refer to privilege discussion below). The limit field identifies the last byte of a code segment.

SYSTEM SEGMENT DESCRIPTORS ( $\mathbf{S}=\mathbf{0}$, TYPE $=1$ 1-3) In addition to code and data segment descriptors, the protected mode MBL 80286 defines System Segment Descriptors. These descriptors define special system data segments which contain a table of descriptors (Local Descriptor Table Descriptor) or segments which contain the execution state of a task (Task State Segment Descriptor).
Fig. 12 gives the formats for the special system data segment descriptors. The descriptors contain a 24 -bit base address of the segment and a 16 -bit limit. The access byte defines the type of descriptor, its state and privilege level. The descriptor contents are valid and the segment is in physical memory if $P=1$. If $P=0$, the segment is not valid. The DPL field is only used in Task State Segment

Fig. 12 - SYSTEM SEGMENT DESCRIPTOR FORMAT System Segment Descriptor


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

descriptors and indicates the privilege level at which the descriptor may be used (see Privilege). Since the Local Descriptor Table descriptor may only be used by a special privileged instruction, the DPL field is not used. Bit 4 of the access byte is 0 to indicate that it is a system control descriptor. The type field specifies the descriptor type as indicated in Fig. 12.

## GATE DESCRIPTORS ( $\mathbf{S}=0$, TYPE $=4-7$ )

Gates are used to control access to entry points within the target code segment. The gate descriptors are call gates, task gates, interrupt gates and trap gates. Gates provide a level of indirection between the source and destination of the control transfer. This indirection allows the CPU to automatically perform protection checks and control entry point of the destination. Call gates are used to change privilege levels (see Privilege), task gates are used to perform a task switch, and interrupt and trap gates are used to specify interrupt service routines. The interrupt gate disables interrupts (resets IF) while the trap gate does not.
Fig. 13 shows the format of the gate descriptors. The descriptor contains a destination pointer that points to the descriptor of the target segment and the entry point offset. The destination selector in an interrupt gate, trap gate, and call gate must refer to a code segment descrip-
tor. These gate descriptors contain the entry point to prevent a program from constructing and using an illegal entry point. Task gates may only refer to a task state

Fig. 13 - GATE DESCRIPTOR FORMAT Gate Descriptor

*Must be set to 0 for compatibility with iAPX 386 . ( $X$ is don't care)

Gate Descriptor Fields

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

segment. Since task gates invoke a task switch, the destination offset is not used in the task gate.

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

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

## SEGMENT DESCRIPTOR CACHE REGISTERS

A segment descriptor cache register is assigned to each of the four segment registers (CS, SS, DS, ES). Segment


Fig. 14 - DESCRIPTOR CACHE REGISTERS

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

## SELECTOR FIELDS

A protected mode selector has three fields: descriptor entry index, local or global descriptor table indicator (TI), and selector privilege (RPL) as shown in Fig. 15. These fields select one of two memory based tables of descriptors, select the appropriate table entry and allow highspeed testing of the selector's privilege attribute.

## LOCAL AND GLOBAL DESCRIPTOR TABLES

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

Fig. 16 - LOCAL AND GLOBAL DESCRIPTOR TABLE DEFINITION

called the Local Descriptor Table (LDT), contains descriptors that can be private to a task. Each task may have its own private LDT. The GDT may contain all descriptor types except interrupt and trap descriptors. The LDT may contain only segment, task gate, and call gate descriptors. A segment cannot be accessed by a task if its segment descriptor does not exist in either descriptor table at the time of access.
The LGDT and LLDT instructions load the base and limit of the global and local descriptor tables. LGDT and LLDT are privileged, i.e. they may only be executed by trusted programs operating at level 0 . The LGDT instruction loads a six byte field containing the 16 -bit table-limit and 24 -bit physical base address of the Global Descriptor Table as shown in Fig. 17. The LDT instruction loads a selector which refers to a Local Descriptor Table descriptor containing the base address and limit for an LDT, as shown in Fig. 12.

Fig. 17 - GLOBAL DESCRIPTOR TABLE AND INTERRUPT DESCRIPTOR TABLE DATA TYPE


## INTERRUPT DESCRIPTOR TABLE

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

Fig. 18 - INTERRUPT DESCRIPTOR TABLE DEFINITION


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

## Privilege

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

## Fig. 19 - HIERARCHICAL PRIVILEGE LEVELS



NOTE: PL BECOMES NUMERICALLY LOWER AS PRIVILEGE LEVEL INCREASES

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

## TASK PRIVILEGE

A task always executes at one of the four privilege levels. The task privilege level at any specific instant is called the Current Privilege Level (CPL) and is defined by the lower two bits of the CS register. CPL cannot change during execution in a single code segment. A task's CPL may only be changed by control transfers through gate descriptors to a new code segment (See Control Transfer).

Tasks begin executing at the CPL value specified by the code segment selector within TSS when the task is initiated via a task switch operation (See Fig. 20). A task executing at Level 0 can access all data segments defined in the GDT and the task's LDT and is considered the most trusted level. A task executing a Level 3 has the most restricted access to data and is considered the least trusted level.

## DESCRIPTOR PRIVILEGE

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

## SELECTOR PRIVILEGE

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

## Descriptor Access and Privilege Validation

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

## DATA SEGMENT ACCESS

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

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

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

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

## CONTROL TRANSFER

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

The ability to reference a descriptor for control transfer is also subject to rules of privilege. A CALL or JUMP instruction may only reference a code segment descriptor with DPL equal to the task CPL or a conforming seg-
ment with DPL of equal or greater privilege than CPL. The RPL of the selector used to reference the code descriptor must have as much privilege as CPL.
RET and IRET instructions may only reference code segment descriptors with descriptor privilege equal to or less privileged than the task CPL. The selector loaded into CS is the return address from the stack. After the return, the selector RPL is the task's new CPL. If CPL changes, the old stack pointer is popped after the return address.

When a JMP or CALL references a Task State Segment descriptor, the descriptor DPL must be the same or less privileged than the task's CPL. Reference to a valid Task State Segment descriptor causes a task switch (see Task Switch Operation). Reference to a Task State Segment descriptor at a more privileged level than the task's CPL generates exception 13.

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

Table 10 - DESCRIPTOR TYPES USED FOR CONTROL TRANSFER

| Control Transfer Types | Operation Types | Descriptor Referenced | Descriptor Table |
| :---: | :---: | :---: | :---: |
| Intersegment within the same privilege level | JMP, CALL, RET, IRET* | Code Segment | GDT/LDT |
| Intersegment to the same or higer privilege level Interrupt within task may change CPL | CALL | Call Gate | GDT/LDT |
|  | Interrupt Instruction, Exception, External Interrupt | Trap or Interrupt Gate | IDT |
| Intersegment to a lower privilege level (changes task CPL) | RET, IRET* | Code Segment | GDT/LDT |
|  | CALL, JMP | Task State Segment | GDT |
| Task Switch | CALL, JMP | Task Gate | GDT/LDT |
|  | IRET** <br> Interrupt Instruction, Exception, External Interrupt | Task Gate | IDT |

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

The privilege rules on control transfer require:

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


## PRIVILEGE LEVEL CHANGES

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

When returning to the original privilege level, its stack is restored as part of the RET or IRET instruction operation. For subroutine calls that pass parameters on the stack and cross privilege levels, a fixed number of words, as specified in the gate, are copied from the previous stack to the current stack. The inter-segment RET instruction with a stack adjustment value will correctly restore the previous stack pointer upon return.

## Protection

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

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

Table 11 - SEGMENT REGISTER LOAD CHECKS

| Error Description | Exception <br> Number |
| :--- | :---: |
| Descriptor table limit exceeded | 13 |
| Segment descriptor not-present | 11 or 12 |
| Privilege rules violated | 13 |
| Invalid descriptor/segment type segment |  |
| register load: |  |
| - Read only data segment load to SS |  |
| - Special control descriptor load to DS, |  |
| - ES, SS | 13 |
| - Execute only segment load to DS, ES, SS |  |
| - Read/Execute code segment load to SS |  |

Table 12 - OPERAND REFERENCE CHECKS

| Error Description | Exception <br> Number |
| :--- | :---: |
| Write into code segment | 13 |
| Read from execute-only code segment | 13 |
| Write to read-only data segment | 13 |
| Segment limit exceeded | 12 or 13 |

Note 1: Carry out in offset calculations is ignored.
Table 13 - PRIVILEGED INSTRUCTION CHECKS

| Error Description | Exception <br> Number |
| :---: | :---: |
| CPL $\neq 0$ when executing the following <br> instructions: <br> LIDT, LLDT, LGDT, LTR, LMSW, CTS, <br> HLT | 13 |
| CPL > IOPL when executing the following <br> instructions: <br> INS, IN, OUTS, OUT, STI, CLI, LOCK | 13 |

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

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

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

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

## EXCEPTIONS

The MBL 80286 detects several types of exceptions and interrupts, in protected mode (see Table 14). Most are restartable after the exceptional condition is removed. Interrupt handlers for most exceptions can read an error code, pushed on the stack after the return address, that

Table 14 - PROTECTED MODE EXCEPTIONS

| Interrupt <br> Vector | Function | Return Address <br> At Failing <br> Instruction? | Always <br> Restartable? | Error Code <br> on Stack? |
| :---: | :--- | :---: | :---: | :---: |
| 8 | Double exception detected | Yes | No $^{2}$ | Yes |
| 9 | Processor extension segment overrun | No | No $^{2}$ | No |
| 10 | Invalid task state segment | Yes | Yes | Yes |
| 11 | Segment not present | Yes | Yes | Yes |
| 12 | Stack segment overrun or stack segment not present | Yes | Yes | Yes |
| 13 | General protection | Yes | No $^{2}$ | Yes |

NOTE 1: When a PUSHA or POPA instruction attempts to wrap around the stack segment, the machine state after the exception will not be restartable because stack segment wrap around is not permitted. This condition is identified by the value of the saved SP being eigher $0000(\mathrm{H}), 0001(\mathrm{H}), \operatorname{FFFE}(\mathrm{H})$, or $\operatorname{FFFF}(\mathrm{H})$.
NOTE 2: These exceptions indicate a violation to privilege rules or usage rules has occurred. Restart is generally not attempted under those conditions.
identifies the selector involved ( 0 if none). The return address normally points to the failing instruction, including all leading prefixes. For a processor extension segment overrun exception, the return address will not point at the ESC instruction that caused the exception; however, the processor extension registers may contain the address of the failing instruction.
These exceptions indicate a violation to privilege rules or usage rules has occurred. Restart is generally not attempted under those conditions.
All these checks are performed for all instructions and can be split into three categories: segment load checks (Table 11), operand reference checks (Table 12), and privileged instruction checks (Table 13). Any violation of the rules shown will result in an exception. A notpresent exception causes exception 11 or 12 and is restartable.

## Special Operations

## TASK SWITCH OPERATION

The MBL 80286 provides a built-in task switch operation which saves the entire MBL 80286 execution state (registers, address space, and a link to the previous task), loads a new execution state, and commences execution in the new task. Like gates, the task switch operation is invoked by executing an inter-segment JMP or CALL instruction which refers to a Task State Segment (TSS) or task gate descriptor in the GDT or LDT. An INT instruction, exception, or external interrupt may also invoke the task switch operation by selecting a task gate descriptor in the associated IDT descriptor entry.
The TSS descriptor points at a segment (see Fig. 20) containing the entire MBL 80286 execution state while a
task gate descriptor contains a TSS selector. The limit field of the descriptor must be $>002 \mathrm{~B}(\mathrm{H})$.

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

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

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

## PROCESSOR EXTENSION CONTEXT SWITCHING

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

Whenever the MBL 80286 switches tasks, if sets the Task Switched (TS) bit of the MSW. TS indicates that a processor extension context may belong to a different task than the current one. The processor extension not present
exception (7) will occur when attempting to execute an ESC or WAIT instruction if TS $=1$ and a processor extension is present ( $M P=1 \mathrm{in}$ MSW).

## POINTER TESTING INSTRUCTIONS

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

Fig. 20 - TASK STATE SEGMENT AND TSS REGISTERS


Table 15 - MBL 80286 POINTER TEST INSTRUCTIONS

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

## DOUBLE FAULT AND SHUTDOWN

If two separate exceptions are detected during a single instruction execution, the MBL 80286 performs the double fault exception (8). If an exception occurs during processing of the double fault exception, the MBL 80286 will enter shutdown. During shutdown no further instructions or exceptions are processed. Either NMI (CPU remains in protected mode) or RESET (CPU exits protected mode) can force the MBL 80286 out of shutdown. Shutdown is externally signalled via a HALT bus operation with A1 HIGH.

## PROTECTED MODE INITIALIZATION

The MBL 80286 initially executes in real address mode after RESET. To allow initialization code to be placed at the top of physical memory, A23-A20 will be HIGH When the MBL 80286 performs memory references relative to the CS register until CS is changed. A23-A20 will be zero for references to the DS, ES, or SS segments. Changing CS in real address mode will force A23-A20 LOW whenever CS is used again. The initial CS:IP value of F000:FFFO provides 64 K bytes of code space for initialization code without changing CS.

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

To force the MBL 80286 CPU registers to match the initial protected mode state assumed by software, execute a JMP instruction with a selector referring to the initial TSS used in the system. This will load the task register, local descriptor table register, segment registers and initial general register state. The TR should point at a valid TSS since any task switch operation involves saving the current task state.

## SYSTEM INTERFACE

The MBL 80286 system interface appears in two forms: a local bus and a system bus. The local bus consists of address, data, status, and control signals at the pins of the CPU. A system bus is any buffered version of the local bus. A system bus may also differ from the local bus in terms of coding of status and control lines and/or timing and loading of signals. The MBL 80286 family includes several devices to generate standard system buses such as the IEEE 796 standard Multibus ${ }^{\text {TM }}$ *.

## Bus Interface Signals and Timing

The MBL 80286 microsystem local bus interfaces the MBL 80286 to local memory and I/O components. The interface has 24 address lines, 16 data lines, and 8 status and control signals.
The MBL 80286 CPU, MBL 82284 clock generator, MBL 82288 bus controller, Intel 82289 bus arbiter, MBL 8286/7 transceivers, and MBL 8282/3 latches provide a buffered and decoded system bus interface. The MBL 82284 generates the system clock and synchronizes $\overline{\text { READY }}$ and RESET. The MBL 82288 converts bus operation status encoded by the MBL 80286 into command and bus control signals. The 82289 bus arbiter generates Multibus bus arbitration signals. These components can provide the timing and electrical power drive levels required for most system bus interfaces including the Multibus.

## Physical Memory and I/O Interface

A maximum of 16 megabytes of physical memory can be addressed in protected mode. One megabyte can be addressed in real address mode. Memory is accessible as bytes or words. Words consist of any two consecutive bytes addressed with the least significant byte stored in the lowest address.
Byte transfers occur on either half of the 16 -bit local data bus. Even bytes are accessed over D7-D0 while odd bytes
are transferred over D15-D8. Even-addressed words are transferred over D15-D0 in one bus cycle, while oddaddressed words require two bus operations. The first transfers data on D15-D8, and the second transfers data on D7-DO. Both byte data transfers occur automatically, transparent to software.
Two bus signals, AO and $\overline{\mathrm{BHE}}$, control transfers over the lower and upper halves of the data bus. Even address byte transfers are indicated by AO LOW and BHE HIGH. Odd address byte transfers are indicated by AO HIGH and $\overline{\mathrm{BHE}}$ LOW. Both A 0 and $\overline{\mathrm{BHE}}$ are LOW for even address word transfers.

The I/O address space contains 64 K addresses in both modes. The I/O space is accessible as either bytes or words, as is memory. Byte wide peripheral devices may be attached to either the upper or lower byte of the data bus. Bytewide I/O devices attached to the upper data byte (D15-D8) are accessed with odd I/O addresses. Devices on the lower data byte are accessed with even I/O addresses. An interrupt controller such as MBL 8259A must be connected to the lower data byte (D7-DO) for proper return of the interrupt vector.

## Bus Operation

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


Six types of bus operations are supported; memory read, memory write, I/O read, I/O write, interrupt ackowledge, and halt/shutdown. Data can be transferred at a maximum rate of one word per two processor clock cycles.
The MBL 80286 bus has three basic states: idle ( Ti ), send
status (Ts), and perform command (Tc). The MBL 80286 CPU also has a fourth local bus state called hold (Th). Th indicates that the MBL 80286 has surrendered control of the local bus to another bus master in response to a HOLD request.

Each bus state is one processor clock long. Fig. 22 shows the four MBL 80286 local bus states and allowed transitions.


## Bus States

The idle ( Ti ) state indicates that no data transfers are in progress or requested. The first active state $T s$ is signaled by status line $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{SO}}$ going LOW and identifying phase 1 of the processor clock. During Ts, the command encoding, the address, and data (for a write operation) are available on the MBL 80286 output pins. The MBL 82288 bus controller decodes the status signals and generates Multibus compatible read/write command and local transceiver control signals.

After Ts, the perform command (Tc) state is entered. Memory or I/O devices respond to the bus operation during Tc, either transferring read data to the CPU or accepting write data. Tc states may be repeated as often as necessary to assure sufficient time for the memory or $1 / O$ device to respond. The $\overline{\text { READY }}$ signal determines whether Tc is repeated. A repeated Tc state is called a wait state.
During hold (Th), the MBL 80286 will float all address, data, and status output pins enabling another bus master to use the local bus. The MBL 80286 HOLD input signal is used to place the MBL 80286 into the Th state. The MBL 80286 HLDA output signal indicates that the CPU has entered Th.

Fig. 23 - BASIC BUS CYCLE


PIPELINING: VALID ADDRESS ( $\mathrm{N}+1$ ) AVAILABLE IN LAST PHASE OF BUS CYCLE ( N ).

## Pipelined Addressing

The MBL 80286 uses a local bus interface with pipelined timing to allow as much time as possible for data access. Pipelined timing allows a new bus operation to be initiated every two processor cycles, while allowing each individual bus operation to last for three processor cycles.
The timing of the address outputs is pipelined such that the address of the next bus operation becomes available during the current bus operation. Or in other words, the first clock of the next bus operation is overlapped with the last clock of the current bus operation. Therefore, address decode and routing logic can operate in advance of the next bus operation. External address latches may hold the address stable for the entire bus operation, and provide additional AC and DC buffering.
The MBL 80286 does not maintain the address of the current bus operation during all Tc states. Instead, the address for the next bus operation may be emitted during phase 2 of any Tc. The address remains valid during phase 1 of the first Tc to guarantee hold time, relative to ALE, for the address latch inputs.

## Bus Control Signals

The MBL 82288 bus controller provides control signals; address latch enable (ALE), Read/Write commands, data transmit/receive (DT/ $\bar{R}$ ), and data enable (DEN) that control the address latches, data transceivers, write enable,
and output enable for memory and I/O systems.
The Address Latch Enable (ALE) output determines when the address may be latched. ALE provides at least one system CLK period of address hold time from the end of the previous bus operation until the address for the next bus operation appears at the latch outputs. This address hold time is required to support Multibus ${ }^{®^{*}}$ and common memory systems.

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

## Command Timing Controls

Two system timing customization options, command extension and command delay, are provided on the MBL 80286 local bus.

Command extension allows additional time for external devices to respond to a command and is analogous to inserting wait states on the MBL 80286. External logic can control the duration of any bus operation such that the operation is only as long as necessary. The $\overline{\text { READY }}$ input signal can extend any bus operation for as long as necessary.

[^0]Fig. 24 - CMDLY CONTROLS THE LEADING EDGE OF COMMAND SIGNAL


Command delay allows an increase of address or write data setup time to system bus command active for any bus operation by delaying when the system bus command becomes active. Command delay is controlled by the MBL 82288 CMDLY input. After Ts, the bus controller samples CMDLY at each failing edge of CLK. If CMDLY is HIGH, the MBL 82288 will not activate the command signal. When CMDLY is LOW, the MBL 82288 will activate the command signal. After the command becomes active, the CMDLY input is not sampled.
When a command is delayed, the available response time from command active to return read data or accept write data is less. To customize system bus timing, an address decoder can determine which bus operations require delaying the command. The CMDLY input does not affect the timing of ALE, DEN, or DT/ $\bar{R}$.
Fig. 24 illustrates four uses of CMDLY. Example 1 shows delaying the read command two system CLKs for cycle $\mathrm{N}-1$ and no delay for cycle N , and example 2 shows delaying the read command one system CLK for cycle $\mathrm{N}-1$ and one system CLK delay for cycle N .

## Bus Cycle Termination

At maximum transfer rates, the MBL 80286 bus alternates between the status and command states. The bus status signals become inactive after Ts so that they may correctly signal the start of the next bus operation after the completion of the current cycle. No external indication of Tc exists on the MBL 80286 local bus. The bus master and bus controller enter Tc directly after Ts and continue executing Tc cycles until terminated by $\overline{\text { READY }}$.

## READY Operation

The current bus master and MBL 82288 bus controller terminate each bus operation simultaneously to achieve maximum bus operation bandwidth. Both are informed in advance by $\overline{R E A D Y}$ active (open-collector output from MBL 82284) which identifies the last Tc cycle of the current bus operation. The bus master and bus controller must see the same sense of the READY signal, thereby requiring $\overline{\operatorname{READY}}$ be synchronous to the system clock.

## Synchronous Ready

The MBL 82284 clock generator provides $\overline{\text { READY }}$ synchronization from both synchronous and asynchronous sources (see Fig. 25). The synchronous ready input ( $\overline{\text { SRDY }}$ )

Fig. 25 - SYNCHRONOUS AND ASYNCHRONOUS READY


NOTES:

1. $\overline{\text { SRDYEN }}$ is active low.
2. If $\overline{\text { SRDYEN }}$ is high, the state of $\overline{\text { SRDY }}$ will not effect $\overline{\text { READY }}$
3. $\overline{\text { ARDYEN }}$ is active low.
of the clock generator is sampled with the failing edge of CLK at the end of phase 1 of each Tc. The state of $\overline{\text { SRDY }}$ is then broadcast to the bus master and bus controller via the $\overline{\operatorname{READY}}$ output line.

## Asynchronous Ready

Many systems have devices or subsystems that are asynchronous to, the system clock. As a result, their ready outputs cannot be guaranteed to meet the MBL 82284 SRDY setup and hold time requirements. But the MBL 82284 asynchronous ready input ( $\overline{\text { ARDY }}$ ) is designed to accept such signals. The $\overline{\operatorname{ARDY}}$ input is sampled the beginning of each Tc cycle by MBL 82284 synchronization logic. This provides one system CLK cycle time to resolve its value before broadcasting it to the bus master and bus controller.
$\overline{\text { ARDY }}$ or $\overline{\text { ARDYEN }}$ must be HIGH at the end of Ts. $\overline{\text { ARDY }}$ cannot be used to terminate bus cycle with no wait states.
Each ready input of the MBL 82284 has an enable pin ( $\overline{\text { SRDYEN }}$ and $\overline{\text { ARDYEN }}$ ) to select whether the current bus operation will be terminated by the synchronous or asynchronous ready. Either of the ready inputs may terminate a bus operation. These enable inputs are active
low and have the same timing as their respective ready inputs. Address decode logic usually selects whether the current bus operation should be terminated by $\overline{\text { ARDY }}$ or SRDY.

## Data Bus Control

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

The data bus is driven with write data during the second phase of Ts. The delay in write data timing allows the read data drivers, from a previous read cycle, sufficient time to enter 3-state OFF before the MBL 80286 CPU begins driving the local data bus for write operations. Write data will always remain valid for one system clock past the last Tc to provide sufficient hold time for Multibus or other similar memory or I/O systems. During write-read or writeidle sequences the data bus enters 3 -state OFF during the second phase of the processor cycle after the last Tc. In a write-write sequence the data bus does not enter 3 -state OFF between Tc and Ts.

## Bus Usage

The MBL 80286 local bus may be used for several functions: instruction data transfers, data transfers by other bus masters, instruction fetching, processor extension data
transfers, interrupt acknowledge, and halt/shutdown. This section describes local bus activities which have special signals or requirements.


Fig. 27 - BACK TO BACK WRITE-READ CYCLES



## HOLD and HLDA

HOLD and HLDA allow another bus master to gain control of the local bus by placing the MBL 80286 bus into the Th state. The sequence of events required to pass control between the MBL 80286 and another local bus master. are shown in Fig. 29.

In this example, the MBL 80286 is initially in the Th state as signaled by HLDA being active. Upon leaving Th, as signaled by HLDA going inactive, a write operation is started. During the write operation another local bus master requests the local bus from the MBL 80286 as shown by the HOLD signal. After completing the write operation, the MBL 80286 performs one Ti bus cycle, to guarantee write data hold time, then enters Th as signaled by HLDA going active.

The CMDLY signal and $\overline{\text { ARDY }}$ ready are used to start and stop the write bus command, respectively. Note that
 antee $\overline{\text { ARDY }}$ will terminate the cycle.

## Instruction Fetching

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

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

The prefetcher normally performs word prefetches independent of the byte alignment of the code segment base in physical memory.
The prefetcher will perform only a byte code fetch operation for control transfers to an instruction beginning on a numerically odd physical address.

Prefetching stops whenever a control transfer or HLT instruction is decoded by the IU and placed into the instruction queue.
In real address mode, the prefetcher may fetch up to 6 bytes beyond the last control transfer or HLT instruction in a code segment.

In protected mode, the prefetcher will never cause a segment overrun exception. The prefetcher stops at the last physical memory word of the code segment. Exception 13 will occur if the program attempts to execute beyond the last full instruction in the code segment.
If the last byte of a code segment appears on an even physical memory address, the prefetcher will read the next physical byte of memory (perform a word code fetch). The value of this byte is ignored and any attempt to execute if causes exception 13.

Fig. 29 - MULTIBUS WRITE TERMINATED BY ASYNCHRONOUS READ WITH BUS HOLD


## Ts = STATUS CYCLE <br> TC = COMMAND CYCLE <br> NOTES:

1. Status lines are not driven by MBL 80286, yet remain high due to pullup resistors in MBL 82288 and Intel 82289 during HOLD state.
2. Address, $M / \overline{\mathrm{OO}}$ and COD/ $\overline{\mathrm{INTA}}$ may start floating during any Tc depending on when internal MBL 80286 bus arbiter decides to release bus to external HOLD. The float starts in $\phi 2$ of $T C$.
3. $\overline{\mathrm{BHE}}$ and LOCK may start floating after the end of any Tc depending on when internal MBL 80286 bus arbiter decides to release bus to external HOLD. The float starts in $\phi 1$ of Tc.
4. The minimum HOLD to HLDA times is shown. Maximum is one Th longer.
5. The earliest HOLD time is shown. It will always allow a subsequent memory cycle if pending is shown.
6. The minimum HOLD to HLDA time is shown. Maximum is a function of the instruction, type of bus cycle and other machine status (i.e., Interrupts, Waits, Lock, etc.)
7. Asynchronous ready allows termination of the cycle. Synchronous ready does not signal ready in this example. Synchronous ready state is ignored after ready is signaled via the asynchronous input.

## Processor Extension Transfers

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

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

## Interrupt Acknowledge Sequence

Fig. 30 illustrates an interrupt acknowledge sequence performed by the MBL 80286 in response to an INTR input. An interrupt acknowledge sequence consists of two INTA bus operations. The first allows a master MBL 8259A Programmable Interrupt Controller (PIC) to determine which if any of its slaves should return the interrupt vector. An eight bit vector is read on DO-D7 of the MBL 80286 during the second INTA bus operation to select an interrupt handler routine from the interrupt table.

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

Three idle processor clocks are provided by the MBL 80286 between INTA bus operations to allow for the minimum INTA to INTA time and CAS (cascade address) out delay of the MBL 8259A. The second INTA bus operation must always have at least one extra Tc state added via logic controlling $\overline{\operatorname{READY}}$. A23-A0 are in 3 -state OFF until after the first Tc state of the second INTA bus operation. This prevents bus contention between the cascade address drivers and CPU address drivers. The extra Tc state allows time for the MBL 80286 to resume driving the address lines for subsequent bus operations.

## Local Bus Usage Priorities

The MBL 80286 local bus is shared among several internal units and external HOLD requests. In case of simultaneous requests, their relative priorities are:
(Highest) Any transfers which assert $\overline{\text { LOCK }}$ either explicitly (via the LOCK instruction prefix) or implicitly (i.e. segment descriptor access, interrupt acknowledge sequence, or an XCHG with memory).

The second of the two byte bus operations required for an odd aligned word operand.

The second or third cycle of a processor extension data transfer.

Local bus request via HOLD input.
Processor extension data operand transfer via PEREQ input.

Data transfer performed by EU as part of an instruction.
(Lowest) An instruction prefetch request from BU. The EU will inhibit prefetching two processor clocks in advance of any data transfers to minimize waiting by EU for a prefetch to finish.

## Halt or Shutdown Cycles

The MBL 80286 externally indicates halt or shutdown conditions as a bus operation. These conditions occur due to a HLT instruction or multiple protection exceptions while attempting to execute one instruction. A halt or shutdown bus operation is signalled when $\overline{\mathrm{S} 1}, \overline{\mathrm{SO}}$ and COD/ $\overline{\mathrm{INTA}}$ are LOW and $\mathrm{M} / \overline{\mathrm{IO}}$ is HIGH . A1 HIGH indicates halt, and A1 LOW indicates shutdown. The MBL 82288 bus controller does not issue ALE, nor is $\overline{\text { READY }}$ required to terminate a halt or shutdown bus operation.

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

Fig. 30 - INTERRUPT ACKNOWLEDGE SEQUENCE


MBL 80286
N


NOT READY READY NOT READY READY


## NOTES:

1. Data is ignored.
2. First INTA cycle should have at least one wait state inserted to meet MBL 8259A minimum INTA pulse width.
3. Second INTA cycle must have at least one wait state inserted since the CPU will not drive A23-A0, $\overline{B H E}$, and $\overline{\text { LOCK until after }}$ the first Tc state. The CPU imposed one/clock delay prevents bus contention between cascade address buffer being disabled by MCE $\downarrow$ and address outputs. Without the wait state, the MBL 80286 address will not be valid for a memory cycle started immediately after the second INTA cycle. The MBL 8259A also requires one wait state for minimum INTA pulse width.
4. $\overline{\text { LOCK }}$ is active for the first INTA cycle to prevent the Intel 82289 from releasing the bus between INTA cycles in a multi-master system.
5. A23-A0 exits 3 -state OFF during $\phi 2$ of the second $T c$ in the INTA cycle.

Fig. 31 - BASIC MBL 80286 SYSTEM CONFIGURATION


## SYSTEM CONFIGURATIONS

The versatile bus structure of the MBL 80286 microsystem, with a full complement of support chips, allows flexible configuration of a wide range of systems. The basic configuration, shown in Fig. 31, is similar to an MBL 8086 maximum mode system. It includes the CPU plus an MBL 8259A interrupt controller, MBL 82284 clock generator, and the MBL 82288 bus controller. The MBL 8086 latches (MBL 8282 and 8283) and transceivers (MBL 8286 and 8287) may be used in an MBL 80286 microsystem.

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

The MBL 80286 and Intel 80287 numeric data processor which includes the 80287 numeric processor extension (NPX) uses this interface. The MBL 80286 and Intel 80287 microsystem has all the instructions and data types of an MBL 8086 and Intel 8087 or MBL 8088 and Intel 8087 system. The 80287 NPX can perform numeric calculations and data transfers concurrently with CPU program execution. Numerics code and data have the same integrity as all other information protected by the MBL 80286 protection mechanism.

The MBL 80286 can overlap chip select decoding and address propagation during the data transfer for the previous bus operation. This information is latched into the MBL 8282/3's by ALE during the middle of a Ts cycle. The latched chip select and address information remains stable during the bus operation while the next cycles address is being decoded and propagated into the system. Decode logic can be implemented with a high speed bipolar PROM.

FUJITSU
MBL 80286-8

MBL 80286-6


The optional decode logic shown in Fig. 31 takes advantage of the overlap between address and data of the MBL 80286 bus cycle to generate advanced memory and 10 -select signals. This minimizes system performance degradation caused by address propagation and decode delays. In addition to selecting memory and I/O, the advanced selects may be used with configurations supporting local and system buses to enable the appropriate bus interface for each bus cycle. The COD $/ \overline{\mathrm{INTA}}$ and $\mathrm{M} / \overline{\mathrm{IO}}$ signals are applied to the decode logic to distinguish between interrupt,

I/O, code and data bus cycles.
By adding the 82289 bus arbiter chip the MBL 80286 provides a Multibus system bus interface as shown in Fig. 32. The ALE output of the MBL 82288 for the MULTIBUS bus is connected to its CMDLY input to delay the start of commands one system CLK as required to meet MULTIBUS address and write data setup times. This arrangement will add at least one extra Tc state to each bus operation which uses the MULTIBUS.
${ }^{*}$ MULTIBUS is a patented bus of Intel.

Fig. 33 - MBL 80286 SYSTEM CONFIGURATION WITH DUAL-PORTED MEMORY


A second MBL 82288 bus controller and additional latches and transceivers could be added to the local bus of Fig. 32. This configuration allows the MBL 80286 to support an on-board bus for local memory and peripherals, and the MULTIBUS for system bus interfacing.

Fig. 33 shows the addition of dual ported dynamic memory between the MULTIBUS system bus and the MBL 80286 local bus. The dual port interface is provided by the 8207 Dual Port DRAM Controller. The 8207 runs synchronously with the CPU to maximize throughput for local memory

Table 16 - MBL 80286 SYSTEMS RECOMMENDED PULL UP RESISTOR VALUES

| MBL 80286 Pin and Name | Pullup Value | Purpose |
| :---: | :---: | :---: |
| $4-\overline{S 1}$ | $20 \mathrm{k} \Omega \pm 10 \%$ | Pull $\overline{\mathrm{SO}}, \overline{\mathrm{S} 1}$, and $\overline{\text { PEACK }}$ inactive during MBL 80286 hold periods |
| $5-\overline{\text { So }}$ |  |  |
| $6-\overline{\text { PEACK }}$ |  |  |
| $53-\overline{\text { ERROR }}$ | $20 \mathrm{k} \Omega \pm 10 \%$ | Pull $\overline{\mathrm{ERROR}}$ and $\overline{\mathrm{BUSY}}$ inactive when 80287 not present (or temporarily removed from socket) |
| $54-\overline{\text { BUSY }}$ |  |  |
| 63 - $\overline{\text { READY }}$ | $910 \Omega \pm 5 \%$ | Pull $\overline{R E A D Y}$ inactive within required minimum time ( $C_{L}=150 \mathrm{pF}, \mathrm{I}_{\mathrm{R}} \leqq 7 \mathrm{~mA}$ ) |

references. It also arbitrates between requests from the local and system buses and performs functions such as refresh, initialization of RAM, and read/modify/write cycles. The 8207 combined with the 8206 Error Checking and Correction memory controller provide for single bit

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin with
Respect to Ground . . . . . . . . . . . . . . . . -1.0 to +7V
Power Dissipation 3.3 Watt
error correction. The dual-ported memory can be combined with a standard MULTIBUS system bus interface to maximize performance and protection in multiprocessor system configurations.
*NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

NOTICE: Specifications contained within the following tables are subject to change.
D.C. CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+55^{\circ} \mathrm{C}$, or $\mathrm{T}_{\text {CASE }}=0^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Symbol | Parameter | $\begin{gathered} \text { MBL 80286-6 } \\ (6 \mathrm{MHz}) \end{gathered}$ |  | $\begin{gathered} \text { MBL 80286-8 } \\ \text { (8 MHz) } \end{gathered}$ |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |  |
| $V_{\text {IL }}$ | Input LOW Voltage | -0.5 | 0.8 | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | 2.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | 2.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| VILC | CLK Input LOW Voltage | -0.5 | 0.6 | -0.5 | 0.6 | V |  |
| $\mathrm{V}_{\text {IHC }}$ | CLK Input HIGH Voltage | 3.8 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | 3.8 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage |  | 0.45 |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 2.4 |  | 2.4 |  | V | $\mathrm{IOH}^{\prime}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Leakage Current |  | $\pm 10$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqq \mathrm{~V}_{\text {IN }} \leqq \mathrm{V}_{\text {CC }}$ |
| IIL | Input Sustaining Current on $\overline{B U S Y}$ and $\overline{E R R O R}$ pins | 30 | 500 | 30 | 500 | $\mu \mathrm{A}$ | $V_{I N}=0 V$ |
| ILO | Output Leakage Current |  | $\pm 10$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqq \mathrm{~V}_{\text {OUT }} \leqq \mathrm{V}_{\mathrm{CC}}$ |
| ILO | Output Leakage Current |  | $\pm 1$ |  | $\pm 1$ | mA | $0 \mathrm{~V} \leqq \mathrm{~V}_{\text {OUT }} \leqq 0.45 \mathrm{~V}$ |
| ${ }^{\text {CC }}$ | Supply Current (turn on, $0^{\circ} \mathrm{C}$ ) |  | 600 |  | 600 | mA | Note 1 |
| $\mathrm{C}_{\text {CLK }}$ | CLK Input Capacitance |  | 20 |  | 20 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |
| $\mathrm{Cl}_{1 \mathrm{~N}}$ | Other Input Capacitance |  | 10 |  | 10 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{0}$ | Input/Output Capacitance |  | 20 |  | 20 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |

NOTE 1: Low temperature is worst case.

MBL 80286-8
FUJITSU
ADUANCE INFORMATIDN
MBL 80286-6
inlumillinilil|
A.C. CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+55^{\circ} \mathrm{C}$, or $\mathrm{T}_{\text {CASE }}=0^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

AC timings are referenced to 0.8 V and 2.0 V points of signals as illustrated in datasheet waveforms, unless otherwise noted.

| Symbol | Parameter | $\begin{gathered} \text { MBL } 80286-6 \\ (6 \mathrm{MHz}) \end{gathered}$ |  | $\begin{gathered} \text { MBL } 80286-8 \\ (8 \mathrm{MHz} \text { ) } \end{gathered}$ |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |  |
| 1 | System Clock (CLK) Period | 83 | 250 | 62 | 250 | ns |  |
| 2 | System Clock (CLK) LOW Time | 20 | 225 | 15 | 225 | ns | at 1.0 V |
| 3 | System Clock (CLK) HIGH Time | 25 | 230 | 25 | 235 | ns | at 3.6 V |
| 17 | System Clock (CLK) Rise Time |  | $10{ }^{1}$ |  | 10 | ns | 1.0 V to 3.6 V |
| 18 | System Clock (CLK) Fall Time |  | 10 |  | 10 | ns | 3.6 V to 1.0 V |
| 4 | Asynch. Inputs Setup Time | 30 |  | 20 |  | ns | Note 1 |
| 5 | Asynch. Inputs Hold Time | 30 |  | 20 |  | ns | Note 1 |
| 6 | RESET Setup Time | 33 |  | 28 |  | ns |  |
| 7 | RESET Hold Time | 5 |  | 5 |  | ns |  |
| 8 | Read Data Setup Time | 20 |  | 10 |  | ns |  |
| 9 | Read Data Hold Time | 8 |  | 8 |  | ns |  |
| 10 | $\overline{\text { READY }}$ Setup Time | 50 |  | 38 |  | ns |  |
| 11 | READY Hold Time | 35 |  | 25 |  | ns |  |
| 12 | Status/PEACK Valid Delay | 1 | 55 | 1 | 40 | ns | Note 2, Note 3 |
| 13 | Address Valid Delay | 1 | 80 | 1 | 60 | ns | Note 2, Note 3 |
| 14 | Write Data Valid Delay | 0 | 65 | 0 | 50 | ns | Note 2, Note 3 |
| 15 | Address/Status/Data Float Delay | 0 | 80 | 0 | 50 | ns | Note 2, Note 4 |
| 16 | HLDA Valid Delay | 0 | 80 | 0 | 50 | ns | Note 2, Note 3 |
| 19 | Address Valid to Status Valid Setup Time | - |  | 38 |  | , | Note 3, 5, and 6 |

NOTE 1: Asychronous inputs are INTR, NMI, HOLD, PEREQ, $\overline{E R R O R}$, and $\overline{B U S Y}$. This specification is given only for testing purposes, to assure recognition at a specific CLK edge.
NOTE 2: Delay from 0.8 V on the CLK, to 0.8 V or 2.0 V or float on the output as appropriate for valid or floating condition.
NOTE 3: Output load: $C_{L}=100 \mathrm{pF}$.
NOTE 4: Float condition occurs when output current is less than I LO in magnitude.
NOTE 5: Delay measured from address either reaching 0.8 V or 2.0 V (Valid) to status going active reaching 2.0 V or status going inactive reaching 0.8 V .
NOTE 6: For load capacitance of 10 pF on Status/PEACK lines, subtract typically 7 ns for 8 MHz spec.

NOTE 7: AC Test Loading on Outputs


NOTE 8: AC Drive and Measurement Points - CLK Input


WAVEFORMS


NOTE: For timing requirements of the MBL 82284 and MBL 82288 , refer to the data sheets of the MBL 82284 and MBL 82288.

## WAVEFORMS (Continued)



NOTES:

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

MBL 80286 RESET INPUT TIMING AND SUBSEQUENT PROCESSOR CYCLE PHASE


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


## NOTES:

1. These signals may not be driven by the MBL 80286 during the time shown. The worst case in terms of latest float time is shown.
2. The data bus will be driven as shown if the last cycle before $T_{1}$ in the diagram was a write Tc.
3. The MBL 80286 floats its status pins during $T_{H}$. External $20 \mathrm{k} \Omega$ resistors keep these signals high (see Table 16).
4. For HOLD request set up to HLDA, refer to Fig. 29.
5. $\overline{\mathrm{BHE}}$ and $\overline{\mathrm{LOCK}}$ are driven at this time but will not become valid until Ts.
6. The data bus will remain in 3 -state OFF if a read cycle is performed.

## WAVEFORMS (Continued)

MBL 80286 PEREQ/PEACK TIMING FOR ONE TRANSFER ONLY
BUS CYCLE TYPE


ASSUMING WORD-ALIGNED MEMORY OPERAND. IF ODD ALIGNED, MBL 80286 TRANSFERS TO/FROM MEMORY BYTE-AT-A-TIME WITH MEMORY CYCLES.

## NOTES:

1. PEACK always goes active during the first bus operation of a processor extension data operand transfer sequence. The first bus operation will be either a memory read at operand address or $1 / O$ read at port address $00 \mathrm{FA}(\mathrm{H})$.
2. To prevent a second processor extension data operand transfer, the worst case maximum time (Shown above) is: $3 x$ (1) - (11) max. (4) min. The actual, configuration dependent, maximum time is: $3 x$ (1) - (11) max. - (4) min. $+A x 2 x$ (1).

A is the number of extra Tc states added to either the first or second bus operation of the processor extension data operand transfer sequence.

## WAVEFORMS (Continued)

INITIAL MBL 80286 PIN STATE DURING RESET


## NOTES:

1. Setup time for RESET $\uparrow$ may be violated with the consideration that $\phi 1$ of the processor clock may begin one system CLK period later.
2. Setup and hold times for RESET $\downarrow$ must be met for proper operation, but RESET $\downarrow$ may occur during $\phi 1$ or $\phi 2$.
3. The data bus is only guaranteed to be in 3 -state OFF at the time shown.
4. HOLD is acknowledged during RESET, causing HLDA to go active and the appropriate pins to float. If HOLD remains active while RESET goes inactive, the MBL 80286 remains in HOLD state and will not perform any bus accesses until HOLD is de-activated.

Fig. 35 - MBL 80286 INSTRUCTION FORMAT EXAMPLES

| BYTE 1 | BYTE 2 | BYTE 3 | BYTE 4 | BYTE 5 |
| :--- | :--- | :--- | :--- | :--- |


A. SHORT OPCODE FORMAT EXAMPLE
$\begin{array}{llll}\text { BYTE } 1 & \text { BYTE } 2 & \text { BYTE 3 BYTE } 4 & \text { BYTE } 5\end{array}$

B. LONG OPCODE FORMAT EXAMPLE

## MBL 80286 INSTRUCTION SET SUMMARY

## Instruction Timing Notes

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

To calculate elapsed times for instruction sequences, multiply the sum of all instruction clock counts, as listed in the table below, by the processor clock period. An 8 MHz processor clock has a clock period of 125 nanoseconds and requires a MBL 80286 system clock (CLK input) of 16 MHz .

## Instruction Clock Count Assumptions

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

## Instruction Set Summary Notes

Addressing displacements selected by the MOD field are not shown. If necessary they appear after the instruction fields shown.
Above/below refers to unsigned value
Greater refers to positive signed value
Less refers to less positive (more negative) signed values
if $d=1$ then to register; if $d=0$ then from register
if $w=1$ then word instruction; if $w=0$ then byte instruction
if $s=0$ then 16-bit immediate data form the operand
if $s=1$ then an immediate data byte is sign-extended to form the 16 -bit operand
$x$ don't care
z used for string primitives for comparison with ZF FLAG
If two clock counts are given, the smaller refers to a register operand and the larger refers to a memory operand

* $=$ add one clock if offset calculation requires summing 3 elements
$\mathrm{n}=$ number of times repeated
$\mathrm{m}=$ number by bytes of code in next instruction
Level (L) - Lexical nesting level of the procedure

The following comments describe possible exceptions, side effects, and allowed usage for instructions in both operating modes of the MBL 80286.

## REAL ADDRESS MODE ONLY

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

## EITHER MODE

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

## PROTECTED VIRTUAL ADDRESS MODE ONLY

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

MBL 80286 INSTRUCTION SET SUMMARY

| FUNCTION | FORMAT |  |  |  | CLOCK COUNT |  | COMMENTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Real Address Mode | Protected Virtual Address Mode | Real Address Mode | Protected Virtual Address Mode |
| DATA TRANSFER MOV = Move: |  |  |  |  |  |  |  |  |
| Register to Register/memory | 1000100w | mod reg r/m |  |  | 2,3* | 2,3* | 2 | 9 |
| Register/memory to register | 1000101 w <br> 1 | mod reg r/m |  |  | 2,5* | 2,5* | 2 | 9 |
| Immediate to register/memory | 1100011 w <br> 1 | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if w=1 | 2,3* | 2,3* | 2 | 9 |
| Immediate to register | 1011 wreg | data | data if w=1 |  | 2 | 2 |  |  |
| Memory to accumulator | 1010000w | addr-low | addr-high |  | 5 | 5 | 2 | 9 |
| Accumulator to memory | 1010001m | addr-low | addr-high |  | 3 | 3 | 2 | 9 |
| Register/memory to segment register | 10001110 | $\bmod 0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  | 2,5* | 17,19* | 2 | 9,10,11 |
| Segment register to register/ memory | 10001100 | mod $0 \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  | 2,3* | 2,3* | 2 | 9 |
| PUSH = Push: |  |  |  |  |  |  |  |  |
| Memory | (111111111 | $\bmod 110 \mathrm{r} / \mathrm{m}$ |  |  | 5* | 5* | 2 | 9 |
| Register | 01010 reg |  |  |  | 3 | 3 | 2 | 9 |
| Segment register | 000 reg 110 |  |  |  | 3 | 3 | 2 | 9 |
| Immediate | 011010 s 0 | data | data if $\mathrm{s}=0$ |  | 3 | 3 | 2 | 9 |
| PUSHA = Push All | 01100000 |  |  |  | 17 | 17 | 2 | 9 |
| $\mathbf{P O P}=\mathbf{P o p}$ : |  |  |  |  |  |  |  |  |
| Memory | 10001111 | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 5* | 5* | 2 | 9 |
| Register | 01011 reg |  |  |  | 5 | 5 | 2 | 9 |
| Segment register | 0000 reg 111 | $(\mathrm{reg} \neq 01$ ) |  |  | 5 | 20 | 2 | 9,10,11 |
| POPA = Pop All | 01100001 |  |  |  |  | 19 | 2 | 9 |
| XCHG = Exchange: |  |  |  |  |  |  |  |  |
| Register/memory with register | 1000011m | mod reg r/m |  |  | 3,5* | 3,5* | 2,7 | 7,9 |
| Register with accumulator | 10010 reg |  |  |  | 3 | 3 |  |  |
| $\mathrm{IN}=$ Input from: |  |  |  |  |  |  |  |  |
| Fixed port | 1110010w | port |  |  | 5 | 5 |  | 14 |
| Variable port | 1110110 w |  |  |  | 5 | 5 |  | 14 |
| OUT = Output to: |  |  |  |  |  |  |  |  |
| Fixed port | 1110011m | port |  |  | 3 | 3 |  | 14 |
| Variable port | 1110111 w |  |  |  | 3 | 3 |  | 14 |
| XLAT = Translate byte to AL | 111010111 |  |  |  | 5 | 5 |  | 9 |
| LEA = Load EA to register | 10001101 | mod reg r/m |  |  | 3* | 3* |  |  |
| LDS = Load pointer to DS | 11000101 | mod reg r/m | $(\bmod \neq 11)$ |  | 7* | 21* | 2 | 9,10,11 |
| LES = Load pointer to ES | 11000100 | mod reg r/m | $(\bmod \neq 11)$ |  | 7* | 21* | 2 | 9,10,11 |
| LAHF = Load AH with flags | 10011111 |  |  |  | 2 | 2 |  |  |
| SAHF = Store AH into flags | 10011110 |  |  |  | 2 | 2 |  |  |
| PUSHF = Push flags | 10011100 |  |  |  | 3 | 3 | 2 | 9 |
| POPF = Pop flags | 10011101 |  |  |  | 5 | 5 | 2,4 | 9,15 |

Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

FUIITSU
MBL 80286-8

MBL 80286-6

## MBL 80286 INSTURCTION SET SUMMARY (Continued)

| FUNCTION | FORMAT |  |  |  | CLOCK COUNT |  | COMMENTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Real Address Mode | Protected Virtual Address Mode | Real Address Mode | Protected Virtual Address Mode |
| ARITHMETIC |  |  |  |  |  |  |  |  |
| ADD = Add: |  |  |  |  |  |  |  |  |
| Reg/memory with register to either | 000000 dw | mod reg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| Immediate to register/memory | 100000 sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if s w=01 | 3,7* | 3,7* | 2 | 9 |
| Immediate to accumulator | 0000010 w | data | data if w=1 |  | 3 | 3 |  |  |
| ADC = Add with carry: |  |  |  |  |  |  |  |  |
| Reg/memory with register to either | 000100 dw | mod reg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| Immediate to register/memory | 100000 sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s} w=01$ | 3,7* | 3,7* | 2 | 9 |
| Immediate to accumulator | 0001010 w | data | data if w=1 |  | 3 | 3 |  |  |
| INC = Increment: |  |  |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 2,7* | 2,7* | 2 | 9 |
| Register | 01000 reg |  |  |  | 2 | 2 |  |  |
| SUB = Subtract: |  |  |  |  |  |  |  |  |
| Reg/memory and register to either | 001010 dw | mod reg r/m |  |  | 2,7 | 2,7* | 2 | 9 |
| Immediate from register/memory | 100000 sw | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if s w $=01$ | 3,7* | 3,7* | 2 | 9 |
| Immediate from accumulator | 0010110 w | data | data if w=1 |  | 3 | 3 |  |  |
| SBB $=$ Subtract with borrow: |  |  |  |  |  |  |  |  |
| Reg/memory and register to either | 000110 dw | mod reg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| Immediate from register/memory | 100000 sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if sw=01 | 3,7* | 3,7* | 2 | 9 |
| Immediate from accumulator | 0001110 w | data | data if $w=1$ |  | 3 | 3 |  |  |
| DEC = Decrement: |  |  |  |  |  |  |  |  |
| Register/memory | 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  | 2,7* | 2,7* | 2 | 9 |
| Register | 01001 reg |  |  |  | 2 | 2 |  |  |
| CMP = Compare: |  |  |  |  |  |  |  |  |
| Register/memory with register | 0011101 w | mod reg r/m |  |  | 2,6* | 2,6* | 2 | 9 |
| Register with register/memory | 0011100 w | mod reg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| Immediate with register/memory | 100000 sw | mod $111 \mathrm{r} / \mathrm{m}$ | data | data if s w=01 | 3,6* | 3,6* | 2 | 9 |
| Immediate with accumulator | 0011110 w | data | data if w=1 |  | 3 | 3 |  |  |
| NEG = Change sign | 1111011 w | $\mathrm{mod} 011 \mathrm{r} / \mathrm{m}$ |  |  | 2 | 7* | 2 | 7 |
| AAA = ASCII adjust for add | 00110111 |  |  |  | 3 | 3 |  |  |
| DAA $=$ Decimal adjust for add | 00100111 |  |  |  | 3 | 3 |  |  |
| AAS = ASCII adjust for subtract | 00111111 |  |  |  | 3 | 3 |  |  |
| DAS = Decimal adjust for subtract | 00101111 |  |  |  | 3 | 3 |  |  |
| MUL = Multiply (unsigned) : | 1111011 w | $\mathrm{mod} 100 \mathrm{r} / \mathrm{m}$ |  |  |  |  |  |  |
| Register-Byte |  |  |  |  | 13 | 13 |  |  |
| Register-Word |  |  |  |  | 21 | 21 |  |  |
| Memory-Byte |  |  |  |  | 16* | 16* | 2 | 9 |
| Memory-Word |  |  |  |  | 24* | 24* | 2 | 9 |
| IMUL = Integer multiply (signed): | 1111011 w | $\bmod 101 \mathrm{r} / \mathrm{m}$ |  |  |  |  |  |  |
| Register-Byte |  |  |  |  | 13 | 13 |  |  |
| Register-Word |  |  |  |  | 21 | 21 |  |  |
| Memory-Byte |  |  |  |  | 16* | 16* | 2 | 9 |
| Memory-Word |  |  |  |  | 24* | / 24* | 2 | 9 |

## MBL 80286 INSTURCTION SET SUMMARY (Continued)



Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

MBL 80286 INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

MBL 80286 INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

MBL 80286 INSTURCTION SET SUMMARY (Continued)

| FUNCTION | FORMAT |  |  |  | CLOCK COUNT |  | COMMENTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Real Address Mode | Protected Virtual Address Mode | Real Address Mode | Protected Virtual Address Mode |
| CONTROL TRANSFER (Continued) |  |  |  |  |  |  |  |  |
| JE/JZ = Jump on equal/zero | 01110100 | disp |  |  | $7+\mathrm{m}$ or 3 | $7+\mathrm{m}$ or 3 |  | 18 |
| JL/JNGE = Jump on less/not greater or equal | 0 1 1 1 1 0 0 | disp |  |  | $7+\mathrm{m}$ or 3 | $7+\mathrm{m}$ or 3 |  | 18 |
| JLE/JNG = Jump on less or equal/ | 0 1 1 1 1 0 | disp |  |  | $7+\mathrm{m}$ or 3 | $7+\mathrm{m}$ or 3 |  | 18 |
| $\begin{aligned} \mathrm{JB} / \mathrm{JNAE}= & \text { Jump on below/not } \\ & \text { above or equal } \end{aligned}$ | 01110010 | disp |  |  | $7+\mathrm{m}$ or 3 | $7+m$ or 3 |  | 18 |
| $\begin{aligned} \text { JBE/JNA }= & \text { Jump on below or } \\ & \text { equal/not above } \end{aligned}$ | 01 1 1 1 1 0 | disp |  |  | $7+\mathrm{m}$ or 3 | $7+\mathrm{m}$ or 3 |  | 18 |
| $\text { JP/JPE }=\underset{\text { Jump }}{J}$ | \| 0111111010 | disp |  |  | 7+m or 3 | $7+m$ or 3 |  | 18 |
| JO = Jump on overflow | 01110000 | disp |  |  | $7+m$ or 3 | $7+m$ or 3 |  | 18 |
| JS = Jump on sign | 01111000 | disp |  |  | $7+\mathrm{m}$ or 3 | $7+\mathrm{m}$ or 3 |  | 18 |
| $\underset{\text { zero }}{\text { JNE/JNZ }}=\underset{\text { Jump on not equal/not }}{ }$ | 01110101 | disp |  |  | $7+\mathrm{m}$ or 3 | $7+m$ or 3 |  | 18 |
| $\begin{aligned} \text { JNL/JGE }= & \text { Jump on not less/ } \\ & \text { greater or euqal } \end{aligned}$ | 0 1 1 1 1 1 0 1 | disp |  |  | $7+\mathrm{m}$ or 3 | $7+\mathrm{m}$ or 3 |  | 18 |
| $\begin{gathered} \text { JNLE/JG }=\underset{\text { equal/greater }}{\text { Jump on }} \text { not less or } \\ \text { ent } \end{gathered}$ | 011 1 1 | disp |  |  | $7+\mathrm{m}$ or 3 | $7+m$ or 3 |  | 18 |
| $\begin{aligned} \text { JNB/JAE }= & \text { Jump on not below/ } \\ & \text { above or equal } \end{aligned}$ |  | disp |  |  | $7+m$ or 3 | $7+m$ or 3 |  | 18 |
| $\begin{aligned} & \text { JNBE/JA = Jump on not below or } \\ & \text { equal/above } \end{aligned}$ | 01110111 | disp |  |  | $7+m$ or 3 | $7+m$ or 3 |  | 18 |
| $\text { JNP/JPO = } \underset{\text { odd }}{\operatorname{Jump}} \text { on not par/par }$ | 0 1 1 1 1 1 1 1 | disp |  |  | $7+\mathrm{m}$ or 3 | $7+m$ or 3 |  | 18 |
| JNO = Jump on not overflow | 01110001 | disp |  |  | $7+\mathrm{m}$ or 3 | $7+\mathrm{m}$ or 3 |  | 18 |
| JNS = Jump on not sign | 01111001 | disp |  |  | $7+\mathrm{m}$ or 3 | $7+\mathrm{m}$ or 3 |  | 18 |
| LOOP = Loop CX times | 11100010 | disp |  |  | $8+\mathrm{m}$ or 4 | $8+\mathrm{m}$ or 4 |  | 18 |
| $\text { LOOPZ/LOOPE = } \underset{\text { zero/equal }}{\text { Loop while }}$ | 11100001 | disp |  |  | $8+m$ or 4 | $8+m$ or 4 |  | 18 |
| LOOPNZ/LOOPNE $=$ Loop while not zero/equal | 11100000 | disp |  |  | $8+m$ or 4 | $8+m$ or 4 |  | 18 |
| JCXZ = Jump on CX zero | 11100011 | disp |  |  | $8+\mathrm{m}$ or 4 | $8+m$ or 4 |  | 18 |
| ENTER = Enter Procedure | 11001000 | data-low | data-high | L |  |  | 2,8 | 8,9 |
| $\mathrm{L}=0$ |  |  |  |  | 11 | 11 | 2,8 | 8,9 |
|  |  |  |  |  | 15 | 15 | 2,8 | 8,9 |
| $L>1$ |  |  |  |  | $\begin{aligned} & 16+4 x \\ & (L-1) \end{aligned}$ | $\begin{aligned} & 16+4 x \\ & (L-1) \end{aligned}$ | 2,8 | 8,9 |
| LEAVE = Leave Procedure | 11001001 |  |  |  | 5 | 5 |  |  |
| INT = Interrupt: |  |  |  |  |  |  |  |  |
| Type specified | 11001101 | type |  |  | 23+m |  | 2,7,8 |  |
| Type 3 | 11001100 |  |  |  | $23+m$ |  | 2,7,8 |  |
| INTO = Interrupt on overflow | 11001110 |  |  |  | $\left\lvert\, \begin{gathered} 24+\text { mor } 3 \\ (3 \text { if no } \\ \text { interrupt }) \end{gathered}\right.$ | (3 if no interrupt) | 2,6,8 |  |

Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

MBL 80286 INSTRUCTION SET SUMMARY (Continued)

| FUNCTION | FORMAT |  |  | CLOCK COUNT |  | COMMENTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Real Address Mode | Protected Virtual Address Mode | Real Address Mode | Protected Virtual Address Mode |
| CONTROL TRANSFER (Continued) |  |  |  |  |  |  |  |
| Protected Mode Only: |  |  |  |  |  |  |  |
| Via interrupt or trap gate to same privilege level |  |  |  | 17+m | 40+m |  | $\begin{array}{r} 7,8,11 \\ 12,18 \end{array}$ |
| Via interrupt or trap gate to fit different privilege level |  |  |  |  | 78+m |  | $\begin{array}{r} 7,8,11 \\ 12,18 \end{array}$ |
| Via Task Gate |  |  |  |  | $167+m$ |  | $7,8,11$ 12,18 |
| $\mathbf{I R E T}=$ Interrupt return | 11001111 |  |  |  | $31+m$ | 2,4 | $\begin{gathered} 8,9,11 \\ 12,15,18 \end{gathered}$ |
| Protected Mode Only: |  |  |  |  |  |  |  |
| To different privilege level |  |  |  |  | 55+m |  | $\begin{gathered} 8,9,11 \\ 12,15,18 \end{gathered}$ |
| To differetit task ( $\mathrm{NT}=1$ ) |  |  |  |  | $169+m$ |  | $\begin{array}{r} 8,9,11 \\ 12,18 \end{array}$ |
| $\begin{aligned} & \text { SOUND }=\begin{array}{c} \text { Detect value out of } \\ \text { range } \end{array} \end{aligned}$ | 01100010 | mod reg r/m |  |  | 13* | $13^{*}$ (Use INT clock count if excep- tion 5) | 2,6 | $\begin{gathered} 6,8,9,11 \\ 12,18 \end{gathered}$ |
|  |  |  |  |  |  |  |  |
| CLC = Clear carry | 11111000 |  |  | 2 | 2 |  |  |
| $\mathbf{C M C}=\text { Complement carry }$ | 11110101 |  |  | 2 | 2 |  |  |
| STC = Set carry | 11111001 |  |  | 2 | 2 |  |  |
| CLD $=$ Clear direction | 11111100 |  |  | 2 | 2 |  |  |
| STD $=$ Set direction | 11111101 |  |  | 2 | 2 |  |  |
| CLI $=$ Clear interrupt | 11111010 |  |  | 3 | 3 |  | 14 |
| STI = Set interrupt | 11111011 |  |  | 2 | 2 |  | 14 |
| HLT = Halt | 11110100 |  |  | 2 | 2 |  | 13 |
| WAIT = Wait | 10011011 |  |  | 3 | 3 |  |  |
| LOCK = Bus lock prefix | 11110000 |  |  | 0 | 0 |  | 14 |
| CTS = Clear task switched flag | 00001111 | 00000110 |  | 2 | 2 | 3 | 13 |
| ESC = Processor Extension Escape | 11011 TTT | mod LLL r/m |  | 9-20* | 9-20* | 5,8 | 8,17 |
| SEG $=$ Segment Override Prefix (TTT LLL are opcode to processor extension) <br> 001 reg 110  |  |  |  | 0 | 0 |  |  |
| PROTECTION CONTROL |  |  |  |  |  |  |  |
| LGDT = Load global descriptor table register | 00001111 | 00000001 | $\bmod 010 \mathrm{r} / \mathrm{m}$ | 11* | 11* | 2,3 | 9,13 |
| SGDT = Store global descriptor table register | 00001111 | 00000001 | $\bmod 000 \mathrm{r} / \mathrm{m}$ | 11* | 11* | 2,3 | 9 |
| LIDT = Load interrupt descriptor table register | 00001111 | 00000001 | $\bmod 011 \mathrm{r} / \mathrm{m}$ | 12* | 12* | 2,3 | 9,13 |
| SIDT = Store interrupt descriptor table register | 00001111 | 00000001 | $\bmod 001 \mathrm{r} / \mathrm{m}$ | 12* | 12* | 2,3 | 9 |
| LLDT = Load local descriptor table register from register memory | 00001111 | 00000000 | $\bmod 010 \mathrm{r} / \mathrm{m}$ |  | 17,19* | 1 | 9,11,13 |

[^1]MBL 80286 INSTRUCTION SET SUMMARY (Continued)

| FUNCTION <br> FORMAT <br> PROTECTION CONTROL (Continued) | FORMAT |  |  | CLOCK COUNT |  | COMMENTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Real Address Mode | Protected Virtual Address Mode | Real Address Mode | Protected Virtual Address Mode |
| PROTECTION CONTROL (Continued) |  |  |  |  |  |  |  |
| SLDT $=$ Store local descriptor table register to register/ memory | $\begin{array}{\|l\|l\|l\|l\|} \hline 00001111 & 00000000 & \bmod 000 \mathrm{r} / \mathrm{m} \\ \hline \end{array}$ |  |  | $\begin{aligned} & 3,6^{*} \\ & 2,3^{*} \end{aligned}$ | $\begin{gathered} 2,3^{*} \\ 17,19^{*} \end{gathered}$ | 1 | 9$9,11,13$ |
| $\begin{gathered} L T R=\underset{\text { Load task register from }}{\text { register/memory }} \end{gathered}$ | 00001111 | 00000000 | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  |  |  |
| STR $=$ Store task register to register memory | 00001111 | 00000000 | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  | 2,3* | 1 | 9 |
| $\begin{gathered} \text { LMSW = Load machine status word } \\ \text { from register/memory } \end{gathered}$ | 00001111 00000001 $\mathrm{mod} 110 \mathrm{r} / \mathrm{m}$ |  |  |  | $\begin{aligned} & 3,6^{*} \\ & 2,3^{*} \end{aligned}$ | 2,3 | 9,13 |
|  | 00001111 00000001 $\mathrm{mad} 100 \mathrm{r} / \mathrm{m}$ |  |  |  |  | 2,3 | 9 |
| SMSW = Store machine status word <br> LAR = Load access rights from register/memory |  |  |  |  | 14,16* | 1 | 9,11,16 |
| LSL = Load segment limit from register/memory | 00001111 | 00000011 | $\mathrm{mod} \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  | 14,16* | 1 | 9,11,16 |
| ARPL = Adjust register privilege level from register/memory | 01100011 $\mathrm{mod} \mathrm{reg} \mathrm{r/m}$  <br> 0.   <br> 00001111 00000000 $\mathrm{mod} 100 \mathrm{r} / \mathrm{m}$ |  |  |  | 10*.11* | 2 | 8,9 |
| VERR = Verify read access: register/memory <br> VERR = Verify write access: |  |  |  | 14,16* | 1 | 9,11,16 |  |
|  | $00001111000000000 \mid \mathrm{mod} 101 \mathrm{r} / \mathrm{m}$ |  |  |  | 14,16* | 1 | 9,11,16 |

Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

## Footnotes

The effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields:
if $\bmod =00$ then DISP $=0^{*}$, disp-low and disp-high are absent
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 $r / m=001$ then $E A=(B X)+(D I)+D I S P$
if $r / m=010$ then $E A=(B P)+(S I)+$ DISP
if $\mathrm{r} / \mathrm{m}=011$ then $E A=(B P)+(D I)+D I S P$
if $\mathrm{r} / \mathrm{m}=100$ then $E A=(\mathrm{SI})+$ DISP
if $\mathrm{r} / \mathrm{m}=101$ then $E A=(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $E A=(B P)+D I S P^{*}$
if $r / m=111$ then $E A=(B X)+$ DISP

DISP follows 2nd byte of instruction (before data if required)
*except if $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then EA $=$ disp-high: disp-low

## SEGMENT OVERRIDE PREFIX

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

reg is assigned according to the following:

## reg Segment Register

00
ES
01
CS
10
SS
11
DS

REG is assigned according to the following table:

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

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

## PACKAGE ILLUSTRATION



PACKAGE DIMENSIONS (Suffix: -CV)

68-PAD CERAMIC (METAL SEAL) LEADLESS CHIP CARRIER (CASE No.: LCC-68C-A01)


## PACKAGE ILLUSTRATION



PACKAGE DIMENSIONS (Suffix: -CR)
68-LEAD CERAMIC (METAL SEAL) PIN GRID ARRAY (CASE No.: PGA-68C-A01)
 inches(millimeters)

## FUJITSU

BIPOLAR CLOCK GENERATOR AND READY INTERFACE FOR MBL 80286 PROCESSORS

## BIPOLAR CLOCK GENERATOR AND READY INTERFACE FOR MBL 80286 PROCESSORS

The Fujitsu MBL 82284 is a clock generator/driver which provides clock signals for MBL 80286 processors and support components. It also contains logic to supply $\overline{\text { READY }}$ to the CPU from either asynchronous or synchronous sources and synchronous RESET from an asynchronous input with hysteresis.

- Generates System Clock for MBL 80286 Processors
- Uses Crystal or TTL Signal for Frequency Source
- Provides Local READY and Multibus* READY Synchronization
- Generates System Reset Output from Schmitt Trigger Input
- Single +5 V Power Supply
- Two Package Options:
- 18-pin Cerdip (Suffix: CZ)
- 18-pin Plastic DIP (Suffix: P)

Fig. 1 - BLOCK DIAGRAM


Fig. 2 - PIN CONFIGURATION


## PIN DESCRIPTION

The following pin function descriptions are for the MBL 82284 clock generator.
Table 1 - PIN DESCRIPTION

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| CLK | 0 | System Clock is the signal used by the processor and support devices which must be synchro nous with the processor. The frequency of the CLK output has twice the desired internal processor clock frequency. CLK can drive both TTL and MOS level inputs. |
| F/C | 1 | Frequency/Crystal Select is a strapping option to select the source for the CLK output. When F/ $\overline{\mathrm{C}}$ is strapped LOW, the internal crystal oscillator drives CLK. When F/C is strapped HIGH, the EFI input drives the CLK output. |
| x1, $\times 2$ | 1 | Crystall In are the pins to which a parallel resonant fundamental mode crystal is attached for the internal oscillator. When $\mathrm{F} / \overline{\mathrm{C}}$ is LOW, the internal oscillator will drive the CLK output at the crystal frequency. The crystal frequency must be twice the desired internal processor clock frequency. |
| EFI | 1 | External Frequency In drives CLK when the F/ $\overline{\mathrm{C}}$ input is strapped HIGH. The EFI input frequency must be twice the desired internal processor clock frequency. |
| PCLK | O | Peripheral Clock is an output which provides a $50 \%$ duty cycle clock with $1 / 2$ the frequency of CLK. PCLK will be in phase with the internal processor clock following the first bus cycle after the processor has been reset. |
| $\overline{\text { ARDYEN }}$ | 1 | Asynchronous Ready Enable is an active LOW input which qualifies the $\overline{\text { ARDY }}$ input. $\overline{\text { ARDYEN selects }} \overline{\text { ARDY }}$ as the source of ready for the current bus cycle. Inputs to $\overline{\text { ARDYEN }}$ may be applied asynchronously to CLK. Setup and hold times are given to assure a guaranteed response to synchronous inputs. |
| $\overline{\text { ARDY }}$ | 1 | Asynchronous Ready is an active LOW input used to terminate the current bus cycle. The <br>  CLK. Setup and hold times are given to assure a guaranteed response to synchronous inputs. |
| $\overline{\text { SRDYEN }}$ | 1 | Synchronous Ready Enable is an active LOW input which qualifies SRDY. SRDYEN selects $\overline{\text { SRDY }}$ as the source for $\overline{\text { READY }}$ to the CPU for the current bus cycle. Setup and hold times must be satisfied for proper operation. |
| $\overline{\text { SRDY }}$ | 1 | Synchronous Ready is an active LOW input used to terminate the current bus cycle. The SRDY input is qualified by the SRDYEN input. Setup and hold times must be satisfied for proper operation. |
| READY | 0 | Ready is an active LOW output which signals the current bus cycle is to be completed. The $\overline{S R D Y}, \overline{S R D Y E N}, \overline{A R D Y}, \overline{A R D Y E N}, \overline{S 1}, \overline{\text { SO }}$ and $\overline{\operatorname{RES}}$ inputs control $\overline{\operatorname{READY}}$ as explained later in the $\overline{R E A D Y}$ generator section. $\overline{\text { READY }}$ is an open collector output requiring an external $910 \Omega$ pullup resistor. |
| $\overline{\mathrm{So}}, \overline{\mathrm{s} 1}$ | 1 | Status inputs prepare the MBL 82284 for a subsequent bus cycle. $\overline{\mathrm{SO}}$ and $\overline{\mathrm{Si}}$ synchronize PCLK to the internal processor clock and control READY. These inputs have pullup resistors to keep them HIGH if nothing is driving them. Setup and hold times must be satisfied for proper operation. |
| RESET | 0 | Reset is an active HIGH output which is derived from the $\overline{\text { RES }}$ input. RESET is used to force the system into an initial state. When RESET is active, $\overline{\text { READY }}$ will be active (LOW). |
| $\overline{\mathrm{RES}}$ | 1 | Reset In is an active LOW input which generates the system reset signal RESET. Signals to $\overline{\mathrm{RES}}$ may be applied asynchronously to CLK. A Schmitt trigger input is provided on RES, so that an RC circuit can be used to provide a time delay. Setup and hold times are given to assure a guaranteed response to synchronous inputs. |
| $\mathrm{V}_{\mathrm{cc}}$ |  | System Power: +5 V power supply. |
| GND |  | System Ground: 0 volts. |

## FUNCTIONAL DESCRIPTION

## INTRODUCTION

The MBL 82284 generates the clock, ready, and reset signals required for MBL 80286 processors and support components. The MBL 82284 is packaged in an 18 -pin DIP and contains a crystal controlled oscillator, MOS clock generator, peripheral clock generator, Multibus ready synchronization logic and system reset generation logic.

## CLOCK GENERATOR

The CLK output provides the basic timing control for an MBL 80286 system. CLK has output characteristics sufficient to drive MOS devices. CLK is generated by either an internal crystal oscillator or an external source as selected by the $F / \bar{C}$ strapping option. When $F / \bar{C}$ is LOW, the crystal oscillator drives the CLK output. When F/ $\overline{\mathrm{C}}$ is HIGH, the EFI input drives the CLK output.
The MBL 82284 provides a second clock output (PCLK) for peripheral devices. PCLK is CLK divided by two. PCLK has a duty cycle of $50 \%$ and TTL output drive characteristics. PCLK is normally synchronized to the internal processor clock.
After reset, the PCLK signal may be out of phase with the internal processor clock. The $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 0}$ signals of the first bus cycle are used to synchronize PCLK to the internal processor clock. The phase of the PCLK output changes by extending its HIGH time beyond one system clock (see waveforms). PCLK is forced HIGH whenever either $\overline{\mathrm{SO}}$ or $\overline{\mathrm{S} 1}$ were active (LOW) for the two previous CLK cycles. PCLK continues to oscillate when both $\overline{\mathrm{SO}}$ and $\overline{\mathrm{S} 1}$ are HIGH.

Since the phase of the internal processor clock will not change except during reset, the phase of PCLK will not change except during the first bus cycle after reset.

## OSCILLATOR

The oscillator circuit of the MBL 82284 is a linear Pierce oscillator which requires an external parallel resonant, fundamental mode, crystal. The output of the oscillator

Fig. 3 - RECOMMENDED CRYSTAL AND READY CONNECTIONS

is internally buffered. The crystal frequency chosen should be twice the required internal processor clock frequency. The crystal should have a typical load capacitance of 32 pF .

X1 and X2 are the oscillator crystal connections. For stable operation of the oscillator, two loading capacitors are recommended, as shown in Table 2. The sum of the board capacitance and loading capacitance should equal the values shown. It is advisable to limit stray board capacitances (not including the effect of the loading capacitors or crystal capacitance) to less than 10 pF between the X1 and X2 pins. Decouple $\mathrm{V}_{\mathrm{cc}}$ and GND as close to the MBL 82284 as possible.

## RESET OPERATION

The reset logic provides the RESET output to force the system into a known, initial state. When the $\overline{R E S}$ input is active (LOW), the RESET output becomes active (HIGH). $\overline{\mathrm{RES}}$ is synchronized internally at the falling edge of CLK before generating the RESET output (see waveforms). Synchronization of the $\overline{\mathrm{RES}}$ input introduces a one or two CLK delay before affecting the RESET output.

At power up, a system does not have a stable $\mathrm{V}_{\mathrm{CC}}$ and CLK. To prevent spurious activity, RES should be asserted until $\mathrm{V}_{\mathrm{CC}}$ and CLK stabilize at their operating values. MBL 80286 processors and support components also require their RESET inputs be HIGH a minimum of 16 CLK cycles. An RC network, as shown in Fig. 4, will keep RES LOW long enough to satisfy both needs.

Fig. 4 - TYPICAL RC $\overline{\text { RES }}$ TIMING CIRCUIT


A Schmitt trigger input with hysteresis on $\overline{\mathrm{RES}}$ assures a single transition of RESET with an RC circuit on RES. The hysteresis separates the input voltage level at which the circuit output switches between HIGH to LOW from the input voltage level at which the circuit output switches between LOW to HIGH. The $\overline{\mathrm{RES}}$ HIGH to LOW input transition voltage is lower than the $\overline{\mathrm{RES}}$ LOW to HIGH input transition voltage. As long as the slope of the $\overline{\mathrm{RES}}$ input voltage remains in the same direction (increasing
or decreasing) around the $\overline{\mathrm{RES}}$ input transition voltage, the RESET output will make a single transition.

## READY OPERATION

The MBL 82284 accepts two ready sources for the system ready signal which terminates the current bus cycle. Either a synchronous ( $\overline{\mathrm{SRDY}}$ ) or asynchronous ready ( $\overline{\mathrm{ARDY}}$ ) source may be used. Each ready input has an enable (SRDYEN and $\overline{\text { ARDYEN }}$ ) for selecting the type of ready source required to terminate the current bus cycle. An address decoder would normally select one of the enable inputs.
$\overline{\text { READY }}$ is enabled (LOW), if either $\overline{\text { SRDY }}+\overline{\text { SRDYEN }}$ $=0$ or $\overline{\text { ARDY }}+\overline{\text { ARDYEN }}=0$ when sampled by the MBL 82284 READY generation logic. $\overline{\text { READY will remain }}$ active for at least two CLK cycles.
The $\overline{\text { READY }}$ output has an open-collector driver allowing other ready circuits to be wire or'ed with it, as shown in
 quires an external $910 \Omega \pm 5 \%$ pull-up resistor. To force the $\overline{\text { READY }}$ signal inactive (HIGH) at the start of a bus
cycle, the $\overline{\mathrm{READY}}$ output floats when either $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{S0}}$ are sampled LOW at the falling edge of CLK. Two system clock periods are allowed for the pull-up resistor to pull the $\overline{\text { READY }}$ signal to $\mathrm{V}_{\mathrm{IH}}$. When RESET is active, $\overline{\text { READY }}$ is forced active one CLK later (see waveforms).

Fig. 5 illustrates the operation of $\overline{\text { SRDY }}$ and $\overline{\text { SRDYEN. }}$ These inputs are sampled on the falling edge of CLK when $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{SO}}$ are inactive and PCLK is HIGH. $\overline{\text { READY }}$ is forced active when both $\overline{\text { SRDY }}$ and $\overline{\text { SRDYEN }}$ are sampled as LOW.
Fig. 6 shows the operation of $\overline{\text { ARDY }}$ and $\overline{\text { ARDYEN. }}$ These inputs are sampled by an internal synchronizer at each falling edge of CLK. The output of the synchronizer is then sampled when PCLK is HIGH. If the synchronizer resolved both the $\overline{\mathrm{ARDY}}$ and $\overline{\mathrm{ARDYEN}}$ have been resolved as active, the $\overline{S R D Y}$ and $\overline{\text { SRDYEN }}$ inputs are ignored. Either $\overline{A R D Y}$ or $\overline{A R D Y E N}$ must be HIGH at end of TS (see Fig. 6).
$\overline{\text { READY }}$ remains active until either $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{SO}}$ are sampled LOW, or the ready inputs are sampled as inactive.

Table 2 - MBL 82284 CRYSTAL LOADING CAPACITANCE VALUES

| Crystal Frequency | C1 Capacitance (pin 7) | C2 Capacitance (pin 8) |
| :---: | :---: | :---: |
| 1 to 8 MHz | 60 pF | 40 pF |
| 8 to 16 MHz | 25 pF | 15 pF |

NOTE: Capacitance values must include stray board capacitance.

Fig. 5 - SYNCHRONOUS READY OPERATION



## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias ias $\qquad$ . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ All Output and Supply Voltages -0.5 V to +7 V All Input Voltages . . . . . . . . . . . . . . . -1.0 V to +5.5 V
Power Dissipation $\qquad$
*NOTE: Permanent device damage may occur if ABSO. LUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $\left.70^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | $\begin{gathered} \text { MBL } 82284-6 \\ (6 \mathrm{MHz}) \\ \hline \end{gathered}$ |  | $\begin{gathered} \text { MBL } 82284-8 \\ (8 \mathrm{MHz}) \end{gathered}$ |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |  |
| $V_{\text {IL }}$ | Input LOW Voltage |  | 0.8 |  | 0.8 | V |  |
| $\mathrm{V}_{1 H}$ | Input HIGH Voltage | 2.0 |  | 2.0 |  | V |  |
| $\mathrm{V}_{\text {IHR }}$ | $\overline{\mathrm{RES}}$ and EFI Input HIGH Voltage | 2.6 |  | 2.6 |  | V |  |
| $\mathrm{V}_{\mathrm{HYS}}$ | $\overline{\mathrm{RES}}$ Input Hysteresis | 0.25 |  | 0.25 |  | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | RESET, PCLK Output LOW Voltage |  | 0.45 |  | 0.45 | V | $\mathrm{IOL}=5 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | RESET, PCLK Output HIGH Voltage | 2.4 |  | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OLR }}$ | READY Output LOW Voltage |  | 0.45 |  | 0.45 | V | $\mathrm{IOL}=7 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OLC }}$ | CLK Output LOW Voltage |  | 0.45 |  | 0.45 | V | $\mathrm{IOL}=5 \mathrm{~mA}$ |
| $V_{\text {OHC }}$ | CLK Output HIGH Voltage | 4.0 |  | 4.0 |  | V | $\mathrm{I}_{\mathrm{OH}}=-800 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Clamp Voltage |  | -1.0 |  | -1.0 | $\checkmark$ | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Forward Input Current |  | -0.5 |  | -0.5 | mA | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $I_{R}$ | Reverse Input Current |  | 50 |  | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{cc}}$ | Power Supply Current |  | 145 |  | 145 | mA |  |
| $\mathrm{C}_{1}$ | Input Capacitance |  | 10 |  | 10 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |

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

AC timings are referenced to 0.8 V and 2.0 V points of signals as illustrated in datasheet waveforms, unless otherwise noted.

| Symbol | Parameter | $\begin{gathered} \text { MBL } 82284-6 \\ (6 \mathrm{MHz}) \end{gathered}$ |  | $\begin{gathered} \text { MBL } 82284-8 \\ \text { (8 MHz) } \end{gathered}$ |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |  |
| 1 | EFI to CLK Delay |  | 35 |  | 30 | ns | at 1.5 V Note 1 |
| 2 | EFI LOW Time | 40 |  | 25 |  | ns | at 1.5 V Note 1 , Note 7 |
| 3 | EFI HIGH Time | 35 |  | 25 |  | ns | at 1.5V Note 1, Note 7 |
| 4 | CLK Period | 83 | 500 | 62 | 500 | ns |  |
| 5 | CLK LOW Time | 20 |  | 15 |  | ns | at 1.0V Note 1, Note 2, 8 |
| 6 | CLK HIGH Time | 25 |  | 25 |  | ns | at 3.6V Note 1, Note 2, 8 |
| 7 | CL, K R ise Time |  | 10 |  | 10 | ns | 1.0V to 3.6V Note 1 |
| 8 | CLK Fall Time |  | 10 |  | 10 | ns | 3.6 V to 1.0V Note 1 |
| 9 | Status Setup Time | 28 |  | 22 |  | ns | Note 1 |
| 10 | Status Hold Time | 1 |  | 1 |  | ns | Note 1 |
| 11 | $\overline{\text { SRDY }}$ or SRDYEN Setup Time | 25 |  | 15 |  | ns | Note 1 |
| 12 | $\overline{\text { SRDY }}$ or SRDYEN Hold Time | 0 |  | 0 |  | ns | Note 1 |
| 13 | $\overline{\text { ARDY }}$ or $\overline{\text { ARDYEN }}$ Setup Time | 5 |  | 0 |  | ns | Note 1, Note 3 |
| 14 | $\overline{\text { ARDY }}$ or $\overline{\text { ARDYEN }}$ Hold Time | 30 |  | 30 |  | ns | Note 1, Note 3 |
| 15 | $\overline{\text { RES }}$ Setup Time | 25 |  | 20 |  | ns | Note 1, Note 3 |
| 16 | $\overline{\text { RES Hold Time }}$ | 10 |  | 10 |  | ns | Note 1, Note 3 |
| 17 | READY Inactive Delay | 5 |  | 5 |  | ns | at 0.8 V Note 4 |
| 18 | READY Active Delay | 0 | 33 | 0 | 24 | ns | at 0.8V Note 4 |
| 19 | PCLK Delay | 0 | 45 | 0 | 45 | ns | Note 5 |
| 20 | RESET Delay | 5 | 50 | 5 | 34 | ns | Note 5 |
| 21 | PCLK LOW Time | t4-20 |  | t4-20 |  | ns | Note 5, Note 6 |
| 22 | PCLK HIGH Time | t4-20 |  | t4-20 |  | ns | Note 5, Note 6 |

NOTE 1: CLK loading: $C_{L}=150 p F$.
NOTE 2: With the internal crystal oscillator using recommended crystal and capacitive loading; or with the EFI input meeting specifications t 2 , and t 3 . Use a parallel-resonant, fundamental mode crystal. The recommended crystal loaidng for CLK frequencies of $8-16 \mathrm{MHz}$ are 25 pF from pin $\times 1$ to ground, and 15 pF from pin $\times 2$ to ground. These recommended values are $\pm 5 \mathrm{pF}$ and include all stray capacitance, Decouple $\mathrm{V}_{\mathrm{CC}}$ and GND as close to the MBL 82284 as possible.
NOTE 3: This is an asynchronous input. This specification is given for testing purposes only, to assure recognition at specific CLK edge.
NOTE 4: $\overline{R E A D Y}$ loading: $I_{\mathrm{OL}}=7 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$. In system application, use $910 \Omega \pm 5 \%$ pullup resistor to meet MBL $80286-8$ and 80286-6 timing requirements.
NOTE 5: PCLK and RESET loading: $C_{L}=75 \mathrm{pF}$. PCLK also has $750 \Omega$ pullup.
NOTE 6: $t 4$ refers to any allowable CLK period.
NOTE 7: When driving the MBL 82284 with EFI, provide minimum EFI HIGH and LOW times as follows:

| CLK Output Frequency: | 8 MHz <br> CLK | 12 MHz <br> CLK | 16 MHz <br> CLK* |
| :---: | :---: | :---: | :---: |
| Min. required EFI HIGH time | 52 ns | 35 ns | 25 ns |
| Min. required EFI LOW time | 52 ns | 40 ns | 25 ns |

*At CLK frequencies above 12 MHz, CLK output HIGH and LOW times are guaranteed only when using crystal with recommended capacitive loading per Table 2, not when driving component from EFI. All features of the MBL 82284 remain functional whether EFI or crystal is used to drive the MBL 82284.
NOTE 8: When using crystal (with recommended capacitive loading per Table 2) appropriate for speed of MBL 80286, CLK output HIGH and LOW times guaranteed to meet MBL 80286 requirements.


NOTE 12: AC Test Loading on Outputs


## WAVEFORMS

## CLK AS A FUNCTION OF EFI



NOTE: The EFI input LOW and HIGH times as shown are required to guarantee the CLK LOW and HIGH times shown.


NOTE 1: This is an asynchronous input. The setup and hold times
shown are required to guarantee the response shown.
NOTE 2: Tie $910 \Omega \pm 5 \%$ pullup resistor to the $\overline{\operatorname{READY}}$ output.

## READY AND PCLK TIMING WITH RES HIGH



NOTE 1: This is an asynchronous input. The setup and hold times shown are required to guarantee the response shown.
NOTE 2: Tie $910 \Omega \pm 5 \%$ pullup resistor to the $\overline{\operatorname{READY}}$ output.

PACKAGE ILLUSTRATION


PACKAGE DIMENSIONS (Suffix: cz)
18-LEAD CERAMIC (CERDIP) DUAL IN-LINE PACKAGE
(CASE No. : DIP-18C-C01)

© 1985 FUJITSU D $18005 \mathrm{~S}-1 \mathrm{C}$

PACKAGE ILLUSTRATION


PACKAGE DIMENSIONS (Suffix: P)

## 18-LEAD PLASTIC DUAL-IN-LINE PACKAGE

 (CASE No.: DIP-18P-M02)

## NMOS BUS CONTROLLER FOR MBL 80286 PROCESSORS

The Fujitsu MBL 82288 Bus Controller is a 20 -pin NMOS component for use in MBL 80286 microsystems. The bus controller provides command and control outputs with flexible timing options. Separate command outputs are used for memory and I/O devices. The data bus is controlled with separate data enable and direction control signals.

Two modes of operation are possible via a strapping option: Multibus compatible bus cycles, and high speed bus cycles.

- Provides Commands and Control for Local and System Bus
- Offers Wide Flexibility in System Configurations
- Flexible Command Timing
- Optional Multibus* Compatible Timing
- Control Drivers with $16 \mathrm{~mA} \mathrm{I}_{\mathrm{OL}}$ and 3-State Command Drivers with $32 \mathrm{~mA} \mathrm{I}_{\mathrm{OL}}$
- Single +5V Supply
- Two Package Options:
-20-Pin Cerdip (Suffix: -CZ)
-20-Pin Plastic DIP (Suffix: -P)

Fig. 1 - BLOCK DIAGRAM
Fig. 2 - PIN CONFIGURATION


[^2]Portions Reprinted by permission of Intel Corporation

## PIN DESCRIPTION

The following pin function descriptions are for the MBL 82288 bus controller.

Table 1 - PIN DESCRIPTION

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| CLK | 1 | System Clock provides the basic timing control for the MBL 82288 in an MBL 80286 microsystem. Its frequency is twice the internal processor clock frequency. The falling edge of this input signal establishes when inputs are sampled and command and control outputs change. |
| $\overline{\mathrm{So}}, \overline{\mathrm{S} 1}$ | 1 | Bus Cycle Status starts a bus cycle and, along with $\mathrm{M} / \overline{\mathrm{IO}}$, defines the type of bus cycle. These inputs are active LOW. A bus cycle is started when either $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{S} 0}$ is sampled LOW at the falling edge of CLK. Setup and hold times must be met for proper operation. |
| $\mathrm{M} / \overline{\mathrm{O}}$ | 1 | Memory or I/O Select determines whether the current bus cycle is in the memory space or I/O space. When LOW, the current bus cycle is in the I/O space. Setup and hold times must be met for proper operation. |
| MB | 1 | Multibus Mode Select determines timing of the command and control outputs. When HIGH, the bus controller operates with Multibus-compatible timings. When LOW, the bus controller optimizes the command and control output timing for short bus cycles. The function of the CEN/ $\overline{\mathrm{AEN}}$ input pin is selected by this signal. This input is typically a strapping option and not dynamically changed. |
| CENL | 1 | Command Enable Latched is a bus controller select signal which enables the bus controller to respond to the current bus cycle being initiated. CENL is an active HIGH input latched internally at the end of each TS cycle. CENL is used to select the appropriate bus controller for each bus cycle in a system where the CPU has more than one bus it can use. This input may be connected to $\mathrm{V}_{\mathrm{CC}}$ to select this MBL 82288 for all transfers. No control inputs affect CENL. Setup and hold times must be met for proper operation. |
| CMDLY | 1 | Command Delay allows delaying the start of a command. CMDLY is an active HIGH input. If sampled HIGH, the command output is not activated and CMDLY is again sampled at the next CLK cycle. When sampled LOW the selected command is enabled. If $\overline{\text { READY }}$ is detected LOW before the command output is activated, the MBL 82288 will terminate the bus cycle, even if no command was issued. Setup and hold times must be satisfied for proper operation. This input may be connected to GND if no delays are required before starting a command. This input has no effect on MBL 82288 control outputs. |
| $\overline{\text { READY }}$ | 1 | Ready indicates the end of the current bus cycle. $\overline{\operatorname{READY}}$ is an active LOW input. Multibus mode requires at least one wait state to allow the command outputs to become active. $\bar{R} E A D Y$ must be LOW during reset, to force the MBL 82288 into the idle state. Setup and hold times must be met for proper operation. The MBL 82284 drives $\overline{\text { READY }}$ LOW during RESET. |

MBL 82288-8
Hixmuminixily
FUJITSU MBL 82288-6


Table 1 - PIN DESCRIPTION (Continued)

| Symbol | Type | Name and Function |
| :---: | :---: | :--- |
| CEN/AEN | I | $\begin{array}{l}\text { Command Enable/Address Enable controls the command and DEN outputs of the bus con- } \\ \text { troller. CEN/ } \overline{\text { AEN inputs may be asynchronous to CLK. Setup and hold times are given to }} \\ \text { assure a guaranteed response to synchronous inputs. This input may be connected to Vcc or } \\ \text { GND. } \\ \text { When MB is HIGH, this pin has the } \overline{\text { AEN function. } \overline{\text { AEN is an active LOW input which indicates }}} \\ \text { that the CPU has been granted use of a shared bus and the bus controller command outputs } \\ \text { may exit 3-state OFF and become inactive (HIGH). } \overline{\text { AEN HIGH indicates that the CPU does }} \\ \text { not have control of the shared bus and forces the command outputs into 3-state OFF and DEN } \\ \text { inactive (LOW). } \overline{\text { AEN would normally be controlled by an 82289 bus arbiter which activates }}\end{array}$ |
| AEN when that arbiter owns the bus to which the bus controller is attached. |  |  |
| When MB is LOW this pin has the CEN function. CEN is an unlatched active HIGH input which |  |  |
| allows the bus controller to activate its command and DEN outputs. With MB LOW, CEN LOW |  |  |
| forces the command and DEN outputs inactive but does not tristate them. |  |  |$\}$

## FUNCTIONAL DESCRIPTION

## INTRODUCTION

The MBL 82288 bus controller is used in MBL 80286 systems to provide address latch control, data transceiver control, and standard level-type command outputs. The command outputs are timed and have sufficient drive capabilities for large TTL buses and meet all IEEE-796 requirements for Multibus. A special Multibus mode is provided to satisfy all address/data setup and hold time requirements. Command timing may be tailored to special needs via a CMDLY input to determine the start of a command and $\overline{\text { READY }}$ to determine the end of a command.

Connection to multiple buses are supported with a latched enable input (CENL). An address decoder can determine which, if any, bus controller should be enabled for the bus cycle. This input is latched to allow an address decoder to take full advantage of the pipelined timing on the MBL 80286 local bus.

Bus shared by several bus controllers are supported. An $\overline{\mathrm{AEN}}$ input prevents the bus controller from driving the shared bus command and data signals except when enabled by an external bus arbiter such as the 82289.

Separate DEN and DT/ $\bar{R}$ outputs control the data transceivers for all buses. Bus contention is eliminated by disabling DEN before changing $D T / \bar{R}$. The DEN timing allows sufficient time for tristate bus drivers to enter 3-state OFF before enabling other drivers onto the same bus.

The term CPU refers to any MBL 80286 processor or MBL 80286 support component which may become an MBL 80286 local bus master and thereby drive the MBL 82288 status inputs.

## PROCESSOR CYCLE DEFINITION

Any CPU which drives the local bus uses an internal clock which is one half the frequency of the system clock (CLK) (see Fig. 3). Knowledge of the phase of the local bus master internal clock is required for proper operation of the MBL 80286 local bus. The local bus master informs the bus controller of its internal clock phase when it asserts the status signals. Status signals are always asserted beginning in Phase 1 of the local bus master's internal clock.

Fig. 3 - CLK RELATIONSHIP TO THE PROCESSOR CLOCK AND BUS T-STATES

MBL 82284 (FOR REFERENCE)


## BUS STATE DEFINITION

The MBL 82288 bus controller has three bus states (see Fig. 4): Idle (TI), Status (TS) and Command (TC). Each bus state is two CLK cycles long. Bus state phases correspond to the internal CPU processor clock phases.

The TI bus state occurs when no bus cycle is currently active on the MBL 80286 local bus. This state may be repeated indefinitely. When control of the local bus is being passed between masters, the bus remains in the TI state.

Fig. 4 - MBL 82288 BUS STATES


## BUS CYCLE DEFINITION

The $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S} 0}$ inputs signal the start of a bus cycle. When either input becomes LOW, a bus cycle is started. The TS bus state is defined to be the two CLK cycles during which either $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{S0}}$ are active (see Fig. 5). These inputs are sampled by the MBL 82288 at every falling edge of CLK. When either $\overline{\mathrm{S} 1}$ or $\overline{\mathrm{S0}}$ are sampled LOW, the next CLK cycle is considered the second phase of the internal CPU clock cycle.

The local bus enters the TC bus state after the TS state. The shortest bus cycle may have one TS state and one TC state. Longer bus cycles are formed by repeating TC states. A repeated TC bus state is called a wait state.

The $\overline{\text { READY }}$ input determines whether the current TC bus state is to be repeated. The $\overline{\operatorname{READY}}$ input has the same timing and effect for all bus cycles. $\overline{\text { READY }}$ is sampled at the end of each TC bus state to see if it is active. If sampled HIGH, the TC bus state is repeated. This is called inserting a wait state. The control and command outputs do not change during wait states.

When $\overline{\text { READY }}$ is sampled LOW, the current bus cycle is terminated. Note that the bus controller may enter the TS bus state directly from TC if the status lines are sampled active at the next falling edge of CLK.

Fig. 5 - BUS CYCLE DEFINITION


Table 2 - COMMAND AND CONTROL OUTPUTS FOR EACH TYPE OF BUS CYCLE

| Type of Bus Cycle | $\mathbf{M} / \overline{\mathbf{I O}}$ | $\overline{\mathbf{S 1}}$ | $\overline{\mathbf{S O}}$ | Command <br> Activated | DT/ $\bar{R}$ <br> State | ALE, DEN <br> Issued? | MCE <br> Issued? |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Interrupt Acknowledge | 0 | 0 | 0 | $\overline{\text { INTA }}$ | LOW | YES | YES |
| I/O Read | 0 | 0 | 1 | $\overline{\text { IORC }}$ | LOW | YES | NO |
| I/O Write | 0 | 1 | 0 | $\overline{\text { IOWC }}$ | HIGH | YES | NO |
| None; Idle | 0 | 1 | 1 | None | HIGH | NO | NO |
| Halt/Shutdown | 1 | 0 | 0 | None | HIGH | NO | NO |
| Memory Read | 1 | 0 | 1 | $\overline{\text { MRDC }}$ | LOW | YES | NO |
| Memory Write | 1 | 1 | 0 | $\overline{\text { MWTC }}$ | HIGH | YES | NO |
| None; Idle | 1 | 1 | 1 | None | HIGH | NO | NO |

## OPERATING MODES

Two types of buses are supported by the MBL 82288: Multibus and non-Multibus. When the MB input is strapped HIGH, Multibus timing is used. In Multibus mode, the MBL 82288 delays command and data activation to meet IEEE-796 requirements on address to command active and write data to command active setup timing. Multibus mode requires at least one wait state in the bus cycle since the command outputs are delayed. The non-Multibus mode does not delay any outputs and does not require wait states. The MB input affects the timing of the command and DEN outputs.

## COMMAND AND CONTROL OUTPUTS

The type of bus cycle performed by the local bus master is encoded in the $\mathrm{M} / \overline{\mathrm{IO}}, \overline{\mathrm{S} 1}$, and $\overline{\mathrm{S} 0}$ inputs. Different command and control outputs are activated depending on the type of bus cycle. Table 2 indicates the cycle decode done by the MBL 82288 and the effect on command, DT/ $\bar{R}$, ALE, DEN, and MCE outputs.

Bus cycles come in three forms: read, write, and halt. Read bus cycles include memory read, $1 / \mathrm{O}$ read, and interrupt acknowledge. The timing of the associated read command outputs ( $\overline{\mathrm{MRDC}}, \overline{\mathrm{IORC}}$, and $\overline{\text { INTA }}$ ), control outputs (ALE, DEN, DT/ $\overline{\mathrm{R}}$ ) and control inputs (CEN $/ \overline{\mathrm{AEN}}, \mathrm{CENL}$, CMDLY, MB, and READY) are identical for all read bus cycles. Read cycles differ only in which command output is activated. The MCE control output is only asserted during interrupt acknowledge cycles.

Write bus cycles activate different control and command outputs with different timing than read bus cycles. Memory write and I/O write are write bus cycles whose timing for command outputs ( $\overline{M W T C}$ and $\overline{\text { IOWC }}$ ), control outputs (ALE, DEN, DT/ $\bar{R}$ ) and control inputs (CEN $/ \overline{\mathrm{AEN}}, \mathrm{CENL}$, CMDLY, MB, and READY) are identical. They differ only in which command output is activated.

Halt bus cycles are different because no command or control output is activated. All control inputs are ignored until the next bus cycle is started via $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S0}}$.

Fig. 6-10 show the basic command and control output timing for read and write bus cycles. Halt bus cycles are not shown since they activate no outputs. The basic idle-readidle and idle-write-idle bus cycles are shown. The signal label CMD represents the appropriate command output for the bus cycle. For Fig. 6-10, the CMDLY input is connected to GND and CENL to $\mathrm{V}_{\mathrm{cc}}$. The effects of CENL and CMDLY are described later in the section on control inputs.
Fig. 6, 7 and 8 show non-Multibus cycles. MB is connected to GND while CEN is connected to $\mathrm{V}_{\mathrm{cc}}$. Fig. 6 shows a read cycle with no wait states while Fig. 7 shows a write cycle with one wait state. The $\overline{\operatorname{READY}}$ input is shown to illustrate how wait states are added.

Fig. 6 - IDEL-READ-IDEL BUS CYCLES WITH MB $=0$


Fig. 7 - IDLE-WRITE-IDLE BUS CYCLES WITH MB = 0


Bus cycles can occur back to back with no TI bus states between TC and TS. Back to back cycles do not affect the timing of the command and control outputs. Command and control outputs always reach the states shown for the same clock edge (within TS, TC, or following bus state) of a bus cycle.

A special case in control timing occurs for back to back write cycles with MB $=0$. In this case, DT/ $\bar{R}$ and DEN remain HIGH between the bus cycles (see Fig. 8). The command and ALE output timing does not change.

Fig. 9 and 10 show a Multibus cycle with $M B=1 . \overline{A E N}$ and CMDLY are connected to GND. The effects of CMDLY and $\overline{\mathrm{AEN}}$ are described later in the section on control inputs. Fig. 9 shows a read cycle with one wait state and Fig. 10 shows a write cycle with two wait states. The second wait state of the write cycle is shown only for example purposes and is not required. The READY input is shown to illustrate how wait states are added.

Fig. 8 - WRITE-WRITE BUS CYCLES WITH MB $=0$


Fig. 9 - IDLE-READ-IDLE BUS CYCLES WITH MB = 1


The MB control input affects the timing of the command and DEN outputs. These outputs are automatically delayed in Multibus mode to satisfy three requirements:

1) 50 ns minimum setup time for valid address before any command output becomes active.
2) 50 ns minimum setup time for valid write data before any write command output becomes active.
3) 65 ns maximum time from when any read command becomes inactive until the slave's read data drivers reach 3-state OFF.

Three signal transitions are delayed by $\mathrm{MB}=1$ as compared to $\mathrm{MB}=0$ :

1) The HIGH to LOW transition of the read command outputs ( $\overline{\mathrm{IORC}}, \overline{\mathrm{MRDC}}$, and $\overline{\mathrm{INTA}}$ ) are delayed one CLK cycle.
2) The HIGH to LOW transition of the write command outputs ( $\overline{\mathrm{IOWC}}$ and $\overline{\mathrm{MWTC}}$ ) are delayed two CLK cycles.
3) The LOW to HIGH transition of DEN for write cycles is delayed one CLK cycle.

Back to back bus cycles with $M B=1$ do not change the timing of any of the command of control outputs. DEN always becomes inactive between bus cycles with $M B=1$.

Except for a halt or shutdown bus cycle, ALE will be issued during the second half of TS for any bus cycle. ALE becomes inactive at the end of the TS to allow latching the address to keep it stable during the entire bus cycle. The address outputs may change during Phase 2 of any TC bus state. ALE is not affected by any control input.

Fig. 11 shows how MCE is timed during interrupt acknowledge (INTA) bus cycles. MCE is one CLK cycle longer than ALE to hold the cascade address from a master MBL 8259A valid after the falling edge of ALE. With the exception of the MCE control output, an INTA bus cycle is identical in timing to a read bus cycle. MCE is not affected by any control input.

Fig. 11 - MCE OPERATION FOR AN INTA BUS CYCLE


## CONTROL INPUTS

The control inputs can alter the basic timing of command outputs, allow interfacing to multiple buses, and share a bus between different masters. For many MBL 80286 systems, each CPU will have more than one bus which may be used to perform a bus cycle. Normally, a CPU will only have one bus controller active for each bus cycle. Some buses may be shared by more than one CPU (i.e. Multibus) requiring only one of them use the bus at a time.

Systems with multiple and shared buses use two control input signals of the MBL 82288 bus controller, CENL and $\overline{\mathrm{AEN}}$ (see Fig. 12). CENL enables the bus controller to control the current bus cycle. The $\overline{\mathrm{AEN}}$ input prevents a bus controller from driving its command outputs. $\overline{\text { AEN }}$ HIGH means that another bus controller may be driving the shared bus.

In Fig. 12, two buses are shown: a local bus and a Multibus. Only one bus is used for each CPU bus cycle. The CENL inputs of the bus controllers select which bus controller is to perform the bus cycle. An address decoder determines which bus to use for each bus cycle. The MBL 82288 connected to the shared Multibus must be selected by CENL and be given access to the Multibus by $\overline{\mathrm{AEN}}$ before it will begin a Multibus operation.

CENL must be sampled HIGH at the end of the TS bus state (see waveforms) to enable the bus controller to activate its command and control outputs. If sampled LOW the commands and DEN will not go active and DT/ $\bar{R}$ will remain HIGH . The bus controller will ignore the CMDLY, CEN, and READY inputs until another bus cycle is started via $\overline{\mathrm{S} 1}$ and $\overline{\mathrm{S0}}$. Since an address decoder is
commonly used to identify which bus is required for each bus cycle, CENL is latched to avoid the need for latching its input.

The CENL input can affect the DEN control output. When $M B=0$, DEN normally becomes active during Phase 2 of TS in write bus cycles. This transition occurs before CENL is sampled. If CENL is sampled LOW, the DEN output will be forced LOW during TC as shown in the timing waveforms.

When $\mathrm{MB}=1$, CEN $/ \overline{\mathrm{AEN}}$ becomes $\overline{\mathrm{AEN}} . \overline{\mathrm{AEN}}$ controls when the bus controller command outputs enter and exit 3 -state OFF. $\overline{\text { AEN }}$ is intended to be driven by a bus arbiter, like the 82289, which assures only one bus controller is driving the shared bus at any time. When $\overline{\mathrm{AEN}}$ makes a LOW to HIGH transition, the command outputs immediately enter 3-state OFF and DEN is forced inactive. An inactive DEN should force the local data transceivers connected to the shared data bus into 3 -state OFF (see Fig. 12). The LOW to HIGH transition of $\overline{\text { AEN }}$ should only occur during TI or TS bus states.

The HIGH to LOW transition of $\overline{\mathrm{AEN}}$ signals that the bus controller may now drive the shared bus command signals. Since a bus cycle may be active or be in the process of starting, $\overline{\mathrm{AEN}}$ can become active during any T -state. $\overline{\mathrm{AEN}}$ LOW immediately allows DEN to go to the appropriate state. Three CLK edges later, the command outputs will go active (see timing waveforms). The Multibus requires this delay for the address and data to be valid on the bus before the commands become active.

When MB=0, CEN $/ \overline{\mathrm{AEN}}$ becomes CEN. CEN is an synchronous input which immediately affects the command and DEN outputs. When CEN makes a HIGH to LOW transition, the commands and DEN are immediately forced inactive. When CEN makes a LOW to HIGH transition, the commands and DEN outputs immediately go to the appropriate state (see timing waveforms). $\overline{\text { READY }}$ must still become active to terminate a bus cycle if CEN remains LOW for a selected bus controller (CENL was latched HIGH).

Some memory or I/O systems may require more address or write data setup time to command active than provided by the basic command output timing. To provide flexible command timing, the CMDLY input can delay the activation of command outputs. The CMDLY input must be sampled LOW to activate the command outputs. CMDLY does not affect the control outputs ALE, MCE, DEN, and DT/ $\bar{R}$.

Fig. 12 - SYSTEM USE OF $\overline{A E N}$ AND CENL


CMDLY is first sampled on the falling edge of the CLK ending TS. If sampled HIGH, the command output is not activated, and CMDLY is again sampled on the next falling edge of CLK. Once sampled LOW, the proper command output becomes active immediately if $M B=0$. If $M B=1$, the proper command goes active no earlier than shown in Fig. 9 and 10.
$\overline{\text { READY }}$ can terminate a bus cycle before CMDLY allows a command to be issued. In this case no commands are issued and the bus controller will deactivate DEN and $D T / \bar{R}$ in the same manner as if a command had been issued.

## WAVEFORMS DISCUSSION

The waveforms show the timing relationships of inputs and outputs and do not show all possible transitions of all signals in all modes. Instead, all signal timing relationships are shown via the general cases. Special cases are shown when needed. The waveforms provide some functional descriptions of the MBL 82288; however, most functional descriptions are provided in Fig. 5 through 11.

To find the timing specification for a signal transition in a particular mode, first look for a special case in the waveforms. If no special case applies, then use a timing specification for the same or related function in another mode.

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Storage Temperature . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Voltage on Any Pin with

Respect to GND . . . . . . . . . . . . . . . . . -0.5 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 1 Watt
*NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | $\begin{gathered} \text { MBL 82288-6 } \\ \text { ( } 6 \mathrm{MHz} \text { ) } \end{gathered}$ |  | $\begin{gathered} \text { MBL } 82288-8 \\ (8 \mathrm{MHz}) \\ \hline \end{gathered}$ |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |  |
| $V_{\text {IL }}$ | Input LOW Voltage | -0.5 | 0.8 | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{1 H}$ | Input HIGH Voltage | 2.0 | $\mathrm{V}_{\mathrm{cc}}+0.5$ | 2.0 | $\mathrm{V}_{\mathrm{Cc}}+0.5$ | V |  |
| $V_{\text {ILC }}$ | CLK Input LOW Voltage | -0.5 | 0.6 | -0.5 | 0.6 | V |  |
| $V_{1 H C}$ | CLK Input HIGH Voltage | 3.8 | $\mathrm{V}_{\mathrm{cc}}+0.5$ | 3.8 | $\mathrm{V}_{C C}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage: Command Outputs Control Outputs |  | $\begin{aligned} & 0.45 \\ & 0.45 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 0.45 \\ & 0.45 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}, \text { Note } 1 \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}, \text { Note } 2 \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage: <br> Command Outputs Control Outputs | $\begin{aligned} & 2.4 \\ & 2.4 \end{aligned}$ |  | $\begin{aligned} & 2.4 \\ & 2.4 \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \text { Note } 1 \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}, \text { Note } 2 \end{aligned}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Current ( $\overline{\mathrm{S} 0}$ and $\overline{\mathrm{S} 1}$ inputs) |  | -0.5 |  | -0.5 | mA | $\mathrm{V}_{\mathrm{f}}=0.45 \mathrm{~V}$ |
| $I_{\text {IL }}$ | Input Leakage current (all other inputs) |  | $\pm 10$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV} \leqq \mathrm{V}_{\mathrm{IN}} \leqq \mathrm{V}_{\mathrm{CC}}$ |
| ILO | Output Leakage Current |  | $\pm 10$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ |
| Icc | Power Supply Current |  | 120 |  | 120 | mA |  |
| $\mathrm{C}_{\text {CLK }}$ | CLK Input Capacitance |  | 12 |  | 12 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |
| C | Input Capacitance |  | 10 |  | 10 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{O}}$ | Input/Output Capacitance |  | 20 |  | 20 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |

NOTE: 1. Command Outputs are TNTA, IORC, $\overline{\text { IOWC, }} \overline{M R D C}$, and MWRC.
2. Control Outputs are DT/ $\bar{R}, ~ D E N, ~ A L E ~ a n d ~ M C E . ~$

## A．C．CHARACTERISTICS <br> $\left(V_{c c}=5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

AC timings are referenced to 0.8 V and 2.0 V points of signals as illustrated in data sheet waveforms，unless otherwise noted．

| Symbol | Parameter | $\begin{gathered} \text { MBL 82288-6 } \\ (6 \mathrm{MHz}) \end{gathered}$ |  | $\begin{gathered} \text { MBL 82288-8 } \\ (8 \mathrm{MHz}) \end{gathered}$ |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |  |
| 1 | CLK Period | 83 | 250 | 62 | 250 | ns |  |
| 2 | CLK HIGH Time | 25 | 230 | 20 | 235 | ns | at 3.6 V |
| 3 | CLK LOW Time | 20 | 225 | 15 | 230 | ns | at 1.0 V |
| 4 | CLK Rise Time |  | 10 |  | 10 | ns | 1.0 V to 3.6 V |
| 5 | CLK Fall Time |  | 10 |  | 10 | ns | 3.6 V to 1.0 V |
| 6 | $\mathrm{M} / \overline{\mathrm{IO}}$ and Status Setup Time | 28 |  | 22 |  | ns |  |
| 7 | $\mathrm{M} / \overline{\mathrm{IO}}$ and Status Hold Time | 1. |  | 1 |  | ns |  |
| 8 | CENL Setup Time | 30 |  | 20 |  | ns |  |
| 9 | CENL Hold Time | 1 |  | 1 |  | ns |  |
| 10 | $\overline{\text { READY Setup Time }}$ | 50 |  | 38 |  | ns |  |
| 11 | $\overline{\text { READY }}$ Hold Time | 35 |  | 25 |  | ns |  |
| 12 | CMDLY Setup Time | 25 |  | 20 |  | ns |  |
| 13 | CMDLY Hold Time | 1 |  | 1 |  | ns |  |
| 14 | $\overline{\text { AEN }}$ Setup Time | 25 |  | 20 |  | ns | Note 3 |
| 15 | $\overline{\text { AEN }}$ Hold Time | 0 |  | 0 |  | ns | Note 3 |
| 16 | ALE，MCE Active Delay from CLK | 3 | 25 | 3 | 20 | ns | Note 4 |
| 17 | ALE，MCE Inactive Delay from CLK |  | 35 |  | 25 | ns | Note 4 |
| 18 | DEN（Write）Inactive from CENL |  | 35 |  | 35 | ns | Note 4 |
| 19 | DT／何 LOW from CLK |  | 40 |  | 25 | ns | Note 4 |
| 20 | DEN（Read）Active from DT／R | 5 | 50 | 5 | 35 | ns | Note 4 |
| 21 | DEN（Read）Inactive Delay from CLK | 3 | 40 | 3 | 35 | ns | Note 4 |
| 22 | DT／可 HIGH from DEN Inactive | 5 | 45 | 5 | 35 | ns | Note 4 |
| 23 | DEN（Write）Active Delay from CLK |  | 35 |  | 30 | ns | Note 4 |
| 24 | DEN（Write）Inactive Delay from CLK | 3 | 35 | 3 | 30 | ns | Note 4 |
| 25 | DEN Inactive from CEN |  | 40 |  | 30 | ns | Note 4 |
| 26 | DEN Active from CEN |  | 35 |  | 30 | ns | Note 4 |
| 27 | DT／友 HIGH from CLK （when CEN＝LOW） |  | 50 |  | 35 | ns | Note 4 |
| 28 | DEN Active from $\overline{\text { AEN }}$ |  | 35 |  | 30 | ns | Note 4 |
| 29 | $\overline{\text { CMD }}$ Active Delay from CLK | 3 | 40 | 3 | 25 | ns | Note 5 |
| 30 | $\overline{\text { CMD }}$ Inactive Delay from CLK | 3 | 30 | 3 | 25 | ns | Note 5 |
| 31 | $\overline{\text { CMD }}$ Inactive from CEN |  | 35 |  | 25 | ns | Note 5 |
| 32 | $\overline{\mathrm{CMD}}$ Active from CEN |  | 45 |  | 25 | ns | Note 5 |
| 33 | $\overline{\mathrm{CMD}}$ Inactive Enable from $\overline{\mathrm{AEN}}$ |  | 40 |  | 40 | ns | Note 5 |
| 34 | $\overline{\mathrm{CMD}}$ Float Delay from $\overline{\mathrm{AEN}}$ |  | 40 |  | 40 | ns | Note 6 |
| 35 | MB Setup Time | 25 |  | 20 |  | ns |  |
| 36 | MB Hold Time | 0 |  | 0 |  | ns |  |
| 37 | Command Inactive Enable from MB $\downarrow$ |  | 40 |  | 40 | ns | Note 5 |
| 38 | Command Float Time from MB $\uparrow$ |  | 40 |  | 40 | ns | Note 6 |
| 39 | DEN Inactive from MB $\uparrow$ |  | 40 |  | 30 | ns | Note 4 |
| 40 | DEN Active from MB $\downarrow$ |  | 35 |  | 30 | ns | Note 4 |

NOTE：3．$\overline{\mathrm{AEN}}$ is an asynchronous input．This specification is for testing purposes only，to assure recognition at a specific CLK edge．
4．Control output load：$C_{L}=150 \mathrm{pF}$ ．
5．Command output load：$C_{L}=300 \mathrm{pF}$ ．
6．Float condition occurs when output current is less than $I_{\text {LO }}$ in magnitude．

NOTE 7: AC Drive and Measurement Points - CLK Input


NOTE 8: AC Setup, Hold and Delay Time Measurement - General


NOTE 9: AC Test Loading on Outputs


## WAVEFORMS

## CLK CHARACTERISTICS



STATUS, ALE, MCE, CHARACTERISTICS


CENL, CMDLY, DEN CHARACTERISTICS WITH MB = 0 AND CEN $=1$ DURING WRITE CYCLE


WAVEFORMS (Continued)
READ CYCLE CHARACTERISTICS WITH MB = 0 AND CEN = 1


WRITE CYCLE CHARACTERISTICS WITH MB $=0$ AND CEN $=1$


FUSITSU

## WAVEFORMS (Continued)


$\overline{\text { AEN }}$ CHARACTERISTICS WITH MB $=1$


NOTE 1: $\overline{\operatorname{AEN}}$ is an asynchronous input. $\overline{\mathrm{AEN}}$ setup and hold times are specified to guarantee the response shown in the waveforms.

## PACKAGE ILLUSTRATION



PACKAGE DIMENSIONS (Suffix -CZ)


## PACKAGE ILLUSTRATION



PACKAGE DIMENSIONS (Suffix: -P)


## NMOS HIGH-INTEGRATION 16-BIT MICROPROCESSOR

The Fujitsu MBL 80186 is a highly integrated 16 -bit microprocessor. The MBL 80186 effectively combines 15-20 of the most common MBL 8086 system components onto one. The MBL 80186 provides two times greater throughput than the standard 5 MHz MBL 8086. The MBL 80186 is upward compatible with MBL 8086 and 88 software and adds 10 new instruction types to the existing set. It is housed in a 68 -pad ceramic LCC (Leadless Chip Carrier: JEDEC Type A) or 68 -pin Ceramic PGA (Pin Grid Array) package.

- Integrated Feature Set:
- Enhanced MBL 8086-2 CPU
- Clock Generator
- 2 Independent, High-Speed DMA Channels
- Programmable Interrupt Controller
- 3 Programmable 16-bit Timers
- Programmable Memory and Peripheral Chip-Select Logic
- Programmable Wait State Generator
- Local Bus Controller
- Available in $8 \mathbf{M H z}$ (MBL 80186) and cost effective 6 MHz (MBL 80186-6) versions.
- High-performance Processor
- 2 Times the Performance of the Standard MBL 8086
- 4 MByte/Sec Bus Bandwidth Interface
- Direct Addressing Capability to 1 MByte of Memory
- Completely Object Code Compatible with All Existing MBL 8086, 88 Software
- 10 New Instruction Types
- High Performance Numerical Coprocessing Capability Through Intel 8087 Interface
- Two Package Options:
- 68-Pad Ceramic LCC (Suffix -CV)
(JEDEC Type A)
- 68-Pin Ceramic PGA (Suffix -CR)

Fig. 1 - BLOCK DIAGRAM


Portions reprinted by permission of Intel Corporation

FUSITSE

Fig. 2 - PIN CONFIGURATIONS


68-PIN PGA

TOP VIEW


BOTTOM VIEW


PIN DESCRIPTION
Table 1 - PIN DESCRIPTION

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}, \mathrm{V}_{\mathrm{cc}}$ | 9,43 | 1 | System Power: +5 V power supply. |
| $\mathrm{V}_{\text {Ss }}, \mathrm{V}_{\text {ss }}$ | 26,60 | 1 | System Ground. |
| RESET | 57 | 0 | Reset Output indicates that the MBL 80186 CPU is being reset, and can be used as a system reset. It is active HIGH, synchronized with the processor clock, and lasts an integer number of clock periods corresponding to the length of the RES signal. |
| X1, $\mathrm{x}^{2}$ | 59, 58 | 1 | Crystal Inputs, X1 and X2, provide an external connection for a fundamental mode parallel resonant crystal for the internal crystal oscillator. X1 can interface to an external clock instead of a crystal. In this case, minimize the capacitance on X 2 or drive X 2 with complemented X 1 . The input or oscillator frequency is internally divided by two to generate the clock signal (CLKOUT). |
| CLKOUT | 56 | 0 | Clock Output provides the system with a $50 \%$ duty cycle waveform. All device pin timings are specified relative to CLOKOUT. CLKOUT has sufficient MOS drive capabilities for the 8087 Numeric Processor Extension. |
| $\overline{\mathrm{RES}}$ | 24 | 1 | System Reset causes the MBL 80186 to immediately terminate its present activity, clear the internal logic, and enter a dormant state. This signal may be asynchronous to the MBL 80186 clock. The MBL 80186 begins fetching instructions approximately 7 clock cycels after RES is returned HIGH. $\overline{\text { RES }}$ is required to be LOW for greater than 4 clock cycles and is internally synchronized. For proper initialization, the LOWto HIGH transition of $\overline{\mathrm{RES}}$ must occur no sooner than 50 microseconds after power up. This input is provided with a Schmitt-trigger to facilitate power-on RES generation via an RC network. When RES occurs, the MBL 80186 will drive the status lines to an inactive level for one clock, and then tri-state them. |
| TEST | 47 | 1 | TEST is examined by the WAIT instruction. If the TEST input is HIGH when "WAIT" execution begins, instruction execution will suspend. TEST will be resampled until it goes LOW, at which time execution will resume. If interrupts are enabled while the MBL 80186 is waiting for TEST, interrupts will be serviced. This input is synchronized internally. |
| TMR IN 0, TMRIN 1 | $\begin{aligned} & 20 \\ & 21 \end{aligned}$ | $1$ | Timer Inputs are used either as clock or control signals, depending upon the programmed timer mode. These inputs are active HIGH (or LOW-toHIGH transitions are counted) and internally synchronized. |
| TMR OUT O, TMR OUT 1 | $\begin{aligned} & 22 \\ & 23 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 0 \\ & \hline \end{aligned}$ | Timer Outputs are used to provide single pulse or continuous waveform generation, depending upon the timer mode selected. |
| DRQO, DRQ1 | $\begin{aligned} & 18 \\ & 19 \end{aligned}$ | $1$ | DMA Request is driven HIGH by an external device when it desires that a DMA channel (Channel 0 or 1) perform a transfer. These signals are active HIGH, level-triggered, and internally synchronized. |
| NMI | 46 | 1 | Non-Maskable Interrupt is an edge-triggered input which causes a type 2 interrupt. NMI is not maskable internally. A transition from a LOW to HIGH initiates the interrupt at the next instruction boundary. NMI is latched internally. An NMI duration of one clock or more will guarantee service. This input is internally synchronized. |
| $\begin{aligned} & \text { INTO, INT1, } \\ & \text { inT2/INTAO, } \\ & \text { INT3/INTA1 } \end{aligned}$ | $\begin{gathered} 45,44 \\ 42 \\ 41 \end{gathered}$ | $\begin{aligned} & 1 \\ & 1 / 0 \\ & 1 / 0 \end{aligned}$ | Maskable Interrupt Requests can be requested by strobing one of these pins. When configured as inputs, these pins are active HIGH. Interrupt Requests are synchronized internally. INT2 and INT3 may be configured via software to provide active-LOW interrupt-acknowledge output signals. All interrupt inputs may be configured via software to be either edge- or level-triggered. To ensure recognition, all interrupt requests must remain active until the interrupt is acknowledged. When iRMX mode is selected, the function of these pins changes (see Interrupt Controller section of this data sheet). |

FUJITSU


MBL 80186
MBL 80186-6

PIN DESCRIPTION (Continued)
Table 1 - PIN DESCRIPTION (Continued)

| Symbol | Pin No. | Type | Name and Function |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A19/S6, <br> A18/S5, <br> A17/S4, <br> A16/S3 | $\begin{aligned} & 65 \\ & 66 \\ & 67 \\ & 68 \end{aligned}$ | $\begin{aligned} & 10 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Address Bus Outputs (16-19) and Bus Cycle Status (3-6) reflect the four most significant address bits during T1. These signals are active HIGH. During T2, T3, Tw and T4, status information is available on these lines as encoded below: |  |  |  |
|  |  |  |  |  | Low | High |
|  |  |  | S6 |  | Processor Cycle | DMA Cycle |
|  |  |  | S3, S4, and S5 are defined as LOW dur |  |  |  |
| AD15-AD0 | $\begin{gathered} 10-17 \\ 1-8 \end{gathered}$ | 1/0 | Address/Data Bus ( $\mathbf{0} \mathbf{- 1 5 \text { ) signals constitute the time mutiplexed memory }}$ or I/O address (T1) and data (T2, T3, Tw, and T4) bus. The bus is active HIGH. AO is analogous to BHE for the lower byte of the data bus, pins D7 through D0. It is LOW during T1 when a byte is to be transferred onto the lower portion of the bus in memory or I/O operations. |  |  |  |
| $\overline{\mathrm{BHE}} / \mathrm{S} 7$ | 64 | 0 | During T1 the Bus High Enable signal should be used to determine if data is to be enabled onto the most significant half of the data bus, pin D15D8. BHE is LOW during T1 for read, write, and interrupt acknowledge cycles when a byte is to be transferred on the higher half of the bus. The S7 status information is available during T2, T3, and T4. S7 is logically equivalent to $\overline{\mathrm{BHE}}$. The signal is active LOW, and is tristated OFF during bus HOLD. |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  | $\overline{\text { BHE Value }}$ | A0 Value |  |  |
|  |  |  | 0 0 1 1 | 0 1 0 1 | Word Transfer Byte Transfer Byte Transfer Reserved | f data bus (D15-D8) <br> data bus (D7-D0) |

## PIN DESCRIPTION (Continued)

Table 1 - PIN DESCRIPTION (Continued)

| Symbol | Pin No. | Type | Name and Function |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARDY | 55 | 1 | Asynchronous Ready informs the MBL 80186 that the addressed memory space or I/O device will complete a data transfer. The ARDY input pin will accept an asynchronous input, and is active HIGH. Only the rising edge is internally synchronized by the MBL 80186. This means that the falling edge of ARDY must be synchronized to the MBL 80186 clock. If connected to $\mathrm{V}_{\mathrm{Cc}}$, no WAIT states are inserted. Asynchronous ready (ARDY) or synchronous ready (SRDY) must be active to terminate a bus cycle. If unused, this line should be tied LOW. |  |  |  |
| SRDY | 49 | 1 | Synchronous Ready must be synchronized externally to the MBL 80186. The use of SRDY provides a relaxed system-timing specification on the Ready input. This is accomplished by eliminating the one-half clock cycle which is required for internally resolving the signal level when using the ARDY input. This line is active HIGH. If this line is connected to $\mathrm{V}_{\mathrm{Cc}}$, no WAIT states are inserted. Asynchronous ready (ARDY) or synchronous ready (SRDY) must be active before a bus cycle is terminated. If unused, this line should be tied LOW. |  |  |  |
| $\overline{\text { LOCK }}$ | 48 | 0 | $\overline{\text { LOCK }}$ output indicates that other system bus masters are not to gain control of the system bus while $\overline{\text { LOCK }}$ is active LOW. The $\overline{\text { LOCK }}$ signal is requested by the LOCK prefix instruction and is activated at the beginning of the first data cycle associated with the instruction following the LOCK prefix. It remains active until the completion of the instruction following the LOCK prefix. No prefetches will occur while $\overline{\text { LOCK }}$ is asserted. $\overline{\text { LOCK }}$ is active LOW, is driven HIGH for one clock during RESET, and then floated. |  |  |  |
| $\overline{\mathrm{S} 0}, \overline{\mathrm{~s} 1}, \overline{\mathrm{~S} 2}$ | 52-54 | 0 | Bus Cycle Status $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ are encoded to provide bus-transaction information: |  |  |  |
|  |  |  | $\overline{5} 2$ | $\overline{51}$ | $\overline{\text { so }}$ | Bus Cycle Initiated |
|  |  |  | 0 0 0 0 1 1 1 1 | 0 0 1 1 0 0 1 1 | 0 1 0 1 0 1 0 1 | Interrupt Acknowledge <br> Read I/O <br> Write I/O <br> Halt <br> Instruction Fetch <br> Read Data from Memory <br> Write Data to Memory <br> Passive (no bus cycle) |

The status pins float during "HOLD."
$\overline{\mathrm{S} 2}$ may be used as a logical M/IO indicator, and $\overline{\mathrm{S} 1}$ as a $\mathrm{DT} / \overline{\mathrm{R}}$ indicator. The status lines are driven HIGH for one clock during Reset, and then floated until a bus cycle begins.
HOLD indicates that another bus master is requesting the local bus. The HOLD input is active HIGH. HOLD may be asynchronous with respect to the MBL 80186 clock. The MBL 80186 will issue a HLDA (HIGH) in response to a HOLD request at the end of T4 or T1. Simultaneous with the issuance of HLDA, the MBL 80186 will float the local bus and control lines. After HOLD is detected as being LOW, the MBL 80186 will lower HLDA. When the MBL 80186 needs to run another bus cycle, it will again drive the local bus and control lines.
Upper Memory Chip Select is an active LOW output whenever a memory reference is made to the defined upper portion ( $1 \mathrm{~K}-256 \mathrm{~K}$ block) of memory. This line is not floated during bus HOLD. The address range activating UCS is software programmable.

PIN DESCRIPTION (Continued)
Table 1 - PIN DESCRIPTION (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\overline{\text { LCS }}$ | 33 | 0 | Lower Memory Chip Select is active LOW whenever a memory reference is made to the defined lower portion ( $1 \mathrm{~K}-256 \mathrm{~K}$ ) of memory. This line is not floated during bus HOLD. The address range activating $\overline{\mathrm{LCS}}$ is software programmable. |
| $\overline{\mathrm{MCSO}}-3$ | 38-35 | 0 | Mid-Range Memory Chip Select signals are active LOW when a memory reference is made to the defined mid-range portion of memory ( $8 \mathrm{~K}-$ 512 K ). These lines are not floated during bus HOLD. The address ranges activating $\overline{\mathrm{MCSO}}-3$ are software programmable. |
| $\overline{\text { PCSO }}$ - 4 | 25, 27-30 | 0 | Peripheral Chip Select Signals $0-4$ are active LOW when a reference is made to the defined peripheral area ( 64 K byte $\mathrm{I} / \mathrm{O}$ space). These lines are not floated during bus HOLD. The address ranges activating PCSO -4 are software programmable. |
| PCS5/A1 | 31 | 0 | Peripheral Chip Select 5 or Latched A1 may be programmed to provide a sixth peripheral chip select, or to provide an internally latched A1 signal. The address range activating PCS5 is software programmable. When programmed to provide latched A1, rather than PCS5, this pin will retain the previously latched value of A1 during a bus HOLD. A1 is active HIGH. |
| PCS6/A2 | 32 | 0 | Peripheral Chip Select 6 or Latched A2 may be programmed to provide a seventh peripheral chip select, or to provide an internally latched A2 signal. The address range activating PCS6 is software programmable. When programmed to provide latched A2, rather than PCS6, this pin will retain the previously latched value of A2 during a bus HOLD. A2 is active HIGH. |
| DT/ $\bar{R}$ | 40 | 0 | Data Transmit/Receive controls the direction of data flow through the external MBL 8286/8287 data bus transceiver. When LOW, data is trans ferred to the MBL 80186. When HIGH, the MBL 80186 places write data on the data bus. |
| $\overline{\text { DEN }}$ | 39 | 0 | Data Enable is provided as an MBL 8286/8287 data bus transceiver output enable. $\overline{\mathrm{DEN}}$ is active LOW during each memory and I/O access. $\overline{\mathrm{DEN}}$ is HIGH whenever DT/ $\overline{\mathrm{R}}$ changes state. |

## FUNCTIONAL DESCRIPTION

## INTRODUCTION

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

## MBL 80186 BASE ARCHITECTURE

The MBL 8086, 88, 186, and 286 family all contain the same basic set of registers, instructions, and addressing modes. The MBL 80186 processor is upward compatible with the MBL 8086, 8088, and 80286 CPUs.

## Register Set

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

## - General Registers

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

## - Segment Registers

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

## - Base and Index Registers

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

## - Status and Control Registers

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

## Status Word Description

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

Fig. 3a - MBL 80186 GENERAL PURPOSE REGISTER SET


Fig. 3b - STATUS WORD FORMAT


Table 2 - STATUS WORD BIT FUNCTIONS

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

## Instruction Set

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

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

## Memory Organization

Memory is organized in sets of segments. Each segment is a linear contiguous sequence of up to $64 \mathrm{~K}\left(2^{16}\right) 8$-bit bytes. Memory is addressed using a two-component address (a pointer) that consists of a 16 -bit base segment and a 16 -bit offset. The 16 -bit base values are contained in one of four internal segment registers (code, data, stack, extra). The physical address is calculated by shifting the base value LEFT by four bits and adding the 16 -bit offset value to yield a 20 -bit physical address (see Fig. 5). This allows for a 1 MByte physical address size.

All instructions that address operands in memory must specify the base segment and the 16 -bit offset value. For speed and compact instruction encoding, the segment register used for physical address generation is implied by the addressing mode used (see Table 3). These rules follow the way programs are written (see Fig. 6) as independent modules that require areas for code and data, a stack, and access to external data areas.

Special segment override instruction prefixes allow the implicit segment register selection rules to be overridden for special cases. The stack, data, and extra segments may coincide for simple programs.

Fig. 4 - MBL 80186 INSTRUCTION SET

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


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


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


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


| FLAG OPERATIONS |  |  |
| :--- | :--- | :---: |
| STC | Set carry flag |  |
| CLC | Clear carry flag |  |
| CMC | Complement carry flag |  |
| STD | Set direction flag |  |
| CLD | Clear direction flag |  |
| STI | Set interrupt enable flag |  |
| CLI | Clear interrupt enable flag |  |
| EXTERNAL SYNCHRONIZATION |  |  |
| HLT | Halt until interrupt or reset |  |
| WAIT | Wait for TEST pin active |  |
| ESC | Escape to extension processor |  |
| LOCK | Lock bus during next instruction |  |
| NO OPERATION |  |  |
| NOP | No operation |  |
|  |  |  |
| ENTER | Format stack for procedure entry |  |
| LEAVE | Restore stack for procedure exit |  |
| BOUND | Detects values outside prescribed range |  |

FUJITSU

MBL 80186
MBL 80186-6

Fig. 4 - MBL 80186 INSTRUCTION SET (Continued)

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

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

Fig. 5 - TWO COMPONENT ADDRESS


Table 3 - SEGMENT REGISTER SELECTION RULES

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

Fig. 6 - SEGMENTED MEMORY HELPS STRUCTURE SOFTWARE


## Addressing Modes

The MBL 80186 provides eight categories of addressing modes to specify operands. Two addressing modes are provided for instructions that operate on register or immediate operands:

- Register Operand Mode: The operand is located in one of the 8 - or 16 -bit general registers.
- Immediate Operand Mode: The operand is included in the instruction.

Six modes are provided to specify the location of an operand in a memory segment. A memory operand address consists of two 16 -bit components: a segment base and an offset. The segment base is supplied by a 16 -bit segment register either implicitly chosen by the addressing mode or explicitly chosen by a segment override prefix. The offset, also called the effective address, is calculated by summing any combination of the following three address elements:

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

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

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

- Direct Mode: The operand's offset is contained in the instruction as an 8 - or 16-bit displacement element.
- Register Indirect Mode: The operand's offset is in one of the registers SI, DI, BX, or BP.
- Based Mode: The operand's offset is the sum of an 8or 16-bit displacement and the contents of a base register (BX or BP).
- Indexed Mode: The operand's offset is the sum of an 8 - or 16 -bit displacement and the contents of an index register (SI or DI).
- Based Indexed Mode: The operand's offset is the sum of the contents of a base register and an index register.
- Based Indexed Mode with Displacement: The operand's offset is the sum of a base register's contents, an index register's contents, and an 8 - or 16-bit displacement.


## Data Types

The MBL 80186 directly supports the following data types:

- Integer: A signed binary numeric value contained in an 8 -bit byte or a 16 -bit word. All operations assume a 2 's complement representation. Signed 32 and 64 -bit integers are supported using the MBL 80186 and Intel 8087 Numeric Data Processor.
- Ordinal: An unsigned binary numeric value contained in an 8 -bit byte or a 16 -bit word.
- Pointer: A 16- or 32-bit quantity, composed of a 16 -bit offset component or a 16 -bit segment base component in addition to a 16 -bit offset component.
- String: A contiguous sequence of bytes or words. A string may contain from 1 to 64 K bytes.
- ASCII: A byte representation of alphanumeric and control characters using the ASCII standard of character representation.
- BCD: A byte (unpacked) representation of the decimal digits 0-9.
- Packed BCD: A byte (packed) representation of two decimal digits (0-9). One digit is stored in each nibble (4-bits) of the byte.
- Floating Point: A signed 32-, 64-, or 80-bit real number representation. (Floating point operands are supported using the MBL 80186 and Intel 8087 Numeric Data Processor configuration.)

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

## I/O Space

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

## Interrupts

An interrupt transfers execution to a new program location. The old program address (CS:IP) and machine state (Status Word) are saved on the stack to allow resumption of the interrupted program. Interrupts fall into three classes: hardware initiated, INT instructions, and instruction exceptions. Hardware initiated interrupts occur in response to an external input and are classified as nonmaskable or maskable.

Programs may cause an interrupt with an INT instruction. Instruction exceptions occur when an unusual condition, which prevents further instruction processing, is detected while attempting to execute an instruction. If the

Fig. 7 - MBL 80186 SUPPORTED DATA TYPES

$\mathrm{CHARACTER}_{\mathrm{N}} \mathrm{CHARACTER}_{1} \mathrm{CHARACTER}_{0}$


SIGNIFICANT DIGIT SIGNIFICANT DIGIT


NOTE:
*SUPPORTED BY MBL 80188 AND INTEL 8087 NUMERIC DATA PROCESSOR CONFIGURATION.
exception was caused by executing an ESC instruction with the ESC trap bit set in the relocation register, the return instruction will point to the ESC instruction, or to the segment override prefix immediately preceding the ESC instruction if the prefix was present. In all other cases, the return address from an exception will point at the instruction immediately following the instruction causing the exception.

A table containing up to 256 pointers defines the proper interrupt service routine for each interrupt. Interrupts $0-31$, some of which are used for instruction exceptions, are reserved. Table 4 shows the MBL 80186 predefined types and default priority levels. For each interrupt, an 8-bit vector must be supplied to the MBL 80186 which identifies the appropriate table entry. Exceptions supply the interrupt vector internally. In addition, internal peripherals and non-cascaded external interrupts will generate their own vectors through the internal interrupt controller. INT instructions contain or imply the vector and allow access to all 256 interrupts. Maskable hardware initiated interrupts supply the 8-bit vector to the CPU during an interrupt acknowledge bus sequence. Non-maskable hardware interrupts use a predefined internally supplied vector.

## Interrupt Sources

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

The software generated MBL 80186 interrupts are described below.

## - Divide Error Exception (Type 0)

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

## - Single-Step Interrupt (Type 1)

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

Table 4 - MBL 80186 INTERRUPT VECTORS

| Interrupt Name | Vector Type | Default <br> Priority | Related Instructions |
| :---: | :---: | :---: | :---: |
| Divide Error Exception | 0 | * 1 | DIV, IDIV |
| Single Step Interrupt | 1 | $12 * * 2$ | All |
| NMI | 2 | 1 | All |
| Breakpoint Interrupt | 3 | *1 | INT |
| INTO Detected Overflow Exception | 4 | *1 | INTO |
| Array Bounds Exception | 5 | *1 | BOUND |
| Unused-Opcode Exception | 6 | * 1 | Undefined Opcodes |
| ESC Opcode Exception | 7 | *1*** | ESC Opcodes |
| Timer 0 Interrupt | 8 | $2 A^{* * * *}$ |  |
| Timer 1 Interrupt | 18 | $2 \mathrm{~B}^{* * * *}$ |  |
| Timer 2 Interrupt | 19 | $2 C^{* * * *}$ |  |
| Reserved | 9 | 3 |  |
| DMA 0 Interrupt | 10 | 4 |  |
| DMA 1 Interrupt | 11 | 5 |  |
| INTO Interrupt | 12 | 6 |  |
| INT1 Interrupt | 13 | 7 |  |
| INT2 Interrupt | 14 | 8 |  |
| INT3 Interrupt | 15 | 9 |  |

## NOTES:

* 1. These are generated as the result of an instruction execution.
** 2. This is handled as in the MBL 8086.
$* * * * 3$. All three timers constitute one source of request to the interrupt controller. The Timer interrupts all have the same default priority level with respect to all other interrupt sources. However, they have a defined priority ordering amongst themselves. (Priority 2A is higher priority than 2B.) Each Timer interrupt has a separate vector type number.

4. Default priorities for the interrupt sources are used only if the user does not program each source into a unique priority level.
***5. An escape opcode will cause a trap only if the proper bit is set in the peripheral control block relocation register.

## - Non-Maskable Interrupt-NMI (Type 2)

An external interrupt source which cannot be masked.

## - Breakpoint Interrupt (Type 3)

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

## - INTO Detected Overflow Exception (Type 4)

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

## - Array Bounds Exception (Type 5)

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

## - Unused Opcode Exception (Type 6)

Generated if execution is attempted on undefined opcodes.

## - Escape Opcode Exception (Type 7)

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

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

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

## Non-Maskable Interrupt Request (NMI)

A non-maskable interrupt (NMI) is also provided. This interrupt is serviced regardless of the state of the IF bit. A typical use of NMI would be to activate a power failure routine. The activation of this input causes an interrupt with an internally supplied vector value of 2 . No external interrupt acknowledge sequence is performed. The IF bit is cleared at the beginning of an NMI interrupt to prevent maskable interrupts from being serviced.

## Single-Step Interrupt

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

## Initialization and Processor Reset

Processor initialization or startup is accomplished by driving the $\overline{\mathrm{RES}}$ input pin LOW. $\overline{\mathrm{RES}}$ forces the MBL 80186 to terminate all execution and local bus activity. No instruction or bus activity will occur as long as $\overline{\mathrm{RES}}$ is active. After $\overline{R E S}$ becomes inactive and an internal processing interval elapses, the MBL 80186 begins execution with the instruction at physical location FFFFO(H). $\overline{R E S}$ also sets some registers to predefined values as shown in Table 5.

Table 5 - MBL 80186 INITIAL REGISTER STATE AFTER RESET

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

## MBL 80186 CLOCK GENERATOR

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

## Oscillator

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

The following parameters may be used for choosing a crystal:

[^3]0 to $70^{\circ} \mathrm{C}$
$30 \Omega$ max

| C0 (Shunt Capacitance of Crystal): | 7.0 pF max |
| :--- | ---: |
| C1 (Load Capacitance): | $20 \mathrm{pF} \pm 2 \mathrm{pF}$ |
| Drive Level: | 1 mW max |

Fig. 8 - RECOMMENDED MBL 80186 CRYSTAL CONFIGURATION


## Clock Generator

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

## READY Synchronization

The MBL 80186 provides both synchronous and asynchronous ready inputs. Asynchronous ready synchronization is accomplished by circuitry which samples ARDY in the middle of T2, T3 and again in the middle of each Tw until ARDY is sampled HIGH. One-half CLKOUT cycle of resolution time is used. Full synchronization is performed only on the rising edge of ARDY, i.e., the falling edge of ARDY must be synchronized to the CLKOUT signal if it will occur during T2, T3 or Tw. High-to-LOW transitions of ARDY must be performed synchronously to the CPU clock.

A second ready input (SRDY) is provided to interface with externally synchronized ready signals. This input is sampled at the end of T2, T3 and again at the end of each Tw until it is sampled HIGH. By using this input rather than the asynchronous ready input, the half-clock cycle resolution time penalty is eliminated.

This input must satisfy set-up and hold times to guarantee proper operation of the circuit.

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

## RESET Logic

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

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

## LOCAL BUS CONTROLLER

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

## Memory/Peripheral Control

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

## Transceiver Control

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

## Table 6 - TRANSCEIVER CONTROL SIGNALS DESCRIPTION

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

## Local Bus Arbitration

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

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

## Local Bus Controller and Reset

Upon receipt of a RESET pulse from the $\overline{\mathrm{RES}}$ input, the local bus controller will perform the following actions:

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

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

- Drive $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ to the passive state (all HIGH) and then float.
- Drive LOCK HIGH and then float.
- Tristate ADO-15., A16-19, $\overline{\mathrm{BHE}}, \mathrm{DT} / \overline{\mathrm{R}}$.
- Drive ALE LOW (ALE is never floated).
- Drive HLDA LOW.


## INTERNAL PERIPHERAL INTERFACE

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

The control block base address is programmed via a 16 -bit relocation register contained within the control block at offset FEH from the base address of the control block (see Fig. 9). It provides the upper 12 bits of the base address of the control block. Note that mapping the control register block into an address range corresponding to a chip-select range is not recommended (the chip select circuitry is discussed later in this data sheet). In addition, bit 12 of this register determines whether the control block will be mapped into $\mathrm{I} / \mathrm{O}$ or memory space. If this bit is 1 , the control block will be located in memory space, whereas if the bit is 0 , the control block will be located in I/O space. If the control register block is mapped into I/O space, the upper 4 bits of the base address must be programmed as 0 (since I/O addresses are only 16 bits wide).
In addition to providing relocation information for the control block, the relocation register contains bits which place the interrupt controller into iRMX mode, and cause the CPU to interrupt upon encountering ESC instructions.

At RESET, the relocation register is set to 20 FFH . This causes the control block to start at FFOOH in I/O space. An offset map of the 256 -byte control register block is shown in Fig. 10.

The integrated MBL 80186 peripherals operate semiautonomously from the CPU. Access to them for the most part is via software read/write of the control and data locations in the control block. Most of these registers can be both read and written. A few dedicated lines, such as interrupts and DMA request provide real-time communication between the CPU and peripherals as in a more conventional system utilizing discrete peripheral blocks. The overall interaction and function of the peripheral blocks has not substantially changed.

## CHIP-SELECT/READY GENERATION LOGIC

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

## Memory Chip Selects

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

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

Fig. 9 - RELOCATION REGISTER

OFFSET: FEH


ET = ESC Trap / No ESC Trap (1/0)
$M / I O=$ Register block located in Memory / I/O Space (1/0)
RMX = Master Interrupt Controller mode / iRMX compatible Interrupt Controller mode (0/1)

Fig. 10 - INTERNAL REGISTER MAP

| Relocation Register | FEH |
| :---: | :---: |
| DMA Descriptors Channel 1 | $\begin{aligned} & \mathrm{DAH} \\ & \mathrm{DOH} \end{aligned}$ |
|  |  |
| DMA Descriptors Channel 0 | $\begin{aligned} & \mathrm{CAH} \\ & \mathrm{COH} \end{aligned}$ |
|  |  |
| Chip-Select Control Registers | $\begin{aligned} & \mathrm{A} 8 \mathrm{H} \\ & \mathrm{AOH} \end{aligned}$ |
| - |  |
|  | 66 H |
| Timer 2 Control Registers | $\begin{aligned} & 60 \mathrm{H} \\ & 5 \mathrm{EH} \\ & 58 \mathrm{H} \\ & 56 \mathrm{H} \\ & 50 \mathrm{H} \end{aligned}$ |
| Timer 1 Control Registers |  |
| Timer 0 Control Registers |  |
|  |  |
|  |  |
| Interrupt Controller Registers |  |

## - Upper Memory $\overline{\mathbf{C S}}$

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

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

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

Any internally generated 20-bit address whose upper 16 bits are greater than or equal to UMCS (with bits 0-5 " 0 ") will cause UCS to be activated. UMCS bits R2-RO are used to specify READY mode for the area or memory defined by this chip-select register, as explained below.

Table 7 - UMCS PROGRAMMING VALUES

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

## - Lower Memory $\overline{\text { CS }}$

The MBL 80186 provides a chip select for low memory called $\overline{\mathrm{LCS}}$. The bottom of memory contains the interrupt vector table, starting at location 00000 H .

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

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

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

Table 8 - LMCS PROGRAMMING VALUES

| Upper Address | Memory <br> Block Size | LMCS Value (Assuming $R 0=R 1=R 2=0)$ |
| :---: | :---: | :---: |
| 003FFH | 1K | 0038H |
| 007FFH | 2K | 0078H |
| 00FFFH | 4K | 00F8H |
| 01 FFFH | 8K | 01F8H |
| 03FFFH | 16K | 03F8H |
| 07FFFH | 32K | 07F8H |
| OFFFFH | 64K | OFF8H |
| 1FFFFH | 128K | 1FF8H |
| 3FFFFH | 256K | 3FF8H |

## - Mid-Range Memory $\overline{\mathrm{CS}}$

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

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

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

Table 9 - MPCS PROGRAMMING VALUES

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

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

MMCS bits R2-R0 specify READY mode of operation for all mid-range chip selects. All devices in mid-range memory must use the same number of WAIT states.

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

## Peripheral Chip Selects

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

Fig. 11 - UMCS REGISTER


A19 A11

Fig. 12 - LMCS REGISTER

OFFSET: A2H


Fig. 13 - MPCS REGISTER

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

Fig. 14 - MMCS REGISTER


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

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

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

Table 10 - PCS ADDRESS RANGES

| PCS Line | Active between Locations |
| :---: | :---: |
| PCSO | PBA - PBA +127 |
| PCS1 | PBA $+128-$ PBA +255 |
| PCS2 | PBA $+256-$ PBA +383 |
| PCS3 | PBA $+384-$ PBA +511 |
| PCS4 | PBA $+512-$ PBA +639 |
| PCS5 | PBA $+640-$ PBA +767 |
| PCS6 | PBA $+768-$ PBA +895 |

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

MPCS bits 0-2 are used to specify READY mode for $\overline{\mathrm{PCS}}-\overline{\mathrm{PCS}} \mathbf{6}$ as outlined below.

Fig. 15 - PACS REGISTER

OFFSET: A4H | A19 | $U$ |
| :---: | :---: |
| A19 | $U$ |

Table 11 - MS, EX PROGRAMMING VALUES

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

## READY Generation Logic

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

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

Table 12 - READY BITS PROGRAMMING

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

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

SRDY lines are always ignored during cycles accessing internal peripherals.

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

## Chip Select/Ready Logic and Reset

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

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


## DMA CHANNELS

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

## DMA Operation

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

Fig. 16 - MPCS REGISTER

OFFSET: A8H


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

Table 13 - DMA CONTROL BLOCK FORMAT

| Register Name | Register Address |  |
| :--- | :---: | :---: |
|  | Ch. 0 | Ch. 1 |
| Control Word | CAH | DAH |
| Transfer Counter | C8H | D8H |
| Destination Pointer (upper 4 bits) | C6H | D6H |
| Destination Pointer | C4H | D4H |
| Source Pointer (upper 4 bits) | C2H | D2H |
| Source Pointer | COH | DOH |

## DMA Channel Control Word Register

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

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

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

## DMA Control Word Bit Descriptions

$\bar{B} / W: \quad B y t e / W o r d(0 / 1)$ Transfers.
ST/STOP: Start/Stop (1/0) Channel.
$\mathrm{CHG} / \overline{\mathrm{NOCHG}}: \quad$ Change/Do not change (1/0) ST/ $\overline{\mathrm{STOP}}$ bit. If this-bit is set when writing to the control word, the ST/ $\overline{\mathrm{STOP}}$ bit will be programmed by the write to the control word. If this bit is cleared when writing the control word, the ST/STOP bit will

Fig. 17 - DMA UNIT BLOCK DIAGRAM


Fig. 18 - DMA CONTROL REGISTER


X = DON'T CARE .

INT: Enable Interrupts to CPU on Transfer Count termination.

TC: If set, DMA will terminate when the contents of the Transfer Count register reach zero. The ST/ $\overline{\mathrm{STOP}}$ bit will also be reset at this point if TC is set. If this bit is cleared, the DMA unit will decrement the transfer count register for each DMA cycle, but the DMA transfer will not stop when the contents of the TC register reach zero.

SYN:
(2 bits)
00 No synchronization.
NOTE: The ST bit will be cleared automatically when the contents of the TC register reach zero regardless of the state of the TC bit.
01 Source synchronization.
10 Destination synchronization.
11 Unused.
SOURCE: INC Increment source pointer by 1 or 2 (depends on $\bar{B} / W$ ) after each transfer.
$M / \overline{I O}$ Source pointer is in $M / I O$ space (1/0).
DEC Decrement source pointer by 1 or 2 (depends on $\bar{B} / W$ ) after each transfer.

DEST: INC Increment destination pointer by 1 or 2 ( $\bar{B} / W$ ) after each transfer.
$\mathrm{M} / \overline{\mathrm{IO}}$ Destination pointer is in $\mathrm{M} / \mathrm{IO}$ space (1/0).

DEC Decrement destination pointer by 1 or 2 (depending on $\bar{B} / W$ ) after each transfer.

P: $\quad$ Channel priority - relative to other channel.
0 low priority.
1 high priority.
Channels will alternate cycles if both set at same priority level.

TDRQ: $\quad 0:$ Disable DMA requests from timer 2.

1: Enable DMA requests from timer 2.

Bit 3:
Bit 3 is not used.
If both INC and DEC are specified for the same pointer, the pointer will remain constant after each cycle.

## DMA Destination and Source Pointer Registers

Each DMA channel maintains a 20 -bit source and a 20 -bit destination pointer. Each of these pointers takes up two full 16 -bit registers in the peripheral control block. The lower four bits of the upper register contain the upper four bits of the 20-bit physical address (see Fig. 18a). These pointers may be individually incremented or decremented

Fig. 18a - DMA MEMORY POINTER REGISTER FORMAT

| HIGHER REGISTER ADDRESS | XXX | XXX | X X X | A19-A16 |
| :---: | :---: | :---: | :---: | :---: |
| LOWER REGISTER ADDRESS | A15-A12 | A11-A8 | A7-A4 | A3-A0 |

15

$$
X X X=\text { DON'T CARE }
$$

after each transfer. If word transfers are performed, the pointer is incremented or decremented by two. Each pointer may point into either memory or I/O space. Since the DMA channels can perform transfers to or from odd addresses, there is no restriction on values for the pointer registers. Higher transfer rates can be obtained if all word transfers are performed to even addresses, since this will allow data to be accessed in a single memory access.

## DMA Transfer Count Register

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

## DMA Requests

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

Table 14 - MAXIMUM DMA TRANSFER RATES

| Type of <br> Synchronization <br> Selected | CPU Running | CPU Halted |
| :--- | :--- | :--- |
| Unsynchronized | $2 \mathrm{MBytes} / \mathrm{sec}$ | $2 \mathrm{MBytes} / \mathrm{sec}$ |
| Source Synch | $2 \mathrm{MBytes} / \mathrm{sec}$ | $2 \mathrm{MBytes} / \mathrm{sec}$ |
| Destination Synch | $1.3 \mathrm{MBy} t \mathrm{ses} / \mathrm{sec}$ | $1.5 \mathrm{MBy} t \mathrm{~s} / \mathrm{sec}$ |

## DMA Acknowledge

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

## DMA Priority

The DMA channels may be programmed such that one

Fig. 19 - TIMER BLOCK DIAGRAM


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

## DMA Programming

DMA cycles will occur whenever the ST/ $\overline{\mathrm{STOP}}$ bit of the Control Register is set. If synchronized transfers are programmed, a DRO must also have been generated. Therefore, the source and destination transfer pointers, and the transfer count register (if used) must be programmed before this bit is set.

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

## DMA Channels and Reset

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

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


## TIMERS

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

## Timer Operation

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

Each timer gets serviced every fourth CPU-clock cycle, and thus can operate at speeds up to one-quarter the internal clock frequency (one-eighth the crystal rate). External clocking of the timers may be done at up to a rate of one-quarter of the internal CPU-clock rate (2 MHz for an $8 \mathrm{MHz} \mathrm{CPU} \mathrm{clock)} .\mathrm{Due} \mathrm{to} \mathrm{internal} \mathrm{synchro-}$ nization and pipelining of the timer circuitry, a timer output may take up to 6 clocks to respond to any individual clock or gate input. Since the count registers and the maximum count registers are all 16 bits wide, 16 bits of resolution are provided. Any Read or Write access to the timers will add one wait state to the minimum fourclock bus cycle, however. This is needed to synchronize and coordinate the internal data flows between the internal timers and the internal bus.

Fig. 20 - TIMER MODE/CONTROL REGISTER


The timers have several programmable options.

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

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

## Timer Mode/Control Register

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

Table 15 - TIMER CONTROL BLOCK FORMAT

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

## ALT:

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

## CONT:

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

## EXT:

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

## P:

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

## RTG:

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

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

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

## EN:

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

## INH:

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

## INT:

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

## MC:

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

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

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

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

## Count Registers

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

## Max Count Registers

Timers 0 and 1 have two MAX COUNT registers, while timer 2 has a single MAX COUNT register. These contain the number of events the timer will count. In timers 0 and 1 , the MAX COUNT register used can alternate between the two max count values whenever the current maximum count is reached. The condition which causes a timer to reset is equivalent between the current count value and the
max count being used. This means that if the count is changed to be above the max count value, or if the max count value is changed to be below the current value, the timer will not reset to zero, but rather will count to its maximum value, "wrap around" to zero, then count until the max count is reached.

## Timers and Reset

Upon RESET, the Timers will perform the following actions:

- All EN (Enable) bits are reset preventing timer counting.
- All SEL (Select) bits are reset to zero. This selects MAX COUNT register A, resulting in the Timer Out pins going HIGH upon RESET.


## INTERRUPT CONTROLLER

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

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

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

The interrupt controller has a special iRMX 86 compatibility mode that allows the use of the MBL 80186 within the iRMX 86 operating system interrupt structure. The controller is set in this mode by setting bit 14 in the peripheral control block relocation register (see iRMX 86 Compatibility Mode section). In this mode, the internal MBL 80186 interrupt controller functions as a "slave" controller to an external "master" controller. Special initialization software must be included to properly set up the MBL 80186 interrupt controller in i RMX 86 mode.

## MASTER MODE OPERATION

## Interrupt Controller External Interface

For external interrupt sources, five dedicated pins are provided. One of these pins is dedicated to NMI, non-maskable interrupt. This is typically used for power-fail interrupts, etc. The other four pins may function either as four inter-
rupt input lines with internally generated interrupt vectors, as an interrupt line and an interrupt acknowledge line (called the "cascade mode") along with two other input lines with internally generated interrupt vectors, or as two interrupt input lines and two dedicated interrupt acknowledge output lines. When the interrupt lines are configured in cascade mode, the MBL 80186 interrupt controller will not generate internal interrupt vectors.

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

## Interrupt Controller Modes of Operation

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

## - Fully Nested Mode

When in the fully nested mode four pins are used as direct interrupt requests. The vectors for these four inputs are generated internally. An in-service bit is provided for every interrupt source. If a lower-priority device requests an interrupt while the in-service bit (IS) is set, no interrupt will be generated by the interrupt controller. In addition, if another interrupt request occurs from the same interrupt source while the in-service bit is set, no interrupt will be generated by the interrupt controller. This allows interrupt service routines to operate with interrupts enabled without being themselves interrupted by lower-priority interrupts. Since interrupts are enabled, higher-priority interrupts will be serviced.
When a service routine is completed, the proper IS bit must be reset by writing the proper pattern to the EOI register. This is required to allow subsequent interrupts from this interrupt source and to allow servicing of lower-priority interrupts. An EOI command is issued at the end of the service routine just before the issuance of the return from interrupt instruction. If the fully nested structure has been upheld, the next highest-priority source with its IS bit set is then serviced.

## - Cascade Mode

The MBL 80186 has four interrupt pins and two of them have dual functions. In the fully nested mode the four pins are used as direct interrupt inputs and the corresponding

Fig. 21 - INTERRUPT CONTROLLER BLOCK DIAGRAM


## MBL 80186

MBL 80186-6
vectors are generated internally. In the cascade mode, the four pins are configured into interrupt input-dedicated acknowledge signal pairs. The interconnection is shown in Fig. 22. INTO is an interrupt input interfaced to a MBL 8259A, while INT2//्INTAO serves as the dedicated interrupt acknowledge signal to that peripheral. The same is true for INT1 and INT3/INTA1. Each pair can selectively be placed in the cascade or non-cascade mode by programming the proper value into INTO and INT1 control registers. The use of the dedicated acknowledge signals eliminates the need for the use of external logic to generate $\overline{\mathrm{INTA}}$ and device select signals.

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

## - Special Fully Nested Mode

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

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

## Operation in a Polled Environment

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

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

## Master Mode Features <br> - Programmable Priority

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

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

## - End-of-Interrupt Command

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

## - Trigger Mode

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

- Interrupt Vectoring

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

## Interrupt Controller Registers

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

## - In-Service Register

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

## - Interrupt Request Register

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

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

## - Mask Register

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

Fig. 22 - CASCADE MODE INTERRUPT CONNECTION


Fig. 23 - INTERRUPT CONTROLLER REGISTERS (NON-iRMX 86 MODE)

| INT3 CONTROL REGISTER |
| :---: |
| INT2 CONTROL REGISTER |
| INT1 CONTROL REGISTER |
| INTO CONTROL REGISTER |
| DMA1 CONTROL REGISTER |
| DMAO CONTROL REGISTER |
| TIMER CONTROL REGISTER |
| INTERRUPT STATUS REGISTER |
| INTERRUPT REQUEST REGISTER |
| IN-SERVICE REGISTER |
| PRIORITY MASK REGISTER |
| MASK REGISTER |
| POLL STATUS REGISTER |
| POLL REGISTER |
| EOI REGISTER |

OFFSET
3EH
3 CH
3AH
38 H
36 H
34H
32H
30 H
2EH
2 CH

## Priority Mask Register

This register is used to mask all interrupts below particular interrupt priority levels. The format of this register is
register inhibits interrupts of priority lower (a higher priority number) than the code specified. For example, 100 written into this register masks interrupts of level five (101), six (110), and seven (111). The register is reset to seven (111) upon RESET so all interrupts are unmasked.

## - Interrupt Status Register

This register contains general interrupt controller status information. The format of this register is shown in Fig. 26. The bits in the status register have the following functions:

DHLT: DMA Halt Transfer; setting this bit halts all DMA transfers. It is automatically set whenever a non-maskable interrupt occurs, and it is reset when an IRET instruction is executed. The purpose of this bit is to allow prompt service of all non-maskable interrupts. This bit may also be set by the CPU.

IRTx: These three bits represent the individual timer interrupt request bits. These bits are used to differentiate the timer interrupts, since the timer IR bit in the interrupt request register is the "OR" function of all timer interrupt requests. Note that setting any one of these three bits initiates an interrupt request to the interrupt controller.

Fig. 24 - IN-SERVICE, INTERRUPT REQUEST, AND MASK REGISTER FORMATS

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

Fig. 25 - PRIORITY MASK REGISTER FORMAT


Fig. 26 - INTERRUPT STATUS REGISTER FORMAT


## - Timer, DMA 0, 1 Control Registers

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

## - INTO-INT3 Control Registers

These registers are the control words for the four external input pins. Fig. 28 shows the format of the INTO and INT1 Control registers; Fig. 29 shows the format of the INT2 and INT3 Control registers. In cascade mode or special fully nested mode, the control words for INT2 and INT3 are not used.

The bits in the various control registers are encoded as follows:

PRO-2: Priority programming information. Highest Priority $=000$, Lowest Priority $=111$

LTM: Level-trigger mode bit, $1=$ level-triggered; $0=$ edge-triggered. Interrupt input levels are active high. In level-triggered mode, an interrupt is generated whenever the external line
is high. In edge-triggered mode, an interrupt will be generated only when this level is preceded by an inactive-to-active transition on the line. In both cases, the level must remain active until the interrupt is acknowledged.

MSK: $\quad$ Mask bit, $1=$ mask; $0=$ nonmask.
C: $\quad$ Cascade mode bit, $1=$ cascade; $0=$ direct

SFNM: $\quad$ Special fully nested mode bit, $1=$ SFNM

## - EOI Register

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

The bits in the EOI register are encoded as follows:
Sx: Encoded information that specifies an interrupt source vector type as shown in Table 4. For example, to reset the In-Service bit for DMA channel 0 , these bits should be set to 01010, since the vector type for DMA channel 0 is 10 . Note that to reset the single In -Service bit for any of the three timers, the vector type for timer 0 ( 8 ) should be written in this register.

Fig. 27 - TIMER/DMA CONTROL REGISTER FORMATS


Fig. 28 - INTO/INT1 CONTROL REGISTER FORMATS


Fig. 29 - INT2/INT3 CONTROL REGISTER FORMATS


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

## - Poll and Poll Status Registers

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

Encoding of the Poll and Poll Status register bits are as follows:

Sx. Encoded information that indicates the vector type of the highest priority interrupting source. Valid only when INTREQ $=1$.

INTREQ: This bit determines if an interrupt request is present. Interrupt Request = 1; no Interrupt Request $=0$.

## iRMX 86 COMPATIBILITY MODE

This mode allows iRMX 86-80186 compatibility. The interrupt model of iRMX 86 requires one master and multiple slave MBL 8259As in cascaded fashion. When iRMX mode is used, the internal MBL 80186 interrupt controller will be used as a slave controller to an external master interrupt controller. The internal MBL 80186 resources will be monitored through the internal interrupt controller, while the external controller functions as the system master interrupt controller.

Upon reset, the MBL 80186 interrupt controller will be in the non-iRMX 86 mode of operation. To set the con-
troller in the iRMX 86 mode, bit 14 of the Relocation Register should be set.
Because of pin limitations caused by the need to interface to an external MBL 8259A master, the internal interrupt controller will no longer accept external inputs. There are however, enough MBL 80186 interrupt controller inptus (internally) to dedicate one to each timer. In this mode, each timer interrupt source has its own mask bit, IS bit, and control word.

The iRMX 86 operating system requires peripherals to be assigned fixed priority levels. This is incompatible with the normal operation of the MBL 80186 interrupt controller. Therefore, the initialization software must program the proper priority levels for each source. The required priority levels for the internal interrupt sources in iRMX mode are shown in Table 16.

Table 16 - INTERNAL SOURCE PRIORITY LEVEL

| Priority Level | Interrupt Source |
| :---: | :---: |
| 0 | Timer 0 |
| 1 | (reserved) |
| 2 | DMA 0 |
| 3 | DMA 1 |
| 4 | Timer 1 |
| 5 | Timer 2 |

These level assignments must remain fixed in the iRMX 86 mode of operation.

## iRMX $\mathbf{8 6}$ Mode External Interface

The configuration of the MBL 80186 with respect to an external MBL 8259A master is shown in Fig. 32. The INTO input is used as the MBL 80186 CPU interrupt input. INT3 functions as an output to send the MBL 80186 slave-interrupt-request to one of the 8 master-PIC-inputs.

Fig. 30 - EOI REGISTER FORMAT


Fig. 31 - POLL REGISTER FORMAT


MBL 80186 MBL 80186-6

Fig. 32 - iRMX 86 INTERRUPT CONTROLLER INTERCONNECTION


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

TNT2 is used as an acknowledge output, suitable to drive the $\overline{\text { INTA }}$ input of an MBL 8259A.

## Interrupt Nesting

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

## Vector Generation in the iRMX $\mathbf{8 6}$ Mode

Vector generation in iRMX mode is exactly like that of a MBL 8259A slave. The interrupt controller generates an 8 -bit vector which the CPU multiplies by four and uses as an address into a vector table. The significant five bits of the vector are user-programmable while the lower three bits are generated by the priority logic. These bits represent the encoding of the priority level requesting service. The significant five bits of the vector are programmed by writing to the interrupt Vector register at offset 20 H .

## Specific End-of-Interrupt

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

## Interruput Controller Registers in the iRMX $\mathbf{8 6}$ Mode

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

## - End-of-Interrupt Register

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

The bits in the EOI register are encoded as follows:
Lx: Encoded value indicating the priority of the IS bit to be reset.

## - In-Service Register

This register can be read from or written into. It contains the in-service bit for each of the internal interrupt sources.

The format for this register is shown in Fig. 35. Bit positions 2 and 3 correspond to the DMA channels; positions 0,4 , and 5 correspond to the integral timers. The source's IS bit is set when the processor acknowledges its interrupt request.

## - Interrupt Request Register

This register indicates which internal peripherals have interrupt requests pending. The format of this register is shown in Fig. 35. The interrupt request bits are set when a request arrives from an internal source, and are reset when the processor acknowledges the request.

## - Mask Register

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

## - Control Registers

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

The bits of the Control Registers are encoded as follows:
PRx: 3-bit encoded field indicating a priority level for the source; note that each source must be programmed at specified levels.

MSK: Mask bit for the priority level indicated by PRx bits.

Fig. 33 - INTERRUPT CONTROLLER REGISTERS (iRMX MODE)


## - Interrupt Vector Register

This register provides the upper five bits of the interrupt vector address. The format of this register is shown in Fig. 37. The interrupt controller itself provides the lower three bits of the interrupt vector as determined by the priority level of the interrupt request.
The format of the bits in this register is:
tx: 5-bit field indicating the upper five bits of the vector address.

Fig. 34 - SPECIFIC EOI REGISTER FORMAT


Fig. 35 - IN-SERVICE, INTERRUPT REQUEST, AND MASK REGISTER FORMATS


## - Priority-Level Mask Register

This register indicates the lowest priority-level interrupt which will be serviced.
The encoding of the bits in this register is:
$m x$ : 3-bit encoded field indication priority-level value. All levels of lower priority will be masked.

## - Interrupt Status Register

This register is defined exactly as in Non-i RMX Mode. (See Fig. 26.)

## Interrupt Controller and Reset

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

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

Fig. 36 - CONTROL WORD FORMAT


Fig. 37 - INTERRUPT VECTOR REGISTER FORMAT


Fig. 38 - PRIORITY LEVEL MASK REGISTER FORMAT

| 15 | 14 | 13 | 8 |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ | 0 | 0 | 0 | 0 | 0 | 0 | $m 2$ | $m 1$ | $m 0$ |

Fig. 39 - TYPICAL MBL 80186 COMPUTER


Fig. 40 - TYPICAL MBL 80186 MULTI-MASTER BUS INTERFACE


## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature under Bias . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin with
Respect to Ground . . . . . . . . . . . . . . . -1.0 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 3 Watt
*NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ}$ to $70^{\circ} \mathrm{C}$ )

Applicable to MBL 80186 ( 8 MHz ) and MBL 80186-6 ( 6 MHz )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | 0.5 | +0.8 | V |  |
| $V_{\text {IH }}$ | Input High Voltage (All except $\times 1$ and ( $\overline{\mathrm{RES}}$ )) | 2.0 | $\mathrm{V}_{\mathrm{Cc}}+0.5$ | V |  |
| $\mathrm{V}_{1 \mathrm{H} 1}$ | Input High Voltage ( $\overline{\mathrm{RES}}$ ) | 3.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA}$ for $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ <br> $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ for all other outputs |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | ${ }^{1} \mathrm{OH}=-400 \mu \mathrm{~A}$ |
| ${ }^{1} \mathrm{Cc}$ | Power Supply Current |  | $\frac{550}{450}$ | mA | Max measured at $\frac{T_{A}=0^{\circ} \mathrm{C}}{T_{A}=70^{\circ} \mathrm{C}}$ |
| ILI | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV}<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {CC }}$ |
| ILO | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V}<\mathrm{V}_{\text {OUT }}<\mathrm{V}_{\text {CC }}$ |
| $\mathrm{V}_{\text {CLI }}$ | Clock Input Low Voltage | -0.5 | 0.6 | V |  |
| $\mathrm{V}_{\mathrm{CHI}}$ | Clock Input High Voltage | 3.9 | $V^{\mathrm{CC}^{+1} .0}$ | V |  |
| $\mathrm{V}_{\text {CLO }}$ | Clock Output Low Voltage |  | 0.6 | V | ${ }^{1} \mathrm{OL}=4.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{CHO}}$ | Clock Output High Voltage | 4.0 |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{CIN}^{\text {IN }}$ | Input Capacitance |  | 10 | pF |  |
| $\mathrm{C}_{10}$ | I/O Capacitance |  | 20 | pF |  |

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

MBL 80186 Timing Requirements All timings Measured At 1.5 Volts Unless Otherwise Noted.
Applicable to MBL 80186 ( 8 MHz ) and MBL $80186-6$ ( 6 MHz )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :--- | :--- | :--- | :--- |
| TDVCL | Data in Setup Time (A/D) | 20 |  | ns |  |
| TCLDX | Data in Hold Time (A/D) | 10 |  | ns |  |
| TARYHCH | Asynchronous Ready <br> (AREADY) Active Setup Time | 20 |  | ns |  |
| TARYLCL | AREADY Inactive Setup Time | 35 |  | ns |  |
| TCHARYX | AREADY Hold Time | 15 |  | ns |  |
| TARYCHL | Asynchronous Ready Inactive <br> Hold Time | 15 |  | ns |  |
| TSRYCL | Synchronous Ready <br> (SREADY) Transition Setup Time | 20 |  | ns |  |
| TCLSRY | SREADY Transition Hold Time | 15 |  | ns |  |
| THVCL | HOLD Setup Time* | 25 |  | ns |  |
| TINVCH | INTR, NMI, TEST, TIMERIN, <br> Setup Time* | 25 |  | ns |  |
| TINVCL | DRQ0, DRQ1, Setup Time* | 25 |  |  |  |

[^4]
## A.C. CHARACTERISTICS (Continued)

## MBL 80186 Master Interface Timing Responses

| Symbol | Parameter | MBL 80186 (8 MHz) |  | MBL 80186-6 (6 MHz) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TCLAV | Address Valid Delay | 5 | 55 | 5 | 63 | ns | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=20-200 \mathrm{pF} \\ & \text { all outputs } \end{aligned}$ |
| TCLAX | Address Hold Time | 10 |  | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 35 | TCLAX | 44 | ns |  |
| TCHCZ | Command Lines Float Delay |  | 45 |  | 56 | ns |  |
| TCHCV | Command Lines Valid Delay (after Float) |  | 55 |  | 76 | ns |  |
| TLHLL | ALE Width | TCLCL-35 |  | TCLCL-35 |  | ns |  |
| TCHLH | ALE Active Delay |  | 35 |  | 44 | ns |  |
| TCHLL | ALE Inactive Delay |  | 35 |  | 44 | ns |  |
| TLLAX | Address Hold Time to ALE Inactive | TCHCL-25 |  | TCHCL-30 |  | ns |  |
| TCLDV | Data Valid Delay | 10 | 44 | 10 | 55 | ns |  |
| TCLDOX | Data Hold Time | 10 |  | 10 |  | ns |  |
| TWHDX | Data Hold Time after $\overline{\text { WR }}$ | TCLCL-40 |  | TCLCL-50 |  | ns |  |
| TCVCTV | Control Active Delay 1 | 10 | 70 | 10 | 87 | ns |  |
| TCHCTV | Control Active Delay 2 | 10 | 55 | 10 | 76 | ns |  |
| tcvetx | Control Inactive Delay | 5 | 55 | 5 | 76 | ns |  |
| TCVDEX | DEN Inactive Delay (Non-Write Cycle) | 10 | 70 | 10 | 87 | ns |  |
| TAZRL | Address Float to $\overline{\mathrm{RD}}$ Active | 0 |  | 0 |  | ns |  |
| TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 10 | 70 | 10 | 87 | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 55 | 10 | 76 | ns |  |
| TRHAV | $\overline{\mathrm{RD}}$ Inactive to Address Active | TCLCL-40 |  | TCLCL-50 |  | ns |  |
| TCLHAV | HLDA Valid Delay | 5 | 50 | 5 | 67 | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Width | 2TCLCL-50 |  | 2TCLCL-50 |  | ns |  |
| TWLWH | WR Width | 2TCLCL-40 |  | 2TCLCL-40 |  | ns |  |
| TAVAL | Address Valid to ALE Low | TCLCH-25 |  | TCLCH-45 |  | ns |  |
| TCHSV | Status Active Delay | 10 | 55 | 10 | 76 | ns |  |
| TCLSH | Status Inactive Delay | 10 | 65 | 10 | 76 | ns |  |
| TCLTMV | Timer Output Delay |  | 60 |  | 75 | ns | 100 pF max |
| TCLRO | Reset Delay |  | 60 |  | 75 | ns |  |
| TCHOSV | Queue Status Dealy |  | 35 |  | 44 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| TAVCH | Address Valid to Clock High | 10 |  | 10 |  | ns |  |

MBL 80186 Chip-Select Timing Responses

| Symbol | Parameter | MBL 80186 ( 8 MHz ) |  | MBL 80186-6 ( 6 MHz ) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TCLCSV | Chip-Select Active Delay |  | 66 |  | 80 | ns |  |
| TCXCSX | Chip-Select Hold Time from Command Inactive | 35 |  | 35 |  | ns |  |
| TCHCSX | Chip-Select Inactive Delay | 5 | 35 | 5 | 47 | ns |  |

## A.C. CHARACTERISTICS (Continued)

MBL 80186 CLKIN Timing Requirements

| Symbol | Parameter | MBL 80186 (8 MHz) |  | MBL 80186-6 (6 MHz) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TCKIN | CLKIN Period | 62.5 | 250 | 83 | 250 | ns |  |
| TCKHL | CLKIN Fall Time |  | 10 |  | 10 | ns | 3.5 V to 1.0 V |
| TCKLH | CLKIN Rise Time |  | 10 |  | 10 | ns | 1.0 V to 3.5 V |
| TCLCK | CLKIN Low Time | 25 |  | 33 |  | ns | 1.5 V |
| TCHCK | CLKIN High Time | 25 |  | 33 |  | ns | 1.5 V |

MBL 80186 CLKOUT Timing Responses ( 200 pF load)

| Symbol | Parameter | MBL 80186 (8 MHz) |  | MBL 80186-6 (6 MHz) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TCICO | CLKIN to CLKOUT Skew |  | 50 |  | 62.5 | ns |  |
| TCLCL | CLKOUT Period | 125 | 500 | 167 | 500 | ns |  |
| TCLCH | CLKOUT Low Time | 1/2TCLCL-7.5 |  | 1/2TCLCL-7.5 |  | ns | 1.5 V |
| TCHCL | CLKOUT High Time | 1/2TCLCL-7.5 |  | 1/2TCLCL-7.5 |  | ns | 1.5 V |
| TCH1CH2 | CLKOUT Rise Time |  | 15 |  | 15 | ns | 1.0 V to 3.5 V |
| TCL2CL1 | CLKOUT Fall Time |  | 15 |  | 15 | ns | 3.5 V to 1.0 V |

MBL 80186 MBL 80186-6

## WAVEFORMS

MAJOR CYCLE TIMING


## WAVEFORMS (Continued)

MAJOR CYCLE TIMING (Continued)


## NOTES:

1. Following a Write cycle, the Local Bus is floated by the MBL 80186 only when the MBL 80186 enters a "Hold Acknowledge" state.
2. INTA occurs one clock later in iRMX-mode
3. Status inactive just prior to T 4 .

WAVEFORMS (Continued)


## WAVEFORMS (Continued)



## WAVEFORMS (Continued)

TIMER ON MBL 80186


## MBL 80186 INSTRUCTION TIMINGS

The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

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

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

All instructions which involve memory reference can require one (and in some cases, two) additional clocks above the minimum timings shown. This is due to the asynchronous nature of the handshake between the BIU and the Execution unit.

## INSTRUCTION SET SUMMARY



Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

## INSTRUCTION SET SUMMARY (Continued)

| FUNCTION | FORMAT |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Shaded areas indicate instructions not available in MBL 8086,88 microsystems.

## INSTRUCTION SET SUMMARY (Continued)



Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

## INSTRUCTION SET SUMMARY (Continued)



Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

## INSTRUCTION SET SUMMARY (Continued)



[^5]
## INSTRUCTION SET SUMMARY (Continued)

| FUNCTION | FORMAT |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PROCESSOR CONTROL |  |  |  |  |
| CLC = Clear carry | 11111000 |  | 2 |  |
| CMC = Complement carry | 11110101 |  | 2 |  |
| STC = Set carry | 11111001 |  | 2 |  |
| CLD = Clear direction | 11111100 |  | 2 |  |
| STD = Set direction | 11111101 |  | 2 |  |
| CLI = Clear interrupt | 11111010 |  | 2 |  |
| $\mathbf{S T I}=$ Set interrupt | 11111011 |  | 2 |  |
| HLT = Halt | 11110100 |  | 2 |  |
| WAIT = Wait | 10011011 |  | 6 | if $\overline{\text { test }}=0$ |
| LOCK = Bus lock prefix | 11110000 |  | 2 |  |
| ESC = Processor extension escape | 11011 TTT | mod LLL r/m | 6 |  |
| (TTT LLL are opcode to processor extension) |  |  |  |  |

Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

## FOOTNOTES

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

DISP follows 2nd byte of instruction (before data if required)
*except if $\bmod =00$ and $r / m=110$ then $E A=$ disp-high: disp-low.
NOTE:
ea calculation time is 4 Clock cycles for all modes, and is included in the execution times GIVEN WHENEVER APPROPRIATE.

## SEGMENT OVERRIDE PREFIX

$$
001 \text { reg } 110
$$

reg is assigned according to the following:

## Segment

reg
Register
00 ES
01 CS
10
SS
11
DS

REG is assigned according to the following table:

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

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

## PACKAGE ILLUSTRATION



## PACKAGE DIMENSIONS (Suffix -CV)



## PACKAGE ILLUSTRATION



## PACKAGE DIMENSION (Suffix -CR)

68-LEAD CERAMIC (METAL SEAL) REPEATED QUAD IN-LINE PACKAGE (CASE No.: RIT-68C-A01)


## MBL 8086 MBL 8086－2 MBL 8086－1

## NMOS 16－BIT MICROPROCESSOR

The Fujitsu MBL8086 high performance 16 －bit CPU is available in three clock rates： 5,8 and 10 MHz ．The CPU is implemented in N－Channel，depletion load，silicon gate technology，and packaged in a $40-\mathrm{pin}$ ceramic or plastic DIP． The MBL 8086 operates in both single processor and multiple processor configurations to achieve high performance levels．
－Direct Addressing Capability of 1 MByte of Memory
－Architecture Designed for Powerful Assembly Language and Efficient High Level Languages．
－ 14 Word by 16 －Bit Register Set with Symmetrical Operations
－ 24 Operand Addressing Modes
－Bit，Byte，Word，and Block Operations
－ 8 and 16－Bit Signed and Unsigned Arithmetic in Binary or Decimal Including Multiply and Divide
－Range of Clock Rates： 5 MHz for MBL 8086， 8 MHz for MBL 8086－2， 10 MHz for MBL 8086－1
－MULTibuS＊System Compatible Interface
－40－Pin DIP： Ceramic DIP（Suffix：－C） Plastic DIP（Suffix：－P）

Fig． 1 －BLOCK DIAGRAM


Fig．2－PIN CONFIGURATIONS

|  |  |  | MAX <br> MODE | $\left.\begin{array}{c} \text { MIN } \\ \text { MODE } \end{array}\right\}$ |
| :---: | :---: | :---: | :---: | :---: |
| GND 1 | 1 | 40 | $\mathrm{V}_{\mathrm{Cc}}$ |  |
| AD14 2 | 2 | 39 | $\square \mathrm{AD} 15$ |  |
| AD13 3 | 3 | 38 | 日A16／S3 |  |
| AD12－4 | 4 | 37 | $\square \mathrm{A} 17 / \mathrm{S} 4$ |  |
| AD11－5 | 5 | 36 | －A18／S5 |  |
| AD10－6 | 6 | 35 | $\square \mathrm{A} 19 / \mathrm{S6}$ |  |
| AD9 7 | 7 | 34 | 口В险／S7 |  |
| AD8－8 | 8 | 33 | $\square M N / \overline{M X}$ |  |
| AD7－9 | 9 | 32 | 日 $\overline{R D}$ |  |
| AD6－1 | $10 \begin{gathered} \text { MBL } \\ 8086 \end{gathered}$ | 31 | ПRQ／GTO | （HOLD） |
| AD5－1 | 11 | 30 | 口 $\overline{\mathrm{RQ}} / \overline{\mathrm{GT} 1}$ | （HLDA） |
| AD4－1 | 12 | 29 | 口ГOCK | （ $\overline{W R}$ ） |
| AD3 1 | 13 | 28 | －$\overline{\text { S2 }}$ | （M／E） |
| AD2 1 | 14 | 27 | －$\overline{\text { S1 }}$ | （DT／R） |
| AD1니 | 15 | 26 | 口So | （ $\overline{\mathrm{DEN}}$ ） |
| ADO－1 | 16 | 25 | 口OSO | （ALE） |
| NMI 1 | 17 | 24 | ПOS1 | （INTA） |
| INTR 1 | 18 | 23 | $\square \overline{\text { TEST }}$ |  |
| CLK－1 | 19 | 22 | 日READY |  |
| GND 2 | 20 | 21 | GRESET |  |

＊Trade Mark of Intel Corporation，USA
Portions Reprinted by permission of Intel Corporation


## TABLE 1 - PIN DESCRIPTION

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

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $A D_{15}-A D_{0}$ | 2-16,39 | I/O | Address Data Bus: These lines constitute the time multiplexed memory/IO address ( $\mathrm{T}_{1}$ ) and data ( $T_{2}, T_{3}, T_{W}, T_{4}$ ) bus. $A_{0}$ is analogous to $\overline{B H E}$ for the lower byte of the data bus, pins $D_{7}-D_{0}$. It is LOW during $T_{1}$ when a byte is to be transferred on the lower portion of the bus in memory or I/O operations. Eight-bit oriented devices tied to the lower half would normally use $A_{0}$ to condition chip select functions. (See $\overline{\mathrm{BHE}}$.) These lines are active HIGH and float to 3 -state OFF during interrupt acknowledge and local bus "hold acknowledge." |
| $\begin{aligned} & \mathrm{A}_{19} / \mathrm{S}_{6}, \\ & \mathrm{~A}_{18} / \mathrm{S}_{5}, \\ & \mathrm{~A}_{17} / \mathrm{S}_{4}, \\ & \mathrm{~A}_{16} / \mathrm{S}_{3} \end{aligned}$ | 35-38 | 0 | Address/Status: During $\mathrm{T}_{1}$ these are the four most significant address lines for memory operations. During I/O operations these lines are LOW. During memory and I/O operations, status information is available on these lines during $T_{2}, T_{3}, T_{W}$, and $T_{4}$. The status of the interrupt enable FLAG bit $\left(S_{5}\right)$ is updated at the beginning of each CLK cycle. $\mathrm{A}_{17} / \mathrm{S}_{4}$ and $\mathrm{A}_{16} / \mathrm{S}_{3}$ are encoded as shown. <br> This information indicates which relocation register is presently being used for data accessing. <br> These lines float to 3 -state OFF during local bus "hold acknowledge." |
| $\overline{\mathrm{BHE}} / \mathrm{S}_{7}$ | 34 | 0 | Bus High Enable/Status: During $\mathrm{T}_{1}$ the bus high enable signal ( $\overline{\mathrm{BHE}}$ ) should be used to enable data onto the most significant half of the data bus, pins $D_{15}-D_{8}$. Eight-bit oriented devices tied to the upper half of the bus would normally use $\overline{\mathrm{BHE}}$ to condition chip select functions. $\overline{\mathrm{BHE}}$ is LOW during $\mathrm{T}_{1}$ for read, write, and interrupt acknowledge cycles when a byte is to be transferred on the high portion of the bus. The $\mathrm{S}_{7}$ status information is available during $T_{2}, T_{3}$, and $T_{4}$. The signal is active LOW, and floats of 3 -state OFF in "hold." It is LOW during $T_{1}$ for the first interrupt acknowledge cycle. |
| $\overline{\mathrm{RD}}$ | 32 | 0 | Read: Read strobe indicates that the processor is performing a memory or I/O read cycle, depending on the state of the $\mathrm{S}_{2}$ pin. This signal is used to read devices which reside on the MBL 8086 local bus. $\overline{\mathrm{RD}}$ is active LOW during $T_{2}, T_{3}$ and $T_{W}$ of any read cycle, and is guaranteed to remain HIGH in $\mathrm{T}_{2}$ until the MBL 8086 local bus has floated. <br> This signal floats to 3 -state OFF in "hold acknowledge." |
| READY | 22 | 1 | READY: is the acknowledgement from the addressed memory or I/O device that it will complete the data transfer. The READY signal from memory/10 is synchronized by the MBL 8284A Clock Generator to form READY. This signal is active HIGH. The MBL 8086 READY input is not synchronized. Correct operation is not guaranteed if the setup and hold times are not met. |
| INTR | 18 | 1 | Interrupt Request: is a level triggered input which is sampled during the last clock cycle of each instruction to determine if the processor should enter into an interrupt acknowledge operation. A subroutine is vectored to via an interrupt vector lookup table located in system memory. It can be internally masked by software resetting the interrupt enable bit. INTR is internally synchronized. This signal is active HIGH. |
| $\overline{\text { TEST }}$ | 23 | 1 | TEST: Input is examined by the "Wait" instruction. If the TEST input is LOW execution continues, otherwise the processor waits in an "Idle" state. This input is synchronized internally during each clock cycle on the leading edge of CLK. |

TABLE 1 - PIN DESCRIPTION (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :--- | :---: | :---: | :--- |
| NMI | 17 | I | Non-maskable interrupt: an edge triggered input which causes a type 2 interrupt. A <br> subroutine is vectored to via an interrupt vector lookup table located in system memory. <br> NMI is not maskable internally by software. A transition from a LOW to HIGH initiates the <br> interrupt at the end of the current instruction. This input is internally synchronized. |
| RESET | 21 | I | Reset: causes the processor to immediately terminate its present activity. The signal must <br> be active HIGH for at least four clock cycles. It restarts execution, as described in the <br> instruction Set description, when RESET returns LOW. RESET is internally synchrnoized. |
| CLK | 19 | I | Clock: provides the basic timing for the processor and bus controller. It is asymmetric <br> with a 33\% duty cycle to provide optimized internal timing. |
| $\mathrm{V}_{\mathrm{CC}}$ | 40 |  | VCC: +5V power supply pin. |
| GND | 1,20 |  | Ground |
| $\mathrm{MN} / \overline{\mathrm{MX}}$ | 33 | 1 | Minimum/Maximum: indicates what mode the processor is to operate in. The two modes <br> are discussed in the following sections. |

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

| $\overline{\mathrm{S}_{2}}, \overline{\mathrm{~S}_{1}}, \overline{\mathrm{~S}_{0}}$ | 26-28 | 0 | Status: active during $T_{4}, T_{1}$, and $T_{2}$ and is returned to the passive state $(1,1,1)$ during $T_{3}$ or during $T_{w}$ when READY is HIGH. This status is used by the MBL 8288 Bus Controller to generate all memory and I/O access control signals. Any change by $\overline{\mathrm{S}_{2}}, \overline{\mathrm{~S}_{1}}$, or $\overline{\mathrm{S}_{0}}$ during $\mathrm{T}_{4}$ is used to indicate the beginning of a bus cycle, and the return to the passive state in $\mathrm{T}_{3}$ or $\mathrm{T}_{\mathrm{w}}$ is used to indicate the end of a bus cycle. <br> These signals float to 3 -state OFF in "hold acknowledge." These status lines are encoded as shown. |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}_{0}, \\ & \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}_{1} \end{aligned}$ | -30, 31 | I/O | Request/Grant: pins are used by other local bus masters to force the processor to release the local bus at the end of the processor's current bus cycle. Each pin is bidirectional with $\overline{\mathrm{RO}} / \overline{\mathrm{GT}}_{0}$ having higher priority than $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}_{1} . \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ has an internal pull-up resistor so may be left unconnected. The request/grant sequence is as follows (see Figure 9): <br> 1. A pulse of 1 CLK wide from another local bus master indicates a local bus request ('hold") to the MBL 8086 (pulse 1). <br> 2. During a $T_{4}$ or $T_{1}$ clock cycle, a pulse 1 CLK wide from the MBL 8086 to the requesting master (pulse 2), indicates that the MBL 8086 has allowed the local bus to float and that it will enter the "hold acknowledge" state at the next CLK. The CPU's bus interface unit is disconnected logically from the local bus during "hold acknowledge." <br> 3. A pulse 1 CLK wide from the requesting master indicates to the MBL 8086 (pulse 3) that the "hold" request is about to end and that the MBL 8086 can reclaim the local bus at the next CLK. <br> Each master-master exchange of the local bus is a sequence of 3 pulses. There must be one dead CLK cycle after each bus exchange. Pulses are active LOW. <br> If the request is made while the CPU is performing a memory cycle, it will release the local bus during $\mathrm{T}_{4}$ of the cycle when all the following conditions are met: <br> 1. Request occurs on or before $T_{2}$. <br> 2. Current cycle is not the low byte of a word (on an odd address). <br> 3. Current cycle is not the first acknowledge of an interrupt acknowledge sequence. <br> 4. A locked instruction is not currently executing. |

TABLE 1 - PIN DESCRIPTION (Continued)

| Symbol | Pin No. | Type | Name and Function |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | If the local bus is idle when the request is made the two possible events will follow: <br> 1. Local bus will be released during the next clock. <br> 2. A memory cycle will start within 3 clocks. Now the four rules for a currently active memory cycle apply with condition number 1 already satisfied. |  |  |  |
| $\overline{\text { LOCK }}$ | 29 | 0 | $\overline{\text { LOCK: }}$ output indicates that other system bus masters are not to gain control of the system bus while $\overline{\text { LOCK }}$ is active LOW. The $\overline{\text { LOCK }}$ signal is activated by the "LOCK" prefix instruction and remains active until the completion of the next instruction. This signal is active LOW, and floats to 3 -state OFF in "hold acknowledge." |  |  |  |
| $\mathrm{OS}_{1}, \mathrm{QS}_{0}$ | 24, 25 | 0 | Queue Status: The queue status is valid during the CLK cycle after which the queue operation is performed. <br> $\mathrm{QS}_{1}$ and $\mathrm{OS}_{0}$ provide status to allow external tracking of the internal MBL 8086 instruction queue. | $\mathrm{QS}_{1}$ <br> 0 (LOW) <br> 0 <br> 1 (HIGH) <br> 1 |  | Characteristics <br> No Operation <br> First Byte of Op <br> Code from Queue <br> Empty the Queue <br> Subsequent Byte <br> from Queue |

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

| $\mathrm{M} / \overline{\mathrm{IO}}$ | 28 | 0 | Status line: logically equivalent to $\mathrm{S}_{2}$ in the maximum mode. It is used to distinguish a memory access from an I/O access. $\mathrm{M} / \overline{\mathrm{IO}}$ becomes valid in the $\mathrm{T}_{4}$ preceding a bus cycle and remains valid until the final $\mathrm{T}_{4}$ of the cycle ( $\mathrm{M}=\mathrm{HIGH}, \overline{\mathrm{IO}}=\mathrm{LOW}$ ). M/ $\overline{\mathrm{IO}}$ floats to 3 -state OFF in local bus "hold acknowledge." |
| :---: | :---: | :---: | :---: |
| $\overline{W R}$ | 29 | 0 | Write: indicates that the processor is performing a write memory or write I/O cycle, depending on the state of the $M / \overline{\mathrm{IO}}$ signal. $\overline{\mathrm{WR}}$ is active for $T_{2}, T_{3}$ and $T_{W}$ of any write cycle. It is active LOW, and floats to 3 -state OFF in local bus "hold acknowledge." |
| $\overline{\text { NTA }}$ | 24 | 0 | $\overline{\text { INTA }}$ is used as a read strobe for interrupt acknowledge cycles. It is active LOW during $\mathrm{T}_{2}$, $T_{3}$, and $T_{w}$ of each interrupt acknowledge cycle. |
| ALE | 25 | 0 | Address Latch Enable: provided by the processor to latch the address into the MBL 8282/8283 address latch. It is a HIGH pulse active during $\mathrm{T}_{1}$ of any bus cycle. Note that ALE is never floated. |
| DT/ $\bar{R}$ | 27 | 0 | Data Transmit/Receive: needed in minimum system that desires to use an MBL 8286/8287 data bus transceiver. It is used to control the direction of data flow through the transceiver. Logically $D T / \bar{R}$ is equivalent to $\overline{S_{1}}$ in the maximum mode, and its timing is the same as for $\mathrm{M} / \overline{\mathrm{OO}}$. ( $\mathrm{T}=\mathrm{HIGH}, \overline{\mathrm{R}}=$ LOW). This signal floats to 3 -state OFF in local bus 'hold acknowledge." |
| $\overline{\text { DEN }}$ | 26 | 0 | Date Enable: provided as an output enable for the MBL 8286/8287 in a minimum system which uses the transceiver. $\overline{\mathrm{DEN}}$ is active LOW during each memory and I/O access and for INTA cycles. For a read or INTA cycle it is active from the middle of $T_{2}$ until the middle of $T_{4}$, while for a write cycle it is active from the beginning of $T_{2}$ until the middle of $T_{4}$ $\overline{\text { DEN }}$ floats to 3 -state OFF in local bus "hold acknowledge." |
| HOLD, HLDA | 31, 30 | 1/O | HOLD: indicates that another master is requesting a local bus"hold." To be acknowledged, HOLD must be active HIGH. The processor receiving the "hold" request will issue HLDA (HIGH) as an acknowledgement in the middle of a $T_{4}$ or $T_{1}$ clock cycle. Simultaneous with the issuance of HLDA the processor will float the local bus and control lines. After HOLD is detected as being LOW, the processor will LOWer the HLDA, and when the processor needs to run another cycle, it will again drive the local bus and control lines. <br> The same rules as for $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ apply regarding when the local bus will be released. <br> HOLD is not an asynchronous input. External synchronization should be provided if the system cannot otherwise guarantee the setup time. |

## FUNCTIONAL DESCRIPTION

## GENERAL OPERATION

The internal functions of the MBL 8086 processor are partitioned logically into two processing units. The first is the Bus Interface Unit (BIU) and the second is the Execution Unit (EU) as shown in the block diagram of Figure 1.
These units can interact directly but for the most part perform as separate asynchronous operational processors. The bus interface unit provides the functions related to instruction fetching and queuing, operand fetch and store, and address relocation. This unit also provides the basic bus control. The overlap of instruction pre-fetching provided by this unit serves to increase processor performance through improved bus bandwidth utilization. Up to 6 bytes of the instruction stream can be queued while waiting for decoding and execution.

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

The execution unit receives pre-fetched instructions from the BIU queue and provides un-relocated operand addresses to the BIU. Memory operands are passed through the BIU for processing by the EU, which passes results to the BIU for storage. See the Instruction Set description for further register set and architectural descriptions.

## MEMORY ORGANIZATION

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


#### Abstract

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


Word (16-bit) operands can be located on even or odd address boundaries and are thus not constrained to even boundaries as is the case in many 16 -bit computers. For address and data operands, the least significant byte of the word is stored in the lower valued address location and the most significant byte in the next higher address location. The BIU automatically performs the proper number of memory accesses, one if the word operand is on an even byte boundary and two if it is on an odd byte boundary. Except for the performance penalty, this double access is transparent to the software. This performance penalty does not occur for instruction fetches, only word operands.

Physically, the memory is organized as a high bank $\left(D_{15}-D_{8}\right)$ and a low bank ( $D_{7}-D_{0}$ ) of 512 K 8 -bit bytes addressed in parallel by the processor's address lines $\mathrm{A}_{19}-\mathrm{A}_{1}$. Byte data with even addresses is transferred on the $D_{7}-D_{0}$ bus lines while odd addressed byte data ( $A_{0}$ HIGH) is transferred on the $D_{15}-D_{8}$ bus lines. The processor provides two enable signals, $\overline{\mathrm{BHE}}$ and $\mathrm{A}_{0}$, to selectively allow reading from or writing into either an odd byte location, even byte location, or both. The instruction stream is fetched from memory as words and is addressed internally by the processor to the byte level as necessary.
In referencing word data the BIU requires one or two memory cycles depending on whether or not the starting byte of the word is on an even or odd address, respectively. Consequently, in referencing word operands

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

performance can be optimized by locating data on even address boundaries. This is an especially useful technique for using the stack, since odd address references to the stack may adversely affect the context switching time for interrupt processing or task multiplexing.
Certain locations in memory are reserved for specific CPU operations (see Figure 3b). Locations from address FFFFOH through FFFFFH are reserved for operations including a jump to the initial program loading routine. Following RESET, the CPU will always begin execution at location FFFFOH where the jump must be. Locations 00000 H through 003FFH are reserved for interrupt operations. Each of the 256 possible interrupt types has its service routine pointed to by a 4 -byte pointer element consisting of a 16 -bit segment address and a 16 bit offset address. The pointer elements are assumed to have been stored at the respective places in reserved memory prior to occurrence of interrupts.

## MINIMUM AND MAXIMUM MODE

The requirements for supporting minimum and maximum MBL 8086 systems are sufficiently different that they cannot be done efficiently with 40 uniquely defined pins. Consequently, the MBL 8086 is equipped with a strap pin (MN/ $\overline{M X}$ ) which defines the system configuration. The definition of a certain subset of the pins changes dependent on the condition of the strap pin. When the $M N / \overline{M X}$. pin is strapped to GND, the MBL 8086 treats pins 24 through 31 in maximum mode. An MBL 8288 bus controller interprets status information coded into $\overline{\mathrm{S}_{0}}, \overline{\mathrm{~S}_{1}}, \overline{\mathrm{~S}_{2}}$ to generate bus timing and control signals compatible with the MULTIBUS* architecture. When the $M N / \overline{M X}$ pin is strapped to $V_{c c}$, the MBL 8086 generates bus control signals itself on pins 24 through 31 , as shown in parentheses in Figure 2. Examples of minimum mode and maximum mode systems are shown in Figure 4.

Fig. 3a - MEMORY ORGANIZATION


Fig. 3b - RESERVED MEMORY LOCATIONS


Fig. 4a - MINIMUM MODE MBL 8086 TYPICAL CONFIGURATION EXAMPLE


FUJITSU
MBL 8086
MBL 8086-2
MBL 8086-1

Fig. 4b - MAXIMUM MODE MBL 8086 TYPICAL CONFIGURATION EXAMPLE


## BUS OPERATION

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

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

During $T_{1}$ of any bus cycle the ALE (Address Latch Enable) signal is emitted (by either the processor or the MBL 8288 bus controller, depending on the MN/ $\overline{M X}$ strap). At the trailing edge of this pulse, a valid address and certain status information for the cycle may be latched.
Status bits $\overline{\mathrm{S}_{0}}, \overline{\mathrm{~S}_{1}}$, and $\overline{\mathrm{S}_{2}}$ are used, in maximum mode, by the bus controller to identify the type of bus transaction according to the following table:

| $\overline{\mathbf{S}_{2}}$ | $\overline{\mathbf{S}_{\mathbf{1}}}$ | $\overline{\mathbf{S}_{\mathbf{0}}}$ | CHARACTERISTICS |
| :--- | :---: | :--- | :--- |
| 0 (LOW) | 0 | 0 | Interrupt Acknowledge |
| 0 | 0 | 1 | Read I/O |
| 0 | 1 | 0 | Write I/O |
| 0 | 1 | 1 | Halt |
| $1(\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 $\mathrm{S}_{3}$ through $\mathrm{S}_{7}$ are multiplexed with high-order address bits and the $\overline{B H E}$ signal, and are therefore valid during $T_{2}$ through $T_{4} . S_{3}$ and $S_{4}$ indicate which segment register (see Instruction Set description) was used for this bus cycle informing the address, according to the following table:

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

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

## I/O ADDRESSING

In the MBL 8086 I/O operations can addressed up to a maximum of 64 K I/O byte registers or 32 K I/O word registers. The I/O address appears in the same format as the memory address on bus lines $A_{15}-A_{0}$. The address lines $A_{19}-A_{16}$ are zero in I/O operations. The variable I/O instructions which use register DX as a pointer have full address capability while the direct I/O instructions directly address one or two of the 256 I/O byte locations in page 0 of the $\mathrm{I} / \mathrm{O}$ address space.
I/O ports are addressed in the same manner as memory locations. Even addressed bytes are transferred on the $D_{7}-D_{0}$ bus lines and odd addressed bytes on $D_{15}-D_{8}$. Care must be taken to assure that each register within an 8 -bit peripheral located on the lower portion of the bus be addressed as even.

Fig. 5 - BASIC SYSTEM TIMING


## EXTERNAL INTERFACE

## PROCESSOR RESET AND INITIALIZATION

Processor initialization or start up is accomplished with activation (HIGH) of the RESET pin. The MBL 8086 RESET is required to be HIGH for greater than 4 CLK cycles. The MBL 8086 will terminate operations on the high-going edge of RESET and will remain dormant as long as RESET is HIGH. The low-going transition of RESET triggers an internal reset sequence for approximately 10 CLK cycles. After this interval the MBL 8086 operates normally beginning with the instruction in absolute location FFFFOH (see Figure 3b). The details of this operation are specified in the Instruction Set description of the Family User's Manual. The RESET input is internally synchronized to the processor clock. At initialization the HIGH-to-LOW transition of RESET must occur no sooner than $50 \mu$ s after power-up, to allow complete initialization of the MBL 8086.
NMI may not be asserted prior to the 2nd CLK cycle following the end of RESET.

## INTERRUPT OPERATIONS

Interrupt operations fall into two classes; software or hardware initiated. The software initiated interrupts and software aspects of hardware interrupts are specified in the Instruction Set description. Hardware interrupts can be classified as non-maskable or maskable.
Interrupts result in a transfer or control to a new program location. A 256 -element table containing address pointers to the interrupt service program locations resides in absolute locations 0 through 3FFH (see Figure 3b), which are reserved for this purpose. Each element in the table is 4 bytes in size and corresponds to an interrupt "type". An
interrupting device supplies an 8-bit type number, during the interrupt acknowledge sequence, which is used to "vector" through the appropriate element to the new interrupt service program location.

## NON-MASKABLE INTERRUPT (NMI)

The processor provides a single non-maskable interrupt pin (NMI) which has higher priority than the maskable interrupt request pin (INTR). A typical use would be to activate a power failure routine. The NMI is edge-triggered on a LOW-to-HIGH transition. The activation of this pin causes a type 2 interrupt. (See instruction Set description.)
NMI is required to have a duration in the HIGH state of greater than two CLK cycles, but is not required to be synchronized to the clock. Any high-going transition of NMI is latched on-chip and will be serviced at the end of the current instruction or between whole moves of a block-type instruction. Worst case response to NMI would be for multiply, divide, and variable shift instructions. There is no specification on the occurrence of the low-going edge; it may occur before, during, or after the servicing of NMI. Another high-going edge triggers another response if it occurs after the start of the NMI procedure. The signal must be free of logical spikes in general and be free of bounces on the low-going edge to avoid triggering extraneous responses.

## MASKABLE INTERRUPT (INTR)

The MBL 8086 provides a single interrupt request input (INTR) which can be masked internally by software with the resetting of the interrupt enable FLAG status bit. The

Fig. 6 - INTERRUPT ACKNOWLEDGE SEQUENCE

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

During the response sequence (figure 6) the processor excutes two successive (back-to-back) Interrupt acknowledge cycles. The MBL 8086 emits the $\overline{\text { LOCK }}$ signal from $\mathrm{T}_{2}$ of the first bus cycle until $\mathrm{T}_{2}$ of the second. A local bus "hold" request will not be honored until the end of the second bus cycle. In the second bus cycle a byte is fetched from the external Interrupt system (e.g., MBL 8259A PIC) which idetifies the source (type) of the Interrupt. This byte is multiplied by four and used as a pointer into the interrupt vector lookup table. An INTR signal left HIGH will be continually responded to within the limitations of the enable bit and sample period. The INTERRUPT RETURN instruction includes a FLAGS pop which returns the status of the original interrupt enable bit when it restores the FLAGS.

## HALT

When a software "HALT" instruction is executed the processor indicates that it is entering the "HALT" state in one of two ways depending upon which mode is strapped. In minimum mode, the processor issues one ALE with no qualifying bus control signals. In Maximum Mode, the processor issues appropriate HALT status on $\overline{\mathrm{S}}_{2}, \overline{\mathrm{~S}}_{1}, \overline{\mathrm{~S}}_{0}$ and the MBL 8288 bus controller issues one ALE. The MBL 8086 will not leave the "HALT" state when a local bus "hold" is entered while in "HALT". In this case, the processor reissues the HALT indicator. An interrupt request or RESET will force the MBL 8086 out of the "HALT" state.

## READ/MODIFY/WRITE (SEMAPHORE) OPERATIONS VIA LOCK

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

## EXTERNAL SYNCHRONIZATION VIA TEST

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

## BASIC SYSTEM TIMING

Typical system configurations for the processor operating in minimum mode and in maximum mode are shown in Figures 4 a and 4b, respectively. In minimum mode, the $\mathrm{MN} / \overline{\mathrm{MX}}$ pin is strapped to $\mathrm{V}_{\mathrm{CC}}$ and the processor emits bus control signals in a manner similar to the 8085 . In maximum mode, the $M N / \overline{M X}$ pin is strapped to $V_{S S}$ and the processor emits coded status information which the MBL 8288 bus controller uses to generate MULTIBUS* compatible bus control signals. Figure 5 illustrates the signal timing relationships.

Fig. 7 - MBL 8086 REGISTER MODEL

| AX | AH | AL |
| :---: | :---: | :---: |
| $B X$ | BH | BL |
| CX | CH | CL |
| DX | DH | DL |

ACCUMULATOR
BASE
COUNT
DATA


STACK POINTER BASE POINTER SOURCE INDEX DESTINATION INDEX

INSTRUCTION POINTER STATUS FLAGS

CODE SEGMENT
DATA SEGMENT STACK SEGMENT EXTRA SEGMENT

[^6]
## SYSTEM TIMING - MINIMUM SYSTEM

The read cycle begins in $\mathrm{T}_{1}$ with the assertion of the Address Latch Enable (ALE) signal. The trailing (lowgoing) edge of this signal is used to latch the address information, which is valid on the local bus at this time, into the MBL 8282/8283 latch. The $\overline{\mathrm{BHE}}$ and $\mathrm{A}_{0}$ signals address the low, high, or both bytes. From $T_{1}$ to $T_{4}$ the $\mathrm{M} / \overline{\mathrm{OO}}$ signal indicates a memory or $\mathrm{I} / \mathrm{O}$ operation. At $\mathrm{T}_{2}$ the address is removed from the local bus and the bus goes to a high impedance state. The read control signal is also asserted at $T_{2}$. The read ( $\overline{\mathrm{RD}}$ ) signal causes the addressed device to enable its data bus drivers to the local bus. Some time later valid data will be available on the bus and the addressed device will drive the READY line HIGH. When the processor returns the read signal to a HIGH level, the addressed device will again 3 -state its bus drivers. If a transceiver (MBL 8286/8287) is required to buffer the MBL 8086 local bus, signal DT/ $\bar{R}$ and $\overline{D E N}$ are provided by the MBL 8086.
A write cycle also begins with the assertion of ALE and the emission of the address. The $\mathrm{M} / \overline{\mathrm{IO}}$ signal is again asserted to indicate a memory or I/O write operation. In the $T_{2}$ immediately following the address emission the processor emits the data to be written into the addressed location. This data remains valid until the middle of $T_{4}$. During $T_{2}, T_{3}$ and $T_{W}$ the processor asserts the write control signal. The write ( $\overline{W R}$ ) signal becomes active at the beginning of $T_{2}$ as opposed to the read which is delayed somewhat into $T_{2}$ to provide time for the bus to float.
The $\overline{\mathrm{BHE}}$ and $\mathrm{A}_{0}$ signals are used to select the proper byte(s) of the memory/IO word to be read or written according to the following table:

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

I/O ports are addressed in the same manner as memory location. Even addressed bytes are transferred on the
$D_{7}-D_{0}$ bus lines and odd addressed bytes on $D_{15}-D_{8}$.
The basic difference between the interrupt acknowledge cycle and a read cycle is that the interrupt acknowledge signal ( $\overline{\text { INTA }}$ ) is asserted in place of the read ( $\overline{\mathrm{RD}}$ ) signal and the address bus is floated. (See Figure 6.) In the second of two successive INTA cycles, a byte of information is read from bus lines $D_{7}-D_{0}$ as supplied by the interrupt system logic (i.e., MBL 8259A Priority Interrupt Controller). This byte identifies the source (type) of the interrupt. It is multiplied by four and used as a pointer into an interupt vector lookup table, as described earlier.

## BUS TIMING - MEDIUM SIZE SYSTEMS

For medium size systems the $M N / \overline{M X}$ pin is connected to GND and the MBL 8288 Bus Controller is added to the system as well as an MBL 8282/8283 latch for latching the system address, and a MBL 8286/8287 transceiver to allow for bus loading greater than the MBL 8086 is capable of handling. Signals ALE, DEN, and DT/ $\bar{R}$ are generated by the MBL 8288 instead of the processor in this configuration although their timing remains relatively the same. The MBL 8086 status outputs ( $\overline{\mathrm{S}}_{2}, \overline{\mathrm{~S}}_{1}$, and $\overline{\mathrm{S}}_{0}$ ) provide type-of-cycle information and become MBL 8288 inputs. This bus cycle information specifies read (code, data, or I/O), write (data or I/O), interrupt acknowledge, or software halt. The MBL 8288 thus issues control signals specifying memory read or write, I/O read or write, or interrupt acknowledge. The MBL 8288 provides two types of write strobes, normal and advanced, to be applied as required. The normal write strobes have data valid at the leading edge of write. The advanced write strobes have the same timing as read strobes, and hence data isn't valid at the leading edge of write. The MBL 8286/8287 transceiver receives the usual $T$ and $\overline{\mathrm{OE}}$ inputs from the MBL 8288's $D T / \bar{R}$ and DEN.
The pointer into the interrupt vector table, which is passed during the second INTA cycle, can derive from an MBL 8259A located on either the local bus or the system bus. If the master MBL 8259A Priority Interrupt Controller is positioned on the local bus, a TTL gate is required to disable the MBL 8286/8287 transceiver when reading from the master MBL 8259A during the interrupt acknowledge sequence and software "poll".

MBL 8086
MBL 8086-2
MBL 8086-1

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias
$0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature............$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin with
Respect to Ground . . . . . . . . . . . . . . . -0.5 to +7 V
Power Dissipation 2.5 Watt

* NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

$$
\begin{array}{lll}
\text { D.C. CHARACTERISTICS } & \text { (MBL 8086: } & \left.V_{C C}=5 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}\right) \\
& (\mathrm{MBL} 8086-2: & \left.V_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{A}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}\right) \\
& (\mathrm{MBL} 8086-1: & V_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{A}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \text { ) }
\end{array}
$$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{cc}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{cc}}$ | Power Supply Current: MBL 8086 <br> MBL 8086-2 <br> MBL 8086-1 |  | $\begin{aligned} & 340 \\ & 350 \\ & 360 \end{aligned}$ | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $I_{L I}$ | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\text {LO }}$ | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $\mathrm{V}_{\mathrm{CL}}$ | Clock Input Low Voltage | -0.5 | +0.6 | V |  |
| $\mathrm{V}_{\mathrm{CH}}$ | Clock Input High Voltage | 3.9 | $\mathrm{V}_{\mathrm{cc}}+1.0$ | V |  |
| $\mathrm{C}_{\text {IN }}$ | Capacitance of Input Buffer (All input except $\left.\mathrm{AD}_{0}-\mathrm{AD}_{15}, \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}\right)$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{10}$ | Capacitance of I/O Buffer $\left(\mathrm{AD}_{0}-\mathrm{AD}_{15}, \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}\right)$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

## A.C. CHARACTERISTICS <br> (MBL 8086: $\quad V_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ ) <br> (MBL 8086-2: $\quad V_{C C}=5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ ) <br> (MBL 8086-1: $\quad \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ )

MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS

| Symbol | Parameter | MBL 8086 |  | MBL 8086-2 |  | MBL 8086-1 <br> (Preliminary) |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TCLCL | CLK Cycle Period | 200 | 500 | 125 | 500 | 100 | 500 | ns |  |
| TCLCH | CLK Low Time | 118 |  | 68 |  | 53 |  | ns |  |
| TCHCL | CLK High Time | 69 |  | 44 |  | 39 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 |  | 10 |  | 10 | ns | $\begin{aligned} & \text { From } 1.0 \mathrm{~V} \\ & \text { to } 3.5 \mathrm{~V} \\ & \hline \end{aligned}$ |
| TCL2CL1 | CLK Fall Time |  | 10 |  | 10 |  | 10 | ns | $\begin{aligned} & \text { From } 3.5 \mathrm{~V} \\ & \text { to } 1.0 \mathrm{~V} \\ & \hline \end{aligned}$ |
| TDVCL | Data in Setup Time | 30 |  | 20 |  | 5 |  | ns |  |
| TCLDX | Data in Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TR1VCL | RDY Setup Time into MBL 8284A (See Notes 1, 2) | 35 |  | 35 |  | 35 |  | ns |  |
| TCLR1X | RDY Hold Time into MBL 8284A (See Notes 1, 2) | 0 |  | 0 |  | 0 |  | ns |  |
| TRYHCH | READY Setup Time into MBL 8086 | 118 |  | 68 |  | 53 |  | ns |  |
| TCHRYX | READY Hold Time into MBL 8086 | 30 |  | 20 |  | 20 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 3) | -8 |  | -8 |  | -10 |  | ns |  |
| THVCH | HOLD Setup Time | 35 |  | 20 |  | 20 |  | ns |  |
| TINVCH | INTR, NMI, TEST Setup Time (See Note 2) | 30 |  | 15 |  | 15 |  | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 |  | 20 |  | 20 | ns | $\begin{array}{\|l\|} \hline \text { From } 0.8 \mathrm{~V} \\ \text { to } 2.0 \mathrm{~V} \\ \hline \end{array}$ |
| TIHIL | Input Fall Time (Except CLK) |  | 12 |  | 12 |  | 12 | ns | $\begin{aligned} & \text { From } 2.0 \mathrm{~V} \\ & \text { to } 0.8 \mathrm{~V} \\ & \hline \end{aligned}$ |

## A.C. CHARACTERISTICS (Continued)

timing responses

| Symbol | Parameter | MBL 8086 |  | MBL 8086-2 |  | MBL 8086-1 (Preliminary) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TCLAV | Address Valid Delay | 10 | 110 | 10 | 60 | 10 | 50 | ns |  |
| TCLAX | Address Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 80 | TCLAX | 50 | 10 | 40 | ns |  |
| TLHLL | ALE Width | TCLCH-20 |  | TCLCH-10 |  | TCLCH-10 |  | ns |  |
| TCLLH | ALE Active Delay |  | 80 |  | 50 |  | 40 | ns |  |
| TCHLL | ALE Inactive Delay |  | 85 |  | 55 |  | 45 | ns |  |
| TLLAX | Address Hold Time to ALE Inactive | TCHCL-10 |  | TCHCL-10 |  | TCHCL-10 |  | ns |  |
| TCLDV | Data Valid Delay | 10 | 110 | 10 | 60 | 10 | 50 | ns |  |
| TCHDX | Data Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TWHDX | Data Hold Time After $\overline{W R}$ | TCLCH-30 |  | TCLCH-30 |  | TCLCH-25 |  | ns |  |
| TCVCTV | Control Active Delay 1 | 10 | 110 | 10 | 70 | 10 | 50 | ns |  |
| TCHCTV | Control Active Delay 2 | 10 | 110 | 10 | 60 | 10 | 45 | ns | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=20-100 \mathrm{pF} \\ & \text { for all } \end{aligned}$ |
| TCVCTX | Control Inactive Delay | 10 | 110 | 10 | 70 | 10 | 50 | ns | Outputs (in addition to |
| TAZRL | Address Float to READ Active | 0 |  | 0 |  | 0 |  | ns | MBL 8086 self-load) |
| TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 10 | 165 | 10 | 100 | 10 | 70 | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 150 | 10 | 80 | 10 | 60 | ns |  |
| TRHAV | $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TCLCL-45 |  | TCLCL-40 |  | TCLCL-35 |  | ns |  |
| TCLHAV | HLDA Valid Delay | 10 | 160 | 10 | 100 | 10 | 60 | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Width | 2TCLCL-75 |  | 2TCLCL-50 |  | 2TCLCL-40 |  | ns |  |
| TWLWH | $\overline{\text { WR Width }}$ | 2TCLCL-60 |  | 2TCLCL-40 |  | 2TCLCH-35 |  | ns |  |
| TAVAL | Address Valid to ALE Low | TCLCH-60 |  | 「CLCH-40 |  | TCLCH-35 |  | ns |  |
| TOLOH | Output Rise Time |  | 20 |  | 20 |  | 20 | ns | $\begin{aligned} & \text { From } 0.8 \mathrm{~V} \text { to } \\ & 2.0 \mathrm{~V} \end{aligned}$ |
| TOHOL | Output Fall Time |  | 12 |  | 12 |  | 12 | ns | From 2.0 V to 0.8 V |

## NOTES:

1. Signal at MBL 8284A 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 ).

A.C. TESTING: INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC " 1 " AND 0.45 V FOR A LOGIC " 0 " TIMING MEASUREMENTS ARE MADE AT 1.5 V FOR BOTH A LOGIC " 1 " AND " 0 ".
a.c. testing load circuit

$C_{\text {L }}$ : INCLUDES JIG CAPACITANCE

WAVEFORMS


WAVEFORMS (Continued)


## A.C. CHARACTERISTICS

MAX MODE SYSTEM (USING MBL 8288 BUS CONTROLLER)
TIMING REQUIREMENTS

| Symbol | Parameter | MBL 8086 |  | MBL 8086-2 |  | MBL 8086-1 <br> (Preliminary) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TCLCL | CLK Cycle Period | 200 | 500 | 125 | 500 | 100 | 500 | ns |  |
| TCLCH | CLK Low Time | 118 |  | 68 |  | 53 |  | ns |  |
| TCHCL | CLK High Time | 69 |  | 44 |  | 39 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 |  | 10 |  | 10 | ns | $\begin{aligned} & \text { From } 1.0 \mathrm{~V} \text { to } \\ & 3.5 \mathrm{~V} \end{aligned}$ |
| TCL2CL1 | CLK Fall Time |  | 10 |  | 10 |  | 10 | ns | $\begin{aligned} & \text { From } 3.5 \mathrm{~V} \text { to } \\ & 1.0 \mathrm{~V} \end{aligned}$ |
| TDVCL | Data in Setup Time | 30 |  | 20 |  | 5 |  | ns |  |
| TCLDX | Data in Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TR1VCL | RDY Setup Time into MBL 8284A (See Notes 1, 2) | 35 |  | 35 |  | 35 |  | ns |  |
| TCLR1X | RDY Hold Time into MBL 8284A (See Notes 1, 2) | 0 |  | 0 |  | 0 |  | ns |  |
| TRYHCH | READY Setup Time into MBL 8086 | 118 |  | 68 |  | 53 |  | ns |  |
| TCHRYX | READY Hold Time into MBL 8086 | 30 |  | 20 |  | 20 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 4) | -8 |  | -8 |  | -10 |  | ns |  |
| TINVCH | Setup Time for Recognition (INTR, NMI, TEST) (See Note 2) | 30 |  | 15 |  | 15 |  | ns |  |
| TGVCH | $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Setup Time | 30 |  | 15 |  | 12 |  | ns |  |
| TCHGX | $\overline{\mathrm{RO}}$ Hold Time into MBL 8086 | 40 |  | 30 |  | 20 |  | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 |  | 20 |  | 20 | ns | $\begin{aligned} & \text { From } 0.8 \mathrm{~V} \text { to } \\ & 2.0 \mathrm{~V} \end{aligned}$ |
| TIHIL | Input Fall Time (Except CLK) |  | 12 |  | 12 |  | 12 | ns | $\begin{aligned} & \text { From } 2.0 \mathrm{~V} \text { to } \\ & 0.8 \mathrm{~V} \end{aligned}$ |

## NOTES:

1. Signal at MBL 8284A or MBL 8288 shown for reference only.
2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.
3. Applies only to T3 and wait states.
4. Applies only to T 2 state ( 8 ns into T 3 ).

FUJITSU
MBL 8086

MBL 8086-2
MBL 8086-1

## A.C. CHARACTERISTICS (Continued)

TIMING RESPONSES

| Symbol | Parameter | MBL 8086 |  | MBL 8086-2 |  | MBL 8086-1 (Preliminary) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TCLML | Command Active Delay (See Note 1) | 10 | 35 | 10 | 35 | 10 | 35 | ns |  |
| TCLMH | Command Inactive Delay (See Note 1) | 10 | 35 | 10 | 35 | 10 | 35 | ns |  |
| TRYHSH | READY Active to Status Passive (See Note 3) |  | 110 |  | 65 |  | 45 | ns |  |
| TCHSV | Status Active Delay | 10 | 110 | 10 | 60 | 10 | 45 | ns |  |
| TCLSH | Status Inactive <br> Delay | 10 | 130 | 10 | 70 | 10 | 55 | ns |  |
| TCLAV | Address Valid Delay | 10 | 110 | 10 | 60 | 10 | 50 | ns |  |
| TCLAX | Address Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 80 | TCLAX | 50 | 10 | 40 | ns |  |
| TSVLH | Status Valid to ALE High (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TSVMCH | Status Valid to MCE High (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TCLLH | CLK Low to ALE Valid (See Note 1) |  | 15 |  | 15 |  | 15 | ns | ${ }^{*} \mathrm{C}_{\mathrm{L}}=20-100 \mathrm{pF} \mid$ |
| TCLMCH | CLK Low to MCE <br> High (See Note 1) |  | 15 |  | 15 |  | 15 | ns | MBL 8086 Outputs (in |
| TCHLL | ALE Inactive Delay (See Note 1) |  | 15 |  | 15 |  | 15 | ns | addition to <br> MBL 8086 |
| TCLMCL | MCE Inactive Delay (See Note 1) |  | 15 |  | 15 |  | 15 | ns | self-load) |
| TCLDV | Data Valid Delay | 10 | 110 | 10 | 60 | 10 | 50 | ns |  |
| TCHDX | Data Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TCVNV | Control Active Delay (See Note 1) | 5 | 45 | 5 | 45 | 5 | 45 | ns |  |
| TCVNX | Control Inactive <br> Delay (See Note 1) | 10 | 45 | 10 | 45 | 10 | 45 | ns |  |
| TAZRL | Address Float to Read Active | 0 |  | 0 |  | 0 |  | ns |  |
| TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 10 | 165 | 10 | 100 | 10 | 70 | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 150 | 10 | 80 | 10 | 60 | ns |  |
| TRHAV | $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TCLCL-45 |  | TCLCL-40 |  | TCLCL-35 |  | ns |  |
| TCHDTL | Direction Control Active Delay (See Note 1) |  | 50 |  | 50 |  | 50 | ns |  |
| TCHDTH | Direction Control Inactive Delay (See Note 1) |  | 30 |  | 30 |  | 30 | ns |  |
| TCLGL | GT Active Delay | 0 | 85 | 0 | 50 | 0 | 45 | ns |  |
| TCLGH | GT Inactive Delay | 0 | 85 | 0 | 50 | 0 | 45 | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Width | 2TCLCL-75 |  | 2TCLCL-50 |  | 2TCLCL-40 |  | ns |  |
| TOLOH | Output Rise Time |  | 20 |  | 20 |  | 20 | ns | $\begin{array}{\|l} \hline \begin{array}{l} \text { From } 0.8 \mathrm{~V} \text { to } \\ 2.0 \mathrm{~V} \end{array} \\ \hline \end{array}$ |
| TOHOL | Output Fall Time |  | 12 |  | 12 |  | 12 | ns | $\begin{aligned} & \text { From } 2.0 \mathrm{~V} \text { to } \\ & 0.8 \mathrm{~V} \end{aligned}$ |

## WAVEFORMS



MBL 8086
MBL 8086-2
MBL 8086-1

WAVEFORMS (Continued)


WAVEFORMS (Continued)


## REQUEST/GRANT SEQUENCE TIMING (MAXIMUM MODE ONLY)


note 1. the coprocessor may not drive the buses outside the region shown without risking contention.


TABLE 2 - INSTRUCTION SET SUMMARY*


[^7]TABLE 2 - INSTRUCTION SET SUMMARY*
CONTROL TRANSFER

CALL = Call:
Direct within segment
Indirect within segment
Direct intersegment
Indirect intersegment
JMP = Unconditional Jump:
Direct within segment
Direct within segment-short Indirect with in segment
Direct intersegment
Indirect intersegment
RET $=$ Return from CALL: Within segment
Within seg, adding immed, to SP Intersegment
Intersegment, adding immediate to SP JE/JZ = Jump on equal/zero
JL/JNGE $=$ Jump on less/not greater
or equal
JLE/JNG $=$ Jump on less or equal/not
JB/JMAE
above or equal
JBE/JNA = Jump on below or
equal/not above
JP/JPE = Jump on parity/parity even
JO = Jump on overflow
JS = Jump on sign
JNE/JNZ = Jump on not equal/not
JNL/JGE = Jump on not less/greater requal
JNLE/JG = Jump on not less
or equal/greater


JNB/JAE = Jump on not below/
above or equal
JNBE/JA = Jump on not below or equal/above
JNP/JPO = Jump on not par/par odd JNO = Jump on not overflow
JNS = Jump on not sign
LOOP $=$ Loop CX times
LOOPZ/LOOPE = Loop while
zero/equal
LOOPNZ/LOOPNE $=$ Loop while not
zero/equal
JCXZ = Jump on CX zero
INT = Interrupt
Type specified
Type 3
INTO = interrupt on overflow
IRET $=$ interrupt return
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
NOP $=$ No operation

| 0 1 1 1 0 0 1 1 | disp |
| :---: | :---: |
| 0 1 1 1 0 1 1 1 | disp |
| 0 1 1 1 1 0 1 1 | disp |
| 010100001 | disp |
| 0 1 1 1 1 0 0 1 <br> 1        | disp |
| 11 1 0 0 1 0 <br> 1      | disp |
| 111000001 | disp |
| 11100000 | disp |
| $0_{11100011}$ | disp |


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

Footnotes:
$A L=8$-bit accumulator
$A X=16$-bit accumulator
CX $=$ Count register
DS $=$ Data segment
ES = Extra segment
Above/below refers to unsigned value
Greater $=$ more positive
Less $=$ less positive (more negative) signed values
if $d=1$ then " $t 0$ " reg; if $d=0$ then "from" reg
if $\mathbf{w}=\mathbf{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 $=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)+$ DISP
if $\mathrm{r} / \mathrm{m}=011$ then $E A=(B P)+(D I)+D I S P$
if $\mathrm{r} / \mathrm{m}=100$ then $E A=(S I)+$ DISP
if $\mathrm{r} / \mathrm{m}=101$ then $E A=(D I)+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $E A=(B P)+D I P^{*}$
if $\mathrm{r} / \mathrm{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 $\mathrm{r} / \mathrm{m}=110$ then $E A=$ disp-high: disp-low
if $\mathrm{s}: \mathrm{w}=01$ then 16 bits of immediate data form the operand.
s:w $=11$ then an immediate data byte is sign extended to
form the 16 -bit operand.
if $\mathrm{v}=0$ then "count" $=1$; if $\mathrm{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 - 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 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)$

[^8]
## PACKAGE ILLUSTRATION



## PACKAGE DIMENSIONS (Suffix: -C)



MBL 8086
MBL 8086-2
MBL 8086-1

## PACKAGE ILLUSTRATION



PACKAGE DIMENSIONS (Suffix:-P)


## NMOS HIGH-INTEGRATION 8-BIT MICROPROCESSOR

## NMOS HIGH-INTEGRATION 8-BIT MICROPROCESSOR

The Fujitsu MBL 80188 is a highly integrated microprocessor with an 8 -bit data bus interface and a 16 -bit internal architecture to give high performance. The MBL 80188 effectively combines $15-20$ of the most compon MBL 8088 components onto one. The MBL 80188 provides two times greater throughput than the standard $5 \mathrm{MHz} \mathrm{M} / \mathrm{L} 8088$. The MBL 8088 is upward compatible with MBL 8086 and 88 software and adds 10 new instruction types fothe existing set. It is housed in a 68 -pad ceramic LCC (Leadless Chip Carrier: JEDEC Type A) or 68 -pin ceramic PGAX (Pin Grid Array) package.

- Integrated Feature Set:
- Enhanced MBL 8088-2 CPU
- Clock Generator
- 2 Independent, High-Speed DMA Channels
- Programmable Interrupt Controller
- 3 Programmable 16-bit Timers
- Programmable Memory and Peripheral Chip-Select Logic
- Programmable Wait State Generator
- Local Bus Controller
- 8-Bit Data Bus Interface: 16-bit internal architecture
- Available in 8 MHz (MBL 80188) and cost effective 6 MHz (MBL 80188-6) versions.
- High-performance 8 MHz Processor
-2 Times the Performance of the Standard MBL 8088
- 2 MByte/Sec Bus Bandwidth Interface
- Direct Addressing Capability to 1 MByte of Memory
- Completely Object Code Compatible with All Existing MBL 8086, 88 Software
- 10 New Instruction Types
- High Performance Numerical Coprocessing Capability

Through Intel 8087 Interface

- Two Package Options:
- 68-Pad Ceramic LCC (Suffix -CV)
(JEDEC Type A)
- 68-Pin Ceramic PGA (Suffix -CR)

Fig. 1 - BLOCK DIAGRAM


Portions Reprinted by permission of Intel Corporation
(c) Intel Corporation, 1982
© FUJITSU LIMITED, 1986

Fig. 2 - PIN CONFIGURATIONS


68-PIN PGA
TOP VIEW


## PIN DESCRIPTION

Table 1 - PIN DESCRIPTION

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}, \mathrm{V}_{\mathrm{cc}}$ | 9,43 | 1 | System Power: +5 V power supply. |
| $\mathrm{V}_{\text {ss }}, \mathrm{V}_{\text {ss }}$ | 26,60 | 1 | System Ground. |
| RESET | 57 | 0 | Reset Output indicates that the MBL 80188 CPU is being reset, and can be used as a system reset. It is active HIGH, synchronized with the processor clock, and lasts an integer number of clock periods corresponding to the length of the RES signal. |
| x1, $\mathrm{x}^{2}$ | 59,58 | 1 | Crystal Inputs, X1 and X2, provide an external connection for a fundamental mode parallel resonant crystal for the internal crystal oscillator. X1 can interface to an external clock instead of a crystal. In this case, minimize the capacitance on X 2 or drive X 2 with complemented X 1 . The input or oscillator frequency is internally divided by two to generate the clock signal (CLKOUT). |
| CLKOUT | 56 | 0 | Clock Output provides the system with a $50 \%$ duty cycle waveform. All device pin timings are specified relative to CLKOUT. CLKOUT has sufficient MOS drive capabilities for the 8087 Numeric Processor Extension. |
| $\overline{\text { RES }}$ | 24 | 1 | System Reset causes the MBL 80188 to immediately terminate its present activity, clear the internal logic, and enter a dormant state. This signal may be asynchronous to the MBL 80188 clock. The MBL 80188 begins fetching instructions approximately 7 clock cycles after $\overline{\mathrm{RES}}$ is returned HIGH. $\overline{R E S}$ is required to be LOW for greater than 4 clock cycles and is internally synchronized. For proper initialization, the LOW-to-HIGH transition of RES must occur no sooner than 50 microseconds after power up. This input is provided with a Schmitt-trigger to facilitate power-on $\overline{\mathrm{RES}}$ generation via an RC network. When RES occurs, the MBL 80188 will drive the status lines to an inactive level for one clock, and then tri-state them. |
| TEST | 47 | 1 | TEST is examined by the WAIT instruction. If the TEST input is HIGH when "WAIT" execution begins, instruction execution will suspend. TEST will be resampled until it goes LOW, at which time execution will resume. If interrupts are enabled while the MBL 80188 is waiting for TEST, interrupts will be serviced. This input is synchronized internally. |
| $\begin{aligned} & \text { TMR IN } 0, \\ & \text { TMR IN } 1 \end{aligned}$ | $\begin{aligned} & 20 \\ & 21 \end{aligned}$ | $1$ | Timer Inputs are used either as clock or control signals, depending upon the programmed timer mode. These inputs are active HIGH (or LOW-toHIGH transitions are counted) and internally synchronized. |
| TMR OUT O, TMR OUT 1 | $\begin{aligned} & 22 \\ & 23 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | Timer Outputs are used to provide single pulse or continuous waveform generation, depending upon the timer mode selected. |
| DRQO, DRQ1 | $\begin{aligned} & 18 \\ & 19 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | DMA Request is driven HIGH by an external device when it desires that a DMA channel (Channel 0 or 1) perform a transfer. These signals are active HIGH, level-triggered, and internally synchronized. |
| NMI | 46 | 1 | Non-Maskable Interrupt is an edge-triggered input which causes a type 2 interrupt. NMI is not maskable internally. A transition from a LOW to HIGH initiates the interrupt at the next instruction boundary. NMI is latched internally. An NMI duration of one clock or more will guarantee service. This input is internally synchronized. |
| INTO, INT1, INT2/INTAO, INT3/INTA1 | $\begin{gathered} 45,44 \\ 42 \\ 41 \end{gathered}$ | $\begin{aligned} & 1 \\ & 1 / 0 \\ & 1 / 0 \end{aligned}$ | Maskable Interrupt Requests can be requested by strobing one of these pins. When configured as inputs, these pins are active HIGH. Interrupt Requests are synchronized internally. INT2 and INT3 may be configured via software to provide active-LOW interrupt-acknowledge output signals. All interrupt inputs may be configured via software to be either edge- or level-triggered. To ensure recognition, all interrupt requests must remain active until the interrupt is acknowledged. When iRMX mode is selected, the function of these pins changes (see Interrupt Controller section of this data sheet). |

FUJITSU


## PIN DESCRIPTION (Continued)

Table 1 - PIN DESCRIPTION (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { A19/S6, } \\ & \text { A18/S5, } \\ & \text { A17/S4, } \\ & \text { A16/S3 } \end{aligned}$ | 65-68 | $\begin{aligned} & \mathrm{O} \\ & \mathrm{O} \\ & \mathrm{O} \\ & \mathrm{O} \end{aligned}$ | Address Bus Outputs (16-19) and Bus Cycle Status (3-6) reflect the four most significant address bits during T1. These signals are active HIGH. During T2, T3, Tw and T4, status information is available on these lines as encoded below: |
| AD7-AD0 | $\begin{gathered} 2,4,6,8 \\ 11,13,15,17 \end{gathered}$ | 1/0 | Address/Data Bus ( $0-7$ ) signals constitute the time mutiplexed memory or I/O address (T1) and data (T2, T3, Tw, and T4) bus. The bus is active HIGH. |
| A15-A8 | $\begin{gathered} 1,3,5,7 \\ 10,12,14,16 \end{gathered}$ | 0 | Address-only Bus (8-15), containing valid address from T1-T4. The bus is active HIGH. |
| S7 | 64 | 0 | This signal is always HIGH to indicate that the MBL 80188 has an 8-bit data bus, and is tri-state OFF during bus HOLD. |
| ALE/QSO | 61 | 0 | Address Latch Enable/Queue Status $\mathbf{0}$ is provided by the MBL 80188 to latch the address into the MBL 8282/8283 address latches. ALE is active HIGH. Addresses are guaranteed to be valid on the trailing edge of ALE. The ALE rising edge is generated off the rising edge of the CLKOUT immediately preceding T1 of the associated bus cycle, effectively onehalf clock cycle earlier than in the standard MBL 80188. The trailing edge is generated off the CLKOUT rising edge in T1 as in the MBL 80188. Note that ALE is never floated. |
| $\overline{\mathrm{WR}} / \mathrm{QS} 1$ | 63 | 0 | Write Strobe/Queue Status 1 indicates that the data on the bus is to be written into a memory or an I/O device. WR is active for T2, T3, and Tw of any write cycle. It is active LOW, and floats during "HOLD." It is driven HIGH for one clock during Reset, and then floated. When the MBL 80188 is in queue status mode, the ALE/QS0 and WR/QS1 pins provide information about processor/instruction queue interaction. |
|  |  |  | QS1 Q $^{\text {a }}$ O ${ }^{\text {a }}$ ( Queue Operation |
|  |  |  | 0 0 No queue operation <br> 0 1 First opcode byte fetched from the queue <br> 1 1 Subsequent byte fetched from the queue <br> 1 0 Empty the queue |
| $\overline{\mathrm{RD}} / \overline{\mathrm{QSMD}}$ | 62 | 0 | Read Strobe indicates that the MBL 80188 is performing a memory or I/O read cycle. $\overline{R D}$ is active LOW for T2, T3, and Tw of any read cycle. It is guaranteed not to go LOW in T2 until after the Address Bus is floated. $\overline{\mathrm{RD}}$ is active LOW, and floats during "HOLD." $\overline{\mathrm{RD}}$ is driven HIGH for one clock during Reset, and then the output driver is floated. A weak internal pull-up mechanism on the RD line holds it HIGH when the line is not driven. During RESET the pin is sampled to determine whether the MBL 80188 should provide ALE, $\overline{W R}$ and $\overline{R D}$, or if the Queue-Status should be provided. $\overline{\mathrm{RD}}$ should be connected to GND to provide Queue-Status data. |
| ARDY | 55 | I | Asynchronous Ready informs the MBL 80188 that the addressed memory space or I/O device will complete a data transfer. The ARDY input pin will accept an asynchronous input, and is active HIGH. Only the rising edge is internally synchronized by the MBL 80188. This means that the falling edge of ARDY must be synchronized to the MBL 80188 clock. If connected to $\mathrm{V}_{\mathrm{Cc}}$, no WAIT states are inserted. Asynchronous ready (ARDY) or synchronous ready (SRDY) must be active to terminate a bus cycle. If unused, this line should be tied low. |

## PIN DESCRIPTION (Continued)

Table 1 - PIN DESCRIPTION (Continued)


FUJITSU
MBL 80188
トํㅐํㅐ․
MBL 80188-6

## PIN DESCRIPTION (Continued)

Table 1 - PIN DESCRIPTION (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| PCSO-4 | 25,27-30 | 0 | Peripheral Chip Select Signals $\mathbf{0 - 4}$ are active LOW when a reference is made to the defined peripheral area ( 64 K byte $\mathrm{I} / \mathrm{O}$ space). These lines are not floated during bus HOLD. The address ranges activating PCSO -4 are software programmable. |
| $\overline{\text { PCS5/A1 }}$ | 31 | 0 | Peripheral Chip Select 5 or Latched A1 may be programmed to provide a sixth peripheral chip select, or to provide an internally latched A1 signal. The address range activating PCS5 is software programmable. When programmed to provide latched A1, rather than PCS5, this pin will retain the previously latched value of A1 during a bus HOLD. A1 is active HIGH. |
| $\overline{\text { PCS6 } / A 2 ~}$ | 32 | 0 | Peripheral Chip Select 6 or Latched A2 may be programmed to provide a seventh peripheral chip select, or to provide an internally latched A2 signal. The address range activating PCS6 is software programmable. When programmed to provide latched A2, rather than PCS6, this pin will retain the previously latched value of A2 during a bus HOLD. A2 is active HIGH. |
| DT/ $\bar{R}$ | 40 | 0 | Data Transmit/Receive controls the direction of data flow through the external MBL 8286/8287 data bus transceiver. When LOW, data is transferred to the MBL 80188. When HIGH, the MBL 80188 places write data bus. |
| $\overline{\text { DEN }}$ | 39 | 0 | Data Enable is provided as an MBL 8286/8287 data bus transceiver output enable. $\overline{\mathrm{DEN}}$ is active LOW during each memory and I/O access. $\overline{D E N}$ is HIGH whenever DT/R changes state. |

## FUNCTIONAL DESCRIPTION

## INTRODUCTION

The following Functional Description describes the base architecture of the MBL 80188. This architecture is common to the MBL 8086, 88, and 286 microprocessor families as well. The MBL 80188 is a very high integration 8 -bit microprocessor. It combines 15-20 of the most common microprocessor system components onto one chip while providing twice the performance of the standard MBL 8088. The MBL 80188 is object code compatible with the MBL 8086, 88 microprocessors and adds 10 new instruction types to the existing MBL 8086, 88 instruction set.

## MBL 80188 BASE ARCHITECTURE

The MBL 8086, 88, 186, 188, and 286 family all contain the same basic set of registers, instructions and addressing modes. The MBL 80188 processor is upward compatible with the MBL 8086, 8088, 80186, and 80286 CPUs.

## Register Set

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

## - General Registers

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

## - Segment Registers

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

## - Base and Index Registers

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

## - Status and Control Registers

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

## Status Word Description

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


Fig. 3b - STATUS WORD FORMAT


RESERVED

Table 2 - STATUS WORD BIT FUNCTIONS

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

## Instruction Set

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

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

## Memory Organization

Memory is organized in sets of segments. Each segment is a linear contiguous sequence of up to $64 \mathrm{~K}\left(2^{16}\right) 8$-bit bytes. Memory is addressed using a two-component address (a pointer) that consists of a 16 -bit base segment and a 16 -bit offset. The 16 -bit base values are contained in one of four internal segment registers (code, data, stack, extra). The physical address is calculated by shifting the base value LEFT by four bits and adding the 16 -bit offset value to yield a 20 -bit physical address (see Fig. 5). This allows for a 1 MByte physical address size.

All instructions that address operands in memory must specify the base segment and the 16 -bit offset value. For speed and compact instruction encoding, the segment register used for physical address generation is implied by the addressing mode used (see Table 3). These rules follow the way programs are written (see Fig. 6) as independent modules that require areas for code and data, a stack, and access to external data areas.

Special segment override instruction prefixes allow the implicit segment register selection rules to be overriden for special cases. The stack, data, and extra segments may coincide for simple programs.

Inlumunuminu

Fig. 4 - MBL 80188 INSTRUCTION SET

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


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


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


| LOGICALS |  |
| :---: | :---: |
| NOT | "Not" byte or word |
| AND | "And" byte or word |
| OR | "Inclusive or" byte or word |
| XOR | "Exclusive or" byte or word |
| TEST | "Test" byte or word |
| SHIFTS |  |
| SHL/SAL | Shift logical/arithmetic left byte or word |
| SHR | Shift logical right byte or word |
| SAR | Shift arithmetic right byte or word |
| ROTATES |  |
| ROL | Rotate left byte or word |
| ROR | Rotate right byte or word |
| RCL | Rotate through carry left byte or word |
| RCR | Rotate through carry right byte or word |
| FLAG OPERATIONS |  |
| STC | Set carry flag |
| CLC | Clear carry flag |
| CMC | Complement carry flag |
| STD | Set direction flag |
| CLD | Clear direction flag |
| STI | Set interrupt enable flag |
| CLI | Clear interrupt enable flag |
| EXTERNAL SYNCHRONIZATION |  |
| HLT | Halt until interrupt or reset |
| WAIT | Wait for TEST pin active |
| ESC | Escape to extension processor |
| LOCK | Lock bus during next instruction |
| NO OPERATION |  |
| NOP | No operation |
| HIGH LEVEL INSTRUCTIONS |  |
| ENTER | Format stack for procedure entry |
| LEAVE | Restore stack for procedure exit |
| BOUND | Detects values outside prescribed range |

Fig. 4 - MBL 80188 INSTRUCTION SET (continued)

| CONDITIONAL TRANSFERS |  |
| :--- | :--- |
| JA/JNBE | Jump if above/not below nor equal |
| JAE/JNB | Jump if above or equal/not below |
| JB/JNAE | Jump if below/not above nor equal |
| JBE/JNA | Jump if below or equal/not above |
| JC | Jump if carry |
| JE/JZ | Jump if equal/zero |
| JG/JNLE | Jump if greater/not less nor equal |
| JGE/JNL | Jump if greater or equal/not less |
| JL/JNGE | Jump if less/not greater nor equal |
| JLE/JNG | Jump if less or equal/not greater |
| JNC | Jump if not carry |
| JNE/JNZ | Jump if not equal/not zero |
| JNO | Jump if not overflow |
| JNP/JPO | Jump if not parity/parity odd |
| JNS | Jump if not sign |
| JO | Jump if overflow |
| JP/JPE | Jump if parity/parity even |
| JS | Jump if sign |


| UNCONDITIONAL TRANSFERS |  |
| :--- | :--- |
| CALL | Call procedure |
| RET | Return from procedure |
| JMP | Jump |
| ITERATION CONTROLS |  |
| LOOP | Loop |
| LOOPE/LOOPZ | Loop if equal/zero |
| LOOPNE/LOOPNZ | Loop if not equal/not zero |
| JCXZ | Jump if register CX = 0 |
| INT | INTERRUPTS |
| INTO | Interrupt |
| IRET | Interrupt if overflow |

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

Fig. 5 - TWO COMPONENT ADDRESS


Table 3 - SEGMENT REGISTER SELECTION RULES

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

Fig. 6 - SEGMENTED MEMORY HELPS STRUCTURE SOFTWARE


## Addressing Modes

The MBL 80188 provides eight categories of addressing modes to specify operands. Two addressing modes are provided for instructions that operate on register or immediate operands:

- Register Operand Mode: The operand is located in one of the 8 - or 16 -bit general registers.
- Immediate Operand Mode: The operand is included in the instruction.

Six modes are provided to specify the location of an operand in a memory segment. A memory operand address consists of two 16 -bit components: a segment base and an offset. The segment base is supplied by a 16 -bit segment register either implicitly chosen by the addressing mode or explicitly chosen by a segment override prefix. The offset, also called the effective address, is calculated by summing any combination of the following three address elements:

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

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

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

- Direct Mode: The operand's offset is contained in the instruction as an 8 - or 16 -bit displacement element.
- Register Indirect Mode: The operand's offset is in one of the registers SI, DI, BX, or BP.
- Based Mode: The operand's offset is the sum of an 8 - or 16 -bit displacement and the contents of a base register (BX or BP).
- Indexed Mode: The operand's offset is the sum of an 8 - or 16 -bit displacement and the contents of an index register (SI or DI).
- Based Indexed Mode: The operand's offset is the sum of the contents of a base register and an index register.
- Based Indexed Mode with Displacement: The operand's offset is the sum of a base register's contents, an index register's contents, and an 8 - or 16 -bit displacement.


## Data Types

The MBL 80188 directly supports the following data types:

- Integer: A signed binary numeric value contained in an 8 -bit byte or a 16 -bit word. All operations assume a 2 's complement representation. Signed 32 - and 64 -bit integers are supported using the MBL 80188 and Intel 8087 Numeric Data Processor.
- Ordinal: An unsigned binary numeric value contained in an 8 -bit byte or a 16 -bit word.
- Pointer: A 16 - or 32 -bit quantity, composed of a 16 -bit offset component or a 16 -bit segment base component in addition to a 16 -bit offset component.
- String: A contiguous sequence of bytes or words. A string may contain from 1 to 64 K bytes.
- ASC/I: A byte representation of alphanumeric and control characters using the ASCII standard of character representation.
- BCD: A byte (unpacked) representation of the decimal digits 0-9.
- Packed BCD: A byte (packed) representation of two decimal digits (0-9). One digit is stored in each nibble (4-bits) of the byte.
- Floating Point: A signed 32-, 64-, or 80 -bit real number representation. (Floating point operands are supported using the MBL 80188 and Intel 8087 Numeric Data Processor configuration).

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

## I/O Space

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

## Interrupts

An interrupt transfers execution to a new program location. The old program address (CS:IP) and machine state (Status Word) are saved on the stack to allow resumption of the interrupted program. Interrupts fall into three classes: hardware initiated, INT instructions, and instruction exceptions. Hardware initiated interrupts occur in response to an external input and are classified as nonmaskable or maskable.

Programs may cause an interrupt with an INT instruction. Instruction exceptions occur when an unusual condition, which prevents further instruction processing, is detected while attempting to execute an instruction. If the exception was caused by executing an ESC instruction with the ESC trap bit set in the relocation register, the return in-

Fig. 7 - MBL 80188 SUPPORTED DATA TYPES


CHARACTER $_{N}$ CHARACTER $_{1}$ CHARACTER $_{0}$


SIGNIFICANT DIGIT SIGNIFICANT DIGIT


BYTE WORD N BYTE WORD 1 BYTE WORD 0


NOTE:
*SUPPORTED BY MBL 80188 AND INTEL 8087 NUMERIC DATA PROCESSOR CONFIGURATION.
struction will point to the ESC instruction, or to the segment override prefix immediately preceding the ESC instruction if the prefix was present. In all other cases, the return address from an exception will point at the instruction immediately following the instruction causing the exception.

A table containing up to 256 pointers defines the proper interrupt service routine for each interrupt. Interrupts $0-31$, some of which are used for instruction exceptions, are reserved. Table 4 shows the MBL 80188 predefined types and default priority levels. For each interrupt, an 8 -bit vector must be supplied to the MBL 80188 which identifies the appropriate table entry. Exceptions supply the interrupt vector internally. In addition, internal peripherals and non-cascaded external interrupts will generate their own vectors through the internal interrupt controller. INT instructions contain or imply the vector and allow access to all 256 interrupts. Maskable hardware initiated interrupts supply the 8 -bit vector to the CPU during an interrupt acknowledge bus sequence. Non-maskable hardware interrupts use a predefined internally supplied vector.

## Interrupt Sources

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

The software generated MBL 80188 interrupts are described below.

## - Divide Error Exception (Type 0)

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

## - Single-Step Interrupt (Type 1 )

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

## - Non-Maskable Interrupt-NMI (Type 2)

An external interrupt source which cannot be masked.

Table 4 - MBL 80188 INTERRUPT VECTORS

| Interrupt Name | Vector Type | Default <br> Priority | Related Instructions |
| :---: | :---: | :---: | :---: |
| Divide Error Exception | 0 | *1 | DIV, IDIV |
| Single Step Interrupt | 1 | 12**2 | All |
| NMI | 2 | 1 | All |
| Breakpoint Interrupt | 3 | *1 | INT |
| INTO Detected Overflow Exception | 4 | *1 | INTO |
| Array Bounds Exception | 5 | *1 | BOUND |
| Unused-Opcode Exception | 6 | *1 | Undefined Opcodes |
| ESC Opcode Exception | 7 | * ${ }^{* * *}$ | ESC Opcodes |
| Timer 0 Interrupt | 8 | $2 A^{* * * *}$ |  |
| Timer 1 Interrupt | 18 | $2 \mathrm{~B}^{* * * *}$ |  |
| Timer 2 Interrupt | 19 | 2C**** |  |
| Reserved | 9 | 3 |  |
| DMA 0 Interrupt | 10 | 4 |  |
| DMA 1 Interrupt | 11 | 5 |  |
| INTO Interrupt | 12 | 6 |  |
| INT1 Interrupt | 13 | 7 |  |
| INT2 Interrupt | 14 | 8 |  |
| INT3 Interrupt | 15 | 9 |  |

NOTES:
*1. These are generated as the result of an instruction execution.
**2. This is handled as in the MBL 8088.
****3. All three timers constitute one source of request to the interrupt controller. The Timer interrpts all have the same default priority level with respect to all other interrupt sources. However, they have a defined priority ordering amongst themselves. (Priority 2A is higher priority than 2B.) Each Timer interrupt has a separate vector type number.
4. Default priorities for the interrupt sources are used only if the user does not program each source into a unique priority level.
***5. An escape opcode will cause a trap only if the proper bit is set in the peripheral control block relocation register.

- Breakpoint Interrupt (Type 3)

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

## - INTO Detected Overflow Exception (Type 4)

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

## - Array Bounds Exception (Type 5)

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

## - Unused Opcode Exception (Type 6)

Generated if execution is attempted on undefined opcodes.

## - Escape Opcode Exception (Type 7)

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

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

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

## Non-Maskable Interrupt Request (NMI)

A non-maskable interrupt (NMI) is also provided. This interrupt is serviced regardless of the state of the IF bit. A typical use of NMI would be to activate a power failure routine. The activation of this input causes an interrupt with an internally supplied vector value of 2 . No external interrupt acknowledge sequence is performed. The IF bit is cleared at the beginning of an NMI interrupt to prevent maskable interrupts from being serviced.

## Single-Step Interrupt

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

## Initialization and Processor Reset

Processor initialization or startup is accomplished by driving the $\overline{R E S}$ input pin LOW. $\overline{R E S}$ forces the MBL 80188 to terminate all execution and local bus activity. No instruction or bus activity will occur as long as $\overline{R E S}$ is active. After $\overline{\operatorname{RES}}$ becomes inactive and an internal processing interval elapses, the MBL 80188 begins execution with the instruction at physical location FFFFO(H). $\overline{R E S}$ also sets some registers to predefined values as shown in Table 5.

## Table 5 - MBL 80188 INITIAL REGISTER STATE AFTER RESET

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

## THE MBL 80188 COMPARED TO THE MBL 80186

The MBL 80188 CPU is an 8 -bit processor designed around the MBL 80186 internal structure. Most internal functions of the MBL 80188 are identical to the equivalent MBL 80186 functions. The MBL 80188 handles the external bus the same way the MBL 80186 does with the distinction of handling only 8 bits at a time. Sixteen bit operands are fetched or written in two consecutive bus cycles. Both processors will appear identical to the software engineer, with the exception of execution time. The internal register structure is identical and all instructions have the same end result. The differences between the MBL 80188 and MBL 80186 are outlined below. Internally, there are three differences between the MBL 80188 and the MBL 80186. All changes are related to the 8 -bit bus interface.

- The queue length is 4 bytes in the MBL 80188 , whereas the MBL 80186 queue contains 6 bytes, or three words. The queue was shortened to prevent overuse of the bus by the BIU when prefetching instructions. This was required because of the additional time necessary to fetch instructions 8 bits at a time.
- To further optimize the queue, the prefetching algorithm was changed. The MBL 80188 BIU will fetch a new instruction to load into the queue each time. There is a 1 -byte hole (space available) in the queue. The MBL 80186 waits until a 2 -byte space is available.
- The internal execution time of the instruction is affected by the 8 -bit interface. All 16 -bit fetches and writes from/to memory take an additional four clock
cycles. The CPU may also be limited by the speed of instruction fetches when a series of simple operations occur. When the more sophisticated instructions of the MBL 80188 are being used, the queue has time to fill and the execution proceeds as fast as the execution unit will allow.

The MBL 80188 and MBL 80186 are completely software compatible by virture of their identical execution units. Software that is system dependent may not be completely transferable, but software that is not system dependent will operate equally well on an MBL 80188 or an MBL 80186.

The hardware interface of the MBL 80188 contains the major differences between the two CPUs. The pin assignments are nearly identical, however, with the following functional changes.

- A8-A15 - These pins are only address outputs on the MBL 80188. These address lines are latched internally and remain valid throughout a bus cycle in a manner similar to the 8085 upper address lines.
- $\overline{\mathrm{BHE}}$ has no meaning on the MBL 80188 and has been eliminated.


## MBL 80188 CLOCK GENERATOR

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

## Oscillator

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

The following parameters may be used for choosing a crystal:

[^9]Fig. 8 - RECOMMENDED MBL 80188 CRYSTAL CONFIGURATION


## Clock Generator

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

## READY Synchronization

The MBL 80188 provides both synchronous and asynchronous ready inputs. Asynchronous ready synchronization is accomplished by circuitry which samples ARDY in the middle of T2, T3 and again in the middle of each Tw until ARDY is sampled HIGH. One-half CLKOUT cycle of resolution time is used. Full synchronization is performed only on the rising edge of ARDY, i.e., the falling edge of ARDY must be synchronized to the CLKOUT signal if it will occur during T2, T3 or Tw. HIGH-to-LOW transitions of ARDY must be performed synchronously to the CPU clock.

A second ready input (SRDY) is provided to interface with externally synchronized ready signals. This input is sampled at the end of T2, T3 and again at the end of each Tw until it is sampled HIGH. By using this input rather than the asynchronous ready input, the half-clock cycle resolution time penalty is eliminated.

This input must satisfy set-up and hold times to guarantee proper operation of the circuit.

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

## RESET Logic

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

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

## LOCAL BUS CONTROLLER

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

## Memory/Peripheral Control

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

## Transceiver Control

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

Table 6 - TRANSCEIVER CONTROL SIGNALS DESCRIPTION

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

## Local Bus Arbitration

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

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

## Local Bus Controller and Reset

Upon receipt of a RESET pulse from the $\overline{\operatorname{RES}}$ input, the local bus controller will perform the following actions:

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

NOTE: $\overline{\mathrm{RD}}$ is also provided with an internal pull-up device to prevent the processor from inadvertently
entering Queue Status mode during reset.

- Drive $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ to the passive state (all HIGH) and then float.
- Drive $\overline{L O C K}$ HIGH and then float.
- Tristate AD0-7, A8-19, S7, DT/ $\bar{R}$.
- Drive ALE LOW (ALE is never floated).
- Drive HLDA LOW.


## INTERNAL PERIPHERAL INTERFACE

All the MBL 80188 integrated peripherals are controlled via 16 -bit registers contained within an internal 256 -byte control block. This control block may be mapped into either memory or I/O space. Internal logic will recognize the address and respond to the bus cycle. During bus cycles to internal registers, the bus controller will signal the operation externally (i.e., the $\overline{R D}, \overline{W R}$, status, address, data, etc., lines will be driven as in a normal bus cycle), but D7-0, SRDY, and ARDY will be ignored. The base address of the control block must be on an even 256 -byte boundary (i.e., the lower 8 bits of the base address are all zeros). All of the defined registers within this control block may be read or written by the MBL 80188 CPU at any time. The location of any register contained within the 256 -byte control block is determined by the current base address of the control block.
The control block base address is programmed via a 16 -bit relocation register contained within the control block at offset FEH from the base address of the control block (see Fig. 9). It provides the upper 12 bits of the base address of the control block. Note that mapping the control register block into an address range corresponding to a chip-select range is not recommended (the chip select circuitry is discussed later in this data sheet). In addition, bit 12 of this register determines whether the control block will be mapped into $1 / O$ or memory space. If this bit is 1 , the control block will be located in memory space, whereas if the bit is 0 , the control block will be located in $\mathrm{I} / \mathrm{O}$ space. If the control register block is mapped into I/O space, the upper 4 bits of the base address must be programmed as 0 (since I/O addresses are only 16 bits wide).

Whenever mapping the MBL 80188 peripheral control block to another location, the programming of the relocation register should be done with a byte write (i.e. OUT DX,AL). Any access to the control block is done 16 bits at a time. Thus, internally, the relocation register will get written with 16 bits of the AX register while externally, the BIU will run only one 8 bit bus cycle. If a word instruction is used (i.e. OUT $D X, A X$ ), the relocation register will be written on the first bus cycle. The BIU will then run a second bus cycle which is unnecessary. The address of the second bus cycle will no longer be within the control
block (i.e. the control block was moved on the first cycle), and therefore, will require the generation of an external ready signal to complete the cycle. For this reason we recommend byte operations to the relocation register. Byte instructions may also be used for the other registers in the control block and will eliminate half of the bus cycles required if a word operation had been specified. Byte operations are only valid on even addresses though, and are undefined on odd addresses.
In addition to providing relocation information for the control block, the relocation register contains bits which place the interrupt controller into iRMX mode, and cause the CPU to interrupt upon encountering ESC instructions. At RESET, the relocation register is set to 20FFH. This causes the control block to start at FFOOH in $\mathrm{I} / \mathrm{O}$ space. An offset map of the 256 -byte control register block is shown in Fig. 10.

The integrated MBL 80188 peripherals operate semiautonomously from the CPU. Access to them for the most part is via software read/write of the control and data locations in the control block. Most of these registers can be both read and written. A few dedicated lines, such as interrupts and DMA request provide real-time communication between the CPU and peripherals as in a more conventional system utilizing discrete peripheral blocks. The overall interaction and function of the peripheral blocks has not substantially changed. The data access from/ to the 256 -byte internal control block will always be 16 -bit and done in one bus cycle. Externally the BIU will still run two bus cycles for each 16 -bit operation.

## CHIP-SELECT/READY GENERATION LOGIC

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

## Memory Chip Selects

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

The range for each chip select is user-programmable and can be set to $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}, 16 \mathrm{~K}, 32 \mathrm{~K}, 64 \mathrm{~K}, 128 \mathrm{~K}$ (plus 1 K and 256 K for upper and lower chip selects). In addition, the beginning or base address of the midrange memory chip select may also be selected. Only one chip select may be programmed to be active for any memory location at a time. All chip select sizes are in bytes.

Fig. 10 - INTERNAL REGISTER MAP

| Relocation Register | FEH |
| :---: | :---: |
| DMA Descriptors Channel 1 | DAH |
|  | DOH |
| DMA Descriptors Channel 0 | CAH |
|  | COH |
| Chip-Select Control Registers | $\mathrm{A8H}$ |
|  | AOH |
| Timer 2 Control Registers | 66H |
| Timer 2 Control Registers | $\begin{aligned} & 60 \mathrm{H} \\ & 5 \mathrm{EH} \end{aligned}$ |
| Timer 1 Control Registers | $58 \mathrm{H}$ |
| Timer 0 Control Registers | $56 \mathrm{H}$ |
|  | 50 H |
|  | 3EH |
| Interrupt Controller Registers | 20 H |

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

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

Fig. 9 - RELOCATION REGISTER


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

Table 7 - UMCS PROGRAMMING VALUES

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

The lower limit of this memory block is defined in the UMCS register (see Fig. 11). This register is at offset AOH in the internal control block. The legal values for bits 6-13 and the resulting starting address and memory block sizes are given in Table 7. Any combination of bits 6-13 not shown in Table 7 will result in undefined operation. After reset, the UMCS register is programmed for a 1 K area. It must be reprogrammed if a larger upper memory area is desired.
Any internally generated 20 -bit address whose upper 16 bits are greater than or equal to UMCS (with bits 0-5 " 0 ") will cause UCS to be activated. UMCS bits R2-RO are used to specify READY mode for the area of memory defined by this chip-select register, as explained below.

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

The MBL 80188 provides a chip select for low memory called $\overline{\mathrm{LCS}}$. The bottom of memory contains the interrupt vector table, starting at location 00000 H .

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

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

Table 8 - LMCS PROGRAMMING VALUES

| Upper Address | Memory <br> Block Size | LMCS Value (Assuming $R 0=R 1=R 2=0)$ |
| :---: | :---: | :---: |
| 003FFH | 1K | 0038H |
| 007FFH | 2K | 0078H |
| 00FFFH | 4K | 00F8H |
| 01FFFH | 8K | 01F8H |
| 03FFFH | 16K | 03F8H |
| 07FFFH | 32 K | 07F8H |
| OFFFFH | 64K | OFF8H |
| 1FFFFH | 128K | 1 FF 8 H |
| 3FFFFH | 256K | 3FF8H |

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

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

The MBL 80188 provides four $\overline{\text { MCS }}$ lines which are active within a user-locatable memory block. This block can be located anywhere within the MBL 80188 1M byte memory address space exclusive of the areas defined by UCS and $\overline{\mathrm{LCS}}$. Both the base address and size of this memory block are programmable.

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

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

Table 9 - MPCS PROGRAMMING VALUES

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

MBL 80188 MBL 80188-6

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

MMCS bits R2-R0 specify READY mode of operation for all mid-range chip selects. All devices in mid-range memory must use the same number of WAIT states.

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

## Peripheral Chip Selects

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

Seven $\overline{\mathrm{CS}}$ lines called $\overline{\mathrm{PCSO}}-6$ are generated by the MBL 80188. The base address is user-programmable; however it can only be a multiple of 1 K bytes, i.e., the least significant 10 bits of the starting address are always 0 .
$\overline{\text { PCS5 }}$ and $\overline{\text { PCS6 }}$ can also be programmed to provide latched

| Fig. 11 - UMCS REGISTER |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OFFSET: AOH | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|  | 1 | 1 | U | U | U | U | U | U | U | $u$ | 1 | 1 | 1 | R2 | R1 | Ro |
| A19 A11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Fig. 12 - LMCS REGISTER


Fig. 13 - MPCS REGISTER

OFFSET: A8H

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

Fig. 14 - MMCS REGISTER

OFFSET: A6H


address bits A1, A2. If so programmed, they cannot be used as peripheral selects. These outputs can be connected directly to the A0, A1 pins used for selecting internal registers of 8 -bit peripheral chips. This scheme simplifies the hardware interface because the 8 -bit registers of peripherals are simply treated as 16 -bit registers located on even boundaries in I/O space or memory space where only the lower 8 -bits of the register are significant: the upper 8 -bits are "don't cares."

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

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

Table 10 - PCS ADDRESS RANGES

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

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

Table 11 - MS, EX PROGRAMMING VALUES

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

MPCS bits 0-2 are used to specify READY mode for $\overline{P C S 4}-\overline{P C S 6}$ as outlined below.

## READY Generation Logic

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

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

Table 12 - READY BITS PROGRAMMING

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

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

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

## Chip Select/Ready Logic and Reset

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

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


## DMA CHANNELS

The MBL 80188 DMA controller provides two independent high-speed DMA channels. Data transfers can occur between memory and I/O spaces (e.g., Memory to $1 / O$ ) or within the same space (e.g., Memory to Memory or 1/O to I/O). Each DMA channel maintains both a 20-bit source and destination pointer which can be optionally incremented or decremented after each data transfer. Each data transfer consumes 2 bus cycles (a minimum of 8 clocks), one cycle to fetch data and the other to store data. This provides a maximum data transfer rate of one MByte/sec.

## DMA Operation

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

Table 13 - DMA CONTROL BLOCK FORMAT

| Register Name | Register Address |  |
| :--- | :---: | :---: |
|  | Ch. 0 | Ch. 1 |
| Control Word | CAH | DAH |
| Transfer Counter | C8H | D8H |
| Destination Pointer (upper 4 bits) | C6H | D6H |
| Destination Pointer | C4H | D4H |
| Source Pointer (upper 4 bits) | C2H | D2H |
| Source Pointer | COH | DOH |

## DMA Channel Control Word Register

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

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

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

Fig. 16 - MPCS REGISTER

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

Fig. 17 - DMA UNIT BLOCK DIAGRAM


Fig. 18 - DMA CONTROL REGISTER


X = DON'T CARE.

## DMA Control Word Bit Descriptions

ST/STOP:
Start/Stop (1/0) Channel.
$\mathrm{CHG} / \overline{\mathrm{NOCHG}}$ : Change/Do not change (1/0) ST/ $\overline{\mathrm{STOP}}$ bit. If this bit is set when writing to the control word, the ST/STOP bit will be programmed by the write to the control word. If this bit is cleared when writing the control word, the ST/ $\overline{\mathrm{STOP}}$ bit will not be altered. This bit is not stored; it will always be a 0 on read.

INT: Enable Interrupts to CPU on byte count termination.
TC: If set, DMA will terminate when the contents of the Transfer Count register reach zero. The ST/STOP bit will also be reset at this point if TC is set. If this bit is cleared, the DMA unit will decrement the transfer count register for each DMA
cycle, but the DMA transfer will not stop when the contents of the TC register reach zero.

SYN:
(2 bits)

SOURCE: INC
$\mathrm{M} / \overline{\mathrm{IO}}$ Source pointer is in $\mathrm{M} / \mathrm{IO}$ space (1/0).
DEC Decrement source pointer by 1 after each transfer.

MBL 80188

DEST: INC Increment destination pointer by 1 after each transfer.
$\mathrm{M} / \overline{\mathrm{IO}}$ Destination pointer is in $\mathrm{M} / \mathrm{IO}$ space (1/0).
DEC Decrement destination pointer by 1 after each transfer.

P: Channel priority - relative to other channel.
0 : low priority.
1: high priority.
Channels will alternate cycles if both set at same priority level.
TDRQ: $\quad 0:$ Disable DMA requests from timer 2. 1: Enable DMA requests from timer 2.

Bit 3: Bit 3 is not used.
If both INC and DEC are specified for the same pointer, the pointer will remain constant after each cycle.

## DMA Destination and Source Pointer Registers

Each DMA channel maintains a 20 -bit source and a 20 -bit destination pointer. Each of these pointers takes up two full 16 -bit registers in the peripheral control block. The lower four bits of the upper register contain the upper four bits of the 20 -bit physical address (see Fig. 18a). These pointers may be individually incremented or decremented after each transfer. Each pointer may point into either memory or I/O space. Since the DMA channels can perform transfers to or from odd addresses, there is no restriction on values for the pointer registers.

## DMA Transfer Count Register

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

## DMA Requests

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

Table 14 - MAXIMUM DMA TRANSFER RATES

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

## DMA Acknowledge

No explicit DMA acknowledge pulse is provided. Since both source and destination pointers are maintained, a read from

Fig. 18a - DMA MEMORY POINTER REGISTER FORMAT

| HIGHER REGISTER ADDRESS | XXX | XXX | XXX | A19-A16 |
| :---: | :---: | :---: | :---: | :---: |
| LOWER REGISTER ADDRESS | A15-A12 | A11-A8 | A7-A4 | A3-A0 |

XXX = DON'T CARE
a requesting source, or a write to a requesting destination, should be used as the DMA acknowledge signal. Since the chip-select lines can be programmed to be active for a given block of memory or I/O space, and the DMA pointers can be programmed to point to the same given block, a chipselect line could be used to indicate a DMA acknowledge.

## DMA Priority

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

## DMA Programming

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

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

## DMA Channels and Reset

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

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


## TIMERS

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

## Timer Operation

The timers are controlled by 11 16-bit registers in the internal peripheral control block. The configuration of these registers is shown in Table 15. The count register contains the current value of the timer. It can be read or written at any time independent of whether the timer is running or not. The value of this register will be incre-

Fig. 19 - TIMER BLOCK DIAGRAM

mented for each timer event. Each of the timers is equipped with a MAX COUNT register, which defines the maximum count the timer will reach. After reaching the MAX COUNT register value, the timer count value will reset to zero during that same clock, i.e., the maximum count value is never stored in the count register itself. Timers 0 and 1 are, in addition, equipped with a second MAX COUNT register, which enables the timers to alternate their count between two different MAX COUNT values programmed by the user. If a single MAX COUNT register is used, the timer output pin will switch LOW for a single clock, 2 clocks after the maximum count value has been reached. In the dual MAX COUNT register mode, the output pin will indicate which MAX COUNT register is currently in use, thus allowing nearly complete freedom in selecting waveform duty cycles. For the timers with two MAX COUNT registers, the RIU bit in the control register determines which is used for the comparison.

Each timer gets serviced every fourth CPU-clock cycle, and thus can operate at speeds up to one-quarter the internal clock frequency (one-eighth the crystal rate). External clocking of the timers may be done at up to a rate of one-quarter of the internal CPU-clock rate $(2 \mathrm{MHz}$ for an 8 MHz CPU clock). Due to internal synchronization and pipelining of the timer circuitry, a timer output may take up to 6 clocks to respond to any individual clock or gate input. Since the count registers and the maximum count registers are all 16 bits wide, 16 bits of resolution are provided. Any Read or Write access to the timers will add one wait state to the minimum four-clock bus cycle, however. This is needed to synchronize and coordinate the internal data flows between the internal timers and the internal bus.

The timers have several programmable options.

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

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

## Timer Mode/Control Register

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

Table 15 - TIMER CONTROL BLOCK FORMAT

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

## ALT:

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

## CONT:

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

## EXT:

The external bit selects between internal and external clocking for the timer. The external signal may be asynchronous with respect to the MBL 80188 clock. If this bit is set, the timer will count LOW-to-HIGH transitions on the input pin. If cleared, it will count an internal clock while using the input pin for control. In this mode, the function of the external pin is defined by the RTG bit.

Fig. 20 - TIMER MODE/CONTROL REGISTER

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

The maximum input to output transition latency time may be as much as 6 clocks. However, clock inputs may be pipelined as closely together as every 4 clocks without losing clock pulses.

## P:

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

## RTG:

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

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

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

## EN:

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

## INH:

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

## INT:

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

## MC:

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

## RIU:

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

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

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

## Count Registers

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

## Max Count Registers

Timers 0 and 1 have two MAX COUNT registers, while timer 2 has a single MAX COUNT register. These contain the number of events the timer will count. In timers 0 and 1, the MAX COUNT register used can alternate between the two max count values whenever the current maximum count is reached. The condition which causes a timer to reset is equivalent between the current count value and the max count being used. This means that if the count is changed to be above the max count value, or if the max count value is changed to be below the current value, the timer will not reset to zero, but rather will count to its maximum value, "wrap around" to zero, then count until the max count is reached.

## Timers and Reset

Upon RESET, the Timers will perform the following actions:

- All EN (Enable) bits are reset preventing timer counting.
- All SEL (Select) bits are reset to zero. This selects MAX COUNT register A, resulting in the Timer Out pins going HIGH upon RESET.


## INTERRUPT CONTROLLER

The MBL 80188 can receive interrupts from a number of sources, both internal and external. The internal interrupt controller serves to merge these requests on a priority basis, for individual service by the CPU.
Internal interrupt sources (Timers and DMA channels) can be disabled by their own control registers or by mask bits within the interrupt controller. The MBL 80188 interrupt controller has its own control registers that set the mode of operation for the controller.

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

The interrupt controller has a special iRMX 86 compatibility mode that allows the use of the MBL 80188 within
the iRMX 86 operating system interrupt structure. The controller is set in this mode by setting bit 14 in the peripheral control block relocation register (see iRMX 86 Compatibility Mode section). In this mode, the internal MBL 80188 interrupt controller functions as a "slave" controller to an external "master" controller. Special initialization software must be included to properly set up the MBL 80188 interrupt controller in iRMX 86 mode.

## NON-iRMX MODE OPERATION

## Interrupt Controller External Interface

For external interrupt sources, five dedicated pins are provided. One of these pins is dedicated to NMI, nonmaskable interrupt. This is typically used for power-fail interrupts, etc. The other four pins may function either as four interrupt input lines with internally generated interrupt vectors, as an interrupt line and an interrupt acknowledge line (called the "cascade mode") along with two other input lines with internally generated interrupt vectors, or as two interrupt input lines and two dedicated interrupt acknowledge output lines. When the interrupt lines are configured in cascade mode, the MBL 80188 interrupt controller will not generate internal interrupt vectors.

External sources in the cascade mode use externally gene-

Fig. 21 - INTERRUPT CONTROLLER BLOCK DIAGRAM

rated interrupt vectors. When an interrupt is acknowledged, two INTA cycles are initiated and the vector is read into the MBL 80188 on the second cycle. The capability to interface to external MBL 8259A programmable interrupt controllers is thus provided when the inputs are configured in cascade mode.

## Interrupt Controller Modes of Operation

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

## - Fully Nested Mode

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

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

## - Cascade Mode

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

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

## - Special Fully Nested Mode

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

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

## Operation in a Polled Environment

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

Service bit of the highest-priority source to be set.

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

## Non-iRMX Mode Features

## - Programmable Priority

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

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

## - End-of-Interrupt Command

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

## - Trigger Mode

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

## - Interrupt Vectoring

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

## Interrupt Controller Registers

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

- In-Service Register

This register can be read from or written into. The format

Fig. 22 - CASCADE MODE INTERRUPT CONNECTION


Fig. 23 - INTERRUPT CONTROLLER REGISTERS (NON-iRMX 86 MODE)

| INT3 CONTROL REGISTER |
| :---: |
| INT2 CONTROL REGISTER |
| INT1 CONTROL REGISTER |
| INTO CONTROL REGISTER |
| DMA1 CONTROL REGISTER |
| DMAO CONTROL REGISTER |
| TIMER CONTROL REGISTER |
| INTERRUPT STATUS REGISTER |
| INTERRUPT REQUEST REGISTER |
| IN-SERVICE REGISTER |
| PRIORITY MASK REGISTER |
| MASK REGISTER |
| POLL STATUS REGISTER |
| POLL REGISTER |
| EOI REGISTER |

is shown in Fig. 24. It contains the In-Service bit for each of the interrupt sources. The In -Service bit is set to indicate that a source's service routine is in progress. When an in Service bit is set, the interrupt controller will not generate interrupts to the CPU when it receives interrupt requests from devices with a lower programmed priority level. The

TMR bit is the In-Service bit for all three timers; the DO and D1 bits are the In-Service bits for the two DMA channels; the $10-13$ are the $\ln$-Service bits for the external interrupt pins. The IS bit is set when the processor acknowledges an interrupt request either by an interrupt acknowledge or by reading the poll register. The IS bit is reset at the end of the interrupt service routine by an end-of-interrupt command issued by the CPU.

## - Interrupt Request Register

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

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

## - Mask Register

This is a 16 -bit register that contains a mask bit for each interrupt source. The format for this register is shown in

Fig. 24 - IN-SERVICE, INTERRUPT REQUEST, AND MASK REGISTER FORMATS

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

Fig. 25 - PRIORITY MASK REGISTER FORMAT


Fig. 26 - INTERRUPT STATUS REGISTER FORMAT


Fig. 24. A one in a bit position corresponding to a particular source serves to mask the source from generating interrupts. These mask bits are the exact same bits which are used in the individual control registers; programming a mask bit using the mask register will also change this bit in the individual control registers, and vice versa.

## - Priority Mask Register

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

## - Interrupt Status Register

This register contains general interrupt controller status information. The format of this register is shown in Fig. 26. The bits in the status register have the following functions:
DHLT: DMA Halt Transfer; setting this bit halts all DMA transfers. It is automatically set whenever a non-maskable interrupt occurs, and it is reset when an IRET instruction is executed. The purpose of this bit is to allow prompt service of all non-maskable interrupts. This bit may also be set by the CPU.

IRTx: These three bits represent the individual timer interrupt request bits. These bits are used to differentiate the timer interrupts, since the timer IR bit in the interrupt request register is
the "OR" function of all timer interrupt requests. Note that setting any one of these three bits initiates an interrupt request to the interrupt controller.

## - Timer, DMA 0, 1 Control Registers

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

## - INTO-INT3 Control Registers

These registers are the control words for the four external input pins. Fig. 28 shows the format of the INTO and INT1 Control registers; Fig. 29 shows the format of the INT2 and INT3 Control registers. In cascade mode or special fully nested mode, the control words for INT2 and INT3 are not used.

The bits in the various control registers are encoded as follows:

PRO-2: Priority programming information. Highest priority $=000$, lowest priority $=111$.
LTM: Level-trigger mode bit. $1=$ level-triggered; $0=$ edge-triggered. Interrupt Input levels are active high. In level-triggered mode, an interrupt is generated whenever the external line is

Fig. 27 - TIMER/DMA CONTROL REGISTER FORMATS


Fig. 28 - INTO/INT1 CONTROL FORMATS


Fig. 29 - INT2/INT3 CONTROL REGISTER FORMATS

high. In edge-triggered mode, an interrupt will be generated only when this level is preceded by an inactive-to-active transition on the line. In both cases, the level must remain active until the interrupt is acknowledged.

MSK: $\quad$ Mask bit, 1 = mask; $0=$ nonmask.
C: $\quad$ Cascade mode bit, $1=$ cascade; $0=$ direct
SFNM: $\quad$ Special fully nested mode bit, $1=$ SFNM

## - EOI Register

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

The bits in the EOI register are encoded as follows:
Sx: Encoded information that specifies an interrupt source vector type as shown in Table 4. For example, to reset the In-Service bit for DMA channel 0, these bits should be set to 01010, since the vector type for DMA channel 0 is 10 . Note that to reset the single In-Service bit for any of the three timers, the vector type for timer 0 (8) should be written in this register.

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

## - Poll and Poll Status Registers

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

Encoding of the Poll and Poll Status register bits are as follows:

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

Table 16 - INTERNAL SOURCE PRIORITY LEVEL

| Priority Level | Interrupt Source |
| :---: | :---: |
| 0 | Timer 0 |
| 1 | (reserved) |
| 2 | DMA 0 |
| 3 | DMA 1 |
| 4 | Timer 1 |
| 5 | Timer 2 |

## iRMX 86 COMPATIBILITY MODE

This mode allows iRMX 86-80188 compatibility. The interrupt model of iRMX 86 requires one master and multiple slave MBL 8259As is cascaded fashion. When iRMX mode is used, the internal MBL 80188 interrupt controller will be used as a slave controller to an external master interrupt controller. The internal MBL 80188 resources will be monitored through the internal interrupt controller, while the external controller functions as the system master interrupt controller.

Upon reset, the MBL 80188 interrupt controller will be in the non-iRMX 86 mode of operation. To set the controller in the iRMX 86 mode, bit 14 of the Relocation Register should be set.

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

Fig. 30 - EOI REGISTER FORMAT


Fig. 31 - POLL REGISTER FORMAT


Fig. 32 - iRMX 86 INTERRUPT CONTROLLER INTERCONNECTION

and control word.
The iRMX 86 operating system requires peripherals to be assigned fixed priority levels. This is incompatible with the normal operation of the MBL 80188 interrupt controller. Therefore, the initialization software must program the proper priority levels for each source. The required priority levels for the internal interrupt sources in iRMX mode are shown in Table 16.

These level assignments must remain fixed in the iRMX 86 mode of operation.

## iRMX $\mathbf{8 6}$ Mode External Interface

The configuration of the MBL 80188 with respect to an external MBL 8259A master is shown in Fig. 32. The INTO input is used as the MBL 80188 CPU interrupt input. INT3 functions as an output to send the MBL 80188 slave-interrupt-request to one of the 8 master-PIC-inputs.

Correct master-slave interface requires decoding of the slave addresses (CASO-2). Slave MBL 8259As do this internally. Because of pin limitations, the MBL 80188 slave address will have to be decoded externally. $\overline{\text { NT1 }}$ is used as a slave-select input. Note that the slave vector address is transferred internally, but the READY input must be supplied externally.

INT2 is used as an acknowledge output, suitable to drive
the $\overline{\text { INTA }}$ input of an MBL 8259A.

## Interrupt Nesting

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

## Vector Generation in the iRMX $\mathbf{8 6}$ Mode

Vector generation in iRMX mode is exactly like that of an MBL 8259A slave. The interrupt controller generates an 8 -bit vector which the CPU multiplies by four and uses as an address into a vector table. The significant five bits of the vector are user-programmable while the lower three bits are generated by the priority logic. These bits represent the encoding of the priority level requesting service. The significant five bits of the vector are programmed by writing to the Interrupt Vector register at offset 20H.

## Specific End-of-Interrupt

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

## Interrupt Controller Registers in the iRMX $\mathbf{8 6}$ Mode

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

## - End-of-Interrupt Register

The end-of-interrupt register is a command register which can only be written. The format of this register is shown in Fig. 34. It initiates an EOI command when written by the MBL 80188 CPU.

The bits in the EOI register are encoded as follows:
Lx: Encoded value indicating the priority of the IS bit to be reset.

## - In-Service Register

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

## - Interrupt Request Register

This register indicates which internal peripherals have interrupt requests pending. The format of this register is shown in Fig. 35. The interrupt request bits are set when a request arrives from an internal source, and are reset when the processor acknowledges the request.

## - Mask Register

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

Fig. 33 - INTERRUPT CONTROLLER REGISTERS (iRMX 86 MODE)

| LEVEL 5 CONTROL REGISTER (TIMER 2) | OFFSET $3 \mathrm{AH}$ |
| :---: | :---: |
| LEVEL 4 CONTROL REGISTER <br> (TIMER 1) | 38H |
| LEVEL 3 CONTROL REGISTER <br> (DMA 1) | 36 H |
| LEVEL 2 CONTROL REGISTER (DMA 0) | 34 H |
| LEVEL O CONTROL REGISTER (TIMER 0) | 32 H |
| INTERRUPT STATUS REGISTER | 30 H |
| INTERRUPT REQUEST REGISTER | 2EH |
| IN-SERVICE REGISTER | 2 CH |
| PRIORITY-LEVEL MASK REGISTER | 2AH |
| MASK REGISTER | 28 H |
| SPECIFIC EOI REGISTER | 22 H |
| INTERRUPT VECTOR REGISTER | 20 H |

register corresponding to the bit.

## - Control Registers

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

The bits of the Control Registers are encoded as follows: PRx: 3-bit encoded field indicating a priority level for the source; not that each source must be programmed at specified levels.
MSK: mask bit for the priority level indicated by PRx bits.

Fig. 34 - SPECIFIC EOI REGISTER FORMAT


Fig. 35 - IN-SERVICE, INTERRUPT REQUEST, AND MASK REGISTER FORMATS


## - Interrupt Vector Register

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

The format of the bits in this register is:
tx : $\quad 5$-bit field indicating the upper five bits of the vector address.

## - Priority-Level Mask Register

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

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

## Interrupt Status Register

This register is defined exactly as in non-i RMX mode (see Fig. 26).

## Interrupt Controller and Reset

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

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

Fig. 36 - CONTROL WORD FORMAT

| 15 | 14 | 13 |  |  |  |  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | - | . | - | - | 0 | 0 | 0 | 0 | 0 | MSK | PR2 | PR1 | PRO |

Fig. 37 - INTERRUPT VECTOR REGISTER FORMAT


Fig. 38 - PRIORITY LEVEL MASK REGISTER FORMAT


Fig. 39 - TYPICAL MBL 80188 COMPUTER


PRCLIMINAPY
MBL 80188


Fig. 40 - TYPICAL MBL 80188 MULTI-MASTER BUS INTERFACE


## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature under Bias ........ . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin with
Respect to Ground
-1.0 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 3 Watt
*NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ}$ to $70^{\circ} \mathrm{C}$ )

Applicable to MBL 80188 ( 8 MHz ) and MBL $80188-6$ ( 6 MHz )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage <br> (All except $\times 1$ and $\overline{R E S}$ ) | 2.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{1 \mathrm{H}_{1}}$ | Input High Voltage ( $\overline{\mathrm{RES}}$ ) | 3.0 | $\mathrm{V}_{\mathrm{cc}}+0.5$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA} \text { for } \overline{\mathrm{SO}} \cdot \overline{\mathrm{~S} 2} \\ & \mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA} \text { for all other outputs } \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| Icc | Power Supply Current |  | $\frac{550}{450}$ | mA | Max measured at $\frac{T_{A}=0^{\circ} \mathrm{C}}{\mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}}$ |
| $I_{\text {L }}$ I | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV}<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {CC }}$ |
| ILO | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V}<\mathrm{V}_{\text {OUT }}<\mathrm{V}_{\text {CC }}$ |
| $\mathrm{V}_{\text {CLI }}$ | Clock Input Low Voltage | -0.5 | 0.6 | V |  |
| VCHI | Clock Input High Voltage | 3.9 | $\mathrm{V}_{C C}+1.0$ | V |  |
| $\mathrm{V}_{\text {CLO }}$ | Clock Output Low Voltage |  | 0.6 | V | $\mathrm{l}^{\mathrm{OL}}=4.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{CHO}}$ | Clock Output High Voltage | 4.0 |  | $\checkmark$ | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{Cin}_{\text {I }}$ | Input Capacitance |  | 10 | pF |  |
| $\mathrm{ClO}_{10}$ | I/O Capacitance |  | 20 | pF |  |

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

MBL 80188 Timing Requirements All Timings Measured At 1.5 Volts Unless Otherwise Noted.
Applicable to MBL 80188 ( 8 MHz ) and MBL $80188-6$ ( 6 MHz )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| TDVCL | Data in Setup Time (A/D) | 20 |  | ns |  |
| TCLDX | Data in Hold Time (A/D) | 10 |  | ns |  |
| TARYHCH | Asynchronous Ready <br> (AREADY) Active Setup Time* | 20 |  | ns |  |
| TARYLCL | AREADY Inactive Setup Time | 35 |  | ns |  |
| TARYCHL | Asynchronous Ready Inactive <br> Hold Time | 15 |  | ns |  |
| TCHARYX | AREADY Hold Time | 15 |  | ns |  |
| TSRYCL | Synchronous Ready <br> (SREADY) Transition Setup Time | 20 |  | ns |  |
| TCLSRY | SREADY Transition Hold Time | 15 |  | ns |  |
| THVCL | HOLD Setup Time* | 25 |  | ns |  |
| TINVCH | INTR, NMI, TEST, TIMERIN, <br> Setup Time* | 25 |  | ns |  |
| TINVCL | DRQO, DRQ1, Setup Time* | 25 |  |  |  |

* To guarantee recognition at next clock.


## MBL 80188


FUJITSU
Preliminary


## A.C. CHARACTERISTICS (Continued)

MBL 80188 Master Interface Timing Responses

| Symbol | Parameters | MBL 80188 (8 MHz) |  | MBL 80188-6 ( 6 MHz ) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TCLAV | Address Valid Delay | 5 | 55 | 5 | 63 | ns | $C_{L}=20-200 p F$ <br> all outputs |
| TCLAX | Address Hold Time | 10 |  | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 35 | TCLAX | 44 | ns |  |
| TCHCZ | Command Lines Float Delay |  | 45 |  | 56 | ns |  |
| TCHCV | Command Lines Valid Delay (after Float) |  | 55 |  | 76 | ns |  |
| TLHLL | ALE Width | TCLCL-35 |  | TCLCL-35 |  | ns |  |
| TCHLH | ALE Active Delay |  | 35 |  | 44 | ns |  |
| TCHLL | ALE Inactive Delay |  | 35 |  | 44 | ns |  |
| TLLAX | Address Hold Time to ALE Inactive | TCHCL-25 |  | TCHCL-30 |  | ns |  |
| TCLDV | Data Valid Delay | 10 | 44 | 10 | 55 | ns |  |
| TCLDOX | Data Hold Time | 10 |  | 10 |  | ns |  |
| TWHDX | Data Hold Time after $\overline{W R}$ | TCLCL-40 |  | TCLCL-50 |  | ns |  |
| TCVCTV | Control Active Delay 1 | 10 | 70 | 10 | 87 | ns |  |
| TCHCTV | Control Active Delay 2 | 10 | 55 | 10 | 76 | ns |  |
| TCVCTX | Control Inactive Delay | 5 | 55 | 5 | 76 | ns- |  |
| TCVDEX | DEN Inactive Delay (Non-Write Cycle) | 10 | 70 | 10 | 87 | ns |  |
| TAZRL | Address Float to $\overline{\mathrm{RD}}$ Active | 0 |  | 0 |  | ns |  |
| TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 10 | 70 | 10 | 87 | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 55 | 10 | 76 | ns |  |
| TRHAV | $\overline{\mathrm{RD}}$ Inactive to Address Active | TCLCL-40 |  | TCLCL-50 |  | ns |  |
| TCLHAV | HLDA Valid Delay | 5 | 50 | 5 | 67 | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Width | 2TCLCL-50 |  | 2TCLCL-50 |  | ns |  |
| TWLWH | $\overline{\text { WR Width }}$ | 2TCLCL-40 |  | 2TCLCL-40 |  | ns |  |
| TAVAL | Address Valid to ALE Low | TCLCH-25 |  | TCLCH-45 |  | ns. |  |
| TCHSV | Status Active Delay | 10 | 55 | 10 | 76 | ns |  |
| TCLSH | Status Inactive Delay | 10 | 65 | 10 | 76 | ns |  |
| TCLTMV | Timer Output Delay |  | 60 |  | 75 | ns | 100 pF max |
| TCLRO | Reset Delay |  | 60 |  | 75 | ns |  |
| TCHOSV | Queue Status Delay |  | 35 |  | 44 | ns |  |
| TCHDX | Status Hold Time | 10 |  | 10 |  | ns |  |
| TAVCH | Address Valid to Clock High | 10 |  | 10 |  | ns |  |

MBL 80188 Chip-Select Timing Responses

| Symbol | Parameter | MBL 80188 (8 MHz) |  | MBL 80188-6 ( 6 MHz ) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TCLCSV | Chip-Select Active Delay |  | 66 |  | 80 | ns |  |
| TCXCSX | Chip-Select Hold Time from Command Inactive | 35 |  | 35 |  | ns |  |
| TCHCSX | Chip-Select Inactive Delay | 5 | 35 | 5 | 47 | ns |  |

FUJITSEU
MBL 80188


## A.C. CHARACTERISTICS (Contiuned)

MBL 80188 CLKIN Timing Requirements

| Symbol | Parameter | MBL 80188 (8 MHz) |  | MBL 80188-6 ( 6 MHz ) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TCKIN | CLKIN Period | 62.5 | 250 | 83 | 250 | ns |  |
| TCKHL | CLKIN Fall Time |  | 10 |  | 10 | ns | 3.5 V to 1.0 V |
| TCKLH | CLKIN Rise Time |  | 10 |  | 10 | ns | 1.0 V to 3.5 V |
| TCLCK | CLKIN Low Time | 25 |  | 33 |  | ns | 1.5 V |
| TCHCK | CLKIN High Time | 25 |  | 33 |  | ns | 1.5 V |

MBL 80188 CLKOUT Timing Responses ( 200 pF load)

| Symbol | Parameter | MBL 80188 ( 8 MHz ) |  | MBL 80188-6 (6 MHz) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TCICO | CLKIN to CLKOUT Skew |  | 50 |  | 62.5 | ns |  |
| TCLCL | CLKOUT Period | 125 | 500 | 167 | 500 | ns |  |
| TCLCH | CLKOUT Low Time | ½TCLCL-7.5 |  | 1/2TCLCL-7.5 |  | ns | 1.5 V |
| TCHCL | CLKOUT High Time | ½TCLCL-7.5 |  | ½TCLCL-7.5 |  | ns | 1.5 V |
| TCH1CH2 | CLKOUT Rise Time |  | 15 |  | 15 | ns | 1.0 V to 3.5 V |
| TCL2CL1 | CLKOUT Fall Time |  | 15 |  | 15 | ns | 3.5 V to 1.0 V |

MAJOR CYCLE TIMING


## WAVEFORMS (Continued)



## NOTES:

1. Following a Write cycle, the Local Bus is floated by the MBL 80188 only when the MBL 80188 enters a "Hold Acknowledge" state.
2. INTA occurs one clock later in iRMX-mode.
3. Status inactive just prior to T4.

WAVEFORMS (Continued)


WAVEFORMS (Continued)

HOLD-HLDA TIMING



WAVEFORMS (Continued)

TIMER ON MBL 80188


## MBL 80188 INSTRUCTION TIMINGS

The following instruction timings represent the minimum execution time in clock cycles for each instruction. The timings given are based on the following assumptions:

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

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

All instructions which involve memory reference can require one (and in some cases, two) additional clocks above the minimum timings shown. This is due to the asynchronous nature of the handshake between the BIU and the Execution unit.

## INSTRUCTION SET SUMMARY



[^10]*Note: Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

INSTRUCTION SET SUMMARY (Continued)

| FUNCTION | FORMAT |  |  |  | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC |  |  |  |  |  |  |
| ADD = Add: |  |  |  |  |  |  |
| Reg/memory with register to either | 000000 dw | mod reg r/m |  |  | 3/10* |  |
| Immediate to register/memory | 100000 sw | mod $000 \mathrm{r} / \mathrm{m}$ | data | data if s w $=01$ | 4/16* |  |
| Immediate to accumulator | 0000010 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| ADC = Add with carry: |  |  |  |  |  |  |
| Reg/memory with register to either Immediate to register/memory | 000100 dw | mod reg r/m |  |  | 3/10* |  |
|  | 100000 sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s} \mathbf{w}=01$ | 4/16* |  |
| Immediate to accumulator | 0001010 w | data | data if w=1 |  | 3/4 | 8/16-bit |
| INC = Increment: |  |  |  |  |  |  |
| Register/memory | (1111111m | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | 3/15* |  |
| Register | 01000 reg |  |  |  | 3 |  |
| SUB = Subtract: |  |  |  |  |  |  |
| Reg/memory and register to either | 001010 dw | mod reg r/m |  |  | 3/10* |  |
| Immediate from register/memory Immediate from accumulator | 100000 sw | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s} w=01$ | 4/16* |  |
|  | 0010110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| SBB = Subtract with borrow: |  |  |  |  |  |  |
| Reg/memory and register to either | 000110 dw | mod reg r/m |  |  | 3/10* |  |
| Immediate from register/memory | 100000 sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if s w = 01 | 4/16* |  |
| Immediate from accumulator | 0001110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| DEC = Decrement: |  |  |  |  |  |  |
| Register/memory | 11111111m | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  | 3/15* |  |
| Register | 01001 reg |  |  |  | 3 |  |
| CMP = Compare: |  |  |  |  |  |  |
| Register/memory with register | 0011101 w | mod reg r/m |  |  | 3/10* |  |
| Register with register/memory | 0011100 w | mod reg r/m |  |  | 3/10* |  |
| Immediate with register/memory | 100000 sw | mod $111 \mathrm{r} / \mathrm{m}$ | data | data if s w $=01$ | 3/10* |  |
| Immediate with accumulator | 0011110 w | data | data if $w=1$ |  | 3/4 | 8/16-bit |
| NEG = Change sign |  | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  | 3 |  |
| AAA $=$ ASCII adjust for add | 00110111 |  |  |  | 8 |  |
| DAA $=$ Decimal adjust for add | 00100111 |  |  |  | 4 |  |
| AAS $=$ ASCII adjust for subtract | 00111111 |  |  |  | 7 |  |
| DAS = Decimal adjust for subtract | 00101111 |  |  |  | 4 |  |
| MUL = Multiply (unsig | 1111011w | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  |  |  |
| Register-Byte |  |  |  |  | 26-28 |  |
| Register-Word |  |  |  |  | 35-37 |  |
| Memory-Byte |  |  |  |  | 32-34 |  |
| Memory-Word |  |  |  |  | 41-43* |  |
| IMUL = Integer multiply (signed) | 1111011w | $\bmod 101 \mathrm{r} / \mathrm{m}$ |  |  |  |  |
| Register-Byte |  |  |  |  | 25-28 |  |
| Register-Word |  |  |  |  | 34-37 |  |
| Memory-Byte |  |  |  |  | 31-34 |  |
| Memory-Word |  |  |  |  | 40-43* |  |
| IMUL = Integer immediate multiply (signed) | 011010 s 1 | mod reg r/m | data | data if $\mathrm{s}=0$ | $\begin{aligned} & 22-251 \\ & 29-32^{*} \end{aligned}$ |  |
| DIV = Divide (unsigned) : | 1111011w | $\bmod 110 \mathrm{r} / \mathrm{m}$ |  |  |  |  |
| Register-Byte |  |  |  |  | 29 |  |
| Register-Word |  |  |  |  | 38 |  |
| Memory-Byte |  |  |  |  | 35 |  |
| Memory-Word |  |  |  |  | 44* |  |

[^11]INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.
*Note: Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

## INSTRUCTION SET SUMMARY (Continued)



Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.
*Note: Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

## INSTRUCTION SET SUMMARY (Continued)



[^12]
## INSTRUCTION SET SUMMARY (Continued)

| FUNCTION | FORMAT | Clock Cycles | Comments |
| :---: | :---: | :---: | :---: |
| PROCESSOR CONTROL |  |  |  |
| CLC = Clear carry | 11111000 | 2 |  |
| CMC = Complement carry | 11110101 | 2 |  |
| STC = Set carry | 11111001 | 2 |  |
| CLD = Clear direction | 11111100 | 2 |  |
| STD = Set direction | 11111101 | 2 |  |
| CLI = Clear interrupt | 11111010 | 2 |  |
| STI = Set interrupt |  | 2 |  |
| HLT = Halt | \|11110100 | 2 |  |
| WAIT = Wait | 10011011 | 6 | if $\overline{\text { test }}=0$ |
| LOCK = Bus lock prefix | 11110000 | 2 |  |
| ESC = Processor extension escape | 11011 T | 6 |  |
| (TTT LLL are opcode to processor extension) |  |  |  |

Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

## FOOTNOTES

The Effective Address (EA) of the memory operand is computed according to the mod and $\mathrm{r} / \mathrm{m}$ fields:
if $\bmod =11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field if $\bmod =00$ then DISP $=0$ *, disp-low and disp-high are absent if $\bmod =01$ then DISP = disp-low sign-extended to 16 -bits, disp-high is absent
if $\bmod =10$ then DISP $=$ disp-high: disp-low
if $r / m=000$ then $E A=(B X)+(S I)+D I S P$
if $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 $r / m=100$ then EA $=(S I)+$ DISP
if $r / m=101$ then EA $=(D I)+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $E A=(B P)+D I S P^{*}$
$i f / r / m=111$ then $E A=(B X)+D I S P$
DISP follows 2nd byte of instruction (before data if required)
*except if $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then $E A=$ disp-high: disp-low.
EA calculation time is 4 clock cycles for all modes, and is included in the execution times given whenever appropriate.

REG is assigned according to the following table:

| 16-Bit $(w=1)$ | $8-$ Bit $(w=0)$ |
| :---: | :---: |
| 000 AX | 000 AL |
| 001 CX | 001 CL |
| 010 DX | 010 DL |
| 011 BX | 011 BL |
| 100 SP | 100 AH |
| 101 BP | 101 CH |
| 110 SI | 110 DH |
| 111 DI | 111 BH |

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

## SEGMENT OVERRIDE PREFIX

$$
001 \text { reg } 110
$$

reg is assigned according to the following:

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

## PACKAGE ILLUSTRATION



## PACKAGE DIMENSIONS (Suffix -CV)

68-PAD CERAMIC (METAL SEAL) LEADLESS CHIP CARRIER (CASE No.: LCC-68C-A01)


## MBL 80188



## PACKAGE ILLUSTRATION



PACKAGE DIMENSIONS (Suffix -CR)
68-LEAD CERAMIC (METAL SEAL) REPEATED QUAD IN-LINE PACKAGE (CASE No.: RIT-68C-A01)


## NMOS 8-BIT MICROPROCESSOR

The Fujitsu MBL 8088 is a new generation, high performance microprocessor implemented in N-channel, depletion load, silicon gate technology (NMOS), and packaged in a 40 -pin ceramic or plastic DIP. The processor has attributes of both 8 - and 16 -bit microprocessors. It is directly compatible with MBL 8086 software and Intel 8080/8085 hardware and peripherals.

- 8-Bit Data Bus Interface
- 16-Bit Internal Architecture
- Direct Addressing Capability to 1 Mbyte of Memory
Direct Software Compatibility with MBL 8086 CPU
14-Word by 16-Bit Register Set with Symmetrical Operations
- 24 Operand Addressing Modes
- Byte, Word, and Block Operations
- 8-Bit and 16-Bit Signed and Unsigned Arithmetic in Binary or Decimal, Including Multiply and Divide
- Compatible with 8155-2, 8755A-2 and 8185-2 Multiplexed Peripherals
- Two Clock Rates: 5 MHz for MBL 8088, 8 MHz for MBL 8088-2, 10MHz for MBL 8088-1
- 40-Pin DIP:

Ceramic DIP (Suffix: -C)
Plastic DIP (Suffix:-P)

Fig. 1 - BLOCK DIAGRAM


Fig. 2 - PIN CONFIGURATION


## TABLE 1 - PIN DESCRIPTION

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

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $A D_{7}-A D_{0}$ | 9-16 | I/O | Address Data Bus: These lines constitute the time multiplexed memory/IO address ( $T_{1}$ ) and data ( $T_{2}, T_{3}, T w$, and $T_{4}$ ) bus. These lines are active HIGH and float to 3 -state OFF during interrupt acknowledge and local bus "hold acknowledge". |
| $\mathrm{A}_{15}-\mathrm{A}_{8}$ | 2-8, 39 | 0 | Address Bus: These lines provide address bits 8 through 15 for the entire bus cycle $\left(T_{1}-T_{4}\right)$. These lines do not have to be latched by ALE to remain valid. $A_{15}-A_{8}$ are active HIGH and float to 3 -state OFF during interrupt acknowledge and local bus "hold acknowledge". |
| $\begin{aligned} & \mathrm{A}_{19} / \mathrm{S}_{6} \\ & \mathrm{~A}_{18} / \mathrm{S}_{5} \\ & \mathrm{~A}_{17} / \mathrm{S}_{4} \\ & \mathrm{~A}_{16} / \mathrm{S}_{3} \end{aligned}$ | 35-38 | 0 | Address/Status: During $\mathrm{T}_{1}$, these are the four most significant address lines for memory operations. During I/O operations, these lines are LOW. During memory and I/O operations, status information is avalable on these lines during $T_{2}, T_{3}, T w$, and $T_{4} . S_{6}$ is always low. The status of the interrupt enable flag bit ( $\mathrm{S}_{5}$ ) is updated at the beginning of each clock cycle. $\mathrm{S}_{4}$ and $\mathrm{S}_{3}$ are encoded as shown. <br> This information indicates which segment register is presently being used for data accessing. <br> These lines float to 3 -state OFF during local bus "hold acknowledge". |
| $\overline{\mathrm{RD}}$ | 32 | 0 | Read: Read strobe indicates that the processor is performing a memory or I/O read cycle, depending on the state of the $10 / \bar{M}$ pin or $S_{2}$. This signal is used to read devices which reside on the MBL 8088 local bus. $\overline{\mathrm{RD}}$ is active LOW during $T_{2}, T_{3}$ and $T w$ of any read cycle, and is guaranteed to remain HIGH in $T_{2}$ until the MBL 8088 local bus has floated. <br> This signal floats to 3 -state OFF in "hold acknowledge". |
| READY | 22 | 1 | READY: is the acknowledgement from the addressed memory or I/O device that it will complete the data transfer. The RDY signal from memory or I/O is synchronized by the MBL 8284A clock generator to form READY. This signal is active HIGH. The MBL 8088 READY input is not synchronized. Correct operation is not guaranteed if the set up and hold times are not met. |
| INTR | 18 | 1 | Interrupt Request: is a level triggered input which is sampled during the last clock cycle of each instruction to determine if the processor should enter into an interrupt acknowledge operation. A subroutine is vectored to via an interrupt vector lookup table located in system memory. It can be internally masked by software resetting the interrupt enable bit. INTR is internally synchronized. This signal is active HIGH. |
| $\overline{\text { TEST }}$ | 23 | 1 | TEST: input is examined by the "wait for test" instruction. If the TEST input is LOW, execution continues, otherwise the processor waits in an "idle" state. This input is synchronized internally during each clock cycle on the leading edge of CLK. |
| NMI | 17 | 1 | Non-Maskable Interrupt: is an edge triggered input which causes a type 2 interrupt. A subroutine is vectored to via an interrupt vector lookup table located in system memory. NMI is not maskable internally by software. A transition from a LOW to HIGH initiates the interrupt at the end of the current instruction. This input is internally synchronized. |

## TABLE 1 - PIN DESCRIPTION (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :--- | :---: | :---: | :--- |
| RESET | 21 | I | RESET: causes the processor to immediately terminate its present activity. The signal <br> must be active HIGH for at least four clock cycles. It restarts execution, as described in <br> the instruction set description, when RESET returns LOW. RESET is internally syn- <br> chronized. |
| CLK | 19 | I | Clock: provides the basic timing for the processor and bus controller. It is asymmetric <br> with a 33\% duty cycle to provide optimized internal timing. |
| $\mathrm{V}_{\mathrm{CC}}$ | 40 |  | $\mathrm{~V}_{\mathrm{CC}}:$ is the $+5 \mathrm{~V} \pm 10 \%$ power supply pin. |
| GND | 1,20 |  | GND: are the ground pins. |
| $\mathrm{MN} / \overline{\mathrm{MX}}$ | 33 | I | Minimum/Maximum: indicates what mode the processor is to operate in. The two <br> modes are discussed in the following sections. |

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

| 10/M | 28 | 0 | Status Line: is an inverted maximum mode $\overline{\mathrm{S}}_{2}$. It is used to distinguish a memory access from an I/O access. IO/ $\bar{M}$ becomes valid in the $T_{4}$ preceding a bus cycle and remains valid until the final $T_{4}$ of the cycle (I/O=HIGH, $\left.\bar{M}=L O W\right)$. $10 / \bar{M}$ floats to 3 -state OFF in local bus "hold acknowledge". |
| :---: | :---: | :---: | :---: |
| $\overline{W R}$ | 29 | 0 | Write: strobe indicates that the processor is performing a write memory or write I/O cycle, depending on the state of the $10 / \bar{M}$ signal. $\overline{W R}$ is active for $T_{2}, T_{3}$, and $T_{w}$ of any write cycle. It is active LOW, and floats to 3 -state OFF in local bus "hold acknowledge". |
| $\overline{\text { INTA }}$ | 24 | 0 | INTA: is used as a read strobe for interrupt acknowledge cycles. It is active LOW during $T_{2}, T_{3}$, and $T_{w}$ of each interrupt acknowledge cycle. |
| ALE | 25 | 0 | Address Latch Enable: is provided by the processor to latch the address into the MBL 8282/8283 address latch. It is a HIGH pulse active during clock low of $T_{1}$ of any bus cycle. Note that ALE is never floated. |
| DT/ $\bar{R}$ | 27 | 0 | Data Transmit/Receive: is needed in a minimum system that desires to use an MBL 8286/8287 data bus transceiver. It is used to control to direction of data flow through the transceiver. Logically, $\mathrm{DT} / \overline{\mathrm{R}}$ is equivalent to $\mathrm{S}_{1}$ in the maximum mode, and its timing is the same as for $10 / \bar{M}$ ( $\mathrm{T}=\mathrm{HIGH}, \overline{\mathrm{R}}=\mathrm{LOW}$ ). This signal floats to 3 -state OFF in local "hold acknowledge". |
| $\overline{\text { DEN }}$ | 26 | 0 | Data Enable: is provided as an output enable for the MBL 8286/8287 in a minimum system which uses the transceiver. DEN is active LOW during each memory and I/O access, and for INTA cycles. For a read or INTA cycle, it is active from the middle of $T_{2}$ until the middle of $T_{4}$, while for a write cycle, it is active from the beginning of $T_{2}$ until the middle of $T_{4}$. $\overline{\mathrm{DEN}}$ floats to 3 -state OFF during local bus "hold acknowledge". |
| $\begin{aligned} & \text { HOLD, } \\ & \text { HLDA } \end{aligned}$ | 30, 31 | 1, 0 | HOLD: indicates that another master is requesting a local bus "hold". To be acknowledged, HOLD must be active HIGH. The processor receiving the "hold" request will issue HLDA (HIGH) as an acknowledgement, in the middle of a $T_{4}$ or $T_{1}$ clock cycle. Simultaneous with the issuance of HLDA the processor will float the local bus and control lines. After HOLD is detected as being LOW, the processor lowers HLDA, and when the processor needs to run another cycle, it will again drive the local bus and control lines. <br> Hold is not an asynchronous input. External synchronization should be provided if the system cannot otherwise guarantee the set up time. |

TABLE 1 - PIN DESCRIPTION (Continued)

| Symbol | Pin No. | Type | Name and Function |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SSO | 34 | 0 | Status line: is logically equivalent to $\overline{\mathrm{SO}}$ in the maximum mode. The combination of $\overline{\mathrm{SSO}}$, $10 / \bar{M}$ and $D T / \bar{R}$ allows the system to completely decode the current bus cycle status. | 10/M | DT/ $\bar{R}$ | $\overline{\text { SSO }}$ | Characteristics |
|  |  |  |  | 1 (HIGH) | 0 | 0 | Interrupt acknowledge |
|  |  |  |  | 1 | 0 | 1 | Read I/O Port |
|  |  |  |  | 1 | 1 | 0 | Write I/O Port |
|  |  |  |  | 1 | 1 | 1 | Halt |
|  |  |  |  | 0 (LOW) | 0 | 0 | Code Access |
|  |  |  |  | 0 | 0 | 1 | Read Memory |
|  |  |  |  | 0 | 1 | 0 | Write Memory |
|  |  |  |  | 0 | 1 | 1 | Passive |

The following pin function descriptions are for the MBL 8088, 8228 system in maximum mode (i.e., $\mathrm{MN} / \overline{\mathrm{MX}}=\mathrm{GND}$.) Only the pin functions which are unique to maximum mode are described; all other pin functions are as described above.

| $\overline{\mathrm{S} 2}, \overline{\mathrm{~s} 1}, \overline{\mathrm{~s} 0}$ | 26-28 | 0 | Status: is active during clock high of $T_{4}, T_{1}$, and $T_{2}$, and is returned to the passive state $(1,1,1)$ during $T_{3}$ or during $T_{w}$ when READY is HIGH. This status is used by the MBL 8288 bus controller to generate all memory and I/O access control signals. Any change by $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}$, or $\overline{\mathrm{SO}}$ during $\mathrm{T}_{4}$ is used to indicate the beginning of a bus cycle, and the return to the passive state in $\mathrm{T}_{3}$ or $\mathrm{T}_{w}$ is used to indicate the end of a bus cycle. <br> These signals float to 3 -state OFF during "hold acknowledge". During the first clock cycle after RESET becomes active, these signals are active HIGH. After this first clock they float to 3-state OFF. |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}, \\ & \overline{\mathrm{RO}} / \overline{\mathrm{GT1}} \end{aligned}$ | 30, 31 | 1/0 | Request/Grant: pins are used by other local bus masters to force the processor to release the local bus at the end of the processor's current bus cycle. Each pin is bidirectional with $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}_{0}$ having higher priority than $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}_{1} . \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ has an internal pull-up resistor, so may be left unconnected. The request/grant sequence is as follows (See Fig. 8): <br> 1. A pulse of one CLK wide from another local bus master indicates a local bus request ("hold") to the MBL 8088 (pulse 1). <br> 2. During a $T_{4}$ or $T_{1}$ clock cycle, a pulse one clock wide from the MBL 8088 to the requesting master (pulse 2), indicates that the MBL 8088 has allowed the local bus to float and that it will enter the "hold acknowledge" state at the next CLK. The CPU's bus interface unit is disconnected logically from the local bus during "hold acknowledge". The same rules as for HOLD/HOLDA apply as for when the bus is released. <br> 3. A pulse one CLK wide from the requesting master indicates to the MBL 8088 (pulse 3) that the "hold" request is about to end and that the MBL 8088 can reclaim the local bus at the next CLK. The CPU then enters $\mathrm{T}_{4}$. |

TABLE 1 - PIN DESCRIPTION (Continued)

| Symbol | Pin No. | Type | Name and Function |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}, \\ & \overline{\mathrm{RQ}} / \overline{\mathrm{GT} 1} \end{aligned}$ | 30, 31 | I/O | Each master-master exchange of the local bus is a sequence of three pulses. There must be one idle CLK cycle after each bus exchange. Pulses are active LOW. <br> If the request is made while the CPU is performing a memory cycle, it will release the local bus during $\mathrm{T}_{4}$ of the cycle when all the following conditions are met: <br> 1. Request occurs on or before $T_{2}$. <br> 2. Current cycle is not the low byte of a word. <br> 3. Current cycle is not the first acknowledge of an interrupt acknowledge sequence. <br> 4. A locked instruction is not currently executing. <br> If the local bus is idle when the request is made the two possible events will follow: <br> 1. Local bus will be released during the next clock. <br> 2. A memory cycle will start within 3 clocks. Now the four rules for a currently active memory cycle apply with condition number 1 already satisfied. |  |  |  |
| $\overline{\text { LOCK }}$ | 29 | 0 | $\overline{\text { LOCK: indicates that other system bus masters are not to gain control of the system bus }}$ while LOCK is active (LOW). The LOCK signal is activated by the "LOCK" prefix instruction and remains active until the completion of the next instruction. This signal is active LOW, and floats to 3 -state off in "hold acknowledge". |  |  |  |
| QS1, QSO | 24, 25 | 0 | Queue Status: provide status to allow external tracking of the internal MBL 8088 instruction queue. <br> The queue status is valid during the CLK cycle after which the queue operation is performed. | QS1 <br> 0 (LOW) <br> 0 <br> 1 (HIGH) <br> 1 | OSO | Characteristics <br> No operation <br> First byte of opcode <br> from queue <br> Empty the queue <br> Subsequent byte from <br> queue |
| - | 34 | 0 | Pin 34 is always high in the maximum mode. |  |  |  |

## FUNCTIONAL DESCRIPTION

## MEMORY ORGANIZATION

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

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

Word (16-bit) operands can be located on even or odd address boundaries. For address and data operands, the least significant byte of the word is stored in the lower valued address location and the most significant byte in the next higher address location. The BIU will automatically execute two fetch or write cycles for 16 -bit operands.

Certain locations in memory are reserved for specific CPU operations. (See Fig. 4.) Locations from addresses FFFFOH through FFFFFH are reserved for operations including a jump to the initial system initialization routine. Following RESET, the CPU will always begin execution at location FFFFOH where the jump must be located. Locations 00000H through 003FFH are reserved for interrupt operations. Four-byte pointers consisting of a 16 -bit segment address and a 16 -bit offset address direct program flow to one of the 256 possible interrupt service routines. The pointer elements are assumed to have been stored at their respective places in reserved memory prior to the occurrence of interrupts.

## MINIMUM AND MAXIMUM MODES

The requirements for supporting minimum and maximum MBL 8088 systems are sufficiently different that they cannot be done efficiently with 40 uniquely defined pins. Consequently, the MBL 8088 is equipped with a strap pin (MN/ $\overline{M X}$ ) which defines the system configuration. The definition of a certain subset of the pins changes, dependent on the condition of the strap pin. When the $M N / \overline{M X}$ pin is strapped to GND, the MBL 8088 defines pins 24 through 31 and 34 in maximum mode. When the

Fig. 3 - MEMORY ORGANIZATION


1

Fig. 4 - RESERVED MEMORY LOCATIONS

$\mathrm{MN} / \overline{\mathrm{MX}}$ pin is strapped to $\mathrm{V}_{\mathrm{CC}}$, the MBL 8088 generates bus control signals itself on pins 24 through 31 and 34.

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

The minimum mode MBL 8088 can be used with either a multiplexed or demultiplexed bus. The multiplexed bus configuration is compatible with the MCS-85* multiplexed bus peripherals (Intel 8155, 8156, 8355, 8755A, and 8185). This configuration (See Fig. 5.) provides the user with a minimum chip count system. This architecture provides the MBL 8088 processing power in a highly integrated form.

The demultiplexed mode requires one latch (for 64 K addressability) or two latches (for a full megabyte of addressing). A third latch can be used for buffering if the address bus loading requires it. An MBL 8286 or MBL 8287 transceiver can also be used if data bus buffering is required. (See Fig. 6.) The MBL 8088 provides $\overline{\mathrm{DEN}}$ and $\mathrm{DT} / \overline{\mathrm{R}}$ to control the transceiver, and ALE to
latch the addresses. This configuration of the minimum mode provides the standard demultiplexed bus structure with heavy bus buffering and relaxed bus timing requirements.

The maximum mode employs the MBL 8288 bus controller. (See Fig. 7.) The MBL 8288 decodes status lines $\overline{\mathrm{S}_{0}}, \overline{\mathrm{~S}}_{1}$, and $\overline{\mathrm{S}_{2}}$, and provides the system with all bus control signals. Moving the bus control to the MBL 8288 provides better source and sink current capability to the control lines, and frees the MBL 8088 pins for extended large system features. Hardware lock, queue status, and two request/grant interfaces are provided by the MBL 8088 in maximum mode. These features allow coprocessors in local bus and remote bus configurations.

[^13]Fig. 5 - MULTIPLEXED BUS CONFIGURATION


Fig. 6 - DEMULTIPLEXED BUS CONFIGRATION EXAMPLES (MINIMUM MODE)


Fig. 7 - FULLY BUFFERED SYSTEM EXAMPLE (MAXIMUM MODE)


MBL 8088
MBL 8088-2
MBL 8088-1

## BUS OPERATION

The MBL 8088 address/data bus is broken into three parts - the lower eight address/data bits $\left(A D_{0}-A D_{7}\right)$, the middle eight address bits ( $A_{8}-A_{15}$ ), and the upper four address bits $\left(A_{16}-A_{19}\right)$. The address/data bits and the highest four address bits are time multiplexed. This technique provides the most efficient use of pins on the
processor, permitting the use of a standard 40 lead package. The middle eight address bits are not multiplexed, i.e. they remain valid throughout each bus cycle. In addition, the bus can be demultiplexed at the processor with a single address latch if a standard, non-multiplexed bus is desired for the system.

Fig. 8 - BASIC SYSTEM TIMING


Each processor bus cycle consists of at least four CLK cycles. These are referred to as $T_{1}, T_{2}, T_{3}$, and $T_{4}$. (See Fig. 8). The address is emitted from the processor during $T_{1}$ and data transfer occurs on the bus during $T_{3}$ and $T_{4}$. $\mathrm{T}_{2}$ is used primarily for changing the direction of the bus during read operations. In the event that a "NOT READY' indication is given by the addressed device, "wait" states (Tw) are inserted between $\mathrm{T}_{3}$ and $\mathrm{T}_{4}$. Each inserted "wait" state is of the same duration as a CLK cycle. Periods can occur between MBL 8088 driven bus cycles. These are referred to as "idle" states (Ti), or inactive CLK cycles. The processor uses these cycles for internal housekeeping.
During $\mathrm{T}_{1}$ of any bus cycle, the ALE (address latch enable) signal is emitted (by either the processor or the MBL 8288 bus controller, depending on the $M N / \overline{M X}$ strap). At the trailing edge of this pulse, a valid address and certain status information for the cycle may be latched.
Status bits $\overline{\mathrm{S}}_{0}, \overline{\mathrm{~S}}_{1}$, and $\overline{\mathrm{S}}_{2}$ are used by the bus controller, in maximum mode, to identify the type of bus transaction according to the following table:

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

Status bits $\mathrm{S}_{3}$ through $\mathrm{S}_{6}$ are multiplexed with high order address bits and are therefore valid during $\mathrm{T}_{2}$ through $\mathrm{T}_{4}$, $S_{3}$ and $S_{4}$ indicate which segment register was used for this bus cycle in forming the address according to the following table:

| $\mathbf{S}_{4}$ | $\mathbf{S}_{\mathbf{3}}$ | CHARACTERISTICS |
| :--- | :---: | :--- |
| 0 (Low) | 0 | Alternate Data (Extra Segment) |
| 0 | 1 | Stack |
| 1 (High) | 0 | Code or None |
| 1 | 1 | Data |

$\mathrm{S}_{5}$ is a reflection of the PSW interrupt enable bit. $\mathrm{S}_{6}$ is always equal to 0 .

## I/O ADDRESSING

In the MBL 8088, I/O operations can address up to a maximum of $64 \mathrm{~K} \mathrm{I} / \mathrm{O}$ registers. The $\mathrm{I} / \mathrm{O}$ address appears in the same format as the memory address on bus lines $A_{15}-A_{0}$. The address lines $A_{19}-A_{16}$ are zero in $1 / O$ operations. The variable I/O instructions, which use register DX as a pointer, have full address capability, while the direct I/O instructions directly address one or two of the 256 I/O byte locations in page 0 of the I/O address space. I/O ports are addressed in the same manner as memory locations.
Designers familiar with the Intel 8085 or upgrading an 8085 design should note that the 8085 addresses I/O with an 8 -bit address on both halves of the 16 -bit address bus. The MBL 8088 uses a full 16 -bit address on its lower 16 address lines.

## EXTERNAL INTERFACE

## PROCESSOR RESET AND INITIALIZATION

Processor initialization or start up is accomplished with activation (HIGH) of the RESET pin. The MBL 8088 RESET is required to be HIGH for greater than foúr clock cycles. The MBL 8088 will terminate operations on the high-going edge of RESET and will remain dormant as long as RESET is HIGH. The low-going transition of RESET triggers an internal reset sequence for approximately 7 clock cycles. After this interval the MBL 8088 operates normally, beginning with the instruction in absolute location FFFFOH. (See Fig. 4.) The RESET input is internally synchronized to the processor clock. At initialization, the HIGH to LOW transition of RESET must occur no sooner than $50 \mu \mathrm{~s}$ after power up, to allow complete initialization of the MBL 8088.
If INTR is asserted sooner than nine clock cycles after the end of RESET, the processor may execute one instruction before responding to the interrupt.
All 3 -state outputs float to 3 -state OFF during RESET. Status is active in the idle state for the first clock after RESET becomes active and then floats to 3 -state OFF.

## INTERRUPT OPERATIONS

Interrupt operations fall into two classes: software or hardware initiated. The software initiated interrupts and software aspects of hardware interrupts are specified in the instruction set description in the MBL 8086 Family


#### Abstract

User's Manual. Hardware interrupts can be classified as non-maskable or maskable.

Interrupts result in a transfer of control to a new program location. A 256 element table containing address pointers to the interrupt service program locations resides in absolute locations 0 through 3FFH (see Fig. 4), which are reserved for this purpose. Each element in the table is 4 bytes in size and corresponds to an interrupt "type". An interrupting device supplies an 8 -bit type number, during the interrupt acknowledge sequence, which is used to vector through the appropriate element to the new interrupt service program location.


## NON-MASKABLE INTERRUPT (NMI)

The processor provides a single non-maskable interrupt (NMI) pin which has higher priority than the maskable interrupt request (INTR) pin. A typical use would be to activate a power failure routine. The NMI is edge-triggered on a LOW to HIGH transition. The activation of this pin causes a type 2 interrupt.
NMI is required to have a duration in the HIGH state of greater than two clock cycles, but is not required to be synchronized to the clock. Any higher going transition of NMI is latched on-chip and will be serviced at the end of the current instruction or between whole moves (2 bytes in the case of word moves) of a block type instruction. Worst case response to NMI would be for multiply, divide, and variable shift instructions. There is no specification on the occurrence of the low-going edge; it may occur before, during, or after the servicing of NMI. Another high-going edge triggers another response if it occurs after the start of the NMI procedure. The signal must be free of logical spikes in general and be free of bounces on the low-going edge to avoid triggering extraneous responses.

## MASKABLE INTERRUPT (INTR)

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

Until the old FLAGS register is restored, the enable bit will be zero unless specifically set by an instruction.
During the response sequence (See Fig. 9), the processor executes two successive (back to back) interrupt acknowledge cycles. The MBL 8088 emits the LOCK signal (maximum mode only) from $T_{2}$ of the first bus cycle until $\mathrm{T}_{2}$ of the second. A local bus "hold" request will not be honored until the end of the second bus cycle. In the second bus cycle, a byte is fetched from the external interrupt system (e.g., MBL 8259A PIC) which identifies the source (type) of the interrupt. This byte is multiplied by four and used as a pointer into the interrupt vector lookup table. An INTR signal left HIGH will be continually responded to within the limitations of the enable bit and sample period. The interrupt return instruction includes a flags pop which returns the status of the original interrupt enable bit when it restores the flags.

## HALT

When a software HALT instruction is executed, the processor indicates that it is entering the HALT state in one of two ways, depending upon which mode is strapped. In minimum mode, the processor issues ALE, delayed by one clock cycle, to allow the system to latch the halt status. Halt status is available on $10 / \bar{M}, ~ D T / \bar{R}$, and $\overline{\mathrm{SSO}}$. In maximum mode, the processor issues appropriate HALT status on $\overline{\mathrm{S}}_{2}, \overline{\mathrm{~S}}_{1}$, and $\overline{\mathrm{S}}_{0}$, and the MBL 8288 bus controller issues one ALE. The MBL 8088 will not leave the HALT state when a local bus hold is entered while in HALT. In this case, the processor reissues the HALT indicator at the end of the local bus hold. An interrupt request or RESET will force the MBL 8088 out of the HALT state.

## READ/MODIFY/WRITE (SEMAPHORE) OPERATIONS VIA LOCK

The $\overline{\text { LOCK }}$ status information is provided by the processor when consecutive bus cycles are required during the execution of an instruction. This allows the processor to perform read/modify/write operations on memory (via the "exchange register with memory" instruction), without another system bus master receiving intervening memory cycles. This is useful in multiprocessor system configurations to accomplish "test and set lock" operations. The $\overline{\text { LOCK }}$ signal is activated (LOW) in the clock cycle following decoding of the LOCK prefix instruction. It is deactivated at the end of the last bus cycle of the instruction following the LOCK prefix. While $\overline{\text { LOCK }}$ is active, a request on a $\overline{\mathrm{RO}} / \overline{\mathrm{GT}}$ pin will be recorded, and then honored at the end of the LOCK.


## EXTERNAL SYNCHRONIZATION VIA TEST

As an alternative to interrupts, the MBL 8088 provides a single software-testable input pin (TEST). This input is utilized by executing a WAIT instruction. The single WAIT instruction is repeatedly executed until the TEST input goes active (LOW). The execution of WAIT does not consume bus cycles once the queue is full.
If a local bus request occurs during WAIT execution, the MBL 8088 3-states all output drivers. If interrupts are enabled, the MBL 8088 will recognize interrupts and process them. The WAIT instruction is then refetched, and reexecuted.

## BASIC SYSTEM TIMING

In minimum mode, the $N M / \overline{M X}$ pin is strapped to $V_{c c}$ and the processor emits bus control signals compatible with the 8085 bus structure. In maximum mode, the $\mathrm{MN} / \overline{\mathrm{MX}}$ pin is strapped to GND and the processor emits coded status information which the MBL 8288 bus controller uses to generate MULTIBUS* compatible bus control signals.

## SYSTEM TIMING - MINIMUM SYSTEM

## (See Fig. 8)

The read cycle begins in $T_{1}$ with the assertion of the address latch enable (ALE) signal. The trailing (low going) edge of this signal is used to latch the address information,
which is valid on the address/data bus $\left(A D_{0}-A D_{7}\right)$ at this time, into the MBL 8282/8283 latch. Address lines $\mathrm{A}_{8}$ through $\mathrm{A}_{15}$ do not need to be latched because they remain valid throughout the bus cycle. From $T_{1}$ to $T_{4}$ the $10 / \bar{M}$ signal indicates a memory or $I / O$ operation. At $T_{2}$ the address is removed from the address/data bus and the bus goes to a high impedance state. The read control signal is also asserted at $T_{2}$. The read ( $\overline{\mathrm{RD}}$ ) signal causes the addressed device to enable its data bus drivers to the local bus. Some time later, valid data will be available on the bus and the addressed device will drive the READY line HIGH. When the processor returns the read signal to a HIGH level, the addressed device will again 3 -state its bus drivers. If a transceiver (MBL 8286/8287) is required to buffer the MBL 8088 local bus, signals $D T / \bar{R}$ and $\overline{D E N}$ are provided by the MBL 8088.
A write cycle also begins with the assertion of ALE and the emission of the address. The $10 / \bar{M}$ signal is again asserted to indicate a memory or I/O write operation. In $\mathrm{T}_{2}$, immediately following the address emission, the processor emits the data to be written into the addressed location. This data remains valid until at least the middle of $T_{4}$. During $T_{2}, T_{3}$, and $T_{W}$, the processor asserts the write control signal. The write ( $\overline{\mathrm{WR}}$ ) signal becomes active at the beginning of $T_{2}$, as opposed to the read, which is delayed somewhat into $T_{2}$ to provide time for the bus to float.

[^14]The basic difference between the interrupt acknowledge cycle and a read cycle is that the interrupt acknowledge ( $\overline{\mathrm{INTA}}$ ) signal is asserted in place of the read ( $\overline{\mathrm{RD}}$ ) signal and the address bus is floated. (See Fig. 9.) In the second of two successive INTA cycles, a byte of information is read from the data bus, as supplied by the interrupt system logic (i.e. MBL 8259A priority interrupt controller). This byte identifies the source (type) of the interrupt. It is multiplied by four and used as a pointer into the interrupt vector lookup table, as described earlier.

## BUS TIMING - MEDIUM COMPLEXITY SYSTEMS

## (See Fig. 10)

For medium complexity systems, the $M N / \overline{M X}$ pin is connected to GND and the MBL 8288 bus controller is added to the system, as well as an MBL 8282/8283 latch for latching the system address, and an MBL 8286/8287 transceiver to allow for bus loading greater than the MBL 8088 is capable of handling. Signals ALE, $\overline{\mathrm{DEN}}$, and $D T / \bar{R}$ are generated by the MBL 8288 instead of the processor in this configuration, although their timing remains relatively the same. The MBL 8088 status outputs $\left(\overline{\mathrm{S}_{2}}, \overline{\mathrm{~S}}_{1}\right.$, and $\overline{\mathrm{S}}_{0}$ ) provide type of cycle information and become MBL 8288 inputs. This bus cycle information specifies read (code, data, or I/O), write (data or I/O), interrupt acknowledge, or software halt. The MBL 8288 thus issues control signals specifying memory read or write, I/O read or write, or interrupt acknowledge. The MBL 8288 provides two types of write strobes, normal and advanced, to be applied as required. The normal write strobes have data valid at the leading edge of write. The advanced write strobes have the same timing as read strobes, and hence, data is not valid at the leading edge of write. The MBL 8286/8287 transceiver receives the usual $T$ and $\overline{\mathrm{OE}}$ inputs from the MBL 8288's $D T / \bar{R}$ and $\overline{\mathrm{DEN}}$ outputs.

The pointer into the interrupt vector table, which is passed during the second $\overline{\text { INTA }}$ cycle, can derive from an MBL 8259A located on either the local bus or the system bus. If the master MBL 8259A priority interrupt controller is positioned on the local bus, a TTL gate is required to disable the MBL 8286/8287 transceiver when reading from the master MBL 8259A during the interrupt acknowledge sequence and knowledge sequence and software "poll".

## THE MBL 8088 COMPARED TO THE MBL 8086

The MBL 8088 CPU is an 8 -bit processor designed around the MBL 8086 internal structure. Most internal functions of the MBL 8088 are identical to the equivalent MBL 8086 functions. The MBL 8088 handles the external
bus the same way the MBL 8086 does with the distinction of handling only 8 bits at a time. Sixteen-bit operands are fetched or written in two consecutive bus cycles. Both processors will appear identical to the software engineer, with the exception of execution time. The internal register structure is identical and all instructions have the same end result. The differences between the MBL 8088 and MBL 8086 are outlined below. The engineer who is unfamiliar with the MBL 8086 is referred to the MBL 8086 Family User's Manual, Chapters 2 and 4, for function description and instruction set information.

Internally, there are three differences between the MBL 8088 and the MBL 8086. All changes are related to the 8 -bit bus interface.

- The queue length is 4 bytes in the MBL 8088, whereas MBL 8086 queue contains 6 bytes, or three words. The queue was shortened to prevent overuse of the bus by the BIU when prefetching instructions. This was required because of the additional time necessary to fetch instructions 8 bits at a time.
- To further optimize the queue, the prefetching algorithm was changed. The MBL 8088 BIU will fetch a new instruction to load into the queue each time there is a 1 byte hole (space available) in the queue. The MBL 8086 waits until a 2-byte space is available.
- The internal execution time of the instruction set is affected by the 8 -bit interface. All 16 -bit fetches and writes from/to memory take an additional four clock cycles. The CPU is also limited by the speed of instruction fetches. This latter problem only occurs when a series of simple operations occur. When the more sophisticated instructions of the MBL 8088 are being used, the queue has time to fill and the execution proceeds as fast as the execution unit will allow.

The MBL 8088 and MBL 8086 are completely software compatible by virtue of their identical execution units. Software that is system dependent may not be completely transferable, but software that is not system dependent will operate equally as well on an MBL 8088 or an MBL 8086.
The hardware interface of the MBL 8088 contains the major differences between the two CPUs. The pin assignments are nearly identical, however, with the following functional changes:

- $\mathrm{A}_{8}-\mathrm{A}_{15}$ - These pins are only address outputs on the MBL 8088. These address lines are latched internally and remain valid throughout a bus cycle in a manner similar to the 8085 upper address lines.
- $\overline{\mathrm{BHE}}$ has no meaning on the MBL 8088 and has been eliminated.
- $\overline{\mathrm{SSO}}$ provides the $\overline{\mathrm{SO}}$ status information in the minimum mode. This output occurs on pin 34 in minimum mode only. DT/ $\overline{\mathrm{R}}, 1 \mathrm{O} / \overline{\mathrm{M}}$, and $\overline{\mathrm{SSO}}$ provide the complete bus status in minimum mode.
- $10 / \bar{M}$ has been inverted to be compatible with the

MCS-85* bus structure.

- ALE is delayed by one clock cycle in the minimum mode when entering HALT, to allow the status to be latched with ALE.

Fig. 10 - MEDIUM COMPLEXITY SYSTEM TIMING

*Trade Mark of Intel Corporation, USA

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias ....... $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature $\ldots . . . . . . . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin with
Respect to Ground . . . . . . . . . . . . . . . . - 0.5 to +7V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . 2.5 Watt
*NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS (MBL 8088: $\quad V_{C C}=5 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ ) <br> (MBL 8088-2: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ ) <br> (MBL 8088-1: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{V}_{1 H}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{cc}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{IOL}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| 1 cc | Power Supply Current:MBL 8088 <br> MBL 8088-2 <br> MBL 8088-1 |  | $\begin{aligned} & 340 \\ & 350 \\ & 360 \end{aligned}$ | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $1 L_{\text {LI }}$ | Input Leakage Current | . | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {cc }}$ |
| 1 Lo | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $\mathrm{V}_{\mathrm{CL}}$ | Clock Input Low Voltage | -0.5 | +0.6 | V |  |
| $\mathrm{V}_{\mathrm{CH}}$ | Clock Input High Voltage | 3.9 | $\mathrm{V}_{\mathrm{cc}}+1.0$ | V |  |
| $C_{\text {IN }}$ | Capacitance of Input Buffer (All input except $\left.\mathrm{AD}_{0}-\mathrm{AD}_{7} \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}\right)$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{10}$ | Capacitance of I/O Buffer $\left(\mathrm{AD}_{0}-\mathrm{AD}_{7} \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}\right)$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

A.C. CHARACTERISTICS (MBL 8088: $\quad \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ )
(MBL 8088-2: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ ) (MBL 8088-1: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \% \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ )

MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS

| Symbol | Parameter | MBL 8088 |  | MBL 8088-2 |  | MBL 8088-1 <br> (Preliminary) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TCLCL | CLK Cycle Period | 200 | 500 | 125 | 500 | 100 | 500 | ns |  |
| TCLCH | CLK Low Time | 118 |  | 68 |  | 53 |  | ns |  |
| TCHCL | CLK High Time | 69 |  | 44 |  | 39 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 |  | 10 |  | 10 | ns | $\begin{aligned} & \text { From } 1.0 \mathrm{~V} \text { to } \\ & 3.5 \mathrm{~V} \end{aligned}$ |
| TCL2CL2 | CLK Fall Time |  | 10 |  | 10 |  | 10 | ns | $\begin{aligned} & \text { From } 3.5 \mathrm{~V} \text { to } \\ & 1.0 \mathrm{~V} \end{aligned}$ |
| TDVCL | Data in Setup Time | 30 |  | 20 |  | 5 |  | ns |  |
| TCLDX | Data in Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TR1VCL | RDY Setup Time into MBL 8284A (See Notes 1, 2) | 35 |  | 35 |  | 35 |  | ns |  |
| TCLR1X | RDY Hold Time into MBL 8284A (See Notes 1, 2) | 0 |  | 0 |  | 0 |  | ns |  |
| TRYHCH | READY Setup Time into MBL 8088 | 118 |  | 68 |  | 53 |  | ns |  |
| TCHRYX | READY Hold Time into MBL 8088 | 30 |  | 20 |  | 20 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 3) | -8 |  | -8 |  | -10 |  | ns |  |
| THVCH | HOLD Setup Time | 35 |  | 20 |  | 20 |  | ns |  |
| TINVCH | INTR, NMI, TEST Setup Time (See Note 2) | 30 |  | 15 |  | 15 |  | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 |  | 20 |  | 20 | ns | $\begin{aligned} & \text { From } 0.8 \mathrm{~V} \text { to } \\ & 2.0 \mathrm{~V} \end{aligned}$ |
| TIHIL | Input Fall Time (Except CLK) |  | 12 |  | 12 |  | 12 | ns | $\begin{aligned} & \text { From } 2.0 \mathrm{~V} \text { to } \\ & 0.8 \mathrm{~V} \end{aligned}$ |

## A.C. CHARACTERISTICS (Continued)

TIMING RESPONSES

| Symbol | Parameter | MBL 8088 |  | MBL 8088-2 |  | MBL 8088-1 <br> (Preliminary) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TCLAV | Address Valid Delay | 10 | 110 | 10 | 60 | 10 | 50 | ns | $C_{L}=20-100 \mathrm{pF} \text { for }$ <br> all MBL 8088 <br> Outputs in addition to interna internal loáds |
| TCLAX | Address Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 80 | TCLAX | 50 | 10 |  | ns |  |
| TLHLL | ALE Width | TCLCH-20 |  | TCLCH-10 |  | TCLCH-10 |  | ns |  |
| TCLLH | ALE Active Delay |  | 80 |  | 50 |  | 40 | ns |  |
| TCHLL | ALE Inactive Delay |  | 85 |  | 55 |  | 45 | ns |  |
| TLLAX | Address Hold Time to ALE Inactive | TCHCL-10 |  | TCHCL-10 |  | TCHCL-10 |  | ns |  |
| TCLDV | Data Valid Delay | 10 | 110 | 10 | 60 | 10 | 50 | ns |  |
| TCHDX | Data Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TWHDX | Data Hold Time After WR | TCLCH-30 |  | TCLCH-30 |  | TCLCH-25 |  | ns |  |
| TCVCTV | Control Active Delay 1 | 10 | 110 | 10 | 70 | 10 | 50 | ns |  |
| TCHCTV | Control Active Delay 2 | 10 | 110 | 10 | 60 | 10 | 45 | ns |  |
| TCVCTX | Control Inactive Delay | 10 | 110 | 10 | 70 | 10 | 50 | ns |  |
| TAZRL | Address Float to READ Active | 0 |  | 0 |  | 0 |  | ns |  |
| TCLRL | RD Active Delay | 10 | 165 | 10 | 100 | 10 | 70 | ns |  |
| TCLRH | RD Inactive Delay | 10 | 150 | 10 | 80 | 10 | 60 | ns |  |
| TRHAV | RD Inactive to Next Address Active | TCLCL-45 |  | TCLCL-40 |  | TCLCL-35 |  | ns |  |
| TCLHAV | HLDA Valid Delay | 10 | 160 | 10 | 100 | 10. | 60 | ns |  |
| TRLRH | RD Width | 2TCLCL-75 |  | 2TCLCL-50 |  | 2TCLCL-40 |  | ns |  |
| TWLWH | WR Width | 2TCLCL-60 |  | 2TCLCL-40 |  | 2TCLCH-35 |  | ns |  |
| TAVAL | Address Valid to ALE Low | TCLCH-60 |  | TCLCH-40 |  | TCLCH-35 |  | ns |  |
| TOLOH | Output Rise Time |  | 20 |  | 20 |  | 20 | ns | $\begin{aligned} & \text { From } 0.8 \mathrm{~V} \text { to } \\ & 2.0 \mathrm{~V} \end{aligned}$ |
| TOHOL | Output Fall Time |  | 12 |  | 12 |  | 12 | ns | $\begin{aligned} & \text { From } 2.0 \mathrm{~V} \text { to } \\ & 0.8 \mathrm{~V} \end{aligned}$ |


A.C. TESTING: INPUTS ARE DRIVEN AT $2.4 V$ FOR A LOGIC " 1 " AND 0.45 V FOR A LOGIC " 0 ". THE CLOCK IS DRIVEN AT 4.3 V AND 0.25 V TIMING MEASUREMENTS ARE MADE AT 1.5 V FOR BOTH A LOGIC " 1 " AND " 0 ".
a.c. testing load circuit

$\mathrm{C}_{\mathrm{L}}$ :INCLUDES JIG CAPACITANCE

## WAVEFORMS

BUS TIMING - MINIMUM MODE SYSTEM


FUJITSU

MBL 8088 MBL 8088-2 MBL 8088-1

## WAVEFORMS (Continued)

BUS TIMING - MINIMUM MODE SYSTEM (Continued)


NOTES: 1. ALL SIGNALS SWITCH BETWEEN $V_{O H}$ AND $V_{\text {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. TWO INTA CYCLES RUN BACK-TO-BACK. THE MBL 8088 LOCAL ADDR/DATA BUS IS FLOATING DURING BOTH INTA CYCLES. CONTROL SIGNALS ARE SHOWN FOR THE SECOND INTA CYCLE.
4. SIGNALS AT MBL 8284A ARE SHOWN FOR REFERENCE ONLY.
5. ALL TIMING MEASUREMENTS ARE MADE AT $1.5 V$ UNLESS OTHERWISE NOTED.

## A.C. CHARACTERISTICS (Continued)

MAX MODE SYSTEM (USING MBL 8288 BUS CONTROLLER) TIMING REQUIREMENTS

| Symbol | Parameter | MBL 8088 |  | MBL 8088-2 |  | MBL 8088-1 (Preliminary) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TCLCL | CLK Cycle Period | 200 | 500 | 125 | 500 | 100 | 500 | ns |  |
| TCLCH | CLK Low Time | 118 |  | 68 |  | 53 |  | ns |  |
| TCHCL | CLK High Time | 69 |  | 44 |  | 39 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 |  | 10 |  | 10 | ns | $\begin{aligned} & \text { From } 1.0 \mathrm{~V} \text { to } \\ & 3.5 \mathrm{~V} \end{aligned}$ |
| TCL2CL1 | CLK Fall Time |  | 10 |  | 10 |  | 10 | ns | $\begin{aligned} & \text { From } 3.5 \mathrm{~V} \text { to } \\ & 1.0 \mathrm{~V} \end{aligned}$ |
| TDVCL | Data in Setup Time | 30 |  | 20 |  | 5 |  | ns |  |
| TCLDX | Data in Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TR1VCL | RDY Setup Time into MBL 8284A (See Notes 1, 2) | 35 |  | 35 |  | 35 |  | ns |  |
| TCLR1X | RDY Hold Time into MBL 8284A (See Notes 1, 2) | 0 |  | 0 |  | 0 |  | ns |  |
| TRYHCH | READY Setup Time into MBL 8088 | 118 |  | 68 |  | 53 |  | ns |  |
| TCHRYX | READY Hold Time into MBL 8088 | 30 |  | 20 |  | 20 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 2) | -8 |  | -8 |  | -10 |  | ns |  |
| TINVCH | Setup Time for Recognition (INTR, NMI, TEST) (See Note 2) | 30 |  | 15 |  | 15 |  | ns |  |
| TGVCH | RQ/GT Setup Time | 30 |  | 15 |  | 12 |  | ns |  |
| TCHGX | RO Hold Time into MBL 8086 | 40 |  | 30 |  | 20 |  | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 |  | 20 |  | 20 | ns | $\begin{aligned} & \text { From } 0.8 \mathrm{~V} \text { to } \\ & 2: 0 \mathrm{~V} \end{aligned}$ |
| TIHIL | Input Fall Time (Except CLK) |  | 12 |  | 12 |  | 12 | ns | $\begin{aligned} & \text { From } 2.0 \mathrm{~V} \text { to } \\ & 0.8 \mathrm{~V} \end{aligned}$ |

## A.C. CHARACTERISTICS (Continued)

TIMING RESPONSES

| Symbol | Parameter | MBL 8088 |  | MBL 8088-2 |  | MBL 8088-1 (Preliminary) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TCLML | Command Active Delay (See Note 1) | 10 | 35 | 10 | 35 | 10 | 35 | ns |  |
| TCLMH | Command Inactive Delay (See Note 1) | 10 | 35 | 10 | 35 | 10 | 35 | ns | $C_{L}=20-100 p F \text { for }$ <br> all MBL 8088 <br> Outputs in addition to internal loads |
| TRYHSH | READY Active to Status Passive (See Note 3) |  | 110 |  | 65 |  | 45 | ns |  |
| TCHSV | Status Active Delay | 10 | 110 | 10 | 60 | 10 | 45 | ns |  |
| TCLSH | Status Inactive Delay | 10 | 130 | 10 | 70 | 10 | 55 | ns |  |
| TCLAV | Address Valid Delay | 10 | 110 | 10 | 60 | 10 | 50 | ns |  |
| TCLAX | Address Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 80 | TCLAX | 50 | 10 | 40 | ns |  |
| TSVLH | Status Valid to ALE High (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TSVMCH | Status Valid to MCE High (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TCLLH | CLK Low to ALE <br> Valid (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TCLMCH | CLK Low to MCE High (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TCHLL | ALE Inactive Delay (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TCLMCL | MCE Inactive Delay (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TCLDV | Data Valid Delay | 10 | 110 | 10 | 60 | 10 | 50 | ns |  |
| TCHDX | Data Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TCVNV | Control Active Delay (See Note 1) | 5 | 45 | 5 | 45 | 5 | 45 | ns |  |
| TCVNX | Control Inactive Delay (See Note 1) | 10 | 45 | 10 | 45 | 10 | 45 | ns |  |
| TAZRL | Address Float to Read Active | 0 |  | 0 |  | 0 |  | ns |  |
| TCLRL | RD Active Delay | 10 | 165 | 10 | 100 | 10 | 70 | ns |  |
| TCLRH | RD Inactive Delay | 10 | 150 | 10 | 80 | 10 | 60 | ns |  |
| TRHAV | RD Inactive to Next Address Active | TCLCL-45 |  | TCLCL-40 |  | TCLCL-35 |  | ns |  |
| TCHDTL | Direction Control Active Delay (See Note 1) |  | 50 |  | 50 |  | 50 | ns |  |
| TCHDTH | Direction Control Inactive Delay (See Note 1) |  | 30 |  | 30 |  | 30 | ns |  |
| TCLGL | GT Active Delay |  | 85 |  | 50 | 0 | 45 | ns |  |
| TCLGH | GT Inactive Delay |  | 85 |  | 50 | 0 | 45 | ns |  |
| TRLRH | RD Width | 2TCLCL-75 |  | 2TCLCL-50 |  | 2TCLCL-40 |  | ns |  |
| TOLOH | Output Rise Time |  | 20 |  | 20 |  | 20 | ns | $\begin{aligned} & \text { From } 0.8 \mathrm{~V} \text { to } \\ & 2.0 \mathrm{~V} \end{aligned}$ |
| TOHOL | Output Fall Time |  | 12 |  | 12 |  | 12 | ns | $\begin{aligned} & \text { From } 2.0 \mathrm{~V} \text { to } \\ & 0.8 \mathrm{~V} \end{aligned}$ |

## NOTES:

1. Signal at MBL 8284A or MBL 8288 shown for reference only.
2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.
3. Applies only to $\mathrm{T}_{2}$ state ( 8 ns into $\mathrm{T}_{3}$ state).

## WAVEFORMS (Continued)



MBL 8088


## WAVEFORMS (Continued)

BUS TIMING-MAXIMUM MODE SYSTEM (USING MBL 8288)


NOTES: 1. ALL SIGNALS SWITCH BETWEEN $V_{O H}$ AND $V_{O}$ _ 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 CYCLES.
4. TWO INTA CYCLES RUN BACK-TO-BACK. THE MBL 8088 LOCAL ADDR/DATA BUS IS FLOATING DURING BOTH INTA CYCLES. CONTROL FOR POINTER ADDRESS IS SHOWN FOR SECOND INTA CYCLE.
5. SIGNALS AT MBL 8284 A OR MBL 8288 ARE SHOWN FOR REFERENCE ONLY
6. THE ISSUANCE OF THE MBL 8288 COMMAND AND CONTROL SIGNALS ( $\overline{M R D C}, \overline{M W T C}, \overline{A M W C}, \overline{\text { IORC }}$ IOWC, AIOWC, INTA AND DEN) LAGS THE ACTIVE HIGH MBL 8288 CEN.
. 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



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


REQUEST/GRANT SEQUENCE TIMING (MAXIMUM MODE ONLY)


NOTE: 1. THE COPROCESSOR MAY NOT DRIVE THE BUSSES OUTSIDE the region shown without risking contention.
hold/hold acknowledge timing (Minimum mode only)


DEN, IO/M

## TABLE 2 - INSTRUCTION SET SUMMARY*

DATA TRANSFER
MOV = Move:
Register/memory to/from register
Immediate to register/memory immediate to register Accumulator to memory Accuistar to momo Segister/memory to segment register

## PUSH $=$ Push:

Register/memory
Registe
Segment register
POP $=\mathbf{P o p}$
Register/memory
Register
Segment register
$\mathbf{x C H G}=$ Exchange:
Register/memory with register
Register with accumulator
IN = Input from:
Fixed port
Variable port
OUT = Output to:
Fixed port
Variable port
XLAT = Translate byte to AL
$L E A=$ Load EA to register LDS = Load pointer to DS LES $=$ Load pointer to ES LAHF = Load AH with flags SAHF = Store AH into flags PUSHF = Push flags POPF = Pop flags

## ARItHMETIC

ADD $=$ Add:
Reg./memory with register to either Immediate to register/memor
Immediate to accumulato
ADC = Add with carry:
Reg./memory with register to either Immediate to register/memory Immediate to accumulato

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



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

$1000011 \mathrm{w} / \mathrm{mod}$ reg $\mathrm{r} / \mathrm{m}$
10010 reg

| 111100010 w | port |
| :--- | :--- |
| 11110110 w |  |



| 1 | 1 | 1 | 1 | 1 | 1 | 1 | $\mathrm{w} / \bmod 0$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | $0_{0} 0 \mathrm{r} / \mathrm{m}$


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


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



DEC $=$ Decrement:
Register/memory
Register
NEG $=$ Change sign
CMP = Compare:
Register/memory and register mmediate with register/memory mmediate with accumulator
AAS "ASCII adjust for subtract
AS $=$ Decimal adjust for subtrac
MUL $=$ Multiply (unsigned)
MUL = Integer multiply (signed)
AM =ASCII adjust for multiply
IV $=$ Divide (unsigned)
AIV $=$ Integer divide (signed)
AAD $=$ ASCII adjust for divide CBW = Convert byte to word
CWD $=$ Convert word to double word

76543210765432107654321076543210

| 11 | 1 | 1 | $1 \mathrm{w} / \bmod 001 \mathrm{r} / \mathrm{m}$ |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 01 | 1 | 0 | 0 | 1 | reg |




## LOGIC

NOT = Invert
SHL/SAL $=$ Shift logical/arithmetic left
SHR $=$ Shift logical right
SAR $=$ Shift arithmetic right
ROL $=$ Rotate left
ROR =Rotate right
RCL $=$ Rotate through carry flag left
RCR $=$ Rotate through carry flag right
AND $=$ And:
Reg./memory and register to either
immediate to register/memory
Immediate to accumulator
TEST = And function to flags. no result
Register/memory and register
mmediate data and register/memory
Immediate data and accumulator
$\mathrm{OR}=\mathrm{Or}:$
Reg./memory and register to either mmediate to register/memory
Immediate to accumulator
XOR $=$ Exelusive or:
Reg./memory and register to either mmediate to register/memory
Immediate to accumulator
$1111011 \mathrm{w} / \bmod 010 \mathrm{r} / \mathrm{m}$

| $110100 \mathrm{v} / \bmod 100 \mathrm{r} / \mathrm{m}$ |
| :--- | :--- |
| 110100 vwlmod 101 r |









| REP $=$ Repeat | 11910012 |
| :---: | :---: |
| MOVS = Move byte/word | 1010010 w |
| CMPS = Compare byte/word | \%010011 |
| SCAS $=$ Scan byte/word |  |
| LODS = Load byte/wd to AL/AX | 1010110 |
| STOS $=$ Store byte/wd from AL |  |

*Mnemonics © Intel Corporation, 1978

## TABLE 2 - INSTRUCTION SET SUMMARY (Continued)*

CONTROL TRANSFER

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

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

Indirect intersegment
RET $=$ Return from CALL: Within segment
Within seg, adding immed, to SP Intersegment
Intersegment, adding immediate to SP JE/JZ = Jump on equal/zero
JL/JNGE = Jump on less/not greater
or equal
JLE/JNG $=$ Jump on less or equal/not
greater
JB/JMAE $=$ Jump on below/not
above or equal
JBE/JNA = Jump on below or
equal/not above
JP/JPE = Jump on parity/parity even
JO = Jump on overflow
JS = Jump on sign
JNE/JNZ = Jump on not equal/not
zero
JNL/JGE = Jump on not less/greater or equal
JNLE/JG = Jump on not less
or equal/greater


| 1100000011 <br> 11000000101 <br> 1 | data-low | data-high |
| :---: | :---: | :---: |
| $0_{11001011}$ |  |  |
| 11001010 | data-low | data-high |
| 01110100 | disp |  |
|  | disp |  |
| $00_{011}^{01} 111110$ | disp |  |
| 01.010010 | disp |  |
| 01110110 | disp |  |
| $00_{01}^{01} 11119010$ | disp |  |
| 01110000 | disp |  |
| 01011110000 | disp |  |
|  | disp |  |
|  | disp |  |
| 0 1 1 1 1 1 1 1 | disp |  |



## Footnotes:

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

| $\underline{16-B i t}[w=1]$ | 8-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 Sl | 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)$

## PACKAGE ILLUSTRATION



PACKAGE DIMENSIONS (Suffix: -C)


MBL 8088
MBL 8088-2
MBL 8088-1

## PACKAGE ILLUSTRATION



PACKAGE DIMENSIONS (Suffix: -P)


## FUJITSU

## NMOS 8 \& 16-BIT I/O PROCESSOR

The Fujitsu MBL 8089 is a revolutionary concept in microprocessor input/output processing. Packaged in a 40-pin DIP package. MBL 8089 is a high performance processor implemented in N -channel, depletion load silicon gate technology (NMOS). The MBL 8089's instruction set and capabilities are optimized for high speed, flexible and efficient I/O handling. It allows easy interface of Fujitsu's 16 -bit MBL 8086 and 8 -bit MBL 8088 microprocessors with 8 - and 16 -bit peripherals. In the REMOTE configuration, MBL 8089 bus is user definable allowing it to be compatible with any $8 / 16$-bit Fujitsu microprocessor, interfacing easily to the Fujitsu multiprocessor system bus standard MULTIBUS*.

The MBL 8089 performs the function of an intelligent DMA controller for the MBL 8086, 88 family and with its processing power, can remove I/O overhead from the MBL 8086 or MBL 8088. It may operate completely in parallel with a CPU, giving dramatically improved performance in I/O intensive applications. MBL 8089 provides two I/O channels, each supporting a transfer rate up to $1.25 \mathrm{Mbyte} / \mathrm{sec}(2.00 \mathrm{Mbyte} / \mathrm{sec})$ at the standard clock frequency of $5 \mathrm{MHz}(8 \mathrm{MHz})$. Memory based communication between the IOP and CPU enhances system flexibility and encourages software modularity, yielding more reliable, easier to develop systems.

- High Speed DMA Capabilities Including I/O to Memory, Memory to I/O, Memory to Memory, and $\mathrm{I} / \mathrm{O}$ to $\mathrm{I} / \mathrm{O}$
- MBL 8086, MBL 8088 Compatible: Removes I/O Overhead from CPU in iAPX 86/11 or 88/11 Configuration
- Allows Mixed Interface of 8-\& 16-Bit Peripherals, to 8- \& 16-Bit Processor Busses
- 1 Mbyte Addressability
- Memory Based Communication with CPU
- Supports LOCAL or REMOTE I/O Processing
- Flexible, Intelligent DMA Functions Including Translation, Search, Word Assembly/Disassembly
- MULTIBUS* Compatible System Interface
- Two Clock Rates: 5 MHz for MBL 8089 8 MHz for MBL 8089-2
- 40-pin Ceramic DIP (Suffix -C)

Fig. 1 - BLOCK DIAGRAM
Fig. 2 - PIN CONFIGURATION



[^15]MBL 8089
Hixinilillill MBL 8089-2

Table 1 - PIN DESCRIPTION

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\begin{aligned} & \text { A0-A15/ } \\ & \text { D0-D15 } \end{aligned}$ | 1/0 | Multiplexed Address and Data Bus: The functions of these lines are defined by the state of $\overline{\mathrm{S} 0}, \overline{\mathrm{~S} 1}$ and $\overline{\mathrm{S} 2}$ lines. The pins are floated after reset and when the bus is not acquired. A8-A15 are stable on transfers to a physical 8 -bit data bus (same bus as MBL 8088), and are multiplexed with data on transfers to a 16 -bit physical bus. |
| $\begin{aligned} & \text { A16-A19/ } \\ & \text { S3-S6 } \end{aligned}$ | 0 | Address and Status: Multiplexed most significant address lines and status information. The address lines are active only when addressing memory. Otherwise, the status lines are active and are encoded as shown below. The pins are floated after reset and when the bus is not acquired. <br> S6 S5 S4 S3 <br> $\begin{array}{llll}1 & 1 & 0 & 0 \\ \text { DMA cycle on } \mathrm{CH} 1\end{array}$ <br> $\begin{array}{llll}1 & 1 & 0 & 1 \\ \text { DMA cycle on } \mathrm{CH} 2\end{array}$ <br> $\begin{array}{llll}1 & 1 & 1 & 0 \\ \text { Non-DMA cycle on } \mathrm{CH} 1\end{array}$ <br> $\begin{array}{llll}1 & 1 & 1 & 1\end{array}$ Non-DMA cycle on CH 2 |
| $\overline{\text { BHE }}$ | 0 | Bus High Enable: The Bus High Enable is used to enable data operations on the most significant half of the data bus (D8D15). The signal is active low when a byte is to be transferred on the upper half of the data bus. The pin is floated after reset and when the bus is not acquired. $\overline{\mathrm{BHE}}$ does not have to be latched. |
| $\overline{\mathrm{s} 0}, \overline{\mathrm{~s} 1}, \overline{\mathrm{~s} 2}$ | 0 | Status: These are the status pins that define the IOP activity during any given cycle. They are encoded as shown below: <br> $\overline{\mathrm{S} 2} \overline{\mathrm{~S} 1} \overline{\mathrm{~s} 0}$ <br> 000 Instruction fetch; I/O space <br> 001 Data fetch; I/O space <br> 0110 Data store; I/O space <br> $\begin{array}{lll}0 & 1 & 1\end{array}$ Not used <br> 100 Instruction fetch; System Memory <br> 101 Data fetch; System Memory <br> 110 Data store; System Memory <br> 111 Passive <br> The status lines are utilized by the bus controller and bus arbiter to generate all memory and I/O control signals. The signals change during T4 if a new cycle is to be entered while the return to passive state in T3 or $T_{w}$ indicates the end of a cycle. The pins are floated after system reset and when the bus is not acquired. |
| READY | 1 | Ready: The ready signal received from the addressed device indicates that the device is ready for data transfer. The signal is active high and is synchronized by the MBL 8284A clock generator. |


| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\overline{\text { LOCK }}$ | 0 | Lock: The lock output signal indicates to the bus arbiter that the bus is needed for more than one continuous cycle. It is set via the channel control register, and during the TSL instruction. The pin floats after reset and when the bus is not acquired. This output is active low. |
| RESET | I | Reset: The receipt of a reset signal causes the IOP to suspend all its activities and enter an idle state until a channel attention is received. The signal must be active for at least four clock cycles. |
| CLK | 1 | Clock: Clock provides all timing needed for internal IOP operation. |
| CA | 1 | Channel Attention: Gets the attention of the IOP. Upon the falling edge of this signal, the SEL input pin is examined to determine Master/Slave or $\mathrm{CH} 1 / \mathrm{CH} 2$ information. This input is active high. |
| SEL | 1 | Select: The first CA received after system reset informs the IOP via the SEL line, whether it is a Master or Slave (0/1 for Master/Slave respectively) and starts the initialization sequence. During any other CA the SEL line signifies the selection of $\mathrm{CH} 1 / \mathrm{CH} 2$. ( $0 / 1$ respectively.) |
| DRQ1-2 | 1 | Data Request: DMA request inputs which signal the IOP that a peripheral is ready to transfer/receive data using channels 1 or 2 respectively. The signals must be held active high until the appropriate fetch/stroke is initiated. |
| $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ | 1/0 | Request Grant: Request Grant implements the communication dialogue required to arbitrate the use of the system bus (between IOP and CPU, LOCAL mode) or I/O bus when two IOPs share the same bus (REMOTE mode). The $\overline{R Q} / \overline{\mathrm{GT}}$ signal is active low. An internal pull-up permits $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ to be left floating if not used. |
| SINTR1-2 | 0 | Signal Interrupt: Signal interrupt outputs from channels 1 and 2 respectively. The interrupts may be sent directly to the CPU or through the MBL 8259A interrupt controller. They are used to indicate to the system the occurrence of user defined events. |
| EXT1-2 | 1 | External Terminate: External terminate inputs for channels 1 and 2 respectively. The EXT signals will cause the termination of the current DMA transfer operation if the channel is so programmed by the channel control register. The signal must be held active high until termination is complete. |
| $\mathrm{V}_{\mathrm{Cc}}$ |  | Voltage: +5 volt power input. |
| $\mathrm{V}_{\text {SS }}$ |  | Ground. |

## FUNCTIONAL DESCRIPTION

The MBL 8089 IOP has been designed to remove I/O processing, control and high speed transfers from the central processing unit. Its major capabilities include that of initializing and maintaining peripheral components and supporting versatile DMA. This DMA function boasts flexible termination conditions (such as external terminate, mask compare, single transfer and byte count expired). The DMA function of the MBL 8089 IOP uses a two cycle approach where the information actually flows through the MBL 8089 IOP. This approach to DMA vastly simplifies the bus timings and enhances compatibility with memory and peripherals, in addition to allowing operations to be performed on the data as it is transferred. Operations can include such constructs as translate, where the MBL 8089 automatically vectors through a lookup table and mask compare, both on the "fly".

The MBL 8089 is functionally compatible with Fujitsu's MBL 8086, MBL 8088 family. It supports any combination of $8 / 16$-bit busses. In the REMOTE mode it can be used to complement other Intel processor families. Hardware and communication architecture are designed to provide simple mechanisms for system upgrade.
Theronly direct communication between the IOP and CPU is handled by the Channel Attention and interrupt lines. Status information, parameters and task programs are passed via blocks of shared memory, simplifying hardware interface and encouraging structured programming.
The MBL 8089 can be used in applications such as file and buffer management in hard disk or floppy disk control. It can also provide for soft error recovery routines and scan
control. CRT control, such as cursor control and auto scrolling, is simplified with the MBL 8089. Keyboard control, communication control and general I/O are just a few of the typical applications for the MBL 8089.

## Remote and Local Modes

Shown in Figure 3 is the MBL 8089 in a LOCAL configuration. The MBL 8086 (or MBL 8088) is used in its maximum mode. The MBL 8089 and MBL 8086 reside on the same local bus, sharing the same set of system buffers. Peripheral located on the system bus can be addressed by either the MBL 8086 or the MBL 8089. The MBL 8089 requests the use of the LOCAL bus by means of the $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ line. This performs a similar function to that of HOLD and HLDA on the Intel 8085A, 8080A and MBL 8086 minimum mode but is implemented on one physical line. When the MBL 8086 relinquishes the system bus, the MBL 8089 used the same bus control, latches and transceiver components to generate the system address, control and data lines. This mode allows a more economical system configuration at the expense of reduced CPU thruput due to IOP bus utilization. A typical REMOTE configuration is shown in Figure 4. In this mode, the IOP's bus is physically separated from the system bus by means of system buffers/latches. The IOP maintains its own local bus and can operate out of local or system memory. The system bus interface contains the following components:

- Up to three MBL 8282 buffer/latches to latch the address to the system bus.
- Up to two MBL 8286 devices bidirectionally buffer the system data bus.

Fig. 3 - TYPICAL iAPX 86/11, 88/11 CONFIGURATION WITH MBL 8089 IN LOCAL MODE, MBL 8088, MBL 8086 IN MAX MODE


- An MBL 8288 bus controller supplies the control signals necessary for buffer operation as well as $\overline{\text { MRDC }}$ (Memory Read) and $\overline{M W T C}$ (Memory Write) signals.
- An MBL 8289 bus arbiter performs all the functions necessary to arbitrate the use of the system bus. This is used in place of the $\overline{R Q} / \overline{G T}$ logic in the LOCAL mode. This arbiter decodes type of cycle information from the MBL 8089 status lines to determine if the IOP desires to perform a transfer over the "common" or system bus.

The peripheral device PER1 and PER2 are supported on their own data and address bus, the MBL 8089 communicates with the peripherals without affecting system bus operation. Optional buffers may be used on the local bus when capacitive loading conditions so dictate. I/O programs and RAM buffers may also reside on the local bus to further reduce system bus utilization.

## COMMUNICATION MECHANISM

Fundamentally, communication between the CPU and IOP is performed through messages prepared in shared memory. The CPU can cause the MBL 8089 to execute a program by placing it in the MBL 8089's memory space and/or directing the MBL 8089's attention to it by asserting a hardware Channel Attention (CA) signal to the IOP, activating the proper I/O channeI. The SEL Pin indicates to the IOP which channel
is being addressed. Communication from the IOP to the processor can be performed in a simillar manner via a system interrupt (SINTR-1,2), if the CPU has enabled interrupts for this purpose. Additionally, the MBL 8089 can store messages in memory regarding its status and the status of any peripherals. This communication mechanism is supported by a hierarchical data structure to provide a maximum amount of flexibility of memory use with the added capability of handling multiple IOP's.
Illustrated in Figure 5 is an overview of the communication data structure hierarchy that exists for the MBL 8089 I/O processor. Upon the first CA from RESET, if the IOP is initialized as the BUS MASTER, 5 bytes of information are read into the MBL 8089 starting at location FFFF6 (FFFF6, FFFF8-FFFFB) where the type of system bus (16-bit or 8 -bit) and pointers to the system configuration block are obtained. This is the only fixed location the MBL 8089 accesses. The remaining addresses are obtained via the data structure hierarchy. The MBL 8089 determines addresses in the same manner as does the MBL 8086 ; i.e., a 16 -bit relocation pointer is offset left 4 bits and added to the 16 -bit address offset, obtaining a 20 -bit address. Once these 20 -bit addresses are formed, they are stored as such as all the MBL 8089 address registers are 20 bits long. After the system configuration pointer address is formed, the MBL 8089 IOP accesses the system configuration block.

Fig. 4 - TYPICAL REMOTE CONFIGURATION


Fig. 5 - COMMUNICATION DATA STRUCTURE HIERARCHY


The System Configuration Block (SCB), used only during startup, points to the Control Block (CB) and provides IOP system configuration data via the SOC byte. The SOC byte initializes IOP I/O bus width to $8 / 16$, and defines one of two IOP $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ operating modes. For $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ mode 0, the IOP is typically initialized as SLAVE and has its $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ line tied to a MASTER CPU (typical LOCAL configuration). In this mode, the CPU normally has control of the bus, grants control to the IOP as needed, and has the bus restored to it upon IOP task completion (IOP request-CPU grant-IOP done). For $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ mode 1, useful only in remote mode between two IOPs, MASTER/SLAVE designation is used only to initialize bus control: from then on, each IOP requests and grants as the bus is needed (IOP1 request-IOP2 grant-IOP2 request-IOP1 grant). Thus, each IOP retains bus control until the other requests it. The completion of initialization is signalled by the IOP clearing the BUSY flag in the CB. This type of startup allows the user to have the startup pointers in ROM with the SCB in RAM. Allowing the SCB to be in RAM gives the user the flexibility of being able to initialize multiple IOPs.

The Control Block furnishes bus control initialization for the IOP operation (CCW or Channel Control Word) and provides pointers to the Parameter Block or "data" memory for both channels 1 and 2. The CCW is retrieved and analyzed upon all CA's other than the first after a reset. The CCW byte is decoded to determine channel operation.

The Parameter Block contains the address of the Task Block and acts as a message center between the IOP and CPU. Parameters or variable information is passed from the CPU to its IOP in this block to customize the software interface to the peripheral device. It is also used for transferring data and status information between the IOP and CPU.

The Task Block contains the instructions for the respective channel. This block can reside on the local bus of the IOP, allowing the IOP to operate concurrently with the CPU, or reside in system memory.

The advantage of this type of communication between the processor, IOP and peripheral, is that it allows for a very clean method for the operating system to handle I/O routines. Canned programs or "Task Blocks" allow for execution of general purpose I/O routines with the status and peripheral command information being passed via the Parameter Block ("data" memory). Task Blocks (or "program" memory) can be terminated or restarted by the CPU, if need be. Clearly, the flexibility of this communication lends itself to modularity and applicability to a large number of peripheral devices and upward compatibility to future end user systems and microprocessor familes.

## Register Set

The MBL 8089 maintains separate registers for its two I/O channels as well as some common registers (see Figure 6). There are sufficient registers for each channel to sustain its own DMA transfers, and process its own instruction stream. The basic DMA pointer registers (GA, GB - 20 bits each), can point either the system bus or local bus, DMA source or destination, and can be autoincremented. A third register set (GC) can be used to allow translation during the DMA process through a lookup table it points to. Additionally, registers are provided for a masked compare during the data transfer and can be set up to act as one of the termination conditions. Other registers are also provided. Many of these registers can be used as general purpose registers during program execution, when the IOP is not performing DMA cycles.

Fig. 6 - REGISTER MODEL
USER PROGRAMMABLE

| TAG 19 |
| :--- |

NON USER PROGRAMMABLE
(ALWAYS POINTS TO SYSTEM MEMORY)


## Bus Operation

The MBL 8089 utilizes the same bus structure as the MBL 8086, MBL 8088 in their maximum mode configurations (see Figure 7). The address is time multiplexed with the data on the first $16 / 8$ lines. A16 through A19 are time multiplexed with four status lines S3-S6. For MBL 8089 cycles, S4 and S3 determined what type of cycle (DMA versus nonDMA) is being performed on channels 1 or 2 . S5 and S6 are a unique code assigned to the MBL 8089 IOP, enabling the user to detect which processor is performing a bus cycle in a multiprocessing environment. The first three status lines, $\overline{\mathrm{SO}}-\mathrm{S2}$, are used with an MBL 8288 bus controller to determine if an instruction fetch or data transfer is being performed in I/O or system memory space.
DMA transfers require at least two bus cycles with each bus cycle requiring a minimum of four clock cycles. Additional clock cycles are added if wait states are required. This two cycle approach simplifies considerably the bus timings in burst DMA. The MBL 8089 optimizes the transfer between two different bus widths by using three bus cycles versus
four to transfer 1 word. More than one read (write) is performed when mapping an 8 -bit bus onto a 16 -bit bus (vice versa). For example, a data transfer from an 8 -bit peripheral to a 16 -bit physical location in memory is performed by first doing two reads, with word assembly within the IOP assembly register file and then one write.
As can be expected, the data bandwidth of the IOP is a function of the physical bus width of the system and I/O busses. Table 2 gives the bandwidth, latency and bus utilization of the MBL 8089. The system bus is assumed to be 16 -bits wide with either an 8 -bit peripheral (under byte column) or 16 -bit peripheral (word column) being shown.
The latency refers to the worst case response time by the IOP to a DMA request, without the bus arbitration times. Notice that the word transfer allows $50 \%$ more bandwidth. This occurs since three bus cycles are required to map 8 -bit data into a 16 -bit location, versus two for a 16 -bit to 16 -bit transfer. Note that it is possible to fully saturate the system bus in the LOCAL mode whereas in the REMOTE mode this is reduced to a maximum of $50 \%$.

Table 2 - ACHIEVABLE MBL 8089 OPERATIONS WITH 16-BIT SYSTEM BUS

|  | MBL 8089 ( 5 MHz ) |  |  |  | MBL 8089-2 (8MHz) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Local |  | Remote |  | Local |  | Remote |  |
|  | Byte | Word | Byte | Word | Byte | Word | Byte | Word |
| Bandwidth | $830 \mathrm{~KB} / \mathrm{S}$ | $1250 \mathrm{~KB} / \mathrm{S}$ | $830 \mathrm{~KB} / \mathrm{S}$ | $1250 \mathrm{~KB} / \mathrm{S}$ | 1328 KB/S | 2000 KB/S | 1328 KB/S | 2000 KB/S |
| Latency | 1.0/2.4 $\mu \mathrm{sec} *$ | 1.0/2.4 $\mu \mathrm{sec}{ }^{*}$ | 1.0/2.4 $\mu \mathrm{sec} *$ | 1.0/2.4 $\mu \mathrm{sec} *$ | 0.625/1.5 $\mu \mathrm{sec}{ }^{* *}$ | $0.625 / 1.5 \mu \mathrm{sec}^{* *}$ | $0.625 / 1.5 \mu \mathrm{sec}^{* *}$ | 0.625/1.5 $\mu \mathrm{sec}{ }^{* *}$ |
| System Bus | $2.4 \mu \mathrm{sec} /$ | $1.6 \mu \mathrm{sec} /$ | $0.8 \mu \mathrm{sec} /$ | $0.8 \mu \mathrm{sec} /$ | $1.5 \mu \mathrm{sec} /$ | $1.0 \mu \mathrm{sec} /$ | $0.5 \mu \mathrm{sec} /$ | $0.5 \mu \mathrm{sec} /$ |
| Utilization | Transfer | Transfer | Transfer | Transfer | Transfer | Transfer | Transfer | Transfer |

* $2.4 \mu \mathrm{sec}$ if interleaving with other channel and no wait states. $1 \mu \mathrm{se}$ if channel is waiting for request.
** $1.5 \mu \mathrm{sec}$ if interleaving with other channel and no wait states. $0.625 \mu \mathrm{sec}$ if channel is waiting for request.

Fig. 7 - MBL 8089 BUS OPERATION


## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\qquad$ $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . Voltage on Any Pin with Respect to Ground $\qquad$ $\ldots-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Respect to Gro
Power Dissipation . . . . . . . . . . -0.5 to +7V
D.C.CHARACTERISTICS $\quad\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{cc}}+1.0$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{cc}}$ | Power Supply Current |  | 350 | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $I_{\text {LI }}$ | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V}<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\text {LO }}$ | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $\mathrm{V}_{\mathrm{CL}}$ | Clock Input Low Voltage | -0.5 | +0.6 | V |  |
| $\mathrm{V}_{\mathrm{CH}}$ | Clock Input High Voltage | 3.9 | $\mathrm{V}_{\mathrm{cc}}+1.0$ | V |  |
| $\mathrm{C}_{\text {IN }}$ | Capacitance of Input Buffer <br> (All Input except $A D_{0}-A D_{15}, \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ ) |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{10}$ | Capacitance of I/O Buffer $\left(A D_{0}-A D_{15}, \overline{R Q} / \overline{G T}\right)$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

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

MBL 8089/8086 AND MBL 8089-2/8086-2 MAX MODE SYSTEM (USING MBL 8288 BUS CONTROLLER) TIMING REQUIREMENTS

| Symbol | Parameter | MBL 8089 |  | MBL 8089-2 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TCLCL | CLK Cycle Period | 200 | 500 | 125 | 500 | ns |  |
| TCLCH | CLK Low Time | (2/3 TCLCL) -15 |  | (2/3 TCLCL) -15 |  | ns |  |
| TCHCL | CLK High Time | $(1 / 3$ TCLCL) +2 |  | (1/3 TCLCL) +2 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 |  | 10 | ns | From 1.0 V to 3.5 V |
| TCL2CL1 | CLK Fall Time |  | 10 |  | 10 | ns | From 3.5 V to 1.0 V |
| TDVCL | Data in Setup Time | 30 |  | 20 |  | ns |  |
| TCLDX | Data in Hold Time | 10 |  | 10 |  | ns |  |
| TR1 VCL | RDY Setup Time into MBL 8284A (See Notes 1, 2) | 35 |  | 35 |  | ns |  |
| TCLR1X | RDY Hold Time into MBL 8284A (See Notes 1, 2) | 0 |  | 0 |  | ns |  |
| TRYHCH | READY Setup Time into MBL 8089 | (2/3 TCLCL) -15 |  | (2/3 TCLCL) -15 |  | ns |  |
| TCHRYX | READY Hold Time into MBL 8089 | 30 |  | 20 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 4) | -8 |  | -8 |  | ns |  |
| TINVCH | Setup Time Recognition (DRQ 1,2, RESET, Ext 1,2) (See Note 2) | 30 |  | 15 |  | ns |  |
| TGVCH | $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Setup Time | 30 |  | 15 |  | ns |  |
| TCAHCAL | CA Width | 95 |  | 75 |  | ns |  |
| TSLVCAL | SEL Setup Time | 75 |  | 55 |  | ns |  |
| TCALSLX | SEL Hold Time | 0 |  | 0 |  | ns |  |
| TCHGX | $\overline{\mathrm{GT}}$ Hold Time into MBL 8089 | 40 |  | 30 |  | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 |  | 20 | ns | From 0.8 V to 2.0 V |
| TIHIL | Input Fall Time (Except CLK) |  | 12 |  | 12 | ns | From 2.0 V to 0.8 V |

MBL 8089
MBL 8089-2

## A.C. CHARACTERISTICS (Continued)

TIMING RESPONSES

| Symbol | Parameter | MBL 8089 |  | MBL 8089-2 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TCLML | Command Active Delay (See Note 1) | 10 | 35 | 10 | 35 | ns | $C_{L}=80 \mathrm{pF}$ |
| TCLMH | Command Inactive Delay (See Note 1) | 10 | 35 | 10 | 35 | ns |  |
| TRYHSH | READY Active to Status Passive (See Note 3) |  | 110 |  | 65 | ns |  |
| TCHSV | Status Active Delay | 10 | 110 | 10 | 60 | ns |  |
| TCLSH | Status Inactive Delay | 10 | 130 | 10 | 70 | ns |  |
| TCLAV | Address Valid Delay | 10 | 110 | 10 | 60 | ns |  |
| TCLAX | Address Hold Time | 10 |  | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 80 | TCLAX | 50 | ns |  |
| TSVLH | Status Valid to ALE High (See Note 1) |  | 15 |  | 15 | ns |  |
| TCLLH | CLK Low to ALE Valid (See Note 1) |  | 15 |  | 15 | ns | $C_{L}=150 \mathrm{pF}$ |
| TCHLL | ALE Inactive Delay (See Note 1) |  | 15 |  | 15 | ns |  |
| TCLDV | Data Valid Delay | 10 | 110 | 10 | 60 | ns |  |
| TCHDX | Data Hold Time | 10 |  | 10 |  | ns |  |
| TCVNV | Control Active Delay (See Note 1) | 5 | 45 | 5 | 45 | ns |  |
| TCVNX | Control Inactive Delay (See Note 1) | 10 | 45 | 10 | 45 | ns |  |
| TCHDTL | Direction Control Active Delay (See Note 1) |  | 50 |  | 50 | ns |  |
| TCHDTH | Direction Control Inactive Delay (See Note 1) |  | 30 |  | 30 | ns |  |
| - TCLGL | $\overline{\mathrm{RO}}$ Active Delay | 0 | 85 | 0 | 50 | ns | $C_{L}=100 \mathrm{pF}$ |
| TCLGH | $\overline{\mathrm{RO}}$ Inactive Delay |  | 85 |  | 50 | ns | Note 5; $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |
| TCLSRV | SINTR Valid Delay |  | 150 |  | 100 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| TOLOH | Output Rise Time |  | 20 |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | 12 |  | 12 | ns | From 2.0 V to 0.8 V |

NOTES: 1. Signal at MBL 8284 A or MBL 8288 shown for reference only.
2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.
3. Applies only to T3 and TW states.
4. Applies only to $T 2$ state.
5. Applies only if $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Mode $1 \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}, 2.7 \mathrm{k} \Omega$ pull up to $\mathrm{V}_{\mathrm{CC}}$.
A.C. TESTING INPUT, OUTPUT WAVEFORM

A.C. TESTING: INPUTS ARE DRIVEN AT 2.4 V FOR A LOGIC " 1 " AND 0.45 V FOR A LOGIC " 0 "' THE CLOCK IS DRIVEN AT 4.3 V AND 0.25 V , TIMING MEASURE. MENTS ARE MADE AT $1.5 V$ FOR BOTH A LOGIC " 1 " AND " 0 ".
A.C. TESTING LOAD CIRCUIT


MBL 8089 BUS TIMING USING MBL 8288


## NOTES:

1. ALL SIGNALS SWITCH BETWEEN $V_{O H}$ AND $V_{O L}$ UNLESS OTHERWISE SPECIFIED.
2. RDY IS SAMPLED NEAR THE END OF $T_{2}, T_{3}, T_{w}$ TO DETERMINE IF $T_{w}$ MAChine states are to be inserted.
3. FOLLOWING A WRITE CYCLE DATA REMAINS VALID ON THE MBL 8089 LOCAL BUS UNTIL A LOCAL BUS MASTER DECIDES TO RUN ANOTHER BUS CYCLE. THE LOCAL BUS IS FLOATED BY THE MBL 8089 WHEN THE MBL 8089 ENTERS A REQUEST BUS ACKNOWLEDGE STATE.
4. SIGNALS AT MBL 8284A OR MBL 8288 ARE SHOWN FOR REFERENCE ONLY
5. THE ISSUANCE OF THE MBL 8288 COMMAND AND CONTROL SIGNALS ( $\overline{M R D C}, \overline{M W T C}, \overline{A M W C}, \overline{I O R C}, \overline{I O W C}, \overline{A I O W C}$, INTA AND DEN) LAGS THE ACTIVE HIGHMBL 8288 CEN.
6. ALL TIMING MEASUREMENTS ARE MADE AT 1.5 V UNLESS OTHERWISE NOTED.
7. $A_{8}-A_{15}$ ARE STABLE ON TRANSFERS TO AN 8 BIT PHYSICAL DATA BUS, i.e. $A_{8}-A_{15}$ DON'T FLOAT ON A READ FROM AN 8 BIT PHYSICAL BUS OR MULTIPLEX WITH DATA ON A WRITE TO AN 8 BIT PHYSICAL BUS BHE IS STABLE (NON MULTIPLEXD) FOR ALL TRANSFERS.

## WAVEFORMS (Continued)

## ASYNCHRONOUS SIGNAL RECOGNITION



NOTES:

1. SETUP REQUIREMENTS FOR ASYNCHRONOUS SIGNALS ONLY TO GUARANTEE RECOGNITION AT NEXT CLK.
2. ALL INPUTS EXCEPT CA ARE LATCHED ON A CLK EDGE. THE CA INPUT IS NEGATIVE EDGE TRIGGERED.
3. DRQ BECOMING ACTIVE GREATER THAN 30 ns AFTER THE RISING EDGE OF CLK WILL GUARANTEE NON-RECOGNITION UNTIL THE NEXT RISING CLOCK EDGE.



WAVEFORMS (Continued)


## WAVEFORMS (Continued)

EXTERNAL TERMINATE SETUP TIMING


SEL SETUP AND TIMING


## MBL 8089 INSTRUCTION SET SUMMARY $\dagger$

## Data Transfers

| POINTER INSTRUCTIONS |  | OPCODE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Load Pointer PPP from Addressed Location | 7 | 0 |  |  |  |  |  | 7 |  |  |  |  | 0 |  |  |  |
| LPD P, M |  | P | P | P | 0 | 0 | A | A 1 | 1 | 0 | 0 |  |  | 1 | 0 |  | M M |
| LPDI P,I | Load Pointer PPP Immediate 4 Bytes | P | P | P | 1 | 0 | 0 | 01 | 0 | 0 | 0 |  |  | 1 | 0 |  | 00 |
| MOVP M, P | Store Contents of Pointer PPP in Addressed Location | P | P | P | 0 | 0 | A | A 1 | 1 | 0 | 0 |  |  | 1 | 0 |  | M M |
| MOVP P, M | Restore Pointer | P | P | P | 0 | 0 | A | A 1 | 1 | 0 | 0 |  |  | 1 | 1 |  | M M |
| MOVE DATA |  | OPCODE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| MOV M, M | Move from Source to Destination $\begin{array}{r}\text { Source } \\ \text { Destination }\end{array}$ | 0 | 00 | 00 |  | 0 A |  | A A W |  | 10 | 00 | 1 |  | 0 |  | 0 N | M M |
|  |  |  | 0 | 0 | 0 | 0 | A | A W | 1 | 1 | 0 |  |  | 1 | 1 |  | M M |
| MOV R, M | Load Register RRR from Addressed Location |  | R R | R | 0 | 0 | A | A W | 1 | 0 | 0 |  |  | 0 | 0 |  | M M |
| MOV M, R | Store Contents of Register RRR in Addressed Location |  | R | R | 0 | 0 | A | A W | 1 | 0 | 0 |  |  | 0 | 1 |  | M M |
| MOVI R | Load Register RRR Immediate (Byte) Sign Extend | R | R | R | wb |  | 0 | 0 W | 0 | 0 | 1 |  |  | 0 | 0 |  | 00 |
| MOVI M | Move Immediate to Addressed Location |  | 00 | 0 wb |  |  | A | A W | 0 | 1 | 0 |  |  | 1 | 1 |  | M M |

## Control Transfer



Arithmetic and Logic Instructions


Arithmetic and Logic Instructions


BIT Manipulation and Test Instructions


## Control


*AA Field in call instruction can be 00, 01, 10 only.
**OPCODE is second byte fetched.
All instructions consist of at least 2 bytes, while some instructions may use up to 3 additional bytes to specify literals and displacement data. The definition of the various fields within each instruction is given below:


| MM Base Pointer Select |  |
| :---: | :---: |
| 00 | GA; general purpose A |
| 01 | GB; general purpose B |
| 10 | GC; general purpose C |
| 11 | PP; parameter pointer |

## RRR Register Field

The RRR field specifies a 16-bit register to be used in the instruction. If GA, GB, GC or TP are referenced by the RRR field, the upper 4 bits of the registers are loaded with the sign bit (Bit 15). PPP registers are used as 20 -bit address pointers.

| RRR |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
| 000 | r0 | GA | $;$ | general purpose A |
| 001 | r1 | GB | $;$ | general purpose B |
| 010 | r2 | GC | $;$ | general purpose C |
| 011 | r3 | BC | $;$ | byte count |
| 100 | r4 | TP | task block pointer |  |
| 101 | r5 | IX | ; | index register |
| 110 | r6 | CC | ; | channel control (mode) |
| 111 | r7 | MC | ; | mask/compare |

See Notes 1, 2.

| PPP |  |  |  |  |
| :---: | :--- | :--- | :--- | :--- |
| 000 | $p^{0}$ | $G A$ | general purpose $A$ |  |
| 001 | $p^{1}$ | $G B$ | $;$ | general purpose B |
| 010 | $p^{2}$ | $G C$ | general purpose $C$ |  |
| 100 | $p^{4}$ | TP | task block pointer |  |

Note 1. Logical and arithmetic instructions should not be used to update the CC register (i.e. - only MOV and MOVI instructions should be used.)
2. A 20 -bit register ( $G A, G B, G C$ or $T P$ ) that is initialized as a 16 -bit I/O space pointer must be saved at even addresses when using MOVP or CALL instructions.

## Notes:

## BBB Bit Select Field

The bit select fieid replaces the RRR field in bit manipulation instructions and is used to select a bit to be operated on by those instructions. Bit 0 is the least significant bit.
wb
011 byte literal
102 byte (word) literal
dd
011 byte displacement
102 byte (word) displacement.

## AA Field

00 The selected pointer contains the operand address.
01 The operand address is formed by adding an 8-bit, unsigned, offset contained in the instruction to the selected pointer. The contents of the pointer are unchanged.
10 The operand address is formed by adding the contents of the index register to the selected pointer. Both registers remain unchanged.
11 Same as 10 except the index register is post autoincremented (by 1 for 8 -bit transfer, by 2 for 16 -bit transfer)

## W Width Field

0 The selected operand is 1 byte long.
1 The selected operand is 2 bytes long.

## Additional Bytes

OFFSET : 8-bit unsigned offset.
SDISP : 8/16-bit signed displacement.
LITERAL : 8/16-bit literal. (32 bits for LDPI).
The order in which the above optional bytes appear in IOP instructions is given below:


Offsets are treated as unsigned numbers. Literals and displacements are sign extended ( 2 's complement).

PACKAGE ILLUSTRATION


PACKAGE DIMENSIONS
(Suffix: -C)


## NMOS PROGRAMMABLE INTERRUPT CONTROLLER

The MBL8259A Programmable Interupt Controller handles up to eight vectored priority interrupts for the CPU. It is cascadable for up to 64 vectored priority interrupts without additional circuitry. It is packaged in a 28 -pin DIP, uses NMOS technology and requires a single +5 V supply. Circuitry is static, requiring no clock input.
The MBL8259A is designed to minimize the software and real time overhead in handling multi-level priority interrupts. It has several modes, permitting optimizatic for a variety of system requirements.

- MBL 8086, MBL 8088 Compatible
- MCS-80*, MCS-85* Compatible
- Eight-Level Priority Controller
- Expandable to 64 Levels
- Programmable Interrupt Modes
- Individual Request Mask Capability
- Single + 5V Supply (No Clocks)
- Two Package Options: -28-Pin Ceramic DIP (Suffix: -C) -28-Pin Plastic DIP (Suffix: -P)

Fig. 1 - BLOCK DIAGRAM


Fig. 2 - PIN CONFIGURATION


[^16]PIN DESCRIPTION
TABLE 1 - PIN DESCRIPTION

| Symbc | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ | 28 | 1 | Supply: +5V Supply. |
| GND | 14 | 1 | Ground |
| $\overline{\text { CS }}$ | 1 | 1 | Chip Select: A low on this pin enables $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ communication between the CPU and the MBL 8259A $\overline{\text { INTA }}$ functions are independent of $\overline{\mathrm{CS}}$. |
| $\overline{W R}$ | 2 | 0 | Write: A low on this pin when $\overline{\mathrm{CS}}$ is low enables the MBL 8259A to accept command words from the CPU. |
| $\overline{\mathrm{RD}}$ | 3 | 1 | Read: A low on this pin when $\overline{C S}$ is low enables the MBL 8259A to release status onto the data bus for the CPU. |
| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | 4-11 | I/O | Bldirectional Data Bus: Control, status and interrupt-vector information is transferred via this bus. |
| $\mathrm{CAS}_{0}-\mathrm{CAS}_{2}$ | 12,13,15 | I/O | Cascade Lines: The CAS lines form a private MBL 8259A bus to control a multiple MBL 8259A structure. These pins are outputs for a master MBL 8259A and inputs for a slave MBL 8259A. |
| $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ | 16 | I/O | Slave Program/Enable Buffer: This is a dual function pin. When in the Buffered Mode it can be used as an output to control buffer transceivers ( $\overline{\mathrm{EN}}$ ). When not in the buffered mode it is used as an input to designate a master ( $\overline{\mathrm{SP}}=1$ ) or slave ( $\overline{\mathrm{SP}}=0$ ). |
| INT | 17 | 0 | Interrupt: This pin goes high wheaever a valid interrupt request is asserted. It is used to interrupt the CPU, thus it is connected to the CPU's interrupt pin. |
| $\underline{I R}-1 R_{7}$ | 18-25 | 1 | Interrupt Request: Asynchronous inputs. An interrupt request is executed by raising an IR input (low to high), and holding it high until it is acknowledged (Edge Triggered Mode), or just by a high level on an IR input (Level Triggered Mode). Unused IR pins should externally be pulled down not to be left open because the IR inputs contain internal pull-up resistors. |
| $\overline{\text { INTA }}$ | 26 | 1 | Interrupt Acknowledge: This pin is used to enable MBL 8259A interruptvector data onto the data bus by a sequence of interrupt acknowledge pulses issued by the CPU. When the MBL 8259A is connected to the MBL 80186/ 80188 or Intel 80186/80188, an external pull-up resistor is required on the INTA pins. |
| $A_{0}$ | 27 | 1 | A0 Address Line: This pin acts in conjunction with the $\overline{\mathrm{CS}}, \overline{\mathrm{WR}}$, and $\overline{\mathrm{RD}}$ pins. It is used by the MBL 8259A to decipher various Command Words the CPU writes and status the CPU wishes to read. It is typically connected to the CPU $A_{0}$ address line ( $A_{1}$ for MBL 8086/8088). |

reconfigured dynamically at any time during the main program. This means that the complete interrupt structure can be defined as required, based on the total system environment.
where-it left off.
This method is called Interrupt. It is easy to see that system throughput would drastically increase, and thus more tasks throughput would drastically increase, and thus more tasks
could be assumed by the microcomputer to further enhance its cost effectiveness.
The Programmable Interrupt Controller (PIC) functions as an overall manager in an Interrupt-Driven system environment. It accepts requests from the peripheral equipment, determines which of the incoming requests is the highest importance (priority), ascertains whether the incoming importance (priority), ascertains whether the incoming
request has higher priority value than the level currently being serviced, and issues an interrupt to the CPU based on this determination.
Each peripheral device or structure usually has a special program or "routine" that is associated with its specific functional or operational requirements; this is referred to as a "service routine". The PIC, after issuing an Interrupt to the CPU, must somehow input information into the CPU that can "point" the Program Counter to the service routine associated with the requesting device. This "pointer" is an address in a vectoring table and will often "pointer" is an address in a vectoring table and be referred to, in this document, as vectoring data.

## The MBL 8259A

The MBL 8259A is a device specifically designed for use in real time, interrupt driven microcomputer systems. It manages eight levels or requests and has built-in features for expandability to other MBL 8259A's (up to 64 levels). It is programmed by the system's software as an I/O peripheral. A selection of priority modes is available to the programmer so that the manner in which the requests are processed by the MBL 8259A can be configured to match his system requirements. The priority modes can be changed or

## FUNCTIONAL DESCRIPTION

## INTERRUPTS IN MICROCOMPUTER SYSTEMS

Microcomputer system design requires that I/O devices such as keyboards, displays, sensors and other components receive servicing in an efficient manner so that large amounts of the total system tasks can be assumed by the microcomputer with little or no effect on throughout.
The most common method of servicing such devices is the Polled approach. This is where the processor must test each device in sequence and in effect "ask" each one if it needs servicing. It is easy to see that a large portion of the main program is looping through this continues polling cycle and that such a method would have a serious, detrimental effect on system throughput, thus limiting the tasks that could be assumed by the microcomputer and reducing the cost effectiveness of using such devices.
A more desirable method would be one that would allow the microprocessor to be executing its main program and only stop to service peripheral devices when it is told to do so by the device itself. In effect, the method would provide an external asynchronous input that would inform the processor that it should complete whatever instruction that is currently being executed and fetch a new routine that will service the requesting device. Once this servicing is complete, however, the processor would resume exactly

Fig. 3a-POLLED METHOD


Fig. 3b-INTERRUPT METHOD


## INTERRRUPT REQUEST REGISTER (IRR) AND IN-SERVICE REGISTER (ISR)

The interrupts at the IR input lines are handled by two registers in cascade, the Interrupt Request Register (IRR) and the In-Service Register(ISR). The IRR is used to store all the interrupt levels which are requesting service; and the ISR is used to store all the interrupt levels which are being serviced.

## PRIORITY RESOLVER

This logic block determines the priorities of the bits set in the IRR. The highest priority is selected and strobed into the corresponding bit of the ISR during INTA pulse.

## INTERRUPT MASK REGISTER (IMR)

The IMR stores the bits which mask the interrupt lines to be masked. The IMR operates on the IRR. Masking of a higher priority input will not affect the interrupt request lines of lower priority.

INT (INTERRUPT)
This output goes directly to the CPU interrupt input. The $\mathrm{V}_{\mathrm{OH}}$ level on this line is designed to be fully compatible with Intel's 8080A and 8085A and MBL 8086 input levels.

## INTA (INTERRUPT ACKNOWLEDGE)

INTA pulses will cause the MBL 8259A to release vectoring information onto the data bus. The format of this data depends on the system mode ( $\mu$ PM) of the MBL 8259A.

## DATA BUS BUFFER

This 3-state, bidirectional 8-bit buffer is used to interface the MBL 8259A to the system Data Bus. Control words and status information are transferred through the Data Bus Buffer.

## READ/WRITE CONTROL LOGIC

The function of this block is to accept OUTput commands from the CPU. It contains the Initialization Command Word (ICW) registers and Operation Command Word (OCW) registers which store the various control formats for device operation. This function block also allows the status of the MBL 8259A to be transferred onto the Data Bus.

## $\overline{\mathrm{CS}}$ (CHIP SELECT)

A LOW on this input enables the MBL 8259A. No reading or writing of the chip will occur unless the device is selected.

## $\overline{W R}$ (WRITE)

A LOW on this input enables the CPU to write control words (ICWs and OCWs) to the MBL 8259A.

## $\overline{\mathrm{RD}}$ (READ)

A LOW on this input enables the MBL 8259A to send the status of the Interrupt Request Register (IRR), In-Service Register (ISR), the Interrupt Mask Register (IMR), or the interrupt level onto the Data Bus.

Fig. 4a-MBL 8259A BLOCK DIAGRAM


Fig. 4b-MBL 8259A BLOCK DIAGRAM


## $\mathrm{A}_{0}$

This input signal is used in conjunction with $\overline{W R}$ and $\overline{\mathrm{RD}}$ signals to write commands into the various command registers, as well as reading the various status registers of the chip. This line can be tied directly to one of the address lines.

## THE CASCADE BUFFER/COMPARATOR

This function block stores and compares the IDs of all MBL 8259A's used in the system. The associated three I/O pins (CASO-2) are outputs when the MBL 8259A is used as a master and are inputs when the MBL 8259A is used as a slave. As a master, the MBL 8259A sends the ID of the interrupting slave device onto the CASO-2 lines. The slave thus selected will send its preprogrammed subroutine address onto the Data Bus during the next one or two consecutive INTA pulses. (See section "Cascading the MBL 8259A".)

## INTERRUPT SEQUENCE

The powerful features of the MBL 8259A in a microcomputer system are its programmability and the interrupt routine addressing capability. The latter allows direct or indirect jumping to the specific interrupt routine requested without any polling of the interrupting devices. The normal sequence of events during an interrupt depends on the type of CPU being used.
The events occur as follows in an MCS-80*/85* system:

1. One or more of the INTERRUPT REQUEST lines (IR7-0) are raised high, setting the corresponding IRR bit(s).
2. The MBL 8259A evaluates these requests, and sends an INT to the CPU, if appropriate.
3. The CPU acknowledges the INT and responds with an INTA pulse.
4. Upon receiving an $\overline{\mathrm{NTA}}$ from the CPU group, the highest priority ISR bit is set, and the corresponding IRR bit is reset. The MBL 8259A will also release a CALL instruction code (11001101) onto the 8-bit Data Bus through its D7-0 pins.
5. This CALL instruction will initiate two more $\overline{I N T A}$ pulses to be sent to the MBL 8259A from the CPU group.
6. These two INTA pulses allow the MBL 8259A to release its preprogrammed subroutine address onto the Data Bus. The lower 8 -bit address is released at the first INTA pulse and the higher 8 -bit address is released at the second INTA pulse.
7. This completes the 3 -byte CALL instruction released by the MBL 8259A. In the AEOI mode the ISR bit is reset at the end of the third INTA pulse. Otherwise, the ISR bit remains set until an appropriate EOI command is issued at the end of the interrupt sequence.
The events occurring in an MBL 8086 system are the same until step 4.
8. Upon receiving an INTA from the CPU group, the highest priority ISR bit is set and the corresponding IRR bit is reset. The MBL 8259A does not drive the Data Bus during this cycle.
9. The MBL 8086 will initiate a second INTA pulse. During this pulse, the MBL 8259A releases an 8-bit pointer onto the Data Bus where it is read by the CPU.
10. This completes the interrupt cycle. In the AEOI mode the ISR bit is reset at the end of the second INTA pulse. Otherwise, the ISR bit remains set until an appropriate

EOI command is issued at the end of the interrupt subroutine.

If no interrupt request is present at step 4 of either sequence (i.e., the request was too short in duration) the MBL 8259A will issue an interrupt level 7. Both the vectoring bytes and the CAS lines will look like an interrupt level 7 was requested.

Fig. 4c-MBL 8259A BLOCK DIAGRAM


Fig. 5-MBL 8259A INTERFACE TO STANDARD SYSTEM BUS


[^17]
## INTERRUPT SEQUENCE OUTPUTS

## MCS-80* MCS-85*

This sequence is timed by three INTA pulses. During the first INTA pulse the CALL opcode is enabled onto the data bus.

## Content of First Interrupt <br> Vector Byte

CALL CODE | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 |

During the second INTA pulse the lower address of the appropriate service routine is enabled onto the data bus. When Interval $=4$ bits $A_{5}-A_{7}$ are programmed, while $A_{0}-A_{4}$ are automatically inserted by the MBL 8259A. When Interval = 8 only $A_{6}$ and $A_{7}$ are programmed, while $A_{0}-A_{5}$ are automatically inserted.

## Content of Second Interrupt <br> Vactor Byte

| IR | Interval=4 |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  |
| 7 | A7 | A6 | A5 | 1 | 1 | 1 | 0 | 0 |  |
| 6 | A7 | A6 | A5 | 1 | 1 | 0 | 0 | 0 |  |
| 5 | A7 | A6 | A5 | 1 | 0 | 1 | 0 | 0 |  |
| 4 | A7 | A6 | A5 | 1 | 0 | 0 | 0 | 0 |  |
| 3 | A7 | A6 | A5 | 0 | 1 | 1 | 0 | 0 |  |
| 2 | A7 | A6 | A5 | 0 | 1 | 0 | 0 | 0 |  |
| 1 | A7 | A6 | A5 | 0 | 0 | 1 | 0 | 0 |  |
| 0 | A7 | A6 | A5 | 0 | 0 | 0 | 0 | 0 |  |


| IR | Interval=8 |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 |  |
| D0 |  |  |  |  |  |  |  |  |
| 7 | A7 | A6 | 1 | 1 | 1 | 0 | 0 |  |
| 6 | A7 | A6 | 1 | 1 | 0 | 0 | 0 |  |
| 5 | A7 | A6 | 1 | 0 | 1 | 0 | 0 |  |
| 4 | A7 | A6 | 1 | 0 | 0 | 0 | 0 |  |
| 3 | A7 | A6 | 0 | 1 | 1 | 0 | 0 |  |
| 2 | A7 | A6 | 0 | 1 | 0 | 0 | 0 |  |
| 1 | A7 | A6 | 0 | 0 | 1 | 0 | 0 |  |
| 0 | A7 | A6 | 0 | 0 | 0 | 0 | 0 |  |

During the third INTA pulse the higher address of the appropriate service routine, which was programmed as byte 2 of the initialization sequence $\left(A_{8}-A_{15}\right)$, is enabled onto the bus.

## Content of Third Interrupt

Vector Byte

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 |

## MBL 8086/MBL 8088

MBL 8086 mode is similar to MCS-80* mode except that only two Interrupt Acknowledge cycles are issued by the processor and no CALL opcode is sent to the processor. The first interrupt acknowledge cycle is similar to that of MCS-80*/85* systems in that the MBL 8259A uses it to internally freeze the state of the interrupts for priority resolution and as a master it issues the interrupt code on the cascade lines at the end of the INTA pulse. On this first cycle it does not issue any data to the processor and leaves
its data bus buffers disabled. On the second interrupt acknowledge cycle in MBL 8086 mode the master (or slave if so programmed) will send a byte of data to the processor with the acknowledged interrupt code composed as follows (note the state of the ADI mode control is ignored and $A_{5}-A_{11}$ are unused in MBL 8086 mode):

Content of Interrupt Vector Byte for MBL 8086 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 |

MBL 80186/MBL 80188
MBL 80186 mode is the same as MBL 8086 mode. However, it is noticed that an external pull-up resistor is required on the INTA pin of the MBL 8259A when it is connected to the MBL 80186/188 or Intel 80186/188.

When the $\overline{\text { INTA }}$ input pin of the MBL 8259A is connected to the INT2//्रTAO or INT3//्NTA1 input/output pin of the MBL 80186/188 without an external pull-up resistor, the $\overline{\text { INTA }}$ pin floats after the MBL80186/188 is reset, because the INT2/INTAO and INT3//̄NTA1 pins are floated (in the input state) by reset. Besides, the INTA pin is pulled up high after the INT2/INTAO and INT3/INTA1 pins are set in the output state by software, because they output a high level in the output state when they are not activated.

In this case, a sequence of a processor's reset and setting the INT2//्INTA0 or INT3//्INTA1 in the output state generates a spurious negative pulse, and the MBL 8259A may recognize this pulse as an INTA pulse when the floating level is near to low level.

To avoid this problem, an external pull-up resistor must be connected on the INTA pin, so that the INTA pin is held high even after processor's reset.

## MBL 8259A'S INTA LEVEL (WITHOUT EXTERNAL PULL-UP RESISTOR)

 MBL 8259A INTAMBL 80186/188 Operation


Notes: $H=$ High level, $F=$ Floating, $L=$ Low level
 in input state)
(2), (4): Processor's setting INT2/INTAO and INT3/䵊TA1 in output state (not activated)

[^18]
## PROGRAMMING THE MBL 8259A

The MBL 8259A accepts two types of command words generated by the CPU:

1. initialization Command Words (iCWs): Before normal operation can begin, each MBL 8259A in the system must be brought to a starting point - by a sequence of 2 to 4 bytes timed by $\overline{W R}$ pulses.
2. Operation Command Words (OCWs): These are the command words which command the MBL 8259A to operate in various interrupt modes. These modes are:
a. Fully nested mode
b. Rotating priority mode
c. Special mask mode
d. Polled mode

The OCWs can be written into the MBL 8259A anytime after initialization.

## INITIALIZATION COMMAND WORDS (ICWs)

## GENERAL

Whenever a command is issued with A0 $=0$ and D4 $=1$, this is interpreted as Initialization Command Word 1 (ICW1). ICW1 starts the initialization sequence during which the following automatically occur.
a. The edge sense circuit is reset, which means that following initialization, an interrupt request (IR) input must make a low-to-high transition to generate an interrupt.
b. The Interrupt Mask Register is cleared.
c. IR7 input is assigned priority 7.
d. The slave mode address is set to 7 .
e. Special Mask Mode is cleared and Status Read is set to IRR.
f. If IC4=0, then all functions selected in ICW4 are set to zero. (Non-Buffered mode*, no Auto-EOI, MCS-80/85* system).

## INITIALIZATION COMMAND WORDS 1 AND 2 (ICW1, ICW2)

$\mathrm{A}_{5}-\mathrm{A}_{15}$ : Page starting address of service routines. In an MCS-80*/85* system, the 8 request levels will generate CALLs to 8 locations equally spaced in memory. These can be programmed to be spaced at intervals of 4 or 8 memory locations, thus the 8 routines will occupy a page of 32 or 64 bytes, respectively.
The address format is 2 bytes long ( $A_{0}-A_{15}$ ). When the routine interval is $4, A_{0}-A_{4}$ are automatically inserted by the MBL 8259A, while $A_{5}-A_{15}$ are programmed externally. When the routine interval is $8, A_{0}-A_{5}$ are automatically inserted by the MBL 8259A, while $A_{6}-A_{15}$ are programmed externally.

The 8 -byte interval will maintain compatibility with current software, while the 4 -byte interval is best for a compact jump table.
In an MBL 8086 system $A_{15}-A_{11}$ are inserted in the five most significant bits of the vectoring byte and the MBL 8259A sets the three least significant bits according to the interrupt level. $\mathrm{A}_{10}-\mathrm{A}_{5}$ are ignored and ADI (Address interval) has no effect.

## Fig. 6-INITIALIZATION SEQUENCE



[^19]Fig. 7-INITIALIZATION COMMAND WORD FORMAT


LTIM: If LTIM $=1$, then the MBL 8259A will operate in the level interrupt mode. Edge detect logic on the interrupt inputs will be disabled.
ADI: CALL address interval. $A D I=1$ then interval=4; $A D I=0$ then interval $=8$.
SNGL: Single.Means that this is the only MBL 8259A in the system. If SNGL = 1 , no ICW3 will be issued.
IC4: If this bit is set, ICW4 has to be read. If ICW4 is not needed, set IC4 $=0$.

## INITIALIZATION COMMAND WORD 3 (ICW3)

This word is read only when there is more than one MBL 8259A in the system and cascading is used, in which case $\mathrm{SNGL}=0$. It will load the 8 -bit slave register. The functions of this register are:
a. In the master mode (either when $S P=1$, or in buffered mode when $M / S=1$ in ICW4) a " 1 " is set for each slave in the system. The master then will release byte 1 of the call sequence (for MCS-80/85* system) and will enable the corresponding slave to release bytes 2 and 3 (for MBL 8086 only byte 2 ) through the cascade lines.
b. In the slave mode (either when $\overline{\mathrm{SP}}=\mathbf{0}$, or If $\mathrm{BUF}=1$ and $\mathrm{M} / \mathrm{S}=0$ in ICW4) bits 2-0 identify the slave. The slave compares its cascade input with these bits and, if they are equal, bytes 2 and 3 of the call sequence (or just byte 2 for MBL 8086) are released by it on the Data Bus.

## INITIALIZATION COMMAND WORD 4 (ICW4)

SFNM: If SFNM=1 the special fully nested mode is programmed.
BUF: If $B U F=1$ the buffered mode is programmed. In buffered mode $\overline{S P} / \overline{E N}$ becomes an enable output and the master/slave determination is by M/S.
$\mathrm{M} / \mathrm{S}$ : If buffered mode is selected: $\mathrm{M} / \mathrm{S}=1$ means the MBL 8259A is programmed to be a master, $M / S=0$ means the MBL 8259A is programmed to be a slave. If $B U F=0, M / S$ has no function.
AEOI: If $A E O I=1$ the automatic end of interrupt mode is programmed.
$\mu \mathrm{PM}: ~ M i c r o p r o c e s s o r ~ m o d e: ~ \mu \mathrm{PM}=0$ sets the MBL 8259A for MCS-80*/85* system operation, $\mu \mathrm{PM}=1$ sets the MBL 8259A for MBL 8086/8088 system operation.

## OPERATION COMMAND WORDS (OCWs)

After the Initialization Command Words (ICWs) are programmed into the MBL 8259A, the chip is ready to accept interrupt requests at its input lines. However, during the MBL 8259A operation, a selection of algorithms can command the MBL 8259A to operate in various modes through the Operation Command Words (OCWs)

## OPERATION CONTROL WORDS (OCWs)

|  |  |  |  |  |  |  |  |  | OCW1 |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AO | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  |  |  |  |  |  |  |
| 1 | M7 | M6 | M5 | M4 | M3 | M2 | M1 | M0 |  |  |  |  |  |  |  |


|  | OCW2 |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | R | SL | EOI | 0 | 0 | L2 | L1 | LO |


\section*{| OCW3 |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---: |
| 0 | 0 | ESMM | SMM | 0 | 1 | $P$ | RR |  |}

OPERATION CONTROL WORD 1 (OCWs)
OCW1 sets and clears the mask bits in the Interrupt Mask Register (IMR). $M_{7}-M_{0}$ represent the eight mask bits. $M=1$ indicates the channel is masked (inhibited), $\mathrm{M}=\mathrm{O}$ indicates the channel is enabled.

## OPERATION CONTROL WORD 2 (OCW2)

R, SL, EOI - These three bits control the Rotate and End of Interrupt modes and combinations of the two. A chart of these combinations can be found on the Operation Command Word Format.
$L_{2}, L_{1}, L_{0}$-These bits determine the interrupt level acted upon when the SL bit is active.

OPERATION CONTROL WORD 3 (OCW3)
ESMM - Enable Special Mask Mode. When this bit is set to 1, it enables the SMM bit to set or reset the Special Mask Mode. When ESMM=0 the SMM bit becomes a "don't care".'
SMM - Special Mask Mode. If ESMM=1 and SMM=1 the MBL 8259A will enter Special Mask Mode. If ESMM $=1$ and SMM $=0$ the MBL 8259A will revert to normal mask mode. When ESMM=0, SMM has no effect.

Fig. 8-OPERATION COMMAND WORD FORMAT


## FULLY NESTED MODE

This mode is entered after initialization unless another mode is programmed. The interrupt requests are ordered in priority form 0 through 7 ( 0 highest). When an interrupt is acknowledged the highest priority request is determined and its vector placed on the bus. Additionally, a bit of the Interrupt Service Register (ISRO-7) is set. This bit remains set until the microprocessor issues an End of Interrupt (EOI) command immediately before returning from the service routine, or if AEOI (Automatic End of Interrupt) bit is set, until the training edge of the last INTA. While the IS bit is set, all further interrupts of the same or lower priority are inhibited, while higher levels will generate an interrupt (which will be acknowledged only if the microprocessor internal interrupt enable flip-flop has been re-enabled through software).
After the initialization sequence, IRO has the highest priority and IR7 the lowest. Priorities can be changed, as will be explained, in the rotating priority mode.

## END OF INTERRUPT (EOI)

The In-Service (IS) bit can be reset either automatically following the training edge of the last in sequence $\overline{\text { INTA }}$ pulse (when AEOI bit in ICW4 is set) or by a command word that must be issued to the MBL 8259A before returning from a service routine (EOI command). An EOI command must be issued twice if in the Cascade mode, once for the master and once for the corresponding slave.

There are two forms of EOI command: Specific and Non-Specific. When the MBL 8259A is operated in modes which preserve the fully nested structure, it can determine which IS bit to reset on EOI. When a Non-Specific EOI command is issued the MBL 8259A will automatically reset the highest IS bit of those that are set, since in the fully nested mode the highest IS level was necessarily the last level acknowledged and serviced. A non-specific EOI can be issued with OCW2 ( $E O I=1, S L=0, R=0$ ).
When a mode is used which may disturb the fully nested structure, the MBL 8259A may no longer be able to determine the last level acknowledged. In this case a Specific End of Interrupt must be issued which includes as part of the command the IS level to be reset. A specific EOI can be issued with OCW2 ( $E O I=1, S L=1, R=0$, and $L O-L 2$ is the binary level of the IS bit to be reset).
It should be noted that an IS bit that is masked by an IMR bit will not be cleared by a non-specific EOI if the MBL 8259A is in the Special Mask Mode.

## AUTOMATIC END OF INTERRUPT (AEOI) MODE

If AEOI=1 in ICW4, then the MBL 8259A will operated in AEOI mode continuously until reprogrammed by ICW4. In this mode the MBL 8259A will automatically perform a non-specific EOI operation at the training edge of the last interrupt acknowledge pulse (third pulse in MCS-80/85*, second in MBL 8086/8088). Note that from a system standpoint, this mode should be used only when a nested multilevel interrupt structure is not required within a single MBL 8259A.

The AEOI mode can only be used in a master MBL 8259A and not a slave.

## AUTOMATIC ROTATION (Equal Priority Devices)

In some applications there are a number of interrupting devices of equal priority. In this mode a device, after being serviced, receives the lowest priority, so a device requesting an interrupt will have to wait, in the worst case until each of 7 other devices are serviced at most once. For example, if the priority and "in service" status is:

Before Rotate (IR4 the highest priority requiring service)

|  | IS7 | IS6 | IS5 | IS4 | IS3 | IS2 | IS1 | ISO |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| "IS' Status | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 

After Rotate (IR4 was serviced, all other priorities rotated correspondingly)

|  | IS7 | IS6 | IS5 | IS4 | IS3 | IS2 | IS1 | ISO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 'IS' Status | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Highest Priority |  |  | Lowest Priority |  |  |  |  |
| Priority Status | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 |

There are two ways to accomplish Automatic Rotation using OCW2, the Rotation on Non-Specific EOI Command ( $\mathrm{R}=1, \mathrm{SL}=0, \mathrm{EOI}=1$ ) and the Rotate in Automatic EOI Mode which is set by ( $\mathrm{R}=1, \mathrm{SL}=0, \mathrm{EOI}=0$ ) and cleared by ( $R=0, S L=0, E O I=0$ ).

## SPECIFIC ROTATION (Specific Priority)

The programmer can change priorities by programming the bottom priority and thus fixing all other priorities; i.e., if IR5 is programmed as the bottom priority device, then IR6 will have the highest one.
The Set Priority command is issued in OCW2 where: $\mathrm{R}=1$, $S L=1$; LO-L2 is the binary priority level code of the bottom priority device.
Observe that in this mode internal status is updated by software control during OCW2. However, it is independent of the End of Interrupt (EOI) command (also executed by OCW2). Priority changes can be executed during an EOI command by using the Rotate on Specific EOI command in OCW2 $(R=1, S L=1, E O I=1$ and $L O-L 2=I R$ level to receive bottom priority).

## INTERRUPT MASKS

Each Interrupt Request input can be masked individually by the Interrupt Mask Register (IMR) programmed through OCW1. Each bit in the IMR masks one interrupt channel if it is set (1). Bit 0 masks IRO, Bit 1 masks IR1 and so forth. Masking and IR channel does not affect the other channels operation.

SPECIAL MASK MODE
Some applications may require an interrupt service routine to dynamically alter the system priority structure during its ęxecution under software control. For example, the routine may wish to inhibit lower priority requests for a portion of its execution but enable some of them for another portion.

The difficulty here is that if an Interrupt Request is acknowledged and an End of Interrupt command did not reset its IS bit (i.e. while executing a service routine), the MBL 8259A would have inhibited all lower priority requests with no easy way for the routine to enable them.

That is where the Special Mask Mode comes in. In the special Mask Mode, when a mask bit is set in OCW1, it inhibits further interrupts at that level and enables interrupts from all other levels (lower as well as higher) that are not masked.

Thus, any interrupts may be selectively enabled by loading the mask register.

The special Mask Mode is set by OCW3 where: ESMM $=1$, $S M M=1$, and cleared where $E S M M=1, S M M=0$.

## POLL COMMAND

In this mode the INT output is not used or the microprocessor internal Interrupt Enable flip-flop is reset, disabling its interrupt input. Service to devices is achieved by software using a Poll command.
The Poll command is Issued by setting $P=" 1$ " in OCW3. The MBL 8259A treats the next $\overline{R D}$ pulse to the MBL 8259A (i.e., $\overline{\mathrm{RD}}=0, \overline{\mathrm{CS}}=0$ ) as an interrupt acknowledge, sets the appropriate IS bit if there is a request, and reads the priority level. Interrupt is frozen from $\overline{W R}$ to $\overline{\mathrm{RD}}$.
The word enabled onto the data bus during $\overline{\mathrm{RD}}$ is:

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | - | - | - | - | W2 | W1 | W0 |

WO-W2: Binary code of the highest priority level requesting service.
1: Equal to a " 1 " if there is an interrupt.
This mode is useful if there is a routine command common to several levels so that the INTA sequence is not needed (saves ROM space). Another application is to use the poll mode to expand the number of priority levels to more than 64.

Fig. 9-PRIORITY CELL-SIMPLIFIED LOGIC DIAGRAM


## READING THE MBL 8259A STATUS

The input status of several internal registers can be read to update the user information on the system. The following registers can be read via OCW3 (IRR and ISR or OCW1 [IMR]).
Interrupt Request Register (IRR): 8-bit register which contains the levels requesting an interrupt to be acknowledged. The highest request level is reset from the IRR when an interrupt is acknowledged. (Not affected by IMR.)
In-Service Register (ISR): 8-bit register which contains the priority levels that are being serviced. The ISR is updated when an End of Interrupt Command is issued.
Interrupt Mask Register (IMR): 8-bit register which contains the interrupt request lines which are masked.
The IRR can be read when, prior to the $\overline{\mathrm{RD}}$ pulse, a Read Register Command is issued with OCW3 ( $R R=1, R I S=0$.)
The ISR can be read when, prior to the $\overline{\mathrm{RD}}$ pulse, a Read Register Command is issued with OCW3 (RR=1, RIS=1).
There is no need to write an OCW3 before every status read operation, as long as the status read corresponds with the previous one; i.e., the MBL 8259A "remembers" whether the IRR or ISR has been previously selected by the OCW3. This is not true when poll is used.
After initialization the MBL 8259A is set to IRR.
For reading the IMR, no OCW3 is needed. The output data bus will contain the IMR whenever $\overline{\mathrm{RD}}$ is active and $\mathrm{A} 0=1$ (OCW1).
Polling overrides status read when $\mathrm{P}=1, \mathrm{RR}=1$ in OCW 3 .

## EDGE AND LEVEL TRIGGERED MODES

This mode is programmed using bit 3 in ICW1.
If LTIM $={ }^{\prime} 0$ ', an interrupt request will be recognized by a low to high transition on an IR input. The IR input can remain high without generating another interrupt.
If $\operatorname{LTIM}={ }^{\prime} 1^{\prime}$, an interrupt request will be recognized by a 'high' level on IR input, and there is no need for an edge detection. The interrupt request must be removed before the EOI command is issued or the CPU interrupt is enabled to prevent a second interrupt from occurring.
The priority cell diagram shows a conceptual circuit of the level sensltive and edge sensitive input circuity of the MBL 8259A. Be sure to note that the request latch is a transparent $D$ type latch.
In both the edge and level triggered modes the IR inputs must remain high until after the falling edge of the first $\overline{\text { INTA. }}$ If the IR input goes low before this time a DEFAULT IR7 will occur when the CPU acknowledges the interrupt. This can be a useful safeguard for detecting interrupts caused by spurious noise glitches on the IR inputs. To implement this feature the IR7 routine is used for "clean up" simply executing a return instruction, thus ignoring the interrupt. If IR7 is needed for other purposes a default IR7 can still be detected by reading the ISR. A normal IR7 interrupt will set the corresponding ISR bit, a default IR7 won't. If a default IR7 routine occurs during a normal IR7 routine, however, the ISR will remain set. In this case it is necessary to keep track of whether or not the IR7 routine was previously entered. If another IR7 occurs it is a default.

Fig. 10-IR TRIGGERING TIMING REQUIREMENTS


## THE SPECIAL FULLY NESTED MODE

This mode will be used in the case of a big system where cascading is used, and the priority has to be conserved within each slave. In this case the fully nested mode will be programmed to the master (using ICW4). This mode is similar to the normal nested mode with the following exceptions:
a. When an interrupt request from a certain slave is in service this slave is not locked out from the master's priority logic and further interrupt requests from higher priority IR's within the slave will be recognized by the master and will initiate interrupts to the processor. (In the normal nested mode a slave is masked out when its request is in service and no higher requests from the same slave can be serviced.)
b. When exiting the Interrupt Service routine the software has to check whether the interrupt serviced was the only one from that slave. This is done by sending a non-specific End of Interrupt (EOI) command to the slave and then reading its $\operatorname{In}$-Service register and checking for zero. If it is empty, a non-specific EOI can be sent to the master too. If not, no EOI should be sent.

## BUFFERED MODE

When the MBL 8259A is used in a large system where bus driving buffers are required on the data bus and the cascading mode is used, there exists the problem of enabling buffers.
The buffered mode will structure the MBL 8259A to send an enable signal on $\overline{S P} / \overline{E N}$ to enable the buffers. In this mode, whenever the MBL 8259A's data bus outputs are enabled, the $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ output becomes active.

This modification forces the use of software programming to determine whether the MBL 8259A is a master or a slave. Bit 3 in ICW4 programs the buffered mode, and bit 2 in ICW4 determines whether it is a master of a slave.

## CASCADE MODE

The MBL 8259A can be easily interconnected in a system of one master with up to eight slaves to handle up to 64 priority levels.
The master controls the slaves through the 3 line cascade bus. The cascade bus acts like chip selects to the slaves during the $\overline{\mathrm{INTA}}$ sequence.
In a cascade configuration, the slave interrupt outputs are connected to the master interrupt request inputs. When a slave request line is activated and afterwards acknowledged, the master will enable the corresponding slave to release the device routine address during bytes 2 and 3 of INTA. (Byte 2 only for MBL 8086/8088).
The cascade bus lines are normally low and will contain the slave address code from the trailing edge of the first INTA pulse to the trailing edge of the third pulse. Each MBL 8259A in the system must follow a separate initialization sequence and can be programmed to work in a different mode. An EOI command must be issued twice: once for the master and once for the corresponding slave. An address decoder is required to activate the Chip Select ( $\overline{\mathbf{C S}}$ ) input of each MBL 8259A.
The cascade lines of the Master MBL 8259A are activated only for slave inputs, non slave inputs leave the cascade line inactive (low).

Fig. 11 - CASCADING THE MBL 8259A (22 INTERRUPT LEVELS)


INTERRUPT REQUESTS

Special consideration should be taken when mixed interrupt requests are assigned to a master 8259A; that is, when some of the master's IR inputs are used for slave interrupt requests and some are used for individual interrupt requests. In this type of structure, the master's IRO must not be used for a slave. This is because when an IR input that isn't initialized as a slave receives an interrupt request,
the CASO-2 lines won't be activated, thus staying in the default condition addressing for IRO (slave IRO). If a slave is connected to the master's IRO when a non-slave interrupt occurs on another master IR input, erroneous conditions may result. Thus IRO should be the last choice when assigning slaves to IR inputs.
(© Intel Corporation, 1979)

Fig. 12 - CASCADE-BUFFERED MODE EXAMPLE

© Intel Corporation, 1979

## ABSOLUTE MAXIMUM RATING*

Ambient Temperature Under Blas . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin
with Respect ot Ground . . . . . . . . . . . . . . -0.5 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . 1 W
*NOTE:- Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $\left(V_{C C}=5 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{cc}}+0.5 \mathrm{~V}$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{IOL}=2.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH}(\text { INT }}$ | Interrupt Output High Voltage | 3.5 |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
|  |  | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $I_{L I}$ | Input Load Current | -10 | +10 | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {cc }}$ |
| ILOL | Output Leakage Current | -10 | +10 | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $I_{\text {cc }}$ | V cc Supply Current |  | 85 | mA |  |
| $I_{\text {LIR }}$ | IR Input Load Current |  | -300 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0 \mathrm{~V}$ |
|  |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {cc }}$ |

CAPACITANCE $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to $V_{\mathrm{ss}}$ |

A.C. CHARACTERISTICS $\left(V_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$ TIMING REQUIREMENTS

| Symboi | Parameter | MBL 8259A |  | MBL 8259A-2 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TAHRL | A0/CS Setup to $\overline{\mathrm{RD}} / \overline{\text { INTA }} \downarrow$ | 0 |  | 0 |  | ns |  |
| TRHAX | AO/ $\overline{C S}$ Hold after $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}} \uparrow$ | 0 |  | 0 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Pulse Width | 235 |  | 160 |  | ns |  |
| TAHWL | A0/ $\overline{C S}$ Setup to $\overline{W R} \downarrow$ | 0 |  | 0 |  | ns |  |
| TWHAX | AO/ $\overline{\mathbf{C S}}$ Hold after $\overline{W R} \uparrow$ | 0 |  | 0 |  | ns |  |
| TWLWH | $\overline{\text { WR Pulse Width }}$ | 290 |  | 190 |  | ns |  |
| TDVWH | Data Setup to $\overline{\mathrm{WR}} \uparrow$ | 240 |  | 160 |  | ns |  |
| TWHDX | Data Hold after $\overline{W R} \uparrow$ | 0 |  | 0 |  | ns |  |
| TJLJH | Interrupt Request Width (Low) | 100 |  | 100 |  | ns | See Note 1 |
| TCVIAL | Cascade Setup to Second or Third $\overline{\text { INTA }} \downarrow$ (SIvae Only) | 55 |  | 40 |  | ns |  |
| TRHRL | End of $\overline{\mathrm{RD}}$ to next $\overline{\mathrm{RD}}$ <br> End of INTA to next INTA within an INTA sequence only | 160 |  | 160 |  | ns |  |
| TWHWL | End of $\overline{W R}$ to next $\overline{W R}$ | 190 |  | 190 |  | ns |  |
| *TCHCL | End of Command to next Command (Not same command type) <br> End of $\overline{\mathrm{INTA}}$ sequence to next $\overline{\mathrm{NTA}}$ sequence. | 500 |  | 500 |  | ns |  |

*Worst case timing for TCHCL in an actual microprocessor system is typically much greater than 500 ns (i.e. Intel 8085A
$=1.6 \mu \mathrm{~s}$, Intel 8085A-2 = $1 \mu \mathrm{~s}$, MBL $8086=1 \mu \mathrm{~s}$, MBL 8086-2 = 625 ns )
NOTE: This is the low time required to clear the input latch in the edge triggered mode.

TIMING RESPONSES

| Symbol | Parameter | MBL 8259A |  | MBL 8259A-2 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TRLDV | Data Valid from $\overline{\mathrm{RD}} / \overline{\mathrm{INTA}} \downarrow$ |  | 200 |  | 120 | ns | $\begin{aligned} & C \text { of Data Bus }= \\ & 100 \text { pF } \\ & \left(\begin{array}{l} \text { C of Data Bus } \\ \text { Max. text } C=100 \mathrm{pF} \\ \text { Min. text } \mathrm{C}=15 \mathrm{pF} \end{array}\right) \end{aligned}$ |
| TRHDZ | Data Float after $\overline{\mathrm{RD}} / \overline{\mathrm{NTTA}} \uparrow$ | 10 | 100 | 10 | 85 | ns |  |
| TJHIH | Interrupt Output Delay |  | 350 |  | 300 | ns |  |
| TIALCV | Cascade Valid from First $\overline{\text { INTA }} \downarrow$ (Master Only) |  | 565 |  | 360 | ns | $\begin{aligned} & C_{\text {INT }}=100 \mathrm{pF} \\ & \mathrm{C}_{\text {CASCADE }}=100 \mathrm{pF} \end{aligned}$ |
| TRLEL | Enable Active from $\overline{\mathrm{RD}} \downarrow$ or $\overline{\text { TNTA }} \downarrow$ |  | 125 |  | 100 | ns |  |
| TRHEH | Enable Inactive from $\overline{\mathrm{RD}} \uparrow$ or $\overline{\mathrm{NTA}} \uparrow$ |  | 150 |  | 150 | ns |  |
| TAHDV | Data Valid from Stable Address |  | 200 |  | 200 | ns |  |
| TCVDV | Cascade Valid to Valid Data |  | 300 |  | 200 | ns |  |

## A.C. TESTING INPUT/OUTPUT WAVEFORM



AC TESTING INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC " 1 " AND 0.45V FOR A LOGIC " 0 ". TIMING MEASUREMENTS ARE MADE AT 2.0 V FOR A LOGIC "1" AND 0.8V FOR A LOGIC "0".
A.C. TESTING LOAD CIRCUIT


## WAVEFORMS

## WRITE



WAVEFORMS (Continued)
READ/INTA


OTHER TIMINGS


## WAVEFORMS (Continued)



NOTES: Interrupt output must remain HIGH at least until leading edge of first $\overline{\text { NTA. }}$ (1) MBL 8086/8088 system mode: at first INTA the Data Bus is not active. (2) 8080/8085 system mode: only.

## PACKAGE ILLUSTRATION



## PLASTIC DIMENSIONS

 CERAMIC DIP(Suffix: -C)

FUJITSU

MBL 8259A
MBL 8259A-2

## PACKAGE ILLUSTRATION



PACKAGE DIMENSIONS
PLASTIC DIP (Suffix: -P)

28-LEAD PLASTIC DUAL IN-LINE PACKAGE
(CASE No. : DIP-28P-M02)



The MBL8282 and MBL8283 are 8-bit bipolar latches with 3state output buffers. They can be used to implement latches, buffers or multiplexers. The MBL8283 inverts the input data at its outputs while the MBL8282 does not. Thus, all of the principle peripherals and input/output functions of a microcomputer system can be implemented with these devices.

## Features

- Address Latch for MBL8086, MBL8088, MBL8089, MCS80*, MCS-85*, MCS-48* Familles
- High Output Drive

Capability for Driving
System Data Bus

- Fully Parallel 8-Bit Data

Register and Buffer


## Logic Diagrams



## Pin Configurations




## Functional Description

The MBL8282 and MBL8283 are 8 -bit latches with 3 -state output buffers. Data having satisfied the setup time requirements is clocked into the data latches by strobing the STB line HIGH to LOW.

Holding the STB line in its active HIGH state makes the latches appear transparent. Data is presented to the data output pins by activating the $\overline{O E}$ input line. When OE is inactive HIGH the output
buffers are in their high impedance state. Enabling or disabling the output buffers will not cause negative-going transients to appear on the data output bus.

## Pin Description

| Pin | Description |
| :---: | :---: |
| STB | STROBE (Input). STB is an input control pulse used to strobe data at the data input pins $\left(A_{0}-A_{7}\right)$ into the data latches. This signal is active to HIGH to allow data in. The data is latched during the HIGH to LOW transition of STB. |
| $\overline{\overline{O E}}$ | OUTPUT ENABLE (Input) $\overline{\mathrm{OE}}$ is an input control signal which when active LOW enables the contents of the data latches to be sent to the data output pins $\left(B_{0}-B_{7}\right)$. $\overline{\mathrm{OE}}$ being inactive HIGH forces the output buffers to their high impedance state. |
| $\overline{\mathrm{DI}_{0}-\mathrm{Dl}_{7}}$ | DATA INPUT PINS (Input). Data present at these pins is clocked into the data input latches when STB is strobed. |
| $\begin{aligned} & \hline \mathrm{DO}_{0}-\mathrm{DO}_{7} \\ & (\mathrm{MBL} \\ & \mathrm{MO}_{0}-\mathrm{DO}_{7} \\ & \left(\mathrm{MBL}_{7}\right) \\ & \hline \end{aligned}$ | DATA OUTPUT PINS (Output). When $\overline{\mathrm{OE}}$ is low, the data in the data latches appears as inverted (MBL8283) or non-inverted (MBL8282) data on the data output pins. |

## Absolute Maximum Ratings*

| Parameter | Rating | Unit |
| :--- | :--- | :--- |
| Temperature Under Bias | $0^{\circ}$ to $70^{\circ}$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $-65^{\circ}$ to $+150^{\circ}$ | ${ }^{\circ} \mathrm{C}$ |
| Supply Voltage | -0.5 to +7.0 | V |
| All Input Voltages | -0.5 to +7.0 | V |
| All Output Voltages (3-State Output) | +5.5 | V |
| Power Dissipation | 1.0 | W |

Note: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. Characteristics

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

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 160 | mA |  |
| $\mathrm{I}_{\mathrm{F}}$ | Forward Input Current |  | -0.2 | mA | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| IR | Reverse Input Current |  | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\text {OFF }}$ | Output Off Current |  | $\pm 50$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OFF }}=0.45 \mathrm{~V}$ to 5.25 V |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | 0.8 | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V} \quad$ See Note 1 |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input High Voltage | 2.0 |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \quad$ See Note 1 |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 12 | pF | $\begin{aligned} & \mathrm{F}=1 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{BIAS}}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ |

Note:

1. Output Loading $\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$.

## A.C. Characteristics

( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$, Loading: Outputs$\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}$,
$\mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$ )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TIVOV | Input to Output Delay -Inverting (MBL8283) -Non-Inverting (MBL8282) | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 22 \\ & 30 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ | (See Note 1) |
| TSHOV | STB to Output Delay -Inverting (MBL8283) -Non-Inverting (MBL8282) | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | $\begin{aligned} & 40 \\ & 45 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |  |
| TEHOZ | Output Disable Time | 5 | 18 | ns |  |
| TELOV | Output Enable Time | 10 | 30 | ns |  |
| TIVSL | Input to STB Setup Time | 0 |  | ns |  |
| TSLIX | Input to STB Hold Time | 25 |  | ns |  |
| TSHSL | STB High Time | 15 |  | ns |  |
| TILIH, TOLOH | Input, Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TIHIL, TOHOL | Input, Output Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

Note:

1. See waveforms and test load circuit on following page.

## A.C. Testing Input/ Output Waveform


A.C. TESTING: INPUTS ARE DRIVEN AT 2.4V FOR A

LOGIC "1" AND 0.45V FOR A LOGIC "0." TIMING MEAS-
UREMENTS ARE MADE AT 1.5V FOR BOTH A LOGIC "1"
AND " 0 ". INPUT RISE AND FALL TIMES ARE MEASURED
FROM ). 8 V TO 2.0V AND ARE DRIVEN AT $5 \pm 2 \mathrm{~ns}$.

## Waveforms



NOTE: 1. FOR MBL 8283 ONLY - OUTPUT MAY BE MOMENTARILY INVALID FOLLOWING THE HIGH GOING STB TRANSITION.
2. ALL TIMING MEASUREMENTS ARE MADE AT 1.5V UNLESS OTHERWISE NOTED.

## Output Test Load Circuits



## Output Delay vs. <br> \section*{Capacitance}




Package Dimensions Dimensions in inches (millimeters)

20-Lead Ceramic Dual In-Line Package DIP-20C-CO1


## FUJITSU

## BIPOLAR CLOCK GENERATOR AND DRIVER FOR MBL 8086/8088/8089

- Generates the System Clock for the MBL 8086/8088/8089 Processors:
5 MHz and 8 MHz with MBL 8284A 10MHz with MBL 8284A-1
- Uses a Crystal or a TTL Signal for Frequency Source
- Provides Local READY and Multibus* READY Synchronization
- Generates System Reset Output from Schmitt Trigger Input
- Capable of Clock Synchronization with Other MBL 8284As
- Single +5 V Power Supply
- 18-Pin Cerdip (Suffix: -CZ)


[^20]
## PIN DESCRIPTION

TABLE 1 - PIN DISCRIPTION

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\frac{\overline{\mathrm{AEN1} 1},}{\mathrm{AEN} 2}$ | 1 | Address Enable: $\overline{\text { AEN }}$ is an active LOW signal. $\overline{\text { AEN }}$ serves to qualify its respective Bus Ready Signal (RDY1 or RDY2). $\overline{\text { AEN1 }}$ validates RDY1 while $\overline{\text { AEN2 }}$ validates RDY2. Two $\overline{\text { AEN }}$ signal inputs are useful in system configurations which permit the processor to access two Multi-Master System Busses. In non Multi-Master configurations the $\overline{\text { AEN }}$ signal inputs are tied true (LOW). |
| RDY1, RDY2 | 1 | Bus Ready: (Transfer Complete), RDY is an active HIGH signal which is an indication from a device located on the system data bus that data has been received, or is available. RDY1 is qualified by $\overline{\text { AEN1 }}$ while RDY2 is qualified by $\overline{\text { EN2 }}$. |
| $\overline{\text { ASYNC }}$ | 1 | Ready Synchronization Select: $\overline{\text { ASYNC }}$ is an input which defines the synchronization mode of the READY logic. When $\overline{A S Y N C}$ is low, two stages of READY synchronization are provided. When $\overline{\text { ASYNC }}$ is left open (internal pull-up resistor is provided.) or HIGH a single stage of READY synchronization is provided. |
| READY | 0 | Ready: READY is an active HIGH signal which is the synchronized RDY signal input. READY is cleared after the guaranteed hold time to the processor has been met. |
| x1, X2 | 1 | Crystal In: X1 and X2 are the pins to which a crystal is attached. The crystal frequency is 3 times the desired processor clock frequency. |
| F/C | 1 | Frequency/Crystal Select: $F / \overline{\mathrm{C}}$ is a strapping option. When strapped LOW, $\mathrm{F} / \overline{\mathrm{C}}$ permits the processor's clock to be generated by the crystal. When F/C is strapped HIGH, CLK is generated from the EFI input. |
| EFI | 1 | External Frequency: When F/ $\overline{\mathrm{C}}$ is strapped HIGH, CLK is generated from the input frequency appearing on this pin. The input signal is a square wave 3 times the frequency of the desired CLK output. |
| CLK | 0 | Processor Clock: CLK is the clock output used by the processor and all devices which directly connect to the processor's local bus (i.e., the bipolar support chips and other MOS devices). CLK has an output frequency which is $1 / 3$ of the crystal or EFI input frequency and a $1 / 3$ duty cycle. An output HIGH of 4.5 volts $\left(\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}\right)$ is provided on this pin to drive MOS devices. |
| PCLK | 0 | Peripheral Clock: PCLK is a TTL level peripheral clock signal whose output frequency is $1 / 2$ that of CLK and has a $50 \%$ duty cycle. |
| OSC | 0 | Oscillator Output: OSC is the TTL level output of the internal oscillator circuitry. Its frequency is equal to that of the crystal. |
| $\overline{\text { RES }}$ | 1 | Reset In: $\overline{\text { RES }}$ is an active LOW signal which is used to generate RESET. The MBL 8284A provides a Schmitt trigger input so that an RC connection can be used to establish the powerup reset of proper duration. |
| RESET | 0 | Reset: RESET is an active HIGH signal which is used to reset the MBL 8086 family processors, its timing characteristics are determined by $\overline{\text { RES. }}$ |
| CSYNC | 1 | Clock Synchronization: CSYNC is an active HIGH signal which allows multiple MBL 8284A to be synchronized to provide clocks that are in phase. When CSYNC is HIGH the internal counters are reset. When CSYNC goes LOW the internal counters are allowed to resume counting. CSYNC needs to be externally synchronized to EFI. When using the internal oscillator CSYNC should be hardwired to ground. |
| GND |  | Ground. |
| $\mathrm{V}_{\text {cc }}$ |  | Power: +5 V supply. |

## FUNCTIONAL DESCRIPTION

## GENERAL

The MBL 8284A is a single chip clock generator/driver for the MBL 8086/MBL 8088/MBL 8089 processors. The chip contains a crystal-controlled oscillator, a divide-by-three counter, complete MULTIBUS* "Ready" synchronization and reset logic. Refer to Figure 1 for Block Diagram and Figure 2 for Pin Configuration.

## OSCILLATOR

The oscillator circuit of the MBL 8284A is designed primarily for use with an external series resonant, fundamental mode, crystal from which the basic operating frequency is derived.
The crystal frequency should be selected at three times the required CPU clock. X1 and X2 are the two crystal input crystal connections. For the most stable operation of the oscillator (OSC) output circuit, two series resistors $\left(R_{1}=R_{2}=510 \Omega\right)$ as shown in the waveform figures are recommended. The output of the oscillator is buffered and brought out on OSC so that other system timing signals can be derived from this stable, crystal-controlled source.

For systems which have a $\mathrm{V}_{\mathrm{CC}}$ ramp time $\geqslant 1 \mathrm{~V} / \mathrm{ms}$ and/or have inherent board capacitance between X1 or X2, exceeding 10pF (not including MBL 8284A pin capacitance), the two $510 \Omega$ resistors should be used. This circuit provides optimum stability for the oscillator in such extreme conditions. It is advisable to limit stray capacitances to less than 10 pF on X 1 and X 2 to minimize deviation from operating at the fundamental frequency. For notes of using MBL 8284A, see page 10.

## CLOCK GENERATOR

The clock generator consists of a synchronous divide-by-three counter with a special clear input that inhibits the counting. This clear input (CSYNC) allows the output clock to be synchronized with an external event (such as another MBL 8284A clock). It is necessary to synchronize the CSYNC input to the EFI clock external to the MBL 8284A. This is accomplished with two Schottky flip-flops. The counter output is a $33 \%$ duty cycle clock at one-third the input frequency.

The $F / \bar{C}$ input is a strapping pin that selects either the crystal oscillator or the EFI input as the clock for the $\div 3$ counter. If the EFI input is selected as the clock source, the oscillator section can be used independently for another clock source. Output is taken from OSC.

## CLOCK OUTPUTS

The CLK output is a $33 \%$ duty cycle MOS clock driver designed to drive the MBL 8086/MBL 8088/MBL 8089 processors directly. PCLK is a TTL level peripheral
clock signal whose output frequency is $1 / 2$ that of CLK, PCLK has a 50\% duty cycle.

## RESET LOGIC

The reset logic provides a Schmitt trigger input ( $\overline{\mathrm{RES}}$ ) and a synchronizing flip-flop to generate the reset timing. The reset signal is synchronized to the falling edge of CLK. A simple RC network can be used to provide power-on reset by utilizing this function of the MBL 8284A.

## READY SYNCHRONIZATION

Two READY inputs (RDY1, RDY2) are provided to accommodate two Multi-Master system busses. Each input has a qualifier ( $\overline{\mathrm{AEN}} 1$ and $\overline{\mathrm{AEN2}}$, respectively). The $\overline{\mathrm{AEN}}$ signals validate their respective RDY signals. If a MultiMaster system is not being used the $\overline{\mathrm{AEN}}$ pin should be tied LOW.

Synchronization is required for all asynchronous activegoing edges of either RDY input to guarantee that the RDY setup and hold times are met. Inactive-going edges of RDY in normally ready systems do not require synchronization but must satisfy RDY setup and hold as a matter of proper system design.

The $\overline{\text { ASYNC }}$ input defines two modes of READY synchronization operation.

When $\overline{\text { ASYNC }}$ is LOW, two stages of synchronization are provided for active READY input signals. Positive-going asynchronous READY inputs will first be synchronized to flip-flop one at the rising edge of CLK and then synchronized to flip-flop two at the next falling edge of CLK, after which time the READY output will go active (HIGH). Negative-going asynchronous READY inputs will be synchronized directly to flip-flop two at the falling edge of CLK, after which time the READY output will go inactive. This mode of operation is intended for use by asynchronous (normally not ready) devices in the system which cannot be guaranteed by design to meet the required RDY setup timing, $t_{\text {RIVCL }}$, on each bus cycle.

When $\overline{A S Y N C}$ is high or left open, the first READY flipflop is bypassed in the READY synchronization logic. READY inputs are synchronized by flip-flop two on the falling edge of CLK before they are presented to the processor. This mode is available for synchronous devices that can be guaranteed to meet the required RDY setup time.
$\overline{\text { ASYNC }}$ can be changed on every bus cycle to select the appropriate mode of synchronization for each device in the system.

[^21]Fig. 3 - CSYNC SYNCHRONIZATION


## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias
. . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Supply Voltages . . . . . . . . . . . . . . . . . -0.5 V to +7.0 V
All Input and Output Voltages. . . . . . . . . -0.5 V to $\mathrm{V}_{\mathrm{Cc}}$
Power Dissipation

* NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS ( $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ )

| Symbol | Parameter |  | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{F}$ | Forward Input Current | $\overline{\text { ASYNC }}$ <br> Other Inputs |  | $\begin{aligned} & -1.3 \\ & -0.5 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & V_{F}=0.45 \mathrm{~V} \\ & V_{F}=0.45 \mathrm{~V} \end{aligned}$ |
| $I_{R}$ | Reverse Input Current | $\overline{\text { ASYNC }}$ <br> Other Inputs |  | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | ${ }_{\mu \mathrm{A}}^{\mu \mathrm{A}}$ | $\begin{aligned} & V_{R}=V_{c c} \\ & V_{R}=5.25 V \end{aligned}$ |
| $\mathrm{V}_{\mathrm{c}}$ | Input Forward Clamp Voltage |  |  | -1.0 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $I_{\text {cc }}$ | Power Supply Current |  |  | 162 | mA |  |
| $V_{\text {IL }}$ | Input LOW Voltage |  |  | 0.8 | V |  |
| $V_{1 H}$ | Input HIGH Voltage |  | 2.0 |  | V |  |
| $V_{\text {IHR }}$ | Reset Input HIGH Voltage |  | 2.6 |  | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | CLK Other Outputs | $\begin{aligned} & 4 \\ & 2.4 \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |
| $V_{\text {IHR }}-V_{\text {ILR }}$ | $\overline{\mathrm{RES}}$ Input Hysteresis |  | 0.25 |  | V |  |

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

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {ehel }}$ | External Frequency HIGH Time | 13 |  | ns | (90\%-90\%) $\mathrm{V}_{\mathrm{IN}}$ |
| teleh | External Frequency LOW Time | 13 |  | ns | (10\%-10\%) $\mathrm{V}_{\text {IN }}$ |
| $t_{\text {elel }}$ | (Note 1) | 40 |  | ns | For MBL 8284A |
|  |  | 33 |  |  | For MBL 8284A-1 |
|  | XTAL Frequency | 12 | 25 | MHz | For MBL 8284A |
|  |  |  | 30 |  | For MBL 8284A-1 |
| $\mathrm{t}_{\text {R1VCL }}$ | RDY1, RDY2 Active Setup to CLK | 35 |  | ns | $\overline{\text { ASYNC }}=\mathrm{HIGH}$ |
| $\mathrm{t}_{\text {R1VCH }}$ | RDY1, RDY2 Active Setup to CLK | 35 |  | ns | $\overline{\text { ASYNC }}=$ LOW |
| $\mathrm{t}_{\text {R1VCL }}$ | RDY1, RDY2 Inactive Setup to CLK | 35 |  | ns |  |
| $\mathrm{t}_{\text {CLR } 1 \times}$ | RDY1, RDY2 Hold to CLK | 0 |  | ns |  |
| $t_{\text {A YVCL }}$ | $\overline{\text { ASYNC }}$ Setup to CLK | 50 |  | ns |  |
| $\mathrm{t}_{\text {clay }}$ | $\overline{\text { ASYNC Hold to CLK }}$ | 0 |  | ns |  |
| $t_{\text {alvriv }}$ | $\overline{\text { AEN1 }}$, $\overline{\text { AEN2 }}$ Setup to RDY1, RDY2 | 15 |  | ns |  |
| $\mathrm{t}_{\text {cla }}$ ( ${ }^{\text {a }}$ | AEN1, $\overline{\text { AEN2 }}$ Hold to CLK | 0 |  | ns |  |
| $\mathrm{t}_{\text {YHEH }}$ | CSYNC Setup to EFI | 20 |  | ns |  |
| $t_{\text {ehyl }}$ | CSYNC Hold to EFI | 10 |  | ns |  |
| trayt | CSYNC Width | $\mathbf{2 \cdot t} \mathrm{t}_{\text {elel }}$ |  | ns |  |
| $\mathrm{t}_{11 \mathrm{HCL}}$ | $\overline{\mathrm{RES}}$ Setup to CLK | 65 |  | ns | (Note 1) |
| ${ }^{\text {ctilin }}$ | $\overline{\text { RES }}$ Hold to CLK | 20 |  | ns | (Note 1) |

## A.C. CHARACTERISTICS (Continued)

TIMING RESPONSES

| Symbol | Parameter | MBL 8284A Min. | $\begin{gathered} \text { MBL 8284A-1 } \\ \text { Min. } \end{gathered}$ | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }}$ clcl | CLK Cycle Period | 125 | 100 |  | ns |  |
| ${ }^{\text {t }}$ CHCL | CLK HIGH Time | $\left(1 / 3 t_{\text {CLCL }}\right)+2$ | 39 |  | ns |  |
| ${ }^{\text {t }}$ cLCH | CLK LOW Time | $\left(2 / 3 \mathrm{t}_{\text {CLCL }}\right)-15$ | 53 |  | ns |  |
| ${ }^{\text {t }}{ }^{\text {H/CH2 }}$ | CLK Rise Time |  |  | 10 | ns | From 1.0 V to 3.5 V |
| ${ }^{\text {t }}{ }^{\text {cl2CL2 }}$ | CLK Fall time |  |  | 10 | ns | From 3.5 V to 1.0 V |
| $\mathrm{t}_{\text {PHPL }}$ | PCLK HIGH Time | $\mathrm{t}_{\text {cLCL }} \mathbf{- 2 0}$ | $\mathrm{t}_{\text {clcl }} \mathbf{- 2 0}$ |  | ns |  |
| tPLPH | PCLK LOW Time | $\mathrm{t}_{\text {clCL }}$-20 | $\mathrm{t}_{\mathrm{CLCL}} \mathbf{- 2 0}$ |  | ns |  |
| $\mathrm{t}_{\text {RYLCL }}$ | Ready Inactive to CLK | -8 | -8 |  | ns | (Note 3) |
| $\mathrm{t}_{\text {RYHCH }}$ | Ready Active to CLK | ( $2 / 3 \mathrm{t}_{\text {CLCL }}$ )-15 | 53 |  | ns | (Note 2) |
| ${ }^{\text {cheliL }}$ | CLK to Reset Delay |  |  | 40 | ns |  |
| ${ }^{\text {t CLPH }}$ | CLK to PCLK HIGH Delay |  |  | 22 | ns |  |
| ${ }^{\text {t CLPL }}$ | CLK to PCLK LOW Delay |  |  | 22 | ns |  |
| ${ }^{\text {tolch }}$ | OSC to CLK HIGH Delay | -5 | -5 | 22 | ns |  |
| $\mathrm{t}_{\text {OLCL }}$ | OSC to CLK LOW Delay | 2 | -2 | 35 | ns |  |
| $\mathrm{t}_{\mathrm{OLOH}}$ | Output Rise Time (except CLK) |  |  | 20 | ns | From 0.8 V to 2.0 V |
| tohol | Output Fall Time (except CLK) |  |  | 12 | ns | From 2.0 V to 0.8 V |

## NOTES:

1. Setup and hold necessary only to guarantee recognition at next clock.
2. Applies only to $T_{3}$ and $T_{w}$ states.
3. Applies only to $T_{2}$ states.
A.C. TESTING INPUT, OUTPUT WAVEFORM
A.C. TESTING LOAD CIRCUIT


|  | $\mathrm{V}_{\mathrm{L}}(\mathrm{V})$ | $\mathrm{R}_{\mathrm{L}}(\Omega)$ | $\mathrm{C}_{\mathrm{L}}(\mathrm{pF})$ |
| :---: | :---: | :---: | :---: |
| CLK | 3.41 V | 590 | 100 |
| READY | 2.08 V | 325 | 30 |



## WAVEFORMS



## WAVEFORMS (Continued)



Clock high and low time (USing x1, X2)


CLOCK HIGH AND LOW TIME (USING EFI)


## READY TO CLOCK (USING X1, X2)



READY TO Clock (USING EFI)


NOTES:

1. $C_{L}=100 \mathrm{pF}$
2. $C_{L}=30 \mathrm{pF}$

## NOTES FOR USING MBL 8284A

For MBL 8284A's stable operation, the following things should be noted:

1. The fundamental mode crystal should be used.
2. Stray capacitances between $X 1$ and $X 2$ should be limited to less than $10 p F$.
3. External resistors for stable crystal oscillation should be connected as Configuration (I) or (II) shown below. Especially, for Configuration (I) circuit, the minimum frequency of crystal is limitted to 15 MHz . A low frequency crystal (less than 15 MHz ) with Configuration (I) circuit may cause an abnormal oscillation. For more stable osciallation over the specified frequency range ( 12 MHz to 25 MHz or 30 MHz ), Configuration (II) circuit is recommendable.
4. The rise time of the power supply voltage $\mathrm{V}_{\mathrm{cc}}$ should be more than 10 ms . A steep $\mathrm{V}_{\mathrm{cc}}$ rising (with the rise time less than 10 ms ) may cause an overtone oscillation.
5. In the power-on reset circuit shown below, the ground terminal of the external capacitor $C$ should be grounded as near to the GND pin of MBL 8284A as possible.
6. When the crystal oscillator circuit is not used (i.e., an external clock source is used), X 1 should be pulled up to $\mathrm{V}_{\mathrm{cc}}$ with an approx. $1 \mathrm{k} \Omega$ resistor and X 2 should be left open. At this time, OSC output is clamped at high level.


POWER-ON RESET CIRCUIT


EXTERNAL CLOCK CONFIGURATION


## PACKAGE ILLUSTRATION



## PACKAGE DIMENSIONS

CERAMIC DIP (Suffix:-CZ)


## Description

The MBL8286 and MBL8287 are 8-bit bipolar transceivers with 3-state outputs. The MBL8287 inverts the input data at its outputs while the MBL8286 does not. Thus, a wide variety of applications for buffering in microcomputer systems can be met.

Features

- Data Bus Buffer Driver for MBL8086, MBL8088,
BML8089, MCS-80*,
MCS-85*, and MCS-48*
Families
- High Output Drive Capability for Driving System Data Bus
- Fully Parallel 8-Bit Transceivers
- 3-State Outputs
- 20-Pin DIP
- No Output Low Noise when Entering or Leaving High Impedance State

Portions reprinted by permission of Intel Corporation ©Intel Corporation, 1983. Compilation and additional materials © 1985 by FUJITSU LIMITED, Tokyo, Japan.


## Logic Diagrams



Pin Configurations


| Pin Description | Symbol | Type | Name and Function |
| :---: | :---: | :---: | :---: |
|  | T | 1 | Transmit: T is an input control signal used to control the direction of the transceivers. When HIGH, it configures the transceiver's $\mathrm{B}_{0}-\mathrm{B}_{7}$ as outputs with $A_{0}-A_{7}$ as inputs. T LOW configures $A_{0}-A_{7}$ as the outputs and $B_{0}-B_{7}$ as the inputs. |
|  | $\overline{O E}$ | 0 | Output Enable: $\overline{\mathrm{OE}}$ is an input control signal used to enable the appropriate output driver (as selected by T ) onto its respective bus. This signal is active LOW. |
|  | $\mathrm{A}_{0}-\mathrm{A}_{7}$ | 1/O | Local Bus Data Pins: These pins serve to either send data to or accept data from the processor's local bus, depending upon the state of the $T$ pin. |
|  | $\begin{aligned} & \mathrm{B}_{0}-\mathrm{B}_{7} \\ & \left(\mathrm{MBBL}^{2}\right) \\ & \mathrm{B}_{0}-\mathrm{B}_{7} \\ & (\mathrm{MBL} 828) \\ & \hline \end{aligned}$ | 1/O | System Bus Data Pins: These pins serve to either send data to or accept data from the system bus, depending upon the state of the $T$ pin. |

## Functional Description

The MBL8286 and MBL 8287 are 8-bit transsceivers with high impedance outputs. With T active HIGH and OE active LOW, data at the
$\mathrm{A}_{0}-\mathrm{A}_{7}$ pins are sent to the $\mathrm{B}_{0}-\mathrm{B}_{7}$ pins. With T inactive low and $\overline{O E}$ active LOW, data at the $B_{0}-B_{7}$ pins is sent to the $\mathrm{A}_{0}-\mathrm{A}_{7}$ pins. No output
low glitching will occur when the transceivers are entering or leaving the high impedance state.

## Absolute Maximum Ratings

| Parameter | Rating | Unit |
| :--- | :--- | :--- |
| Temperature Under Bias | $0^{\circ}$ to $70^{\circ}$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $-65^{\circ}$ to $+150^{\circ}$ | ${ }^{\circ} \mathrm{C}$ |
| Supply Voltage | -0.5 to +7.0 | V |
| All Output Voltages (3-State Output) | +5.5 | V |
| All Input Voltages | -0.5 to +7.0 | V |
| Power Dissipation | 1.0 | W |

Note: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## DC Characteristics

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

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{c}}$ | Input Clamp Voltage |  | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| Icc | $\text { Power Supply Current }- \text { MBL8287 }$ |  | $\begin{aligned} & 130 \\ & 160 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| If | Forward Input Current |  | -0.2 | mA | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| IR | Reverse Input Current |  | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | $\text { Output Low Voltage } \begin{aligned} & \text { —B Outputs } \\ & -A \text { Outputs } \end{aligned}$ |  | $\begin{aligned} & 0.45 \\ & 0.45 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | $\text { Output High Voltage }- \text { B Outputs }$ | $\begin{aligned} & 2.4 \\ & 2.4 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |
| $\begin{aligned} & \overline{I_{\text {OFF }}} \\ & \mathbf{I}_{\text {OFF }} \end{aligned}$ | Output Off Current Output Off Current |  | $\begin{aligned} & I_{F} \\ & I_{R} \end{aligned}$ |  | $\begin{aligned} & \mathrm{V}_{\mathrm{OFF}}=0.45 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OFF}}=5.25 \mathrm{~V} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage - - A Side |  | $\begin{aligned} & 0.8 \\ & 0.9 \end{aligned}$ | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, See Note 1 <br> $V_{C C}=5.0 \mathrm{~V}$, See Note 1 |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | V | $\mathrm{V}_{\text {CC }}=5.0 \mathrm{~V}$, See Note 1 |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 12 | pF | $\begin{aligned} & \mathrm{F}=1 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{BIAS}}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |

Note: 1. $B$ Outputs $-\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$;
A Outputs-I $\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$.

## AC Characteristics

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

1. B Outputs- $\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}$,
$\mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$;
A Outputs- $\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$,
$\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$.

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TIVOV | Input to Output Delay Inverting -MBL8287 <br> Non-Inverting -MBL8286 | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 22 \\ & 30 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ | (See Note 1) |
| TEHTV | Transmit/Receive Hold Time | 5 |  | ns |  |
| TTVEL | Transmit/Receive Setup | 10 |  | ns |  |
| TEHOZ | Output Disable Time | 5 | 18 | ns |  |
| TELOV | Output Enable Time | 10 | 30 | ns |  |
| $\begin{aligned} & \text { TILIH, } \\ & \text { TOLOH } \end{aligned}$ | Input/Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| $\begin{aligned} & \text { TIHIL, } \\ & \text { TOHOL } \end{aligned}$ | Input/Output FallTime |  | 12 | ns | From 2.0 V to 8.0 V |

Note: 1. See the following waveforms and test load circuits.

## Waveforms



Note: All timing measurements are made at 1.5 V unless otherwise noted.

## MBL8286

MBL8287

## Test Load Circuits





## Output Delay Versus

## Capacitance




## Package Dimensions

Dimensions in inches (millimeters)

20-Lead Ceramic (CERDIP) Dual In-Line Package DIP-20C-C01


## FUJITSU <br> FOR MBL 8086/MBL 8088 /MBL 8089 PROCESSORS

MBL 8288

## BUS CONTROLLER FOR MBL 8086/MBL 8088/MBL 8089 PROCESSORS

The Fujitsu MBL 8288 Bus Controller is a 20 -pin bipolar component for use with medium-to-large MBL 8086/MBL 8088 processing systems. The bus controller provides command and control timing generation as well as bipolar bus drive capability while optimizing system performance.

A strapping option on the bus controller configures it for use with a multi-master system bus and separate I/O bus.

- Bipolar Drive Capability
- Provides Advanced Commands
- Provides Wide Flexibility in System Configurations
- 3-State Command Output Drivers
- Configurable for Use with an I/O Bus
- Facilitates Interface to One or Two Multi-Master Busses
- $\mathbf{1 0} \mathbf{~ M H z}$ Clock Rate
- Standard 20-pin Cerdip (Suffix-CZ)

Fig. 1 - BLOCK DIAGRAM
Fig. 2 - PIN ASSIGNMENT

*Trade Mark of Intel Corporation, USA.
Reprinted by premission of Intel Corporation © Intel Corporation, 1983

TABLE 1 - PIN DESCRIPTION

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ |  | Power: +5V supply |
| GND |  | Ground |
| $\overline{\mathrm{S}}, \overline{\mathrm{S} 1}, \mathrm{~S} 2$ | 1 | Status Input Pins: These pins are the status input pins from the MBL 8086, MBL 8088 or MBL 8089 processors. The MBL 8288 decodes these inputs to generate command and control signals at the appropriate time. When these pins are not in use (passive) they are all HIGH. (See chart under Command and Control Logic.) |
| CLK | 1 | Clock: This is a clock signal from the MBL 8284 clock generator and serves to establish when command and control signals are generated. |
| ALE | 0 | Address Latch Enable: This signal serves to strobe and address into the address latches. This signal is active HIGH and latching occurs on the falling (HIGH to LOW) transition. ALE is intended for use with transparent $D$ type latches. |
| DEN | 0 | Data Enable: This signal serves to enable data transceivers onto either the local or system data bus. This signal is active HIGH. |
| DT/ $\bar{R}$ | 0 | Data Transmit/Receive: This signal establishes the direction of data flow through the transceivers. A HIGH on this line indicates Transmit (Write to I/O or memory) and a LOW indicates Receive (Read). |
| $\overline{\text { AEN }}$ | 1 | Address Enable: $\overline{\text { AEN }}$ enables command outputs of the MBL 8288 Bus Controller at least 85 ns after it becomes active (LOW). $\overline{\text { AEN }}$ going inactive immediately 3 -states the command output drivers. $\overline{\text { AEN }}$ does not affect the I/O command lines if the MBL 8288 is in the I/O Bus mode (IOB tied HIGH). |
| CEN | 1 | Command Enable: When this signal is LOW all MBL 8288 command outputs and the DEN and $\overline{\text { PDEN }}$ control outputs are forced to their inactive state. When this signal is HIGH, these same outputs are enabled. |
| IOB | 1 | Input/Output Bus Mode: When the IOB is strapped HIGH the MBL 8288 functions in the I/O Bus mode. When it is strapped LOW, the MBL 8288 functions in the System Bus mode. (See sections on I/O Bus and System Bus modes). |
| $\overline{\text { AIOWC }}$ | 0 | Advanced I/O Write Command: The AIOWC issues an I/O Write Command earlier in the machine cycle to give $\mathrm{I} / \mathrm{O}$ devices an early indication of a write instruction. Its timing is the same as a read command signal. AIOWC is active LOW. |
| $\overline{\text { IOWC }}$ | 0 | I/O Write Command: This command line instructs an I/O device to read the data on the data bus. This signal is active LOW. |
| $\overline{\text { IORC }}$ | 0 | I/O Read Command: This command line instructs an I/O device to drive its data onto the data bus. This signal is active LOW. |
| $\overline{\text { AMWC }}$ | 0 | Advanced Memory Write Command: The $\overline{\text { AMWC }}$ issues a memory write command earlier in the machine cycle to give memory devices an early indication of a write instruction, its timing is the same as a read command signal, $\overline{\text { AMWC }}$ is active LOW. |
| $\overline{\text { MWTC }}$ | 0 | Memory Write Command: This command line instructs the memory to record the data present on the data bus. This signal is active LOW. |
| $\overline{\text { MRDC }}$ | 0 | Memory Read Command: This command line instructs the memory to drive its data onto the data bus. This signal is active LOW. |
| $\overline{\text { INTA }}$ | 0 | Interrupt Acknowledge: This command line tells an interrupting device that its interrupt has been acknowledged and that it should drive vectoring information onto the data bus. This signal is active LOW. |
| MCE/PDEN | 0 | This is a dual function pin. <br> MCE (IOB is tied LOW): Master Cascade Enable occurs during an interrupt sequence and serves to read a Cascade Address from a master PIC (Priority Interrupt Controller) onto the data bus. The MCE signal is active HIGH. <br> PDEN (IOB is tied HIGH): Peripheral Data Enable enables the data bus transceiver for the I/O bus that DEN performs for the system bus. $\overline{\text { PDEN }}$ is active LOW. |

## FUNCTIONAL DESCRIPTION

COMMAND AND CONTROL LOGIC
The command logic decodes the three MBL 8086, MBL 8088 or MBL 8089 CPU status lines ( $\overline{\mathrm{S} 0}, \overline{\mathrm{~S} 1}, \overline{\mathrm{~S} 2}$ ) to determine what command is to be issued.
This chart shows the meaning of each status "word".

| $\overline{\mathrm{SO}} \mathrm{S} 1 \mathrm{~S} 2$ | Processor State | MBL 8288 Command |
| :---: | :---: | :---: |
| $0 \quad 00$ | Interrupt Acknowledge | $\overline{\text { INTA }}$ |
| $\begin{array}{llll}0 & 0 & 1\end{array}$ | Read I/O Port | $\overline{\text { IORC }}$ |
| 010 | Write I/O Port | $\overline{\text { IOWC, }} \overline{\text { AIOWC }}$ |
| $\begin{array}{llll}0 & 1 & 1\end{array}$ | Halt | None |
| 100 | Code Access | $\overline{\text { MRDC }}$ |
| 1001 | Read Memory | $\overline{\text { MRDC }}$ |
| 110 | Write Memory | $\overline{\text { MWTC, }}$, $\overline{\text { MWWC }}$ |
| $\begin{array}{llll}1 & 1 & 1\end{array}$ | Passive | None |

The command is issued in one of two ways dependent on the mode of the MBL 8288 Bus Controller.
I/O Bus Mode - The MBL 8288 is in the I/O Bus mode if the IOB pin is strapped HIGH. In the I/O Bus mode all I/O command lines ( $\overline{\text { ORC, }} \overline{\text { IOWC, }} \overline{\text { AIOWC, }} \overline{\text { INTA }}$ ) are always enabled (i.e., not dependent on $\overline{\text { AEN }}$ ). When an I/O command is initiated by the processor, the MBL 8288 immediately activates the command lines using $\overline{\text { PDEN }}$ and $D T / \bar{R}$ to control the $I / O$ bus transceiver. The $1 / O$ command lines should not be used to control the system bus in this configuration because no arbitration is present. This mode allows one MBL 8288 Bus Controller to handle two external busses. No waiting is involved when the CPU wants to gain access to the I/O bus. Normal memory access requires a "Bus Ready" signal ( $\overline{\mathrm{AEN}}$ LOW) before it will proceed. It is advantageous to use the $1 O B$ mode if I/O or peripherals dedicated to one processor exist in a multi-processor system.
System Bus Mode - The MBL 8288 is in the System Bus mode if the IOB pin is strapped LOW. In this mode no command is issued until 85 ns after the $\overline{\mathrm{AEN}}$ Line is activated (LOW). This mode assumes bus arbitration logic will inform the bus controller (on the $\overline{\mathrm{AEN}}$ line) when the bus is free for use. Both memory and I/O commands wait for bus arbitration. This mode is used when only one bus exists. Here, both I/O and memory are shared by more than one processor.

## COMMAND OUTPUTS

The advanced write commands are made available to initiate write procedures early in the machine cycle. This signal can be used to prevent the processor from entering an unnecessary wait state.

The command outputs are
$\overline{\overline{M R D C}}$ - Memory Read Command
$\overline{\text { MWTC }}$ - Memory Write Command
$\overline{\overline{I O R C}}$ - I/O Read Command
$\overline{\overline{I O W C}}$ - I/O Write Command
$\overline{\overline{\text { AMWC }}}$ - Advanced Memory Write Command
$\overline{\overline{\text { AIOWC }} \text { - Advanced I/O Write Command }}$
$\overline{\text { INTA }}$ - Interrupt Acknowledge

INTA (Interrupt Acknowledge) acts as an I/O read during an interrupt cycle. Its purpose is to inform an interrupting device that its interrupt is being acknowledged and that it should place vectoring information onto the data bus.

## CONTROL OUTPUTS

The control outputs of the MBL 8288 are Data Enable (DEN), Data Transmit/Receive (DT/ $\bar{R}$ ) and Master Cascade Enable/Peripheral Data Enable (MCE/ $\overline{\text { PDEN }}$ ). The DEN signal determines when the external bus should be enabled onto the local bus and the DT/ $\overline{\mathrm{R}}$ determines the direction of data transfer. These two signals usually go to the chip select and direction pins of a transceiver.

The MCE/ $\overline{\operatorname{PDEN}}$ pin changes function with the two modes of the MBL 8288. When the MBL 8288 is in the IOB mode (IOB HIGH) the PDEN signal serves as a dedicated data enable signal for the $1 / O$ or Peripheral System bus.

## INTERRUPT ACKNOWLEDGE AND MCE

The MCE signal is used during an interrupt acknowledge cycle if the MBL 8288 is in the System Bus mode (IOB LOW). During any interrupt sequence there are two interrupt acknowledge cycles that occur back to back. During the first interrupt cycle no data or address transfers take place. Logic should be provided to mask off MCE during this cycle. Just before the second cycle begins the MCE signal gates a master Priority Interrupt Controller's (PIC) cascade address onto the processor's local bus where ALE (Address Latch Enable) strobes it into the address latches. On the leading edge of the second interrupt cycle the addressed slave PIC gates an interrupt vector onto the system data bus where it is read by the processor.

If the system contains only one PIC, the MCE signal is not used. In this case the second Interrupt Acknowledge signal gates the interrupt vector onto the processor bus.

## ADDRESS LATCH ENABLE AND HALT

Address Latch Enable (ALE) occurs during each machine cycle and serves to strobe the current address into the address latches. ALE also serves to strobe the status ( $\overline{\mathbf{S O}}$, $\overline{\mathrm{S} 1}, \overline{\mathrm{~S}} 2$ ) into a latch for halt state decoding.

## COMMAND ENABLE

The Command Enable (CEN) input acts as a command qualifier for the MBL 8288. If the CEN pin is high the MBL 8288 functions normally. If the CEN pin is pulled

LOW, all command lines are held in their inactive state (not 3 -state). This feature can be used to impiement memory partitioning and to eliminate address conflicts between system bus devices and resident bus devices.

* NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{c}}$ | Input Clamp Voltage |  | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| Icc | Power Supply Current |  | 230 | mA |  |
| $\mathrm{I}_{\mathrm{F}}$ | Forward Input Current |  | -0.7 | mA | $V_{F}=0.45 \mathrm{~V}$ |
| $I_{R}$ | Reverse Input Current |  | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage: Command Outputs Control Outputs |  | $\begin{aligned} & 0.5 \\ & 0.5 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage: Command Outputs Control Outputs | $\begin{aligned} & 2.4 \\ & 2.4 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & v \\ & v \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |
| $V_{\text {IL }}$ | Input Low Voltage |  | 0.8 | V |  |
| $V_{\text {IH }}$ | Input High Voltage | 2.0 |  | V |  |
| Ioff | Output Off Current |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OFF }}=0.4$ to 5.25 V |

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

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| TCLCL | CLK Cycle Period | 100 |  | ns |  |
| TCLCH | CLK Low Time | 50 |  | ns |  |
| TCHCL | CLK High Time | 30 |  | ns |  |
| TSVCH | Status Active Setup Time | 35 |  | ns |  |
| TCHSV | Status Active Hold Time | 10 |  | ns |  |
| TSHCL | Status Inactive Setup Time | 35 |  | ns |  |
| TCLSH | Status Inactive Hold Time | 10 |  | ns |  |

## A.C. CHARACTERISTICS (Continued) TIMING RESPONSES

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCVNV | Control Active Delay | 5 | 45 | ns | $\overline{M R D C}$$\overline{\text { IORC }}$ |
| TCVNX | Control Inactive Delay | 10 | 45 | ns |  |
| $\begin{aligned} & \text { TCLLH, } \\ & \text { TCLMCH } \end{aligned}$ | ALE MCE Active Delay (from CLK) |  | 20 | ns |  |
| TSVLH, TSVMCH | ALE MCE Active Delay (from Status) |  | 20 | ns |  |
| TCHLL | ALE Inactive Delay | 4 | 15 | ns | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA} \end{aligned}$ |
| TCLML | Command Active Delay | 10 | 35 | ns |  |
| TCLMH | Command Inactive Delay | 10 | 35 | ns | $\overline{\text { INTA }} \quad C_{L}=300 \mathrm{pF}$ |
| TCHDTL | Direction Control Active Delay |  | 50 | ns | $\overline{\text { AMWC }}$ |
| TCHDTH | Direction Control Inactive Delay |  | 30 | ns | AIOWC |
| TAELCH | Command Enable Time |  | 40 | ns | Other $\quad\left\{\begin{array}{l}\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \\ \mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}\end{array}\right.$ |
| TAEHCZ | Command Disable Time |  | 40 | ns |  |
| TAELCV | Enable Delay Time | 85 | 200 | ns |  |
| TAEVNV | AEN to DEN |  | 20 | ns |  |
| TCEVNV | CEN to DEN, PDEN |  | 25 | ns |  |
| TCELRH | CEN to Command |  | TCLML | ns |  |
| TOLOH | Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |


A.C. TESTING: Inputs are driven at 2.4 V for a logic " 1 " and 0.45 V for a logic " 0 ". The clock is driven at 4.3 V and 0.25 V . Timing measurements are made at 1.5 V for both a logic " 1 " and " 0 ". Input rise and fall times are $5 \pm 2 \mathrm{~ns}$, (measured between 0.8 V and 2.0 V .)


## WAVEFORMS



## NOTES:

1. ADDRESS/DATA Bus is shown only for reference purposes.
2. Leading edge of ALE and MCE is determined by the falting edge of CLK or status going active, whichever occurs last.
3. All timing measurements are made at 1.5 V unless specified otherwise.

## WAVEFORMS (Continued)



## PACKAGE ILLUSTRATION



## PACKAGE DIMENSIONS

(Suffix: -CZ)


## BIPOLAR BUS ARBITER FOR MBL 8086/8088/80186/80188/8089

The Fujitsu MBL 8289 Bus Arbiter is a 20-pin, 5-volt-only bipolar component for use with medium to large MBL 8086/8088/ 80186/80188 multi-master/multiprocessing systems. The MBL 8289 provides system bus arbitration for systems with multiple bus masters, such as an MBL 8086/8088/80186/80188 CPU with MBL 8089 IOP in its REMOTE mode, while providing bipolar buffering and drive capability.

- Provides Multi-Master System Bus Protocol
- Synchronizes MBL 8086/8088/80186/80188/ 8089 Processors with Multi-Master Bus: $-5 \mathrm{MHz}, 8 \mathrm{MHz}$ (MBL 8086/8088/8089), and 6 MHz (MBL 80186/80188) with MBL 8289 -10 MHz (MBL 8086/8088) and 8 MHz (MBL 80186/80188) with MBL 8289-1
- Provides Simple Interface with MBL 8288 Bus Controllers
- Four Operating Modes for Flexible System Configuration
- Compatible with Intel Bus Standard MULTIBUS*
- Provides System Bus Arbitration for MBL 8089 IOP in Remote Mode
- Two Package Options:
- 20-Pin Cerdip (Suffix: -CZ)
- 20-Pin Plastic DIP (Suffix: -P)

Fig. 1 - BLOCK DIAGRAM


Fig. 2 - PIN CONFIGURATION


Fig. 3 - FUNCTIONAL PINOUT


[^22]
## PIN DESCRIPTION

## TABLE 1 - PIN DESCRIPTION

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{Cc}}$ |  | Power: +5 V supply $\pm 10 \%$. |
| GND |  | Ground. |
| $\overline{\mathrm{S} 0}, \overline{\mathrm{~S} 1}, \overline{\mathrm{~s} 2}$ | 1 | Status Input Pins: The status input pins from an MBL 8086, MBL 8088, MBL 80186, MBL 80188 or MBL 8089 processor. The MBL 8289 decodes these pins to initiate bus request and surrender actions. (See Table 2.) |
| CLK | 1 | Clock: From the MBL 8284A clock chip and serves to establish when bus arbiter actions are initiated. |
| $\overline{\text { LOCK }}$ | 1 | Lock: A processor generated signal which when activated (low) prevents the arbiter from surrendering the multi-master system bus to any other bus arbiter, regardless of its priority. |
| $\overline{\text { CRQLCK }}$ | 1 | Common Request Lock: An active low signal which prevents the arbiter from surrendering the multi-master system bus to any other bus arbiter requesting the bus through the $\overline{C B R Q}$ input pin. |
| RESB | 1 | Resident Bus: A strapping option to configure the arbiter to operate in systems having both a multi-master system bus and a Resident Bus. Strapped high, the multi-master system bus is requested or surrendered as a function of the SYSB/ $\overline{\operatorname{RESB}}$ input pin. Strapped low, the SYSB/ $\overline{\operatorname{RESB}}$ input is ignored. |
| ANYROST | 1 | Any Request: A strapping option which permits the multi-master system bus to be surrendered to a lower priority arbiter as if it were an arbiter of higher priority (i.e., when a lower priority arbiter requests the use of the multimaster system bus, the bus is surrendered as soon as it is possiblel. When ANYROST is strapped low, the bus is surrendered according to Table 2. If ANYROST is strapped high and $\overline{\mathrm{CBRO}}$ is activated, the bus is surrendered at the end of the present bus cycle. Strapping CBRO low and ANYROST high forces the MBL 8289 arbiter to surrender the multi-master system bus after each transfer cycle. Note that when surrender occurs BREQ is driven false (high). |
| $\overline{O B}$ | 1 | IO Bus: A strapping option which configures the MBL 8289 Arbiter to operate in systems having both an 10 Bus (Peripheral Bus) and a multi-master system bus. The arbiter requests and surrenders the use of the multi-master system bus as a function of the status line, $\overline{\mathbf{S 2}}$. The multi-master system bus is permitted to be surrendered while the processor is performing 10 commands and is requested whenever the processor performs a memory command. Interrupt cycles are assumed as coming from the peripheral bus and are treated as an 10 command. |


| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\overline{\text { AEN }}$ | 0 | Address Enable: The output of the MBL 8289 Arbiter to the processor's address latches to the MBL 8288 Bus Controller and 8284A Clock Generator. $\overline{\mathrm{AEN}}$ serves to instruct the Bus Controller and address latches when to tri-state their output drivers. |
| $\frac{S Y S B /}{R E S B}$ | 1 | System Bus/Resident Bus: An input signal when the arbiter is configured in the S.R. Mode (RESB is strapped high) which determines when the multi-master system bus is requested and multi-master system bus surrendering is permitted. The signal is intended to originate from a form of address-mapping circuitry, as a decoder or PROM attached to the resident address bus. Signal transitions and glitches are permitted on this pin from $\phi 1$ of T4 to $\phi 1$ of T2 of the processor cycle. During the period from $\phi 1$ of T2 to $\phi 1$ of T4, only clean transitions are permitted on this pin (no glitches). If a glitch occurs, the arbiter may capture or miss it, and the multi-master system bus may be requested or surrendered, depending upon the state of the glitch. The arbiter requests the multi-master system bus in the S.R. Mode when the state of the SYSB/ $\overline{\text { RESB }}$ pin is high and permits the bus to be surrendered when this pin is low. |
| $\overline{\text { CBRQ }}$ | 1/0 | Common Bus Request: An input signal which instructs the arbiter if there are any other arbiters of lower priority requesting the use of the multi-master system bus. <br> The CBRO pins (open-collector output) of all the MBL 8289 Bus Arbiters which surrender to the multi-master system bus upon request are connected together. <br> The Bus Arbiter running the current transfer cycle will not itself pull the $\overline{\text { CBRO }}$ line low. Any other arbiter connected to the $\overline{\mathrm{CBRO}}$ line can request the multi-master system bus. The arbiter presently running the current transfer cycle drops its $\overline{\mathrm{BREQ}}$ signal and surrenders the bus whenever the proper surredner conditions exist. Strapping $\overline{C B R Q}$ low and ANYRQST high allows the multi-master system bus to be surrendered after each transfer cycle. See the pin definition of ANYROST. |
| $\overline{\text { INIT }}$ | 1 | Initialize: An active low multi-master system bus input signal used to reset all the bus arbiters on the multi-master system bus. After initialization, no arbiters have the use of the multimaster system bus. |
| $\overline{\text { BCLK }}$ | 1 | Bus Clock: The multi-master system bus clock to which all multi-master system bus interface signals are synchronized. |

TABLE 1 - PIN DESCRIPTION (Continued)

| Symbol | Type | Name and Function |
| :--- | :---: | :--- |
| $\overline{\text { BREQ }}$ | O | Bus Request: An active low output signal in <br> the parallel Priority Resolving Scheme which <br> the arbiter activates to request the use of the <br> multi-master system bus. |
| $\overline{\text { BPRN }}$ | I | Bus Priority In: The active low signal returned <br> to the arbiter to instruct if that it may acquire <br> the multi-master system bus on the next falling <br> edge of BCLK. $\overline{\text { BPRN indicates to the arbiter }}$ <br> that it is the highest priority requesting arbiter <br> presently on the bus. The loss of $\overline{B P R N}$ <br> instructs the arbiter that it has lost priority to <br> a higher priority arbiter. |
| $\overline{\text { BPRO }}$ | O | Bus Priority Out: An active low output signal <br> used in the serial priority resolving scheme <br> where $\overline{B P R O}$ is daisy-chained to $\overline{B P R N ~ o f ~ t h e ~}$ <br> next lower priority arbiter. |

## FUNCTIONAL DESCRIPTION

The MBL 8289 Bus Arbiter operates in conjunction with the MBL 8288 Bus Controller to interface MBL 8086/ 8088/80186/188 processors to a multi-master system bus (both the MBL 8086 and MBL 8088 are configured in their max mode). The processor is unaware of the arbiter's existence and issues commands as though it has exclusive use of the system bus. If the processor does not have the use of the multi-master system bus, the arbiter prevents the Bus Controller (MBL 8288), the data transceivers and the address latches from accessing the system bus (e.g. all bus driver outputs are forced into the high impedance state). Since the command sequence was not issued by the MBL 8288, the system bus will appear as "Not Ready" and the processor will enter wait states. The processor will remain in Wait until the Bus Arbiter acquires the use of the multi-master system bus whereupon the arbiter will allow the bus controller, the data transceivers, and the address latches to access the system. Typically, once the command has been issued and a data transfer has taken place, a transfer acknowledge (XACK) is returned to the processor to indicate "READY" from the accessed slave device. The processor then completes its transfer cycle. Thus the arbiter serves to multiplex a processor (or bus master) onto a multi-master system bus and avoid contention problems between bus masters.

## ARBITRATION BETWEEN BUS MASTERS

In general, higher priority masters obtain the bus when a lower priority master completes its present transfer cycle. Lower priority bus masters obtain the bus when a higher priority master is not accessing the system bus. A strapping option (ANYROST) is provided to allow the arbiter

| Symbol | Type | Name and Function |
| :--- | :--- | :--- |
| $\overline{\mathrm{BUSY}}$ | $1 / \mathrm{O}$ | Busy: An active low open collector multi- <br> master system bus interface signal used to <br> instruct all the arbiters on the bus when the <br> multi-master system bus is available. When the <br> multi-master system bus is available the highest <br> requesting arbiter (determined by $\overline{\mathrm{BPRN})}$ <br> seizes the bus and pulls $\overline{\mathrm{BUSY}}$ low to keep <br> other arbiters off of the bus. When the arbiter is <br> done with the bus, it releases the $\overline{\mathrm{BUSY}}$ signal, <br> permitting it to go high and thereby allowing <br> another arbiter to acquire the multi-master <br> system bus. |

to surrender the bus to a lower priority master as though it were a master of higher priority. If there are no other bus masters requesting the bus, the arbiter maintains the bus so long as its processor has not entered the HALT State. The arbiter will not voluntarily surrender the system bus and has to be forced off by another master's bus request, the HALT State being the only exception. Additional strapping options permit other modes of operation wherein the multi-master system bus is surrendered or requested under different sets of conditions.

## PRIORITY RESOLVING TECHNIQUES

Since there can be many bus masters on a multi-master system bus, some means of resolving priority between bus masters simultaneously requesting the bus must be provided. The MBL 8289 Bus Arbiter provides several resolving techniques. All the techniques are based on a priority concept that at a given time one bus master will have priority above all the rest. There are provisions for using parallel priority resolving techniques, serial priority resolving techniques, and rotating priority techniques.

## PARALLEL PRIORITY RESOLVING

The parallel priority resolving technique uses a separate bus request line ( $\overline{B R E Q}$ ) for each arbiter on the multi-master system bus, see Figure 4. Each $\overline{\mathrm{BREO}}$ line enters into a priority encoder which generates the binary address of the highest priority $\overline{B R E O}$ line which is active. The binary address is decoded by a decoder to select the corresponding $\overline{\text { BPRN }}$ (Bus Priority In) line to be returned to the highest priority requesting arbiter. The arbiter receiving priority ( $\overline{\mathrm{BPRN}}$ true) then allows its associated bus master

## MBL 8289 MBL 8289-1

onto the multi-master system bus as soon as it becomes available (i.e., the bus is no longer busy). When one bus arbiter gains priority over another arbiter it cannot immediately seize the bus, it must wait until the present bus transaction is complete. Upon completing its transaction the present bus occupant recognizes that it no longer has priority and surrenders the bus by releasing $\overline{\mathrm{BUSY}} . \overline{\mathrm{BUSY}}$ is an active low "OR" tied signal line which goes to every
bus arbiter on the system bus. When BUSY goes inactive (high), the arbiter which presently has bus priority ( $\overline{\mathrm{BPRN}}$ true) then seizes the bus and pulls BUSY low to keep other arbiters off of the bus. See waveform timing diagram, Figure 5 . Note that all multi-master system bus transactions are synchronized to the bus clock ( $\overline{B C L K}$ ). This allows the parallel priority resolving circuitry or any other priority resolving scheme employed to settle.

Fig. 4 - PARALLEL PRIORITY RESOLVING TECHNIQUE


Fig. 5 - HIGHER PRIORITY ARBITER OBTAINING THE BUS FROM A LOWER PRIORITY ARBITER

(1) HIGHER PRIORITY bUS ARBITER REQUESTS THE MULTI-MASTER SYSTEM BUS.
(2) ATTAINS PRIORITY.
(3) LOWER PRIORITY BUS ARBITER RELEASES BUSY.
(4) HIGHER PRIORITY BUS ARBITER THEN ACQUIRES THE BUS AND PULLS BUSY DOWN.

## SERIAL PRIORITY RESOLVING

The serial priority resoiving technique eliminates the need for the priority encoder-decoder arrangement by daisychaining the bus arbiters together, connecting the higher priority bus arbiter's $\overline{\mathrm{BPRO}}$ (Bus Priority Out) output to the $\overline{\text { BPRN }}$ of the next lower priority. See Figure 6.

Fig. 6 - SERIAL PRIORITY RESOLVING


THE NUMBER OF ARBITERS THAT MAY BE DAISYCHAINED TOGETHER IN THE SERIAL PRIORITY RESOLVING SCHEME IS A FUNCTION OF BCLK AND THE PROPAGATION DELAY FROM ARBITER TO ARBITER. NORMALLY, AT 10 MHz ONLY 3 ARBITERS MAY BE DAISY-CHAINED.

## ROTATING PRIORITY RESOLVING

The rotating priority resolving technique is similar to that of the parallel priority resolving technique except that priority is dynamically reassigned. The priority encoder is replaced by a more complex circuit which rotates priority between requesting arbiters thus allowing each arbiter an equal chance to use the multi-master system bus, over time.

## WHICH PRIORITY RESOLVING TECHNIQUE TO USE

There are advantages and disadvantages for each of the techniques described above. The rotating priority resolving technique requires substantial external logic to implement while the serial technique uses no external logic but can accommodate only a limited number of bus arbiters before the daisy-chain propagation delay exceeds the multimaster's system bus clock ( $\overline{\mathrm{BCLK}}$ ). The parallel priority resolving technique is in general a good compromise between the other two techniques. It allows for many arbiters to be present on the bus while not requiring too much logic to implement.

## MBL 8289 MODES OF OPERATION

There are two types of processors in the MBL 8086/80186 family. An Input/Output processor (the MBL 8089 IOP) and the MBL 8086/8088/80186/80188 CPUs. Consequently, there are two basic operating modes in the MBL 8289 bus arbiter. One, the IOB (I/O Peripheral Bus) mode, permits the processor access to both an I/O Peripheral Bus and a multi-master system bus. The second, the RESB (Resident Bus mode), permits the processor to communicate over both a Resident Bus and a multi-master system bus. An I/O Peripheral Bus is a bus where all devices on that bus, including memory, are treated as I/O devices and are addressed by I/O commands. All memory commands are directed to another bus, the multi-master system bus. A Resident Bus can issue both memory and I/O commands, but it is a distinct and separate bus from the multi-master system bus. The distinction is that the Resident Bus has only one master, providing full availability and being dedicated to that one master.

The $\overline{\mathrm{OB}}$ strapping option configures the MBL 8289 Bus Arbiter into the $\overline{I O B}$ mode and the strapping option RESB configures it into the RESB mode. It might be noted at this point that if both strapping options are strapped false, the arbiter interfaces the processor to a multi-master system bus only (see Figure 7). With both options strapped true, the arbiter interfaces the processor to a multi-master system bus, a Resident Bus, and an I/O Bus.

In the $\overline{\mathrm{IOB}}$ mode, the processor communicates and controls a host of peripherals over the Peripheral Bus. When the I/O Processor needs to communicate with system memory, it does so over the system memory bus. Figure 8 shows a possible I/O Processor system configuration.

The MBL 8086/8088/80186/80188 processors can communicate with a Resident Bus and a multi-master system bus. Two bus controllers and only one Bus Arbiter would be needed in such a configuration as shown in Figure 9. In such a system configuration the processor would have access to memory and peripherals of both busses. Memory mapping techniques are applied to select which bus is to be accessed. The SYSB/ $\overline{\operatorname{RESB}}$ input on the arbiter serves to instruct the arbiter as to whether or not the system bus is to be accessed. The signal connected to SYSB/ $\overline{\text { RESB }}$ also enables or disables commands from one of the bus controllers.

A summary of the modes that the MBL 8289 has, along with its response to its status lines inputs, is summarized in Table 2.

[^23]TABLE 2 - SUMMARY OF MBL 8289 MODES, REQUESTING AND RELINQUISHING THE MULTI-MASTER SYSTEM BUS

| Command | $\begin{array}{\|l} \text { Status Lines From } \\ \text { MBL } \\ 8086 / 8088 / 8089 / \\ 80186 / 80188 \end{array}$ |  |  | $\frac{\text { IOB Mode }}{\text { Only }}$ | $\frac{\text { RESB (M }}{10 \mathrm{~B}=\mathrm{High}}$ | de) Only RESB = High | $\begin{array}{r} \text { IOB Mode } \\ \overline{\text { IOB }=\text { Low }} \end{array}$ | RESB Mode $\text { ESB }=\mathrm{High}$ | $\begin{gathered} \text { Single } \\ \text { Bus Mode } \\ \hline \overline{10 B}=\text { High } \\ \text { RESB }=\text { Low } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1/O COMMANDS | $\begin{gathered} \overline{\mathbf{S 2}} \\ 0 \\ 0 \\ 0 \end{gathered}$ | $\begin{gathered} \overline{\mathbf{S 1}} \\ 0 \\ 0 \\ 1 \end{gathered}$ | $\begin{gathered} \overline{\mathbf{S O}} \\ 0 \\ 1 \\ 0 \end{gathered}$ | $\begin{gathered} \overline{\mathrm{IOB}}=\text { Low } \\ \mathrm{x} \\ \mathrm{x} \\ \mathrm{x} \end{gathered}$ | $\begin{gathered} \text { SYSB/RESB } \\ =\text { High } \end{gathered}$ | $\begin{gathered} \text { SYSB } / \overline{\text { RESB }} \\ =\text { Low } \\ x \\ x \\ x \end{gathered}$ | $\begin{gathered} \text { SYSB } / \overline{\text { RESB }} \\ =\text { High } \\ x \\ x \\ x \end{gathered}$ | $\begin{gathered} \text { SYSB } / \overline{\text { RESB }} \\ =\text { Low } \\ x \\ x \\ x \end{gathered}$ |  |
| HALT | 0 | 1 | 1 | X | x | x | x | x | x |
| MEM COMMANDS | 1 1 1 | 0 0 1 | $\begin{aligned} & 0 \\ & 1 \\ & 0 \end{aligned}$ |  |  | $x$ |  | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ |  |
| IDLE | 1 | 1 | 1 | x | x | x | x | X | x |

NOTES:

1. $x=$ Multi-Master System Bus is allowed to be Surrendered.
2. = Multi-Master System Bus is Requested.

| Mode | Pin <br> Strapping | Multi-Master System Bus |  |
| :---: | :---: | :---: | :---: |
|  |  | Requested** | Surrendered* |
| Single Bus Multi-Master Mode | $\begin{aligned} & \overline{\overline{O B B}}=\text { High } \\ & \text { RESB }=\text { Low } \end{aligned}$ | Whenever the processor's status lines go active | $\mathrm{HLT}+\mathrm{TI} \cdot \mathrm{CBRO}+$ HPBRQ $^{\dagger}$ |
| RESB Mode Only | $\begin{aligned} & \overline{\mathrm{IOB}}=\text { High } \\ & \text { RESB }=\text { High } \end{aligned}$ | SYSB/ $\overline{R E S B}=$ High $\cdot$ ACTIVE STATUS | $\begin{aligned} & (S Y S B / \overline{R E S B}=L o w+T I) \cdot \\ & C B R Q+H L T+H P B R Q \end{aligned}$ |
| IOB Mode Only | $\begin{aligned} & \overline{1 O B}=\text { Low } \\ & \text { RESB }=\text { Low } \end{aligned}$ | Memory Commands | (I/O Status + TI) $\cdot$ CBRQ + HLT + HPBRO |
| IOB Mode - RESB Mode | $\begin{aligned} & \overline{\mathrm{OB}}=\text { Low } \\ & \text { RESB }=\text { High } \end{aligned}$ | (Memory Command) • (SYSB/ $\overline{R E S B}=$ High) | ((I/O Status Commands) + $(S Y S B / \overline{R E S B}=$ Low) $)$. $\mathrm{CBRQ}+\mathrm{HPBRQ}^{\dagger}+\mathrm{HLT}$ |

NOTES:

* $\overline{\text { LOCK }}$ prevents surrender of Bus to any other arbiter, $\overline{\mathrm{CRQLCK}}$ prevents surrender of Bus to any lower priority arbiter.
** Except for HALT and Passive or IDLE Status.
$\dagger$ HPBRQ, Higher priority Bus request or $\overline{\mathrm{BPRN}}=1$.

1. $\overline{I O B}$ Active Low.
2. RESB Active High.
3.     + is read as "OR" and - as "AND."
4. $\mathrm{TI}=$ Processor Idle Status $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}, \overline{\mathrm{~S} 0}=111$
5. HLT $=$ Processor Halt Status $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}, \overline{\mathrm{SO}}=011$

Fig. 7 - TYPICAL MEDIUM COMPLEXITY CPU SYSTEM


Fig. 8 - TYPICAL MEDIUM COMPLEXITY IOB SYSTEM


FUJITSUU
MBL 8289


Fig. 9 - MBL 8289 BUS ARBITER SHOWN IN SYSTEM-RESIDENT BUS CONFIGURATION


* BY ADDING ANOTHER MBL 8289 ARBITER AND CONNECTING ITS $\overline{A E N}$ TO THE MBL 8288 WHOSE $\overline{A E N}$ IS PRESENTLY GROUNDED, THE PROCESSOR COULD HAVE ACCESS TO TWO MULTI-MASTER BUSES.


## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $\qquad$ . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Output and Supply Voltages . . . . . . . . -0.5 V to +7.0 V
All Input Voltages . . . . . . . . . . . . . . . . -0.5 V to +5.5 V
Power Dissipation
D.C. CHARACTERISTICS $V_{c C}=5 \mathrm{~V} \pm 10 \%, T_{A}$
D.C. CHARACTERISTICS $\left(V_{C C}=+5 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$
*NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

| Symbol | Parameter |  | Min. | Max. | Units | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{c}}$ | Input Clamp Voltage |  |  | -1.0 | V | $\mathrm{V}_{\mathrm{CC}}=4.50 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\text {F }}$ | Input Forward Current |  |  | -0.5 | mA | $\mathrm{V}_{\mathrm{CC}}=5.50 \mathrm{~V}, \mathrm{~V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Reverse Input Leakage Current |  |  | 60 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.50 \mathrm{~V}, \mathrm{~V}_{\mathrm{R}}=5.50 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\overline{\text { BUSY, }} \overline{\text { CBRQ }}$ |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA}$ |
|  |  | $\overline{\text { AEN }}$ |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |
|  |  | $\overline{\text { BPRO, } \overline{B R E Q}}$ |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | OutputHighVoltage | $\overline{\text { BUSY }}$, $\overline{\mathrm{CBRO}}$ | Open Collector |  |  |  |
|  |  | $\overline{\mathrm{AEN}}, \overline{\mathrm{BPRO}}, \overline{\mathrm{BREQ}}$ | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{Cc}}$ | Power Supply Current |  |  | 95 | mA |  |
| $\mathrm{V}_{1 L}$ | Input Low Voltage |  |  | 0.8 | V |  |
| $\mathrm{V}_{1}$ | Input High Voltage |  | 2.0 |  | V |  |
| Cin Status | Input Capacitance |  |  | 25 | pF |  |
| Cin (Others) | Input Capacitance |  |  | 12 | pF |  |

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

| Symbol | Parameter | MBL 8289 Min | MBL 8289-1 <br> Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TCLCL | CLK Cycle Period | 125 | 100 |  | ns |  |
| TCLCH | CLK Low Time | 65 | 53 |  | ns |  |
| TCHCL | CLK High Time | 35 | 26 |  | ns |  |
| TSVCH | Status Active Setup | 65 | 55 | TCLCL-10 | ns |  |
| TSHCL | Status Inactive Setup | 50 | 45 | TCLCL-10 | ns |  |
| THVCH | Status Active Hold | 10 | 10 |  | ns |  |
| THVCL | Status Inactive Hold | 10 | 10 |  | ns |  |
| TBYSBL | $\overline{\text { BUSY }} \uparrow \downarrow$ Setup to $\overline{\text { BCLK }} \downarrow$ | 20 | 20 |  | ns |  |
| TCBSBL | $\overline{\text { CBRQ }} \uparrow \downarrow$ Setup to $\overline{\text { BCLK }} \downarrow$ | 20 | 20 |  | ns |  |
| TBLBL | $\overline{\text { BCLK }}$ Cycle Time | 100 | 100 |  | ns |  |
| TBHCL | $\overline{\text { BCLK High Time }}$ | 30 | 30 | 0.65 [TBLBL] | ns |  |
| TCLLL1 | LOCK Inactive Hold | 10 | 10 |  | ns |  |
| TCLLL2 | LOCK Active Setup | 40 | 40 |  | ns |  |
| TPNBL | $\overline{\text { BPRN }} \downarrow \uparrow$ to $\overline{\text { BCLK }}$ Setup Time | 15 | 15 |  | ns |  |
| TCLSR1 | SYSB/ $\overline{\text { RESB }}$ Setup | 0 | 0 |  | ns |  |
| TCLSR2 | SYSB/RESB Hold | 20 | 20 |  | ns |  |
| TIVIH | Initialization Pulse Width | $\begin{aligned} & 3 \text { TBLBL + } \\ & 3 \text { TCLCL } \end{aligned}$ | $\begin{aligned} & 3 \mathrm{TBLBL}+ \\ & 3 \mathrm{TCLCL} \\ & \hline \end{aligned}$ |  | ns |  |

FUSITSU
FUJITSU

## A.C. CHARACTERISTICS (Continued)

timing responses

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TBLBRL | $\overline{\text { BCLK }}$ to $\overline{\text { RREQ }}$ Delay $\downarrow \uparrow$ |  | 35 | ns |  |
| TBLPOH | $\overline{\text { BCLK }}$ to $\overline{\mathrm{BPRO}} \downarrow \uparrow$ (See Note 1) |  | 40 | ns |  |
| TPNPO | $\overline{\mathrm{BPRN}} \downarrow \uparrow$ to $\overline{\mathrm{BPRO}} \downarrow \uparrow$ Delay (See Note 1) |  | 25 | ns |  |
| TBLBYL | $\overline{\text { BCLK }}$ to $\overline{\mathrm{BUSY}}$ Low |  | 60 | ns |  |
| TBLBYH | $\overline{\mathrm{BCLK}}$ to $\overline{\mathrm{BUSY}}$ Float (See Note 2) |  | 35 | ns |  |
| TCLAEH | CLK to $\overline{\mathrm{AEN}} \mathrm{High}$ |  | 65 | ns |  |
| TBLAEL | $\overline{\text { BCLK }}$ to $\overline{\mathrm{AEN}}$ Low |  | 40 | ns |  |
| TBLCBL | $\overline{\text { BCLK }}$ to $\overline{\mathrm{CBRO}}$ Low |  | 60 | ns |  |
| TBLCBH | $\overline{\text { BCLK }}$ to $\overline{\text { CBRO }}$ Float (See Note 2) |  | 35 | ns |  |
| TOLOH | Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

$\downarrow \uparrow$ Denotes that spec applies to both transition of the signal.

## NOTES:

1. $\overline{B C L K}$ generates the first $\overline{B P R O}$ wherein subsequent $\overline{B P R O}$ changes lower in the chain are generated through $\overline{B P R N}$.
2. Measured at .5 V above GND.
A.C. TESTING INPUT, OUTPUT WAVEFORM

A.C. TESTING: INPUTS ARE DRIVEN AT 2.4 V FOR A LOGIC "1" AND 0.45V FOR A LOGIC "0". THE CLOCK IS DRIVEN AT 4.3V AND 0.25 V . TIMING MEASUREMENTS ARE MADE AT 1.5 V FOR BOTH A LOGIC " 1 " AND " 0 ". INPUT RISE AND FALL TIMES (MEASURED BETWEEN 0.8 V AND 2.0 V ) ARE DRIVEN AT $5 \pm 2 \mathrm{NS}$.
A.C. TESTING LOAD CIRCUIT


## WAVEFORMS



## ADDITIONAL NOTES:

The signals related to CLK are typical processor signals, and do not relate to the depicted sequence of events of the signals referenced to $\overline{B C L K}$. The signals shown related to the $\overline{B C L K}$ represent a hypothetical sequence of events for illustration. Assume 3 bus arbiters of priorities 1, 2 and 3 configured in serial priority resolving scheme as shown in Figure 6. Assume arbiter 1 has the bus and is holding busy low. Arbiter \#2 detects its processor wants the bus and pulls low BREQ\#2. If $\overline{\text { BPRN\#2 }}$ is high (as shown), arbiter \#2 will pull low $\overline{C B R O}$ line. $\overline{C B R O}$ signals to the higher priority arbiter \#1 that a lower priority arbiter wants the bus. [A higher priority arbiter would be granted BPRN when it makes the bus request rather than having to wait for another arbiter to release the bus through $\overline{\mathrm{CBRO}}] .{ }^{* *}$ Arbiter \#1 will relinquish the multi-master system bus when it enters a state not requiring it (see Table 1), by lowering its $\overline{\text { BPRO\#1 }}$ (tied to $\overline{\text { BPRN\#2) and releasing BUSY. Arbiter }}$ \#2 now sees that it has priority from BPRN\#2 being low and releases $\overline{C B R O}$. As soon as BUSY signifies the bus is available (high), arbiter \#2 pulls BUSY low on next falling edge of BCLK. Note that if arbiter \#2 didn't want the bus at the time it received priority, it would pass priority to the next lower priority arbiter by lowering its $\overline{\text { BPRO\#2 }}$ [TPNPO].

[^24]FUJITSU
MBL 8289


PACKAGE ILLUSTRATION AND DIMENSIONS
CERAMIC DIP (Suffix: CZ)


PLASTIC DIP (Suffix: P)


## Section 2

Microcomputers
and Peripherals

| 8-Bit Microcomputers and Peripherals |  |  |
| :---: | :---: | :---: |
| 2-2 | MBL8048N/E/H | NMOS Single-Chip 8-Bit Microcomputer |
| 2-2 | MBL8035N/E/H | NMOS Single-Chip 8-Bit Microcomputer |
| 2-22 | MBL8049N/E/H | NMOS Single-Chip 8-Bit Microcomputer |
| 2-22 | MBL8039N/E/H | NMOS Single-Chip 8-Bit Microcomputer |
| 2.42 | MBL8749H/N | NMOS Single-Chip 8-Bit Microcomputer |
| 2-67 | MBL8051AH | NMOS Single-Chip 8-Bit Microcomputer |
| 2.67 | MBL8031AH | NMOS Single-Chip 8-Bit Microcomputer |
| 2-86 | MBL80C49H/N | CMOS Single-Chip 8-Bit Microcomputer |
| 2-86 | MBL80C39H/N | CMOS Single-Chip 8-Bit Microcomputer |
| 2-114 | MBL8243 | NMOS Input/Output Expander |
| 2-124 | MBL82C43 | CMOS Input/Output Expander |
| 4-Bit Microcomputers and Peripherals |  |  |
| 2-136 | Selector Guide for 4-Bit Microcomputers MB88301A NMOS D/A Converter |  |
| 2-160 |  |  |
| 2-171 | MB88304 | NMOS Input/Outut Expander |
| 2-171 | MB88305 | NMOS Input/Outut Expander |
| 2-181 | MB88310 | CMOS Input/Output Expander |
| 2-181 | MB88311 | CMOS Input/Output Expander |
| 2-192 | MB88306 | CMOS Output Expander |
| 2-192 | MB88307 | CMOS Output Expander |
| 2-192 | MB88308 | CMOS Output Expander |
| 2-192 | MB88309 | CMOS Output Expander |

## Description

The Fujitsu MBL8048/MBL8035 is a totally self-contained 8 -bit parallel one-chip microcomputer fabricated wtih an N -channel silicon gate MOS process.

The MBL 8048 has a $1 \mathrm{~K} \times 8$ ROM program memory, a $64 \times 8$ RAM data memory, 27 I/O ports, an 8 -bit timer/counter and clock generator on-chip. A single power supply of +5 V is used. The MBL8035 is identical to the MBL8048 except without program memory. It can be used with external memory for system prototyping and preproduction systems.

The design is optimized for low cost, high performance applications because the MBL8048/MBL8035 is fabricated on a single silicon chip and can be used for applications that require additional expansion of ROMs, RAMs, I/O port, etc.

This microcomputer permits external program operation and a single-step operation mode. Low power applications are possible by using the stand-by mode feature.

The MBL8048/MBL8035 is packaged in a standard 40-pin DIP package and operation is guaranteed from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## Features

- 8 -bit Parallel Microcomputer
12-bit Addressing
- 96 Instructions: $70 \%$ Single
Byte
- $1.875 \mu$ s Cycle (E-Version)
$2.5 \mu \mathrm{~s}$ Cycle ( N -Version)
- All Instructions are 1 or
2 Cycles .
- $1 \mathrm{~K} \times 8$ ROM (MBL8048 only)
$64 \times 8$ RAM
$27 \mathrm{I} / \mathrm{O}$ Lines
- Interval Timer/Event Counter
- Single Level Interrupt
Capability
- Resident Clock Generator
(External Frequency Source)
- External Input Capability
- Easily Expandable Memory and I/O
- 8 Level Stack
- External Program Mode Capability
- Low Power Stand-by Mode Capability
- Single +5 V Power Supply
- N-channel Silicon Gate E/D MOS Process
- Standärd 40 -Pin DIP
- MBL8048: Compatible with Intel 8048 MBL8035: Compatible with Intel 8035

Portions reprinted by permission of Intel Corporation, Copyright © 1985 Intel Corporation. Compilation and additional materials Copyright © 1985 by Fujitsu Limited, Tokyo, Japan, and Fujitsu Microelectronics, Inc., Santa Clara, California, U.S.A. Fujitsu Limited is a licensee of Intel Corporation and authorized to produce alternate source products.


Block Diagram


Pin Assignment


This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.
*These pins are internally pulled up.

## Pin Description

| Pin No. | Pin Name | Symbol | Function |
| :---: | :---: | :---: | :---: |
| 1 | Sense | T0 | This pin has the following functions according to instructions. <br> 1) Output of clock ( $\phi 1$ ) 2 MHz at 6 MHz XTAL <br> 2) Condition input for a Conditional Branch |
| 2 | Crystal 1 | XTAL 1 | This is an input terminal for the internal Clock Generator to be connected to a terminal of the external crystal. |
|  |  |  | Also, this pin can be used as the input from an external clock source. |
|  |  |  | Note: This input is not compatible with TTL levels. |
| 3 | Crystal 2 | XTAL 2 | This is an input terminal for the internal Clock Generator to be connected to the other terminal of the external crystal. |
|  |  |  | Note: This input is not compatible with TTL level. |
| 4 | Reset | RESET | This input forces the MPU to be reset or initialized. |
|  |  |  | Note: This input is not compatible with TTL level. |
| 5 | Single Step | SS | This input is used in conjunction with ALE for single step operation. |
| 6 | Interrupt | $\overline{\text { INT }}$ | This input is used to request an external interrupt. |
| 7 | External Address | EA | When EA goes high while $\overline{\text { RESET }}$ is low, an external address (memory) can be used as the external program operation mode. |
| 8 | Read | $\overline{\mathrm{RD}}$ | This output is used as a strobe signal for an input of data from the data port (DB port). Also, it can be used as a read-enable signal when using an external data memory. |
| 9 | Program <br> Store <br> Enable | $\overline{\text { PSEN }}$ | This output signal is generated at a fetch cycle in the external program operation mode. |
|  |  |  | It is used as an enable signal for an external program memory. |
| 10 | Write | WR | This output is a strobe signal for a data output from the DB port. |
|  |  |  | Also, it can be used as a write-enable signal for an external data memory. |
| 11 | Address Latch Enable | ALE | This output signal is generated at the beginning of a fetch cycle both in the internal and external progaram memory operations. |
|  |  |  | This output is used as a synchronizing signal with an external circuit and also, as a strobe signal for address outputs ( $A_{0}$ thru $A_{7}$ ) of the DB port in the external program operation mode. |
|  |  |  | These pins are used as a bidirectional 8-bit input/output port (DB port). |
| $\begin{aligned} & \text { thru } \\ & 19 \end{aligned}$ | Data Bus Port | thru DB7 | When an external memory is used as a program memory or data memory, this port is used as an address bus ( $A_{0}$ thru $\mathrm{A}_{7}$ ) or data input/output port, respectively. |
| 20 | Power Supply | $\mathrm{V}_{\text {SS }}$ | This pin is used as the Ground (GND) terminal. |
| $\begin{aligned} & 21 \\ & \text { thru } \\ & 24 \end{aligned}$ | Port 2 | $\begin{aligned} & \text { P20 } \\ & \text { thru } \\ & \text { P23 } \end{aligned}$ | These are the lower four bits of a quasi-bidirectional input/output port (P2 port) which are used as address outputs ( $\mathrm{A}_{8}$ thru $\mathrm{A}_{11}$ ) in a fetch cycle of the external program memory operation mode. When an expansion I/O instruction is executed, these are switched to an I/O expander bus for use with the MBL8243. |

## FUJITSU

| Pin Description (Continued) | Pin No. | Pin Name | Symbol | Function |
| :---: | :---: | :---: | :---: | :---: |
|  | 25 | Program | PROG | This output is used as a strobe signal for an I/O expander (MBL8243) when performing an expansion I/O instruction. |
|  | 26 | Power Supply | $V_{\text {DD }}$ | This is used as the power supply terminal ( +5 V ) for the built-in RAM |
|  | $\begin{aligned} & \hline 27 \\ & \text { thru } \\ & 34 \\ & \hline \end{aligned}$ | Port 1 | $\begin{aligned} & \hline \mathrm{P} 1_{0} \\ & \text { thru } \\ & \mathrm{P} 1_{7} \\ & \hline \end{aligned}$ | This is a quasi-bidirectional input/output port (P1 port) |
|  | $\begin{aligned} & \overline{35} \\ & \text { thru } \\ & 38 \end{aligned}$ | Port 2 | $\begin{aligned} & \hline \mathrm{P}_{2} \\ & \text { thru } \\ & \mathrm{P}_{7} \end{aligned}$ | These are the upper four bits of the quasi-bidirectional input/output port 2 (P2). |
|  | 39 | Sense | $\mathrm{T}_{1}$ | This pin has the following functions according to the instruction given: <br> 1) Event Input for Event Counter <br> 2) Condition Input for Conditional Branch |
|  | 40 | Power Supply | $\mathrm{V}_{\mathrm{CC}}$ | This is used as the power supply terminal ( +5 V ). In stand-by operation mode this terminal is connected to GND. |

## Functional Descriptions for Basic Blocks

| Block Name | Function |
| :---: | :---: |
| Clock Generation Circuitry | A master clock signal within a frequency range of 1 MHz to 6 MHz is supplied from the built-in Clock Generator using an external crystal and capacitor network, or from an external signal source. |
|  | The frequency of the master clock is divided through the 1/3 Frequency Divider to generate a state clock signal. Then, the frequency of the state clock is divided through the 1/5 Frequency Divider to generate a final cycle clock signal. |
|  | The state clock can be transferred to the $T_{0}$ terminal by an instruction. |
|  | The cycle clock is used for internal operations and is also available on the ALE terminal. |
| I/O Port | Three bidirectional or quasi-bidirectional 8-bit I/O ports and three input terminals are provided for signal inputs and outputs. |
|  | Port 0 (Bus Port) and the lower 4 bits of Port 2 shown in the Block Diagram are used for access to external memories or I/O expanders. |
| Built-in ROM and RAM | In the MBL8048, programs are stored in the built-in ROM (1 Byte). Also, the contents in the ROM can be used as data for some instructions. |
|  | The built-in RAM ( 64 Bytes) is used for general register area, stack area and working area. |
|  | ROM is expandable up to a total of 4 K Bytes with externally attached ROM by switching the memory bank. |
|  | RAM is expandable by an additional 256 Bytes with externally attached RAM. |
|  | MBL8035 does not have any built-in ROM. It uses external ROM for program storing. |
| Program Counter | The program counter is an 11-bit register which indicates a fetch address of program memory and is incremented by every execution of an instruction. |

## Functional Descriptions <br> for Basic Blocks

(Continued)

| Block Name | Function |
| :--- | :--- |
| Instruction Register | The Instruction Register is an 8-bit register which stores a <br> fetched instruction in a fetch cycle. |
| Instruction Decoder | The Instruction Decoder decodes the instruction stored in <br> the Instruction register and generates various control <br> signals for both internal circuitry and external peripherals. |
| Arithmetic Logic Unit (ALU) | Various operations such as addition, subtraction, <br> comparison, etc., are executed in the ALU. Operation to be <br> executed is determined from the decoding of an instruction. |
|  | The Interval Timer/Event Counter is an 8-bit register which <br> can be controlled by instruction execution. The interval <br> timer mode or event counter mode can be designated by <br> instruction execution, as well. |
| This register is not initialized by the RESET signal. In the <br> interval timer mode, the register can count up the <br> frequency signal which is generated by dividing the cycle <br> clock frequency by 32. |  |
| When the source oscillation frequency is 6 MHz, this <br> enables the register to count a time interval of up to |  |
| 20.48ms with resolution of $80 \mu \mathrm{s}$. |  |

## FUJITSU

## Resident Data Memory Map (RAM)



Status Register (PSW)
The Status Register is an 8-bit register configured as shown in the following figure. The upper four bits are used for flags to indicate the status of the MPU, and when a sub-routine call or an interrupt occurs, the contents of the program counter is transferred to one of the 8 register pairs of the Stack Register as determined by the lower three bits of the Status Register. The remaining one bit is an unused bit.


## Flags

CY (Carry): When an overflow occurs in the Accumulator during an operation in the ALU, " 1 " is set in this bit.

HC (Half Carry): When an overflow occurs from Bit 3 to Bit 4 in the accumulator as a result of an addition, " 1 " is set in this bit.
$F_{0}$ (User Flag): This flag can be controlled as a user flag by the proper instruction.

BS (Bank select): This flag can be controlled to select a Register Bank by an instruction. When BS $=0$, the Register Bank 0 is selected. When $B S=1$, the Register Bank 1 is selected.

## Stack Register ( 8 Level Capability)

The Stack Register occupies 16-bytes of memory within the on-board RAM. It is configured into eight levels of two bytes each as shown in Figure 1.

## Stack Pointer (SP)

In Figure 1., "SP" indicates the stack level to be used for the next sub-routine call or interrupt. The Stack Pointer generates one of eight address codes and resides in the lower three bits of the status register.
$\mathrm{SP}=00001 \mathrm{SP}_{2} \mathrm{SP}_{1} \mathrm{SP}_{0}$

## Program Counter (PC)

In Figure 1., " $\mathrm{PC}_{\mathrm{n}}$ " indicates the individual bit contents of each of the Program Counter bits.

## Interrupt Operation

There are two interrupt modes, external interrupts, and timer/counter interrupts.

When either interrupt occurs, an interrupt flag is set and upon completion of the executing instruction the interrupt is processed.

Interrupt processing is as follows:

1. The contents of the Status Register and Program Counter are saved on the Stack.
2) Program flow jumps to the address specified at address three (3) for external interrupts and address seven (7) for timer/counter interrupts.
3. Completion of the interrupt processing occurs upon execution of the RETR (Return and Restore Status) instruction.
4. The contents of the program counter and status register are restored from the stack, the interrupt flag is reset to be ready for the next interrupt, and program execution continues from where it left off.
Timer/counter interrupts occur when the overflow flag is set as a result of an overflow from the Timer/Counter.

External interrupts occur when a low level input is applied to the "INT" input.

External interrupts have priority over Timer/Counter interrupts, so if both interrupts occur at the same time the external interrupt will be processed first. After completion of the external interrupt and resetting of the interrupt flag the Timer/ Counter interrupt will be processed.

## Instructions

All instructions are either one or two bytes long and execute in one or two cycles. Address-
ing modes are classified into direct, expanded, indirect, immediate and implied.

Instruction Mode

1) 1 Byte Instruction


Implied Addressing Mode


Register Indirect
Addressing Mode


Register Direct
Addressing Mode
2) 2 Byte Instruction

| $f$ | OP |
| :---: | :---: |

Immediate Addressing Mode

| $A_{H}$ | $f$ | $A_{L}$ |
| :---: | :---: | :---: |

Expanded Addressing Mode
f: Instruction Operation Set
r: Register Set
OP: Operand Data
$A_{H}, A_{L}$ : Operand Address

Figure 1.


Operation Flow Chart


Flow Chart for Interrupt Operation


## Accumulator

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | CY |  | $F_{0}$ | $F_{1}$ |  |
| Add register to $A$ Add data memory to A | ADD A, $\mathrm{R}_{\mathrm{r}}$ | 6 X | 1 | 1 | * |  | - | - | $\left(R_{r}\right)+(A) \rightarrow(A)$ |
|  | ADD A,@R ${ }_{0}$ | 60 | 1 | 1 |  |  | - | - | $\left(\left(R_{0}\right)\right)+(A) \rightarrow(A)$ |
|  | ADD A,@R1 | 61 | 1 | 1 | * |  | - | - | $\left(\left(R_{1}\right)\right)+(A) \rightarrow(A)$ |
| Add immediate to A | ADD A,\#data | 03 | 2 | 2 | * |  | - | - | data $+(A)-(A)$ |
| Add register with carry | ADDC A, $\mathrm{R}_{\mathrm{r}}$ | 7X | 1 | 1 | * |  | - | - | $\left(\mathrm{R}_{\mathrm{r}}\right)+(\mathrm{A})+(\mathrm{C}) \rightarrow(\mathrm{A})$ |
| Add data memory with carry | ADDC A,@R ${ }_{0}$ | 70 | 1 | 1 |  |  | - | - | $\left(\left(R_{0}\right)\right)+(A)+(C) \rightarrow(A)$ |
|  | ADDC A,@R ${ }_{1}$ | 71 | 1 | 1 | * |  | - | - | $\left(\left(R_{1}\right)\right)+(A)+(C)-(A)$ |
| Add immediate to A with carry | ADDC A,\#data | 13 | 2 | 2 | * | * | - | - | data $+(A)+(C) \rightarrow(A)$ |
| And register to A | ANL A, $\mathrm{R}_{\mathrm{r}}$ | 5 X | 1 | 1 | - | - | - | - | $\left(R_{r}\right) \cap(A)-(A)$ |
| And data memory to A | ANL A, @R ${ }_{0}$ | 50 | 1 | 1 | - | - | - | - | $\left(\left(\mathrm{R}_{0}\right)\right) \cap(\mathrm{A}) \rightarrow(\mathrm{A})$ |
|  | ANL A, @ $\mathrm{R}_{1}$ | 51 | 1 | 1 | - | - | - | - | $\left(\left(R_{1}\right)\right) \cap(A) \rightarrow(A)$ |
| And immediate to A | ANL A,\#data | 53 | 2 | 2 | - | - | - | - | data $\cap(A) \rightarrow(A)$ |
| Clear A | CLR A | 27 | 1 | 1 | - | - | - | - | $0 \rightarrow(\mathrm{~A})$ |
| Complement A | CPL A | 37 | 1 | 1 | - | - | - | - | $(\bar{A}) \rightarrow(A)$ |
| Decimal Adjust A | DA A | 57 | 1 | 1 | * | - | - | - | Note (1) |
| Decrement A | DEC A | 07 | 1 | 1 | - | - | - | - | (A) $-1 \rightarrow$ (A) |
| Increment A | INC A | 17 | 1 | 1 | - | - | - | - | $(\mathrm{A})+1 \rightarrow(\mathrm{~A})$ |
| Or register to A | ORL A, $\mathrm{R}_{\mathrm{r}}$ | 4X | 1 | 1 | - | - | - | - | $\left(R_{r}\right) \cup(A) \rightarrow(A)$ |
| Or data memory to $A$ | ORL A, @R ${ }_{0}$ | 40 | 1 | 1 | - | - | - | - | $\left(\left(\mathrm{R}_{0}\right)\right) \cup(\mathrm{A}) \rightarrow(\mathrm{A})$ |
|  | ORLA, @R ${ }_{1}$ | 41 | 1 | 1 | - | - | - | - | $\left(\left(R_{1}\right) \cup(A)-(A)\right.$ |
| Or immediate to A | ORL A,\#data | 43 | 2 | 2 | - | - | - | - | data $\cup(A) \rightarrow(A)$ |
|  |  |  |  |  |  |  |  |  | -11111110 |
| Rotate A left Rotate A left with carry | RLA RLC A | F7 | 1 1 | 1 1 | - | - | - | - |  |
| Rotate A right | RR A | 77 | 1 | 1 | - | - | - | - | -71111110 |
| Rotate A right with carry | RRC A | 67 | 1 | 1 | * | - | - | - | - 0 - 711111 |
| SWAP nibbles of A | SWAP A | 47 | 1 | 1 | - | - | - | - | $\left(A_{4-7}\right) \geq\left(A_{0-3}\right)$ |
|  | XRL A, $\mathrm{R}_{\mathrm{r}}$ | DX | 1 | 1 | - | - | - | - | $\left(R_{r}\right) \oplus(A) \rightarrow(A)$ |
| Exclusive Or data memory to A | XRL A, @R ${ }_{0}$ | D0 | 1 | 1 | - | - | - | - | $\left(\left(R_{0}\right)\right) \oplus(A) \rightarrow(A)$ |
|  | XRL A, @ $\mathrm{R}_{1}$ | D1 | 1 | 1 | - | - | - | - | $\left(\left(\mathrm{R}_{1}\right)\right) \oplus(\mathrm{A}) \rightarrow(\mathrm{A})$ |
| Exclusive Or immediate to A | XRL A,\#data | D3 | 2 | 2 | - |  | - | - | data $\oplus(A) \rightarrow(A)$ |

## Instruction Set Summary

(Continued)

## Input/Output

| Operation | Mnemonic | OP Code |  | Cycle | Flag |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Byte |  |  | HC Fo | $F_{1}$ |  |
| And immediate to BUS | ANL BUS,\#data | 98 | 2 | 2 | - | - | - | data $\cap(B \cup S) \rightarrow(B U S)$ |
| $P_{1}$ | ANL $\mathrm{P}_{1}$, \#data | 99 | 2 | 2 | - | - - | - | data $\cap\left(\mathrm{P}_{1}\right) \rightarrow\left(\mathrm{P}_{1}\right)$ |
| $P_{2}$ | ANL $\mathrm{P}_{2}$,\#data | 9A | 2 | 2 |  |  |  | data $\cap\left(P_{2}\right) \longrightarrow\left(P_{2}\right)$ |
| And A to Expander Port | ANLD $\mathrm{P}_{\mathrm{p}}, \mathrm{A}$ | 9 X |  | 2 | - | $-\quad-$ |  | $(A) \cap\left(P_{P}\right) \rightarrow\left(P_{P}\right)$ |
| Input BUS to A | INS A,BUS | 08 | 1 | 2 | - | - - | - | $(B \cup S) \rightarrow(A)$ |
| Port 1 to A | IN A, $\mathrm{P}_{1}$ | 09 | 1 | 2 | - | - - | - | $\left(P_{1}\right) \rightarrow(A)$ |
| Port 2 to A | IN A, $\mathrm{P}_{2}$ | OA | 1 | 2 | - | - - | - | $\left(P_{2}\right) \rightarrow(A)$ |
| Input Expander port to A | MOVD A, PP | OX | 1 | 2 | - | - - | - | $\begin{gathered} \left(P_{p}\right) \rightarrow\left(A_{0-3}\right) \\ 0 \rightarrow\left(A_{4-7}\right) \end{gathered}$ |
| Or immediate to BUS | ORL BUS,\#data | 88 | 2 | 2 | - | - - | - | data $\cup(B \cup S)-(B \cup S)$ |
| $\mathrm{P}_{1}$ | ORL $\mathrm{P}_{1}$,\#data | 89 | 2 | 2 | - | - - | - | data $\cup\left(\mathrm{P}_{1}\right)-\left(\mathrm{P}_{1}\right)$ |
| $\mathrm{P}_{2}$ | ORL $\mathrm{P}_{2}$,\#data | 8A | 2 | 2 | - | - | - | data $\cup\left(\mathrm{P}_{2}\right) \rightarrow\left(\mathrm{P}_{2}\right)$ |
| Or A to Expander Port | ORLD $P_{p}, A$ | 8 X | 1 | 2 | - | - - | - | data $\cup\left(P_{P}\right) \rightarrow\left(P_{P}\right)$ |
| Output A to BUS | OUṪL BUS, A | 02 | 1 | 2 | - | - - | - | $(\mathrm{A}) \rightarrow(\mathrm{BUS})$ |
| $\mathrm{P}_{1}$ | OUTL $P_{1}, A$ | 39 | 1 | 2 | - | - | - | $(\mathrm{A}) \rightarrow\left(\mathrm{P}_{1}\right)$ |
| $\mathrm{P}_{2}$ | OUTL $P_{2}, A$ | 3A | 1 | 2 | - | - - | - | $(\mathrm{A}) \rightarrow\left(\mathrm{P}_{2}\right)$ |
| Output A to Expander Port | MOVD Pr, $A$ | 3X | 1 | 2 | - | - - | - | $(\mathrm{A}) \rightarrow\left(\mathrm{P}_{\mathrm{P}}\right)$ |

## Data Moves

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  | $F_{1}$ |  |
| Move register to $A$ Move data memory to $A$ | MOV A, $\mathrm{R}_{\mathrm{r}}$ | FX | 1 | 1 | - | - | - | - | $\left(R_{r}\right) \rightarrow(A)$ |
|  | MOV A,@R ${ }_{0}$ | F0 | 1 | 1 | - | - | - | - | $\left(\left(R_{0}\right)\right) \rightarrow(A)$ |
|  | MOV A,@R ${ }_{1}$ | F1 | 1 | 1 | - | - | - | - | $\left(\left(R_{1}\right)\right) \rightarrow(A)$ |
| Move immediate to A | MOV A,\#data | 23 | 2 | 2 | - | - | - | - | data $\rightarrow(A)$ |
| Move A to register | MOV $\mathrm{R}_{\mathrm{r}}, \mathrm{A}$ | AX | 1 | 1 | - | - | - | - | $(A) \rightarrow\left(R_{r}\right)$ |
| Move A to data memory | MOV @ $\mathrm{R}_{0}, \mathrm{~A}$ | A0 | 1 | 1 | - | - | - | - | $(\mathrm{A})-\left(\left(\mathrm{R}_{0}\right)\right)$ |
|  | MOV @ $\mathrm{R}_{1}, \mathrm{~A}$ | A1 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \rightarrow\left(\left(\mathrm{R}_{1}\right)\right)$ |
| Move immediate to register Move immediate to data memory | MOV $\mathrm{R}_{\mathrm{r}}$ \# \#data | $B X$ | 2 | 2 | - | - | - | - | data $\rightarrow\left(\mathrm{R}_{\mathrm{r}}\right)$ |
|  | MOV @ $\mathrm{R}_{0}$, \#data $\mathrm{BO}^{\text {a }}$ |  | 2 | 2 | - | - | - | - | data $-\left(\left(\mathrm{R}_{0}\right)\right)$ |
|  | MOV @ $\mathrm{R}_{1}$, \#data $\mathrm{B}_{1}$ |  | 2 | 2 | - | - | - | - | data - $\left(\left(\mathrm{R}_{1}\right)\right)$ |
| Move PSW to A | MOV A,PSW | C7 | 1 | 1 | - | - | - | - | $($ PSW $) \rightarrow(A)$ |
| Move A to PSW | MOV PSW,A | D7 | 1 | 1 | * | * | * | - | $(\mathrm{A}) \rightarrow$ (PSW) |
| Move external data memory to A | MOVX A, @R ${ }_{0}$ | 80 | 1 | 2 | - | - | - | - | $\left(\left(R_{0}\right)\right)-(A)$ |
|  | MOVX A, @R ${ }_{1}$ | 81 | 1 | 2 | - | - | - | - | $\left(\left(R_{1}\right)\right) \rightarrow(A)$ |
| Move A to eternal data memory | MOVX@ $\mathrm{R}_{0}$, A | 90 | 1 | 2 | - | - | - | - | $(\mathrm{A}) \rightarrow\left(\left(\mathrm{R}_{0}\right)\right)$ |
|  | MOVX @R ${ }_{1}$,A | 91 | 1 | 2 | - | - | - | - | $(\mathrm{A}) \rightarrow\left(\left(\mathrm{R}_{1}\right)\right)$ |
| Move to A from current page | MOVP A,@A | A3 | 1 | 2 | - | - | - | - | $((A)) \rightarrow(A)$ |
| Move to $A$ from page 3 | MOVP3 A,@A | E3 | 1 | 2 | - | - | - | - | $((A))$ within page $3 \rightarrow(A)$ |
| Exchange A and register Exchange $A$ and data memory | XCH A, $\mathrm{R}_{\mathrm{r}}$ | 2 x | 1 | 1 | - | - | - | - | $\left(R_{r}\right) \geq(A)$ |
|  | XCH A,@R ${ }_{0}$ | 20 | 1 | 1 | - | - | - | - | $\left(\left(R_{0}\right)\right)$ こ (A) |
|  | $\mathrm{XCH} A, @ \mathrm{R}_{1}$ | 21 | 1 | 1 | - | - | - | - | $\left(\left(R_{1}\right)\right) \Longrightarrow(A)$ |
| Exchange nibble of $A$ and data memory | XCHD A, @R ${ }_{0}$ | 30 | 1 | 1 | - | - | - | - | $\left((\mathrm{RO})_{0-3}\right) \rightleftarrows\left(\mathrm{A}_{0-3}\right)$ |
|  | XCHD A,@R ${ }_{1}$ | 31 | 1 | 1 | - | - | - | - | $\left((\mathrm{R} 1)_{0-3}\right) \geq\left(A_{0-3}\right)$ |

## Instruction Set Summary <br> (Continued)

## Registers

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | CY HC Fo | F1 |  |
| Decrement Register | DEC $\mathrm{R}_{\mathrm{r}}$ | cx | 1 | 1 | - - - | - | $\left(R_{r}\right)-1 \rightarrow\left(R_{r}\right)$ |
| Increment register | INC $\mathrm{R}_{\mathrm{r}}$ | 1 x | 1 | 1 | - - - | - | $\left(R_{r}\right)+1 \rightarrow\left(R_{r}\right)$ |
| Increment data memory | INC @ $\mathrm{R}_{0}$ | 10 | 1 | 1 | - - - | - | $\left(\left(\mathrm{R}_{0}\right)\right)+1 \rightarrow\left(\left(\mathrm{R}_{0}\right)\right)$ |
|  | INC @ $\mathrm{R}_{1}$ | 10 | 1 | 1 | - - | - | $\left(\left(\mathrm{R}_{1}\right)\right)+1 \rightarrow\left(\left(\mathrm{R}_{1}\right)\right)$ |

## Timer/Counter



Control

| Operation | Mnemonic | OP <br> Code | Byte | Cycle | Flag |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | CY |  | Fo | $F_{1}$ |  |
| Disable external Interrupt | DIS I | 15 | 1 | 1 | - | - | - | - |  |
| Enable external Interrupt | ENI | 05 | 1 | 1 | - | - | - | - |  |
| Enable Clock output on $\mathrm{T}_{0}$ | ENT ${ }_{0}$ CLK | 75 | 1 | 1 | - | - | - | - |  |
| No Operation | NOP | 00 | 1 | 1 | - | - | - | - |  |
| Select register bank 0 | SEL RBO | C5 | 1 | 1 | - | - | - | - | $0 \rightarrow(\mathrm{BS})$ |
| Select register bank 1 | SEL RB1 | D5 | 1 | 1 | - | - | - | - | $1 \rightarrow(\mathrm{BS})$ |
| Select memory bank 0 | SEL MB0 | E5 | 1 | 1 | - | - | - | - | $0 \rightarrow$ (MBF) |
| Select memory bank 1 | SEL MB1 | F5 | 1 | 1 | - | - | - | - | $1 \rightarrow$ (MBF) |



## Instruction Set Summary

(Continued)


OP Code of JMP, CALL, JB ${ }_{\mathrm{r}}$ (Table 3)


## Instruction Codes

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | NOP |  | OUTL BSU,A | $\begin{gathered} \text { ADD } \\ \text { A, \# } \end{gathered}$ | $\underset{0 \times \mathrm{x}}{\mathrm{JMP}}$ | $\begin{gathered} \text { EN } \\ 1 \end{gathered}$ |  | $\underset{A}{\text { DEC }}$ | $\begin{gathered} \text { INS } \\ A, B \cup S \end{gathered}$ | $\underset{A, P_{1}}{\mathbb{N}}$ | $\operatorname{in}_{\mathrm{A}, \mathrm{P} 2}$ |  | $\begin{gathered} \text { MOVD } \\ \text { A,P4 } \end{gathered}$ | $\begin{gathered} \text { MOVD } \\ \text { A,PS } \end{gathered}$ | $\begin{gathered} \text { MOVD } \\ \text { A,P6 } \end{gathered}$ | $\begin{gathered} \text { MOVD } \\ \text { A,P7 } \end{gathered}$ |
| 1 | INC @RO | INC @R1 | $\begin{aligned} & \text { JBO } \\ & \text { addr } \end{aligned}$ | ADDC A \# | $\begin{aligned} & \text { CALL } \\ & 0 \times x \times \end{aligned}$ | $\underset{1}{\text { DIS }}$ | $\begin{aligned} & \text { JTF } \\ & \text { addr } \end{aligned}$ | $\underset{A}{\text { INC }}$ | $\begin{gathered} \text { INC } \\ \text { RO } \end{gathered}$ | $\underset{\text { R1 }}{\substack{\text { N }}}$ | $\begin{aligned} & \text { INC } \\ & \text { R2 } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { R3 } \end{aligned}$ | $\begin{gathered} \text { INC } \\ \text { R4 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R5 } \end{gathered}$ | $\begin{aligned} & \text { INC } \\ & \text { R6 } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { R7 } \end{aligned}$ |
| 2 | $\begin{gathered} \mathrm{XCH} \\ \mathrm{~A}, @ R 0 \end{gathered}$ | $\begin{gathered} \mathrm{XCH} \\ \mathrm{~A}, @ \mathrm{Q} 1 \end{gathered}$ |  | $\xrightarrow{\text { m, }}$ | $\begin{aligned} & \mathrm{JMP} \\ & 1 \times \mathrm{x} \end{aligned}$ | $\stackrel{\text { EN }}{\text { TCNT1 }}$ | JNTO addr | $\underset{A}{\text { CLR }}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{RO} \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 1 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \mathrm{xCH} \\ & \mathrm{~A}, \mathrm{R} 3 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 4 \end{aligned}$ | $\begin{aligned} & \mathrm{xCH} \\ & \mathrm{~A}, \mathrm{R} 5 \end{aligned}$ | $\begin{aligned} & \mathrm{xCH} \\ & \mathrm{~A}, \mathrm{R} 6 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 7 \end{aligned}$ |
| 3 | $\begin{aligned} & \text { XCHD } \\ & \text { A,@RO } \end{aligned}$ | $\begin{aligned} & \text { XCHD } \\ & \text { A,@R1 } \end{aligned}$ | JB1 <br> addr |  | $\begin{aligned} & \text { CALL } \\ & 1 \times x \end{aligned}$ | $\begin{aligned} & \text { DIS } \\ & \text { TCNT1 } \end{aligned}$ | $\begin{aligned} & \text { JT0 } \\ & \text { addr } \end{aligned}$ | $\underset{\mathrm{A}}{\mathrm{CPL}}$ |  | $\underset{\mathrm{P}_{1, \mathrm{~A}}^{\text {OUTL }}}{ }$ | $\begin{aligned} & \text { OUTL } \\ & \text { P2,A } \end{aligned}$ |  | $\begin{gathered} \text { MOVD } \\ \text { P4,A } \end{gathered}$ | MOVD P5,A | $\underset{\text { P6,A }}{\substack{\text { MOVD }}}$ | $\begin{gathered} \text { MOVD } \\ \text { P7,A } \end{gathered}$ |
| 4 | $\begin{gathered} \text { ORL } \\ \text { A,@R0 } \end{gathered}$ | $\begin{aligned} & \text { ORL } \\ & \text { A,@R1 } \end{aligned}$ | $\underset{A, T}{M O V}$ | $\begin{aligned} & \text { ORL } \\ & \mathrm{A}, \# \end{aligned}$ | $\begin{aligned} & \text { JMP } \\ & 2 \times \mathrm{x} \end{aligned}$ | $\begin{aligned} & \text { STRT } \\ & \text { CNT } \end{aligned}$ | JNT1 addr | $\underset{A}{\text { SWAP }}$ | $\begin{aligned} & \text { ORL } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \mathrm{ORL} \\ & \mathrm{~A}, \mathrm{R} 1 \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A,R2 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A,R3 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \mathrm{A}, \mathrm{R4} \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \mathrm{A}, \mathrm{RS} \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \mathrm{A}, \mathrm{R} 6 \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \mathrm{A}, \mathrm{R} 7 \end{aligned}$ |
| 5 | $\begin{aligned} & \text { ANL } \\ & \text { A,@R0 } \end{aligned}$ | $\begin{gathered} \text { ANL } \\ \text { A,@R1 } \end{gathered}$ | JB2 | $\begin{gathered} \text { ANL } \\ \text { A.\# } \end{gathered}$ | $\begin{aligned} & \text { CALL } \\ & 2 \times x \end{aligned}$ | $\begin{gathered} \text { STRT } \end{gathered}$ | JT1 addr | $\begin{gathered} \text { DA } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,RO } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R1 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R2 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R4 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R6 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R7 } \end{aligned}$ |
| 6 | $\begin{gathered} \text { ADD } \\ \text { A,@R0 } \end{gathered}$ | $\begin{gathered} \text { ADD } \\ \text { A,@R1 } \end{gathered}$ | $\underset{\mathrm{T}, \mathrm{~A}}{\mathrm{MOV}}$ |  | $\begin{aligned} & \text { JMP } \\ & 3 \times x \end{aligned}$ | $\begin{aligned} & \text { STOP } \\ & \text { TCNT } \end{aligned}$ |  | $\underset{A}{\text { RRC }}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,RO } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R1 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R2 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R4 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R6 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R7 } \end{aligned}$ |
| 7 | ADDC <br> A,@RO | $\begin{aligned} & \text { ADDC } \\ & \text { A,@R1 } \end{aligned}$ | JB3 addr |  | $\begin{aligned} & \text { CALL } \\ & 3 \times \times \end{aligned}$ | $\begin{aligned} & \text { ENTO } \\ & \text { CLK } \end{aligned}$ | $\begin{aligned} & \mathrm{JFF} \\ & \text { addr } \end{aligned}$ | $\underset{A}{\text { RR }}$ | $\begin{gathered} \text { ADDC } \\ \text { A,RO } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R1 } \end{gathered}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A,R2 } \end{aligned}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R3 } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R4 } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R5 } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R6 } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R7 } \end{gathered}$ |
| 8 | $\begin{aligned} & \text { MOVX } \\ & \text { A,@RO } \end{aligned}$ | $\begin{aligned} & \text { MOVX } \\ & \text { A,@R1 } \end{aligned}$ |  | RET | $\begin{aligned} & \text { JMP } \\ & 4 \times \mathrm{x} \end{aligned}$ | $\begin{gathered} \text { CLR } \\ \text { FO } \end{gathered}$ | JN1 <br> addr |  | ORL BUS,\# | $\begin{aligned} & \text { ORL } \\ & \text { P1,\# } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { P2.\# } \end{aligned}$ |  | $\begin{aligned} & \text { ORLD } \\ & \text { P4,A } \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \text { P5,A } \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \text { P6, } \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \text { P7,A } \end{aligned}$ |
| 9 | MOVX <br> @RO,A | MOVX <br> @R1,A | JB4 addr | RETR | $\begin{aligned} & \text { CALL } \\ & 4 \times \times \times \end{aligned}$ | $\begin{gathered} \text { CPL } \\ \text { FO } \end{gathered}$ | $\begin{aligned} & \text { JNZ } \\ & \text { addr } \end{aligned}$ | $\begin{gathered} \text { CLR } \\ \text { C } \end{gathered}$ | ANL BUS,\# | $\begin{aligned} & \text { ANL } \\ & \text { P1, } \end{aligned}$ | $\begin{aligned} & \mathrm{ANL} \\ & \mathrm{P} 2, \# \end{aligned}$ |  | $\begin{aligned} & \text { ANLD } \\ & \text { P4,A } \end{aligned}$ | $\begin{gathered} \text { ANLD } \\ \text { P5,A } \end{gathered}$ | $\begin{aligned} & \text { ANLD } \\ & \text { P6,A } \end{aligned}$ | $\begin{aligned} & \text { ANLD } \\ & \text { PT, A } \end{aligned}$ |
| A | $\begin{gathered} \text { MOV } \\ \text { @RO,A } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { @R1,A } \end{gathered}$ |  | $\begin{aligned} & \text { MOVP } \\ & \text { A,@A } \end{aligned}$ | $\begin{aligned} & \text { JMP } \\ & 5 \times x \end{aligned}$ | $\begin{gathered} \text { CLR } \\ \text { che } \end{gathered}$ |  | $\begin{gathered} \mathrm{CPL} \\ \mathrm{C} \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & \text { RO,A } \end{aligned}$ | MOV R1,A | MOV R2, A | MOV R3, A | $\begin{aligned} & \text { MOV } \\ & \text { R4,A } \end{aligned}$ | MOV <br> R5, A | MOV R6, A | $\begin{aligned} & \text { MOV } \\ & \text { R7,A } \end{aligned}$ |
| B | $\begin{gathered} \text { MOV } \\ \text { @RO, } \end{gathered}$ | MOV @R1,\# | JB5 addr | JMPP @A | $\begin{aligned} & \text { CALL } \\ & 5 \times x \end{aligned}$ | CPL | JFO addr |  | MOV R0, \# | MOV R1, \# | MOV R2, \# | MOV R3, \# | $\begin{aligned} & \text { MOV } \\ & \text { R4, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R5, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R6, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R7, \# } \end{aligned}$ |
| C |  |  |  |  | $\begin{aligned} & \text { JMP } \\ & 6 \times x \end{aligned}$ | $\begin{aligned} & \text { SEL } \\ & \text { RBO } \end{aligned}$ | $\underset{\text { addr }}{\mathrm{JZ}}$ | $\begin{gathered} \text { MOV } \\ \text { A,PSW } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { RO } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R1 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R2 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R3 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R4 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R5 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R6 } \end{gathered}$ | DEC |
| D | $\begin{gathered} \text { XRL } \\ \text { A,@R0 } \end{gathered}$ | $\begin{gathered} \text { XRL } \\ \text { A,@R1 } \end{gathered}$ | JB6 addr | $\begin{gathered} \text { XRL } \\ \text { A\# } \end{gathered}$ | $\begin{aligned} & \text { CALL } \\ & 6 \times x \end{aligned}$ | $\begin{aligned} & \text { SEL } \\ & \text { RB1 } \end{aligned}$ |  | $\begin{aligned} & \text { MOV } \\ & \text { PSW,A } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,RO } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R1 } \end{aligned}$ | $\begin{aligned} & \mathrm{XRL} \\ & \mathrm{~A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R3 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R4 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R6 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \mathrm{A}, \mathrm{R} 7 \end{aligned}$ |
| E |  |  |  | MOVP3 A,@A | $\mathrm{JMP}_{7 \times \mathrm{x}}^{\mathrm{JMP}}$ | SEL <br> MBO | JNC addr | $\begin{gathered} \text { RL } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { RO,M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R1,M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R2,M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R3,M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R4,M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R5,M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R6, M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R7,M } \end{aligned}$ |
| F | $\begin{gathered} \text { MOV } \\ \text { A,@R0 } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { A,@R1 } \end{gathered}$ | $\begin{aligned} & \text { JB7 } \\ & \text { addr } \end{aligned}$ |  | $\begin{aligned} & \text { CALL } \\ & 7 \times \times \end{aligned}$ | SEL MB1 | Jc addr | $\underset{A}{\text { RLC }}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,RO } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R1 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R2 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R3 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R4 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, R6 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R7 } \end{aligned}$ |

[^25]$\square$
Single-byte, Single-cycle Instruction

$\square$| Single-byte, Two-cycle |
| :--- |
| Instruction |


$\square$| Two-byte, Two-cycle |
| :--- |
| Instruction |

## Typical

 Applications(1) Stand Alone System

(2) Expanded System



AC Characteristics*
$\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}$ $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Parameter | Symbol | H-Version |  | E-Version |  | N-Version |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ALE Pulse Width | $t_{\text {LL }}$ | 150 |  | 260 |  | 410 |  | ns |
| Address Setup Time (to ALE!) | $t_{\text {AL }}$ | 70 |  | 140 |  | 230 |  | ns |
| Address Hold Time (from ALE!) | $t_{\text {LA }}$ | 50 |  | 80 |  | 120 |  | ns |
| Control Pulse Width (RD, WR) | ${ }^{\text {c CC1 }}$ | 480 |  | 730 |  | 1050 |  | ns |
| Control Pulse Width (PSEN) | ${ }^{\text {c }}$ C 2 | 350 |  | 550 |  | 800 |  | ns |
| Data Setup Time (before WRI) | $t_{\text {dw }}$ | 390 |  | 610 |  | 880 |  | ns |
| Data Hold Time (after WRI)** | $t_{\text {wo }}$ | 40 |  | 80 |  | 120 |  | ns |
| Data Hold Time (after RDt, PSEN 1 ) | ${ }^{\text {D }}$ DR | 0 | 110 | 0 | 160 | 0 | 220 | ns |
| Data Delayed Time (RD\| to data in) | $\mathrm{t}_{\text {RD1 }}$ |  | 350 |  | 550 |  | 800 | ns |
| Data Delayed Time (PSEN ! to data in) | $\mathrm{t}_{\mathrm{RD2}}$ |  | 210 |  | 360 |  | 550 | ns |
| Address Setup Time (to WR!) | $t_{\text {AW }}$ | 310 |  | 480 |  | 680 |  | ns |
| Address Setup Time (RD, to data in) | $\mathrm{t}_{\text {AD1 }}$ |  | 760 |  | 1130 |  | 1590 | ns |
| Address Setup Time (PSEN, to data in) | $\mathrm{t}_{\mathrm{AD} 2}$ |  | 480 |  | 750 |  | 1090 | ns |
| Address Floating Time (to RD!, WR!) | $\mathrm{t}_{\text {AFC1 }}$ | 140 |  | 210 |  | 290 |  | ns |
| Address Floating Time (to PSEN:) | $\mathrm{t}_{\text {AFC2 }}$ | 10 |  | 20 |  | 40 |  | ns |
| RD, WR Output Time (from ALEI) | $t_{\text {LAFC1 }}$ | 200 |  | 300 |  | 420 |  | ns |
| PSEN Output Time (from ALE!) | $\mathrm{t}_{\text {LAFC2 }}$ | 60 |  | 110 |  | 170 |  | ns |
| ALE Output Time (from RDt, WRt, PROGt) | ${ }_{\text {t }}^{\text {cal }}$ | 50 |  | 80 |  | 120 |  | ns |
| ALE Output Time (from PSENT) | ${ }_{\text {t }}^{\text {ca } 2}$ | 320 |  | 460 |  | 620 |  | ns |
| Port Control Setup Before Falling Edge of PROG Time | $t_{\text {cP }}$ | 100 |  | 170 |  | 250 |  | ns |
| Port Control Hold After Falling Edge of PROG Time | $t_{P C}$ | 160 |  | 300 |  | 460 |  | ns |
| PROG Time P2 Input Must Be Valid | $t_{\text {PR }}$ |  | 700 |  | 1000 |  | 1380 | ns |
| P2 Input Data Hold Time (after PROG ${ }^{1}$ ) | $t_{\text {PF }}$ | 0 | 140 | 0 | 190 | 0 | 250 | ns |
| Output Data Setup Time (to PROG1) | $t_{\text {DP }}$ | 400 |  | 600 |  | 850 |  | ns |
| Output Data Hold Time (after PROG ${ }^{\text {t }}$ ) | $t_{\text {PD }}$ | 90 |  | 130 |  | 200 |  | ns |
| PROG Pulse Width | $\mathrm{t}_{\mathrm{PP}}$ | 700 |  | 1060 |  | 1500 |  | ns |
| Port2 I/O Data Setup Time (to ALE!) | $t_{\text {PL }}$ | 160 |  | 300 |  | 460 |  | ns |
| Port2 I/O Data Hold Time (from ALEt) | $t_{\text {LP }}$ | 40 |  | 60 |  | 80 |  | ns |
| Port Data Output Time (from ALE!) | $t_{\text {PV }}$ |  | 510 |  | 660 |  | 850 | ns |
| Cycle Time*** | $\mathrm{t}_{\mathrm{CY}}$ | 1.36 |  | 1.875 |  | 2.5 |  | $\mu \mathrm{s}$ |
| $\mathrm{T}_{0}$ Output Cycle Time | $t_{\text {OPRR }}$ | 270 |  | 370 |  | 500 |  | ns |

*: 6 MHz XTAL (N-Version), 8 MHz XTAL (E-Version), 11 MHz XTAL (H-Version) Load Conditions: BUS: $\mathrm{C}_{\mathrm{L}}=$ 150 pF ; Other Outputs $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$
**: Load Conditions $C_{L}=20 \mathrm{pF}$, High Impedance
$* * * ; t_{C Y}=2.5 \mu \mathrm{~S}\left(6 \mathrm{MHz}\right.$ XTAL N-Version), $\mathrm{t}_{\mathrm{CY}}=1.875 \mu \mathrm{~s}\left(8 \mathrm{MHz}\right.$ XTAL E-Version), $\mathrm{t}_{\mathrm{CY}}=1.36 \mu \mathrm{~s}(11 \mathrm{MHz} \mathrm{XTAL}$ H-Version)

## FUJITSU

## Timing Diagram

Instruction Fetch From External Program Memory


Read From External Data Memory


Write To External Data Memory


## Timing Diagram (Continued)

P20-23 Input/Output For Use Of External Program Memory And Expander I/O Port


Port 1/Port 2 Outputs


Clock Outputs
$T_{0}$
ALE
PSEN
$\overline{\overline{W D}}$
PROG

## Package Dimensions

Dimensions in inches
(millimeters)


40-Lead Plastic Dual In-Line Package (Case No.: DIP-40P-M01)

© 1985 FUJITSU LIMITED D40005S-1C

## Oscillation Circuits

Crystal Oscillator

*Including stray capacitances

External Clock Drive

*Both high and low times should be more than $35 \%$ of the cycle time, and rise and fall times should be less than 20 ns .

# MBL8049N/E/H MBL8039N/E/H NMOS Single-Chip 8-Bit Microcomputer 

## Description

The Fujitsu MBL8049/MBL8039 is a totally self-contained 8 -bit parallel one-chip microcomputer fabricated with an N -channel silicon gate MOS process.
The MBL8049 has a $2 \mathrm{~K} \times 8$ ROM program memory, a $128 \times 8$ RAM data memory, 27 I/O ports, an 8 -bit timer/counter and clock generator on chip. A single power supply of +5 V is used. The MBL8039 is identical to the MBL8049 except without program memory. It can be used with external memory for system prototyping and preproduction systems.

The design is optimized for low cost, high performance applications because the MBL8049/MBL8039 is fabricated on a single silicon chip and can be used for applications that require additional expansion of ROMs, RAMs, I/O port, etc.

This microcomputer permits external program operation and a single-step operation mode. Low power applications are possible by using the stand-by mode feature.

The MBL8049/MBL8039 is packaged in a standard 40-pin DIP package and operation is guaranteed from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## Features

- 8-bit Parallel Microcomputer
- 12-bit Addressing
- 96 Instructions: 70\% Single Byte
- $1.875 \mu$ s Cycle (E-Version) 2.5 $\boldsymbol{\mu}$ s Cycle ( N -Version) All Instructions are 1 or 2 Cycles.
- $\mathbf{~ 2 K} \times 8$ ROM (MBL8049 only) $128 \times 8$ RAM 27 I/O Lines
- Interval Timer/Event Counter
- Single Level Interrupt Capability
- Resident Clock Generator (External Frequency Source)
- External Input Capability
- Easily Expandable Memory and I/O
- 8 Level Stack
- External Program Mode Capability
- Low Power Stand-by Mode Capability
- Single +5 V Power Supply
- N-channel Silicon Gate E/D MOS Process
- Standard 40-Pin DIP
- MBL8049: Compatible with Intel 8049 MBL8039: Compatible with Intel 8039

Portions reprinted by permission of Intel Corporation, Copyright © 1985 Intel Corporation. Compilation and additional materials Copyright © 1985 by Fujitsu Limited, Tokyo, Japan, and Fujitsu Microelectronics, Inc., Santa Clara, California, U.S.A. Fujitsu Limited is a licensee of Intel Corporation and authorized to produce alternate source products.


Block Diagram


Pin Assignment


This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.
*These pins are internally pulled up.

Pin Description


## Pin Description <br> (Continued)

| Pin No. | Pin Name | Symbol | Function |
| :--- | :--- | :--- | :--- |
| 25 | Program | PROG | This output is used as a strobe signal for an I/O expander <br> (MBL8243) when performing an expansion I/O instruction. |
| 26 | Power <br> Supply | $\mathrm{V}_{\mathrm{DD}}$ | This is used as the power supply terminal ( +5 V ) for the <br> built-in RAM. |
| 27 | Port 1 | $\mathrm{P} 1_{0}$ <br> thru <br> $\mathrm{P1}_{7}$ | This is a quasi-bidirectional input/output port (P1 port) |
| thru |  |  |  |
| 34 | Port 2 | $\mathrm{P2}_{4}$ <br> thru <br> $\mathrm{P}_{7}$ | These are the upper four bits of the quasi-bidirectional <br> input/output port 2 (P2). |
| 35 |  |  |  |
| thru |  |  |  |
| 38 |  |  |  |

## Functional Descriptions for Basic Blocks

| Block Name | Function |
| :---: | :---: |
| Clock Generation Circuitry | A master clock signal within a frequency range of 1 MHz to 6 MHz is supplied from the built-in Clock Generator using an external crystal and capacitor network, or from an external signal source. |
|  | The frequency of the master clock is divided through the $1 / 3$ Frequency Divider to generate a state clock signal. Then, the frequency of the state clock is divided through the $1 / 5$ Frequency Divider to generate a final cycle clock signal. |
|  | The state clock can be transferred to the $T_{0}$ terminal by an instruction. |
|  | The cycle clock is used for internal operations and is also available on the ALE terminal. |
| 1/O Port | Three bidirectional or quasi-bidirectional 8-bit I/O ports and three input terminals are provided for signal inputs and outputs. |
|  | Port 0 (Bus Port) and the lower 4 bits of Port 2 shown in the Block Diagram are used for access to external memories or I/O expanders. |
| Built-in ROM and RAM | In the MBL8049, programs are stored in the built-in ROM (2K Bytes). Also, the contents in the ROM can be used as data for some instructions. |
|  | The built-in RAM (128 bytes) is used for general register area, stack area and working area. |
|  | ROM is expandable up to a total of 4 K Bytes with externally attached ROM by switching the memory bank. |
|  | RAM is expandable by an additional 256 Bytes with externally attached RAM. |
|  | MBL8039 does not have any built-in ROM. It uses external ROM for program storing. |
| Program Counter | The program counter is an 11-bit register which indicates a fetch address of program memory and is incremented by every execution of an instruction. |

## Functional Descriptions <br> for Basic Blocks

(Continued)

| Block Name | Function |
| :--- | :--- |
| Instruction Register | The Instruction Register is an 8-bit register which stores a <br> fetched instruction in a fetch cycle. |
| Instruction Decoder | The Instruction Decoder decodes the instruction stored in <br> the Instruction register and generates various control <br> signals for both internal circuitry and external peripherals. |
| Arithmetic Logic Unit (ALU) | Various operations such as addition, subtraction, <br> comparison, etc., are executed in the ALU. Operation to be <br> executed is determined from the decoding of an instruction. |
|  | The Interval Timer/Event Counter is an 8-bit register which <br> can be controlled by instruction execution. The interval <br> timer mode or event counter mode can be designated by <br> instruction execution, as well. |
|  | This register is not initialized by the RESET signal. In the <br> interval timer mode, the register can count up the <br> frequency signal which is generated by dividing the cycle <br> clock frequency by 32. |
| When the source oscillation frequency is $6 M H z$, this |  |
| enables the register to count a time interval of up to |  |
| 20.48ms with resolution of $80 \mu \mathrm{~s}$. |  |

Resident Data Memory Map (RAM)


Status Register (PSW)
The Status Register is an 8-bit register configured as shown in the following figure. The upper four bits are used for flags to indicate the status of the MPU, and when a sub-routine call or an interrupt occurs, the contents of the program counter is transferred to one of the 8 register pairs of the Stack Register as determined by the lower three bits of the Status Register. The remaining one bit is an unused bit.


## Flags

CY (Carry): When an overflow occurs in the Accumulator during an operation in the ALU, " 1 " is set in this bit.

HC (Half Carry): When an overflow occurs from Bit 3 to Bit 4 in the accumulator as a result of an addition, " 1 " is set in this bit.

Fo(User Flag): This flag can be controlled as a user flag by the proper instruction.

BS (Bank select): This flag can be controlled to select a Register Bank by an instruction. When $B S=0$, the Register Bank 0 is selected. When BS = 1, the Register Bank 1 is selected.

Stack Register (8 Level Capability)
The Stack Register occupies 16-bytes of memory within the on-board RAM. It is configured into eight levels of two bytes each as shown in Figure 1.

## Stack Pointer (SP)

In Figure 1., " SP " indicates the stack level to be used for the next sub-routine call or interrupt. The Stack Pointer generates one of eight address codes and resides in the lower three bits of the status register.
$\mathrm{SP}=00001 \mathrm{SP}_{2} \mathrm{SP}_{1} \mathrm{SP}_{0}$
Program Counter (PC)
In Figure 1., " $\mathrm{PC}_{\mathrm{n}}$ " indicates the individual bit contents of each of the Program Counter bits.

## Interrupt Operation

There are two interrupt modes, external interrupts, and timer/counter interrupts.

When either interrupt occurs, an interrupt flag is set and upon completion of the executing instruction the interrupt is processed.

Interrupt processing is as follows:

1. The contents of the Status Register and Program
Counter are saved on the Stack.
2. Program flow jumps to the address specified at address three (3) for external interrupts and address seven (7) for timer/counter interrupts.
3. Completion of the interrupt processing occurs upon execution of the RETR (Return and Restore Status) instruction.
4. The contents of the program counter and status register are restored from the stack, the interrupt flag is reset to be ready for the next interrupt, and program execution continues from where it left off.

Timer/counter interrupts occur when the overflow flag is set as a result of an overflow from the Timer/Counter.

External interrupts occur when a low level input is applied to the "INT" input.
External interrupts have priority over Timer/Counter interrupts, so if both interrupts occur at the same time the external interrupt will be processed first. After completion of the external interrupt and resetting of the interrupt flag the Timer/ Counter interrupt will be processed.

## Instructions

All instructions are either one or two bytes long and execute in one or two cycles. Addressing modes are classified into direct, expanded, indirect, immediate and implied.

Instruction Mode

1) 1 Byte Instruction


Register Indirect
Addressing Mode


Register Direct Addressing Mode
2) 2 Byte Instruction

| $f$ | OP |
| :---: | :---: |

Immediate Addressing Mode


Expanded Addressing Mode
f: Instruction Operation Set
r: Register Set
OP: Operand Data
$A_{H}, A_{L}$ : Operand Address

Figure 1.



## Instruction Set Summary

## Accumulator

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | CY | HC Fo | $F_{1}$ |  |
| Add register to A | ADD A, $\mathrm{R}_{\mathrm{r}}$ | 6X | 1 | 1 | * | . - | - | $\left(R_{r}\right)+(A)-(A)$ |
| Add data memory to A | ADD A,@R | 60 | 1 | 1 |  | - | - | $\left(\left(R_{0}\right)\right)+(A)-(A)$ |
|  | ADD A,@R ${ }_{1}$ | 61 | 1 | 1 | , | * - | - | $\left(\left(\mathrm{R}_{1}\right)\right)+(A) \rightarrow(A)$ |
| Add immediate to A | ADD A,\#data | 03 | 2 | 2 | * | * - | - | data $+(A) \rightarrow(A)$ |
| Add register with carry | ADDC A, R ${ }_{r}$ | 7 X | 1 | 1 | , | - - | - | $\left(R_{r}\right)+(A)+(C) \rightarrow(A)$ |
| Add data memory with carry | ADDC A, @R ${ }_{0}$ | 70 | 1 | 1 |  | * - | - | $\left(\left(R_{0}\right)\right)+(A)+(C)-(A)$ |
|  | ADDC A, @R ${ }_{1}$ | 71 | 1 | 1 |  | * - | - | $\left(\left(R_{1}\right)\right)+(A)+(C) \rightarrow(A)$ |
| Add immediate to A with carry | ADDC A,\#data | 13 | 2 | 2 | * | * - | - | data $+(A)+(C)-(A)$ |
| And register to A | ANL A, $\mathrm{r}_{\mathrm{r}}$ | 5X | 1 | 1 | - | - - | - | $\left(R_{r}\right) \cap(A)-(A)$ |
| And data memory to A | ANL A,@R ${ }_{0}$ | 50 | 1 | 1 | - | - - | - | $\left(\left(\mathrm{R}_{0}\right)\right) \cap(\mathrm{A}) \rightarrow(\mathrm{A})$ |
|  | ANL A, @R ${ }_{1}$ | 51 | 1 | 1 | - | - - | - | $\left(\left(\mathrm{R}_{1}\right)\right) \cap(\mathrm{A}) \rightarrow(\mathrm{A})$ |
| And immediate to A | ANL A,\#data | 53 | 2 | 2 | - | - - | - | data $\cap(A)-(A)$ |
| Clear A | CLR A | 27 | 1 | 1 | - | - - | - | $0 \rightarrow(A)$ |
| Complement A | CPL A | 37 | 1 | 1 | - | - - | - | $(\bar{A}) \rightarrow(A)$ |
| Decimal Adjust A | DA A | 57 | 1 | 1 | , | - - | - | Note (1) |
| Decrement A | DEC A | 07 | 1 | 1 | - | - - | - | (A) $-1 \rightarrow(\mathrm{~A})$ |
| Increment A | INC A | 17 | 1 | 1 | - | - - | - | $(A)+1 \rightarrow(A)$ |
| Or register to A | ORL A, $\mathrm{R}_{r}$ | 4X | 1 | 1 | - | - - | - | $\left(R_{r}\right) \cup(A)-(A)$ |
| Or data memory to $A$ | ORL A,@R ${ }_{0}$ | 40 | 1 | 1 | - | - - | - | $\left(\left(R_{0}\right)\right) \cup(A) \rightarrow(A)$ |
|  | ORL A,@R ${ }_{1}$ | 41 | 1 | 1 | - | - - | - | $\left(\left(R_{1}\right) \cup(A)-(A)\right.$ |
| Or immediate to A | ORL A,\#data | 43 | 2 | 2 | - | - - | - | data $\cup(A) \rightarrow(A)$ |
| Rotate A left | RLA | E7 | 1 | 1 |  | - - | - | 5प111110 |
| Rotate A left with carry | RLC A | F7 | 1 | 1 | * | - - | - | 鸟 |
| Rotate A right | RR A | 77 | 1 | 1 | - | - - | - | 年 |
| Rotate A right with carry | RRC A | 67 | 1 | 1 | * | - - | - | $44_{0}$ |
| SWAP nibbles of A | SWAP A | 47 | 1 | 1 | - | - - | - | $\left(A_{4-7}\right) \geq\left(A_{0-3}\right)$ |
| Exclusive Or register to A | XRL A, $\mathrm{R}_{\mathrm{r}}$ | DX | 1 | 1 | - | - - | - | $\left(R_{r}\right) \oplus(A) \rightarrow(A)$ |
| Exclusive Or data memory to $A$ | XRL A, @ $\mathrm{R}_{0}$ | D0 | 1 | 1 | - | - - | - | $\left(\left(R_{0}\right)\right) \oplus(A) \rightarrow(A)$ |
|  | XRL A, @R ${ }_{1}$ | D1 | 1 | 1 | - | - | - | $\left(\left(R_{1}\right)\right) \oplus(A) \rightarrow(A)$ |
| Exclusive Or immediate to A | XRL A,\#data | D3 | 2 | 2 | - | - - | - | data $\oplus(A) \rightarrow(A)$ |

## Instruction Set Summary <br> (Continued)

## Input/Output

| Operation | Mnemonic | OP <br> Code |  |  | Fla |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Byte | Cycle |  |  |  | $F_{1}$ |  |
| And immediate to BUS | ANL BUS,\#data | 98 | 2 | 2 | - | - | - | - | data $\cap(B \cup S) \rightarrow(B \cup S)$ |
| $P_{1}$ | ANL $\mathrm{P}_{1}$,\#data | 99 | 2 | 2 | - | - | - | - | data $\cap\left(\mathrm{P}_{1}\right) \rightarrow\left(\mathrm{P}_{1}\right)$ |
| $\mathrm{P}_{2}$ | ANL $P_{2}$, \#data | 9A | 2 | 2 | - | - | - | - | data $\cap\left(\mathrm{P}_{2}\right) \rightarrow\left(\mathrm{P}_{2}\right)$ |
| And A to Expander Port | ANLD $P_{p}, A$ | 9 X | 1 | 2 | - | - | - | - | (A) $\cap\left(P_{P}\right) \rightarrow\left(P_{P}\right)$ |
| Input BUS to A | INS A,BUS | 08 | 1 | 2 | - | - | - | - | $(B \cup S) \rightarrow(A)$ |
| Port 1 to A | IN A, $\mathrm{P}_{1}$ | 09 | 1 | 2 | - | - | - | - | $\left(P_{1}\right) \rightarrow(A)$ |
| Port 2 to A | IN A, $\mathrm{P}_{2}$ | OA | 1 | 2 | - | - | - | - | $\left(P_{2}\right) \rightarrow(A)$ |
| Input Expander port to A | MOVD A, $\mathrm{P}_{\mathrm{P}}$ | OX | 1 | 2 | - | - | - | - | $\begin{aligned} & \left(P_{P}\right) \rightarrow(A)_{0-3} \\ & 0 \rightarrow(A)_{4-7} \end{aligned}$ |
| Or immediate to BUS | ORL BUS,\#data | 88 | 2 | 2 | - | - | - | - | data $\cup(B \cup S) \rightarrow(B U S)$ |
| $\mathrm{P}_{1}$ | ORL $\mathrm{P}_{1}$,\#data | 89 | 2 | 2 | - | - | - | - | data $\cup\left(\mathrm{P}_{1}\right) \rightarrow\left(\mathrm{P}_{1}\right)$ |
| $\mathrm{P}_{2}$ | ORL $P_{2}$, \#data | 8A | 2 | 2 | - | - | - | - | data $\cup\left(\mathrm{P}_{2}\right) \rightarrow\left(\mathrm{P}_{2}\right)$ |
| Or A to Expander Port | ORLD Pr,A | 8X | 1 | 2 | - | - | - | - | data $\cup\left(P_{P}\right) \rightarrow\left(P_{P}\right)$ |
| Output A to BUS | OUTL BUS,A | 02 | 1 | 2 | - | - | - | - | $(\mathrm{A}) \rightarrow(\mathrm{BUS})$ |
| $\mathrm{P}_{1}$ | OUTL $P_{1}, A$ | 39 | 1 | 2 | - | - | - | - | $(\mathrm{A}) \rightarrow\left(\mathrm{P}_{1}\right)$ |
| $\mathrm{P}_{2}$ | OUTL $P_{2}, A$ | 3A | 1 | 2 | - | - | - | - | $(\mathrm{A}) \rightarrow\left(\mathrm{P}_{2}\right)$ |
| Output A to Expander Port | MOVD Pp, ${ }^{\text {a }}$ | 3 X | 1 | 2 | - | - | - | - | $(A) \rightarrow\left(P_{P}\right)$ |

## Data Moves

| Operation | Mnemonic | OP Code | Byte | Cycle | Fiag |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  | $F_{1}$ |  |
| Move register to $A$ Move data memory to $A$ | MOV A, $\mathrm{R}_{\mathrm{r}}$ | FX | 1 | 1 | - | - | - | - | $\left(R_{r}\right) \rightarrow(A)$ |
|  | MOV.A,@R | FO | 1 | 1 | - | - | - | - | $\left(\left(R_{0}\right)\right) \rightarrow(A)$ |
|  | MOV A,@R ${ }_{1}$ | F1 | 1 | 1 | - | - | - | - | $\left(\left(R_{1}\right)\right) \rightarrow(A)$ |
| Move immediate to $A$ | MOV A,\#data | 23 | 2 | 2 | - | - | - | - | data $\rightarrow(A)$ |
| Move A to register | MOV $\mathrm{R}_{\mathrm{r}}, \mathrm{A}$ | AX | 1 | 1 | - | - | - | - | $(\mathrm{A}) \rightarrow\left(\mathrm{R}_{r}\right)$ |
| Move A to data memory | MOV @ $\mathrm{R}_{0}, \mathrm{~A}$ | A0 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \rightarrow\left(\left(\mathrm{R}_{0}\right)\right)$ |
|  | MOV@R ${ }_{1}, A$ | A1 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \rightarrow\left(\left(\mathrm{R}_{1}\right)\right)$ |
| Move immediate to register Move immediate to data memory | MOV $\mathrm{R}_{\mathrm{r}}$ \# ${ }^{\text {data }}$ | $B X$ | 2 | 2 | - | - | - | - | data $\rightarrow\left(R_{r}\right)$ |
|  | MOV @ $\mathrm{R}_{0}$, \#data $\mathrm{BO}^{\text {a }}$ |  | 2 | 2 | - | - | - | - | data $\rightarrow\left(\left(\mathrm{R}_{0}\right)\right)$ |
|  | MOV @ $\mathrm{R}_{1}$, \#data $\mathrm{B}_{1}$ |  | 2 | 2 | - | - | - | - | data $\rightarrow\left(\left(\mathrm{R}_{1}\right)\right)$ |
| Move PSW to A | MOV A,PSW | C7 | 1 | 1 | - | - | - | - | $(\mathrm{PSW}) \rightarrow(\mathrm{A})$ |
| Move A to PSW | MOV PSW,A | D7 | 1 | 1 | * | * | * | - | $(\mathrm{A}) \rightarrow(\mathrm{PSW})$ |
| Move external data memory to $A$ | MOVX A, @R ${ }_{0}$ | 80 | 1 | 2 | - | - | - | - | $\left(\left(R_{0}\right)\right) \rightarrow(A)$ |
|  | MOVX A, @R ${ }_{1}$ | 81 | 1 | 2 | - | - | - | - | $\left(\left(R_{1}\right)\right) \rightarrow(A)$ |
| Move A to eternal data memory | MOVX @ $\mathrm{R}_{0}$, A | 90 | 1 | 2 | - | - | - | - | $(\mathrm{A})-\left(\left(\mathrm{R}_{0}\right)\right)$ |
|  | MOVX@R ${ }_{1}, \mathrm{~A}$ | 91 | 1 | 2 | - | - | - | - | $(\mathrm{A}) \rightarrow\left(\left(\mathrm{R}_{1}\right)\right)$ |
| Move to $A$ from current page | MOVP A,@A | A3 | 1 | 2 | - | - | - | - | $((A)) \rightarrow(A)$ |
| Move to $A$ from page 3 | MOVP3 A, @A | E3 | 1 | 2 | - | - | - | - | $((A))$ within page $3 \rightarrow$ (A) |
| Exchange A and register Exchange $A$ and data memory | $\begin{aligned} & \mathrm{XCH} A, \mathrm{R}_{\mathrm{r}} \\ & \mathrm{XCH} \mathrm{A,@R}_{0} \\ & \text { XCH A,@R } \end{aligned}$ | 2 X | 1 | 1 | - | - | - | - | $\left(R_{r}\right) \rightleftarrows(A)$ |
|  |  | 20 | 1 | 1 | - | - | - | - | $\left(\left(R_{0}\right)\right) \rightleftarrows(A)$ |
|  |  | 21 | 1 | 1 | - | - | - | - | $\left(\left(R_{1}\right)\right) \geq(A)$ |
| Exchange nibble of $A$ and data memory | XCHD A, @R ${ }_{0}$ | 30 | 1 | 1 | - | - | - | - | $\left((\mathrm{RO})_{0-3}\right) \rightleftarrows\left(\mathrm{A}_{0-3}\right)$ |
|  | XCHD A,@R ${ }_{1}$ | 31 | 1 | 1 | - | - | - | - | $\left((\mathrm{R} 1)_{0-3}\right) \geq\left(\mathrm{A}_{0-3}\right)$ |



Instruction Set Summary (Continued)

## Registers

## Control

## Instruction Set Summary <br> (Continued)

## Branch



## Subroutine

|  |  | OP Code | Byte | Cycle | Flag |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operation | Mnemonic |  |  |  |  |  |  | $F_{1}$ |  |
| Jump to subroutine | CALL addr | \%4 | 2 | 2 | - | - | - | - | Note (4) |
| Return | RET | 83 | 1 | 2 | - | - | - | - | Note (5) |
| Return and restore status | RETR | 90 | 1 | 2 | . | * | * | - | Note (6) |

## Flags

| Operation | Mnemonic | OP <br> Code | Byte | Cycle | Flag |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | CY | HC |  | $F_{1}$ |  |
| Clear carry | CLR C | 97 | 1 | 1 | Z | - | - | - | $0 \rightarrow$ (C) |
| Complement carry | CPL C | A7 | 1 | 1 | CP | - | - | - | $(\bar{C}) \rightarrow(C)$ |
| Clear Flag 0 | CLR $\mathrm{F}_{0}$ | 85 | 1 | 1 | - | - | Z | - | $0 \rightarrow\left(F_{0}\right)$ |
| Complement Flag 0 | CPL F ${ }_{0}$ | 95 | 1 | 1 |  | - | CP | - | $\left(\overline{F_{0}}\right) \rightarrow\left(F_{0}\right)$ |
| Clear Flag 1 | CLR $\mathrm{F}_{1}$ | A5 | 1 | 1 | - | - | - | Z | $0 \rightarrow\left(F_{1}\right)$ |
| Complement Flag 1 | CPL F 1 | B5 | 1 | 1 |  |  | - | CP | $\left(\overline{F_{1}}\right)-\left(F_{1}\right)$ |

## Notes:

Operation Code X: Tables-1, 2 \%: Table 3
Flag*: This flag is set or reset in the state after executed instruction.
Z: This flag is reset.
CP: This flag is complemented.

1) The accumulator value is adjusted to form BCD digits following the binary addition of BCD numbers.
2) DJNZ R $R_{r}$, addr;
$\left(R_{r}\right)-1 \xrightarrow{\rightarrow}\left(R_{r}\right)$
if $\left(R_{r}\right) \neq 0$ addr $\rightarrow\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right)$
if $\left(R_{r}\right)=0$ execute next instruction
3) JMPP @A
$((\mathrm{A}))-\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right)$
4) CALL addr
$\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right) \rightarrow((\mathrm{SP}))$
$(S P)+1 \rightarrow(S P)$
$\left(\mathrm{PC}_{8}\right.$ to $\left.\mathrm{PC}_{11}\right),(\mathrm{MBF}),\left(\mathrm{PSW}_{4}\right.$ to $\left.\mathrm{PSW}_{7}\right) \rightarrow((\mathrm{SP}))$
$(S P)+1 \rightarrow(S P)$
$\mathrm{A}_{\mathrm{L}} \rightarrow\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right)$
$\mathrm{A}_{\mathrm{H}} \rightarrow\left(\mathrm{PC}_{8}\right.$ to $\left.\mathrm{PC}_{10}\right)$
$\mathrm{MBF} \rightarrow\left(\mathrm{PC}_{11}\right)$

## Instruction Set Summary

 (Continued)OP Code of Register Access (Table 1)
Mnemonic $\quad$ Rr RO R1 R2 R3 R4 R5 R6 R7

| $1 N C R r$ | 18 | 19 | $1 A$ | $1 B$ | $1 C$ | $1 D$ | $1 E$ | $1 F$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

$\mathrm{XCH} A, \mathrm{Rr} \quad 28 \quad 29 \quad 2 \mathrm{~A} \quad 2 \mathrm{~B} \quad 2 \mathrm{C}$ 2D 2E 2F
ORLA,Rr $48 \quad 49$ 4A 4B 4C 4D 4E 4F
ANL A,Rr $58 \quad 59$ 5A 5B 5C 5D 5E 5F
ADD A,Rr $68 \quad 69$ 6A 6B 6C 6D 6E 6F
ADDC A,Rr $78 \quad 79$ 7A 7B 7C 7D 7E 7F
MOV Rr,A A8 A9 AA AB AC AD AE AF
MOV Rr,\#data B8 B9 BA BB BC BD BE BF
DECRr C8 C9 CA CB CC CD CE CF
XRL A,Rr D8 D9 DA DB DC DD DE DF
DJNZ Rr,M E8 E9 EA EB EC ED EE EF

| MOV A,Rr | F8 | F9 | FA | FB | FC | FD | FE |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| OP Code of Expander (Table 2) |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
| Mnemonic | PP | P4 | P5 | P6 |
| P7 |  |  |  |  |
| MOVD A, $P_{P}$ |  | $0 C$ | $0 D$ | $0 E$ |
| MOVD $P_{P}, A$ | $3 C$ | $3 D$ | $3 E$ | $3 F$ |
| ORLD $P_{P}, A$ | $8 C$ | $8 D$ | $8 E$ | $8 F$ |
| ANLD $P_{P}, A$ | $9 C$ | $9 D$ | $9 E$ | $9 F$ |



OP Code of JMP, CALL, JB ${ }_{\mathrm{r}}$ (Table 3)


## Instruction Codes

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | NOP | HALT | OUTL <br> BSU.A | $\begin{gathered} \text { ADD } \\ \text { A. } \# \end{gathered}$ | $\begin{aligned} & \text { JMP } \\ & 0 \times x \end{aligned}$ | $\underset{1}{\mathrm{EN}}$ |  | $\underset{A}{\text { DEC }}$ | $\begin{aligned} & \text { INS } \\ & \text { I,BUS } \end{aligned}$ | $\underset{A, P 1}{i N}$ | $\begin{gathered} \mathbb{N}, \\ \mathrm{A}, \mathrm{P} 2 \end{gathered}$ |  | $\begin{gathered} \text { MOVD } \\ \text { A,P4 } \end{gathered}$ | $\begin{gathered} \text { MOVD } \\ \text { A,P5 } \end{gathered}$ | $\begin{gathered} \text { MOVD } \\ \text { A,P6 } \end{gathered}$ | MOVD A.P7 |
| 1 | $\begin{aligned} & \text { INC } \\ & \text { @RO } \end{aligned}$ | INC <br> @R1 | $\begin{aligned} & \text { JBO } \\ & \text { addr } \end{aligned}$ | ADDC | $\begin{aligned} & \text { CALL } \\ & 0 \times x \end{aligned}$ | $\underset{1}{\text { DIS }}$ | $\begin{aligned} & \text { JTF } \\ & \text { addr } \end{aligned}$ | $\underset{A}{\text { INC }}$ | $\begin{aligned} & \text { INC } \\ & \text { RO } \end{aligned}$ | $\begin{gathered} \text { INC } \\ \text { R1 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R2 } \end{gathered}$ | INC $\mathrm{R} 2$ | $\begin{gathered} \text { INC } \\ \text { R } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R5 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R6 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R7 } \end{gathered}$ |
| 2 | $\begin{gathered} \mathrm{XCH} \\ \mathrm{~A} @ \mathrm{OR} \end{gathered}$ | $\begin{gathered} \mathrm{XCH} \\ \text { A.@R1 } \end{gathered}$ |  | MOV A.\# | $\begin{aligned} & \text { JMP } \\ & 1 \times \mathrm{x} \end{aligned}$ | $\begin{gathered} \text { EN } \\ \text { TCNT } 1 \end{gathered}$ | JNTO addr | $\underset{A}{\text { CLR }}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{RO} \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 1 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 3 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 4 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 5 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 6 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \text { A,R7 } \end{aligned}$ |
| 3 | $\begin{aligned} & \text { XCHD } \\ & \text { A, @RO } \end{aligned}$ | XCHD A,@R1 | JB1 |  | $\begin{aligned} & \text { CALL } \\ & 1 \times \times \end{aligned}$ | $\begin{gathered} \text { DIS } \\ \text { TCNT1 } \end{gathered}$ | $\begin{aligned} & \text { JT0 } \\ & \text { addr } \end{aligned}$ | $\underset{A}{\mathrm{CPL}}$ |  | $\begin{gathered} \text { OUTL } \\ \text { P1, } \end{gathered}$ | OUTL P2,A |  | $\begin{aligned} & \text { MOVD } \\ & \text { P4,A } \end{aligned}$ | $\begin{gathered} \text { MOVD } \\ \text { P5,A } \end{gathered}$ | $\begin{gathered} \text { MOVD } \\ \text { P6,A } \end{gathered}$ | MOVD P7,A |
| 4 | $\begin{aligned} & \text { ORL } \\ & \text { A.@R } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A.@R1 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A.T } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A.\# } \end{aligned}$ | $\begin{aligned} & \text { JMP } \\ & 2 \times x \end{aligned}$ | $\begin{aligned} & \text { STRT } \\ & \text { CNT } \end{aligned}$ | $\text { JNT } 1$ addr | $\underset{A}{\text { SWAP }}$ | $\begin{aligned} & \text { ORL } \\ & \text { A.RO } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A.R1 } \end{aligned}$ | ORL <br> A.R2 | $\begin{aligned} & \text { ORL } \\ & \text { A.R3 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A, R4 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A,R6 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A,R7 } \end{aligned}$ |
| 5 | $\begin{gathered} \text { ANL } \\ \text { A, @Ro } \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,@R1 } \end{aligned}$ | $\begin{aligned} & \text { JB2 } \\ & \text { addr } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A. } \end{aligned}$ | $\begin{aligned} & \text { CALL } \\ & 2 \times x \end{aligned}$ | $\begin{gathered} \text { STRT } \\ T \end{gathered}$ | JT1 <br> addr | $\begin{gathered} \text { DA } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & \text { A.RO } \end{aligned}$ | ANL A.R1 | $\begin{aligned} & \text { ANL } \\ & \text { A,R2 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R3 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R4 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R6 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A.R7 } \end{aligned}$ |
| 6 | $\begin{aligned} & \text { ADD } \\ & \text { A.@R } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A.@R1 } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { T.A } \end{gathered}$ |  | JMP $3 \times x$ | $\begin{aligned} & \text { STOP } \\ & \text { TCNT } \end{aligned}$ |  | $\underset{A}{\text { RRC }}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,RO } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R1 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A.R2 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A.R4 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R6 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R7 } \end{aligned}$ |
| 7 | ADDC <br> A,@R0 | ADDC <br> A.@R1 | JB3 |  | $\begin{aligned} & \text { CALL } \\ & 3 \times \times \end{aligned}$ | $\begin{aligned} & \text { ENTO } \\ & \text { CLK } \end{aligned}$ | JF1 addr | $\begin{gathered} \text { RR } \\ A \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A.RO } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R1 } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R2 } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R3 } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A.R4 } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R5 } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R6 } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R7 } \end{gathered}$ |
| 8 | MOVX <br> A.@RO | MOVX <br> A.@R1 |  | RET | JMP $4 \times x$ | $\begin{aligned} & \text { CLR } \\ & \text { F } \end{aligned}$ | JN1 <br> addr |  | $\begin{aligned} & \text { ORL } \\ & \text { BUS. } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { P1,\# } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { P2,\# } \end{aligned}$ |  | $\begin{aligned} & \text { ORLD } \\ & \text { P4.A } \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \text { P5,A } \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \text { P6, } \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \hline \text { P7,A } \end{aligned}$ |
| 9 | MOVX @RO.A | MOVX <br> @R1.A | JB4 addr | RETR | $\begin{gathered} \text { CALL } \\ 4 \times x \end{gathered}$ | $\begin{gathered} \text { CPL } \\ \text { FO } \end{gathered}$ | JNZ addr | $\underset{\mathrm{C}}{\mathrm{CLR}}$ | ANL BUS.\# | $\begin{aligned} & \text { ANL } \\ & \text { P1. \# } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { P2. * } \end{aligned}$ |  | $\begin{aligned} & \text { ANLD } \\ & \text { P4.A } \end{aligned}$ | $\begin{aligned} & \text { ANLD } \\ & \text { P5,A } \end{aligned}$ | $\begin{aligned} & \text { ANLD } \\ & \text { P6.A } \end{aligned}$ | ANLD P7,A |
| A | $\begin{gathered} \text { MOV } \\ \text { @RO,A } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ @ R 1 . A \end{gathered}$ |  | $\begin{aligned} & \text { MOVP } \\ & \text { A,@A } \end{aligned}$ | $\begin{aligned} & \text { JMP } \\ & 5 \times \mathrm{x} \end{aligned}$ | $\begin{gathered} \text { CLRR } \\ \text { che } \end{gathered}$ |  | $\begin{gathered} \mathrm{CPL} \\ \mathrm{C} \end{gathered}$ | MOV RO.A | $\begin{aligned} & \text { MOV } \\ & \text { R1,A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R2.A } \end{aligned}$ | MOV R3,A | $\begin{aligned} & \text { MOV } \\ & \text { R4.A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R5,A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R6, A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R7,A } \end{aligned}$ |
| B | $\begin{aligned} & \text { MOV } \\ & \text { @RO, } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { @R1,\# } \end{gathered}$ | $\begin{aligned} & \text { JB5 } \\ & \text { addr } \end{aligned}$ | JMPP @A | $\begin{aligned} & \text { CALL } \\ & 5 \times x \end{aligned}$ | $\begin{gathered} \text { CPL } \\ \text { F1 } \end{gathered}$ | $\begin{aligned} & \text { JFO } \\ & \text { addr } \end{aligned}$ |  | $\begin{aligned} & \text { MOV } \\ & \text { RO\# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R1\# } \end{aligned}$ | MOV R2\# | $\begin{gathered} \text { MOV } \\ \text { R3\# } \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & \text { R4\# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R5\# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R6\#\# } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { R7\# } \end{gathered}$ |
| C |  |  |  |  | $\begin{aligned} & \text { JMP } \\ & 6 \times x \end{aligned}$ | $\begin{aligned} & \text { SEL } \\ & \text { RBO } \end{aligned}$ | $\underset{\text { addr }}{\mathrm{JZ}}$ | MOV <br> A.PSW | $\begin{gathered} \text { DEC } \\ \text { RO } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R1 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R2 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R3 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R4 } \end{gathered}$ | $\begin{aligned} & \text { DEC } \\ & \text { R5 } \end{aligned}$ | $\begin{gathered} \text { DEC } \\ \text { R6 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R7 } \end{gathered}$ |
| D | $\begin{gathered} \text { XRL } \\ \text { A.@R0 } \end{gathered}$ | $\begin{gathered} \text { XRL } \\ \text { A,@R1 } \end{gathered}$ | $\begin{gathered} \text { JB6 } \\ \text { addr } \end{gathered}$ | $\underset{\text { A\# }}{\text { XRL }}$ | $\begin{aligned} & \text { CALL } \\ & 6 \times x \end{aligned}$ | $\begin{aligned} & \text { SEL } \\ & \text { RB1 } \end{aligned}$ |  | MOV PSW.A | $\begin{aligned} & \text { XRL } \\ & A, R O \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R1 } \end{aligned}$ | $\begin{aligned} & \mathrm{XRL} \\ & \mathrm{~A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A.R3 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A.R4 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R6 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R7 } \end{aligned}$ |
| E |  |  |  | MOVP3 <br> A.@A | JMP $7 \times \times$ | $\begin{aligned} & \text { SEL } \\ & \text { MBO } \end{aligned}$ | JNC addr | $\begin{gathered} \text { RL } \\ A \end{gathered}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { ROO,M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R1,M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R2M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R3.M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R4.M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R5.M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R6.M } \end{aligned}$ | $\begin{gathered} \text { DJNZ } \\ \text { R7,M } \end{gathered}$ |
| F | $\begin{gathered} \text { MOV } \\ \text { A.@Ro } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { A,@R1 } \end{gathered}$ | JB7 addr |  | $\begin{aligned} & \text { CALL } \\ & 7 \times x \end{aligned}$ | SEL MB1 | $\underset{\text { addr }}{\mathrm{JC}}$ | $\underset{A}{\text { RLC }}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,RO } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A.R2 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R4 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R6 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R7 } \end{aligned}$ |

## \#: Immediate data

H ; Higher 4 bits
L; Lower 4 bits
$\square$ Single-byte, Single-cycle Instruction

$\square$| Single-byte, Two-cycle |
| :--- |
| Instruction |

## Typical

Applications
(1) Stand Alone System

(2) Expanded System


## Absolute Maximum Ratings $\dagger$

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to +7.0 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 1.5 | W |

$\dagger$ Permanent device damage may occur if the ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliabilty.

## Recommended Operating Conditions

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}$ | $+5.0 \pm 10 \%$ | V |
| Operating Temperature | $\mathrm{V}_{\mathrm{SS}}$ | 0 | V |

## DC Characteristics

$\left(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}$
$\left.=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\right)$

| Parameter |  | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Max. |  |
| Input Low Voltage | $\frac{\text { All Except XTAL1, } 2, ~}{\text { RESET }}$ | $V_{I L}$ |  | -0.3 | 0.8 | V |
|  | XTAL1,2, $\overline{\text { RESET }}$ | $\mathrm{V}_{\mathrm{IL} 1}$ |  | -0.3 | 0.6 | V |
| Input High Voltage | $\frac{\text { All Except XTAL1, }}{\text { RESET }}$, | $V_{I H}$ |  | 2.0 | $\mathrm{V}_{\mathrm{Cc}}$ | V |
|  | XTAL1,2, RESET | $\mathrm{V}_{\mathrm{IH} 1}$ |  | 3.8 | $\mathrm{V}_{\mathrm{CC}}$ | V |
| Output Low Voltage | BUS | $\mathrm{V}_{\text {OL }}$ | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |  | 0.45 | V |
|  | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\text { PSEN }}, \mathrm{ALE}$ | $\mathrm{V}_{\mathrm{OL} 1}$ | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |  | 0.45 | V |
|  | PROG | $\mathrm{V}_{\mathrm{OL} 2}$ | $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ |  | 0.45 | V |
|  | Other outputs | $\mathrm{V}_{\mathrm{OL3}}$ | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |  | 0.45 | V |
| Output High Voltage | BUS | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ | 2.4 |  | V |
|  | 产, $\overline{\mathrm{WR}}, \overline{\text { PSEN }}, \mathrm{ALE}$ | $\mathrm{V}_{\mathrm{OH} 1}$ | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ | 2.4 |  | V |
|  | Other Outputs | $\mathrm{V}_{\mathrm{OH} 2}$ | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}$ | 2.4 |  | V |
| Input Leakage Current | T, $\overline{\text {, }}$ NT | $\mathrm{I}_{\mathrm{LL}}$ | $\mathrm{V}_{\text {SS }} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |  | $\pm 10$ | $\mu \mathrm{A}$ |
|  | $\begin{aligned} & \text { P10-P17, P20-P27 } \\ & \text { EA, SS } \end{aligned}$ | $\mathrm{I}_{1 / 1}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+0.45 \mathrm{~V} \leq \\ & \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}} \end{aligned}$ |  | -500 | $\mu \mathrm{A}$ |
| Output Leakage <br> Current | BUS, $T_{0}$ (HighImpedance) | $\mathrm{I}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+0.45 \mathrm{~V} \leq \\ & \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}} \end{aligned}$ |  | $\pm 10$ | $\mu \mathrm{A}$ |
| V ${ }_{\text {DD }}$ Supply Current | MBL8049/39N/E | $I_{\text {D }}$ |  |  | 30 | mA |
|  | MBL8049/39H |  |  |  | 50 | mA |
| Total Supply Current | MBL8049/39N/E | $I_{D D}+I_{C C}$ |  |  | 150 | mA |
|  | MBL8049/39H |  |  |  | 170 | mA |

AC Characteristics*
$\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{\mathrm{DD}}$ $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

|  |  | H-Version | E-Version | N-Version |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Parameter | Symbol | Min. | Max. | Min. | Max. | Min. | Max. | Unit.

[^26]Timing Diagram
Instruction Fetch From External Program Memory


Read From External Data Memory


Write To External Data Memory


Timing Diagram (Continued)

P20-23 Input/Output For Use Of External Program Memory And Expander I/O Port


Port 1/Port 2 Outputs


Clock Outputs


## Package Dimensions

Dimensions in inches
(millimeters)

## 40-Lead Ceramic <br> (Metal Seal) Dual In-Line Package

 (Case No.: DIP-40C-A01)
© 1986 FUJITSU LIMITED D40006S-1C

40-Lead Plastic Dual In-Line Package (Case No.: DIP-40P-M01)


© 1985 FUJITSU LIMITED D40005S-1C

## Oscillation Circuits

## Crystal Oscillator

 External Clock Drive

* Including stray capacitances

*Both high and low times should be more than $35 \%$ of the cycle time, and rise and fall times should be less than 20 ns .



## NMOS

SINGLE-CHIP 8-BIT

## DESCRIPTION

The Fujitsu MBL8749 is an 8-bit single-chip microcomputer that uses a $2 \mathrm{~K} \times 8$-bit Electrically Programmable Read Only Memory (EPROM) for program memory. The EPROM can be erased by using an ultraviolet (UV) light source; thus, program memory for the MBL8749 can be changed as often as required. Also included in the MBL8749 are: $256 \times 8$-bit static RAM, 27 I/O lines, an 8 -bit timer/counter, and a clock generator. The device can be ordered in either of two speed versions: N -version for operation at 6 MHz and the H -version for operation at 11 MHz . For either frequency, the operating temperature range is $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.
The MBL8749 is fabricated using an N -channel, 2-layer polysilicon-gate MOS process. The MBL8749 is housed in a 40-pin ceramic windowed DIP and requires a single +5 -volt supply for basic operation and a 21 -volt supply for programming the EPROM.

The MBL8749 is well suited for applications such as system evaluation, system prototyping, and low-volume production work.

## FEATURES

- $2 \mathrm{~K} \times 8$-bit program memory (EPROM)
- $256 \times 8$-bit data memory (static RAM)
- 8-level stack
- 8 pairs of working registers
- 27 I/O lines: Two 8-bit I/O ports, one 8-bit data bus, two test inputs, and one interrupt input
- 8-bit timer/counter
- On-chip clock generator (or external clock source)
- Single-level interrupt
- External program mode
- Single-step operation
- RAM retention in low-power standby mode
- ALU functions: Addition, decimal adjust addition, and logic operations
- Instruction cycle time: $1.36 \mu \mathrm{~s}$ for H -version ( 11 MHz ) and $2.5 \mu \mathrm{~s}$ for N -Version ( 6 MHz )
- Powerful instruction set: 96 instructions (230 op-codes). All instructions complete in one or two instruction cycles with 70\% being of the single-byte type
- Some instructions can process ROM contents as data


PIN ASSIGNMENT


This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

## Features (Cont)

- I/O port data can be handled directly in logic operations
- Binary coded decimal (BCD) data can be handled
- Single +5 V power supply
- $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ operating temperature range
- N-channel, 2-layer polysilicon-gate MOS process
- 40-pin ceramic DIP package
- Compatible with Intel 8749
- Replaceable with Fujitsu MBL8049/48 and Intel 8049/8048


## PIN DESCRIPTIONS

| Pin No. | Symbol | Function |
| :---: | :---: | :---: |
| 1 | T0 | Test Input 0: Input for conditional branch instructions JTO and JNTO. Clock output when an ENTO CLK instruction is executed. |
| 2 | XTAL1 | Connections for external crystal. If an external TTL clock source is used, proper interface circuits are required between the clock source and XTAL1/XTAL2, since these inputs are not TTL compatible. Generally an open-collector drive and a squarewave pulse shaper will suffice. |
| 3 | XTAL2 |  |
| 4 | $\overline{\text { RESET }}$ | When active low, resets MPU and initializes processor as follows: <br> - Clears program counter and stack pointer. <br> - Selects memory bank 0 and register bank 0 . <br> - Disables T0 output. <br> - Places bus in the high-impedance state and ports 1 and 2 in the input mode. <br> - Disables interrupts and stops the timer/counter. <br> - Clears timer and user flags F0 and F1. |
| 5 | $\overline{\mathrm{SS}}$ | Input for single step operation. When $\overline{\mathrm{SS}}$ is pulsed and goes low, the MPU executes the current instruction and stops. The next instruction address is fetched and placed in the four low-order bits of port 2 and the bus port. When $\overline{S S}$ is pulsed high, the single-step operation is repeated so long as $\overline{\mathrm{SS}}$ is repetitively driven low, high, low, high, etc. When $\overline{\mathrm{SS}}$ is permanently set to the high state, normal operation resumes. |
| 6 | $\overline{\text { INT }}$ | When active low, initiates an external interrupt request. <br> The $\overline{\mathrm{NT}}$ input signal must remain low until the interrupt request is latched. This pin also serves as an input for a conditional branch instruction (JNI). |
| 7 | EA | All program memory accesses are directed to an external program memory when EA is high. At this time, the Program Store Enable ( $\overline{\mathrm{PSEN}}$ ) strobe is also output to external program memory. |
| 8 | $\overline{\mathrm{RD}}$ | The read strobe ( $\overline{\mathrm{RD}}$ ) is active (Low) when data is read from the bus port. This strobe output signal enables data onto the bus port from external devices including external data memory. The $\overline{R D}$ strobe is output when either an INS A,BUS or MOVX A @Rr instruction is executed. |
| 9 | $\overline{\text { PSEN }}$ | The Program Store Enable ( $\overline{\mathrm{PSEN}}$ ) strobe is output to external program memory each time the memory is accessed. <br> This external program memory enable signal is generated in the instruction fetch cycle and the instruction is fetched on the rising edge of this signal. |

PIN DESCRIPTIONS (continued)

| Pin No. | Designator | Function |
| :---: | :---: | :---: |
| 10 | $\overline{\mathrm{WR}}$ | When active low, the write ( $\overline{\mathrm{WR}}$ ) strobe enables data to pass from the data bus port to external I/O devices, including external memory. The $\overline{W R}$ strobe is active when executing an "OUTL BUS, $A$ " or a "MOVX@Rr, A" instruction. |
| 11 | ALE | Clock signal (ALE) output generated in each instruction cycle. This signal is used for external synchronization with the MPU. The address signal to the external program memory or external data memory is latched at the falling edge of the ALE signal. This signal is output except during single-step operations. |
| $\begin{aligned} & 12 \\ & \text { to } \\ & 19 \end{aligned}$ | $\begin{aligned} & \text { DB0 } \\ & \text { to } \\ & \text { DB7 } \end{aligned}$ | A bidirectional I/O port called the bus port (Port 0). Strobe signals $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ are output on data input or output. This port can also be used for latch output or as the interface to the external program memory or external data memory. When the external program memory is accessed, the address signal (the low-order 8 bits) is output synchronously with the ALE signal and the instruction is fetched from the specified address synchronously with the $\overline{\text { PSEN }}$ signal. When external data memory is accessed, the address signal is output synchronously with the ALE signal and data is read or written synchronously with the $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ signal. When data is not being input or output, the bus port is in a high-impedance state. |
| 20 | $\mathrm{V}_{S S}$ | Ground terminal (GND) |
| $\begin{aligned} & 21 \\ & \text { to } \\ & 24 \end{aligned}$ | P20 to <br> P23 | A pseudo-bidirectional I/O port. All bits must be set to 1 before the port is used for input. The four low-order bits (P20 to P23) function as the interface to the I/O expander (MBL8243) or serve as an output for the address signal (four high-order bits) when the external program memory is used. The port data is lost on access to the I/O expander and retained when the external program memory is accessed; it is recovered when no address data is output. |
| $\begin{aligned} & 35 \\ & \text { to } \\ & 38 \end{aligned}$ | $\begin{aligned} & \text { P24 } \\ & \text { to } \\ & \text { P27 } \end{aligned}$ |  |
| 25 | PROG | Strobe signal (PROG) output to the I/O expander. This signal is also used as an input strobe to program the internal EPROM. |
| 26 | $V_{D D}$ | Power supply to the internal RAM and EPROM. |
| $\begin{aligned} & 27 \\ & \text { to } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { P10 } \\ & \text { to } \\ & \text { P17 } \end{aligned}$ | An 8-bit pseudo-bidirectional I/O port. All bits must be set high before the port is used for input. |
| 39 | T1 | Input for conditional branch instructions JT1 and JNT1; also serves as event input when event counter mode is selected. The event counter is incremented on the falling edge of this input signal. |
| 40 | $\mathrm{V}_{\mathrm{CC}}$ | +5-volt power supply. |

## BLOCK DIAGRAM



## FUNCTIONAL DESCRIPTION

| Block Name | Function |
| :---: | :---: |
| Clock Generation Circuitry | Using a capacitor, a crystal, or an external clock source, the on-chip clock generator produces a master clock within a frequency range of 1 -to- 6 MHz for N -version parts and 11 MHz for H version parts. The master clock frequency is divided by three to produce a state clock signal which, in turn, is divided by five to produce a cycle clock signal. The cycle clock is used for all internal operations and is available on the ALE pin. When an ENTO CLK instruction is executed, the state clock is output on the T0 pin. |
| I/O Port | Three bidirectional or quasi-bidirectional 8-bit I/O ports and three input terminals are provided for signal inputs and outputs. <br> Port 0 (Bus Port) and the lower 4 bits of Port 2 shown in the Block Diagram are used for access to external memories or I/O expanders. |
| On-chip ROM and RAM | Programs are stored in the on-chip EPROM ( 2 K bytes). Also, the contents of ROM can be used as data for some instructions. <br> The on-chip RAM (256 bytes) is used for general-purpose registers, the 16-byte stack, and scratch-pad memory (refer to RAM memory map that follows). <br> ROM can be expanded up to 4 K bytes by memory addons and by switching memory banks; RAM can be expanded an additional 256 bytes by simple addons. A standalone system and one designed for memory addons are shown following the "Functional Description." |
| Program Counter | The program counter is a 12-bit register that holds the address in program memory from which the next instruction is to be fetched and is incremented by every execution of an instruction. |
| Instruction Register | The Instruction Register is an 8-bit register that holds the next instruction to be executed. |
| Instruction Decoder | The Instruction Decoder decodes the instruction stored in the Instruction Register and generates various control signals for both internal circuits and external peripherals. |
| Arithmetic Logic Unit (ALU) | Various operations such as addition, subtraction, comparison, etc. are executed in the ALU. Operations to be executed are determined from the instruction decoding process. |
| Interval Timer/ Event Counter | The Interval Timer/Event Counter is an 8-bit register under instruction control. The interval timer mode or event counter mode can be designated by instruction execution, as well. This register is not initialized by the RESET signal. In the interval timer mode, the register counts up the frequency signal which is generated by dividing the cycle clock frequency by 32. <br> When the source frequency is 6 MHz , this enables the register to count a time interval of up to 20.48 ms with a resolution of $80 \mu \mathrm{~s}$. <br> In this mode, the register generates an interrupt vector address (Address 07), if the register overflows from (FF) ${ }_{16}$ to $(00)_{16}$. <br> Even if an oveflow occurs, the register continues to count up. This enables the register to count a longer time interval by using proper software. <br> In the event counter mode, the register counts on the falling edge of the $T_{1}$ input. <br> In this mode, the features of the register other than the counting trigger are the same as those in the interval timer mode. (Note. The $\mathrm{T}_{1}$ input pulse has a minimum width of 500-nanoseconds and, at 6 MHz , a minimum cycle time of 7.5 -microseconds.) |
| Status Register Including Stack Pointer | The Status Register is an 8-bit register which consists of four bits for flags, three bits for the Stack Pointer, and an unused bit. <br> The flag bits indicate the status of the MPU. <br> The Stack Pointer specifies an address in the stack to be used in the next subroutine call or interrupt. |



## EXPANDED SYSTEM



## MBL8749H/N

## RESIDENT DATA MEMORY MAP (RAM)



## STATUS REGISTER

The Status Register is an 8-bit register that holds the Program Status Word (PSW). The register is configured as shown. The upper four bits are used for flags to indicate the status of the MPU. When a subroutine call or an interrupt occurs, the contents of the program counter are transferred to one of the 8 register pairs of the Stack Register as determined by the lower three bits of the Status Register. The remaining bit is unused.

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CY | HC | $\mathrm{F}_{0}$ | BS | Blank <br> (Unused Bit) | $\mathrm{SP}_{2}$ | $\mathrm{SP}_{1}$ | $\mathrm{SP}_{0}$ |
| Flags |  |  |  |  | Stack Pointer |  |  |

## FLAGS

CY (Carry): When an overflow occurs in the Accumulator during an ALU operation, this bit is set to " 1 ".

HC (Half Carry): When an overflow occurs from Bit 3 to Bit 4 in the accumulator as a result of an addition, this bit is set to " 1 ".
$F_{0}$ (User Flag): This flag is instruction-controlled by the user.
BS (Bank Select): This flag is used for register-bank identification. When BS $=0$, Register Bank 0 is selected; when BS $=1$, Register Bank 1 is selected.

## STACK REGISTER

The Stack Register uses 16 bytes of memory in the on-chip RAM. The Stack Register consists of eight levels, that is, a stack level consists of two bytes as shown.


SP (Stack Pointer): In the above figure, "SP" indicates an
address in the stack pointer that will be used for the next subroutine call or interrupt. "SP" is given as an 8-bit code from the lower three bits of the status register as follows:

$$
\mathrm{SP}=00001 \underbrace{\mathrm{SP}_{2} \mathrm{SP}_{1} \mathrm{SP}_{0}}
$$

$P_{n}$ (Program Counter): In the above figure, " $\mathrm{PC}_{\mathrm{n}}$ " indicates the content of the $n^{\text {th }}$ bit in the Program Counter.

## INTERRUPT OPERATION

There are two modes for interrupt operation: external interrupts and timer/counter interrupts. A timer/counter interrupt is masked by an external input; thus, external interrupts always have priority. The basic operation for both types of interrupts are the same, except a timer/counter interrupt is initiated on overflow of the counter. Subsequent flowcharts provide operational detail for the interrupt procedures that follow.

- Upon executing the current instruction, the interrupt flag is set.
- Contents of the Status Register and Program Counter are saved in the stack.
- For an external interrupt, the Program Counter is loaded with address 003; for a timer/counter interrupt, address 007 is loaded in the PC.
- After the interrupt is serviced, a RETR instruction is executed which restores the pre-interrupt contents of the Status Register and Program Counter.
- The interrupt flag is reset.


## OPERATION FLOWCHART



FUJITSU
MBL8749H/N


## PROGRAMMING AND VERIFYING EPROM MEMORY

Internal program memory of the MBL8749 is a $2 \mathrm{~K} \times 8$-bit EPROM that can be electrically written into, and erased by using an ultraviolet (UV) light source. Pin functions for programming and verifying the EPROM are repeated here for convenience of the user.

## Pin Descriptions

| Name | Function |
| :--- | :--- |
| XTAL1, <br> XTAL2 | Clock signal (1 to 3MHz) input |
| $\overline{\text { RESET }}$ | Initialize and address-latch signal input: <br> Address data input to the data bus is internally <br> latched on the rising edge of the $\overline{\text { RESET signal. }}$ |
| T0 | Program mode is selected when this signal is <br> low and verify mode is selected when it is high. |
| EA | Program and verify enable signal input: Either <br> mode is enabled when 18 volts is applied to this <br> pin. |
| BUS <br> (D7 to <br> DO) | Address and data inputs in the program mode <br> and data output in the verify mode. |
| VDD | Power supply |
| PROG | Input pulses for programming |

## PROGRAMMING PROCEDURE

Step 1: Initialization
$V_{C C}$ and $V_{D D}=5 \mathrm{~V}$
Clock signal $=1$ to 3 MHz (Internal or external clock)
$\overline{\text { RESET }}=0 \mathrm{~V}$
$\mathrm{TO}, \mathrm{EA}=5 \mathrm{~V}$
BUS and PROG pins floating.
Step 2: $\mathrm{TO}=0 \mathrm{~V}$
Select program mode.
Step 3: $\mathrm{EA}=18 \mathrm{~V}$
Enable program or verify mode
Step 4: Input address signals.
BUS = 8 low-order bits
P22 to P20: = 3 high-order bits
Step 5: $\overline{\text { RESET }}=5 \mathrm{~V}$
Internally latch the address inputs.
Step 6: Input write data to BUS.
Step 7: $V_{D D}=21 \mathrm{~V}$
Turn on programming power supply.

Step 8: Apply 0 volts to the PROG pin and then apply a programming pulse of 18 volts for 50 ms . Again apply 0 volts to the pin and then let it float.

Step 9: $V_{D D}=5 \mathrm{~V}$, BUS floating
Turn off programming power supply ( $\mathrm{V}_{\mathrm{DD}}=21 \mathrm{~V} \rightarrow 5 \mathrm{~V}$ ), and let BUS float.

Step 10: T0 $=5 \mathrm{~V}$
Select verify mode.
Step 11: Externally read BUS data to verify data.
Step 12: TO = OV
Terminate verify mode and select program mode.
Step 13: $\overline{\text { RESET }}=0 \mathrm{~V}$
Go to the next step when data has been written. If data is not valid, repeat procedures, beginning with Step 4.
Step 14: EA $=5 \mathrm{~V}$
Disable program or verify mode.

## ERASING EPROM

Data written into the EPROM can be erased by applying ultraviolet light rays with a wavelength of 2537 angstroms. With UV light source directly above the transparent lid at a distance of 2-to-3 centimeters, the time for complete erasure is between $15-$ and- 20 minutes for most commercial lamps. The recommended amount of UV radiation is $10 \mathrm{Wsec} / \mathrm{cm}^{2}$; the luminous intensity on the package surface is designed to be approximately $12000 \mu \mathrm{~W} / \mathrm{cm}^{2}$.

If the package surface is soiled by grease, adhesives, or other light inhibitors, the erasing time will increase. Before attempting to erase data, it is recommended that surface be cleaned with alcohol or some other detergent that will not damage the package.

## INSTRUCTIONS

All instructions are one or two bytes and also execute in either one or two cycles. Addresing modes are classified as direct, expanded, indirect, immediate and implied. Single-byte and double-byte instruction formats are as follows:

## 1-Byte Instruction:



Implied Addressing Mode


MB8749H/N

## 2-Byte Instruction:

$\square$ Immediate Addressing Mode

| $A_{H}$ | $f$ | $A_{L}$ |
| :--- | :--- | :--- |

f: Instruction Operation Set
r: Register Set
OP: Operand Data
$A_{H}, A_{L}$ : Operand Address
Table 1. Instruction Set Summary

| Accumulator and Memory Instructions |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operation | Mnemonic | $\begin{gathered} \text { OP } \\ \text { code } \end{gathered}$ | Byte | Cycle | Flag |  |  |  | Notes |
|  |  |  |  |  | C | AC | F0 | F1 |  |
| Add register to A | ADD A, Rr | 6X | 1 | 1 | * | * | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A})+(\mathrm{Rr})$ |
| Add data memory to A | ADD A, @R0 | 60 | 1 | 1 | * | * | - | - | $(A) \leftarrow(A)+((R 0))$ |
|  | ADD A, @R1 | 61 | 1 | 1 | * | * | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A})+((\mathrm{R} 1))$ |
| Add immediate to A | ADD A, \#data | 03 | 2 | 2 | * | * | - | - | $(A) \leftarrow(A)+$ data |
| Add register to A with carry | ADDC A, Rr | 7X | 1 | 1 | * | * | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A})+(\mathrm{Rr})+(\mathrm{C})$ |
| Add data memory to A with carry | ADDC A, @R0 | 70 | 1 | 1 | * | * | - | - | $(A) \leftarrow(A)+((R 0))+(C)$ |
|  | ADDC A, @R1 | 71 | 1 | 1 | * | * | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A})+((\mathrm{R} 1))+(\mathrm{C})$ |
| Add immediate to A with Carry | ADDC A, \#data | 13 | 2 | 2 | * | * | - | - | $(A) \leftarrow(A)+$ data $+(C)$ |
| And register to $A$ | ANL A, Rr | 5X | 1 | 1 | - | - | - | - | $(A) \leftarrow(A) \cap(\mathrm{Rr})$ |
| And data memory to A | ANL A, @RO | 50 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A}) \cap((\mathrm{RO}))$ |
|  | ANL A, @R1 | 51 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A}) \cap((\mathrm{R} 1))$ |
| And immediate to A | ANL A, \#data | 53 | 2 | 2 | - | - | - | - | $(A) \leftarrow(A) \cap$ data |
| Clear A | CLR A | 27 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \leftarrow 0$ |
| Complement A | CPL A | 37 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \leftarrow(\overline{\mathrm{A}})$ |
| Decimal Adjust A | DA A | 57 | 1 | 1 | * | - | - | - | Note 1 |
| Decrement A | DEC A | 07 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A})-1$ |
| Increment A | INC A | 17 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A})+1$ |
| Or register to A | ORL A, Rr | 4X | 1 | 1 | - | - | - | - | $(A) \leftarrow(A) \cup(R r)$ |
| Or data memory to A | ORL A, @R0 | 40 | 1 | 1 | - | - | - | - | $(A) \leftarrow(A) \cup((R 0))$ |
|  | ORL A, @R1 | 41 | 1 | 1 | - | - | - | - | $(A) \leftarrow(A) \cup((R 1))$ |
| Or immediate to A | ORL A, \#data | 43 | 2 | 2 | - | - | - | - | $(A) \leftarrow(A) \cup$ data |
| Rotate A left | RL A | E7 | 1 | 1 | - | - | - | - | प7\|W|T|10 |
| Rotate A left through carry | RLC A | F7 | 1 | 1 | * | - | - | - | ¢ 6 - $71+17 \mid 10$ |
| Rotate A right | RR A | 77 | 1 | 1 | - | - | - | - |  |
| Rotate A right through carry | RRC A | 67 | 1 | 1 | * | - | - | - |  |
| SWAP nibles of A | SWAP A | 47 | 1 | 1 | - | - | - | - | $(A 7 \sim 4) \rightleftarrows(A 3 \sim 0)$ |
| Exclusive or register to $A$ | XRL A, Rr | DX | 1 | 1 | - | - | - | - | $(A) \leftarrow(A) \oplus(\mathrm{Rr})$ |
| Exclusive or data memory to A | XRL A, @RO | D0 | 1 | 1 | - | - | - | - | $(A) \leftarrow(A) \oplus((R 0))$ |
|  | XRL A, @R1 | D1 | 1 | 1 | - | - | - | - | $(A) \leftarrow(A) \oplus((\mathrm{R} 1))$ |
| Exclusive or immediate to A | XRL A, \#data | D3 | 2 | 2 | - | - | - | - | $(A) \leftarrow(A) \oplus$ data |

FUSITSU
Mixmuinuil MBL8749H/N

| Input/Output Instructions (Cont) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operation | Mnemonic | $\begin{gathered} \text { OP } \\ \text { code } \end{gathered}$ | Byte | Cycle | Flag |  |  |  | Notes |
|  |  |  |  |  | C | AC | F0 | F1 |  |
| And immediate to BUS | ANL BUS, \#data | 98 | 2 | 2 | - | - | - | - | $(\mathrm{BUS}) \leftarrow(\mathrm{BUS}) \cap$ data |
| P1 | ANL P1, \#data | 99 | 2 | 2 | - | - | - | - | $(\mathrm{P} 1) \leftarrow(\mathrm{P} 1) \cap$ data |
| P2 | ANL P2, \#data | 9A | 2 | 2 | - | - | - | - | $(\mathrm{P} 2) \leftarrow(\mathrm{P} 2) \cap$ data |
| And $A$ to Expander Port | ANLD $\mathrm{P}_{\mathrm{p}}, \mathrm{A}$ | 9 x | 1 | 2 | - | - | - | - | $\left(P_{p}\right) \leftarrow\left(P_{p}\right) \cap(A 3 \sim 0)$ |
| Input BUS to A | INS A, BUS | 08 | 1 | 2 | - | - | - | - | $(\mathrm{A}) \leftarrow(\mathrm{BUS})$ |
| Port 1 to A | IN A, P1 | 09 | 1 | 2 | - | - | - | - | $(\mathrm{A}) \leftarrow(\mathrm{P} 1)$ |
| Port 2 to A | IN A, P2 | OA | 1 | 2 | - | - | - | - | $(\mathrm{A}) \leftarrow(\mathrm{P} 2)$ |
| Input Expander Port to A | MOVD A, $\mathrm{P}_{\mathrm{p}}$ | OX | 1 | 2 | - | - | - | - | $\begin{aligned} & (\mathrm{A} 3 \sim 0) \leftarrow\left(\mathrm{P}_{\mathrm{p}}\right) \\ & (\mathrm{A} 7 \sim 0) \leftarrow 0 \end{aligned}$ |
| Or immediate to BUS | ORL BUS, \#data | 88 | 2 | 2 | - | - | - | - | $(\mathrm{BUS}) \leftarrow(\mathrm{BUS}) \cup$ data |
| P1 | ORL P1, \#data | 89 | 2 | 2 | - | - | - | - | $(\mathrm{P} 1) \leftarrow(\mathrm{P} 1) \cup$ data |
| P2 | ORL P2, \#data | 8A | 2 | 2 | - | - | - | - | $(\mathrm{P} 2) \leftarrow(\mathrm{P} 2) \cup$ data |
| Or A to Expander Port | ORLD $P_{p}, A$ | 8 X | 1 | 2 | - | - | - | - | $\left(P_{p}\right) \leftarrow\left(P_{p}\right) \cup(A 3 \sim 0)$ |
| Output A to BUS | OUTL BUS, A | 02 | 1 | 2 | - | - | - | - | $(\mathrm{BUS}) \leftarrow(A)$ |
| P1 | OUTL P1, A | 39 | 1 | 2 | - | - | - | - | $(\mathrm{P} 1) \leftarrow(\mathrm{A})$ |
| P2 | OUTL P2, A | 3A | 1 | 2 | - | - | - | - | $(\mathrm{P} 2) \leftarrow(\mathrm{A})$ |
| Output A to Expander Port | MOVD $P_{p}, A$ | 3 X | 1 | 2 | - | - | - | - | $\left(P_{p}\right) \leftarrow(A 3 \sim 0)$ |
| Data Move Instructions |  |  |  |  |  |  |  |  |  |
| Move register to A | MOV A, Rr | FX | 1 | 1 | - | - | - | - | $(\mathrm{A}) \leftarrow(\mathrm{Rr})$ |
| Move data memory to $A$ | MOV A, @R0 | F0 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \leftarrow((\mathrm{RO}))$ |
|  | MOV A, @R1 | F1 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \leftarrow((\mathrm{R} 1))$ |
| Move immediate to $A$ | MOV A, \#data | 23 | 2 | 2 | - | - | - | - | (A) $\leftarrow$ data |
| Move A to register | MOV Rr, A | AX | 1 | 1 | - | - | - | - | $(\mathrm{Rr}) \leftarrow(\mathrm{A})$ |
| Move A to data memory | MOV @R0, A | A0 | 1 | 1 | - | - | - | - | $((\mathrm{RO}) \mathrm{)}$ ¢ (A) |
|  | MOV @R1, A | A1 | 1 | 1 | - | - | - | - | $((\mathrm{R} 1)) \leftarrow(\mathrm{A})$ |
| Move immediate to register | MOV Rr, \#data | BX | 2 | 2 | - | - | - | - | $(\mathrm{Rr}) \leftarrow$ data |
| Move immediate to data memory | MOV @R0, \#data | B0 | 2 | 2 | - | - | - | - | $((\mathrm{RO})) \leftarrow$ data |
|  | MOV @R1, \#data | B1 | 2 | 2 | - | - | - | - | $((\mathrm{R} 1)) \leftarrow$ data |
| Move PSW to A | MOV A, PSW | C7 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \leftarrow(\mathrm{PSW})$ |
| Move A to PSW | MOV PSW, A | D7 | 1 | 1 | * | * | * | - | $(\mathrm{PSW}) \leftarrow(\mathrm{A})$ |
| Move external data memory to A | MOVX A, @R0 | 80 | 1 | 2 | - | - | - | - | $(\mathrm{A}) \leftarrow((\mathrm{RO}))$ |
|  | MOVX A, @R1 | 81 | 1 | 2 | - | - | - | - | $(\mathrm{A}) \leftarrow((\mathrm{R} 1))$ |
| Move A to external data memory | MOVX @R0, A | 90 | 1 | 2 | - | - | - | - | $((\mathrm{RO}) \mathrm{)}$ ¢ (A) |
|  | MOVX @R1, A | 91 | 1 | 2 | - | - | - | - | $((\mathrm{R} 1)) \leftarrow(\mathrm{A})$ |
| Move to A from current page | MOVP A, @A | A3 | 1 | 2 | - | - | - | - | $(\mathrm{A}) \leftarrow((\mathrm{A}))$ |
| Move to A from Page 3 | MOVP3A, @A | E3 | 1 | 2 | - | - | - | - | $(\mathrm{A}) \leftarrow((\mathrm{A})$ ) within page 3 |
| Exchange $A$ and register | XCH A, Rr | 2X | 1 | 1 | - | - | - | - | $(A) \rightleftharpoons(R r)$ |
| Exchange A and data memory | XCH A, @RO | 20 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \rightleftarrows((\mathrm{RO}))$ |
|  | XCH A, @R1 | 21 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \rightleftarrows((\mathrm{R} 1))$ |
| Exchange nibble of $A$ and data memory | XCHD A, @R0 | 30 | 1 | 1 | - | - | - | - | $(A 3 \sim 0) \rightleftarrows((R 0) 3 \sim 0)$ |
|  | XCHD A, @R1 | 31 | 1 | 1 | - | - | - | - | $(\mathrm{A} 3 \sim 0) \rightleftharpoons((\mathrm{R} 1) 3 \sim 0)$ |
| Register Instructions |  |  |  |  |  |  |  |  |  |
| Decrement register | DEC Rr | CX | 1 | 1 | - | - | - | - | $(\mathrm{Rr}) \leftarrow(\mathrm{Rr})-1$ |
| Increment register | INC Rr | 1 x | 1 | 1 | - | - | - | - | $(\mathrm{Rr}) \leftarrow(\mathrm{Rr})+1$ |
| Increment data memory | INC@RO | 10 | 1 | 1 | - | - | - | - | $((\mathrm{RO})) \leftarrow((\mathrm{RO}))+1$ |
|  | INC@R1 | 11 | 1 | 1 | - | - | - | - | $((\mathrm{R} 1)) \leftarrow((\mathrm{R} 1))+1$ |


| Timer/Counter Instructions (Cont) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operation | Mnemonic | $\begin{gathered} \text { OP } \\ \text { code } \end{gathered}$ | Byte | Cycle | Flag |  |  |  | Notes |
|  |  |  |  |  | C | AC | F0 | F1 |  |
| Disable Timer/Counter Interrupt | DIS TCNTI | 35 | 1 | 1 | - | - | - | - |  |
| Enable Timer/Counter Interrupt | EN TCNTI | 25 | 1 | 1 | - | - | - | - |  |
| Read Timer/Counter | MOV A, T | 42 | 1 | 1 | - | - | - | - | $(\mathrm{A}) \leftarrow(\mathrm{T})$ |
| Load Timer/Counter | MOV T, A | 62 | 1 | 1 | - | - | - | - | $(\mathrm{T}) \leftarrow(\mathrm{A})$ |
| Start Time | STRT T | 55 | 1 | 1 | - | - | - | - |  |
| Start Counter | STRT CNT | 45 | 1 | 1 | - | - | - | - |  |
| Stop Timer/Counter | STOP TCNT | 65 | 1 | 1 | - | - | - | - |  |
| Control Instructions |  |  |  |  |  |  |  |  |  |
| Disable external interrupt | DIS I | 15 | 1 | 1 | - | - | - | - |  |
| Enable external interrupt | EN I | 05 | 1 | 1 | - | - | - | - |  |
| Enable Clock output on T0 | ENTO CLK | 75 | 1 | 1 | - | - | - | - |  |
| No Operation | NOP | 00 | 1 | 1 | - | - | - | - |  |
| Select register bank 0 | SEL RB0 | C5 | 1 | 1 | - | - | - | - | $(\mathrm{BS}) \leftarrow 0$ |
| Select register bank 1 | SEL RB1 | D5 | 1 | 1 | - | - | - | - | (BS) $\leftarrow 1$ |
| Select memory bank 0 | SEL MB0 | E5 | 1 | 1 | - | - | - | - | $(\mathrm{MBF}) \leftarrow 0$ |
| Select memory bank 1 | SEL MB1 | F5 | 1 | 1 | - | - | - | - | $(\mathrm{MBF}) \leftarrow 1$ |

Branch and Jump Instructions

| Decrement register and test | DJNZ Rr, addr | EX | 2 | 2 | - | - | - | - | $(\mathrm{Rr}) \neq 0$ (Note 4) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Jump unconditional | JMP addr | \%4 | 2 | 2 | - | - | - | - | Unconditional Branch |
| Jump indirect | JMPP @A | B3 | 1 | 2 | - | - | - | - | Unconditional Branch (Note 5) |
| Jump on Carry = 1 | JC addr | F6 | 2 | 2 | - | - | - | - | (C) $=1$ |
| Jump on Carry = 0 | JNC addr | E6 | 2 | 2 | - | - | - | - | (C) $=0$ |
| Jump on A zero | JZ addr | C6 | 2 | 2 | - | - | - | - | $(\mathrm{A})=0$ |
| Jump on A not zero | JNZ addr | 96 | 2 | 2 | - | - | - | - | $(\mathrm{A}) \neq 0$ |
| Jump on T0 = 1 | JT0 addr | 36 | 2 | 2 | - | - | - | - | (TO) $=1$ |
| Jump on $\mathrm{TO}=0$ | JNT0 addr | 26 | 2 | 2 | - | - | - | - | (T0) $=0$ |
| Jump on T1 = 1 | JT1 addr | 56 | 2 | 2 | - | - | - | - | $(\mathrm{T} 1)=1$ |
| Jump on T1 $=0$ | JNT1 addr | 46 | 2 | 2 | - | - | - | - | (T1) $=0$ |
| Jump on F0 = 1 | JF0 addr | B6 | 2 | 2 | - | - | - | - | (F0) $=1$ |
| Jump on F1 = 1 | JF1 addr | 76 | 2 | 2 | - | - | - | - | (F1) $=1$ |
| Jump on timer flag | JTF addr | 16 | 2 | 2 | - | - | - | - | (TF) $=1$ |
| Jump on $\overline{\mathrm{NTT}}=0$ | JNI addr | 86 | 2 | 2 | - | - | - | - | $(\overline{\text { INT }})=0$ |
| Jump on accumulator bit | JBr addr | \%2 | 2 | 2 | - | - | - | - | (Ar) $=1$ |

Subroutine Instructions

| Jump to subroutine | CALL addr | $\% 4$ | 2 | 2 | - | - | - | - | (Note 6) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Return | RET | 83 | 1 | 2 | - | - | - | - | (Note 7) |
| Return and restore status | RETR | 93 | 1 | 2 | $\star$ | $\star$ | $\star$ | - | (Note 8) |

Flag Instructions

| Clear carry | CLR C | 97 | 1 | 1 | Z | - | - | - | (C) $\leftarrow 0$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Complement carry | CPL C | A7 | 1 | 1 | CP | - | - | - | (C) $\leftarrow(\bar{C})$ |
| Clear Flag 0 | CLR F0 | 85 | 1 | 1 | - | - | Z | - | (FO) $\leftarrow 0$ |
| Complement Flag 0 | CPL F0 | 95 | 1 | 1 | - | - | CP | - | $(\mathrm{FO}) \leftarrow(\overline{\mathrm{FO}})$ |
| Clear Flag 1 | CLR F1 | A5 | 1 | 1 | - | - | - | Z | $(\mathrm{F} 1) \leftarrow 0$ |
| Complement Flag 1 | CPL F1 | B5 | 1 | 1 | - | - | - | CP | $(\mathrm{F} 1) \leftarrow(\overline{\mathrm{F}} 1)$ |

Table 2. OP Codes for Register Access

| Mnemonic | Rr | Ro | R1 | R2 | R3 | R4 | R5 | R6 | R7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INC Rr |  | 18 | 19 | 1A | 1B | 1C | 1D | 1E | 1F |
| XCH A, Rr |  | 28 | 29 | 2A | 2B | 2 C | 2D | 2E | 2 F |
| ORL A, Rr |  | 48 | 49 | 4A | 4B | 4C | 4D | 4E | 4F |
| ANL A, Rr |  | 58 | 59 | 5A | 5B | 5 C | 5D | 5E | 5 F |
| ADD A, Rr |  | 68 | 69 | 6A | 6B | 6C | 6D | 6E | 6F |
| ADDC A, Rr |  | 78 | 79 | 7A | 7B | 7 C | 7D | 7E | 7F |
| MOV Rr, A |  | A8 | A9 | AA | AB | AC | AD | AE | AF |
| MOV Rr, \#data |  | B8 | B9 | BA | BB | BC | BD | BE | BF |
| DEC Rr |  | C8 | C9 | CA | CB | CC | CD | CE | CF |
| XRL A, Rr |  | D8 | D9 | DA | DB | DC | DD | DE | DF |
| DJNZ Rr, M |  | E8 | E9 | EA | EB | EC | ED | EE | EF |
| MOV A, Rr |  | F8 | F9 | FA | FB | FC | FD | FE | FF |

$\begin{array}{llllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$


Table 3. OP Codes for Expander

| Mnemonic | Pp | P4 | P3 | P2 | P1 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| MOVD A, Pp |  | OC | OD | OE | OF |
| MOVD Pp, A |  | 3 C | 3D | 3E | 3 F |
| ORLD Pp, A |  | 8C | 8D | 8E | 8 F |
| ANLD Pp, A |  | 9C | 9D | 9E | 9 F |
| $\begin{array}{llllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$ |  |  |  |  |  |
|  | Po |  |  |  |  |

Table 4. OP Codes for JMP, CALL, and JBr Instructions
JMP


First Byte
Second Byte
CALL


Second Byte
JBr


First Byte


Second Byte
$A_{L}$ : Address $A_{7}$ to $A_{0}$
$A_{H}$ : Address $\mathrm{A}_{10}, \mathrm{~A}_{9}, \mathrm{~A}_{8}$
$\mathrm{B}_{\mathrm{r}}: \mathrm{r}^{\text {th }}$ Bit on Accumulator

## Notes:

1. Refer to Tables 1 and 2 for OP Code suffixes of " $X$ "; refer to Table 3 for OP Code prefixes of "\%".
2. Flag status:

* = Set, or reset flag bit to the state it was in before instruction execution.
$z=$ Reset flag bit.
CP = Complement flag bit.

3. The accumulator value is adjusted to form BCD digits following the binary addition of BCD number.
4. DJNZ $R_{r}$ addr: $\left(R_{r}\right)-1 \rightarrow\left(R_{r}\right)$

$$
\begin{aligned}
& \text { if }\left(R_{r}\right) \neq 0 \text {, add } \rightarrow\left(\mathrm{PC}_{0} \text { to } \mathrm{PC}_{7}\right) \text {. } \\
& \text { if }\left(R_{r}\right)=0 \text {, execute next instruction. }
\end{aligned}
$$

5. JMPP @A: $\quad((A)) \rightarrow\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right)$
6. CALL addr
$\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right) \rightarrow((\mathrm{SP}))$
$(\mathrm{SP})+1 \rightarrow(\mathrm{SP})$
$\left(\mathrm{PC}_{8}\right.$ to $\left.\mathrm{PC}_{11}\right),(\mathrm{MBF}),\left(\mathrm{PSW}_{4}\right.$ to $\left.\mathrm{PSW}_{7}\right) \rightarrow((\mathrm{SP}))$
$(S P)+1 \rightarrow(S P)$
$\mathrm{A}_{\mathrm{L}} \rightarrow\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right)$
$\mathrm{A}_{\mathrm{H}} \rightarrow\left(\mathrm{PC}_{8}\right.$ to $\left.\mathrm{PC}_{10}\right)$
$\mathrm{MBF} \rightarrow\left(\mathrm{PC}_{11}\right)$
7. RET
$(\mathrm{SP})-1 \rightarrow(\mathrm{SP})$
$\left((\mathrm{SP})_{0}\right.$ to $\left.(\mathrm{SP})_{3}\right) \rightarrow(\mathrm{PC})_{8}$ to $\left.(\mathrm{PC})_{11}\right)$
$(\mathrm{SP})-1 \rightarrow(\mathrm{SP})$
$((\mathrm{SP})) \rightarrow\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right)$
8. RETR
$(S P)-1 \rightarrow(S P)$
$\left((S P)_{0}\right.$ to $(S P)_{3} \rightarrow\left(\mathrm{PC}_{8}\right.$ to $\left.\mathrm{PC}_{11}\right)$
$\left((\mathrm{SP})_{4}\right.$ to $(\mathrm{SP})_{7} \rightarrow\left(\mathrm{PSW}_{4}\right.$ to $\left.\mathrm{PSW}_{7}\right)$
$(\mathrm{SP})-1 \rightarrow(\mathrm{SP})$
$((\mathrm{SP})) \rightarrow\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right)$
$A_{L}$ : Lower 8 Bits of Address
$A_{H}: A_{8}, A_{9}, A_{10}$ of Address
MBF: Memory Bank Flag

## INSTRUCTION CODES

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | NOP |  | $\begin{gathered} \text { OUT } \\ (B S U, A) \end{gathered}$ | $\begin{gathered} \text { ADD } \\ \text { A. } \# \end{gathered}$ | $\begin{aligned} & \text { JMP } \\ & 0 \times x \times \end{aligned}$ | $\begin{gathered} \text { EN } \\ 1 \end{gathered}$ |  | $\underset{A}{\text { DEC }}$ | $\begin{aligned} & \text { INS } \\ & \text { (A, BUS) } \end{aligned}$ | $\mathbb{A}_{A_{1} P_{1}}$ | $\begin{aligned} & \text { IN } \\ & \text { A. } \mathrm{P} 2 \end{aligned}$ |  | $\begin{aligned} & \text { NOVD } \\ & \text { A. P4 } \end{aligned}$ | $\begin{aligned} & \text { MOVD } \\ & \text { A. P5 } \end{aligned}$ | $\begin{aligned} & \text { MCiD } \\ & \text { A PG } \end{aligned}$ | $\begin{aligned} & \text { MOVD } \\ & \text { A. P7 } \end{aligned}$ |
| 1 | $\begin{aligned} & \text { INC } \\ & \text { @RO } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & @ R 1 \end{aligned}$ | $\begin{aligned} & \text { JBO } \\ & \text { addr } \end{aligned}$ | $\begin{gathered} \text { ADDC } \\ \text { A. \# } \end{gathered}$ | CALL | $\begin{gathered} \text { DIS } \\ 1 \end{gathered}$ | JTF addr | $\underset{\text { A }}{\text { INC }}$ | $\begin{array}{r} \text { INC } \\ \text { RO } \end{array}$ | $\begin{gathered} \text { INC } \\ \text { R1 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R2 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R3 } \end{gathered}$ | $\begin{array}{r} \text { INC } \\ \text { R4 } \end{array}$ | $\begin{gathered} \text { INC } \\ \text { R5 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R6 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R. } 7 \end{gathered}$ |
| 2 | $\begin{gathered} \mathrm{XCH} \\ \mathrm{~A}, @ R 0 \end{gathered}$ | $\begin{gathered} \mathrm{XCH} \\ \text { A. @R1 } \end{gathered}$ |  | $\begin{gathered} \text { MOV } \\ \text { A, \# } \end{gathered}$ | $\begin{aligned} & \text { JMP } \\ & 1 \mathrm{x} x \end{aligned}$ | $\begin{gathered} \mathrm{EN} \\ \text { TCNT1 } \end{gathered}$ | JNTO addr | $\underset{A}{\text { CLR }}$ | $\begin{aligned} & \mathrm{XCH} \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 1 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 3 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 4 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \text { A, R5 } \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \text { A. R6 } \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \text { A. R7 } \end{aligned}$ |
| 3 | $\begin{aligned} & \mathrm{XCHD} \\ & \mathrm{~A} . @ \mathrm{RO} \end{aligned}$ | $\begin{aligned} & \text { XCHD } \\ & \text { A. @R1 } \end{aligned}$ | JB1 addr |  | $\begin{aligned} & \text { CALL } \\ & 1 \times x \end{aligned}$ | $\begin{gathered} \text { DIS } \\ \text { TCNT1 } \end{gathered}$ | $\begin{aligned} & \text { JTO } \\ & \text { addr } \end{aligned}$ | $\underset{A}{\mathrm{CPL}}$ |  | $\begin{aligned} & \text { OUTL } \\ & \text { P1. A } \end{aligned}$ | $\begin{aligned} & \text { OUTL } \\ & \text { P2. A } \end{aligned}$ |  | MOVD <br> P4. A | $\begin{aligned} & \text { MOVD } \\ & \text { P5. A } \end{aligned}$ | $\begin{aligned} & \text { MOVD } \\ & \text { P6. A } \end{aligned}$ | $\begin{aligned} & \text { MOVD } \\ & \text { P7. A } \end{aligned}$ |
| 4 | ORL <br> A. @R0 | $\begin{gathered} \text { ORL } \\ \text { A. @R1 } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { A. T } \end{gathered}$ | $\begin{aligned} & \text { ORL } \\ & \text { A, \# } \end{aligned}$ | $\begin{aligned} & \text { JMP } \\ & 2 \times \mathrm{x} \end{aligned}$ | $\begin{aligned} & \text { STRT } \\ & \text { CNT } \end{aligned}$ | JNT1 <br> addr | $\underset{A}{\text { SWAP }}$ | $\begin{aligned} & \text { ORL } \\ & \text { A. RO } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A. R1 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A. R2 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A. R3 } \end{aligned}$ | ORL A. R4 | ORL A. R5 | OPL A. R6 | $\begin{aligned} & \text { ORL } \\ & \text { A. R7 } \end{aligned}$ |
| 5 | $\begin{gathered} \text { ANL } \\ \text { A. @R0 } \end{gathered}$ | $\begin{gathered} \text { ANL } \\ \text { A. @R1 } \end{gathered}$ | $\begin{aligned} & \text { JB2 } \\ & \text { addr } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A. } \# \end{aligned}$ | $\begin{aligned} & \text { CALL } \\ & 2 \times x \times \end{aligned}$ | $\begin{gathered} \text { STRT } \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{JT1} \\ & \text { addr } \end{aligned}$ | $\begin{gathered} \text { DA } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R2 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A. R4 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A. R5 } \end{aligned}$ | $\begin{gathered} \text { ANL } \\ \text { A, R6 } \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & \text { A. R7 } \end{aligned}$ |
| 6 | $\begin{gathered} \text { ADD } \\ \text { A. @RO } \end{gathered}$ | $\begin{gathered} \text { ADD } \\ \text { A. @R1 } \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & \text { T. A } \end{aligned}$ |  | JMP | $\begin{aligned} & \text { STOP } \\ & \text { TCNT } \end{aligned}$ |  | $\underset{A}{\text { RRC }}$ | $\begin{aligned} & \text { ADD } \\ & \text { A. R } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A. R1 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A. R2 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R4 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A. RS } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A. R6 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A. R7 } \end{aligned}$ |
| 7 | $\begin{gathered} \text { ADDC } \\ \text { A. @RO } \end{gathered}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A, @R1 } \end{aligned}$ | $\begin{gathered} \text { JB3 } \\ \text { addr } \end{gathered}$ |  | $\begin{aligned} & \text { CALL } \\ & 3 \times x \end{aligned}$ | $\begin{aligned} & \text { ENTO } \\ & \text { CLK } \end{aligned}$ | $\begin{aligned} & \text { JF1 } \\ & \text { addr } \end{aligned}$ | $\begin{gathered} \text { RR } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A. RO } \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A. R } \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A. R2 } \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A. R3 } \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A. R4 } \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A. R5 } \end{aligned}$ | ADDC <br> A. R6 | $\begin{aligned} & \text { ADDC } \\ & \text { A. R7 } \end{aligned}$ |
| 8 | $\binom{\text { MOVX }}{\text { (A, @ RO) }}$ | $\left(\begin{array}{c} \text { MOVX } \\ (A, \text { © R1) } \end{array}\right.$ |  | RET | JMP | $\begin{gathered} \text { CLR } \\ \text { F0 } \end{gathered}$ | $\underset{\text { addr }}{\mathrm{JNI}}$ |  | $\begin{aligned} & \text { ORL } \\ & \text { (BUS, \#) } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { P1, \# } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { P2, \# } \end{aligned}$ |  | $\begin{aligned} & \text { ORLD } \\ & \text { P4. A } \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \text { P5. A } \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \text { P6. A } \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \text { P7.A } \end{aligned}$ |
| 9 | MOVX @RO. A | MOVX @R1.A | JB4 addr | RETR | $\underset{4 \times x}{C A L L}$ | $\begin{aligned} & \text { CPL } \\ & \text { F0 } \end{aligned}$ | $\begin{aligned} & \text { JNZ } \\ & \text { addr } \end{aligned}$ | $\begin{gathered} \text { CLR } \\ \text { C } \end{gathered}$ | $\begin{gathered} \text { ANL } \\ (B U S, *) \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & \text { P1, \# } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { P2.\# } \end{aligned}$ |  | $\begin{aligned} & \text { ANLD } \\ & \text { P4. A } \end{aligned}$ | $\begin{aligned} & \text { ANLD } \\ & \text { P5. A } \end{aligned}$ | ANLD P6. A | ANLD P7. A |
| A | $\begin{gathered} \text { MOV } \\ \text { @RO.A } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ @ R 1 . A \end{gathered}$ |  | $\begin{aligned} & \text { MOVP } \\ & \text { A. @A } \end{aligned}$ | $\begin{aligned} & \text { JMP } \\ & 5 \times x \end{aligned}$ | $\begin{gathered} \text { CLR } \\ \text { C } \end{gathered}$ |  | $\stackrel{\mathrm{CPL}}{\mathrm{C}^{2}}$ | $\begin{aligned} & \text { MOV } \\ & \text { RO, A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R1, A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R2. A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R3. A } \end{aligned}$ | $\begin{aligned} & \mathrm{MOV} \\ & \text { R4. A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R5. A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R6. A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R7. A } \end{aligned}$ |
| B | MOV @RO, \# | MOV @R1, \# | JB5 addr | JMPP @A | $\begin{gathered} \text { CALL } \\ 5 \times \times \end{gathered}$ | $\begin{gathered} \mathrm{CPL} \\ \mathrm{~F} 1 \end{gathered}$ | JFO addr |  | $\begin{aligned} & \text { MOV } \\ & \text { RO, } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R1. \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R2. \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R3, } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R4, \# } \end{aligned}$ | MOV R5. \# | $\begin{aligned} & \text { MOV } \\ & \text { R6. \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R7. \# } \end{aligned}$ |
| C |  |  |  |  | $\begin{aligned} & \text { JMP } \\ & 6 \times x \end{aligned}$ | $\begin{aligned} & \text { SEL } \\ & \text { RB0 } \end{aligned}$ | $\underset{\text { addr }}{\text { JZ }}$ | MOV <br> A. PSW | $\begin{aligned} & \text { DEC } \\ & \text { RO } \end{aligned}$ | $\begin{gathered} \mathrm{DEC} \\ \mathrm{R} 1 \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R2 } \end{gathered}$ | $\begin{aligned} & \text { DEC } \\ & 1, i, ~ \end{aligned}$ | $\begin{gathered} \text { DEC } \\ \text { R } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R5 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R6 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R7 } \end{gathered}$ |
| D | $\begin{gathered} \mathrm{XRL} \\ \mathrm{~A}, ~ @ R O \end{gathered}$ | $\begin{gathered} \text { XRL }, @ \text { A. } \end{gathered}$ | JB6 addr | $\begin{aligned} & \text { XRL } \\ & \text { A, \# } \end{aligned}$ | $\begin{aligned} & \text { CALL } \\ & 6 \times x \end{aligned}$ | SEL <br> RB1 | JNIBF addr | $\begin{gathered} \text { MOV } \\ \text { PSW. A } \end{gathered}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A. R2 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A. R } \end{aligned}$ | $\begin{aligned} & \mathrm{XRL} \\ & \text { A. R4 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A. RS } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R6 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A. R7 } \end{aligned}$ |
| E |  |  |  | MOVP3 A. @A | $\begin{aligned} & \text { JMP } \\ & 7 \times \mathrm{x} \end{aligned}$ | $\begin{aligned} & \text { SEL } \\ & \text { MBO } \end{aligned}$ | JNC addr | $\begin{aligned} & \text { RL } \\ & A \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { RO, M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R1,M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R2, M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R3, } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R4, M } \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R5, M } \end{aligned}$ | $\begin{gathered} \text { DJNZ } \\ \text { R6, addr } \end{gathered}$ | DJNZ R7. M |
| F | $\begin{gathered} \text { MOV } \\ \text { A.@RO } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { A, @R1 } \end{gathered}$ | $\begin{aligned} & \mathrm{JB7} \\ & \mathrm{addr} \end{aligned}$ |  | $\begin{aligned} & \text { CALL } \\ & 7 \times x \times \end{aligned}$ | $\begin{aligned} & \text { SEL } \\ & \text { MB1 } \end{aligned}$ | $\underset{\text { addr }}{\mathrm{JC}}$ | $\underset{\mathrm{A}}{\mathrm{RLC}}$ | $\begin{aligned} & \text { MOV } \\ & \text { A. RO } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A. R1 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A. R2 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A. R3 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A. R4 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A. R5 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A. R6 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A. R7 } \end{aligned}$ |

## Legend:

\#
Immediate data
$\square=1$ Byte, 1 Cycle Instruction
$\square=1$ Byte, 2 Cycle Instruction
$\square=2$ Byte, 2 Cycle Instruction

## MBL8749H/N

## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Rating | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$, <br> $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ to <br> $\mathrm{V}_{\mathrm{SS}}+7$ | V |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ to <br> $\mathrm{V}_{\mathrm{SS}}+7$ | V |
| Operating <br> Temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 1.5 | W |

Note:
Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability

RECOMMENDED OPERATING CONDITIONS

| Parameter |  | Value |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | Symbol | Min | Typ | Max | Unit |
|  | $\mathrm{V}_{\mathrm{CC}}$ <br> $\mathrm{V}_{\mathrm{DD}}$ | 4.5 | 5.0 | 5.5 | V |
|  | $\mathrm{~V}_{\mathrm{SS}}$ |  | 0 |  | V |
| Operating <br> Temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 |  | +70 | ${ }^{\circ} \mathrm{C}$ |

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

| Parameter | Symbol | Applicable Pin/Device | Value |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |  |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | All Except XTAL1, XTAL2, $\overline{\text { RESET }}$ | -0.3 | 0.8 | V |  |
|  | $\mathrm{V}_{\text {IL } 1}$ | XTAL1, XTAL2, $\overline{\text { RESET }}$ | -0.3 | 0.6 | V |  |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | All Except XTAL1, XTAL2, $\overline{\text { RESET }}$ | 2.0 | $\mathrm{V}_{\mathrm{Cc}}$ | V |  |
|  | $\mathrm{V}_{\mathrm{H}+1}$ | XTAL1, XTAL2, $\overline{\text { RESET }}$ | 3.8 | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | BUS |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
|  | $\mathrm{V}_{\mathrm{OL} 1}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\text { PSEN }}$, ALE |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
|  | $\mathrm{V}_{\text {OL2 }}$ | PROG |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ |
|  | $\mathrm{V}_{\mathrm{OL} 3}$ | All Other Outputs |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | BUS | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
|  | $\mathrm{V}_{\mathrm{OH} 1}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\text { PSEN }}$, ALE | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
|  | $\mathrm{V}_{\mathrm{OH} 2}$ | All Other Outputs | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}$ |
| Input Leakage Current | 1 LI | T1, INT |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
|  | $\mathrm{ILII}^{1}$ | P10-P17, P20-P27, EA, $\overline{\text { SS }}$ |  | -500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+0.45 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| Output Leakage Current | ILO | BUS, T0 |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+0.45 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}, \\ & \text { In High-Z state } \end{aligned}$ |
| $\mathrm{V}_{\text {DD }}$ Supply Current | $\mathrm{I}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{DD}}$ |  | 50 | mA |  |
| Total Supply Current | $\mathrm{I}_{\mathrm{CC}}+\mathrm{I}_{\mathrm{DD}}$ | $V_{C C}, V_{D D}$ |  | 170 | mA |  |

DC CHARACTERISTICS (Programming Mode)
( $T_{A}=25 \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=21 \pm 0.5 \mathrm{~V}$ or $5 \mathrm{~V} \pm 5 \%$ )

| Parameter | Symbol | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $V_{\text {DD }}$ Program Voltage High Level | $\mathrm{V}_{\text {DDH }}$ | 20.5 | 21.5 | V |
| $V_{D D}$ Program Voltage Low Level | $V_{\text {DDL }}$ | 4.75 | 5.25 |  |
| PROG Program Voltage High Level | $\mathrm{V}_{\mathrm{PH}}$ | 17.5 | 18.5 | V |
| PROG Program Voltage Low Level | $\mathrm{V}_{\mathrm{PL}}$ | - | 0.2 |  |
| EA Program/Verify Voltage High Level | $\mathrm{V}_{\text {EAH }}$ | 17.5 | 18.5 | V |
| EA Program/Verify Voltage Low Level | $V_{\text {EAL }}$ | - | 5.25 |  |
| $\mathrm{V}_{\text {DD }}$ High Voltage Supply Current | IDD | - | 30.0 | mA |
| PROG High Voltage Supply Current | IPROG | - | 16.0 |  |
| EA High Voltage Supply Current | $\mathrm{I}_{\mathrm{EA}}$ | - | 1.0 |  |

Notes:

1. High Level Voltage $\left(V_{D D H}, V_{P H}\right)$ should not be applied to $V_{D D}$ and PROG pins unless $V_{C C}=5 \mathrm{~V} \pm 5 \%$ and $E A=18 \mathrm{~V} \pm 0.5 \mathrm{~V}$.
2. $V_{D D}, P R O G$, and EA should not exceed the above specified range, including overshoot and undershoot.

## Oscillator Circuits

$\square$

## MBL8749H/N

AC CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\right)$

| Parameter | Symbol | Value (MBL8749H) |  | Value (MBL8749N) |  | Unit | Test Conditons |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |  |
| ALE Pulse Width | $\mathrm{t}_{\mathrm{LL}}$ | 150 |  | 410 |  | ns | Note 1 |
| Address Setup Time (to ALE ${ }^{\text {d }}$ | $t_{\text {AL }}$ | 70 |  | 230 |  | ns |  |
| Address Hold Time (from ALE!) | $t_{\text {LA }}$ | 50 |  | 120 |  | ns |  |
| $\overline{\mathrm{RD}}$ \& $\overline{\mathrm{WR}}$ Pulse Width | $\mathrm{t}_{\mathrm{CC} 1}$ | 480 |  | 1050 |  | ns |  |
| $\overline{\text { PSEN }}$ Pulse Width | $\mathrm{t}_{\mathrm{CC} 2}$ | 350 |  | 800 |  | ns |  |
| Data Setup Time (to $\overline{\mathrm{WR}} \mathrm{t}$ ) | $t_{\text {DW }}$ | 390 |  | 880 |  | ns |  |
| Data Hold Time (from $\overline{\mathrm{WR}} \mathrm{t}$ ) | two | 40 |  | 120 |  | ns | Note 2 |
| Data Hold Time (from $\overline{\mathrm{RD}} \uparrow, \overline{\mathrm{PSEN}} \mathrm{f}$ ) | $t_{\text {DR }}$ | 0 | 110 | 0 | 220 | ns | Note 1 |
| Data Delay Time (from $\overline{\mathrm{RD}}$ ) | $\mathrm{t}_{\mathrm{RD} 1}$ |  | 350 |  | 800 | ns |  |
| Data Delay Time (from $\overline{\text { PSEN }}$ ) | $\mathrm{t}_{\mathrm{RD} 2}$ |  | 210 |  | 550 | ns |  |
| Address Setup Time (to $\overline{\mathrm{WR}}$ !) | $t_{\text {AW }}$ | 310 |  | 680 |  | ns |  |
| Data Delay Time ( $\overline{\mathrm{RD}})$ | $t_{\text {AD1 }}$ |  | 760 |  | 1590 | ns |  |
| Data Delay Time ( $\overline{\text { PSEN }}$ ) | $t_{\text {AD2 }}$ |  | 480 |  | 1090 | ns |  |
| Address Floating Time (to $\overline{\mathrm{RD}} \downarrow, \overline{\mathrm{WR}} \downarrow$ ) | $\mathrm{t}_{\text {AFC1 }}$ | 140 |  | 290 |  | ns |  |
| Address Floating Time (to $\overline{\text { PSEN }}$ ) | $\mathrm{t}_{\mathrm{AFC} 2}$ | 10 |  | 40 |  | ns |  |
| $\overline{\mathrm{RD}}$ \& $\overline{\mathrm{WR}}$ Output Delay Time (from ALE!) | $t_{\text {LAFC1 }}$ | 200 |  | 420 |  | ns |  |
| PSEN Output Delay Time (from ALE!) | $t_{\text {LAFC2 }}$ | 60 |  | 170 |  | ns |  |
| ALE Delay Time (from $\overline{\mathrm{RD}} \uparrow, \overline{\mathrm{WR}} \mathrm{t}$, PROG $\dagger$ ) | $\mathrm{t}_{\text {CA1 }}$ | 50 |  | 120 |  | ns |  |
| ALE Delay Time (from $\overline{\text { PSEN }}$ ) | $\mathrm{t}_{\mathrm{CA} 2}$ | 320 |  | 620 |  | ns |  |
| Port Control Setup Time (to PROG!) | $\mathrm{t}_{\mathrm{CP}}$ | 100 |  | 250 |  | ns |  |
| Port Control Hold Time (from PROG!) | $t_{\text {PC }}$ | 160 |  | 460 |  | ns |  |
| Port 2 Input Data Delay Time (from PROG!) | $t_{\text {PR }}$ |  | 700 |  | 1380 | ns |  |
| Port 2 Input Data Hold Time (from PROG1) | $\mathrm{t}_{\text {PF }}$ | 0 | 140 | 0 | 250 | ns |  |
| Output Data Setup Time (to PROG ${ }^{\text {() }}$ | $t_{\text {DP }}$ | 400 |  | 850 |  | ns |  |
| Output Data Hold Time (from PROGI) | $t_{\text {PD }}$ | 90 |  | 200 |  | ns |  |
| PROG Pulse Width | $t_{\text {pp }}$ | 700 |  | 1500 |  | ns |  |
| Port 2 I/O Data Setup Time (to ALE $\dagger$ ) | $t_{\text {PL }}$ | 160 |  | 460 |  | ns |  |
| Port 2 I/O Data Hold Time (from ALEE) | $\mathrm{t}_{\text {LP }}$ | 40 |  | 80 |  | ns |  |
| Port Data Output Time (from ALEJ) | $t_{\text {PV }}$ |  | 510 |  | 850 | ns |  |
| Cycle Time | $t_{C Y}$ | 1.36 |  | 2.5 |  | $\mu \mathrm{s}$ |  |
| T0 Output Frequency | $t_{\text {OPRR }}$ | 270 |  | 500 |  | ns |  |

[^27]
## AC CHARACTERISTICS (Programming Mode)

( $T_{A}=25 \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=21 \mathrm{~V} \pm 0.5 \mathrm{~V}$ or $5 \mathrm{~V} \pm 5 \%$ )

| Parameter | Symbol | Value |  |
| :---: | :---: | :---: | :---: |
|  |  | Min | Max |
| Address setup time (before $\overline{\text { RESET }}$ ) | $\mathrm{t}_{\text {AW }}$ | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ | - |
| Address hold time (after $\overline{\text { RESET }} \uparrow$ ) | $t_{\text {WA }}$ | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ | - |
| Input data setup time (before PROG1) | $t_{\text {bw }}$ | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ | - |
| Input data hold time (after PROG!) | $t_{\text {Wo }}$ | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ | - |
| $\overline{\text { RESET }}$ hold time (after EA!) | $t_{\text {PH }}$ | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ | - |
| $\mathrm{V}_{\mathrm{DD}}$ setup time (before PROGt) | $\mathrm{t}_{\text {VDDW }}$ | $4 \cdot \mathrm{t}_{\text {CY }}$ | - |
| $\mathrm{V}_{\mathrm{DD}}$ hold time (after PROG!) | $\mathrm{t}_{\text {VDDH }}$ | 0 | - |
| Program Pulse width | $t_{\text {PW }}$ | 50 ms | 60 ms |
| T0 setup time (before $\overline{\text { RESET }} \dagger$ ) | $\mathrm{t}_{\text {TW }}$ | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ | - |
| TO hold time (after $\mathrm{V}_{\text {DD }}{ }^{\text {! }}$ ) | $\mathrm{t}_{\text {WT }}$ | $4 \cdot \mathrm{t}_{\mathrm{Cr}}$ | - |
| Data output delay time (after TOt) | $t_{\text {D }}$ | - | $4 \cdot t_{C Y}$ |
| RESET pulse width (to latch Address) | $t_{\text {ww }}$ | $4 \cdot t_{C r}$ | - |
| $V_{D D}$ and PROG rise/fall time | $t_{r}, t_{f}$ | $0.5 \mu \mathrm{~s}$ | $2.0 \mu \mathrm{~s}$ |
| MPU cycle time | $\mathrm{t}_{\mathrm{CY}}$ | $5.0 \mu \mathrm{~s}$ | - |
| RESET setup time (before EAt) | $t_{\text {RE }}$ | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ | - |
| EA setup time (before $\overline{\text { RESET }}$ ) | $t_{\text {EA }}$ | 10 ms | - |

## MBL8749H/N

TIMING DIAGRAMS
External Program Memory Operations (Instruction Fetch)


External Data Memory Read Operation


External Data Memory Write Operation


MBL8749H/N

TIMING DIAGRAMS (continued)
Four Low-Order Bits of Port 2 When Expander Port And External Program Memory Are Used


I/O Port Output Timing


## Clock Output Timing



TIMING DIAGRAM (Programming the EPROM)


MBL8749H/N
Minnumillill

## PACKAGE DIMENSIONS



## Description

The Fujitsu MBL8051AH/8031AH are single-chip 8-bit microcomputers developed as members of the MBL8051 Series. These microcomputers have powerful architecture and instruction set designed for controller applications.

The MBL8051AH contains a $4 \mathrm{~K} \times 8$-bit program memory (mask ROM), a $128 \times 8$-bit data memory (static RAM), 32 I/O lines configured as four 8 -bit parallel ports, two programmable 16 -bit timer/counters, a programmable serial I/O port, a five-source two-priority-level multi-interrupt function, and on-chip oscillator with clock circuitry. The MBL8031AH has all of these features except the on-chip memory.

The MBL8051AH/MBL8031AH can have up to $64 \mathrm{~K} \times 8$-bit program memory and up to $(64 \mathrm{~K}+128) \times 8$-bit data memory in expanded system configuration. Both microcomputers can use standard TTL compatible memories and most byte-oriented Intel MCS-80* and MCS-85* peripherals for additional memory and I/O capability.

As a control-oriented feature, the MBL8051AH/MBL8031AH have a bit handling hardware: 128 bit-locations in the data memory and the special function registers can be directly addressable by the user with bit manipulation instructions. This is very useful for control type applications.

The instruction set is designed for efficient use of the program memory space: consisting of $44 \%$ one-byte, $41 \%$ two-byte, and $15 \%$ three-byte instructions. At 12 MHz clock, over half of the instructions execute in just $1.0 \mu \mathrm{~s}$, while the longest instructions, multiply and divide, require only $4 \mu \mathrm{~s}$.

The MBL8051AH/MBL8031AH are fabricated by Fujitsu's N -channel poly-silicon-gate E/D MOS process, and packaged in a 40-pin ceramic or plastic DIP. They have TTL compatible inputs/outputs and operate with a single +5 V power supply and a 12 MHz to 3.5 MHz clock.
*Trademark of Intel Corporation
Portions Reprinted by permission of Intel Corporation ©Intel Corporation, 1984. Compilation and addtional materials Copyright © 1986 by Fujitsu Limited, Tokyo, Japan, and Fujitsu Microelectronics, Inc., Santa Clara, California, U.S.A.


## Features and

 Pin Assignment

## Logic Symbol



This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

## Block Diagram



Pin Description

| Power Supply | Symbol | Pin No. | Type | Name \& Function |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{V}_{\text {cc }}$ | 40 | - | +5 V power supply pin. |
|  | $\mathrm{V}_{\text {SS }}$ | 20 | - | Ground pin. |
| ClockI/O Ports | XTAL1 | 19 | 1 | Crystal 1: Input to the inverting amplifier that forms part of the oscillator. This pin should be connected to ground when an external oscillator is used. |
|  | XTAL2 | 18 | 0 | Crystal 2: Output of the inverting amplifier, and input to internal clock generator. This pin receives the oscillator signal when an external oscillator is used. |
|  | $\begin{aligned} & \text { P0.7/AD7- } \\ & \text { P0.0/AD0 } \end{aligned}$ | 32-39 | 1/O | Port 0: Port 0 is an 8 -bit open-drain bidirectional I/O port. As an open-drain output port, each pin can sink 8 LS-TTL loads. Port 0 pins that have is written to them float, and in that state will function as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external memory. In this application it uses strong internal pullups when emitting is. |
|  | P1.7-P1.0 | 8-1 | 1/O | Port 1: Port 1 is an 8-bit quasi-bidirectional I/O port with internal pullups. The Port 1 output buffers can sink/source 4 LS-TTL loads. Port 1 pins that have 1 s written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 1 pins that are externally being pulled low will source current ( $\mathrm{I}_{\mathrm{IL}}$, on the data sheet) because of the internal pullups. |


| Pin Description (continued) | Symbol | Pin No. | Type | Name \& Function |
| :---: | :---: | :---: | :---: | :---: |
| I/O Ports (Continued) | $\begin{aligned} & \text { P2.7/A15- } \\ & \text { P2.0/A8 } \end{aligned}$ | 28-21 | 1/O | Port 2: Port 2 is an 8-bit quasi-bidirectional I/O port with internal pullups. The Port 2 output buffers can sink/source 4 LSTTL loads. Port 2 emits the high-order address byte during accesses to external memory that use 16-bit addresses. In this application it uses the strong internal pullups when emitting is. Port 2 also receives the high-order address and control bits during program verification. |
|  | P3.7-P3.0 | 17-10 | 1/0 | Port 3: Port 3 is an 8-bit bidirectional I/O port with internal pullups. It also serves the functions of various special features of the MBL8051AH, as listed below: |
|  |  |  |  | Port Pin Alternate Function |
|  |  |  |  | P3.0 RXD (Serial input port) |
|  |  |  |  | P3.1 TXD (Serial output port) |
|  |  |  |  | P3. 2 INT0 (External interrupt 0) |
|  |  |  |  | P3.3 INT1 (External interrupt 1) |
|  |  |  |  | P3.4 T0 (Timer 0 external input) |
|  |  |  |  | P3.5 T1 (Timer 1 external input) |
|  |  |  |  | P3.6 $\quad$ WR (External data memory write strobe) |
|  |  |  |  | P3.7 RD (External data memory read strobe) |
|  |  |  |  | The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate. The Port 3 output buffers can source/sink 4 LS-TTL loads. |
| Other Ports | RST | 9 | I | Reset input: A high on this pin for two machine cycles while the oscillator is running resets the device. A small external pulldown resistor ( $\approx 8.2 \mathrm{k} \Omega$ ) from RST to $\mathrm{V}_{\text {SS }}$ permits power-on reset when a capacitor ( $\approx 10 \mathrm{pF}$ ) is also connected from RST to $\mathrm{V}_{\mathrm{CC}}$. |
|  | ALE | 30 | 0 | Address Latch Enable output pulse for latching the low byte of the address during accesses to external memory: ALE is emitted at a constant rate of $1 / 6$ of the oscillator frequency, for external timing or clocking purposes, even when there are no accesses to external memory. However, one ALE pulse is skipped during each access to external data memory. ALE can sink/source 8 LSTTL inputs. |
|  | PSEN | 29 | 0 | Program Store Enable is the read strobe to external program memory. When the device is executing out of external program memory, PSEN is activated twice each machine cycle (except that two PSEN activations are skipped during accesses to external data memory). PSEN is not activated; remaining high, during internal program memory execution. |
|  | $\overline{E A}$ | 31 | 1 | External Address Enable input: When $\overline{\mathrm{EA}}$ is held high the CPU executes out of internal program memory (unless the program counter exceeds OFFFH). Holding EA low forces the CPU to execute out of external memory regardless of the program counter value. In the MBL8031AH, EA must be externally wired low. |

## Instruction Set Description

The MBL8051AH instruction set includes 111 instructions, 49 of which are single-byte, 45 twobyte and 17 three-byte. The instruction op code format consists of a function mnemonic followed by a "destination, source" operand field. This field specifies the data type and addressing method(s) to be used.

The MBL8051AH instruction set is divided into five functional groups:

- Arithmetic Operations
- Logical Operations
- Data Transfer
- Boolean Variable Manipulation
- Program \& Machine Control (subroutine control/branch)

The following table summarizes the MBL8051 AH instruction set.

## Instruction Sot

 Summary (1)Arithmetic Operations

| Mnemonic + Operand | Operation | Op Code (Hex) | Byte/ Cycle | Program Status Word |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | c | AC | FO | RS1 | RSo | OV | - | P |
| ADD A, Rn | Add register to accumulator | 2 X | 1/1 | 1 | 1 | - | - | - | 1 |  | $\downarrow$ |
| $\overline{\text { ADD A, direct }}$ | Add direct byte to accumulator | 25 | 2/1 | 1 | 1 | - | - | - | 1 |  | 1 |
| ADD A, @Ri | Add indirect RAM to accumulator | $\begin{aligned} & 26 \\ & 27 \end{aligned}$ | 1/1 | 1 | , | - | - | $\bullet$ | 1 |  | 1 |
| ADD A, \#data | Add immediate data to accumulator | 24 | 2/1 | 1 | 1 | - | - | - | 1 |  | 1 |
| ADDC A, Rn | Add register to accumulator with carry | 3 X | 1/1 | 1 | 1 | $\bullet$ | - | - | 1 |  | 1 |
| $\overline{A D D C A} \text {, }$ direct | Add direct byte to accumulator with carry | 35 | 2/1 | 1 | 1 | - | - | - | 1 |  | 1 |
| ADDC A, @Ri | Add indirect RAM to accumulator with carry | $\begin{aligned} & 36 \\ & 37 \end{aligned}$ | 1/1 | 1 | $\downarrow$ | - | - | - | 1 |  | 1 |
| $\begin{aligned} & \text { ADDC A, } \\ & \text { \#data } \end{aligned}$ | Add immediate data to accumulator with carry | 34 | 2/1 | 1 | 1 | - | - | - | 1 |  | 1 |
| SUBB A, Rn | Subtract register from accumulator with borrow | 9 X | 1/1 | $\downarrow$ | 1 | - | - | - | $\dagger$ |  | 1 |
| SUBB A, direct | Subtract direct byte from accumulator with borrow | 95 | 2/1 | 1 | 1 | - | $\bullet$ | - | 1 |  | 1 |
| SUBB A, @Ri | Subtract indirect RAM from accumulator with borrow | $\begin{aligned} & 96 \\ & 97 \end{aligned}$ | 1/1 | 1 | 1 | - | - | - | 1 |  | 1 |
| SUBB A, \#data | Subtract immediate data from accumulator with borrow | 94 | 2/1 | 1 | 1 | - | - | - | 1 |  | 1 |
| INC A | Increment accumulator | 04 | 1/1 | $\bullet$ | - | - | - | - | $\bullet$ |  | 1 |
| INC Rn | Increment register | OX | 1/1 | - | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |  | $\bullet$ |

## Instruction Set

Summary (1)(Continued)

Arithmetic Operations (continued)

| Mnemonic + Operand | Operation | Op Code (Hex) | Byte/ Cycle | Program Status Word |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | c | AC | F0 | RS1 | Rso | OV | - | P |
| INC direct | Increment direct byte | 05 | 2/1 | $\bullet$ | - | - | - | $\bullet$ | - |  | $\bullet$ |
| INC@Ri | increment indirect RAM | $\begin{aligned} & 06 \\ & 07 \end{aligned}$ | 1/1 | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ | - |  | - |
| INC DPTR | Increment data pointer | A3 | 1/2 | - | $\bullet$ | - | - | - | - |  | $\bullet$ |
| DEC A | Decrement accumulator | 14 | 1/1 | - | $\bullet$ | - | - | - | - |  | 1 |
| DEC Rn | Decrement register | 1X | 1/1 | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |  | $\bullet$ |
| DEC direct | Decrement direct byte | 15 | 2/1 | $\bullet$ | - | - | - | - | $\bullet$ |  | - |
| $\overline{\text { DEC @Ri }}$ | Decrement indirect RAM | $\begin{aligned} & 16 \\ & 17 \end{aligned}$ | 1/1 | $\bullet$ | - | $\bullet$ | - | $\bullet$ | $\bullet$ |  | $\bullet$ |
| MUL AB | Multiply A and B | A4 | 1/4 | 1 | $\bullet$ | - | - | - | 1 |  | 1 |
| DIV AB | Divide A by B | 84 | 1/4 | 1 | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | 1 |  | 1 |
| DA A | Decimal adjust accumulator | D4 | 1/1 | 1 | - | - | - | - | - |  | 1 |

Mnemonics © Intel Corporation 1979

## Instruction Set

 Summary (2)Logical Operations

| Mnemonic + Operand | Operation | Op Code (Hex) | Byte/ Cycle | Program Status Word |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | c | AC | FO | RS1 | Rso | ov | - | P |
| ANL A, Rn | AND register to accumulator | 5X | 1/1 | $\bullet$ | - | - | $\bullet$ | - | - |  | $\downarrow$ |
| ANL A, direct | AND direct byte to accumulator | 55 | 2/1 | $\bullet$ | $\bullet$ | $\bullet$ | - | - | - |  | 1 |
| ANL A, @Ri | AND indirect RAM to accumulator | $\begin{aligned} & 56 \\ & 57 \end{aligned}$ | 1/1 | $\bullet$ | - | $\bullet$ | - | $\bullet$ | - |  | 1 |
| ANL A, \#data | AND immediate data to accumulator | 54 | 2/1 | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ | - |  | 1 |
| ANL direct, A | AND accumulator to direct byte | 52 | 2/1 | $\bullet$ | - | $\bullet$ | - | - | - |  | $\bullet$ |
| ANL direct, \#data | AND immediate data to a direct byte | 53 | 3/2 | $\bullet$ | $\bullet$ | $\bullet$ | - | - | - |  | - |
| ORL A, Rn | OR register to accumulator | 4X | 1/1 | - | - | - | - | - | - |  | $!$ |
| ORL A, direct | OR direct byte to accumulator | 45 | 2/1 | $\bullet$ | - | $\bullet$ | - | - | - |  | 1 |
| ORL A, @Ri | OR indirect RAM to accumulator | $\begin{aligned} & \hline 46 \\ & 47 \end{aligned}$ | 1/1 | $\bullet$ | $\bullet$ | - | - | - | - |  | 1 |
| ORL A, \#data | OR immediate data to accumulator | 44 | 2/1 | - | $\bullet$ | - | - | - | - |  | $\downarrow$ |
| ORL direct, A | OR accumulator to direct byte | 42 | 2/1 | $\bullet$ | - | $\bullet$ | - | $\bullet$ | - |  | - |
| ORL direct, \#data | OR immediate data to direct byte | 43 | 3/2 | $\bullet$ | - | - | - | - | - |  | - |
| XRL A, Rn | Exclusive-OR register to accumulator | 6X | 1/1 | - | - | - | - | - | - |  | 1 |
| XRL A, direct | Exclusive-OR direct byte to accumulator | 65 | 2/1 | $\bullet$ | - | - | - | - | - |  | 1 |

## FUJITSU

| Instruction Set Summary (2)(Continued) | Mnemonic <br> + Operand | Operation | Op Code (Hex) | Byte/ Cycle | Program Status Word |  |  |  |  | OV | - | P |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | c | AC | FO | RS1 | Rso |  |  |  |
| Logical Operations (continued) | XRL A, @Ri | Exclusive-OR indirect RAM to accumulator | $\begin{aligned} & 65 \\ & 67 \end{aligned}$ | 1/1 | - | - | $\bullet$ | $\bullet$ | - | $\bullet$ |  | 1 |
|  | XRL A, \#data | Exclusive-OR immediate data to accumulator | 64 | 2/1 | $\bullet$ | - | $\bullet$ | - | $\bullet$ | - |  | 1 |
|  | XRL direct, A | Exclusive-OR accumulator to direct byte | 62 | 2/1 | $\bullet$ | - | - | - | - | - |  | - |
|  | XRL direct, \#data | Exclusive-OR immediate data to direct byte | 63 | 3/2 | - | - | - | - | - | $\bullet$ |  | - |
|  | CLR A | Clear accumulator | E4 | 1/1 | - | $\bullet$ | - | - | $\bullet$ | - |  | 1 |
|  | CPL A | Complement accumulator | F4 | 1/1 | - | - | - | - | - | - |  | $\bullet$ |
|  | RL A | Rotate accumulator left | 23 | 1/1 | - | $\bullet$ | - | - | - | - |  | $\bullet$ |
|  | RLC A | Rotate accumulator left through carry | 33 | 1/1 | 1 | $\bullet$ | $\bullet$ | - | - | - |  | 1 |
|  | RR A | Rotate accumulator right | 03 | 1/1 | - | $\bullet$ | $\bullet$ | - | $\bullet$ | - |  | $\bullet$ |
|  | RRC A | Rotate accumulator right through carry | 13 | 1/1 | $\downarrow$ | $\bullet$ | $\bullet$ | $\bullet$ | - | - |  | 1 |
|  | SWAP A | Swap nibbles within accumulator | C4 | 1/1 | - | $\bullet$ | - | $\bullet$ | $\bullet$ | - |  | - |
|  | Mnemonics © Intel Corporation 1979 |  |  |  |  |  |  |  |  |  |  |  |


| Instruction Set Summary (3) | Mnemonic <br> + Operand | Operation | Op Code (Hex) | Byte/ Cycle | Program Status Word |  |  |  |  | OV | - | P |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | c | AC | FO | RS1 | RSo |  |  |  |
| Data Transfer | MOV A, Rn | Move register to accumulator | EX | 1/1 | - | - | $\bullet$ | $\bullet$ | - | $\bullet$ |  | 1 |
|  | *MOV A, direct | Move direct byte to accumulator | E5 | 2/1 | - | $\bullet$ | - | - | - | - |  | 1 |
|  | MOV A, @Ri | Move indirect RAM to accumulator | $\begin{aligned} & \text { E6 } \\ & \text { E7 } \end{aligned}$ | 1/1 | - | - | - | - | $\bullet$ | - |  | 1 |
|  | MOV A, \#data | Move immediate data to accumulator | 74 | 2/1 | $\bullet$ | - | - | $\bullet$ | - | - |  | 1 |
|  | MOV Rn, A | Move accumulator to register | FX | 1/1 | - | - | - | - | - | - |  | $\bullet$ |
|  | MOV Rn, direct | Move direct byte to register | AX | 2/2 | $\bullet$ | $\bullet$ | - | - | - | - |  | - |
|  | MOV Rn, \#data | Move immediate data to register | 7 X | 2/1 | - | - | $\bullet$ | - | - | - |  | - |
|  | MOV direct, A | Move accumulator to direct byte | F5 | 2/1 | - | - | - | - | - | - |  | - |
|  | MOV direct, Rn | Move register to to direct byte | 8X | 2/2 | - | - | - | - | - | - |  | - |
|  | MOV direct, direct | Move direct byte to direct byte | 85 | 3/2 | $\bullet$ | - | - | - | - | - |  | $\bullet$ |

* MOV A, ACC is not a valid instruction


## FUSITSU

Instruction Set Summary (3)(Continued)

Data Transfer (continued)

| Mnemonic + Operand | Operation | Op Code (Hex) | Byte/ Cycle | Program Status Word |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | C | AC | FO | RS1 | RSo | OV | - | P |
| MOV direct, @Ri | Move indirect RAM to direct byte | $\begin{aligned} & 86 \\ & 87 \end{aligned}$ | 2/2 | - | - | - | - | - | - |  | $\bullet$ |
| MOV direct, \#data | Move immediate data to direct byte | 75 | 3/2 | $\bullet$ | - | - | - | - | $\bullet$ |  | - |
| MOV @Ri, A | Move accumulator to indirect RAM | $\begin{aligned} & \text { F6 } \\ & \text { F7 } \end{aligned}$ | 1/1 | - | - | $\bullet$ | - | - | $\bullet$ |  | - |
| MOV @Ri, direct | Move direct byte to indirect RAM | $\begin{aligned} & \text { A6 } \\ & \text { A7 } \end{aligned}$ | 2/2 | - | $\bullet$ | $\bullet$ | - | - | - |  | $\bullet$ |
| MOV@Ri, \#data | Move immediate data to indirect RAM | $\begin{aligned} & 76 \\ & 77 \end{aligned}$ | 2/1 | $\bullet$ | $\bullet$ | $\bullet$ | - | - | - |  | $\bullet$ |
| MOV DPTR, \#data 16 | Load data pointer with a 16-bit constant | 90 | 3/2 | $\bullet$ | $\bullet$ | $\bullet$ | - | - | - |  | - |
| MOVC A, @A+DPTR | Move code byte relative to data pointer to accumulator | 93 | 1/2 | - | - | $\bullet$ | - | - | - |  | 1 |
| MOVC A, @A+PC | Move code byte relative to program counter to accumulator | 83 | 1/2 | - | - | $\bullet$ | - | - | - |  | 1 |
| MOVX A, @Ri | Move external RAM (8-bit addr) to accumulator | $\begin{aligned} & \text { E2 } \\ & \text { E3 } \end{aligned}$ | 1/2 | - | - | $\bullet$ | - | $\bullet$ | - |  | $\downarrow$ |
| MOVX A, @DPTR | Move external RAM (16-bit addr) to accumulator | EO | 1/2 | - | $\bullet$ | $\bullet$ | - | - | - |  | 1 |
| MOVX@Ri, A | Move accumulator to external.RAM (8-bit addr) | $\begin{aligned} & \text { F2 } \\ & \text { F3 } \end{aligned}$ | 1/2 | - | - | $\bullet$ | - | - | - |  | - |
| MOVX @DPTR, A | Move accumulator to external RAM (16bit addr) | F0 | 1/2 | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - | - |  | $\bullet$ |

Mnemonics © Intel Corporation 1979

| Instruction Set Summary (3)(Continued) | Mnemonic + Operand | Operation | $\begin{gathered} \text { Op } \\ \text { Code } \\ \text { (Hex) } \end{gathered}$ | Byte/ Cycle | Program Status Word |  |  |  |  | OV | $-\quad \mathbf{P}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | c | AC | F0 | RS1 | Rso |  |  |  |
| Data Transfer (continued) | PUSH direct | Push direct byte onto stack | CO | 2/2 | $\bullet$ | - | - | - | - | $\bullet$ |  | - |
|  | POP direct | Pop direct byte from stack | D0 | 2/2 | $\bullet$ | - | - | - | - | - |  | - |
|  | XCH A, Rn | Exchange register with accumulator | CX | 1/1 | $\bullet$ | - | - | - | - | - |  | 1 |
|  | $\overline{\mathrm{XCH}} \mathrm{A}$, direct | Exchange direct byte with accumulator | C5 | 2/1 | - | - | - | $\bullet$ | $\bullet$ | $\bullet$ |  | 1 |
|  | XCH A, @Ri | Exchange indirect RAM with accumulator | $\begin{aligned} & \mathrm{C} 6 \\ & \mathrm{C} 7 \end{aligned}$ | 1/1 | $\bullet$ | - | - | - | - | - |  | 1 |
|  | XCHD A, @Ri | Exchange low-order digit indirect RAM with A | $\begin{aligned} & \hline \text { D6 } \\ & \text { D7 } \end{aligned}$ | 1/1 | $\bullet$ | - | - | - | - | - |  | 1 |
| Boolean Variable Manipulation | CLR C | Clear carry flag | C3 | 1/1 | 1 | $\bullet$ | - | $\bullet$ | - | - |  | - |
|  | CLR bit | Clear direct bit | C2 | 2/1 | - | $\bullet$ | - | - | $\bullet$ | - |  | - |
|  | SETB C | Set carry flag | D3 | 1/1 | 1 | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |  | $\bullet$ |
|  | SETB bit | Set direct bit | D2 | 2/1 | $\bullet$ | - | - | $\bullet$ | - | - |  | - |
|  | CPL C | Complement carry flag | B3 | 1/1 | 1 | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - |  | - |
|  | $\overline{\text { CPL bit }}$ | Complement direct bit | B2 | 2/1 | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ | - |  | $\bullet$ |
|  | ANL C, bit | AND direct bit to carry flag | 82 | 2/2 | 1 | - | - | $\bullet$ | $\bullet$ | $\bullet$ |  | - |
|  | ANL C, 1 bit | AND complement of direct bit to carry flag | B0 | 2/2 | 1 | - | - | - | - | - |  | - |
|  | ORL C/bit | OR direct bit to carry flag | 72 | 2/2 | 1 | - | - | - | $\bullet$ | - |  | $\bullet$ |
|  | ORL C, 1 bit | OR complement of direct bit to carry flag | A0 | 2/2 | 1 | $\bullet$ | - | - | - | $\bullet$ |  | - |
|  | MOV C/bit | Move direct bit to carry flag | A2 | 2/1 | 1 | - | - | - | - | - |  | - |
|  | MOV bit, C | Move carry flag to direct bit | 92 | 2/2 | $\bullet$ | - | - | $\bullet$ | - | $\bullet$ |  | $\bullet$ |

Mnemonics © Intel Corporation 1979

## Instruction Set

 Summary (4)Program and Machine Control

| Mnemonic + Operand | Operation | Op Code (Hex) | Byte/ Cycle | Program Status Word |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | c | AC | FO | RS1 | RSo | ov | - | P |
| ACALL addr 11 | Absolute subroutine call | *1 | 2/2 | - | - | - | - | - | - |  | - |
| CALL addr | ACALL addr 11 or LCALL addr 16 |  |  | - | - | - | - | - | - |  | $\bullet$ |
| LCALL addr 16 | Long subroutine call | 12 | 3/2 | $\bullet$ | - | - | - | - | - |  | - |
| RET | Return from subroutine | 22 | 1/2 | $\bullet$ | - | - | - | - | - |  | $\bullet$ |
| RETI | Return from interrupt | 32 | 1/2 | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |  | $\bullet$ |
| AJMP addr 11 | Absolute jump | *1 | 2/2 | $\bullet$ | - | - | $\bullet$ | $\bullet$ | $\bullet$ |  | $\bullet$ |
| LJMP addr 16 | Long jump | 02 | 3/2 | $\bullet$ | $\bullet$ | - | - | - | $\bullet$ |  | - |
| SJMP rel | Short jump (relative addr) | 80 | 2/2 | $\bullet$ | - | - | - | - | - |  | $\bullet$ |
| JMP @A+DPTR | Jump indirect relative to data pointer | 73 | 1/2 | $\bullet$ | - | - | - | - | - |  | $\bullet$ |
| $\overline{J Z ~ r e l ~}$ | Jump if accumulator is zero | 60 | 2/2 | - | - | - | - | $\bullet$ | $\bullet$ |  | - |
| JNZ rel | Jump if accumulator is not zero | 70 | 2/2 | - | - | - | - | - | - |  | $\bullet$ |
| JC rel | Jump if carry flag is set | 40 | 2/2 | $\bullet$ | - | - | - | - | - |  | $\bullet$ |
| JNC rel | Jump if carry flag is not set | 50 | 2/2 | - | $\bullet$ | - | $\bullet$ | - | - |  | - |
| JB bit, rel | Jump if direct bit is set | 20 | 3/2 | - | - | - | - | - | - |  | - |
| JNB bit, rel | Jump if direct bit is not set | 30 | 3/2 | - | - | - | - | $\bullet$ | $\bullet$ |  | $\bullet$ |
| JBC bit, rel | Jump if direct bit is set \& clear bit | 10 | 3/2 | - | - | - | - | - | - |  | $\bullet$ |
| CJNE A, direct, rel | Compare direct to accumulator \& jump if not equal | B5 | 3/2 | 1 | $\bullet$ | - | - | - | - |  | - |
| CJNE A, \#data, rel | Compare immediate data to A \& jump if not equal | B4 | 3/2 | $\dagger$ | - | - | - | - | $\bullet$ |  | $\bullet$ |
| CJNE Rn, \#data, rel | Compare immediate data to reg. \& jump if not equal | $\begin{aligned} & \text { B6 } \\ & \text { B7 } \end{aligned}$ | 3/2 | 1 | - | - | - | - | $\bullet$ |  | - |
| CJNE @Ri, \#data, rel | Compare immediate data to indirect RAM \& jump if not equal | BX | 3/2 | 1 | - | - | - | - | $\bullet$ |  | - |
| DJNZ Rn, rel | Decrement register \& jump if not zero | DX | 2/2 | - | - | - | - | - | - |  | - |
| DJNZ direct, rel | Decrement direct byte \& jump if not zero | D5 | 3/2 | $\bullet$ | - | $\bullet$ | - | - | - |  | - |
| NOP | No operation | 00 | 1/1 | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |  | $\bullet$ |

Mnemonics © Intel Corporation 1979

## Instruction Set

Description (Continued)

## Notes on Data Addressing Modes:

| Rn | - Working register R0-R7 (See Table 1 below) |
| :--- | :--- |
| direct | -128 internal RAM locations, any I/O port, control status register |
| @Ri | - Indirect internal RAM location addressed by register R0 or R1 |
| \#data | -8 -bit constant included in instruction |
| \#data 16 | -16 -bit constant included as bytes $2 \& 3$ of instruction |
| bit | -128 software flags, any I/O pin, control status bit |

Notes on Program Addressing Modes:
addr 16 - Destination address for LCALL \& LJMP may be anywhere within the 64K program memory address space.
addr 11 - Destination address for ACALL \& AJMP will be within the same 2K page of program memory as the first byte of the following instruction.
rel - SJMP and all conditional jumps include an 8-bit offset byte. Range is +127 to -128 bytes relative to first byte of the following instruction.

Notes on Affecting Flag Setting:
1 - Affected (set or reset)

- Not affected


## Notes on Instruction Set Op Codes:

1. See Table 1 for op code $X$.
2. *The first 3 bits of op code are determined by operand (addr 11).

Table 1 Op codes of Register Access Instructions
Mnemonic

| + Operand | Rn | RO | R1 | R2 | R3 | R4 | R5 | R6 | R7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADD A, Rn |  | 28 | 29 | 2A | 2B | 2 C | 2D | 2E | 2 F |
| ADDC A, Rn |  | 38 | 39 | 3A | 3B | 3 C | 3D | 3E | 3F |
| SUBB A, Rn |  | 98 | 99 | 9A | 9B | 9 C | 9D | 9E | 9F |
| INC Rn |  | 08 | 09 | OA | OB | OC | OD | OE | OF |
| DEC Rn |  | 18 | 19 | 1A | 1B | 1C | 1D | 1E | 1F |
| ANL A, Rn |  | 58 | 59 | 5A | 5B | 5 C | 5D | 5E | 5F |
| ORL A, Rn |  | 48 | 49 | 4A | 4B | 4C | 4D | 4E | 4F |
| XRL A, Rn |  | 68 | 69 | 6A | 7B | 6C | 6D | 6E | 6F |
| MOV A, Rn |  | E8 | E9 | EA | EB | EC | ED | EE | EF |
| MOV Rn, A |  | F8 | F9 | FA | FB | FC | FD | FE | FF |
| MOV Rn, \#data |  | 78 | 79 | 7A | 7B | 7C | 7D | 7E | 7F |
| MOV Rn, direct |  | A8 | A9 | AA | AB | AC | AD | AE | AF |
| MOV direct, Rn |  | 88 | 89 | 8A | 8B | 8C | 8D | 8 E | 8F |
| XCH A, Rn |  | C8 | C9 | CA | CB | CC | CD | CE | CF |

Instruction Set Description (Continued)
Instruction Code Summary

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | NOP | JBC bit, rel | $\underset{\text { bit, rel }}{\text { JB }}$ | JNB bit, rel | $\underset{\text { rel }}{\mathrm{JC}}$ | JNC rel | $\begin{aligned} & J Z \\ & \text { rel } \end{aligned}$ | JNZ rel | $\underset{\text { rel }}{\text { SJMP }}$ | MOV DPTR,* data 16 | ORL <br> C. /bit | ANL C, /bit | $\begin{aligned} & \text { PUSH } \\ & \text { dir } \end{aligned}$ | $\begin{aligned} & \text { POP } \\ & \text { dir } \end{aligned}$ | $\begin{gathered} \text { MOVX } \\ \text { A. } \\ \text { @DPTR } \end{gathered}$ | $\begin{gathered} \text { MOVX } \\ @ \text { DPTR, } \\ \text { A } \end{gathered}$ |
| 1 | AJMP <br> (PO) | ACALL (PO) | $\begin{aligned} & \text { AJMP } \\ & \text { (P1) } \end{aligned}$ | ACALL (P1) | AJMP (P2) | ACALL (P2) | $\begin{aligned} & \text { AJMP } \\ & \text { (P3) } \end{aligned}$ | ACALL (P3) | AJMP (P4) | ACALL <br> (P4) | AJMP (P5) | ACALL (P5) | $\begin{aligned} & \text { AJMP } \\ & \text { (P6) } \end{aligned}$ | ACALL (P6) | AJMP <br> (P7) | ACALL (P7) |
| 2 | LJMP addr16 | LCALL addr16 | RET | RETI | ORL dir, A | ANL dir, A | $\underset{\operatorname{dir} . \mathrm{A}}{\underset{\operatorname{dir}}{ }}$ | ORL C, bit | $\begin{aligned} & \text { ANL } \\ & \text { C, bit } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { bit, C } \end{aligned}$ | MOV C, bit | $\begin{gathered} \text { CPL } \\ \text { bit } \end{gathered}$ | $\begin{gathered} \text { CLR } \\ \text { bit } \end{gathered}$ | $\underset{\text { bit }}{\text { SETB }}$ | MOVX <br> A, @RO | $\begin{aligned} & \text { MOVX } \\ & @ R 0, ~ A \end{aligned}$ |
| 3 | $\begin{gathered} \text { RR } \\ \text { A } \end{gathered}$ | $\begin{gathered} \text { RRC } \\ \text { A } \end{gathered}$ | $\begin{gathered} \text { RL } \\ A \end{gathered}$ | $\underset{\text { A }}{\text { RLC }}$ | ORL dir, \#data | ANL dir, \#data | XRL dir, \#data | $\begin{aligned} & \mathrm{JMP} \\ & A+D P T R \end{aligned}$ | MOVCA, <br> @A+PC | MOVCA, (1)+DPTR | $\begin{aligned} & \text { INC } \\ & \text { DPTR } \end{aligned}$ | $\begin{gathered} \text { CPL } \\ \mathrm{C} \end{gathered}$ | $\begin{gathered} \text { CLR } \\ \text { C } \end{gathered}$ | $\begin{gathered} \text { SETB } \\ \text { C } \end{gathered}$ | $\begin{aligned} & \text { MOVX } \\ & \text { A, @R1 } \end{aligned}$ | $\begin{gathered} \text { MOVX } \\ @ R 1, A \end{gathered}$ |
| 4 | $\underset{A}{\text { INC }}$ | $\underset{\mathrm{A}}{\mathrm{DEC}}$ | $\begin{gathered} \text { ADD } \\ \text { A, \#data } \end{gathered}$ | ADDC <br> A, \#data | ORL <br> A, \#data | $\begin{gathered} \text { ANL } \\ \text { A, \#data } \end{gathered}$ | $\begin{gathered} \text { XRL } \\ \text { A, \#data } \end{gathered}$ | MOV <br> A, \#data | $\begin{aligned} & \text { DIV } \\ & \text { AB } \end{aligned}$ | $\begin{aligned} & \text { SUBB } \\ & \text { A, \#data } \end{aligned}$ | $\underset{A B}{M U L}$ | CJNE, A, *data, rel | $\underset{A}{\text { SWAP }}$ | $\underset{A}{\mathrm{DA}}$ | $\underset{A}{C L R}$ | $\begin{gathered} \text { CPL } \\ \hline \end{gathered}$ |
| 5 | INC dir | DEC dir | ADD A, dir | ADDC A, dir | ORL <br> A, dir | ANL A, dir | $\begin{aligned} & \text { XRL } \\ & \text { A, dir } \end{aligned}$ | MOV dir, \#data | MOV dir, dir | SUBB <br> A, dir |  | CJNE A, dir, rel | $\mathrm{XCH}$ A, dir | DJNZ dir, rel | MOV A, dir | $\begin{gathered} \text { MOV } \\ \text { dir, A } \end{gathered}$ |
| 6 | $\begin{aligned} & \text { INC } \\ & @ R O \end{aligned}$ | DEC @RO | $\begin{gathered} \text { ADD } \\ \text { A, @RO } \end{gathered}$ | ADDC <br> A, @RO | $\begin{aligned} & \text { ORL } \\ & \text { A. @RO } \end{aligned}$ | $\begin{gathered} \text { ANL } \\ \text { A, @RO } \end{gathered}$ | $\begin{gathered} \text { XRL } \\ \text { A, @RO } \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & \text { @RO, } \\ & \text { \#data } \\ & \hline \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { dir, @RO } \end{gathered}$ | $\begin{aligned} & \text { SUBB } \\ & \text { A, @R } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { @RO, dir } \end{gathered}$ | CJNE @RO. \#data, rel | $\begin{gathered} \mathrm{XCH} \\ \mathrm{~A}, @ \mathrm{RO} \end{gathered}$ | $\begin{aligned} & \text { XCHD } \\ & \text { A, @RO } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { A. @RO } \end{gathered}$ | $\begin{gathered} \mathrm{MOV} \\ @ \mathrm{RO}, \mathrm{~A} \end{gathered}$ |
| 7 | INC @R1 | DEC <br> @R1 | $\begin{gathered} \text { ADD } \\ \text { A, @R1 } \end{gathered}$ | ADDC <br> A, @R1 | $\begin{aligned} & \text { ORL } \\ & \text { A, @R1 } \end{aligned}$ | $\begin{gathered} \text { ANL } \\ \text { A, @R1 } \end{gathered}$ | $\begin{gathered} \text { XRL } \\ \text { A, @R1 } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ @ R 1, \\ \text { \# data } \\ \hline \end{gathered}$ | $\left[\begin{array}{c} \text { MOV } \\ \text { dir, @R1 } \end{array}\right.$ | $\begin{aligned} & \text { SUBB } \\ & \text { A, @R1 } \end{aligned}$ | MOV @R1, dir | CJNE @R1, \&data, rel | $\begin{gathered} \mathrm{XCH} \\ \mathrm{~A}, @ \mathrm{R} \end{gathered}$ | $\begin{aligned} & \text { XCHD } \\ & \text { A, @R1 } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { A, @R1 } \end{gathered}$ | $\begin{gathered} \mathrm{MOV} \\ @ \mathrm{R1}, \mathrm{~A} \end{gathered}$ |
| 8 | $\begin{aligned} & \text { INC } \\ & \text { RO } \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { RO } \end{aligned}$ | ADD | ADDC A, RO | $\begin{aligned} & \mathrm{ORL} \\ & \mathrm{~A}, \mathrm{RO} \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, RO } \end{aligned}$ | $\left\|\begin{array}{c} \text { MOV } \\ \text { RO, \#data } \end{array}\right\|$ | MOV dir, RO | SUBB A, RO | MOV Ro, dir |  | $\begin{aligned} & \mathrm{XCH} \\ & \text { A, RO } \end{aligned}$ | DJNZ RO, rel | $\begin{aligned} & \text { MOV } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { RO, A } \end{aligned}$ |
| 9 | $\begin{aligned} & \text { INC } \\ & \text { R1 } \end{aligned}$ | $\begin{gathered} \text { DEC } \\ \text { R1 } \end{gathered}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R1 } \end{aligned}$ | ADDC A, R1 | $\begin{aligned} & \text { ORL } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R1 } \end{aligned}$ | $\left\|\begin{array}{c} \mathrm{MOV} \\ \mathrm{R} 1, \text { \#data } \end{array}\right\|$ | $\begin{gathered} \text { MOV } \\ \text { dir } \end{gathered}$ | SUBB A, R1 | MOV R1, dir | CJNE R1, \#data, rel | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 1 \end{aligned}$ | DJNZ <br> R1, rel | $\begin{aligned} & \text { MOV } \\ & \text { A, R1 } \end{aligned}$ | MOV R1, A |
| A | $\begin{aligned} & \text { INC } \\ & \text { R2 } \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { R2 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & A \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A R } \end{aligned}$ | $\begin{aligned} & \mathrm{ORL} \\ & \mathrm{~A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R2 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R2 } \end{aligned}$ | $\left\|\begin{array}{c} \mathrm{MOV} \\ \text { R2, \#data } \end{array}\right\|$ | MOV dir, R2 | SUBB A, R2 | MOV R2, dir |  | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R2, rel } \end{aligned}$ | MOV A, R2 | MOV R2, A |
| B | $\begin{aligned} & \text { INC } \\ & \text { R3 } \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { R3 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R3 } \end{aligned}$ | ADDC A, R3 | $\begin{aligned} & \text { ORL } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R3 } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { R3, \#data } \end{gathered}$ | MOV dir, R3 | $\begin{aligned} & \text { SUBB } \\ & \text { A, R3 } \end{aligned}$ | MOV R3, dir |  | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 3 \end{aligned}$ | DJNZ R3, rel | MOV <br> A, R3 | $\begin{aligned} & \text { MOV } \\ & \text { R3, A } \end{aligned}$ |
| C | $\begin{gathered} \text { INC } \\ \text { R4 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R4 } \end{gathered}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R4 } \end{aligned}$ | ADDC A, R4 | $\begin{aligned} & \text { ORL } \\ & \text { A, R4 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R4 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R4 } \end{aligned}$ | $\left\|\begin{array}{c} \mathrm{MOV} \\ \text { R4, \#data } \end{array}\right\|$ | MOV dir, R4 | SUBB A, R4 | MOV R4, dir | CJNE R4, \#data, rel | $\begin{aligned} & \mathrm{XCH} \\ & \text { A, R4 } \end{aligned}$ | DJNZ <br> R4, rel | $\begin{aligned} & \text { MOV } \\ & \text { A, R4 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R4, A } \end{aligned}$ |
| D | $\begin{gathered} \text { INC } \\ \text { R5 } \end{gathered}$ | $\begin{aligned} & \text { DEC } \\ & \text { R5 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R5 } \end{aligned}$ | ADDC A, R5 | $\begin{aligned} & \text { ORL } \\ & \text { A, R5 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R5 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R5 } \end{aligned}$ | MOV R5, \#data | $\begin{gathered} \text { MOV } \\ \text { dir, R5 } \end{gathered}$ | $\begin{aligned} & \text { SUBB } \\ & \text { A, R5 } \end{aligned}$ | MOV R5, dir |  | $\begin{gathered} \mathrm{XCH} \\ \text { A, R5 } \end{gathered}$ | DJNZ R5, rel | $\begin{aligned} & \text { MOV } \\ & \text { A, R5 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R5, A } \end{aligned}$ |
| E | $\begin{aligned} & \text { INC } \\ & \text { R6 } \end{aligned}$ | $\begin{gathered} \text { DEC } \\ \text { R6 } \end{gathered}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R6 } \end{aligned}$ | ADDC A, R6 | $\begin{aligned} & \text { ORL } \\ & \text { A, R6 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R6 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R6 } \end{aligned}$ | $\left\|\begin{array}{c} \text { MOV } \\ \text { R6, \#data } \end{array}\right\|$ | MOV dir, R6 | SUBB A, R6 | MOV R6, dir | $\left\lvert\, \begin{gathered} \text { CJNE } \\ \text { R6, \#data, } \\ \text { rel } \end{gathered}\right.$ | $\begin{aligned} & \mathrm{XCH} \\ & \text { A, R6 } \end{aligned}$ | DJNZ <br> R6, rel | $\begin{aligned} & \text { MOV } \\ & \text { A, R6 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R6, A } \end{aligned}$ |
| F | $\begin{gathered} \text { INC } \\ \text { R7 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R7 } \end{gathered}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R7 } \end{aligned}$ | ADDC $\mathrm{A}, \mathrm{R} 7$ | $\begin{aligned} & \text { ORL } \\ & \mathrm{A}, \mathrm{R} 7 \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R7 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R7 } \end{aligned}$ | MOV R7, \#data | $\begin{gathered} \text { MOV } \\ \text { dir, R7 } \end{gathered}$ | $\begin{aligned} & \text { SUBB } \\ & \text { A, R7 } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { R7, dir } \\ \hline \end{gathered}$ | $\left\lvert\, \begin{gathered} \text { CJNE } \\ \text { R7, \#data, } \\ \text { rel } \end{gathered}\right.$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 7 \end{aligned}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R7, rel } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, R7 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R7, A } \end{aligned}$ |



| Absolute Maximum Ratings | Parameter | Symbol | Rating |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. |  |
|  | Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ | $\mathrm{V}_{\mathrm{SS}}+7.0$ | V |
|  | Input Voltage | $\mathrm{V}_{\text {IN }}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ | $\mathrm{V}_{\mathrm{SS}}+7.0$ | V |
|  | Output Voltage | $\mathrm{V}_{\text {OUT }}$ | $\mathrm{V}_{\text {SS }}-0.3$ | $\mathrm{V}_{\text {SS }}+7.0$ | V |
|  | Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ |  | 1.5 | W |
|  | Operating Ambient Temperature | $\mathrm{T}_{\text {A }}$ | 0 | +70 | ${ }^{\circ} \mathrm{C}$ |
|  | Storage Temperature | Tstg | -55 | +150 | ${ }^{\circ} \mathrm{C}$ |

Note: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

Recommended Operating Conditions

|  | Value |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5.0 | 5.5 | V |
|  | $\mathrm{~V}_{\mathrm{SS}}$ |  | 0 |  | V |
| Operating Ambient Temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 |  | +70 | ${ }^{\circ} \mathrm{C}$ |

## DC Characteristics

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

| Parameter | Pin | Symbol | Value |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. |  |  |
| Input High Voltage | All Inputs except RST and XTAL2 | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
|  | RST and XTAL2 | $\mathrm{V}_{\mathrm{HH} 1}$ | 2.5 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V | XTAL1 $=0 \mathrm{~V}$ |
| Input Low Voltage |  | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {Ss }}-0.3$ | 0.8 | V |  |
| Power-Down Voltage | VPD | $V_{P D}$ | 4.5 | 5.5 | V | $\mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}$ |
| Output High Voltage | Ports 1, 2, 3 | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-80 \mu \mathrm{~A}$ |
|  | Port 0, ALE, $\overline{\text { PSEN }}$ | $\mathrm{V}_{\mathrm{OH} 1}$ | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| Output Low Voltage | Ports 1, 2, 3 | $\mathrm{V}_{\mathrm{OL}}$ |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
|  | Port 0, ALE, PSEN | $\mathrm{V}_{\mathrm{OL} 1}$ |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ |
| Low Level Input Leakage Current | Ports 1, 2, 3 | ILL |  | -500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=0.45 \mathrm{~V}$ |
|  | XTAL2 | 1 IL2 |  | -3.2 | mA | $\begin{aligned} & \text { XTAL1 }=0 \mathrm{~V}, \\ & \text { VIN }=0.45 \mathrm{~V} \end{aligned}$ |
| High Level Input Leakage Current | RST | $\mathrm{l}_{\mathrm{H}} \mathrm{H}$ |  | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}<\mathrm{V}_{\mathrm{CC}}-1.5 \mathrm{~V}$ |
| Input Leakage Current | Port 0, $\overline{\mathrm{EA}}$ | lı | -10 | +10 | $\mu \mathrm{A}$ | $0.45 \mathrm{~V}<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {CC }}$ |
| Power Supply Current | $\mathrm{V}_{\text {cc }}$ | $I_{\text {cc }}$ |  | 125 | mA | $\begin{aligned} & \text { All outputs open; } \\ & \overline{E A}=V_{C C} \end{aligned}$ |
| Power-Down Current | VPD | $I_{\text {PD }}$ |  | 10 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{PD}}=5 \mathrm{~V} \end{aligned}$ |
| Capacitance of I/O Buffer |  | $\mathrm{ClO}_{10}$ |  | 10 | pF | $\mathrm{f}_{\mathrm{C}}=1.0 \mathrm{MHz}$, |

Note: Capacitive loading on Ports 0 and 2 may cause spurious noise pulses to be superimposed on the VOLs of ALE and Ports 1 and 3. The noise is due to external bus capacitance discharging into the Port 0 and Port 2 pins when these pins make 1 -to- 0 transitions during bus operations. In the worst cases, the noise pulse on the ALE line may exceed 0.8 V . In such cases it may be desirable to qualify ALE with a Schmitt Trigger, or use an address latch with a Schmitt Trigger STROBE input.

## AC Characteristics

( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$; $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ for Port 0, ALE and PSEN outputs, $C_{L}=80 \mathrm{pF}$ for all other outputs)

External Program Memory Charactēristics

| Parameter | Symbol | $\mathrm{fc}=12 \mathrm{MHz}$ |  | Unit | $\mathrm{fc}=3.5 \mathrm{MHz}$ to 12 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  | Min. | Max. |  |
| Oscillation Period | TCLCL | 83 |  | ns | 1/fc (Max.) | 1/fc (Min.) |  |
| Cycle Time | TCY | 1.0 |  | $\mu \mathrm{S}$ | $\begin{aligned} & \text { 12TCLCL } \\ & \text { (Min.) } \end{aligned}$ | $\begin{aligned} & \text { 12TCLCL } \\ & \text { (Max.) } \end{aligned}$ |  |
| ALE Pulse Width | TLHLL | 127 |  | ns | 2TCLCL-40 |  | ns |
| Address Setup Time (To ALE) | TAVLL | 43 |  | ns | TCLCL-40 |  | ns |
| Address Hold Time (After ALE) | TLLAX | 48 |  | ns | TCLCL-35 |  | ns |
| Instr In Delay Time (After ALE) | TLLIV |  | 233 | ns |  | 4TCLCL-100 |  |
| ALE to PSEN | TLLPL | 58 |  | ns | TCLCL-25 |  | ns |
| $\overline{\text { PSEN Pulse Width }}$ | TPLPH | 215 |  | ns | 3TCLCL-35 |  | ns |
| Instr In Delay Time (After PSEN) | TPLIV |  | 125 | ns |  | 3TCLCL-12 |  |
| Input Instr Hold Time (After PSEN) | TPXIX | 0 |  | ns | 0 |  | ns |
| Input Instr Float Time (After PSEN) | TPXIZ |  | 63 | ns |  | TCLCL-20 | ns |
| Address Delay Time (After PSEN) | TPXAV | 75 |  | ns | TCLCL-8 |  | ns |
| Input Instr Delay Time (After Address) | TAVIV |  | 302 | ns |  | 5TCLCL-11 | ns |
| Address Float Time (To PSEN) | TPLAZ |  | 20 | ns |  | 20 | ns |

External Data Memory Characteristics

| $\overline{\mathrm{RD}}$ Pulse Width | TRLRH | 400 |  | ns | 6TCLCL-100 |  | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { WR Pulse Width }}$ | TWLWH | 400 |  | ns | 6TCLCL-100 |  | ns |
| Address Hold Time (After ALE) | TLLAX | 48 |  | ns | TCLCL-35 |  | ns |
| Data In Delay Time (After RD) | TRLDV |  | 252 | ns |  | 5TCLCL-165 | ns |
| Data Hold Time (After RD) | TRHDX | 0 |  | ns | 0 |  | ns |
| Data Float Time (After RD) | TRHDZ |  | 97 | ns |  | 2TCLCL-70 | ns |
| Data In Delay Time (After ALE) | TLLDV |  | 517 | ns |  | 8TCLCL-150 | ns |
| Data In Delay Time (After Address) | TAVDV |  | 585 | ns |  | 9TCLCL-165 | ns |
| ALE To $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ | TLLWL | 200 | 300 | ns | 3TCLCL-50 | $3 \mathrm{TCLCL}+50$ | ns |
| Address Setup Time (To RD or WR) | TAVWL | 203 |  | ns | 4TCLCL-130 |  | ns |
| $\overline{\overline{R D}}$ or $\overline{\text { WR }}$ High To ALE High | TWHLH | 43 | 123 | ns | TCLCL-40 | TCLCL+40 | ns |

## AC Characteristics

$\left(V_{C C}=5 \mathrm{~V} \pm 10 \%, V_{S S}=\right.$ $0 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=$ 100 pF for Port 0, ALE and PSEN outputs, $C_{L}=80 \mathrm{pF}$ for all other outputs)

External Data Memory Characteristics (Continued)

| Parameter | Symbol | $f \mathrm{f}=12 \mathrm{MHz}$ |  | Unit | fc $=3.5 \mathrm{MHz}$ to 12 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  | Min. | Max. |  |
| Data Valid <br> To WR Transition | TQVWX | 23 |  | ns | TCLCL-60 |  | ns |
| Data Setup Time (Before WR) | TQVWH | 433 |  | ns | 7TCLCL-150 |  | ns |
| Data Hold Time (After WR) | TWHQX | 33 |  | ns | TCLCL-50 |  | ns |
| Address Float Time (After RD) | TRLAZ |  | 20 | ns |  | 20 | ns |

## External Program Memory Read Cycle Timing Diagram

## External Data Memory Read Cycle Timing Diagram

## External Data

Memory Write Cycle Timing Diagram

ALE

PSEN
$\overline{W R}$

PORT 0

PORT 2


## External Clock Drive

| External Clock Drive Characteristics | Parameter | Symbol | $\mathrm{fc}=3.5 \mathrm{MHz}$ to 12 MHz |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Unit |
|  | Oscillation Frequency | 1/TCLCL | 3.5 | 12 | ns |
|  | High Time | TCHCX | 20 |  | ns |
|  | Low Time | TCLCX | 20 |  | ns |
|  | Rise Time | TCLCH |  | 20 | ns |
|  | Fall Time | TCHCL |  | 20 | ns |

External Clock Timing Diagram


## AC Testing Input/Output and Float Waveforms



AC inputs during testing are driven at 2.4 V for a logic " 1 " and 0.45 V for a logic " 0 ". Timing measurements are made at 2.0 V for a logic " 1 " and 0.8 V for a logic " 0 ". For timing purposes, the float state is defined as the point at which a PO pin sinks 3.2 mA or sources $400 \mu \mathrm{~A}$ at the voltage test levels.

## Oscillator Configurations



Serial Port TimingShift Register Mode
(Test Conditions: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ )

| Symbol | Parameter | $\mathrm{f}_{\mathrm{C}}=12 \mathrm{MHz}$ |  | $\mathrm{f}_{\mathrm{c}}=3.5 \mathrm{MHz}$ to 12 MHz |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| TXLXL | Serial Port Clock Cycle Time | 1.0 |  | 12TCLCL |  | $\mu \mathrm{s}$ |
| TQVXH | Output Data Setup to Clock Rising Edge | 700 |  | 10TCLCL-133 |  | ns |
| TXHQX | Output Data Hold After Clock Rising Edge | 50 |  | 2TCLCL-117 |  | ns |
| TXHDX | Input Data Hold After Clock Rising Edge | 0 |  | 0 |  | ns |
| TXHDV | Clock Rising Edge to Input Data Valid |  | 700 |  | 10TCLCL-133 | ns |

## Serial Port Timing Diagram



## Package Dimensions

Dimensions in inches (millimeters)

## 40-Lead Ceramic

## (Metal Seal)

Dual In-Line Package
(Case No.: DIP-40C-A01)

© 1986 FUJITSU LIMITED D40006S-1C

40-Lead Plastic
Dual In-Line Package
(Case No.: DIP-40P-M01)

© 1985 FUJITSU LIMITED D40005S-1C

## Description

The Fujitsu MBL80C49/MBL80C39 is a totally self-contained 8 -bit single-chip microcomputer fabricated witt, silicon-gate CMOS technology. The MBL80C49 has an 8 -bit MPU, a $2 \mathrm{~K} \times 8$ ROM program memory, and $128 \times 8$ RAM data memory, 27 I/O ports, an 8 -bit timer/counter, and clock generator on chip. The MBL80C39 is identical to the MBL80C49 except without internal program memory. It can be used with external memory for system prototyping and preproduction systems.

The design is optimized for low cost and high performance applications because the MBL80C49/MBL80C39 is fabricated on a single silicon chip and can be used for applications that require additional expansion of ROM, RAM, I/O ports, and so on.

This microcomputer permits external program operation and single-step operation. Low power applications are possible by using the standby-mode feature. The software is upward compatible with the MBL8049/MBL8039 and Intel 8049/8039.

The MBL80C49/MBL80C39 uses a single power supply of +5 V . It is packaged in a 40-pin DIP or a 48 -pin Flat Package. Operation of $N$ version ( 6 MHz ) is guaranteed over the range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, and H version ( 11 MHz ), $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$.

## Features

- 8-bit Single-chip

Microcomputer

- 12-bit Addressing
- 98 Instructions (232 Instruction Codes): 70\% of Instructions are Single Byte.
- $2.5 \mu$ Instruction Cycle for N version, $1.36 \mu \mathrm{~s}$ instruction cycie for H version: Ali instructions are 1 or 2 cycle.
- ALU Functions: Addition, Decimal Adjust Addition, and Logic Operations
- 2K x 8-bit ROM
- $128 \times 8$-bit RAM
- 8-level Stack
- 8 pairs of Working Registers
- 8-bit Interval Timer/Event Counter
- 27 I/O Lines: Two 8-bit I/O Ports, One Data Bus, Two Test Pins and One Interrupt
- Easily Expandable Memory and I/O
- On-chip Clock Generator (or External Clock)
- Single-level Interrupt Capability
- Single-step Operation Capability
- External Program Mode Capability
- Low-power Standby Mode Capability by HALT and STOP Instructions
- Single +5V Power Supply
- Silicon-gate CMOS Technology
- Standard 40-pin DIP (Ceramic/Plastic)
- Standard 48-pin Flat Package
- Compatible with Intel 8049/8039 and Fujitsu MBL8049/MBL8039



## Pin Assignment

|  | 40-PIN DIP |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| T0 $\square$ | 1 | $\bigcirc$ | 40 | $\square \mathrm{v}_{\mathrm{cc}}$ |
| XTAL1 | 2 |  | 39 | $\square \mathrm{T} 1$ |
| XTAL2 | 3 |  | 38 | $\square \mathrm{P} 27$ |
| RESET | 4 |  | 37 | $\square \mathrm{P} 26$ |
| $\overline{\text { SS }}$ | 5 |  | 36 | $\square \mathrm{P} 25$ |
| INT | 6 |  | 35 | $\square \mathrm{P} 24$ |
| EA | 7 |  | 34 | $\square \mathrm{P} 17$ |
| ED | 8 |  | 33 | ص P16 |
| PSEN | 9 |  | 32 | $\square \mathrm{P} 15$ |
| WR | 10 | TOP | 31 | $\square \mathrm{P} 14$ |
| ALE | 11 |  | 30 | $\square \mathrm{P} 13$ |
| DBO | 12 |  | 29 | $\square \mathrm{P} 12$ |
| DB1 | 13 |  | 28 | $\square \mathrm{P} 11$ |
| DB2 | 14 |  | 27 | $\square \mathrm{P} 10$ |
| DB3 | 15 |  | 26 | $\square \overline{\mathbf{S P}}$ |
| DB4 | 16 |  | 25 | $\square \mathrm{PROG}$ |
| DB5 | 17 |  | 24 | $\square \mathrm{P} 23$ |
| DB6 | 18 |  | 23 | $\square \mathrm{P} 22$ |
| DB7 | 19 |  | 22 | $\square \mathrm{P} 21$ |
| Vss | 20 |  | 21 | $\square \mathrm{P} 20$ |



## Logic Symbol



Block Diagram


Pin Description

| Symbol | Name | Pin No.* | Type | Function |
| :--- | :--- | :--- | :--- | :--- |
| $V_{\text {CC }}$ | Power Supply | $40(18)$ | - | Main power supply; +5V during operation. |
| $V_{\text {SS }}$ | Ground | $20(42)$ | - | Circuit GND potential. |
| XTAL1 | Crystal 1 | $2(21)$ | 1 | One side of crystal input for internal oscillator. <br> Also input for external source. (Non-TTL <br> level input) |
| XTAL2 | Crystal 2 | $3(22)$ | 1 | Other side of crystal input. |
| PROG | Program | $25(48)$ | O | Output strobe for MBL82C43 I/O expander. |
| P10-P17 | Port 1** | $27-34$ <br> $(3-6$, <br> $8-11)$ | I/O | 8-bit quasi-bidirectional port. |
| P20-P23 | Port 2** | $21-24$ <br> $(44-47)$ | I/O | 8-bit quasi-bidirectional port. <br> P20-P23 contain the four high order program <br> counter bits during an external program <br> memory fetch and serve as a 4-bit I/O expander <br> bus for MBL82C43. |
| P24-P27 | 35-38 <br> $(13-16)$ |  |  |  |


| Pin Description (Continued) | Symbol | Name | Pin No.* | Type | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | DB0-DB7 | Data Bus | $\begin{aligned} & 12-19 \\ & (33-37, \\ & 39-41) \end{aligned}$ | 1/O | True bidirectional port which can be written or read synchronously using the RD, WR strobes. The port can also be statically latched. <br> Contains the 8 low order program counter bits during an external program memory fetch, and receives the addressed instruction under the control of PSEN. Also contains the address and data during an external RAM data store instruction under control of ALE, $\overline{\text { RD, and }} \overline{\mathrm{WR}}$. |
|  | T0 | Test 0 | 1 (20) | 1/O | Input pin testable using the conditional transfer instructions JTO and JNTO. TO can be designated as a clock output using ENTO CLK instruction. |
|  | T1 | Test 1 | 39 (17) | 1 | Input pin testable uising the JT1, and JNT1 instructions. Can be designated as the event counter input using the STRT CNT instruction. |
|  | $\overline{\text { INT }}$ | Interrupt Request | 6 (25) | 1 | Interrupt input. Initiates an interrupt if interrupt is enabled. Interrupt is disabled after a reset. (Active low). <br> Interrupt must remain low for at least 3 machine cycles to ensure proper operation. |
|  | RESET | Reset** | 4 (23) | 1 | Input used to initialize the processor. (Active low) (Non-TTL level input) |
|  | $\overline{\mathrm{RD}}$ | Read | 8 (27) | 0 | Output strobe activated during a BUS read. Can be used to enable data onto the BUS from an external device. (Active low) |
|  |  |  |  |  | Used as a read strobe to external data memory. |
|  | $\overline{\text { WR }}$ | Write | 10 (30) | 0 | Output strobe during a BUS write. (Active low) Used as write strobe to external data memory. |
|  | ALE | Address Latch Enable | 11 (31) | 0 | This signal occurs once during each cycle and is useful as a clock output. <br> The negative edge of ALE strobes address into external data and program memory. |
|  | $\overline{\text { PSEN }}$ | Program Store Enable | 9 (29) | 0 | This output occurs only during a fetch to external program memory. (Active low) |
|  | $\overline{\text { SS }}$ | Single Step** | 5 (24) | 1 | Single step input can be used in conjunction with ALE to "single step" the processor through each instruction. (Active low) |
|  | EA | External <br> Access | 7 (26) | 0 | External Access forces all program memory fetches to reference external memory. Useful for emulation and debug, and essential for testing and program verification. (Active high) |
|  | $\overline{\text { SR }}$ | Standby <br> Release** | 26 (2) | 1 | This is the control input for standby operation. A low level on this input releases the MPU from the standby mode. |
|  | Note: **Brac | keted value is ap e pins are internaly | ied to Flat Pa y pulled up. | ckage. |  |

## Functional Description

## Architecture

The following sections break the MBL80C49 into function blocks and describe each in detail. See Block Diagram.

## Arithmetic Section

The arithmetic section of the processor contains the basic data manipulation functions of the MBL80C49 and can be divided into the following blocks:

- Arithmetic Logic Unit (ALU)
- Accumulator
- Carry Flag
- Instruction Decoder

In a typical operation, data stored in the accumulator is combined in the ALU with data from another source on the internal bus (such as a register or I/O port). The result is stored in the accumulator or another register.

The following is a detailed description of the function of each block.

## Instruction Decoder

The operation code (op code) portion of each program instruction is stored in the Instruction Decoder and converted to outputs which control the function of each of the blocks of the Arithmetic Section. These lines control the source of data and the destination register as well as the function performed in the ALU.

## Arithmetic Logic Unit

The ALU accepts 8-bit data words from one or two sources and generates an 8-bit result under control of the Instruction Decoder. The ALU can perform the following functions:

- Add With or Without Carry
- AND, OR, Exclusive OR
- Increment/Decrement
- Bit Complement
- Rotate Left, Right
- Swap Nibbles
- BCD Decimal Adjust

If the operation performed by the ALU results in a value represented by more than 8 bits (overflow of most significant bit), a Carry Flag is set in the Program Status Word.

## Accumulator

The accumulator is the single most important data register in the processor, being one of the sources of input to the ALU and often the destination of the result of operations performed in the ALU. Data to and from I/O ports and memory also normally passes through the accumulator.

## Program Memory

Resident program memory consists of 2048 words eight bits wide which are addressed by the program counter. In the MBL80C49 the memory is ROM which is mask programmable at the factory. The MBL80C39 has no internal program memory and is used with external memory devices. Program code is completely interchangeable among the various versions. To access the upper 2K of program memory in the MBL80C49, a select memory bank and a JUMP or CALL instruction must be executed to cross the 2 K boundary.

There are three Program
Memory locations of special importance as shown in Fig. 1.

Location 0
Activating the Reset line of the processor causes the first instruction to be fetched from location 0.

## Location 3

Activating the Interrupt input line of the processor (if interrupt is enabled) causes a jump to subroutine at location 3.

## Location 7

A timer/counter interrupt resulting from timer/counter overflow (if enabled) causes a jump to subroutine at location 7.

Therefore, the first instruction to be executed after initialization is stored in location 0 , the first word of an external interrupt service subroutine is stored in location 2, and the first word of a timer/counter service routine is stored in location 7. Program memory can be used to store constants as well as program instructions. Instructions such as MOVP and MOVP3 allow easy access to data "look-up" tables.

## Data Memory

Resident data memory is organized as 128 words 8 -bits wide in the MBL80C49/MBL80C39. All locations are indirectly addressable through either of two RAM Pointer Registers which reside at address 0 and 1 of the register array. In addition, as shown in Fig. 2, the first 8 locations (0-7) of the array are designated as working registers and are directly addressable by several instructions. Since these registers are more easily addressed, they are usually used to store frequently accessed intermediate results. The DJNZ instruction makes very efficient use of the working registers as program loop counters by allowing the programmer to decrement and test the register in a single instruction.

By executing a Register Bank
Switch instruction (SEL RB) RAM location 24-31 are designated as the working registers in place of locations 0-7 and are then directly addressable. This second bank of working registers may be used as an extension of the first bank or reserved for use during interrupt service subroutines allowing the registers of Bank 0 used in the main program to be instantly "saved" by a Bank Switch. Note that if this second bank is not used, locations 24-31 are still addressable as general purpose RAM. Since the two RAM pointer Registers RO and R1 are a part of the working register array, bank switching

Functional Description
(Continued)
effectively creates two more pointer registers (R0/ and R1/) which can be used with R0 and R1 to easily access up to four separate working areas in RAM at one time. RAM locations $(8-23)$ also serve a dual role in that they contain the program counter stack. These locations are addressed by the Stack Pointer during subroutine calls as well as by RAM Pointer Registers R0 and R1. If the level of subroutine nesting is less than 8 , all stack registers are not required and can be used as general purpose RAM locations. Each level of subroutine nesting not used provides the user with two additional RAM locations.

## Input/Output

The MBL80C49 has 27 lines which can be used for input or output functions. These lines are grouped as 3 ports of 8 lines each which serve as either inputs, outputs of bidirectional ports and 3 "test" inputs which can alter program sequences when tested by conditional jump instructions.

## Ports 1 and 2

Ports 1 and 2 are each 8 bits wide and have identical characteristics. Data written to these ports is statically latched and remains unchanged until rewritten. As input ports these lines are non-latching, i.e., inputs must be present until
read by an input instruction. Inputs are fully TTL compatible and outputs will drive one standard TTL load.

The lines of ports 1 and 2 are called quasi-bidirectional because of special output circuit structure which allows each line to serve as an input, and output, or both even though outputs are statically latched. Each line is continuously pulled up to $V_{C C}$ through a resistive device of relatively high impedance.

This pullup is sufficient to provide the source current for a TTL high level yet can be pulled low by a standard TTL gate thus allowing the same pin to be used for both input and output. To provide fast switching times in a " 0 " to " 1 " transition to relatively low impedance device is switched in momentarily ( $\approx 1 / 5$ of a machine cycle) whenever a " 1 " is written to the line. When a " 0 " is written to the line a low impedance device overcomes the light pullup and provides TTL current sinking capability. Since the pulldown transistor is a low impedance device a " 1 " must first be written to any line which is to be used as an input. Reset initializes all lines to the high impedance " 1 " state.

It is important to note that the ORL and ANL are read/write operations. When executed,
the $\mu \mathrm{C}$ "reads" the port, modifies the data according to the instruction, then "writes" the data back to the port. The "writing" (essentially an OUTL instruction) enables the low impedance pullup momentarily again even if the data was unchanged from a " 1 ". This specifially applies to the configurations that have inputs and outputs mixed together on the same port.

## Bus

Bus is also an 8-bit port which is a true bidirectional port with associated input and output strobes. If the bidirectional feature is not needed, Bus can serve as either a statically latched output port or nonlatched input port. Input and output lines on this port cannot be mixed however.
As a static port, data is written and latched using the OUTL instruction and inputted using the INS instruction. The INS and OUTL instructions generate pulses on the corresponding $\overline{R D}$ and $\overline{W R}$ output strobe lines; however, in the static port mode they are generally not used. As a bidirectional port the MOVX instructions are used to read and write the port. A write to the port generates a pulse on the WR output line and output data is valid at the trailing edge of WR. A read of the port generates a pulse on the $\overline{R D}$

Figure 1. Program Memory Map


Figure 2. Data Memory Map


## Functional Description <br> (Continued)

output line and input data must be valid at the trailing edge of RD. When not being written or read, the BUS lines are in a high impedance state.

## Test and INT Inputs

Three pins serve as inputs and are testable with the conditional jump instruction. These are T0, T1, and INT. These pins allow inputs to cause program branches without the necessity to load an input port into the accumulator. The T0, T1, and INT pins have other possible functions as well. See the pin description in page 3.

## Program Counter and Stack

The Program Counter is an independent counter while the Program Counter Stack is implemented using pairs of registers in the Data Memory Array. Only 11 bits of the Program Counter are used to address the 2048 words of on-board program memory of the MBL80C49, while the most significant bits can be used for external Program Memory fetches. See Fig. 3. The Program Counter is initialized to zero by activating the Reset line.

An interrupt or CALL to a subroutine causes the contents of the program counter to be stored in one of the 8 register pairs of the Program Counter Stack as shown in Fig. 7. The pair to be used is determined by a 3-bit Stack Pointer which is part of the Program Status Word (PSW).

Data RAM locations 8-23 are available as stack registers and are used to store the Program Counter and 4 bits of PSW as shown in Fig. 7. The Stack Pointer when initialized to 000 points to RAM locations 8 and 9. The first subroutine jump or interrupt results in the program counter contents being transfered to locations 8 and 9 of the RAM array. The stack pointer is then incremented by one to point to locations 10 and 11 in anticipation of another CALL. Nesting of subroutines within subroutines can continue up to 8 times without oveflowing the stack.

If overflow does occur the deepest address stored (locations 8 and 9 ) will be overwritten and lost since the stack pointer overflows from 111 to 000 . It also underflows from 000 to 111.

The end of a subroutine, which is signalled by a return instruction (RET or RETR), causes the Stack Pointer to be decremented and the contents of the resulting register pair to be transferred to the Program Counter.

## Program Status Word

An 8-bit status word which can be loaded to and from the accumulator is called the

Program Status Word (PSW).
Fig. 5 shows the information available in the word. The Program Status Word is actually a collection of flip flops throughout the machine which can be read or written as a whole. The ability to write to PSW allows for easy restoration of machine status after a power down sequence.

The upper four bits of PSW are stored in the Program Counter Stack with every call to subroutine or interrupt vector and are optionally restored upon return with the RETR instruction. The RET return instruction does not update PSW.

Figure 3. Program Counter


Figure 4. Program Counter Stack


Functional Description
(Continued)

The PSW bit definitions are as follows:
Bits 0-2: Stack Pointer bits ( $\mathrm{S}_{0}$, $\mathrm{S}_{1}, \mathrm{~S}_{2}$ )
Bit 3: Not used ("1" level when read)
Bit 4: Working Register Bank Switch Bit (BS)
$0=$ Bank 0
1 = Bank 1

Bit 5: Flag 0 bit (FO) user controlled flag which can be complemented or cleared, and tested with the conditional jump instruction JFO.
Bit 6: Auxiliary Carry (AC) carry bit generated by an ADD instruction and used by the decimal adjust instruction DAA.
Bit 7: Carry (CY) carry flag which indicates that the previous operation has resulted in overflow of the accumulator.

## Conditional Branch Logic

The conditional branch logic within the processor enables several conditions internal and external to the processor to be tested by the users program. By using the conditional jump instruction the conditions that are listed in Table 2 can effect a change in the sequence of the program execution.

## Timer/Counter

The MBL80C49 contains a counter to aid the user in counting external events and generating accurate time delays without placing a burden on the processor for these functions. In both modes the counter operation is the same, the only difference being the source of the input to the counter. The timer/event counter is shown in Fig. 6.

## Counter

The 8 -bit binary counter is presettable and readable with two MOV instructions which transfer the contents of the accumulator to the counter and vice versa. The counter content may be affected by Reset and should be initialized by software. The counter is stopped by a Reset or STOP TCNT instruction and remains stopped until started as a timer by a START T instruction or as an event counter by a START

CNT instruction. Once started the counter will increment to this maximum count (FF) and overflow to zero continuing its count until stopped by a STOP TCNT instruction or Reset.

The increment from maximum count to zero (overflow) results in the setting of an overflow flag flip-flop and in the generation of an interrupt request. The state of the overflow flag is testable with the conditional jump instruction JTF. The flag is reset by executing a JTF or by Reset. The interrupt request is stored in a latch and then ORed with the external interrupt input INT. The timer interrupt may be enabled or disabled independently of external interrupt by the EN TCNTI and DISTCNTI instructions. If enabled, the counter overflow will cause a subroutine call to location 7 where the timer or counter service routine may be stored.

If timer and external interrupts occur simultaneously, the external source will be recognized and the Call will be to location 3 . Since the timer interrupt is latched it will remain pending until the external device is serviced and immediately be recognized upon return from the service routine. The pending timer interrupt is reset by the Call to location 7 or may be removed by executing a DIS TCNTI instruction.

## As An Event Counter

Execution of a START CNT instruction connects the T1 input pin to the counter input and enables the counter. The T1 input is sampled at the beginning of state 3 or in state time 4. Subsequent high to low transistions on T1 will cause the counter to increment. T1 must be held low for at least 1 machine cycle to insure it won't be missed. The maximum

Figure 5. Program Status Word (PSW)


Figure 6. Timer/Event Counter


Table 2

| Device Testable | Jump Conditions <br> (Jump On) |  |
| :--- | :--- | :--- |
| Accumulator | All zeros | Not all zeros |
| Accumulator Bit | - | 1 |
| Carry Flag | - | 1 |
| User Flags (FO, F1) | - | 1 |
| Timer Overflow Flag | 0 | 1 |
| Test Inputs (T0, T1) | 0 | 1 |
| Interrupt Input (INT) | 0 | - |

## Functional Description

(Continued)
rate at which the counter may be incremented is once per three instruction cycles (every $5.7 \mu \mathrm{sec}$ when using an 8 MHz crystal)-there is no minimum frequency. $T 1$ input must remain stable for at least $1 / 5$ machine cycle after each transition.

## As A Timer

Execution of a START T instruction connects an internal clock to the counter input and enables the counter. The internal clock is derived by passing the basic machine cycle clock through a $\div 32$ prescaler. The prescaler is reset during the START T instruction. The resulting clock increments the counter every 32 machine cycle. Various delays from 1 to 256 counts can be obtained by presetting the counter and detecting overflow. Times longer than 256 counts may be achieved by accumulating multiple overflows in a register under software control. For time resolution less than 1 count, an external clock can be applied to the T1 input and the counter operated in the event counter mode. ALE divided by 3 or more can serve as this external

- clock. Very small delays or "fine tuning" of larger delays can be easily accomplished by software delay loops.
Clock and Timing Circuits
Timing generation for the MBL80C49 is completely selfcontained with the exception of a frequency reference which can be XTAL, ceramic resonator, or external clock source. The clock and Timing circuitry can be divided into the following functional blocks.


## Oscillator

The on-board oscillator is a high gain parallel resonant circuit with a frequency range of 1 to 11 MHz . The X1 external pin is the input to the amplifier stage while X2 is the output. A crystal or ceramic resonator connected between X1 and X2 provides the feedback and phase shift required for oscillatin. If an accurate frequency reference is not required, ceramic resonator may be used in place of the crystal.

For accurate clocking a crystal should be used. An externally generated clock may also be applied to $\mathrm{X} 1-\mathrm{X} 2$ as the frequency source.

## State Counter

The output of the oscillator is divided by 3 in the State counter to create a clock which defines the state times of the machine (CLK). CLK can be made available on the external pin TO by executing an ENTO CLK instruction. The output of CLK on TO is disabled by Reset of the processor.

## Cycle Counter

CLK is then divided by 5 in the Cycle Counter to provide a clock which defines a machine cycle consisting of 5 machine states as shown in Fig. 7. This clock is called Address Latch Enable (ALE) because of its
function in MBL80C49 with external memory. It is provided continously on the ALE output pin.

## Reset

The reset input provides a means for initialization for the processor. This Schmitt-trigger input has an internal pull-up device, which in combination with an external $1 \mu \mathrm{fd}$ capacitor, provides an internal reset pulse of sufficient length to guarantee all circuitry is reset, as shown in Fig. 8. If the reset pulse is generated externally the RESET pin must be held low for at least 10 milliseconds after the power supply is within tolerance. Only 5 machine cycles ( $6.8 \mu \mathrm{~s}$ @ 11 MHz ) are required if power is already on and the oscillator has stablized. ALE and PSEN (if $E A=1$ ) are active while in Reset.

Figure 7. Timing Generation and Cycle Timing
diagram of clock utilities

instruction crcle


## Functional Description (Continued)

Reset performs the following functions:

1) Sets program counter to zero.
2) Sets stack pointer to zero.
3) Selects register bank 0 .
4) Selects memory bank 0.
5) Sets BUS to high
impedance state (except when $\mathrm{EA}=5 \mathrm{~V}$ ).
6) Sets Ports 1 and 2 to input mode.
7) Disables interrupts (timer and external).
8) Stops timer.
9) Clears timer flag.
10) Clears FO and F1.
11) Disables clock output from TO.

## Interrupt

An interrupt sequence is initiated by applying a low ("0") level input to the INT pin. Interrupt is level triggered and active low to allow "WIRE ORing" of several interrupt sources at the input pin. Fig. 9 shows the interrupt logic of the MBL80C49. The interrupt line is sampled every instruction cycle and when detected causes a "call to subroutine" at location 3 in program memory as soon as all cycles of the current instruction are complete. On 2-cycle instructions, the interrupt line is sampled on the 2nd cycle
only. INT must be held low for at least 3 machine cycles to ensure proper interrupt operations. As in any CALL to subroutine, the Program Counter and Program Status word are saved in the stack. For a description of this operation see the previous section, Program Counter and Stack. Program Memory location 3 usually contains an unconditional jump to an interrupt service subroutine elsewhere in program memory. The end of an interrupt service subroutine is signalled by the execution of a Return and Restore Status instruction RETR. The interrupt system is single level in that once an interrupt is detected all further interrupt requests are ignored until execution of an RETR reenables the interrupt input logic. This occurs at the beginning of the second cycle of the RETR instruction. This sequence holds true also for an internal interrupt generated by timer overflow. If an internal timer/counter generated interrupt and an external interrupt are detected at the same time, the external source will be recognized. See the following Timer/Counter section for a description of timer interrupt. If needed, a
second external interrupt can be created by enabling the timer/counter interrupt, loading FFH in the Counter (one less than terminal count), and enabling the event counter mode. $A$ " 1 " to " 0 " transition on the T1 input will then cause an interrupt vector to location 7.

## Interrupt Timing

The interrupt input may be enabled or disabled under Program Control using the ENI and DIS I instructions. Interrupts are disabled by Reset and remain so until enabled by the users program. An interrupt request must be removed before the RETR instruction is executed upon return from the service routine

Figure 8. Reset Circuit
external reset


Figure 9. Interrupt Logic


FUJITSU

## Functional Description

 (Continued)otherwise the processor will re-enter the service routine immediately. Many peripheral devices prevent this situation by resetting their interrıft request line whenever the processor accesses (Reads or Writes) the peripherals data buffer register. If the interrupting device does not require access by the processor, one output line of the MBL80C49 may be designated as an "interrupt acknowledge" which is activated by the service subroutine to reset the interrupt request. The INT pin may also be tested using the conditional jump instruction JNI. This instruction may be used to detect the presence of a pending interrupt before interrupts are enabled. If interrupt is left disabled $\overline{\mathrm{INT}}$ may be used as another test input like T0 and T1.

## Single-Step

This feature, as pictured in Fig. 10, provides the user with a debug capability in that the processor can be stepped through the program one instruction at a time. When stopped, the address of the next instruction to be fetched is available concurrently on BUS and the lower half of Port 2. The user can therefore follow the program through each of the instruction steps. A timing diagram, showing the interaction between output ALE and input SS, is shown. The BUS buffer contents are lost during single step; however, a latch may be added to reestablish the lost I/O capability if needed. Data is valid at the leading edge of ALE.

## Timing

The MBL80C49 operates in a single-step mode as follows:

1) The processor is requested to stop by applying a low level on SS.
2) The processor responds by stopping during the address fetch portion of the next instruction. If a double cycle instruction is in progress when the single step command is received, both cycles will be completed before stopping. 3) The processor acknowledges
it has entered the stopped state by raising ALE high. In this state (which can be maintained indefinitely) the address of the next instruction to be fetched is present on BUS and the lower half of port 2 .
3) $S S$ is then raised high to bring the processor out of the stopped mode allowing it to fetch the next instruction. The exit from stop is indicated by the processor bringing ALE low.
4) To stop the processor at the next instruction SS must be brought low again soon after ALE goes low. If SS is left high the processor remains in a "Run" mode.
A diagram for implementing the single-step function of the MBL80C49 is shown in Fig. 10. A D-type flip-flop with preset and clear is used to generate SS. In the run mode, SS is held high by keeping the flip-flop preset (preset has precedence over the clear input). To enter single step, preset is removed allowing ALE to bring SS low via the clear input. ALE should be buffered since the clear input of an SN7474 is the equivalent of 3 TTL loads. The processor is now in the stopped state. The next
instruction is initiated by clocking a " 1 " into the flip-flop. This "1" will not appear on SS unless ALE is high, removing clear from the flip-flop. In response to SS going high the processor begins an instruction fetch which brings ALE Iow, resetting SS through the clear input and causing the processor to again enter the stopped state.

## External Access Mode

Normally the first 2K words of program memory are automatically fetched from internal ROM. The EA input pin however allows the user to effectively disable internal program memory by forcing all program memory fetches to reference external memory. The following chapter explains how access to external program memory is accomplished.

The External Access mode is very useful in system test and debug because it allows the user to disable his internal applications program and substitute an external program of his choice-a diagnostic routine for instance. In addition, the section on Test

Figure 10. Single Step Operation


## Functional Description

(Continued)
and Debug explains how internal program memory can be read externally, independent of the processor. A "1" level on EA initiates the external access mode. For proper operation, Reset should be applied while the EA input is changed.
Low Power Standby Operation
MBL80C49 has two low-power standby modes, HALT and STOP modes. Both are initiated by software and are released by hardware.

## Halt Mode

This mode is initiated by the HALT instruction (OP code: 01H). When the HALT instruction is executed, the device enters the HALT mode and stops executing instructions after that.

During the HALT mode all the other internal circuits stop, except the on-chip oscillator. The oscillator idles and the clock is inhibited to the internal circuits. This time the program counter holds the address next to the HALT instruction, and the internal RAM, internal registers, and flags keep the states executing the HALT instruction. The input/output ports hold the states shown below:

| Type | Pin | State |
| :---: | :---: | :---: |
| Input | XTAL1, <br> XTAL2, <br> EA, <br> RESET, <br> INT, SR | Active |
|  | T1, $\overline{\text { SS }}$ | Inactive |
|  | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, PSEN, ALE | High Level |
| Output | $\begin{aligned} & \hline \text { P10-17, } \\ & \text { P20-27, } \\ & \text { DB0-DB7, } \\ & \text { TO, PROG } \end{aligned}$ | High Impedance |

In this mode, the supply voltage, $\mathrm{V}_{\mathrm{CC}}$ can be lowered to 3.5 V , and the supply current reduced to 2 mA for N version and 4 mA for H version.

## A negative pulse at one of

 RESET, INT, and SR inputs releases the device from the HALT mode. When a pulse is applied, the device restarts executing instructions from an address shown below, depending on the applied pin. Before applying the negative pulse, the supply voltage must be returned to the value ( +5 V $\pm 10 \%$ ) to guarantee normal operation.
## $\overline{\text { RESET }}$ (Low level sense):

A negative pulse with minimum 12 instruction cycle width is needed for the standby release. The low level releases the device from the standby state, and initializes the device to the reset state. Approximately 8200 instruction cycles later $\overline{\text { RESET }}$ returns to high and the device restarts the execution from address \#0.

## INT (Low level sense):

The low level releases the device from the standby state, and after a dummy cycle of approximately 5 instruction cycles the device restarts the execution from an address next to the HALT instruction executed. If the external interrupt is enabled, the control jumps at address \#3 after executing the instruction next to the HALT instruction executed. The INT pulse must be kept low until the interrupt is accepted.

## $\overline{\mathbf{S R}}$ (Low leyel sense):

A negative pulse with minimum 2 instruction cycle is required for the standby release. The low level releases the device from the standby state, and after a dummy cycle of approximately 5 instruction cycles the device restarts the execution from an address next to the HALT instruction executed.

## Stop Mode

This mode is initiated by the STOP instruction (OP code: C1H). When the STOP instruction is executed, the device enters the STOP mode and stops executing instructions after that.

During the STOP mode all the internal circuits stop. Only the internal RAM is retained. The internal registers and flags are not kept. The input/output ports hold the states shown below:

| Type | Pin | State |
| :---: | :---: | :---: |
| Input | EA, <br> RESET <br> INT, SR | Active |
|  | XTAL1, <br> XTAL2, <br> T1, SS | Inactive |
| Output | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, PSEN, ALE | High Level |
|  | $\begin{aligned} & \text { P10-17, } \\ & \text { P20-27, } \\ & \text { DB0-DB7, } \\ & \text { TO, PROG } \end{aligned}$ | High Impedance |

In this mode, the supply voltage, $\mathrm{V}_{\mathrm{cc}}$ can be lowered to 2.0 V , and the supply current reduced to $50 \mu \mathrm{~A}$.

A negative pulse at RESET input releases the device from the STOP mode. When a RESET pulse is applied, the device restarts executing instructions from an address $\# 0$. Before applying the negative pulse,the supply voltage must be returned to the value ( $+5 \mathrm{~V} \pm 10 \%$ ) to guarantee normal operation.

## RESET (Low level sense):

A negative pulse with minimum 12 instruction cycle width is needed for the standby release. The low level releases the device from the standby state, and initializes the device to the reset state. Approximately 8200 instruction cycles after RESET returns to high, the device restarts the execution from address \#0.

## Instruction Set Summary $\dagger$

## Accumulator and Memory Instructions

| Operation | Mnemonic | OP <br> Code | Byte | Cycle | Flag |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | $F_{0}$ | $F_{1}$ |  |
| Add Register to $A$ <br> Add data memory to $A$ | ADD A, Rr | 6 x | 1 | 1 | * |  | - | - | (A) $-(\mathrm{A})+(\mathrm{Rr})$ |
|  | ADD A, @RO | 60 | 1 | 1 | * |  | - | - | $(\mathrm{A})-(\mathrm{A})+((\mathrm{RO}))$ |
|  | ADD A, @R1 | 61 | 1 | 1 | * |  | - | - | $(\mathrm{A})-(\mathrm{A})+((\mathrm{R} 1))$ |
| Add immediate to A | ADD A, \#data | 03 | 2 | 2 | * | , | - | - | (A) $-(A)+$ data |
| Add register to A with carry Add data memory to $A$ with carry | ADDC A, Rr | 7 X | 1 | 1 | * | * | - | - | (A) $-(\mathrm{A})+(\mathrm{Rr})+(\mathrm{C})$ |
|  | ADDC A, @RO | 70 | 1 | 1 |  |  | - | - | $(A)-(A)+((R 0))+(C)$ |
|  | ADDC A, @R1 | 71 | 1 | 1 |  |  | - | - | $(A)-(A)+((R 1))+(C)$ |
| Add immediate to A with carry | ADDC A, \#data | 13 | 2 | 2 |  |  | - | - | $(\mathrm{A})-(\mathrm{A})+$ data $+(\mathrm{C})$ |
| And register to $\mathbf{A}$ And data memory to $A$ | ANL A, Rr | 5X | 1 | 1 | - | - | - | - | (A) - (A) $\cap(\mathrm{Rr})$ |
|  | ANL A, @RO | 50 | 1 | 1 | - | - | - | - | $(\mathrm{A})-(\mathrm{A}) \cap((\mathrm{RO}))$ |
|  | ANL A, @R1 | 51 | 1 | 1 | - | - | - | - | $(\mathrm{A})-(\mathrm{A}) \cap((\mathrm{R} 1))$ |
| And immediate to $\mathbf{A}$ | ANL A, \#data | 53 | 2 | 2 | - | - | - | - | $(\mathrm{A})-(\mathrm{A}) \cap$ data |
| Clear A <br> Complement A Decimal Adjust A Decrement A Increment A | CLR A | 27 | 1 | 1 | - | - | - | - | (A) -0 |
|  | CPL A | 37 | 1 | 1 | - | - | - | - | (A) - (A) |
|  | DA A | 57 | 1 | 1 | * | - | - | - | (Note 1) |
|  | DEC A | 07 | 1 | 1 | - | - | - | - | (A) - (A) - 1 |
|  | INC A | 17 | 1 | 1 | - | - | - | - | (A) $-(\mathrm{A})+1$ |
| Or register to $A$ Or data memory to $A$ | ORL A, Rr | 4X | 1 | 1 | - | - | - | - | (A) $-(A) \cup(\mathrm{Rr})$ |
|  | ORL A, @RO | 40 | 1 | 1 | - | - | - | - | $(A)-(A) \cup((R 0))$ |
|  | ORL A, @R1 | 41 | 1 | 1 | - | - | - | - | $(\mathrm{A})-(\mathrm{A}) \cup((\mathrm{R} 1))$ |
| Or immediate to A | ORL A, \#data | 43 | 2 | 2 | - | - | - | - | (A) $-(\mathrm{A}) \cup$ data |
| Rotate A left <br> Rotate A left through carry <br> Rotate $A$ right <br> Rotate A right through carry <br> SWAP nibbles of $A$ | RLA | E7 | 1 | 1 | - | - | - | - |  |
|  | RLC A | F7 | 1 | 1 |  |  | - | - | (c)-7\|l|l|lo |
|  | RR A | 77 | 1 | 1 | - | - | - | - |  |
|  | RRC A | 67 | 1 | 1 |  | - | - | - |  |
|  | SWAPA | 47 | 1 | 1 | - | - | - | - | $\left\langle A_{A-n}=\overline{\left(A_{0-3}\right)}\right.$ |
| Exclusive Or register to $A$ Exclusive Or data memory to | XRLA, Rr | DX | 1 | 1 | - | - | - | - | $(\mathrm{A})-(\mathrm{A})+(\mathrm{Rr})$ |
|  | XRL A, @RO | DO | 1 | 1 | - | - | - | - | $(A)-(A)+((R 0))$ |
|  | XRL A, @R1 | D1 | 1 | 1 | - | - | - | - | $(\mathrm{A})-(\mathrm{A})+((\mathrm{R} 1))$ |
| Exclusive Or immediate to A | XRL A, \#data | D3 | 2 | 2 | - | - | - | - | (A) $-(\mathrm{A})+$ data |

$\dagger$ Mnemonic copyright Intel Corporation 1983. (except HALT and STOP)
Operation Code X: See Tables 1 and 2.
\%: See Table 3.
Flags*: This flag is set or reset in the state after executed instruction.
$Z$ : This flag is reset.
CP: This flag is complemented.
Note: (1) The accumulator value is adjusted to form BCD digits following the binary addition of BCD number.

## Instruction Set Summary

 (Continued)
## Input/Output Instructions

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | HC Fo | $F_{1}$ |  |
| And immediate to BUS | ANL BUS, \#data98 |  | 2 | 2 | - | - - | - | $(B \cup B)-(B U S) \cap$ data |
| And immediate to P1 | ANL P1, \#data | 99 | 2 | 2 | - | - - | - | $(\mathrm{P} 1)-(\mathrm{P} 1) \cap$ data |
| And immediate to P2 | ANL P2, \#data | 9A | 2 | 2 | - | - - | - | $(\mathrm{P} 2)-(\mathrm{P} 2) \cap$ data |
| And $\mathbf{A}$ to Expander Port | ANLD $P_{P}, A$ | 9X | 1 | 2 | - | - - | - | $\left(P_{P}\right)-\left(P_{P}\right) \cap\left(A^{\prime} \sim 0\right)$ |
| Input BUS to $A$ | INS A, BUS | 08 | 1 | 2 | - | - - | - | (A) - (BUS) |
| Input P1 to A | IN A, P1 | 09 | 1 | 2 | - | - - | - | (A) - (P1) |
| Input P2 to A | IN A, P2 | OA | 1 | 2 | - | - - | - | $(\mathrm{A})-(\mathrm{P} 2)$ |
| Input Expander Port to A | MOVD A, PP | OX | 1 | 2 | - | - - | - | $(A 3 \sim 0)-\left(P_{P}\right),(A 7 \sim 4)-0$ |
| Or immediate to BUS | ORL BUS, \#data | 88 | 2 | 2 | - | - - | - | $(\mathrm{BUS})-(\mathrm{BUS}) \cup$ data |
| Or immediate to P1 | ORL P1, \#data | 89 | 2 | 2 | - | - - | - | $(\mathrm{P} 1)-(\mathrm{P} 1) \cup$ data |
| Or immediate to P2 | ORL P2, \#data | 8A | 2 | 2 | - | - - | - | $(\mathrm{P} 2)-(\mathrm{P} 2) \cup$ data |
| Or A to Expander Port | ORLD $P_{p}, A$ | 8X | 1 | 2 | - | - - | - | $\left(P_{P}\right)-\left(P_{P}\right) \cup(A 3 \sim 0)$ |
| Output A to BUS | OUTL BUS, A | 02 | 1 | 2 | - | - - | - | (BUS) - (A) |
| Output A to P1 | OUTL P1, A | 39 | 1 | 2 | - | - - | - | (P1) - (A) |
| Output A to P2 | OUTL P2, A | 3A | 1 | 2 | - | - - | - | $(P 2)-(A)$ |
| Output A to Expander Port | MOVD $P_{p}, \mathrm{~A}$ | 3 X | 1 | 2 | - | - - | - | $\left(P_{P}\right)-(A 3 \sim 0)$ |

## Data Move Instructions

| Operation | Mnemonic | OP Code | Byte | Cycle | Fiag |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | HC Fo | $F_{1}$ |  |
| Move register to $A$ | MOV A, Rr | FX | 1 | 1 | - | - - | - | (A) - (Rr) |
| Move data memory to $A$ | MOV A, @RO | FO | 1 | 1 | - | - - | - | (A) $-((\mathrm{RO}))$ |
|  | MOV A, @R1 | F1 | 1 | 1 | - | - - | - | $(\mathrm{A})-((\mathrm{R} 1))$ |
| Move immediate to A | MOV A, \#data | 23 | 2 | 2 | - | - - | - | (A) - data |
| Move A to register | MOV Rr, A | AX | 1 | 1 | - | - - | - | $(\mathrm{Rr})-(\mathrm{A})$ |
| Move A to data memory | MOV @RO, A | AO | 1 | 1 | - | - - | - | $((\mathrm{RO}) \mathrm{)}$-(A) |
|  | MOV @R1, A | A1 | 1 | 1 | - | - - | - | ((R1)) - (A) |
| Move immediate to register | MOV Rr, \#data | BX | 2 | 2 | - | - - | - | (Rr) - data |
| Move immediate to data memory | MOV @RO, \#data | B0 | 2 | 2 | - | - - | - | $((\mathrm{RO})$ ) - data |
|  | MOV @R1, \#data | B1 | 2 | 2 | - | - - | - | ((R1)) - data |
| Move PSW to A | MOV A, PSW | C7 | 1 | 1 | - | - - | - | (A) - (PSW) |
| Move A to PSW | MOV PSW, A | D7 | 1 | 1 | * | * * | - | $(\mathrm{PSW})-(\mathrm{A})$ |
| Move external data memory to $A$ | MOVX A, @RO | 80 | 1 | 2 | - | - - | - | $(\mathrm{A})-((\mathrm{RO}))$ |
|  | MOVX A, @R1 | 81 | 1 | 2 | - | - - | - | $(\mathrm{A})-((\mathrm{R} 1))$ |
| Move A to external data memory | MOVX @RO, A | 90 | 1 | 2 | - | - - | - | $((\mathrm{RO}) \mathrm{)}$ - (A) |
|  | MOVX @R1, A | 91 | 1 | 2 | - | - - | - | $((R 1))-(A)$ |
| Move to A from current page | MOVP A, @A | A3 | 1 | 2 | - | - - | - | $\begin{aligned} & (P C 7-0)-(A), \\ & (A)-((P C)) \end{aligned}$ |
| Move to A from page 3 | MOVP3 A, @A | E3 | 1 | 2 | - | - - | - | $\begin{aligned} & (P C 7 \sim 0)-(A),(P C 11 \sim 8) \\ & -3,(A)-((P C)) \end{aligned}$ |
| Exchange A and register | XCH A, Rr | 2X | 1 | 1 | - | - - | - | ( A$)=(\mathrm{Rr})$ |
| Exchange $A$ and data memory | XCH A, @RO | 20 | 1 | 1 | - | - - | - | $(A)=((R 0))$ |
|  | XCH A, @R1 | 21 | 1 | 1 | - | - - | - | $(\mathrm{A})=((\mathrm{R} 1))$ |
| Exchange nibble of $A$ and data memory | XCHD A, @RO | 30 | 1 | 1 | - | - - | - | $(\mathrm{A} 3 \sim 0) \leftrightarrows((\mathrm{RO}) 3 \sim 0)$ |
|  | XCHD A, @R1 | 31 | 1 | 1 | - | - - | - | $(A 3 \sim 0)=((R 1) 3 \sim 0)$ |

Instruction Set Summary
(Continued)

Branch and Jump Instructions

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | HC |  | $F_{1}$ |  |
| Decrement register and test | DJNZ Rr, addr | EX | 2 | 2 | - | - | - | - | (Rr) $\neq 0$ Note (1) |
| Jump unconditional | JMP addr | \%4 | 2 | 2 | - | - | - | - | Unconditional Branch |
| Jump indirect | JMPP @ A | B3 | 1 | 2 | - | - | - | - | Unconditional Branch Note (2) |
| Jump on carry = 1 | JC addr | F6 | 2 | 2 | - | - | - | - | $(C)=1$ |
| Jump on carry = 0 | JNC addr | E6 | 2 | 2 | - | - | - | - | $(\mathrm{C})=0$ |
| Jump on A zero | JZ addr | C6 | 2 | 2 | - | - | - | - | (A) $=0$ |
| Jump on A no zero | JNZ addr | 96 | 2 | 2 | - | - | - | - | $(\mathrm{A}) \neq 0$ |
| Jump on T0 = 1 | JT0 addr | 36 | 2 | 2 | - | - | - | - | (TO) $=1$ |
| Jump on T0 $=0$ | JNT0 addr | 26 | 2 | 2 | - | - | - | - | $(\mathrm{TO})=0$ |
| Jump on T1 = 1 | JT1 addr | 56 | 2 | 2 | - | - | - | - | (T1) $=1$ |
| Jump on T1 $=0$ | JNT1 addr | 46 | 2 | 2 | - | - | - | - | $(\mathrm{T} 1)=0$ |
| Jump on F0 = 1 | JF0 addr | B6 | 2 | 2 | - | - | - | - | $(\mathrm{FO})=1$ |
| Jump on F1 = 1 | JF1 addr | 76 | 2 | 2 | - | - | - | - | $(\mathrm{F} 1)=1$ |
| Jump on timer flag, Clear flag | JTF addr | 16 | 2 | 2 | - | - | - | - | (TF) $=1$ |
| Jump on $\overline{\mathrm{NT}}=0$ | JNI addr | 86 | 2 | 2 | - | - | - | - | $(\overline{\text { INT }})=0$ |
| Jump on accumulator bit | JBb addr | \%2 | 2 | 2 | - | - | - | - | $(\mathrm{Ab})=1$ |

## Subroutine Instructions

|  |  | OP <br> Code | Byte | Cycle | Flag |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operation | Mnemonic |  |  |  |  |  |  | $F_{1}$ |  |
| Jump to subroutine | CALL addr | \%4 | 2 | 2 | - | - | - | - | Note (3) |
| Return | RET | 83 | 1 | 2 | - | - | - | - | Note (4) |
| Return and restore status | RETR | 93 | 1 | 2 | * | * | * | - | Note (5) |

## Flags Instructions

| Operation | Mnemonic | OP <br> Code | Byte | Cycle | Flag |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | CY |  |  | $F_{1}$ |  |
| Clear carry | CLR C | 97 | 1 | 1 | Z | - | - | - | (C) -0 |
| Complement carry | CPL C | A7 | 1 | 1 | CP | - | - | - | (C) $-(\bar{C})$ |
| Clear flag 0 | CLR F0 | 85 | 1 | 1 | - | - | Z | - | (FO) -0 |
| Complement flag 0 | CPL F0 | 95 | 1 | 1 | - | - | CP | - | (FO) - ( $\overline{\mathrm{FO}})$ |
| Clear flag 1 | CLR F1 | A5 | 1 | 1 | - | - | - | Z | (F1) -0 |
| Complement flag 1 | CPL F1 | B5 | 1 | 1 | - | - | - | CP | $(\mathrm{F} 1)-(\overline{\mathrm{F}}$ ) |

(1) DJNZ Rr, Addr: (Rr) - $1 \rightarrow$ (Rr)
if $(\mathrm{Rr}) \neq 0$, addr $\rightarrow\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right)$.
if $\left(R_{r}\right)=0$, execute next instruction.
(2) JMPP @ A: ((A)) $\rightarrow\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right)$

## Register Instructions

| Operation | Mnemonic | OP <br> Code | Byte | Cycle | Flag |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | CY |  | $F_{0}$ | $F_{1}$ |  |
| Decrement register | DEC Rr | CX | 1 | 1 | - | - | - | - | $(\mathrm{Rr})-(\mathrm{Rr})-1$ |
| Increment register | INC Rr | 1X | 1 | 1 | - | - | - | - | $(\mathrm{Rr})-(\mathrm{Rr})+1$ |
| Increment data memory | INC@RO | 10 | 1 | 1 | - | - | - | - | $((\mathrm{RO}))-((\mathrm{RO}))+1$ |
|  | INC@R1 | 11 | 1 | 1 | - |  | - | - | $((\mathrm{R} 1))-((\mathrm{R} 1))+1$ |

Instruction Set Summary
(Continued)

## Timer/Counter Instructions



## Control Instructions

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | CY | HC Fo | $F_{1}$ |  |
| Disable external Interrupt | DIS I | 15 | 1 | 1 | - | - - | - |  |
| Enable external Interrupt | EN I | 05 | 1 | 1 | - | - - | - |  |
| Enable Clock output on T0 | ENTO CLK | 75 | 1 | 1 | - | - - | - |  |
| No Operation | NOP | 00 | 1 | 1 | - | - - | - |  |
| Select register bank 0 | SEL RBO | C5 | 1 | 1 | - | - - | - | (BS) -0 |
| Select register bank 1 | SEL RB1 | D5 | 1 | 1 | - | - - | - | (BS) -1 |
| Select memory bank 0 | SEL. MBO | E5 | 1 | 1 | - | - - | - | $(M B F)-0$ |
| Select memory bank 1 | SEL MB1 | F5 | 1 | 1 | - | - - | - | (MBF) - 1 |

Standby Instructions

|  |  | OP Code | Byte | Cycle | Flag |  |  |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operation | Mnemonic |  |  |  | CY | HC | Fo | $F_{1}$ |  |
| Halt | HALT | 01 | 1 | 1 | - | - | - | - |  |
| Stop | STOP | C1 | 1 | 1 | - | - | - | - |  |

## Instruction Set Summary (Continued)

Table 1. O.P. Code of Register Access Instruction

| Mnemonic | Rr | RO | R1 | R2 | R3 | R4 | R5 | R6 | 6 R7 |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INC Rr |  | 18 | 19 | 1A | 1B | 1 C | 1D | 1 E | E 1F |  |  |  |  |  |  |  |  |
| XCH A, Rr |  | 28 | 29 | 2A | 2 B | 2C | 2D | 2E | 2F |  |  |  |  |  |  |  |  |
| ORL A, Rr |  | 48 | 49 | 4A | 4B | 4C | 4D | 4E | 4F |  |  |  |  |  |  |  |  |
| ANL A, Rr |  | 58 | 59 | 5A | 5B | 5C | 5D | 5E | 5F |  |  |  |  |  |  |  |  |
| ADD A, Rr |  | 68 | 69 | 6A | 6B | 6C | 6D | 6E | 6F |  |  |  |  |  |  |  |  |
| ADDC A, Rr |  | 78 | 79 | 7A | 7B | 7C | 7D | 7E | 7F | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| MOV Rr, A |  | A8 | A9 | AA | AB | AC | AD | AE | E AF |  |  |  |  |  | $\mathrm{r}_{2}$ | $r_{1}$ | $r_{0}$ |
| MOV Rr, \#data |  | B8 | B9 | BA | BB | BC | BD | BE | E BF |  |  |  |  |  |  |  |  |
| DEC Rr |  | C8 | C9 | CA | CB | CC | CD | CE | E CF |  |  |  |  |  |  |  |  |
| XRL A, Rr |  | D8 | D9 | DA | DB | DC | DD | DE | E DF |  |  |  |  |  |  |  |  |
| DJNZ Rr, M |  | E8 | E9 | EA | EB | EC | ED | EE | EF |  |  |  |  |  |  |  |  |
| MOV A, Rr |  | F8 | F9 | FA | FB | FC | FD | FE | FF |  |  |  |  |  |  |  |  |

Table 2. OP Code Of Expander Port Instruction

| Mnemonic | PP | P4 | P5 | P6 | P7 |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MOVD A.P $\mathrm{P}_{\mathrm{P}}$ |  | 0 C | OD | OE | OF | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| MOVD $P_{P}, A$ |  | 3 C | 3D | 3E | 3 F |  |  |  |  |  |  | $\mathrm{P}_{1}$ |  |
| ORLD $P_{p}, A$ |  | 8 C | 8D | 8 E | 8F |  |  |  |  |  |  |  |  |
| ANLD $P_{p}, A$ |  | 9 C | 9D | 9 E | 9 F |  |  |  |  |  |  |  |  |

OP Code of JMP/CALL/JB ${ }_{b}$


Notes:
(3) CALL addr:
( $\mathrm{PC}_{0}$ to $\mathrm{PC}_{7}$ ) $\rightarrow$ ( (SP))
$\left(\mathrm{PC}_{8}\right.$ to $\left.\mathrm{PC}_{1}\right)$ ), (MBF), ( $\mathrm{PSW}_{5}$ to $\left.\mathrm{PSW}_{7}\right) \rightarrow((\mathrm{SP}))$
$(\mathrm{SP})+1 \rightarrow$ (SP)
$\mathrm{A}_{\mathrm{L}} \rightarrow\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right)$
$\mathrm{A}_{\mathrm{H}}^{\mathrm{L}} \rightarrow\left(\mathrm{PC}_{8}\right.$ to $\left.\mathrm{PC}_{10}\right)$
$\mathrm{MBF} \rightarrow\left(\mathrm{PC}_{11}\right)$
(4) RET:
(SP) - $1 \rightarrow$ (SP)
$((S P)) \rightarrow\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right),\left(\mathrm{PC}_{8}\right.$ to $\left.\mathrm{PC}_{11}\right)$
(5) RETR:
$(S P)-1 \rightarrow(S P)$
(SP) $)$
$((\mathrm{SP}))_{0}$ to $\left(\mathrm{SP}^{2}\right)_{3} \rightarrow\left(\mathrm{PC}_{8}\right.$ to $\left.\mathrm{PC}_{11}\right)$
((SP) $)_{4}$ to (SP $)_{7}^{3} \rightarrow\left(\mathrm{PSWW}_{4}\right.$ to $\mathrm{PSW}_{7}$ )
$((\mathrm{SPP})) \rightarrow\left(\mathrm{PC}_{0}\right.$ to $\left.\mathrm{PC}_{7}\right),\left(\mathrm{PC}_{8}\right.$ to $\left.\mathrm{PC}_{11}\right)$
$((S P)) \rightarrow\left(\mathrm{PSW}_{5}\right.$ to $\left.\mathrm{PSW}_{7}\right)$, (MBF)

## Instruction Codes

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | NOP | HALT | $\begin{gathered} \text { OUT } \\ (\mathrm{BSU}, \mathrm{~A}) \end{gathered}$ | $\begin{aligned} & \text { ADD } \\ & (\mathrm{A}, \#) \end{aligned}$ | $\underset{0}{\mathrm{JMP}}$ | $\underset{1}{\mathrm{EN}}$ |  | DEC (A) | $\begin{gathered} \text { INS } \\ (A, B \cup S) \end{gathered}$ | $\underset{(\mathrm{A}, \mathrm{P} 1)}{\operatorname{lN}}$ | $\underset{(A, P 2)}{\mathbb{N}}$ |  | $\begin{aligned} & \text { MOVD } \\ & (\mathrm{A}, \mathrm{P} 4) \end{aligned}$ | $\begin{aligned} & \text { MOVD } \\ & (\mathrm{A}, \mathrm{P}) \end{aligned}$ | $\begin{aligned} & \text { MOVD } \\ & (\mathrm{A}, \mathrm{P} 6) \end{aligned}$ | $\begin{aligned} & \text { MOVD } \\ & (\mathrm{A}, \mathrm{P} 7) \end{aligned}$ |
| 1 | $\begin{aligned} & \text { INC } \\ & \text { @RO } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { @R1 } \end{aligned}$ | JB | ADDC <br> (A,\#) | $\begin{gathered} \mathrm{CALL} \\ 0 \end{gathered}$ | $\underset{1}{\text { DIS }}$ | JTF | INC <br> (A) | $\begin{aligned} & \text { INC } \\ & \text { (RO) } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { (R1) } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { (R2) } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { (R3) } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { (R4) } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { (R5) } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { (R6) } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { (R7) } \end{aligned}$ |
| 2 | $\begin{gathered} \text { XCH } \\ \text { (A,@RO) } \end{gathered}$ | $\begin{gathered} \mathrm{XCH} \\ (\mathrm{~A}, @ \mathrm{R} 1) \end{gathered}$ |  | $\begin{gathered} \text { MOV } \\ \text { (A,\#) } \end{gathered}$ | $\underset{1}{\text { JMP }}$ | $\begin{gathered} \text { EN } \\ \text { TCNTI } \end{gathered}$ | JNTO | $\begin{gathered} \text { CLR } \\ (A) \end{gathered}$ | $\begin{gathered} \mathrm{XCH} \\ (\mathrm{~A}, \mathrm{RO}) \end{gathered}$ | $\begin{gathered} x C H \\ (A, R 1) \end{gathered}$ | $\underset{(\mathrm{A}, \mathrm{R} 2)}{\mathrm{XCH}}$ | $\begin{gathered} \mathrm{XCH} \\ (\mathrm{~A}, \mathrm{R} 3) \end{gathered}$ | $\begin{gathered} \mathrm{XCH} \\ (\mathrm{~A}, \mathrm{R} 4) \end{gathered}$ | $\begin{gathered} \mathrm{XCH} \\ (\mathrm{~A}, \mathrm{R} 5) \end{gathered}$ | $\begin{gathered} \mathrm{XCCH} \\ (\mathrm{~A}, \mathrm{R}) \end{gathered}$ | $\begin{gathered} \mathrm{XCH} \\ (\mathrm{~A}, \mathrm{R}) \end{gathered}$ |
| 3 | $\begin{gathered} \mathrm{XCHD} \\ \left(A, \mathrm{~B}^{2}\right) \end{gathered}$ | $\begin{gathered} \mathrm{XCHD} \\ \left(\mathrm{~A}, \oplus \mathrm{R}_{1}\right) \end{gathered}$ | JB 1 |  | $\underset{1}{\text { CALL }}$ | $\begin{gathered} \text { DIS } \\ \text { TCNTI } \end{gathered}$ | JTO | $\begin{gathered} \mathrm{CPL} \\ (\mathrm{~A}) \end{gathered}$ |  | $\begin{aligned} & \text { OUTL } \\ & \text { (P1,A) } \end{aligned}$ | $\begin{aligned} & \text { OUTL } \\ & (\mathrm{P} 2, \mathrm{~A}) \end{aligned}$ |  | MOVD (P4,A) | MOVD (P5,A) | $\begin{aligned} & \text { MOVD } \\ & \text { (P6,A) } \end{aligned}$ | $\begin{aligned} & \text { MOVD } \\ & (\mathrm{P} 7, \mathrm{~A}) \end{aligned}$ |
| 4 | $\begin{gathered} \text { ORL } \\ \text { (Ac@RO) } \end{gathered}$ | $\begin{gathered} \text { ORL } \\ (\mathrm{A}, @ \mathrm{~B} 1) \end{gathered}$ | MOV <br> (A,T) | $\begin{aligned} & \text { ORL } \\ & (A, \#) \end{aligned}$ | $\begin{gathered} \text { JMP } \\ 2 \end{gathered}$ | $\begin{aligned} & \text { STRT } \\ & \text { CNT } \end{aligned}$ | JNT1 | SWAP <br> (A) | $\begin{aligned} & \text { ORL } \\ & (\mathrm{A}, \mathrm{RO}) \end{aligned}$ | $\underset{(\mathrm{A}, \mathrm{R} 1)}{\mathrm{ORL}}$ | $\underset{(\mathrm{A}, \mathrm{R} 2)}{\mathrm{ORL}}$ | $\begin{gathered} \text { ORL } \\ (\mathrm{A}, \mathrm{R} 3) \end{gathered}$ | $\begin{gathered} \text { ORL } \\ (A, R 4) \end{gathered}$ | $\begin{gathered} \text { ORL } \\ (\mathrm{A}, \mathrm{R} 5) \end{gathered}$ | ORL (A,R6) | $\begin{aligned} & \text { ORL } \\ & (\mathrm{A}, \mathrm{R} 7) \end{aligned}$ |
| 5 | $\begin{gathered} \text { ANL } \\ (A, @ R 0) \end{gathered}$ | $\begin{gathered} \text { ANL } \\ (A, @ R 1) \end{gathered}$ | $\begin{gathered} \text { JB } \\ 2 \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & (\mathrm{A}, \\|) \end{aligned}$ | $\underset{2}{\mathrm{CALL}}$ | $\begin{gathered} \text { STRT } \\ T \end{gathered}$ | JT1 | $\begin{aligned} & \text { DA } \\ & \text { (A) } \end{aligned}$ | $\underset{(\mathrm{A}, \mathrm{RO})}{\mathrm{ANL}}$ | $\begin{gathered} \text { ANL } \\ (\mathrm{A}, \mathrm{R} 1) \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & (\mathrm{A}, \mathrm{R} 2) \end{aligned}$ | $\underset{(A, R 3)}{A N L}$ | $\begin{gathered} \text { ANL } \\ (\mathrm{A}, \mathrm{R} 4) \end{gathered}$ | $\underset{(\mathrm{A}, \mathrm{R} 5)}{\mathrm{ANL}}$ | $\begin{gathered} \text { ANL } \\ (\mathrm{A}, \mathrm{R} 6) \end{gathered}$ | $\begin{gathered} \text { ANL } \\ (\mathrm{A}, \mathrm{R} 7) \end{gathered}$ |
| 6 | $\begin{gathered} \text { ADD } \\ \text { (A,@RO) } \end{gathered}$ | $\begin{gathered} \text { ADD } \\ (A, @ R 1) \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & (T, A) \end{aligned}$ |  | ${ }_{3}{ }_{3}$ | $\begin{aligned} & \text { STOP } \\ & \text { TCNT } \end{aligned}$ |  | RRC <br> (A) | $\begin{aligned} & \text { ADD } \\ & (A, R 0) \end{aligned}$ | $\underset{(A, R 1)}{A D D}$ | $\begin{gathered} \text { ADD } \\ (\mathrm{A}, \mathrm{R} 2) \end{gathered}$ | $\begin{gathered} \mathrm{ADD} \\ (\mathrm{~A}, \mathrm{R} 3) \end{gathered}$ | $\begin{gathered} A D D \\ (A, R 4) \end{gathered}$ | $\begin{gathered} \text { ADD } \\ (\mathrm{A}, \mathrm{R} 5) \end{gathered}$ | $\begin{gathered} \text { ADD } \\ (\mathrm{A}, \mathrm{R} 6) \end{gathered}$ | $\begin{gathered} \text { ADD } \\ (\mathrm{A}, \mathrm{R} 7) \end{gathered}$ |
| 7 | ADDC <br> (A,@RO) | ADDC <br> (A,@R1) | JB 3 |  | $\begin{gathered} \mathrm{CALL} \\ 3 \end{gathered}$ | $\begin{aligned} & \text { ENTO } \\ & \text { CLK } \end{aligned}$ | JF1 | $\begin{aligned} & \text { RR } \\ & \text { (A) } \end{aligned}$ | ADDC (A,RO) | ADDC <br> (A,R1) | ADDC <br> (A,R2) | ADDC (A,R3) | $\begin{aligned} & \text { ADDC } \\ & \text { (A,R4) } \end{aligned}$ | ADDC (A,R5) | $\begin{aligned} & \text { ADDC } \\ & (\mathrm{A}, \mathrm{R} 6) \end{aligned}$ | ADDC (A,R7) |
| 8 | MOVX <br> (A,@RO) | MOVX $(A, @ R 1)$ |  | RET | JMP | $\begin{gathered} \text { CLR } \\ \text { FO } \end{gathered}$ | JNI |  | $\begin{gathered} \text { ORL } \\ (B \cup S, \#) \end{gathered}$ | $\underset{(\mathrm{P} 1, \#)}{\text { ORL }}$ | $\begin{gathered} \text { ORL } \\ (\mathrm{P} 2, \#) \end{gathered}$ |  | $\begin{aligned} & \text { ORLD } \\ & (\mathrm{P} 4, \mathrm{~A}) \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \text { (P5,A) } \end{aligned}$ | ORLD <br> (P6,A) | $\begin{aligned} & \text { ORLD } \\ & (P 7, A) \end{aligned}$ |
| 9 | MOVX (@RO,A) | $\begin{gathered} \text { MOVX } \\ (@ R 1, A) \end{gathered}$ | ${ }^{\text {JB }}$ | RETR | $\underset{4}{\mathrm{CALL}}$ | $\begin{aligned} & \mathrm{CPL} \\ & \mathrm{FO} \end{aligned}$ | JNZ | $\underset{\mathrm{C}}{\mathrm{CLR}}$ | $\begin{gathered} \text { ANL } \\ (B \cup S, \#) \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & (\mathrm{P} 1, \#) \end{aligned}$ | $\begin{gathered} \text { ANL } \\ (\mathrm{P} 2, \#) \end{gathered}$ |  | $\begin{aligned} & \text { ANLD } \\ & (P 4, A) \end{aligned}$ | $\begin{aligned} & \text { ANLD } \\ & \text { (P5,A) } \end{aligned}$ | $\begin{aligned} & \text { ANLD } \\ & (\mathrm{PG}, \mathrm{~A}) \end{aligned}$ | $\begin{aligned} & \text { ANLD } \\ & (\mathrm{P} 7, \mathrm{~A}) \end{aligned}$ |
| A | $\begin{gathered} \text { MOV } \\ (@ R 0, A) \end{gathered}$ | $\begin{gathered} \text { MOV } \\ (@ R 1, A) \end{gathered}$ |  | MOVP <br> (A,@A) | $\underset{5}{\mathrm{JMP}}$ | $\underset{\text { F1 }}{\text { C1 }}$ |  | $\begin{gathered} \text { CPL } \\ \mathrm{C} \end{gathered}$ | $\begin{gathered} \text { MOV } \\ (\mathrm{RO}, \mathrm{~A}) \end{gathered}$ | $\begin{gathered} \text { MOV } \\ (\mathrm{R} 1, \mathrm{~A}) \end{gathered}$ | $\begin{gathered} \text { MOV } \\ (\mathrm{R} 2, \mathrm{~A}) \end{gathered}$ | $\begin{gathered} \text { MOV } \\ (R 3, A) \end{gathered}$ | $\begin{gathered} \text { MOV } \\ (\mathrm{R} 4, \mathrm{~A}) \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { (R5,A) } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ (\mathrm{R} 6, \mathrm{~A}) \end{gathered}$ | $\begin{gathered} \text { MOV } \\ (R 7, A) \end{gathered}$ |
| B | $\begin{gathered} \text { MOV } \\ \text { (@RO,\#) } \end{gathered}$ | $\begin{array}{\|c} \text { MOV } \\ \text { (@R1, }) \end{array}$ | $\begin{gathered} \text { JB } \\ 5 \end{gathered}$ | (@A) | $\begin{gathered} \text { CALL } \\ 5 \end{gathered}$ | $\begin{gathered} \text { CPL } \\ \text { F1 } \end{gathered}$ | JFO |  | $\begin{gathered} \text { MOV } \\ (\text { RO, } \end{gathered}$ | $\underset{(\mathrm{R} 1, \#)}{\mathrm{MOV}}$ | $\begin{gathered} \text { MOV } \\ \text { (R2,\#) } \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & \text { (R3,\#) } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { (R4,\#) } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { (R5, \#) } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ (R 6, \#) \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { (R7,\#) } \end{gathered}$ |
| C |  | STOP |  |  | $\underset{6}{\mathrm{JMP}}$ | $\begin{aligned} & \text { SEL } \\ & \text { RBO } \end{aligned}$ | Jz | $\begin{gathered} \mathrm{MOV} \\ (\mathrm{~A}, \mathrm{PSW}) \end{gathered}$ | $\begin{aligned} & \mathrm{DEC} \\ & \text { (RO) } \end{aligned}$ | DEC <br> (R1) | DEC <br> (R2) | DEC <br> (R3) | DEC <br> (R4) | DEC (R5) | DEC (R6) | DEC <br> (R7) |
| D | $\begin{gathered} \text { XRL } \\ (\mathrm{A}, @ R 0) \end{gathered}$ | $\begin{gathered} \text { XRL } \\ (A, @ R 1) \end{gathered}$ | $\begin{gathered} \mathrm{JB} \\ 6 \end{gathered}$ | $\begin{gathered} \text { XRL } \\ (\mathrm{A}, \#) \end{gathered}$ | $\begin{gathered} C A L L \\ 6 \end{gathered}$ | SEL <br> RB1 |  | $\begin{gathered} \text { MOV } \\ \text { (PSW,A) } \end{gathered}$ | $\underset{(\mathrm{A}, \mathrm{RO})}{\mathrm{XRL}}$ | $\begin{gathered} \text { XRL } \\ (\mathrm{A}, \mathrm{R} 1) \end{gathered}$ | $\underset{(\mathrm{A}, \mathrm{R} 2)}{\mathrm{XRL}}$ | $\underset{(A, R 3)}{\underset{(A R L}{ }}$ | $\underset{(\mathrm{ARL}}{\mathrm{XR})}$ | $\begin{gathered} \text { XRL } \\ (\mathrm{A}, \mathrm{R} 5) \end{gathered}$ | $\underset{(\mathrm{A}, \mathrm{R6})}{\mathrm{XRL}}$ | $\begin{gathered} \text { XRL } \\ (\mathrm{A}, \mathrm{R} 7) \end{gathered}$ |
| E |  |  |  | MOVP3 <br> (A,@A) | $\begin{gathered} \text { JMP } \\ 7 \end{gathered}$ | $\begin{aligned} & \text { SEL } \\ & \text { MBO } \end{aligned}$ | JNC | $\begin{aligned} & \text { RL } \\ & \text { (A) } \end{aligned}$ | DJNZ <br> (ROM) | $\begin{aligned} & \text { DJNZ } \\ & \text { (R1,M) } \end{aligned}$ | DJNZ <br> (R2,M) | DJNZ <br> (R3,M) | $\begin{gathered} \text { DJNZ } \\ \text { (R4,M) } \end{gathered}$ | DJNZ <br> (R5,M) | DJNZ <br> (R6,M) | DJNZ <br> (R7,M) |
| F | $\begin{array}{\|c\|} \text { MOV } \\ \text { (A,@RO) } \end{array}$ | $\begin{gathered} \text { MOV } \\ \text { (A,@R1) } \end{gathered}$ | $\begin{gathered} \text { JB } \\ 7 \end{gathered}$ |  | $\begin{gathered} \text { CALL } \\ 7 \end{gathered}$ | $\begin{aligned} & \text { SEL } \\ & \text { MB1 } \end{aligned}$ | JC | RLC (A) | $\underset{(\mathrm{A}, \mathrm{RO})}{\mathrm{MOV}}$ | $\underset{(A, R 1)}{M O V}$ | $\begin{gathered} \text { MOV } \\ (\mathrm{A}, \mathrm{R} 2) \end{gathered}$ | $\underset{(\mathrm{A}, \mathrm{R} 3)}{\mathrm{MOV}}$ | $\begin{gathered} \operatorname{MOV} \\ (\mathrm{A}, \mathrm{R}) \end{gathered}$ | $\underset{(\mathrm{A}, \mathrm{R})}{\mathrm{MOV}}$ | $\underset{(A, R 6)}{M O V}$ | $\underset{(A, R 7)}{M O V}$ |

\#: Immediate data
H; Higher 4 Bits
L; Lower Bits


1 Byte, 1 Cycle Instruction
$\square$ 1 Byte, 2 Cycles Instruction
$\square$ 2 Byte, 2 Cycles Instruction

Typical Application

Figure 15. Stand Alone System


Figure 16. Expanded System



## DC Characteristics

Recommended operating conditions, unless otherwise noted.
$\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$ for MBL80C49N/MBL80C39N $)$
$\left(\mathrm{T}_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$ for MBL80C49H/MBL80C39H$)$

| Parameter | Applicable Pin/Device | Symbol | Value |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. |  |  |
| Input Low Voltage | $\begin{aligned} & \text { All except } \\ & \text { XTAL1, XTAL2, } \\ & \text { RESET } \\ & \hline \end{aligned}$ | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | 0.8 | V |  |
|  | $\begin{aligned} & \text { XTAL1, XTAL2, } \\ & \frac{\text { RESET }}{} \end{aligned}$ | $\mathrm{V}_{\text {IL1 }}$ | -0.3 | 0.6 | V |  |
| Input High Voltage | $\begin{aligned} & \text { All except } \\ & \text { XTAL } 1 \text {, XTAL2, } \\ & \text { RESET } \end{aligned}$ | $\mathrm{V}_{\mathrm{IH}}$ | 2.2 | $\mathrm{V}_{\text {cc }}$ | V |  |
|  | $\begin{aligned} & \frac{\text { XTAL1 } \times T A L 2, ~}{\text { RESET }} \end{aligned}$ | $\mathrm{V}_{1 \mathrm{H} 1}$ | 3.8 | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| Output Low Voltage | BUS | $\mathrm{V}_{\mathrm{OL}}$ |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
|  | RD, WR, $\overline{\text { PSEN }}$, ALE | $\mathrm{V}_{\mathrm{OL} 1}$ |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
|  | PROG | $\mathrm{V}_{\mathrm{OL} 2}$ |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ |
|  | All Other Outputs | $\mathrm{V}_{\text {OL3 }}$ |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| Output High Voltage | BUS | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
|  | $\overline{\overline{R D}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}$, ALE, PROG, TO | $\mathrm{V}_{\mathrm{OH} 1}$ | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
|  | P10-P17, P20-P27 | $\mathrm{V}_{\mathrm{OH} 2}$ | 2.4 |  | V | $\mathrm{IOH}=-40 \mu \mathrm{~A}$ |
| Input Leakage Current | $\overline{\text { RESET }}$, $\overline{\mathrm{SS}}, \overline{\mathrm{SR}}$ | $\mathrm{I}_{\mathrm{L}}$ |  | -100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+0.45 \leqq \mathrm{~V}_{\text {IN }} \leqq \mathrm{V}_{\mathrm{CC}}$ |
|  | T1, $\overline{\text { INT, EA }}$ | $\mathrm{I}_{\mathrm{LI} 1}$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leqq \mathrm{V}_{\text {IN }} \leqq \mathrm{V}_{\mathrm{CC}}$ |
|  | P10-P17, P20-P27 | $\mathrm{ILI}^{2}$ |  | -200 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+0.45 \leqq \mathrm{~V}_{\text {IN }} \leqq \mathrm{V}_{\text {CC }}$ |
| Output Leakage Current | BUS, TO | $\mathrm{I}_{\text {LO }}$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+0.45 \leqq \mathrm{~V}_{\mathrm{IN}} \leqq \mathrm{~V}_{\mathrm{CC}} \\ & \text { High-Imppedance } \\ & \text { Mode } \end{aligned}$ |
| Standby <br> Supply Current | MBL80C49N/C39N | ICCH |  | 2 | mA | $v_{C C}=3.5 \mathrm{~V}, 6 \mathrm{MHz},$ <br> HALT Mode |
|  | MBL80C49H/C49H | $\mathrm{I}_{\mathrm{CCH}}$ |  | 4 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=3.5 \mathrm{~V}, 11 \mathrm{MHz}, \\ & \text { HALT Mode } \end{aligned}$ |
|  | MBL80C49N/H, MBL80C39N/H | Iocs |  | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=2.0 \mathrm{~V}, \\ & \text { STOP Mode } \end{aligned}$ |
| Active Supply Current | MBL80C49N/C39N | $\mathrm{I}_{\mathrm{CC}}$ |  | 10 | mA | All Outputs Open |
|  | MBL80C49H/C39H | I Cc |  | 18 | mA | All Outputs Open |

## AC Characteristics

Recommended operating conditions, unless otherwise noted.
( $T_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ for MBL80C49N/MBL80C39N)
( $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$ for MBL80C49H/MBL80C39H )

| Parameter | Symbol | MBL80C49H/C39H |  | MBL80C49N/C39N |  |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| ALE Pulse Width | $t_{\text {LL }}$ | 150 |  | 410 |  | ns |  |
| Address Setup Time (to ALE!) | $t_{\text {AL }}$ | 70 |  | 230 |  | ns |  |
| Address Hold Time (from ALE!) | $\mathrm{t}_{\text {LA }}$ | 50 |  | 120 |  | ns | Note 1 |
| $\overline{\overline{R D}}$ \& $\overline{W R}$ Pulse Width | $\mathrm{t}_{\mathrm{CC} 1}$ | 480 |  | 1050 |  | ns | Noter |
| PSEN Pulse Width | $\mathrm{t}_{\mathrm{CC} 2}$ | 350 |  | 800 |  | ns |  |
| Data Setup Time (to WR1) | $t_{\text {DW }}$ | 390 |  | 880 |  | ns |  |
| Data Hold Time (from $\overline{W R} 1$ ) | $t_{\text {wD }}$ | 40 |  | 120 |  | ns | Note 2 |
| Data Hold Time (from $\overline{\mathrm{RD}} \uparrow, \overline{\text { PSEN }}$ ) | $t_{\text {DR }}$ | 0 | 110 | 0 | 220 | ns |  |
| Data Delay Time (from $\overline{\mathrm{RD}}$ ) | $t_{\text {RD1 }}$ |  | 350 |  | 800 | ns |  |
| Data Delay Time (from $\overline{\text { PSEN }}$ ) | $\mathrm{t}_{\mathrm{RD} 2}$ |  | 210 |  | 550 | ns |  |
| Address Setup Time (to $\overline{\mathrm{WR}}$ ) | $t_{\text {AW }}$ | 310 |  | 680 |  | ns |  |
| Data Delay Time ( $\overline{\mathrm{RD}}$ ) | $t_{\text {AD1 }}$ |  | 760 |  | 1590 | ns |  |
| Data Delay Time ( $\overline{\text { PSEN }}$ ) | $t_{\text {AD2 }}$ |  | 480 |  | 1090 | ns |  |
| Address Floating Time (to $\overline{\mathrm{RD}}!, \overline{\mathrm{WR}}$ ) | $\mathrm{t}_{\text {AFC1 }}$ | 140 |  | 290 |  | ns |  |
| Address Floating Time (to $\overline{\text { PSEN }} \downarrow$ ) | $\mathrm{t}_{\text {AFC2 }}$ | 10 |  | 40 |  | ns |  |
| $\overline{\overline{\mathrm{RD}}, \overline{\mathrm{WR}} \text { Output Delay Time (from ALE!) }}$ | $t_{\text {LAFC1 }}$ | 200 |  | 420 |  | ns |  |
| PSEN Output Delay Time (from ALE!) | $\mathrm{t}_{\text {LAFC2 }}$ | 60 |  | 170 |  | ns |  |
| ALE Delay Time (from $\overline{\mathrm{RD}} \uparrow, \overline{\mathrm{WR}}$, PROG 1 ) | $\mathrm{t}_{\text {CA1 }}$ | 50 |  | 120 |  | ns |  |
| ALE Delay Time (from $\overline{\text { PSEN }}$ ) | ${ }_{\text {t }}{ }_{\text {c }}$ 2 | 320 |  | 620 |  | ns | Note 1 |
| Port Control Setup Time (to PROG!) | $\mathrm{t}_{\mathrm{CP}}$ | 100 |  | 250 |  | ns | Note 1 |
| Port Control Hold Time (from PROG!) | $t_{P C}$ | 160 |  | 460 |  | ns |  |
| Port 2 Input Data Delay Time (from PROG!) | $t_{P R}$ |  | 700 |  | 1380 | ns |  |
| Port 2 Input Data Hold Time (from PROGI) | $\mathrm{t}_{\text {PF }}$ | 0 | 140 | 0 | 250 | ns |  |
| Output Data Setup Time (to PROG ${ }^{\text {t }}$ | $t_{\text {DP }}$ | 400 |  | 850 |  | ns |  |
| Output Data Hold Time (from PROG) | $t_{\text {PD }}$ | 90 |  | 200 |  | ns |  |
| PROG Pulse Width | $t_{\text {PP }}$ | 700 |  | 1500 |  | ns |  |
| Port $21 / O$ Data Setup Time (to ALEI) | $\mathrm{t}_{\mathrm{PL}}$ | 160 |  | 460 |  | ns |  |
| Port 2 I/O Data Hold Time (from ALEt) | $\mathrm{t}_{\mathrm{LP}}$ | 40 |  | 80 |  | ns |  |
| Port Data Output Time (from ALE!) | $t_{P V}$ |  | 510 |  | 850 | ns |  |
| Cycle Time | $\mathrm{t}_{\mathrm{Cr}}$ | 1.36 |  | 2.5 |  | $\mu \mathrm{s}$ |  |
| TO Output Frequency | topRR | 270 |  | 500 |  | ns |  |

[^28]
## Timing Diagram

Figure 11. Timing Diagram ${ }^{(1)}$

Instruction Fetch From External Program Memory


Read From External Data Memory


Write To External Data Memory


## Timing Diagram

 (Continued)Figure 12. Timing Diagram (2)

P20-P23 Input/Output for Use of External Program Memory and Expander I/O Port


Port 1/Port 2 Outputs


Clock Outputs


## AC Characteristics

 for Standby Operation| Parameter |  | Symbol | Value |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. | Max. |
| Standby Release Pulse Width | $\overline{\text { SR }}$ | $\mathrm{t}_{\mathrm{RW} 1}$ | $2 \cdot t_{C Y}$ | - | - |
|  | RESET | $\mathrm{t}_{\mathrm{RW} 2}$ | $12 \cdot \mathrm{t}_{\mathrm{Cr}}$ | - | - |
| Standby Release Time |  | $\mathrm{t}_{\mathrm{RT1}}$ | $4 \cdot t_{C Y}$ | $5 \cdot t_{C Y}$ | $6 \cdot t_{\text {cr }}$ |
|  | HALT Mode | $\mathrm{t}_{\text {RT2 }}$ | $4 \cdot t_{C Y}$ | $5 \cdot \mathrm{t}_{\mathrm{CY}}$ | $6 \cdot \mathrm{t}_{\mathrm{Cr}}$ |
|  | STOP Mode | $\mathrm{t}_{\text {RT2 }}$ | - | $8197 \cdot t_{\text {CY }}$ | $8200 \cdot \mathrm{t}_{\mathrm{Cr}}$ |
| $\mathrm{V}_{\text {cc }}$ Hold Time |  | $\mathrm{t}_{\text {PD }}$ | $5 \cdot t_{C Y}$ | - | - |
| $\mathrm{V}_{\text {cc }}$ Setup Time |  | $t_{\text {PS }}$ | $5 \cdot \mathrm{t}_{C Y}$ | - | - |

## Timing Diagram

Figure 13. Standby Operation Timing (1)

INTERNAL PROGRAM MEMORY OPERATION


## Timing Diagram

(Continued)
Figure 14. Standby Operation Timing (2)

EXTERNAL PROGRAM MEMORY OPERATION


Oscillation Circuits

Crystal Oscillator

*Including stray capacitances

External Clock Drive

*Both high and low times should be more than $35 \%$ of the cycle time, and the rise and fall times should be less than 20ns.

## Package Dimensions

Dimensions in inches (millimeters)

40-Lead Ceramic
(Metal Seal)
Dual In-Line Package
(Case No.: DIP-40G-A01)

© 1986 FUJITSU LIMITED D40006S-1C

## 40-Lead Plastic

Dual In-Line Package
(Case No.: DIP-40P-M01)

© 1985 FUJITSU LIMITED D40005S-1C

## 48-Lead Plastic

Flat Package
(CASE NO.FPPT-48P-M02)


Dimensions in inches (millimeters)

## NMOS INPUT/OUTPUT EXPANDER

The Fujitsu MBL 8243 is an input/output expander designed specifically to provide a low cost means of I/O expansion for the MBL 8048 series of single-chip microcomputers. Fabricated in 5 volts NMOS, the MBL 8243 combines low cost single supply voltage and high drive current capability. Also, the MBL 8243 is packaged in a 24 -pin cerdip or plastic DIP package.

The MBL 8243 consists of four 4-bit bidirectional static I/O ports and one 4-bit port which serves as an interface to the MBL 8048 series microcomputers. The 4-bit interface requires that only 4 I/O lines of the MBL 8048/8049/ 80C49/8749 be used for I/O expansion, and also allows multiple MBL 8243's to be added to the same bus.

The I/O ports of the MBL 8243 serve as a direct extension of the resident I/O facilities of the MBL 8048 series microcomputers and are accessed by their own MOVD. ANLD, and ORLD instructions.

## FEATURES

- Simple Interface to Fujitsu MBL 8048 Series and Intel MCS-48*
- Four 4-Bit I/O Ports.
- AND and OR Directly to Ports.
- High Current Drive: 5 mA at 0.45 V

20 mA at 1.0 V

## - On-Chip Power-On Reset Circuit.

- Single +5 V Power Supply.
- N-Channel Silicon-Gate E/D MOS Process.
- Two Package Options:
—Standard 24-pin Cerdip (Suffix: Z)
-Standard 24-pin Plastic DIP (Suffix: M)
- Pin-Compatible with Intel 8243 and Fujitsu MBL 82C43.

[^29]

Fig. 1 - PIN ASSIGNMENT


This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

Fig. 2 - LOGIC SYMBOL


Fig. 3 - BLOCK DIAGRAM


## PIN DESCRIPTION

The MBL 8243 has two interfaces: One is the processor interface; $\overline{C S}$, PROG, and Port 2, which are used for the processor to communicate with the MBL 8243 device. Another is the expansion I/O ports; Ports 4, 5, 6, and 7, which serve as an expansion of the processor's I/O.
Tabie 1-Pin Description

| Symbol | Pin No. | Type | Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ | 24 | - | +5 V supply. |
| GND | 12 | - | 0 V supply. |
| $\overline{\mathrm{CS}}$ | 6 | 1 | Chip Select input: A high on $\overline{\mathrm{CS}}$ inhibits any change of output or internal status. |
| PROG | 7 | 1 | Clock input: A high-to-low transition on PROG signifies that address and control are available on P20-P23, and a low-to-high transition signifies that data is available on P20-P23. |
| $\mathrm{P} 20-\mathrm{P} 23$ | 11 to 8 | 1/0 | Port 2: Four (4) bit bi-directional port contains the address and control bits on a high-to-low transition of PROG. During a low-tohigh transition contains the data for a selected output port if a write operation, or the data from a selected port before the low-tohigh transition if a read operation. |
| $\begin{aligned} & P 40-P 43 \\ & P 50 \text { - P53 } \\ & \text { P60 - P63 } \\ & \text { P70 - P73 } \end{aligned}$ | $\begin{gathered} 2 \text { to } 5 \\ 1,23 \text { to } 21 \\ 20 \text { to } 17 \\ 13 \text { to } 16 \end{gathered}$ | 1/0 | Ports 4, 5, 6, and 7: Four (4) bit bi-directional I/O ports. May be programmed to be input (during read), low impedance latched output (after write), or a tri-state (after read). Data on pins P20P23 may be directly written. ANDed or ORed with previous data. |

## FUNCTIONAL DESCRIPTION

## GENERAL OPERATION

The MBL 8243 contains four 4-bit I/O ports which serve as an extension of the on-chip I/O and are addressed as ports 4-7. The following operations may be performed on these ports:

- Transfer Accumulator to Port.
- Transfer Port to Accumulator.
- AND Accumulator to Port.
- OR Accumulator to Port.

All communication between the MBL 8048 series and the MBL 8243 occurs over Port 2 (P20-P23) with timing provided by an output pulse on the PROG pin of the processor. Each transfer consists of two 4-bit nibbles:
The first containing the "op code" and port address and the second containing the actual 4 -bits of data. A high-tolow transition of the PROG line indicates that address is present while a low-to-high transition indicates the presence of data. Additional MBL 8243's may be added to the 4-bit bus and chip selected using additional output lines from the MBL 8048 series microcomputers.

## POWER ON INITIALIZATION

Initial application of power to the device forces input/ output ports $4,5,6$, and 7 to the tri-state and port 2 to the input mode. The PROG pin may be either high or low when power is applied. The first high-to-low transition of PROG causes device to exit power on mode. The power on sequence is initiated if $\mathrm{V}_{\mathrm{CC}}$ drops below 1 V .

| P21 | P20 | Address <br> Code | P23 | P22 | Instruction <br> Code |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Port 4 | 0 | 0 | Read |
| 0 | 1 | Port 5 | 0 | 1 | Write |
| 1 | 0 | Port 6 | 1 | 0 | ORLD |
| 1 | 1 | Port 7 | 1 | 1 | ANLD |

## WRITE MODES

The device has three write modes. MOVD Pi, A directly writes new data into the selected port and old data is lost. ORLD Pi, A takes new data, OR's it with the old data and then writes it to the port. ANLD Pi, A takes new data, AND's it with the old data and then writes it to the port. Operation code and port address are latched from the input port 2 on the high-to-low transition of the PROG pin. On the low-to-high transition of PROG data on port 2 is transferred
to the logic block of the specified output port.
After the logic manipulation is performed, the data is latched and outputed. The old data remains latched until new valid outputs are entered.

## READ MODE

The device has one read mode. The operation code and port address are latched from the input port 2 on the high-to-low transition of the PROG pin. As soon as the read operation and port address are decoded, the appropriate outputs are tri-stated, and the input buffers switched on. The read operation is terminated by a low-to-high transition of the PROG pin. The port ( $4,5,6$ or 7 ) that was selected is switched to the tri-stated mode while port 2 is returned to the input mode.
Normally, a port will be in an output (write mode) or input (read mode). If modes are changed during operation, the first read following a write should be ignored; all following reads are valid. This is to allow the external driver on the port to settle after the first read instruction removes the low impedance drive from the MBL 8243 output. A read of any port will leave that port in a high impedance state.

## SINK CAPABILITY

The MBL 8243 can sink 5 mA at 0.45 V on each of its 16 I/O lines simultaneously. If, however, all lines are not sinking simultaneously or all lines are not fully loaded, the drive capability of any individual line increases as is shown by the accompanying curve.

Fig. $4-\Sigma \mathrm{I}_{\mathrm{OL}}$ vs $\mathrm{I}_{\mathrm{OL}}$ (at $\mathrm{V}_{\mathrm{OL}} \leqq 0.45 \mathrm{~V}$ )


For example, if only 5 of the 16 lines are to sink current at one time, the curve shows that each of those 5 lines is capable of sinking 9 mA at 0.45 V (if any lines are to sink 9 mA the total $\mathrm{I}_{\mathrm{OL}}$ must not exceed 45 mA or five 9 mA loads).

Example: How many pins can drive 5 TTL loads ( 1.6 mA ) assuming remaining pins are unloaded?
$\mathrm{I}_{\mathrm{OL}}=5 \times 1.6 \mathrm{~mA}=8 \mathrm{~mA}$
$\Sigma I_{\mathrm{OL}}=60 \mathrm{~mA}$ from curve
$\#$ pins $=60 \mathrm{~mA} \div 8 \mathrm{~mA} /$ pin $=7.5=7$
In this case, 7 lines can sink 8 mA for a total of 56 mA . This leaves 4 mA sink current capability which can be divided in any way among the remaining 8 I/O lines of the MBL 8243.

Example: This example shows how the use of the 20 mA sink capability of Port 7 affects the sinking capability of the other I/O lines.

An MBL 8243 will drive the following loads simultaneously.

2 loads -20 mA at 1 V (port 7 only)
8 loads -4 mA at 0.45 V
6 loads -3.2 mA at 0.45 V
Is this within the specified limits?
$\Sigma I_{\text {OL }}=(2 \times 20)+(8 \times 4)+(6 \times 3.2)=91.2 \mathrm{~mA}$. From the curve: for $I_{\mathrm{OL}}=4 \mathrm{~mA} . \Sigma \mathrm{I}_{\mathrm{OL}} \approx 93 \mathrm{~mA}$. since $91.2 \mathrm{~mA}<93 \mathrm{~mA}$ the loads are within specified limits.

Although the 20 mA at 1 V loads are used in calculating $\Sigma \mathrm{I}_{\mathrm{OL}}$, it is the largest current required at 0.45 V which determines the maximum allowable $\Sigma \mathrm{I}_{\mathrm{OL}}$.

## TYPICAL APPLICATION

Fig. 5 - I/O EXPANDER INTERFACE


Fig. 6 - MULTIPLE I/O EXPANDER INTERFACE


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Rating | Unit |
| :--- | :--- | :--- | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{GND}-0.3$ to GND+7.0 | V |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | $\mathrm{GND}-0.3$ to GND+7.0 |  |
| Ambient Temperature <br> under Bias | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 |  |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 1 | W |

## NOTE:

Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to ABSOLUTE MAXIMUM RATINGS conditions for extended periods may affect device reliability.

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | +5 $\pm 10 \%$ | V |
|  | GND | 0 |  |
| Operating Temperature | $\mathrm{T}_{\text {A }}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

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

| Parameter | Symbol | Conditions | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. | Max. |  |
| Input Low Voltage | $V_{\text {IL }}$ |  | GND-0.3 |  | 0.8 | V |
| Input High Voltage | $V_{1 H}$ |  | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |
| Output Low Voltage | $\mathrm{V}_{\text {OL1 }}$ | Ports 4 to 7 $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}$ |  |  | 0.45 | V |
|  | $\mathrm{V}_{\text {OL2 }}$ | Ports 4 to 7 $\mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA}$ |  |  | 1.0 | V |
|  | $\mathrm{V}_{\text {OL3 }}$ | Port 2 $\mathrm{I}_{\mathrm{OL}}=0.6 \mathrm{~mA}$ |  |  | 0.45 | V |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH} 1}$ | Ports 4 to 7 $\mathrm{I}_{\mathrm{OH}}=-240 \mu \mathrm{~A}$ | 2.4 |  |  | V |
|  | $\mathrm{V}_{\mathrm{OH} 2}$ | Port 2 $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ | 2.4 |  |  | V |
| Input Leakage Current | IIL1 | $\begin{aligned} & \text { Ports } 4 \text { to } 7 \\ & \mathrm{GND} \leqq \mathrm{~V}_{\mathrm{IN}} \leqq \mathrm{~V}_{\mathrm{CC}} \\ & \hline \end{aligned}$ | -10 |  | 20 | $\mu \mathrm{A}$ |
|  | $I_{\text {IL2 }}$ | Port 2, $\overline{\mathrm{CS}}, \mathrm{PROG}$ <br> GND $\leqq V_{\text {IN }} \leqq V_{C C}$ | -10 |  | 10 | $\mu \mathrm{A}$ |
| Total IOL of 16 Output | $\Sigma \mathrm{I}_{\text {OL }}$ | $\mathrm{I}_{\text {OUT }}=5 \mathrm{~mA}$ at each pin of Ports 4 to 7 |  |  | 80 | mA |
| Supply Current | $\mathrm{I}_{\mathrm{cc}}$ |  |  | 10 | 20 | mA |

## AC CHARACTERISTICS

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

| Parameter | Symbol | Condition | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. | Max. |  |
| Address/Operation Code Setup Time | $\mathrm{t}_{\mathrm{A}}$ | $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ | 100 |  |  | ns |
| Address/Operation Code Hold Time | $\mathrm{t}_{\mathrm{B}}$ | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ | 60 |  |  | ns |
| Data Setup Time | ${ }^{\text {c }}$ | $C_{L}=80 \mathrm{pF}$ | 200 |  |  | ns |
| Data Hold Time | $\mathrm{t}_{\mathrm{D}}$ | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ | 20 |  |  | ns |
| Port 2 Floating Time | $\mathrm{t}_{\mathrm{H}}$ | $C_{L}=20 \mathrm{pF}$ | 0 |  | 150 | ns |
| PROG Pulse Width | $\mathrm{t}_{\mathrm{K}}$ |  | 700 |  |  | ns |
| $\overline{\mathrm{CS}}$ Setup/Hold Times | ${ }^{\text {t }}$ cs |  | 50 |  |  | ns |
| Ports 4 to 7 Output Delay Time | $\mathrm{t}_{\text {Po }}$ | $C_{L}=100 \mathrm{pF}$ |  |  | 700 | ns |
| Ports 4 to 7 Setup/Hold Times | $\mathrm{t}_{\text {LPI }}$ |  | 100 |  |  | ns |
| Port 2 Output Delay Time | ${ }^{t}$ ACC | $C_{L}=80 \mathrm{pF}$ |  |  | 650 | ns |

Fig. 7 - TIMING DIAGRAM


## PACKAGE DIMENSIONS

CERAMIC DIP (Suffix: Z)


## PACKAGE DIMENSIONS

PLASTIC DIP (Suffix: M)


## CMOS INPUT/OUTPUT EXPANDER

The Fujitsu MBL 82C43 is an input/output expander designed specifically to provide a low cost means of I/O expansion for the MBL 8048 series of single-chip microcomputers. Fabricated in 5 volts CMOS, the MBL 82C43 combines low cost single supply voltage and high drive current capability. Also, the MBL 82 C 43 is packaged in a 24 -pin cerdip, plastic DIP, or plastic flat package (SOP).

The MBL 82C43 consists of four 4-bit bidirectional static I/O ports and one 4-bit port which serves as an interface to the MBL 8048 series microcomputers. The 4 -bit interface requires that only 4 I/O lines of the MBL 8048/8049/ 80C49/8749 be used for I/O expansion, and also allows multiple MBL 82C43's to be added to the same bus.

The I/O ports of the MBL 82C43 serve as a direct extension of the resident I/O facilities of the MBL 8048 series microcomputers and are accessed by their own MOVD, ANLD, and ORLD instructions.

## FEATURES

- CMOS Version of Fujitsu MBL 8243.
- Simple Interface to Fujitsu MBL 8048 Series and Intel MCS-48*
- Four 4-Bit I/O Ports.
- AND and OR Directly to Ports.
- High Current Drive: 5 mA at 0.45 V

20 mA at 1.0 V

- On-Chip Power-On Reset Circuit
- Single +5 V Power Supply.
- Silicon-gate CMOS Process
- Three Package Options:
-Standard 24-pin Cerdip (Suffix:-CZ)
-Standard 24-pin Plastic DIP (Suffix:-P)
-Standard 24-pin Plastic SOP (Suffix:-PF)
- Pin-Compatible with Fujitsu MBL 8243 and Intel 8243.

[^30]


This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

Fig. 1 - LOGIC SYMBOL


Fig. 2 - BLOCK DIAGRAM


## PIN DESCRIPTION

The MBL 82C43 has two interfaces: One is the processor interface; $\overline{C S}$, PROG, and Port 2, which are used for the processor to communicate with the MBL 82C43 device. Another is the expansion I/O ports; Ports 4,5,6, and 7, which serve as an expansion of the processor'si/O.
Table 1-Pin Description

| Symbol | Pin No. | Type | Function |
| :--- | :---: | :---: | :--- |
| V Cc | 24 | - | +5 V supply. |
| GND | 12 | - | 0 V supply. |
| $\overline{\text { CS }}$ | 6 | 1 | Chip Select input: A high on CS inhibits any change of output or <br> internal status. |
| PROG | 7 | I | Clock input: A high-to-low transition on PROG signifies that address <br> and control are available on P20-P23, and a low-to-high transition <br> signifies that data is available on P20-P23. |
| P20 - P23 | 11 to 8 | I/O | Port 2: Four (4) bit bi-directional port contains the address and control <br> bits on a high-to-low transition of PROG. During a low-to-high transition <br> contains the data for a selected output port if a write operation, or the <br> data from a selected port before the low-to-high transition if a read <br> operation. |
| P40 - P43 <br> P50 - P53 <br> P60 - P63 <br> P70 - P73 | 1, 23 to 21 <br> 20 to 17 <br> 13 to 16 | I/O | Ports 4, 5, 6, and 7: Four (4) bit bi-directional I/O ports. May be <br> programmed to be input (during read), low impedance latched output <br> (after write), or a tri-state (after read). Data on pins P20-P23 may be <br> directly written, ANDed or ORed with previous data. |

## MBL 82C43

## FUNCTIONAL DESCRIPTION

## general operation

The MBL 82C43 contains four 4-bit I/O ports which serve as an extension of the on-chip I/O and are addressed as ports 4-7. The following operations may be performed on these ports:

- Transfer Accumulator to Port.
- Transfer Port to Accumulator.
- AND Accumulator to Port.
- OR Accumulator to Port.

All communication between the MBL 8048 series and the MBL 82C43 occurs over Port 2 (P20 - P23) with timing provided by an output pulse on the PROG pin of the processor. Each transfer consists of two 4-bit nibbles:

The first containing the "op code" and port address and the second containing the actual 4-bits of data. A high-to-low transition of the PROG line indicates that address is present while a low-to-high transition indicates the presence of data. Additional MBL 82C43's may be added to the 4-bit bus and chip selected using additional output lines from the MBL 8048 series microcomputers.

## POWER ON INITIALIZATION

Initial application of power to the device forces input/output ports $4,5,6$, and 7 to the tri-state and port 2 to the input mode. The PROG pin may be either high or low when power is applied. The first high-to-low transition of PROG causes device to exit power on mode. The power on sequence is initiated if $\mathrm{V}_{\mathrm{CC}}$ drops below 1 V.

| P21 | P20 | Address <br> Code | P23 | P22 | Instruction <br> Code |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Port 4 | 0 | 0 | Read |
| 0 | 1 | Port 5 | 0 | 1 | Write |
| 1 | 0 | Port 6 | 1 | 0 | ORLD |
| 1 | 1 | Port 7 | 1 | 1 | ANLD |

## WRITE MODES

The device has three write modes. MOVD Pi, A directly writes new data into the selected port and old data is lost. ORLD Pi, A takes new data, OR's it with the old data and then writes it to the port. ANLD Pi, A takes new data, AND's it with the old data and then writes it to the port. Operation code and port address are latched from the input port 2 on the high-to-low transition of the PROG pin. On the low-to-high transition of PROG data on port 2
is transferred to the logic block of the specified port.
After the logic manipulation is performed, the data is latched and outputed. The old data remains latched until new valid outputs are entered.

## READ MODE

The device has one read mode. The operation code and port address are latched from the input port 2 on the high-to-low transition of the PROG pin. As soon as the read operation and port address are decoded, the appropriate outputs are tri-stated, and the input buffers switched on. The read operation is terminated by a low-to-high transition of the PROG pin. The port (4,5,6 or 7) that was selected is switched to the tri-stated mode while port 2 is returned to the input mode.

Normally, a port will be in an output (write mode) or input (read mode). If modes are changed during operation, the first read following a write should be ignored; all following reads are valid. This is to allow the external driver on the port to settle after the first read instruction removes the low impedance drive from the MBL 82C43 output. A read of any port will leave that port in a high impedance state.

## SINK CAPABILITY

The MBL 82 C 43 can sink 5 mA at 0.45 V on each of its 16 I/O lines simultaneously. If, however, all lines are not sinking simultaneously or all lines are not fully loaded, the drive capability of any individual line increases as is shown by the accompanying curve.


For example, if only 5 of the 16 lines are to sink current at one time, the curve shows that each of those 5 lines is capable of sinking 9 mA at 0.45 V (if any lines are to sink 9 mA the total $\mathrm{I}_{\mathrm{OL}}$ must not exceed 45 mA or five 9 mA loads).

Example: How many pins can drive 5 TTL loads ( 1.6 mA ) assuming remaining pins are unloaded?
$\mathrm{I}_{\mathrm{OL}}=5 \times 1.6 \mathrm{~mA}=8 \mathrm{~mA}$
$\Sigma \mathrm{I}_{\mathrm{OL}}=60 \mathrm{~mA}$ from curve
$\#$ pins $=60 \mathrm{~mA} \div 8 \mathrm{~mA} /$ pin $=7.5=7$
In this case, 7 lines can sink 8 mA for a total of 56 mA . This leaves 4 mA sink current capability which can be divided in any way among the remaining $8 \mathrm{I} / \mathrm{O}$ lines of the MBL 82C43.

Example: This example shows how the use of the 20 mA sink capability of Port 7 affects the sinking capability of the other I/O lines.

An MBL 82C43 will drive the following loads simultaneously.

2 loads -20 mA at 1 V (port 7 only)
8 loads -4 mA at 0.45 V
6 loads -3.2 mA at 0.45 V
Is this within the specified limits?
$\Sigma \mathrm{I}_{\mathrm{OL}}=(2 \times 20)+(8 \times 4)+(6 \times 3.2)=91.2 \mathrm{~mA}$. From the curve: for $\mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA} . \Sigma \mathrm{I}_{\mathrm{OL}} \approx 93 \mathrm{~mA}$. since $91.2 \mathrm{~mA}<93 \mathrm{~mA}$ the loads are within specified limits.

Although the 20 mA at 1 V loads are used in calculating $\Sigma \mathrm{I}_{\mathrm{OL}}$, it is the largest current required at 0.45 V which determines the maximum allowable $\Sigma I_{\text {OL }}$.

## TYPICAL APPLICATION

Fig. 4 - I/O EXPANDER INTERFACE


Fig. 5 - MULTIPLE I/O EXPANDER INTERFACE


MBL 82C43

## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Rating | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | GND -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | GND -0.3 to $+7.0^{*}$ |  |
| Ambient Temperature under Bias | $\mathrm{T}_{\mathrm{A}}$ | -40 to +85 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 |  |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 1 | W |

## NOTE:

Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to ABSOLUTE MAXIMUM RATINGS conditions for extended periods may affect device reliability.

* $\mathrm{V}_{\mathrm{IN}}$ should not exceed $\mathrm{V}_{\mathrm{cc}}+0.3 \mathrm{~V}$.


## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Value | Unit | Note |
| :--- | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | $+5 \pm 10 \%$ | V | Normal Operation |
|  |  | 3.5 to 6.0 |  | Standby Operation |
|  | GND | 0 | V |  |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ | -40 to +85 | ${ }^{\circ} \mathrm{C}$ |  |

## DC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Conditions | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| Input Low Voltage | $V_{\text {IL }}$ |  | GND -0.3 |  | 0.8 | V |
| Input High Voltage | $V_{\text {IH }}$ |  | 2.2 |  | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |
| Output Low Voltage | $\mathrm{V}_{\text {OL1 }}$ | Ports 4 to 7 $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}$ |  |  | 0.45 | V |
|  | $\mathrm{V}_{\text {OL2 }}$ | $\begin{aligned} & \text { Ports } 4 \text { to } 7 \\ & \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA} \\ & \hline \end{aligned}$ |  |  | 1.0 | V |
|  | $\mathrm{V}_{\text {OL3 }}$ | Port 2 $\mathrm{I}_{\mathrm{OL}}=0.6 \mathrm{~mA}$ |  |  | 0.45 | V |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH} 1}$ | Ports 4 to 7 $\mathrm{I}_{\mathrm{OH}}=-240 \mu \mathrm{~A}$ | 2.4 |  |  | V |
|  | $\mathrm{V}_{\mathrm{OH} 2}$ | Port 2 $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ | 2.4 |  |  | V |
| Input Leakage Current | IIL1 | Ports 4 to 7 $\mathrm{GND} \leqq \mathrm{~V}_{\mathrm{IN}} \leqq \mathrm{~V}_{\mathrm{CC}}$ | -10 |  | 20 | $\mu \mathrm{A}$ |
|  | IIL2 | Port 2, $\overline{C S}$, PROG $\mathrm{GND} \leqq \mathrm{~V}_{\mathrm{IN}} \leqq \mathrm{~V}_{\mathrm{CC}}$ | -10 |  | 10 | $\mu \mathrm{A}$ |
| Total $\mathrm{I}_{\text {OI }}$ of 16 Outputs | $\Sigma 1_{01}$ | $\mathrm{I}_{\text {OUT }}=5 \mathrm{~mA}$ at each piñ of Ports 4 to 7 |  |  | 80 | mA |
| Supply Current | $\mathrm{ICC1}$ | All outputs open, Normal operation |  | 200 | 600 | $\mu \mathrm{A}$ |
|  | $\mathrm{ICC2}$ | All outputs open, Standby operation |  | 1 | 10 | $\mu \mathrm{A}$ |

## AC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Condition | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| Address/Operation Code Setup Time | $\mathrm{t}_{\mathrm{A}}$ | $C_{L}=80 \mathrm{pF}$ | 100 |  |  | ns |
| Address/Operation Code Hold Time | $\mathrm{t}_{\mathrm{B}}$ | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ | 60 |  |  | ns |
| Data Setup Time | $\mathrm{t}_{\mathrm{C}}$ | $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ | 200 |  |  | ns |
| Data Hold Time | $\mathrm{t}_{\mathrm{D}}$ | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ | 20 |  |  | ns |
| Port 2 Floating Time | $\mathrm{t}_{\mathrm{H}}$ | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ | 0 |  | 150 | ns |
| PROG Pulse Width | $t_{k}$ |  | 700 |  |  | ns |
| $\overline{\mathrm{CS}}$ Setup/Hold Times | ${ }^{\text {c }}$ cs |  | 50 |  |  | ns |
| Ports 4 to 7 Output Delay Time | $\mathrm{t}_{\mathrm{PO}}$ | $C_{L}=100 \mathrm{pF}$ |  |  | 700 | ns |
| Ports 4 to 7 Setup/Hold Times | $\mathrm{t}_{\text {LPI }}$ |  | 100 |  |  | ns |
| Port 2 Output Delay Time | $\mathrm{t}_{\text {ACC }}$ | $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ |  |  | 650 | ns |

Fig. 6 - TIMING DIAGRAM


## PACKAGE DIMENSIONS

CERAMIC DIP (Suffix:-CZ)


## PACKAGE DIMENSIONS

PLASTIC DIP (Suffix:-P)


## PACKAGE DIMENSIONS

PLASTIC SOP (Suffix:-PF)


## Selector Guide

## 4-Bit

Microcomputers

## 4-Bit Microcontrollers and Peripherals

Table 1: FUJITSU 4-BIT MCU FAMILY

| Process/ <br> Series | $\begin{gathered} \text { ROM } \\ \text { Size } \\ \text { [bits] } \end{gathered}$ | $\begin{aligned} & \text { RAM } \\ & \text { Size } \\ & \text { [bits] } \end{aligned}$ | Device Number | Package ${ }^{1}$ | Device Number | Package |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NMOS <br> MB 8840 <br> Series | $\begin{aligned} & 2 K \times 8 \\ & 2 K \times 8 \\ & 1 K \times 8 \\ & 1 K \times 8 \end{aligned}$ | $\begin{array}{r} 128 \times 4 \\ 128 \times 4 \\ 64 \times 4 \\ 64 \times 4 \end{array}$ | MB 8841HM/-PSH MB 8842M/-PSH MB 8843M/-PSH MB 8844M/-PSH | DIP-42P-M01/M02 <br> DIP-28P-M02/M03 <br> DIP-42P-M01/M02 <br> DIP-28P-M02/M03 | MB 8845HM <br> MB 8846M <br> MB 8847M <br> MB 8848M | FPT-48P-M02 <br> FPT-48P-M02 <br> FPT-48P-M02 <br> FPT-48P-M02 |
| CMOS <br> MB 8850/H <br> MB 8850B <br> Series | $\begin{aligned} & 2 K \times 8 \\ & 2 K \times 8 \\ & 1 K \times 8 \end{aligned}$ | $\begin{array}{r} 128 \times 4 \\ 128 \times 4 \\ 64 \times 4 \end{array}$ | MB $8851 \mathrm{M} /-\mathrm{PSH}$ MB 8852M/-PSH MB 8854M/-PSH | DIP-42P-M01/M02 DIP-28P-M02/M03 DIP-28P-M02/M03 | MB 8855M MB 8856M MB 8858M | FPT-48P-M02 <br> FPT-48P-M02 <br> FPT-48P-M02 |
|  | $\begin{aligned} & 2 K \times 8 \\ & 2 K \times 8 \\ & 1 K \times 8 \end{aligned}$ | $\begin{array}{r} 128 \times 4 \\ 128 \times 4 \\ 64 \times 4 \end{array}$ | MB 8851AM/-PSH MB 8852AM/-PSH MB 8854AM/-PSH | DIP-42P-M01/M02 <br> DIP-28P-M02/M03 <br> DIP-28P-M02/M03 | MB 8855AM MB 8856AM MB 8858AM | FPT-48P-M02 <br> FPT-48P-M02 <br> FPT-48P-M02 |
|  | $\begin{aligned} & 2 K \times 8 \\ & 2 K \times 8 \\ & 1 K \times 8 \end{aligned}$ | $\begin{array}{r} 128 \times 4 \\ 128 \times 4 \\ 64 \times 4 \end{array}$ | MB $8851 \mathrm{LM} /$-PSH MB 8852LM/-PSH MB 8854LM/-PSH | DIP-42P-M01/M02 <br> DIP-28P-M02/M03 <br> DIP-28P-M02/M03 | MB 8855LM MB 8856LM MB 8858LM | FPT-48P-M02 <br> FPT-48P-M02 <br> FPT-48P-M02 |
|  | 2K $\times 8$ | $128 \times 4$ | MB 8851HM/-PSH | DIP-42P-M01/M02 | MB 8855HM | FPT-48P-M02 |
|  | 2K x 8 | $128 \times 4$ | MB 8851B-P3 | DIP-42P-M01 | MB 8855B-P ${ }^{3}$ | FPT-48P-M02 |
| CMOS <br> MB 88200/H <br> MB 88200B <br> Series | $\begin{aligned} & 512 \times 8 \\ & 1 K \times 8 \end{aligned}$ | $\begin{aligned} & 16 \times 4 \\ & 32 \times 4 \end{aligned}$ | $\begin{aligned} & \text { MB 88201-P } \\ & \text { MB 88202-P } \end{aligned}$ | $\begin{aligned} & \text { DIP-16P-M02 } \\ & \text { DIP-16P-M02 } \end{aligned}$ | MB 88201-PF MB 88202-PF | FPT-16P-M03 <br> FPT-16P-M03 |
|  | $\begin{aligned} & 512 \times 8 \\ & 1 K \times 8 \end{aligned}$ | $\begin{aligned} & 16 \times 4 \\ & 32 \times 4 \end{aligned}$ | MB 88201A-P MB 88202A-P | $\begin{aligned} & \text { DIP-16P-M02 } \\ & \text { DIP-16P-M02 } \end{aligned}$ | MB 88201A-PF MB 88202A-PF | FPT-16P-M03 FPT-16P-M03 |
|  | $\begin{aligned} & 512 \times 8 \\ & 1 K \times 8 \end{aligned}$ | $\begin{aligned} & 16 \times 4 \\ & 32 \times 4 \end{aligned}$ | MB 88201H-P MB 88202H-P | $\begin{aligned} & \text { DIP-16P-M02 } \\ & \text { DIP-16P-M02 } \end{aligned}$ | MB 88201H-PF MB 88202H-PF | FPT-16P-M03 <br> FPT-16P-M03 |
|  | $1 \mathrm{~K} \times 8$ | $32 \times 4$ | *MB 88205B-P ${ }^{3}$ | DIP-28P-M02 | - | - |
| CMOS <br> MB 88210 <br> Series | $1 \mathrm{~K} \times 8$ | $32 \times 4$ | MB 88211-P4 | DIP-20P-M02 | - | - |
| NMOS <br> MB 88400/H <br> Series | 4K $\times 8$ | $192 \times 4$ | MB 88401-P/-PSH | DIP-42P-M01/M02 | MB 88401-PF | FPT-48P-M02 |
|  | $\begin{aligned} & 4 K \times 8 \\ & 2 K \times 8 \end{aligned}$ | $\begin{aligned} & 256 \times 4 \\ & 256 \times 4 \end{aligned}$ | MB 88401H-P/-PSH MB 88403H-P/-PSH | $\begin{aligned} & \text { DIP-42P-M01/M02 } \\ & \text { DIP-42P-M01/M02 } \end{aligned}$ | MB 88401H-PF MB 88403H-PF | FPT-48P-M02 <br> FPT-48P-M02 |
| NMOS <br> MB 88410/H <br> Series | $\begin{aligned} & 4 K \times 8 \\ & 2 K \times 8 \end{aligned}$ | $\begin{aligned} & 192 \times 4 \\ & 192 \times 4 \end{aligned}$ | $\begin{aligned} & \text { MB 88411-P/-PSH }{ }^{4} \\ & \text { MB 88413-P/-PSH } \end{aligned}$ | $\begin{aligned} & \text { DIP-42P-M01/M02 } \\ & \text { DIP-42P-M01/M02 } \end{aligned}$ | $\begin{aligned} & \text { MB 88411-PF } \\ & \text { MB 88413-PF } \end{aligned}$ | FPT-48P-M02 <br> FPT-48P-M02 |
|  | $\begin{array}{r} 4 K \times 8 \\ 2 K \times 8 \end{array}$ | $\begin{aligned} & 256 \times 4 \\ & 256 \times 4 \end{aligned}$ | MB $88411 \mathrm{H}-\mathrm{P} /-\mathrm{PSH}^{4}$ MAB $88413 \mathrm{H}-\mathrm{P} /-\mathrm{PSH}^{4}$ | DIP-42P-M01/M02 Dif-42F-iviûi/iviûz | MB $88411 \mathrm{H}-\mathrm{PF}^{4}$ Vivis $88413 \mathrm{H} \cdot \mathrm{PF}^{4}$ | FPT-48P-M02 <br> FPT-48P-M02 |
| NMOS <br> MB 88420/H <br> Series | $\begin{aligned} & 4 K \times 8 \\ & 3 K \times 8 \\ & 2 K \times 8 \end{aligned}$ | $\begin{aligned} & 192 \times 4 \\ & 192 \times 4 \\ & 128 \times 4 \end{aligned}$ | MB 88421-PSH ${ }^{5}$ MB 88422-PSH ${ }^{5}$ MB 88423-PSH ${ }^{5}$ | $\begin{aligned} & \text { DIP-64P-M01 } \\ & \text { DIP-64P-M01 } \\ & \text { DIP-64P-M01 } \end{aligned}$ | - | - |
|  | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | MB $88421 \mathrm{H}-\mathrm{PSH}^{5}$ | DIP-64P-M01 | - | - |

$\left.\begin{array}{ccccccccccc|}\hline \begin{array}{c}\text { Maximum } \\ \text { Input } \\ \text { Only } \\ \text { Ports }\end{array} & \begin{array}{c}\text { Maximum } \\ \text { Output } \\ \text { Only } \\ \text { Ports }\end{array} & \begin{array}{c}\text { Maximum } \\ \text { l/O } \\ \text { Ports }\end{array} & \begin{array}{c}\text { Maximum } \\ \text { Control } \\ \text { Ports }\end{array} & \begin{array}{c}\text { Supply } \\ \text { Voltage }\end{array} & \begin{array}{c}\text { Typical } \\ \text { Power } \\ \text { Dissipation } \\ \text { [mW] }\end{array} & \begin{array}{c}\text { Number } \\ \text { of } \\ \text { Instruc- } \\ \text { tions }\end{array} & \begin{array}{c}\text { Minimum } \\ \text { Instruction } \\ \text { Cycle Time } \\ \text { [ } \mu \mathrm{s}]\end{array} & \begin{array}{c}\text { Maximum } \\ \text { Clock } \\ \text { Frequency }\end{array} \\ \text { [MHz] }\end{array} \quad \begin{array}{c}\text { Process/ } \\ \text { Series }\end{array}\right]$

Table 1: (Continued)

| Process/ Series | $\begin{aligned} & \text { ROM } \\ & \text { Size } \\ & {[\text { bits] }} \end{aligned}$ | $\begin{aligned} & \text { RAM } \\ & \text { Size } \\ & \text { [bits] } \end{aligned}$ | Device Number | Package ${ }^{1}$ | Device Number | Package |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMOS <br> MB 88500/H <br> Series | $\begin{aligned} & 4 K \times 8 \\ & 4 K \times 8 \\ & 2 K \times 8 \end{aligned}$ | $\begin{aligned} & 192 \times 4 \\ & 256 \times 4 \\ & 256 \times 4 \end{aligned}$ | MB 88501-P/-PSH MB 88505-P/-PSH MB 88507-P/-PSH | DIP-42P-M01/M02 DIP-42P-M01/M02 DIP-42P-M01/M02 | MB 88501-PF MB 88505-PF MB 88507-PF | FPT-48P-M02 <br> FPT-48P-M02 <br> FPT-48P-M02 |
|  | $\begin{aligned} & 4 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | $\begin{aligned} & 192 \times 4 \\ & 256 \times 4 \end{aligned}$ | MB 88501A-P/-PSH MB 88505A-P/-PSH | $\begin{aligned} & \text { DIP-42P-M01/M02 } \\ & \text { DIP-42P-M01/M02 } \end{aligned}$ | MB 88501A-PF MB 88505A-PF | FPT-48P-M02 <br> FPT-48P-M02 |
|  | $\begin{aligned} & 4 K \times 8 \\ & 2 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | $256 \times 4$ $256 \times 4$ <br> $256 \times 4$ | MB 88501H-P/-PSH MB 88503H-P/-PSH MB 88505H-P/-PSH | DIP-42P-M01/M02 DIP-42P-M01/M02 DIP-42P-M01/M02 | MB 88501H-PF MB 88503H-PF MB 88505H-PF | FPT-48P-M02 <br> FPT-48P-M02 <br> FPT-48P-M02 |
| CMOS <br> MB 88510 <br> MB 88510B <br> Series | $\begin{aligned} & 4 K \times 8 \\ & 2 K \times 8 \end{aligned}$ | $\begin{aligned} & 256 \times 4 \\ & 192 \times 4 \end{aligned}$ | *MB 88511-P/-PSH ${ }^{4}$ <br> *MB 88513-P/-PSH ${ }^{4}$ | $\begin{aligned} & \text { DIP-42P-M01/M02 } \\ & \text { DIP-42P-M01/M02 } \end{aligned}$ | *MB 88511-PF ${ }^{4}$ <br> * MB 88513-PF ${ }^{4}$ | FPT-48P-M02 <br> FPT-48P-M02 |
|  | $\begin{aligned} & 6 K \times 8 \\ & 8 K \times 8 \\ & 4 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | $\begin{aligned} & 256 \times 4 \\ & 256 \times 4 \\ & 256 \times 4 \\ & 256 \times 4 \end{aligned}$ | $\begin{aligned} & \text { MB 88514B-PSH } H^{345} \\ & \text { MB 88515B-PSH } \\ & \text { MB 88516B-PSH } \\ & \text { MB 88517B-P }{ }^{344} \end{aligned}$ | DIP-64P-M01 <br> DIP-64P-M01 <br> DIP-64P-M01 <br> DIP-42P-M01 | - - - - | - - - - |
| CMOS <br> MB 88520 <br> MB 88520B <br> Series | $\begin{aligned} & 4 K \times 8 \\ & 4 K \times 8 \\ & 2 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | $\begin{aligned} & 256 \times 4 \\ & 256 \times 4 \\ & 256 \times 4 \\ & 256 \times 4 \end{aligned}$ | MB 88521-PSH ${ }^{5}$ <br> * MB 88522- $\mathrm{PSH}^{5}$ <br> MB 88523-PSH ${ }^{5}$ <br> MB 88525-PSH ${ }^{5}$ | DIP-64P-M01 <br> DIP-64P-M01 <br> DIP-64P-M01 <br> DIP-64P-M01 | $\begin{gathered} \text { MB 88521-PF } \\ - \\ \text { MB } 88523 \cdot P^{5} \end{gathered}$ | $\begin{aligned} & \text { FPT-64P-M01 } \\ & \text { FPT-64P-M01 } \end{aligned}$ |
|  | $4 K \times 8$ | $256 \times 4$ | MB 88525B-PSH ${ }^{35}$ | DIP-64P-M01 | MB 88525B-PF ${ }^{35}$ | FPT-64P-M01 |
| CMOS <br> MB 88530 <br> Series | $\begin{aligned} & 2 K \times 8 \\ & 2 K \times 8 \end{aligned}$ | $\begin{aligned} & 128 \times 4 \\ & 128 \times 4 \end{aligned}$ | $\begin{aligned} & \text { MB 88535-P/-PSH }{ }^{6} \\ & \text { MB 88536-P/-PSH } \end{aligned}$ | $\begin{aligned} & \text { DIP-42P-M01/M02 } \\ & \text { DIP-42P-M01/M02 } \end{aligned}$ | $\begin{aligned} & \text { MB 88535-PF }{ }^{6} \\ & \text { MB 88536-PF } \end{aligned}$ | FPT-48P-M02 FPT-48P-M02 |
| CMOS <br> MB 88540 <br> Series | $\begin{aligned} & 4 K \times 8 \\ & 4 K \times 8 \\ & 4 K \times 8 \\ & 4 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | $\begin{aligned} & 256 \times 4 \\ & 256 \times 4 \\ & 256 \times 4 \\ & 256 \times 4 \\ & 256 \times 4 \end{aligned}$ | - | - | MB 88541-PF ${ }^{7}$ <br> * MB 88543- $\mathrm{PF}^{7}$ <br> *MB 88544-PF ${ }^{7}$ <br> * MB 88545- $\mathrm{PF}^{7}$ <br> * $\mathrm{MB} 88546-\mathrm{PF}^{7}$ | FPT-70P-M01 <br> FPT-80P-M01 <br> FPT-80P-M01 <br> FPT-80P-M01 <br> FPT-80P-M01 |
| CMOS <br> MB 88550/H <br> Series | $\begin{aligned} & 8 K \times 8 \\ & 6 K \times 8 \end{aligned}$ | $\begin{aligned} & 256 \times 4 \\ & 256 \times 4 \end{aligned}$ | - | - | MB 88551-PF ${ }^{45}$ MB 88552-PF ${ }^{45}$ | FPT-80P-M01 <br> FPT-80P-M01 |
|  | $\begin{aligned} & 8 K \times 8 \\ & 6 K \times 8 \end{aligned}$ | $\begin{array}{r} 256 \times 4 \\ 256 \times 4 \end{array}$ | - | - | MB $88551 \mathrm{H}-\mathrm{PF}^{45}$ MB 88552H-PF ${ }^{45}$ | FPT-80P-M01 <br> FPT-80P-M01 |
| CMOS <br> MB 88560 <br> Series | $\begin{aligned} & 3 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | $\begin{aligned} & 192 \times 4 \\ & 255 \times 4 \end{aligned}$ | - | - | $\begin{aligned} & \text { MB 88561-PF } 478 \\ & { }^{\text {iviB } 88562-P F^{348}} \end{aligned}$ | FPT-80P-M01 FPT-80िP-iviūi |

Notes: 1. 28- and 42-pin DIP packages may be specified with standard 100 mil pin spacing [M or -P suffix as shown], or smalloutline 70 mil pin spacing [-PSH suffix]. The 64 -pin DIP is available in small-outline 70 mil pin spacing only [-PSH suffix].
2. When the on-chip prescaler is connected, the maximum external clock frequency can be doubled. A 4.194 MHz crystal can be used for MB 884XX or MB 885XX devices. (except MB 88530 series)
3. On-chip VFD driver port
4. On-chip A/D converter
5. Multiple I/O ports
8. On-chip PLL 2-138

* Under development

6. On-chip D/A converter
7. On-chip LCD driver

| Maximum Input Only Ports | Maximum Output Only Ports | Maximum <br> I/O <br> Ports | Maximum Control Ports | Supply Voltage | Typical Power Dissipation [mW] | Number of Instructions | Minimum Instruction Cycle Time [ $\mu \mathrm{s}$ ] | Maximum Clock Frequency ${ }^{2}$ [MHz] | Process/ Series |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 4 | 12 | 15 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 75 | 2.86 | 2.0 | CMOS <br> MB 88500/H <br> Series |
| 4 | 12 | 15 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 75 | 2.0 | 3.0 |  |
| 4 | 12 | 15 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 75 | 2.0 | 3.0 |  |
| 4 | 12 | 15 | 5 | 3.5 to 6.0 | 10 at 1 MHz | 75 | 2.86 | 2.0 |  |
| 4 | 12 | 15 | 5 | 3.5 to 6.0 | 10 at 1 MHz | 75 | 2.86 | 2.0 |  |
| 4 | 12 | 15 | 5 | $5.0 \pm 10 \%$ | 20 at 2 MHz | 76 | 1.5 | 4.0 |  |
| 4 | 12 | 15 | 5 | $5.0 \pm 10 \%$ | 20 at 2 MHz | 76 | 1.5 | 4.0 |  |
| 4 | 12 | 15 | 5 | $5.0 \pm 10 \%$ | 20 at 2 MHz | 76 | 1.5 | 4.0 |  |
| 0 | 0 | 34 | 5 | $5.0 \pm 10 \%$ | 15 at 1 MHz | 79 | 2.0 | 3.0 | CMOS <br> MB 88510 <br> MB 88510B <br> Series |
| 0 | 0 | 34 | 5 | $5.0 \pm 10 \%$ | 15 at 1 MHz | 79 | 2.0 | 3.0 |  |
| 0 | 25 | 29 | 5 | $5.0 \pm 10 \%$ | 15 at 1 MHz | 81 | 2.0 | 3.0 |  |
| 0 | 25 | 29 | 5 | $5.0 \pm 10 \%$ | 15 at 1 MHz | 81 | 2.0 | 3.0 |  |
| 0 | 17 | 26 | 5 | $5.0 \pm 10 \%$ | 15 at 1 MHz | 81 | 2.0 | 3.0 |  |
| 0 | 15 | 19 | 5 | $5.0 \pm 10 \%$ | 15 at 1 MHz | 81 | 2.0 | 3.0 |  |
| 4 | 8 | 40 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 80 | 2.0 | 3.0 | CMOS <br> MB 88520 <br> MB 88520B <br> Series |
| 4 | 8 | 40 | 5 | $5.0 \pm 10 \%$ | TBD | 80 | 2.0 | 3.0 |  |
| 4 | 8 | 40 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 80 | 2.0 | 3.0 |  |
| 4 | 8 | 40 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 80 | 2.0 | 3.0 |  |
| 4 | 32 | 16 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 79 | 2.0 | 3.0 |  |
| 4 | 8 | 17 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 70 | 3.0 | 2.0 | CMOS <br> MB 88530 <br> Series |
| 4 | 8 | 15 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 70 | 3.0 | 2.0 |  |
| 4 | 4 | 16 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 75 | 2.86 | 2.0 | CMOS <br> MB 88540 <br> Series |
| 4 | 4 | 16 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 76 | 2.0 | 3.0 |  |
| 4 | 4 | 24 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 80 | 2.0 | 3.0 |  |
| 4 | 4 | 16 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 76 | 2.0 | 3.0 |  |
| 4 | 4 | 24 | 5 | $5.0 \pm 10 \%$ | 10 at 1 MHz | 80 | 2.0 | 3.0 |  |
| 0 | 0 | 68 | 5 | $5.0 \pm 10 \%$ | 15 at 1 MHz | 82 | 2.0 | 3.0 | CMOS <br> MB 88550/H <br> Series |
| 0 | 0 | 68 | 5 | $5.0 \pm 10 \%$ | 15 at 1 MHz | 82 | 2.0 | 3.0 |  |
| 0 | 0 | 68 | 5 | $5.0 \pm 10 \%$ | 25 at 2 MHz | 82 | 1.5 | 4.0 |  |
| 0 | 0 | 68 | 5 | $5.0 \pm 10 \%$ | 25 at 2 MHz | 82 | 1.5 | 4.0 |  |
| 4 | 4 | 11 | 2 | $5.0 \pm 10 \%$ | 85 at 4.5 MHz | 70 | 6.67 | 4.5 | CMOS <br> MB 88560 <br> Series |
| 4 | 4 | 11 | 2 | $5.0 \pm 10 \%$ | TBD | 71 | 6.67 | 4.5 |  |

Table 2: FEATURES OPTIONS AVAILABLE ON THE FUJITSU 4-BIT MCU FAMILY

| Device Number | Process | ROM Size [bits] | RAM Size [bits] | Package | Ambient Temperature Range $\left[{ }^{\circ} \mathrm{C}\right]$ | Seriai Port Output Latch | Serial <br> Buffer | Nesting Levels |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MB 8841HM/-PSH | NMOS | 2K $\times 8$ | $128 \times 4$ | DIP | -30 to +70 | option | 4 | 4 |
| MB 8842M/-PSH | NMOS | 2K x 8 | $128 \times 4$ | DIP | -30 to +70 | no | 4 | 4 |
| MB 8843M/-PSH | NMOS | $1 \mathrm{~K} \times 8$ | $64 \times 4$ | DIP | -30 to +70 | option | 4 | 4 |
| MB 8844M/-PSH | NMOS | $1 \mathrm{~K} \times 8$ | $64 \times 4$ | DIP | -30 to +70 | no | 4 | 4 |
| MB 8845HM | NMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | FPT | -30 to +70 | option | 4 | 4 |
| MB 8846M | NMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | FPT | -30 to +70 | no | 4 | 4 |
| MB 8847M | NMOS | $1 \mathrm{~K} \times 8$ | $64 \times 4$ | FPT | -30 to +70 | option | 4 | 4 |
| MB 8848M | NMOS | $1 \mathrm{~K} \times 8$ | $64 \times 4$ | FPT | -30 to +70 | no | 4 | 4 |
| MB 8851M/-PSH | CMOS | $2 \mathrm{~K} \times 8$ | . $128 \times 4$ | DIP | -40 to +85 | option | 4 | 4 |
| MB 8851AM/-PSH | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | DIP | -30 to +70 | option | 4 | 4 |
| MB 8851B-P | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | DIP | -30 to +70 | option | 4 | 4 |
| MB $8851 \mathrm{HM} /$-PSH | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | DIP | -40 to +85 | option | 4 | 4 |
| MB 8851 LM/-PSH | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | DIP | -30 to +70 | option | 4 | 4 |
| MB 8852M/-PSH | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | DIP | -40 to +85 | no | 4 | 4 |
| MB 8852AM/-PSH | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | DIP | -30 to +70 | no | 4 | 4 |
| MB 8852LM/-PSH | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | DIP | -30 to +70 | no | 4 | 4 |
| MB 8854M/-PSH | CMOS | $1 \mathrm{~K} \times 8$ | $64 \times 4$ | DIP | -40 to +85 | no | 4 | 4 |
| MB 8854AM/-PSH | CMOS | $1 \mathrm{~K} \times 8$ | $64 \times 4$ | DIP | -30 to +70 | no | 4 | 4 |
| MB $8854 \mathrm{LM} /$-PSH | CMOS | $1 \mathrm{~K} \times 8$ | $64 \times 4$ | DIP | -30 to +70 | no | 4 | 4 |
| MB 8855M | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | FPT | -40 to +85 | option | 4 | 4 |
| MB 8855AM | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | FPT | -30 to +70 | option | 4 | 4 |
| MB 8855B-P | CMOS | 2K $\times 8$ | $128 \times 4$ | FPT | -30 to +70 | option | 4 | 4 |
| MB 8855HM | CMOS | 2K $\times 8$ | $128 \times 4$ | FPT | -40 to +85 | option | 4 | 4 |
| MB 8855LM | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | FPT | -30 to +70 | option | 4 | 4 |
| MB 8856M | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | FPT | -40 to +85 | no | 4 | 4 |
| MB 8856AM | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | FPT | -30 to +70 | no | 4 | 4 |
| MB 8856LM | CMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | FPT | -30 to +70 | no | 4 | 4 |
| MB 8858M | CMOS | $1 \mathrm{~K} \times 8$ | $64 \times 4$ | FPT | -40 to +85 | no | 4 | 4 |
| MB 8858AM | CMOS | $1 \mathrm{~K} \times 8$ | $64 \times 4$ | FPT | -30 to +70 | no | 4 | 4 |
| MB 8858LM | CMOS | $1 \mathrm{~K} \times 8$ | $64 \times 4$ | FPT | -30 to +70 | no | 4 | 4 |

FUJITSU


| Output Port Options ${ }^{1}$ | PLA <br> Output Port ${ }^{2}$ [bits] | Optional On-chip Prescaler | On-chip Clock Generator | Features | Device Number |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 5 | 4/8 | yes | yes | High speed | MB 8841HM/-PSH |
| 3 | 4/8 | yes | yes | Standard | MB 8842M/-PSH |
| 4 | 4/8 | yes | yes | Standard | MB 8843M/-PSH |
| 3 | 4/8 | yes | yes | Standard | MB 8844M/-PSH |
| 5 | 4/8 | yes | yes | High speed | MB 8845HM |
| 3 | 4/8 | yes | yes | Standard | MB 8846M |
| 4 | 4/8 | yes | yes | Standard | MB 8847M |
| 3 | 4/8 | yes | yes | Standard | MB 8848M |
| 2 | 4/8 | yes | yes | Standard | MB 8851M/-PSH |
| 2 | 4/8 | yes | yes | Wide voltage range | MB 8851AM/-PSH |
| 2 | 4/8 | yes | yes | VFD driver port [8 seg. $\times 8$ digits], high speed | MB 8851B-P |
| 4 | 4/8 | yes | yes | High speed | MB $8851 \mathrm{HM} /-\mathrm{PSH}$ |
| 2 | 4/8 | yes | yes | Low voltage | MB $8851 \mathrm{LM} /$-PSH |
| 2 | 4/8 | yes | yes | Standard | MB 8852M/-PSH |
| 2 | 4/8 | yes | yes | Wide voltage range | MB 8852AM/-PSH |
| 2 | 4/8 | yes | yes | Low voltage | MB 8852LM/-PSH |
| 2 | 4/8 | yes | yes | Standard | MB 8854M/-PSH |
| 2 | 4/8 | yes | yes | Wide voltage range | MB 8854AM/-PSH |
| 2 | 4/8 | yes | yes | Low voltage | MB 8854LM/-PSH |
| 2 | 4/8 | yes | yes | Standard | MB 8855M |
| 2 | 4/8 | yes | yes | Wide voltage range | MB 8855AM |
| 2 | 4/8 | yes | yes | VFD driver port [8 seg. $\times 8$ digits], high speed | MB 8855B-P |
| 4 | 4/8 | yes | yes | High speed | MB 8855HM |
| 2 | 4/8 | yes | yes | Low voltage | MB 8855LM |
| 2 | 4/8 | yes | yes | Standard | MB 8856M |
| 2 | 4/8 | yes | yes | Standard | MB 8856AM |
| 2 | 4/8 | yes | yes | Standard | MB 8856LM |
| 2 | 4/8 | yes | yes | Standard | MB 8858M |
| 2 | 4/8 | yes | yes | Wide voltage range | MB 8858AM |
| 2 | 4/8 | yes | yes | Low voltage | MB 8858LM |

Table 2: (Continued)

| Device Number | Process | ROM Size [bits] | RAM Size [bits] | Package | Ambient Temperature Range $\left[{ }^{\circ} \mathrm{C}\right]$ | Serial Port Output Latch | Serial Buffer | Nesting Levels |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MB 88201-P | CMOS | $512 \times 8$ | $16 \times 4$ | DIP | -40 to +85 | - | - | 2 |
| MB 88201-PF | CMOS | $512 \times 8$ | $16 \times 4$ | FPT | -40 to +85 | - | - | 2 |
| MB 88201A-P | CMOS | $512 \times 8$ | $16 \times 4$ | DIP | -30 to +70 | - | - | 2 |
| MB 88201A-PF | CMOS | $512 \times 8$ | $16 \times 4$ | FPT | -30 to +70 | - | - | 2 |
| MB 88201H.P | CMOS | $512 \times 8$ | $16 \times 4$ | DIP | -40 to +85 | - | - | 2 |
| MB 88201H-PF | CMOS | $512 \times 8$ | $16 \times 4$ | FPT | -40 to +85 | - | - | 2 |
| MB 88202-P | CMOS | $1 \mathrm{~K} \times 8$ | $32 \times 4$ | DIP | -40 to +85 | - | - | 4 |
| MB 88202-PF | CMOS | $1 \mathrm{~K} \times 8$ | $32 \times 4$ | FPT | -40 to +85 | - | - | 4 |
| MB 88202A-P | CMOS | $1 \mathrm{~K} \times 8$ | $32 \times 4$ | DIP | -30 to +70 | - | - | 4 |
| MB 88202A-PF | CMOS | $1 \mathrm{~K} \times 8$ | $32 \times 4$ | FPT | -30 to +70 | - | - | 4 |
| MB 88202H-P | CMOS | $1 \mathrm{~K} \times 8$ | $32 \times 4$ | DIP | -40 to +85 | - | - | 4 |
| MB 88202H-PF | CMOS | $1 \mathrm{~K} \times 8$ | $32 \times 4$ | FPT | -40 to +85 | - | - | 4 |
| *MB 88205B-P | CMOS | $1 \mathrm{~K} \times 8$ | $32 \times 4$ | DIP | -40 to +85 | - | - | 4 |
| MB 88211-P | CMOS | $1 \mathrm{~K} \times 8$ | $32 \times 4$ | DIP | 0 to +70 | - | - | 4 |
| MB 88401-P/-PSH | NMOS | $4 \mathrm{~K} \times 8$ | $192 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88401-PF | NMOS | $4 \mathrm{~K} \times 8$ | $192 \times 4$ | FPT | -30 to +70 | yes | 4 | 8 |
| MB 88401H-P/-PSH | NMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88401H-PF | NMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -30 to +70 | yes | 4 | 8 |
| MB 88403H-P/-PSH | NMOS | $2 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88403H-PF | NMOS | $2 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -30 to +70 | yes | 4 | 8 |
| MB 88411-P/-PSH | NMOS | $4 \mathrm{~K} \times 8$ | $192 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88411-PF | NMOS | $4 \mathrm{~K} \times 8$ | $192 \times 4$ | FPT | -30 to +70 | yes | 4 | 8 |
| MB 88411H-P/-PSH | NMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88411H-PF | NMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -30 to +70 | yes | 4 | 8 |
| MB 88413-P/-PSH | NMOS | $2 \mathrm{~K} \times 8$ | $192 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88413-PF | NMOS | $2 \mathrm{~K} \times 8$ | $192 \times 4$ | FPT | -30 to +70 | yes | 4 | 8 |
| MB 88413H-P/-PSH | NMOS | 2K x 8 | $256 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88413H-PF | NMOS | $2 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -30 to +70 | yes | 4 | 8 |
| MB 88421-PSH | NMOS | $4 \mathrm{~K} \times 8$ | $192 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| M̄B 88421H-PSH | NMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88422-PSH | NMOS | $3 \mathrm{~K} \times 8$ | $192 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88423-PSH | NMOS | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |


| Output <br> Port <br> Options | PLA <br> Output <br> Port | Optional <br> [bits] | On-chip <br> On-chip <br> Prescaler | Clock <br> Cenerator | Features |
| :---: | :---: | :---: | :---: | :---: | :---: |$\quad$ Device Number


| 4 | - | yes | yes | Low cost | MB 88201-P |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 4 | - | yes | yes | Low cost | MB 88201-PF |
| 4 | - | yes | yes | Wide voltage range | MB 88201A.P |
| 4 | - | yes | yes | Wide voltage range | MB 88201A-PF |
| 4 | - | yes | yes | High speed | MB 88201H-P |
| 4 | - | yes | yes | High speed | MB 88201H-PF |
| 4 | - | yes | yes | Low cost | MB 88202-P |
| 4 | - | yes | yes | Low cost | MB 88202-PF |
| 4 | - | yes | yes | Wide voltage range | MB 88202A-P |
| 4 | - | yes | yes | Wide voltage range | MB 88202A-PF |
| 4 | - | yes | yes | High speed | MB 88202H-P |
| 4 | - | yes | yes | High speed | MB 88202H-PF |
| 3 | - | yes | yes | Low cost, VFD driver port [8 seg. $\times 8$ digits] | *MB 88205B-P |
| 3 | - | yes (fixed) | yes | Low cost, A/D converter [ 8 bits $\times 1$ channel] | MB 88211-P |
| 3 | 4/8 | yes | yes | Standard | MB 88401-P/-PSH |
| 2 | 4/8 | yes | yes | Standard | MB 88401-PF |
| 4 | 4/8 | yes | yes | High speed | MB 88401H-P/-PSH |
| 4 | 4/8 | yes | yes | High speed | MB 88401H-PF |
| 4 | 4/8 | yes | yes | High speed, ROM 2K version | MB 88403H-P/-PSH |
| 4 | 4/8 | yes | yes | High speed, ROM 2K version | MB 88403H-PF |
| 3 | 4/8 | yes | yes | On-chip A/D converter [8 bits $\times 7$ channels] | MB 88411-P/-PSH |
| 2 | 4/8 | yes | yes | On-chip A/D converter [8 bits $\times 7$ channels] | MB 88411-PF |
| 4 | 4/8 | yes | yes | On-chip A/D converter [ 8 bits $\times 7$ channels], high speed | MB 88411H-P/-PSH |
| 4 | 4/8 | yes | yes | On-chip A/D converter [ 8 bits $\times 7$ channels], high speed | MB 88411H-PF |
| 3 | 4/8 | yes | yes | On-chip A/D converter [ 8 bits $\times 7$ channels], ROM 2 K version | MB 88413-P/-PSH |
| 2 | 4/8 | yes | yes | On-chip A/D converter [8 bits $\times 7$ channels], ROM 2 K version | MB 88413-PF |
| 4 | 4/8 | yes | yes | On-chip A/D converter [8 bits $\times 7$ channels], high speed, ROM 2 K version | MB 88413H-P/-PSH |
| 4 | 4/8 | yes | yes | On-chip A/D converter [ 8 bits $\times 7$ channels], high speed, ROM 2K version | MB 88413H-PF |
| 3 | 4 | yes | yes | Multiple I/O ports [57 1/O ports] | MB 88421-PSH |
| 5 | 4 | yes | yes | Multiple I/O ports [57, 1/O ports], high-speed | MB 88421H-PSH |
| 3 | 4 | yes | yes | Multiple I/O ports [57 I/O ports], ROM 3 K version | MB 88422-PSH |
| 3 | 4 | yes | yes | Multiple I/O ports [57 I/O ports], ROM 2 K version | MB 88423-PSH |

Table 2: (Continued)

| Device Number | Process | ROM Size [bits] | RAM Size [bits] | Package | Ambient Temperature Range $\left[{ }^{\circ} \mathrm{C}\right]$ | Serial Port Output Latch | Serial <br> Buffer | Nesting Levels |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MB 88501-P/-PSH | CMOS | $4 \mathrm{~K} \times 8$ | $192 \times 4$ | DIP | -40 to +85 | yes | 4 | 8 |
| MB 88501-PF | CMOS | $4 \mathrm{~K} \times 8$ | $192 \times 4$ | FPT | -40 to +85 | yes | 4 | 8 |
| MB 88501A-P/-PSH | CMOS | $4 \mathrm{~K} \times 8$ | $192 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88501 A-PF | CMOS | $4 \mathrm{~K} \times 8$ | $192 \times 4$ | FPT | -30 to +70 | yes | 4 | 8 |
| MB 88501H-P/-PSH | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -40 to +85 | yes | 4 | 8 |
| MB 88501H-PF | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -40 to +85 | yes | 4 | 8 |
| MB 88503H-P/-PSH | CMOS | $2 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -40 to +85 | yes | 4 | 8 |
| MB 88503H-PF | CMOS | $2 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -40 to +85 | yes | 4 | 8 |
| MB 88505-P/-PSH | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -40 to +85 | yes | 4/8 | 8 |
| MB 88505-PF | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -40 to +85 | yes | 4/8 | 8 |
| MB 88505A-P/-PSH | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -30 to +70 | yes | 4/8 | 8 |
| MB 88505A-PF | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -30 to +70 | yes | 4/8 | 8 |
| MB 88505H-P/-PSH | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -40 to +85 | yes | 4/8 | 8 |
| MB 88505H-PF | CMOS | 4K $\times 8$ | $256 \times 4$ | FPT | -40 to +85 | yes | 4/8 | 8 |
| MB 88507-P/-PSH | CMOS | $2 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -40 to - 85 | yes | 4/8 | 8 |
| MB 88507-PF | CMOS | 2K x 8 | $256 \times 4$ | FPT | -40 to +85 | yes | 4/8 | 8 |
| *MB 88511-P/-PSH | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -40 to +85 | yes | 4/8 | 8 |
| *MB 88511-PF | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -40 to +85 | yes | 4/8 | 8 |
| *MB 88513-P/-PSH | CMOS | 2K x 8 | $192 \times 4$ | DIP | -40 to +85 | yes | 4/8 | 8 |
| *MB 88513-PF | CMOS | 2K x 8 | $192 \times 4$ | FPT | -40 to +85 | yes | 4/8 | 8 |
| MB 88514B-PSH | CMOS | 6K x 8 | $256 \times 4$ | DIP | -40 to +85 | yes | 4/8 | 8 |
| MB 88515B-PSH | CMOS | $8 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -40 to +85 | yes | 4/8 | 8 |
| MB 88516B-PSH | cmos | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -40 to +85 | yes | 4/8 | 8 |
| MB 88517B-P | cmos | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -40 t0 +85 | yes | 4/8 | $\overline{\text { ® }}$ |
| MB 88521-PSH | cmos | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88521-PF | CMOS | 4K $\times 8$ | $256 \times 4$ | FPT | -30 to +70 | yes | 4 | 8 |


| Output <br> Port <br> Options | PLA <br> Output <br> Port <br> [bits] | Optional <br> On-chip <br> Prescaler | On-chip <br> Clock <br> Generator |  | Features |
| :---: | :---: | :--- | :--- | :--- | :--- |

Table 2: (Contined)

| Device Number | Process | $\begin{aligned} & \text { ROM } \\ & \text { Size } \\ & \text { [bits] } \end{aligned}$ | RAM Size [bits] | Package | Ambient Temperature Range $\left[{ }^{\circ} \mathrm{C}\right]$ | Serial Port Output Latch | Serial <br> Buffer | Nesting Levels |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| *MB 88522-PSH | CMOS | 4K $\times 8$ | $256 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88523-PSH | CMOS | $2 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -30 to +70 | yes | 4 | 8 |
| MB 88523-PF | CMOS | $2 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -30 to +70 | yes | 4 | 8 |
| MB 88525-PSH | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -30 to +70 | yes | 4/8 | 8 |
| MB 88525B-PSH | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | DIP | -30 to +70 | yes | 4/8 | 8 |
| MB 88525B-PF | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -30 to +70 | yes | 4/8 | 8 |
| MB 88535-P/-PSH ${ }^{3}$ | CMOS | 2K $\times 8$ | $128 \times 4$ | DIP | -30 to +70 | option | 4 | 4 |
| MB 88535-PF ${ }^{3}$ | cmos | $2 \mathrm{~K} \times 8$ | $128 \times 4$ | FPT | -30 to +70 | option | 4 | 4 |
| MB 88536-P/-PSH ${ }^{3}$ | CMOS | 2K $\times 8$ | $128 \times 4$ | DIP | -30 to +70 | option | 4 | 4 |
| MB 88536-PF ${ }^{3}$ | CMOS | 2K $\times 8$ | $128 \times 4$ | FPT | -30 to +70 | option | 4 | 4 |
| MB 88541-PF | cmos | 4K $\times 8$ | $256 \times 4$ | FPT | -40 to +85 | yes | 4 | 8 |
| *MB 88543-PF | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -40 to +85 | yes | 4/8 | 8 |
| *MB 88544-PF | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -40 to +85 | yes | 4/8 | 8 |
| *MB 88545-PF | cMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -40 to +85 | yes | 4/8 | 8 |
| *MB 88546-PF | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -40 to +85 | yes | 4/8 | 8 |


| Output <br> Port <br> Options | PLA <br> Output <br> Port $^{2}$ <br> [bits] | Optional <br> On-chip <br> Prescaler | On-chip <br> Clock <br> Generator | Features |
| :---: | :---: | :---: | :---: | :---: | :---: |

Table 2: (Continued)

| Device Number | Process | ROM Size [bits] | $\begin{aligned} & \text { RAM } \\ & \text { Size } \\ & \text { [bits] } \end{aligned}$ | Package | Ambient Temperature Range [ $\left.{ }^{\circ} \mathrm{C}\right]$ | Serial Port Output Latch | Serial Buffer | Nesting Levels |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MB 88551-PF | CMOS | $8 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -30 to +70 | yes | 4/8 | 8 |
| MB 88551H-PF | cmos | $8 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -30 to +70 | yes | 4/8 | 8 |
| MB 88552-PF | cmos | $6 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -30 to +70 | yes | 4/8 | 8 |
| MB 88552H-PF | CMOS | $6 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -30 to +70 | yes | 4/8 | 8 |
| MB 88561-PF | CMOS | $3 \mathrm{~K} \times 8$ | $192 \times 4$ | FPT | -40 to +85 | yes | - | 4 |
| *MB 88562-PF | CMOS | $4 \mathrm{~K} \times 8$ | $256 \times 4$ | FPT | -40 to +85 | yes | - | 4 |

## Notes:

1. Standard pull-up, high-current pull-up, standard open-drain, high-current open-drain, middle-current open-drain, high-voltage open-drain, and 12 V -interface open-drain output port configurations are available on certain devices.
2. " 4 " means dual 4 -bit parallel output, " 8 " means 8 -bit parallel output. Either option is available.
3. MB 8850 series device.

* Under development.

| Output <br> Port <br> Options | PLA <br> Output <br> Port <br> [bits] | Optional <br> On-chip <br> Prescaler | On-chip <br> Clock <br> Generator | Features | yes | On-chip A/D converter [5 bits $\times 4$ channels], <br> programmable pulse generator [9 bits $\times 1$ 1, <br> multiple I/O ports [68 I/O ports] |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- | MB 88551-PF

Table 3: PERIPHERAL INTEGRATED CIRCUITS FOR THE FUJITSU 4-BIT MCU FAMILY

| Process | Device Number | Function | Features |
| :---: | :---: | :---: | :---: |
| NMOS | MB 88301A-P | D/A Converter | Pulsewidth modulation type, 6-bit $\times 3 \mathrm{ch}$. 13-bit x 1 ch., 4 -bit data input |
|  | MB 88303-P | TV Display Controller [for TV/VCR] | 20 character $\times 9$ lines, $5 \times 7$ dot matrix, 64 character types, programmable character size/position/blink, parallel data input, character generator ROM |
|  | MB 88304-P | I/O Expander [open-drain output] | 4-bit $\times 4 \mathrm{ch}$. I/O ports, parallel/AND/OR I/O ports, power on reset |
|  | MB 88305-P | 1/O Expander [3 state output] | 4-bit x 4 ch . I/O ports, parallel/AND/OR I/O ports, power on reset |
| CMOS | MB 88306-P/-PF | Output Expander | Rising-edge-triggered shift clock input, 8 -bit CMOS data output, serial I/O |
|  | MB 88307-P/-PF | Output Expander | Rising-edge-triggered shift clock input, 8 -bit N-ch. open-drain data output, serial I/O |
|  | MB 88308-P/-PF | Output Expander | Falling-edge-triggered shift clock input, 8 -bit CMOS data output, serial I/O |
|  | MB 88309-P/-PF | Output Expander | Falling-edge-triggered shift clock input, 8 -bit N-ch. open-drain data output, serial I/O |
|  | MB 88310-P | I/O Expander [open-drain output] | CMOS version of MB 88304 |
|  | MB 88311-P | 1/O Expander [3 state output] | CMOS version of MB 88305 |
|  | MB 88313-P | TV Display Controller [for TV/VCR] | 16(8) characters $\times 1(2)$, line(s), $5 \times 7$ dot matrix, 32 character types, programmable character size/position/blink, serial data input, character generator ROM |
|  | *MB 88321-P | TV Display Controller [for TV, ROM version] | 20 characters $\times 9$ lines, $8 \times 8$ dot matrix, 64 character types, programmable character size/position/blink, serial data input, character generator ROM, RGB outputs |
|  | *MB 88322-P | TV Display Controller [for TV, RAM version] | Character generator RAM version of MB 88321 |
|  | MB 88323-P | TV Display Controller [for VCR, ROM version] | 20 characters $\times 9$ lines, $8 \times 8$ dot matrix, 64 character types, programmable character size/position/blink, serial data input, character generator ROAN, v́ \& 'i sync generation |
|  | MB 88324-P | TV Display Controller [for VCR, RAM version] | Character generator RAM version of MB 88323 |

[^31]| Package | Supply Voltage | Ambient Temperature Range $\left[{ }^{\circ} \mathrm{C}\right]$ | $\begin{gathered} \text { Typical } \\ \text { Operating } \\ \text { Clock Frequency } \\ {[\mathrm{MHz}]} \end{gathered}$ | Process |
| :---: | :---: | :---: | :---: | :---: |
| DIP-16P-M02 | $5.0 \pm 10 \%$ | -30 to +70 | 4.0 | NMOS |
| $\begin{aligned} & \text { DIP-22P-M02/ } \\ & \text { FPT-24P-M02 } \end{aligned}$ | $5.0 \pm 10 \%$ | -30 to +70 | 6.0 |  |
| DIP-24P-M01 | $5.0 \pm 10 \%$ | -30 to +70 | - |  |
| DIP-24P-M01 | $5.0 \pm 10 \%$ | -30 to +70 | - |  |
| DIP-16P-M02/ FPT-16P-M02 | $5.0 \pm 10 \%$ | -40 to +85 | 2.0 | CMOS |
| DIP-16P-M02/ <br> FPT-16P-M02 | $5.0 \pm 10 \%$ | -40 to +85 | 2.0 |  |
| DIP-16P-M02/ <br> FPT-16P-M02 | $5.0 \pm 10 \%$ | -40 to +85 | 2.0 |  |
| DIP-16P-M02/ FPT-16P-M02 | $5.0 \pm 10 \%$ | -40 to +85 | 2.0 |  |
| DIP-24P-M01 | $5.0 \pm 10 \%$ | -40 to +85 | - |  |
| DIP-24P-M01 | $5.0 \pm 10 \%$ | -40 to +85 | - |  |
| DIP-16P-M02/ <br> FPT-16P-M02 | $5.0 \pm 10 \%$ | -30 to +70 | 6.0 |  |
| DIP-22P-M02 | $5.0 \pm 10 \%$ | -30 to +70 | TBD |  |
| DIP-22P-M02 | $5.0 \pm 10 \%$ | -30 to +70 | TBD |  |
| DIP-22P-M02 | $5.0 \pm 10 \%$ | -30 to +70 | 7.16 |  |
| DIP-22P-M02 | $5.0 \pm 10 \%$ | -30 to +70 | 7.16 |  |

DIP-16P-M02
FPT-16P-M02

DIP-22P-M02

DIP-22P-M02

DIP-22P-M02

DIP-22P-M02
$5.0 \pm 10 \%$
-30 to +70

Table 4: PIGGYBACK EPROM TYPE EVALUATION DEVICES FOR THE FUJITSU 4-BIT FAMILY

| Device Number ${ }^{1}$ | Applicable Series/ Devices | Process | Piggyback EPROM | External ROM Size [bits] | Package | Supply Voltage | Ambient Temperature Range $\left[{ }^{\circ} \mathrm{C}\right.$ ] | RAM Size [bits] |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MB 8850U1-C-401E | MB 8840/50 | CMOS | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850U1-C-402E | MB 8840/50 | CMOS | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850U1-C-403E | MB 8840/50 | cMOS | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850U1-C-411E | MB 8840/50 | cmos | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850U1-C-412E | MB 8840/50 | cMOS | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850U1-C-413E | MB 8840/50 | cmos | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850U2-C-401E | MB 8840/50 | cMOS | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850U2-C-402E | MB 8840/50 | CMOS | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850U2-C-403E | MB 8840/50 | CMOS | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850U2-C-411E | MB 8840/50 | cMOS | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MPP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850U2-C-412E | MB 8840/50 | CMOS | MBM 27C32A | $4 K \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850U2-C-413E | MB 8840/50 | CMOS | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850H-C-001 | MB 8840H/50H | CMOS | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 8850H-C-002 | MB 8840H/50H | CMOS | MBM 27C32A | $4 \mathrm{~K} \times 8$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $128 \times 4$ |
| MB 88408 U -C-001E | MB 88400 | NMOS | MBM 2732A | 4K x 8 | MDP-42C-P03 | $5.0 \pm 10 \%$ | -30 to +70 | $192 \times 4$ |
| MB 88408 U -C-002E | MB 88400 | NMOS | MBM 2732A | 4K $\times 8$ | MDP-42C-P03 | $5.0 \pm 10 \%$ | -30 to +70 | $192 \times 4$ |
| MB 88408 U-C-003E | MB 88400 | NMOS | MBM 2732A | $4 \mathrm{~K} \times 8$ | MDP-42C-P03 | $5.0 \pm 10 \%$ | -30 to +70 | $192 \times 4$ |
| MB 88408H-C-101 | MB 88400H | NMOS | MBM 2732A | $4 \mathrm{~K} \times 8$ | MDP-42C-P03 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88408H-C-111 | MB 88400H | NMOS | MBM 2732A | $4 \mathrm{~K} \times 8$ | MDP-42C-P03 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88418-C-001E | MB 88410 | NMOS | MBM 2732A | $4 \mathrm{~K} \times 8$ | MDP-42C-P03 | $5.0 \pm 10 \%$ | -30 to +70 | $192 \times 4$ |
| MB 88418H-C-101 | MB 88410H | NMOS | MBM 2732A | $4 \mathrm{~K} \times 8$ | MDP-42C-P03 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88418H-C-111 | MB 88410H | NMOS | MBM 2732A | $4 \mathrm{~K} \times 8$ | MDP-42C-P03 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88428-C-101 | MB 88420 | NMOS | MBM 2764/ MBM 2732A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-64C-P01 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| *MB 88428-C-102 | MB 88420 | NMOS | MBM 2764/ MBM 2732A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | ivīf-64C-PUTi | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |


| Number of Instructions | Output Port | PLA <br> Output <br> Mask <br> Number | Serial Port Output Latch | On-chip Prescaler | Oscillation Type | Standby Function | Output Port Level During Standby | Serial Buffer | Output Port Level During Reset | Device Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 70 | standard open-drain | \#001 ${ }^{2}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | yes/no ${ }^{5}$ | high-Z | 4 | high | MB 8850U1-C-401E |
| 70 | standard open-drain | \# $002{ }^{3}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | yes/no ${ }^{5}$ | high-Z | 4 | high | MB 8850U1-C-402E |
| 70 | standard open-drain | \#003 ${ }^{4}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | yes/no ${ }^{5}$ | high-Z | 4 | high | MB 8850U1-C-403E |
| 70 | standard pull-up | \# $001{ }^{2}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | yes/no ${ }^{5}$ | high-Z | 4 | high | MB 8850U1-C-411E |
| 70 | standard pull-up | \# $002{ }^{3}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | yes/no ${ }^{5}$ | high-Z | 4 | high | MB 8850U1-C-412E |
| 70 | standard pull-up | \#003 ${ }^{4}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | yes/no ${ }^{5}$ | high-Z | 4 | high | MB 8850U1-C-413E |
| 70 | standard open-drain | \#001 ${ }^{2}$ | no | yes/no ${ }^{5}$ | crystal/ ceramic | yes/no ${ }^{5}$ | high-Z | 4 | high | MB 8850U2-C-401E |
| 70 | standard open-drain | \# $002{ }^{3}$ | no | yes/no ${ }^{5}$ | crystal/ ceramic | yes/no ${ }^{5}$ | high-Z | 4 | high | MB 8850U2-C-402E |
| 70 | standard open-drain | \#003 ${ }^{4}$ | no | yes/no ${ }^{5}$ | crystal/ ceramic | yes/no ${ }^{5}$ | high-Z | 4 | high | MB 8850U2-C-403E |
| 70 | standard pull-up | \#001 ${ }^{2}$ | no | yes/no ${ }^{5}$ | crystal/ ceramic | yes/no ${ }^{5}$ | high-Z | 4 | high | MB 8850U2-C-411E |
| 70 | standard pull-up | \# $002{ }^{3}$ | no | yes/no ${ }^{5}$ | crystal/ ceramic | yes/no ${ }^{5}$ | high-Z | 4 | high | MB 8850U2-C-412E |
| 70 | standard pull-up | $\# 003{ }^{4}$ | no | yes/no ${ }^{5}$ | crystal/ ceramic | yes/no ${ }^{5}$ | high-Z | 4 | high | MB 8850U2-C-413E |
| 70 | standard ${ }^{10}$ open-drain | $\# 001{ }^{2}$ | no | yes/no ${ }^{5}$ | crystal/ ceramic | $\begin{aligned} & \text { yes/no }{ }^{11} \\ & \text { (soft) } \end{aligned}$ | hold | 4 | low | MB 8850H-C-001 |
| 70 | standard 10 open-dran | \# $001{ }^{2}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | $\text { yes/no }{ }^{12}$ <br> (hard) | hold | 4 | high | MB 8850H-C-002 |
| 75 | high-current open-drain | $\# 001{ }^{2}$ | yes | yes/no ${ }^{5}$ | crystal ceramic | no | - | 4 | high | MB 88408U-C-001E |
| 75 | high-current open-drain | \# $002{ }^{3}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | no | - | 4 | high | MB 88408U-C-002E |
| 75 | high-current open-drain | $\# 003{ }^{4}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | no | - | 4 | high | MB 88408U-C-003E |
| 76 | high-current open-drain | $\# 001{ }^{2}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | no | - | 4 | high | MB 88408H-C-101 |
| 76 | high-current open-drain | $\# 001{ }^{2}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | no | - | 4 | low | MB 88408H-C-111 |
| 74 | high-current open-drain | $\# 001{ }^{2}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | no | - | 4 | high | MB 88418-C-001E |
| 75 | high-current open-drain | $\# 001{ }^{2}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | no | - | 4 | high | MB 88418H-C-101 |
| 75 | high-current open-drain | $\# 001{ }^{2}$ | yes | yes/no ${ }^{5}$ | crystal/ ceramic | no | - | 4 | low | MB 88418H-C-111 |
| 81 | standard pull-up | none | yes | yes | crystal/ ceramic | no | - | 4 | high | MB 88428-C-101 |
| 81 | standard open-drain | none | yes | yes | crystal/ ceramic | no | - | 4 | high | *MB 88428-C-102 |

Table 4: (Continued)

| Device Number ${ }^{1}$ | Applicable Series/ Devices | Process | Piggyback EPROM | External ROM Size [bits] | Package | Supply Voltage | Ambient Temperature Range $\left[^{\circ} \mathrm{C}\right.$ ] | RAM Size [bits] |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MB 88428H-C-201 | MB 88420H | NMOS | MBM 2764/ MBM 2732A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-64C-P01 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88428H-C-202 | MB 88420H | NMOS | MBM 2764/ <br> MBM 2732A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-64C-P01 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88428H-C-203 | MB 88420H | NMOS | MBM 2764/ <br> MBM 2732A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-64C-P01 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88508-C-101 | MB 88501 | CMOS | MBM 27C64/ MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-42C-P03 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| MB 88508-CF-101 ${ }^{6}$ | MB 88501 | cmos | MBM 27C64 ${ }^{7}$ | $8 \mathrm{~K} \times 8$ | MQP-48C-P01 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| MB 88508U-C-101 | MB 88505/507 | CMOS | MBM 27C64/ <br> MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-42C-P03 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| MB 88508U-CF-101 ${ }^{6}$ | MB 88505/507 | cmos | MBM $27 \mathrm{C64}{ }^{7}$ | $8 \mathrm{~K} \times 8$ | MQP-48C-P01 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| MB 88508U-C-102 | MB 88505/507 | CMOS | MBM 27C64/ <br> MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-42C-P03 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| MB 88508U-CF-102 ${ }^{6}$ | MB 88505/507 | CMOS | MBM 27C64 ${ }^{7}$ | $8 \mathrm{~K} \times 8$ | MQP-48C-P01 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| MB 88508H-C-101 | $\begin{aligned} & \text { MB 88501H/ } \\ & 503 \mathrm{H} \end{aligned}$ | CMOS | MBM 27C64/ <br> MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| MB 88508H-CF-101 ${ }^{6}$ | $\begin{aligned} & \text { MB } 88501 \mathrm{H} / \\ & 503 \mathrm{H} \end{aligned}$ | CMOS | MBM 27 C64 ${ }^{7}$ | $8 \mathrm{~K} \times 8$ | MQP-48C-P01 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| *MB 88508H-C-102 | $\begin{aligned} & \text { MB 88501H/ } \\ & 503 \mathrm{H} \end{aligned}$ | CMOS | MBM 27C64/ <br> MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| *MB 88508H-CF-102 ${ }^{6}$ | $\begin{aligned} & \text { MB 88501H/ } \\ & 503 \mathrm{H} \end{aligned}$ | CMOS | MBM 27 C64 ${ }^{7}$ | $8 \mathrm{~K} \times 8$ | MQP-48C-P01 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| *MB 88PG517B-C-201 | MB 88517B | CMOS | MBM 27C64/ <br> MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| MB 88PG517B-C-202 | MB 88517B | CMOS | MBM 27C64/ <br> MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-42C-P04 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| MB 88518B-C-101 | $\begin{aligned} & \text { MB 88514B/ } \\ & 515 B / 516 B \end{aligned}$ | CMOS | MBM 27C64/ <br> MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-64C-P01 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| MB 88518B-C-102 | MB 88514B/ 515B/516B | CMOS | MBM 27C64/ MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-64C-P01 | $5.0 \pm 10 \%$ | -40 to +85 | $256 \times 4$ |
| MB 88528-C-101. | MB 88521/523 | CMOS | $\begin{aligned} & \text { MBM 27C64/ } \\ & \text { MBM 27C32A } \end{aligned}$ | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-64C-P01 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88528-C-102 | MB 88521/523 | CMOS | MBM 27C64/ <br> MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-64C-P01 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88528-C-301 | MB 88525 | CMOS | MBM 27C64/ MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-64C-P01 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88528-C-302 | MB 88525 | CMOS | MBM 27C64/ MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-64C-P01 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88528B-C-101 | MB 88520B | CMOS | MBM 27C64/ MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-64C-P01 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88528B-C-102 | MB 88520B | CMOS | MBM 27C64/ MBM 27C32A | $\begin{aligned} & 8 K \times 8 \\ & 4 K \times 8 \end{aligned}$ | MDP-64C-P01 | $5.0 \pm 10 \%$ | -30 to +70 | $256 \times 4$ |
| MB 88538-C-201E ${ }^{68}$ | MB 88535 | CMOS | MBM 27C32A ${ }^{7}$ | $4 \mathrm{~K} \times 8$ | MDP-42C-P01 | $5.0 \pm 10 \%$ | -30 to +70 | $128 \times 4$ |
| MB 88538-C-202E ${ }^{68}$ | MB 88536 | CMOS | MBM $27{ }^{\text {C }}$ [ $32{ }^{7}$ | $4 \mathrm{~K} \times 8$ | MDP-42C-P01 | $5.0 \pm 10 \%$ | -30 to +70 | $128 \times 4$ |


| Number of Instructions | Output Port | PLA <br> Output <br> Mask <br> Number | Serial Port Output Latch | On-chip Prescaler | Oscillation Type | Standby Function | Output Port Level During Standby | Serial Buffer | Output <br> Port <br> Level <br> During <br> Reset | Device Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 82 | standard pull-up | none | yes | yes | crystal/ ceramic | no | - | 4 | high | MB 88428H-C-201 |
| 82 | high-current open-drain | none | yes | yes | crystal/ ceramic | no | - | 4 | high | MB 88428H-C-202 |
| 82 | high-current open-drain | none | yes | yes | crystal/ ceramic | no | - | 4 | low | MB 88428H-C-203 |
| 77 | standard pull-up | $\# 001{ }^{2}$ | yes | yes | crystal/ ceramic | yes | high-Z | 4 | high | MB 88508-C-101 |
| 77 | standard pull-up | \# $001{ }^{2}$ | yes | yes | crystal/ ceramic | yes | high-Z | 4 | high | MB 88508CF-101 ${ }^{6}$ |
| 77 | standard pull-up | $\# 001{ }^{2}$ | yes | yes | crystal/ ceramic | yes | high-Z | $4 / 8^{9}$ | high | MB 88508 U -C-101 |
| 77 | standard pull-up | \#001 ${ }^{2}$ | yes | yes | crystal/ ceramic | yes | high-Z | $4 / 8{ }^{9}$ | high | MB 88508U-CF-101 ${ }^{6}$ |
| 77 | high-current open-drain | \# $001{ }^{2}$ | yes | yes | crystal/ ceramic | yes | hold | $4 / 8^{9}$ | high | MB 88508U-C-102 |
| 77 | high-current open-drain | $\# 001{ }^{2}$ | yes | yes | crystal/ ceramic | yes | hold | $4 / 8^{9}$ | high | MB 88508 U-CF-102 ${ }^{6}$ |
| 78 | standard pull-up | \#001 ${ }^{2}$ | yes | yes | crystal/ ceramic | yes | high-Z | 4 | high | MB 88508H-C-101 |
| 78 | standard pull-up | \# $001{ }^{2}$ | yes | yes | crystal/ ceramic | yes | high-Z | 4 | high | MB 88508H-CF-101 ${ }^{6}$ |
| 78 | high-current open-drain | \# $001{ }^{2}$ | yes | yes | crystal/ ceramic | yes | hold | 4 | high | *MB 88508H-C-102 |
| 78 | high-current open-drain | \# $001{ }^{2}$ | yes | yes | crystal/ ceramic | yes | hold | 4 | high | *MB 88508H-CF-102 ${ }^{6}$ |
| 81 | standard pull-up | none | yes | yes | crystal/ ceramic | no | - | $4 / 8^{9}$ | high | *MB 88PG517B-C-201 |
| 81 | standard open-drain | none | yes | yes | crystal/ ceramic | no | - | $4 / 8{ }^{9}$ | high | MB 88PG517B-C-202 |
| 81 | high-current pull-up | none | yes | yes | crystal/ ceramic | yes | high-Z | $4 / 8^{9}$ | $\begin{aligned} & \text { EO-E24: L } \\ & \text { other: } \end{aligned}$ | MB 88518B-C-101 |
| 81 | high-current open-drain | none | yes | yes | crystal/ ceramic | yes | hold | $4 / 8^{9}$ | $\begin{aligned} & \text { EO-E24: L } \\ & \text { other: H } \end{aligned}$ | MB 88518B-C-102 |
| 82 | standard pull-up | none | yes | yes | crystal/ ceramic | yes | high-Z | 4 | high | MB 88528-C-101 |
| 82 | standard ${ }^{10}$ open-drain | none | yes | yes | crystal/ ceramic | yes | hold | 4 | high | MB 88528-C-102 |
| 82 | standard pull-up | none | yes | yes | crystal/ ceramic | yes | high-Z | $4 / 8{ }^{9}$ | high | MB 88528-C-301 |
| 82 | standard ${ }^{10}$ open-drain | none | yes | yes | crystal ceramic | yes | hold | $4 / 8{ }^{9}$ | high | MB 88528-C-302 |
| 81 | standard pull-up | none | yes | yes | RCnetwork | yes | high-Z | $4 / 8{ }^{9}$ | $\begin{aligned} & \text { EO-E23: L } \\ & \text { other : H } \end{aligned}$ | MB 88528B-C-101 |
| 81 | standard open-drain | none | yes | yes | crystal/ ceramic | yes | hold | $4 / 8{ }^{9}$ | $\begin{aligned} & \text { E0-E23: L } \\ & \text { other : } \mathrm{H} \end{aligned}$ | MB 88528B-C-102 |
| 70 | standard pull-up | none | yes | yes | crystal/ ceramic | no | - | 4 | high | MB 88538-C-201E ${ }^{68}$ |
| 70 | standard pull-up | none | yes | yes | crystal/ ceramic | no | - | 4 | high | MB 88538-C-202E 68 |

Table 4: (Continued)

| Device Number |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| *MB 88PG543-CF-XXX | Applicable <br> Series/ <br> Devices | MB 88543 | CMOS | MBM 27C64 |

## Notes:

1.     - C designates a ceramic DIP package, and -CF, a ceramic FPT package. E indicates that the EPROM is attached to the package.
2. Dual 4-bit parallel output
3. 8 -bit parallel output for 7 -segment LED/dual 4-bit parallel output
4. 8-bit parallel output for 7 -segment LED
5. Selectable using external control pin
6. For evaluation only
7. LCC package (MBM 27C32A-CV, MBM 27C64-CV except for MB 88508/U, MBM 27C64-MCV for MB 88508/U)
8. Multi-chip ceramic package configuration
9. Software selectable
10. P-Port is 12 V -interface open-drain output port.
11. Soft: Software standby initiation
12. Hard: Hardware standby initiation

* Under development.

| Number of Instructions | Output Port | PLA <br> Output <br> Mask <br> Number | Serial Port Output Latch | On-chip Prescaler | Oscillation Type | Standby Function | Output <br> Port <br> Level <br> During <br> Standby | Serial <br> Buffer | Output <br> Port <br> Level <br> During <br> Reset | Device Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 78 | TBD | none | yes | yes | TBD | yes | TBD | 4/89 | TBD | *MB 88PG543-CF-XXX |
| 78 | TBD | none | yes | yes | TBD | yes | TBD | $4 / 8{ }^{9}$ | TBD | *MB 88PG543-CF-XXX |
| 82 | TBD | none | yes | yes | TBD | yes | TBD | 4/8 ${ }^{9}$ | TBD | *MB 88PG544-CF-XXX |
| 82 | TBD | none | yes | yes | TBD | yes | TBD | $4 / 8^{9}$ | TBD | *MB 88PG544-CF-XXX |
| 78 | TBD | none | yes | yes | TBD | yes | TBD | $4 / 8^{9}$ | TBD | *MB 88PG545-CF-XXX |
| 78 | TBD | none | yes | yes | TBD | yes | TBD | $4 / 8^{9}$ | TBD | *MB 88PG545-CF-XXX |
| 82 | TBD | none | yes | yes | TBD | yes | TBD | $4 / 8^{9}$ | TBD | *MB 88PG546-CF-XXX |
| 82 | TBD | none | yes | yes | TBD | yes | TBD | $4 / 8{ }^{9}$ | TBD | *MB 88PG546-CF-XXX |
| 82 | standard pull-up | none | yes | yes | crystal/ ceramic | yes | high-Z | 4/8 ${ }^{9}$ | high | MB 88558-CF-101 ${ }^{6}$ |
| 82 | high-current open-drain | none | yes | yes | crystal/ ceramic | yes | hold | 4/89 | high | MB 88558-CF-1026 |
| 82 | high-current open-drain | none | yes | yes | crystal/ ceramic | yes | hold | $4 / 8{ }^{9}$ | $\begin{aligned} & \text { R0-R7: L } \\ & \text { other: H } \end{aligned}$ | MB 88558-CF-103 ${ }^{6}$ |
| 82 | standard pull-up | none | yes | yes | crystal/ ceramic | yes | high-Z | $4 / 8{ }^{9}$ | high | MB 88558H-CF-101 ${ }^{6}$ |
| 82 | high-current open-drain | none | yes | yes | crystal/ ceramic | yes | hold | $4 / 8{ }^{9}$ | high | MB 88558H-CF-102 ${ }^{6}$ |
| 82 | high-current open-drain | none | yes | yes | crystal/ ceramic | yes | hold | $4 / 8^{9}$ | $\begin{aligned} & \text { RO-R7: L } \\ & \text { other: H } \end{aligned}$ | MB 88558H-CF-103 ${ }^{6}$ |

Table 5: EVALUATION BOARDS FOR THE FUJITSU 4-BIT MCU FAMILY

| Device Number | Description | Applicable Series/Devices | Dimensions [mm] | Device Number |
| :---: | :---: | :---: | :---: | :---: |
| MB 2115-01 | CRT unit | All | $319 \times 510 \times 325$ | MB 2115-01 |
| MB 2115-02 | Monitor board with keyboard | All | $283 \times 328 \times 66$ | MB 2115-02 |
| MB 2115-04 | EPROM writer board with RS-232C interface | All | $140.5 \times 152$ | MB 2115-04 |
| MB 2115-13 ${ }^{1}$ | DUE ${ }^{2}$ board | MB 88400 | $160 \times 284$ | MB 2115-13 ${ }^{1}$ |
| MB 2115-13A ${ }^{1}$ \& MB 2115-89 ${ }^{3}$ | DUE board \& DUE adapter | MB 88400H | $\begin{aligned} & 160 \times 284 \\ & 160 \times 284 \\ & \hline \end{aligned}$ | MB 2115-13A ${ }^{1}$ \& MB 2115-89 ${ }^{3}$ |
| MB 2115-14 ${ }^{1}$ | DUE board | MB 88410 | $160 \times 284$ | MB 2115-14 ${ }^{1}$ |
| $\begin{aligned} & \text { MB2115-14A }{ }^{1} \& \\ & \text { MB } 2115-89^{3} \end{aligned}$ | DUE board \& DUE adapter | MB 88410H | $\begin{aligned} & 160 \times 284 \\ & 160 \times 284 \end{aligned}$ | MB 2115-14A ${ }^{1}$ \& MB 2115-89 ${ }^{3}$ |
| MB 2115-31 $A^{1}$ \& MB 2115-89 ${ }^{3}$ | DUE board \& DUE adapter | MB 88500/500H | $\begin{aligned} & 160 \times 284 \\ & 160 \times 284 \end{aligned}$ | MB 2115-31A ${ }^{1}$ \& MB 2115-89 ${ }^{3}$ |
| MB 2115-32 ${ }^{1}$ | DUE board | MB 88541 | $200 \times 284$ | MB 2115-32 ${ }^{1}$ |
| MB 2115-33A ${ }^{1}$ | DUE board | $\begin{gathered} \mathrm{MB} 8840 / 50 \mathrm{H} / \\ 200 / 200 \mathrm{H} \end{gathered}$ | $160 \times 284$ | MB 2115-33A |
| $\begin{aligned} & \text { MB 2115-33A }{ }^{1} \& \\ & \text { MB 2115-94 } \end{aligned}$ | DUE board \& DUE adapter | MB 8850B | $\begin{aligned} & 160 \times 284 \\ & 135 \times 190 \end{aligned}$ | MB 2115-33A ${ }^{1}$ \& MB 2115-94 |
| $\text { MB 2115-33A }{ }^{1} \&$ MB 2115-98 | DUE board \& DUE adapter | MB 88530 | $\begin{aligned} & 160 \times 284 \\ & 100 \times 100 \end{aligned}$ | MB 2115-33A ${ }^{1}$ \& MB 2115-98 |
| MB 2115-34 ${ }^{1}$ \& MB 2115-96 \& MB 2115-924 | DUE board \& DUE adapter \& SDIP 64-pin cable | MB 88510B <br> (Except MB 88517B) | $\begin{aligned} & 200 \times 284 \\ & 135 \times 190 \end{aligned}$ | MB 2115-34 ${ }^{1}$ \& MB 2115-96 \& MB 2115-92 ${ }^{4}$ |
| MB 2115-35 ${ }^{1}$ \& MB 2115-95 \& MB 2115-92 ${ }^{4}$ | DUE board \& DUE adapter \& SDIP 64-pin cable | MB 88520B | $\begin{aligned} & 200 \times 284 \\ & 135 \times 190 \end{aligned}$ | $\begin{aligned} & \text { MB 2115-35 }{ }^{1} \text { \& } \\ & \text { MB 2115-95 \& } \\ & \text { MB 2115-92 } \end{aligned}$ |
| MB 2115-36A ${ }^{1}$ \& MB 2115-86 ${ }^{3}$ | DUE board \& DUE adapter | MB 88550/550H | $\begin{aligned} & 200 \times 284 \\ & 160 \times 284 \end{aligned}$ | $\begin{aligned} & \text { MB } 2115-36 A^{1} \& \\ & \text { MB } 2115-86^{3} \end{aligned}$ |
| MB 2115-37A ${ }^{1}$ \& MB 2115-88 ${ }^{3}$ \& MB 2115-92 ${ }^{4}$ | DUE board \& DUE adapter \& SDIP 64-pin cable | MB 88520/420/420H | $\begin{aligned} & 200 \times 284 \\ & 160 \times 284 \end{aligned}$ |  |
| MB 2115-38 ${ }^{1}$ | DUE board | MB 88511/513/517B | $200 \times 284$ | MB 2115-38 ${ }^{1}$ |
| MB 2115-39 ${ }^{1}$ | DUE board | MB 88210 | $160 \times 284$ | MB 2115-39 ${ }^{1}$ |
| MB 2115-40 ${ }^{1}$ | DUE board | MB 88561 | $200 \times 430$ | MB 2115-40 ${ }^{1}$ |
| MB 2115-41 ${ }^{1}$ | DUE board | MB 88562 | $200 \times 430$ | MB 2115-41 ${ }^{1}$ |
| *MB 2115-42 ${ }^{1}$ | DUE board | MB 88543/4/5/6 | $200 \times 430$ | *MB 2115-42 ${ }^{1}$ |
| ${ }^{*}$ MB 2115-43 ${ }^{1}$ | DUE board | MB 88200B | XXX $\times$ XXX | *MB 2115-43 ${ }^{1}$ |

## Notes:

1. Used in conjunction with the MB 2115-01 CRT unit and the MB 2115-02 monitor board with keyboard.
2. Device-Under-Evaluation.
3. This adapter applied to 12 V -interface open-drain output port and select the port each bit.
4. MB 2115-92 is cable with SDIP 64-pin connector.

* Under development.

Table 6: SUPPORT SOFTWARE FOR THE FUJITSU 4-BIT MCU FAMILY

| Order Number | Description | Media Supplied | Applicable Series | Support System |
| :---: | :---: | :---: | :---: | :---: |
| SM05212-A010 | Cross- <br> Assembler | 8' standard floppy disk [single sided, single density or single sided, double density] | MB 8840/50/50H/ OB/530 | Intellec ${ }^{1}$ Series II/III MDS |
| SM05220-A010 |  |  | MB 88200/200H/200B/210 | Intellec Series II/III MDS |
| SM05215-A010 |  |  | MB 88400/400H/410/410H/420/ $420 \mathrm{H} / 500 / 500 \mathrm{H} / 510 / 510 \mathrm{~B} / 520 /$ 520B/540/550/550H/560 | Intellec Series II/III MDS |
| SM07412-A012 | Cross- <br> Assembler | 8' standard floppy disk [single sided, single density] | MB 8840/50/50H/50B/530 | CP/M ${ }^{2}-86$ |
| SM07420-A012 |  |  | MB 88200/200H/200B/210 | CP/M-86 |
| SM07415-A012 |  |  | MB 88400/400H/410/410H/420/ 420H/500/500H/510/510B/520/ 520B/540/550/550H/560 | CP/M-86 |
| *SMXXXXX-A010 |  | $5^{\prime \prime}$ mini floppy disk [double sided, double density] | MB 88400/400H/410/410H/420/ $420 \mathrm{H} / 500 / 500 \mathrm{H} / 510 / 510 \mathrm{~B} / 520 /$ 520B/540/550/550H/560 | IBM PC-DOS |
| SM07412-G022 ${ }^{3}$ | Host- <br> Emulator | 8" standard floppy disk [single sided, single density] | MB 8840/50/50H/50B/530 | CP/M-86 |
| SM07420-G022 ${ }^{3}$ |  |  | MB 88200/200H/200B/210 | CP/M-86 |
| SM07415-G022 ${ }^{3}$ |  |  | MB 88400/400H/410/410H/420/ 420H/500/500H/510/510B/520/ 520B/540/550/550H/560 | CP/M-86 |
| *SMXXXXX-G0203 |  | $5^{\prime \prime}$ mini floppy disk [double sided, double density] | MB 88400/400H/410/410H/420/ $420 \mathrm{H} / 500 / 500 \mathrm{H} / 510 / 510 \mathrm{~B} / 520 /$ 520B/540/550/550H/560 | IBM PC-DOS |

Notes:

1. Intellec is a registered trademark of Intel Corporation.
2. $C P / M$ is a registered trademark of Digital Research.
3. MB 2115-01, -02, -04 and an applicable DUE board are needed.

* Under development.


## FUJITSU

# NMOS 13-BIT $\times 1$-CHANNEL, 6-BIT $\times 3$-CHANNEL <br> D/A CONVERTER 

## NMOS 13-BIT x 1-CHANNEL, 6-BIT $\times$ 3-CHANNEL D/A CONVERTER

The Fujitsu MB 88301A, a pulse width modulation (PWM) type digital-toanalog converter (DAC), is designed for interface with Fujitsu's MB 8840/ 8850 series and MB 88400/88500 series 4-bit single-ship microcomputers and also with a wide range of general 4-bit and 8-bit microprocessors.

The MB 88301A has four conversion outputs: one 13-bit resolution output and three 6 -bit resolution outputs. All outputs generate positive pulse of varying pulse widths. The pulse widths vary in propotion to digital data programmed by the processor in the internal data register. With the connection of external filter circuits to the outputs, the MB 88301A provides an excellent, easy-to-configure DAC.

## FEATURES

- Pulse width modulation D/A converter
- 4-bit parallel address/data loading
- Four on-chip pulse width modulators:
-13 -bit resolution $\times 1$ channel
-6 -bit resolution $\times 3$ channels
- On-chip 4 MHz clock generator with external crystal or ceramic resonator
- Clock cycle time / Clock frequency:
$-0.25 \mu \mathrm{~s} / 4 \mathrm{MHz}$ for 13 -bit resolution
$-0.50 \mu \mathrm{~s} / 2 \mathrm{MHz}$ for 6 -bit resolution
- Three synchronization clock outputs:
- 2 MHz clock output ( 4 MHz divided by 2 )
-15.625 kHz clock output ( 4 MHz divided by $2^{8}$ )
-488 Hz clock output ( 4 MHz divided by $2^{13}$ )
- Single buffered conversion outputs.
- High-voltage open-drain conversion outputs
- Wide operating temperature range: $-30^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- Single +5 V power supply
- TTL compatible inputs/outputs
- N-channel silicon-gate E/D MOS process
- Two Package Options:
- 16 pin plastic DIP (Suffix: -P)
- 16 pin plastic SOP (Suffix: -PF)


[^32]Fig. 1 - LOGIC SYMBOL


Fig. 2 - BLOCK DIAGRAM


## PIN DESCRIPTION

Table 1 - PIN DESCRIPTION

| Symbol | Pin No. | Type | Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ | 16 | - | +5V power supply pin. |
| $\mathrm{V}_{\text {SS }}$ | 8 | - | Ground pin. |
| XTAL | 7 | - | External 4 MHz crystal or ceramic resonator pins for the on-chip clock generator. |
| EXTAL | 6 | - |  |
| DI3-DIO | 5 to 2 | 1 | 4-bit parallel address/data input: The address/data format is that DI3 is the most significant bit (MSB) and that DIO is the least significant bit (LSB). These inputs are TTL compatible. <br> MSB <br> LSB |
| LDI | 1 | 1 | Write strobe input for a 4-bit address/data: At the leading edge of LDI, a 4-bit address on the ID3 to IDO inputs is latched into the internal address register. At the trailing edge of LDI, a 4-bit data on the DI3 to DIO inputs are written into the internal data register designated by the address latched at the leading edge. This input is TTL compatible. |
| DAC1-DAC4 | 12 to 15 | 0 | Pulse width modulator outputs (DAC outputs): <br> DAC1: 13-bit resolution (one channel) <br> DAC2-DAC4: 6-bit resolution (three channels) <br> All four outputs are high-voltage open drain. |
| TMO1-TMO3 | 9 to 11 | 0 | Synchronization clock outputs (Timing outputs): <br> TMO1: 2 MHz ( 4 MHz divided by 2 ) <br> TMO2: $15.625 \mathrm{kHz}\left(4 \mathrm{MHz}\right.$ divided by $\left.2^{8}\right)$ <br> TMO3: $488 \mathrm{~Hz}\left(4 \mathrm{MHz}\right.$ divided by $\left.2^{13}\right)$ <br> All three clocks have a duty ratio of approximately $50 \%$, and are TTL compatible. |

## FUNCTIONAL DESCRIPTION

## GENERAL OPERATION

The MB 88301A is a pulse width modulation (PWM) type digital-to-analog converter (DAC). It converts digital data programmed by the processor in the internal data register (13-bit or 6 -bit write-only register) into positive pulses. The width of these pulses is propotional to the value of the programmed data, and the cycle time of the pulses is defined by the resolution value ( 6 or 13 bits). The MB 88301 A has four conversion outputs: channel 1 is a 13 -bit resolution output DAC1, and channel 2 to 4 are 6 -bit resolution outputs DAC2 to DAC4. The converted waveform appears at each DAC output. A user-designed external low-pass filter connected to the DAC output eliminates AC components from the output waveform and converts the waveform into a DC voltage propotional to the pulse width.

## DIGITAL DATA INPUT

Fig. 4 shows the input timing of digital data to be converted: Digital data to define the width of the positive pulse is written into the 13 -bit and 6 -bit internal data registers through the DI3 to DIO 4-bit address/data inputs using the write strobe input LDI. At the leading edge of LDI, a 4-bit address on the DI3 to DIO inputs is latched into the internal address register. At the trailing edge of LDI, a 4-bit data on the DI3 to DIO inputs is loaded into the internal data register designated by the address register.

Fig. 5 shows the address/data format: DI3 is the most significant bit (MSB) and DIO is the least significant bit (LSB).

Fig. 3 - ADDRESS/DATA INPUT TIMING


Fig. 4 - ADDRESS/DATA FORMAT
MSB

| DI3 | DI2 | DI1 | DI0 |
| :--- | :--- | :--- | :--- |

Fig. 6 shows the internal data register address map: The whole space size is 10 words. Addresses \#0 to \#3, addresses \#4 and \#5, addresses \#6 and \#7, and addresses \#8 and \#9 are assigned to DAC1, DAC2, DAC3 and DAC4, respectively. Fig. 7 shows the internal data register format: To the DAC1 data register, three 4 -bit and one 1 -bit digital data must be written. To the DAC2 to DAC4 data registers, one 4-bit and one 2-bit digital data must be written.


Fig. 6 - INTERNAL DATA REGISTER FORMAT


## PULSE WIDTH MODULATION/DAC OUTPUT WAVEFORM

## - 13-Bit Resolution D/A Converter: DAC1

Fig. 8 shows the configuration of the 13 -bit resolution pulse width modulator: The on-chip clock generater provides 4 MHz clock for the 13 -bit free-running counter. When all bits of the counter is zero, the all-zero detector sets the output $R$ -R-S flip-flop. The coincidence detector compares the counter with the data register. When they match, the coincidence detector resets the output flip-flop. The waveform appearing at the DAC1 output depends on the data register value, shown in Fig. 9.


Fig. 8 - DAC1 OUTPUT WAVEFORM


## - 6-Bit Resolution D/A Converters: DAC2 to DAC4

Fig. 10 shows the configulation of the 6 -bit resolution pulse width modulator: The 2 MHz clock that is the output of Bit 1 of the 13 -bit free-running counter drives the 6 -bit freerunning counter. This 6 -bit counter is also part of the 13 -bit counter (Bits 2 to 7). The comparator compares the counter with the data register every cycle. When the counter value is equal to or less than the data register value, the comparator outputs a high level at the DAC output. When the counter value exceeds the date register value, the comparator outputs a low level at the DAC output. This produces the waveforms at the DAC2, DAC3, and DAC4 outputs, shown in Fig. 11.

Fig. 9 - 6-BIT PULSE WIDTH MODULATOR CONFIGURATION


## EXTERNAL FILTER CONFIGURATION

The on-chip pulse width modulator generates positive pulse waveforms similar to the one shown in Fig. 13 at the DAC outputs (DAC1 to DAC4). The pulse width $\left(t_{H}\right)$ is proportional to the digital data programmed into the data register. The cycle time ( T ) is determined by the resolution value ( 6 or 13 bits).
User-designed low-pass filters are required at the DAC outputs to eliminate AC components from the output waveform and to convert the waveform to a DC voltage. Fig. 12 shows an example of a simple output configuration in which an RC integrator is used as the low-pass filter. With this circuit, the DAC waveform shown in Fig. 13 is converted to the $\mathrm{V}_{\text {OUt }}$ output waveform shown in Fig. 14. Ripple and response time $\left(t_{R}\right)$ depend on the time constant of the RC filter. A longer time constant reduces ripple but increases response time. A time constant that best meets the tradeoff between desired accuracy and response time should be chosen. Also, since the DAC outputs are high-voltage open drain, they can externally be pulled up to a power supply higher than 5 V . This prevents the output voltage from attenuating through the external low-pass filters.

## Note:

The low-pass filter shown in Fig. 12 is just an example. In actual practice, depending on the user's system design, additional amplifiers, multi-stage filters, and other circuits will be needed for the external low-pass filter.

## notice

To change the DC output voltage of the external low-pass filter, the data register value must be updated to vary the positive pulse width (duty ratio) of the DAC output. However, all bits on the data register can not be changed at the same time. They are updated a nibble at a time by the 4 -bit parallel data loading. In addition, the DAC output is single buffered. Because of this nibble-by-nibble update and single buffering, the data register value during update may become transient. During this pulse cycle, depending on the transient value, an undesirable duty ratio disturbance may occur at the DAC output, affecting the filter output. It is therefore necessary to design the output filter so that such disturbances in the DAC output waveform will not appear at the filter output. This notice applies to both the 13 -bit and 6 -bit resolution converters. With the 13 -bit resolution converter, however, it is possible to avoid such disturbance by software. This is done by controlling the update timing of the data register value through monitoring of the DAC1 output and the TMO3 output waveforms.
Also, note the following thing when the DAC1 output is used: in the steady state where the DAC1 data register bits are all set (i.e., data is " $1 F F F$ ") the DAC1 output remains high. But, when the data is updated, there is a possibility that the DAC1 output may become undefined during that output cycle time (less than one cycle time). To avoid this phenomenon, the following method is utilized:

1. Not use data of "1FFF", or
2. Change the DAC1 data register value (i.e., " $1 \mathrm{FFF}^{\prime \prime}$ ) just before the counter become full (i.e., all bits are set). Since in this case an undesired pulse due to the data change may appear at the DAC1 output, the pulse must be eliminated with the external filter.


Fig. 12 - DAC OUTPUT WAVEFORM

$\mathbf{t}_{\mathrm{H}}$ : Pulse width
T : Cycle time

Fig. 13 - VOUT OUTPUT WAVEFORM


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Rating | Unit | Pins/C | ons |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{V}_{\text {Ss }}-0.3$ to $\mathrm{V}_{\text {Ss }}+8.0$ | V | $\mathrm{V}_{\text {cc }}$ | $\mathrm{V}_{\mathrm{ss}}=0 \mathrm{~V}$ |
| Input Voltage | $V_{\text {IN }}$ | $\mathrm{V}_{\text {SS }}-0.3$ to $\mathrm{V}_{\text {SS }}+8.0$ | V | $\begin{aligned} & \text { DIO-DI3, LDI, } \\ & \text { EXTAL, XTAL } \end{aligned}$ |  |
| Output Voltage | $\mathrm{V}_{\text {OUt }}$ | $\mathrm{V}_{\text {SS }}-0.3$ to $\mathrm{V}_{\text {SS }}+15.0$ | V | DAC1-DAC4 |  |
|  |  | $\mathrm{V}_{\text {SS }}-0.3$ to $\mathrm{V}_{\text {SS }}+8.0$ |  | TMO1-TMO3 |  |
| Operating Temperature | $\mathrm{T}_{\text {A }}$ | -30 to +70 | ${ }^{\circ} \mathrm{C}$ | Ambient temperature |  |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |  |  |

NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Value |  |  | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. |  |
|  |  |  |  |  |  |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5.0 | 5.5 | V |
|  | $\mathrm{~V}_{\mathrm{SS}}$ |  | 0 |  |  |
| Input High Voltage | $\mathrm{V}_{1 \mathrm{H}}$ | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}$ | V |
| Input Low Voltage | $\mathrm{V}_{1 \mathrm{~L}}$ | -0.3 |  | 0.8 | V |
| Clock Frequency ${ }^{*}$ | $\mathrm{f}_{\mathrm{c}}$ | 0.5 |  | 4.0 | MHz |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ | -30 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

NOTE: * Crystal or ceramic resonator should be used. See Fig. 17.

## DC CHARACTERISTICS

(Recommended operating conditions unless otherwise noted.)

| Parameter | Symbol | Pins/Conditions | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. | Max. |  |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \text { TMO1-TMO3 } \\ & \mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A} \end{aligned}$ | 2.4 |  |  | V |
|  |  | DAC1-DAC4 | Open Drain |  |  |  |
|  |  | $\begin{aligned} & \mathrm{TMO} 1-\mathrm{TMO} \\ & \mathrm{I}_{\mathrm{OL}}=1.8 \mathrm{~mA} \end{aligned}$ |  | * | 0.4 | V |
| Output Low Voltage | $\mathrm{V}_{\text {OL }}$ | $\begin{aligned} & \hline \text { DAC1-DAC4 } \\ & \text { IoL }=2.0 \mathrm{~mA} \text {, } \\ & 5 \mathrm{k} \Omega \text { External } \\ & \text { Pull Up Resistor } \end{aligned}$ |  |  | 0.8 | V |
| Output Leakage Current | ILOH | $\begin{aligned} & \text { DAC1-DAC4 } \\ & \mathrm{VOH}_{\mathrm{OH}}=13.2 \mathrm{~V}, \\ & \text { OFF State } \\ & \hline \end{aligned}$ |  |  | 50 | $\mu \mathrm{A}$ |
| Supply Current | $I_{\text {cc }}$ | $V_{C C}=5.5 \mathrm{~V}$ <br> All Outputs Open |  | 15 | 25 | mA |

## AC CHARACTERISTICS

(Recommended operating conditions unless otherwise noted.)

| Parameter | Symbol | Pins/Conditions | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LDI Pulse Width | PwLDI | LDI <br> Fig. 14, Fig. 16 | 5 |  |  | $\mu \mathrm{s}$ |
| LDI Rise/Fall times | $\begin{aligned} & \mathrm{t}_{\text {rLDI }} \\ & \mathrm{t}_{\mathrm{fLDI}} \end{aligned}$ | LDI <br> Fig. 14, Fig. 16 |  |  | 1.5 | $\mu \mathrm{s}$ |
| Address/Data Setup Time | $\mathrm{t}_{s}$ | DI3 - DIO <br> Fig. 14, Fig. 16 | 0.5 |  |  | $\mu \mathrm{s}$ |
| Address/Data Hold Time | $\mathrm{t}_{\mathrm{H}}$ | DI3 - DIO <br> Fig. 14, Fig. 16 | 2 |  |  | $\mu \mathrm{s}$ |
| TMO Rise/Fall times | $\begin{aligned} & \mathrm{t}_{\text {rтмо }} \\ & \mathrm{t}_{\text {fTMO }} \end{aligned}$ | TM01-TM03 Fig. 15, Fig. 16 |  |  | 0.2 | $\mu \mathrm{s}$ |

Fig. 14 - ADDRESS/DATA INPUT TIMING


Fig. 15 - SYNCHRONIZATION CLOCK OUTPUT TIMING


Fig. 16 - AC TEST CONDITIONS

## INPUT CONDITIONS

- Input Levels: 2.0V for a logic " 1 " 0.8 V for a logic " 0 "


## OUTPUT CONDITIONS

- Timing Reference Levels: 2.4 V for a logic " 1 " 0.4 V for a logic " 0 "
- Output Load Circuit: $C_{L}=100 \mathrm{pF}$ (including scope and jig capacitances) $R_{L}=4 \mathrm{k} \Omega$


Fig. 17 - CRYSTAL/CERAMIC OSCILLATOR CIRCUIT

$\mathrm{fc}=4 \mathrm{MHz}$
$\mathrm{C} 1=\mathrm{C} 2=20 \mathrm{pF}-60 \mathrm{pF}$

## PACKAGE DIMENSIONS

PLASTIC DIP (Suffix: -P)


## PACKAGE DIMENSIONS

PLASTIC SOP(Suffix: -PF)

## 16-LEAD PLASTIC FLAT PACKAGE (CASE No.: FPT-16P-M02)



## NMOS INPUT/OUTPUT EXPANDER

The Fujitsu MB 88304/MB 88305 are peripheral integrated circuits that can be connected to a 4 -bit or 8 -bit single-chip microcomputer (MCU) to provide additional I/O ports. Besides furnishing simple I/O port expansion, the MB 88304 and MB 88305 can AND or OR port data with data from the MCU, on instruction from the MCU.

The MB 88304/MB 88305 are pseudo-bidirectional ports. They are accessed in 4 -bit units, but each individual bit can be used for either input or output, and input and output can be intermixed. The interface to the MCU requires only the connection of a 4 -bit interface port and a strobe signal. All output ports of the MB 88304 are open-drain; MB 88305 output ports all have pull-up resistors. The output ports on both chips are reset to the high-impedance state at power-up.

The MB 88304/MB 88305 are fabricated with N-channel silicon-gate E/D MOS process, and packaged in $24-$ pin plastic DIP. Also, they are powered with a single +5 V power supply, and operate over the ambient temperature range of $-30^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$.

## FEATURES

- Four 4-bit I/O ports (16 lines)
- Four Functions: parallel input, parallel output, AND output, and OR output
- AND and OR functions provide individual output capability
- Single-bit input/output: Input and output can be intermixed on each port
- High output drive
- Built-in power-on reset circuit
- $\overline{\mathrm{CS}}$ pin for simplified input/output expansion
- Two output circuit types: Open-drain output (MB 88304)

3-state output (MB 88305)

- Easily connectable to MCUs with 8243 interface
- Single +5 V power supply
- $-30^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ operating temperature range
- N-channel silicon-gate E/D MOS process
- 24-pin plastic DIP (Suffix: -P)


[^33]

Fig. 1 - BLOCK DIAGRAM


## PIN DESCRIPTION

The MB 88304/88305 have two interfaces: One is the processor interface; $\overline{C S}, \overline{L D I}$, and DI3-DIO, which are used for the processor to communicate with the MB 88304/5 devices. Another is the expansion I/O ports; Ports A, B, C, and D, which serve as an expansion of the processor's $1 / \mathrm{O}$.

Table 1 - PIN DESCRIPTION

| Symbol | Pin No. | Type | Name/Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ | 24 | - | $\mathrm{V}_{\mathbf{C C}}$ : is the +5 V power supply pin. |
| GND | 12 | - | GND: is the ground pin. |
| $\overline{\text { CS }}$ | 6 | 1 | Chip Select: is a low-level-sense high-impedance input. A low level on this input selects the device. This input is TTL-compatible. |
| $\overline{\text { LDI }}$ | 7 | 1 | Load Data Input : is an edge-triggered strobe input. The operation code and address code on DIO to DI3 are latched at the $\overline{\text { LDI }}$ falling edge. The data transffered via DIO to DI3 becomes valid on the rising edge of the $\overline{\text { LDT input. }}$ |
| DI3 to DIO | 8 to 11 | I/O | Data Bus: is a 4-bit bidirectional port used for interface to the MCU. The operation code and address code provided by the MCU on this port are latched at the falling edge of the $\overline{\mathrm{LDI}}$ strobe input, and input/output data is transferred at the rising edge of the $\overline{\mathrm{LDI}}$. The DI port remains in the highimpedance state except when the input operation is executed. |
| PA0 to PA3 | 2 to 5 | 1/0 | Ports A, B, C, and D are 4-bit bidirectional ports used as expansion I/O ports. These four ports are addressed by address codes provided by the MCU. |
| PBO, <br> PB1 to PB3 | $\begin{gathered} 1, \\ 21 \text { to } 23 \end{gathered}$ | 1/0 | When an input operation code is given by the MCU, data on the addressed port is transferred to the DIO to DI3 at the rising edge of the $\overline{\text { LDI. When an }}$ output operation code is provided, data on the DIO to DI3 is transferred and latched to the addressed port at the rising edge of the $\overline{\mathrm{LDI}}$. Logical operations are also possible, in which data on the addressed port is ANDed or ORed with |
| PCO to PC3 | 20 to 17 | I/O | rising edge of the |
| PD0 to PD3 | 16 to 13 | 1/0 | After a power-on reset, Ports $A$ to $D$ are all set to the high-impedance state. An individual port is released from the high-impedance state when the OUT, AND, or OR function is applied to it. (Since the MB 88304 has open-drain outputs, a line returns to the high-impedance state when an " 1 " is written on it.) |

## FUNCTIONAL DESCRIPTION

The four 4-bit I/O ports of the MB 88304 and MB 88305 are labelled port $A$, port $B$, port $C$, and port $D(P A, P B, P C$, and PD). They serve as expansion I/O ports for a one-chip microcomputer (MCU), and can be accessed via an MCU port. Their functions are as follows:

- Data transfer from the MCU to port A, B, C, or D
- Data transfer from port $A, B, C$, or $D$ to the MCU
- ANDing of the port A, B, C, or D data with MCU data and latching of the result at port $A, B, C$, or $D$
- ORing of the port $A, B, C$, or D data with MCU data and latching of the result at port $A, B, C$, or $D$
For interface to the MCU, the MB 88304 and MB 88305 have a 4-bit interface port (DIO to DI3), a strobe input ( $\overline{\mathrm{LDI}} \mathrm{pin}$ ), and a chip select input ( $\overline{\mathrm{CS}}$ pin). The interface data consists of two 4 -bit units. The first 4 bits give the operation code (2-bits) and address code ( 2 bits). The second 4 -bits are the input or output data. Both 4 -bit units are transferred through the interface port (DIO to DI3) on timings determined by the strobe (LDI) signal. The MB 88304 or MB 88305 reads the operation code and address code from the MCU on the falling edge of the $\overline{L D I}$ signal, and sends or receives the I/O data on the rising edge of LDT.
The $\overline{\mathrm{CS}}$ pin is used to read a chip select signal from the MCU's I/O port when two or more MB 88304 or MB 88305 chips are connected to the MCU.

| Ope. Code |  | Funciton | Addr. Code |  | Port Address |
| :---: | :---: | :--- | :---: | :---: | :---: |
|  |  |  | DI1 | DIO |  |
| 0 | 0 |  | IN (Input) | 0 | 0 |
| Port A (PA) |  |  |  |  |  |
| 0 | 1 | OUT (Output) | 0 | 1 | Port B (PB) |
| 1 | 0 | OR (Logical OR) | 1 | 0 | Port C (PC) |
| 1 | 1 | AND (Logical AND) | 1 | 1 | Port D (PD) |

## POWER-ON RESET

The MB 88304 and MB 88305 contain an internal power-on reset circuit that detects the rise of $\mathrm{V}_{\mathrm{Cc}}$ on the power supply line and holds the chip circuits in the reset state. In the reset state, the interface port (pins DIO to DI3) is set to the input state, and ports $A$ to $D$ (PA to PD) are in the high-impedance state (except that latched output ports are not reset). The $\mathrm{V}_{\mathrm{cc}}$ line must rise smoothly for the reset circuit to operate. Regardless of the input level (high of low) of the $\overline{L D I}$ pin at the moment power is applied, the reset state is released at the first falling edge of the $\overline{\text { LDI }}$ input. A power-on reset also occurs if the supply voltage $\left(\mathrm{V}_{\mathrm{cc}}\right)$ drops to 1 V or less, then recovers to the rated voltage.

## OUTPUT MODE (Write Mode)

Corresponding to three functions of the MCU, the MB 88304 and MB 88305 have three output modes: data transfer output (OUT), logical OR (OR), and logical AND (AND).

- OUT

The designated port latches and outputs the 4-bit data transferred from the MCU.

- AND

The 4-bit data transferred from the MCU is ANDed with the 4-bit data of the designated port, which then latches the result as output.

- OR

The 4-bit data transferred from the MCU is ORed with the 4-bit data of the designated port, which then latches the result as output.
The operation code and address code sent from the MCU to pins DIO to DI3 of the MB 88304 or MB 88305 are latched on the falling edge of the strobe signal at the $\overline{\text { LDI }}$ pin. The MCU data is read on the rising edge of the strobe signal and sent to the logic circuit of the designated port, where it is processed. The MCU data is then latched as output data.

## INPUT MODE (Read Mode)

The MB 88304 and MB 88305 have only one input mode (IN), corresponding to data input by the MCU.

- IN

The input data at the port designated by the MCU is read and sent to the MCU via the interface port (DIO to DI3).
The operation and address code sent from the MCU to pins DIO to DI3 of the MB 88304 or MB 88305 are latched on the falling edge of the strobe signal at the LDI pin. If the operation code specifies input, the MB 88304 or MB 88305 sends data from the port designated by the address code to the MCU via DIO to DI3.
A power-on reset places the chip in the input mode with ports $A$ to $D$ in the high-impedance state. If only the IN function is used thereafter, the ports remain in the highimpedance state. Release from the high-impedance state takes place when the OUT, AND, or OR function is used.
The MB 88304 and MB 88305 are designed for easy external driving. The MB 88304 has open-drain outputs, while the MB 88305 outputs have pull-up resistors. For both chips, the input level of a port to be used for input can be read by writing a 1 and performing the IN function. Input and output can therefore be intermixed within the four bits of each of the four ports ( $A$ to $D$ ).

Minnulumill
FUJITSU


Fig. 2 - PORT CIRCUIT CONFIGURATION


## SINK CURRENT FROM PORTS A TO D

When $\mathrm{V}_{\mathrm{OL}} \leqq 0.45 \mathrm{~V}$, the MB 88304 and MB 88305 can sink 5 mA ( $\mathrm{I}_{\mathrm{OL}}$ ) on each of their $16 \mathrm{I} / \mathrm{O}$ lines simultaneously. When this current sinking capability is not required on all of the $1 / O$ lines, or not all of the lines have to sink 5 mA , the driving capability (sink current) of the other I/O lines can be increased according to the characteristics shown in the curve below.


For instance, if one of the $I / O$ lines has to sink 9 mA , the total $I_{\text {OL }}\left(\Sigma I_{\text {OL }}\right)$ of all the lines can be up to 45 mA .
Example-1: How many I/O lines with 5 TTL leads can be driven?
$\mathrm{I}_{\mathrm{OL}}=5 \times 1.6 \mathrm{~mA}=8 \mathrm{~mA}$
$\Sigma I_{\text {OL }} \leqq 60 \mathrm{~mA}$ (from the total $\mathrm{I}_{\mathrm{OL}}$ characteristics curve)
$60 \mathrm{~mA} / 8 \mathrm{~mA}=7 \mathrm{I} / \mathrm{O}$ lines
The chip can drive 7 lines with 5 TTL loads, making a total of 56 mA on these lines. The remaining 4 mA can be shared among the other 9 I/O lines.

Example-2: Suppose that two of the load lines have $\mathrm{I}_{\mathrm{OL}}=$ 20 mA (at $\mathrm{V}_{\mathrm{OL}} \leqq 1 \mathrm{~V}$ ). Can the MB 88304 or MB 88305 drive the following loads?
$2 \mathrm{I} / \mathrm{O}$ lines: 20 mA (at $\mathrm{V}_{\mathrm{OL}} \leqq 1 \mathrm{~V}$ )
8 I/O lines: $\quad 4 \mathrm{~mA}$ (at $\mathrm{V}_{\mathrm{OL}} \leqq 0.45 \mathrm{~V}$ )
$6 \mathrm{I} / \mathrm{O}$ lines: 3.2 mA (at $\mathrm{V}_{\mathrm{OL}} \leqq 0.45 \mathrm{~V}$ )
Total $\mathrm{I}_{\mathrm{OL}}=(2 \times 20 \mathrm{~mA})+(8 \times 4 \mathrm{~mA})+(6 \times 3.2 \mathrm{~mA})$

$$
=91.2 \mathrm{~mA}
$$

Reading the total $\mathrm{I}_{\mathrm{OL}}$ characteristic for $\mathrm{I}_{\mathrm{OL}}=$
4 mA , we see that $\Sigma \mathrm{l}_{\mathrm{OL}} \leqq 93 \mathrm{~mA}$. Since 91.2 mA $\leqq 93 \mathrm{~mA}$, the chip can drive these loads.
Note: The allowable total $\mathrm{IOL}_{\mathrm{OL}}\left(\Sigma \mathrm{I}_{\mathrm{OL}}\right)$ depends on the maximum sink current of the lines for which $V_{\text {OL }}$ must be equal to or less than 0.45 V .

Fig. 4 - TYPICAL APPLICATIONS

- INTERFACE WITH 4-BIT MICROCOMPUTER

- INTERFACE WITH 8-BIT MICROCOMPUTER

- INTERFACE WITH 4-BIT MICROCOMPUTER


NOTE: * Output port of MB 8841 should be open-drain type.

## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Rating | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\text {SS }}-0.3$ to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ to +7.0 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ | -30 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 1.0 | W |

NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational section of this data sheet. Exposure to ABSOLUTE MAXIMUM RATINGS conditions for extended periods may affect device reliability.

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $+5 \pm 10 \%$ | V |
|  | $\mathrm{~V}_{\mathrm{SS}}$ | 0 |  |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ | -30 to +70 | ${ }^{\circ} \mathrm{C}$ |

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

| Parameter |  | Symbol | Value |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| Input Low Voltage |  |  | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {SS }}-0.3$ |  | 0.8 | V |  |
| Input High Voltage |  | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
| Output Low Voltage | Port A to D | $\mathrm{V}_{\text {OL1 }}$ | - |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}$ |
|  |  | $\mathrm{V}_{\text {OL2 }}$ | - |  | 1.0 | V | $\mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA}$ |
| Output Low Voltage | DI0 to DI3 | $\mathrm{V}_{\text {OL3 }}$ | - |  | 0.6 | V | $\mathrm{I}_{\mathrm{OL}}=1.8 \mathrm{~mA}$ |
| Output High Voltage | Ports A to D | $\mathrm{V}_{\mathrm{OH} 1}$ | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}(\mathrm{MB} \mathrm{88305})$ |
| Output High Voltage | DI0 to DI3 | $\mathrm{V}_{\mathrm{OH} 2}$ | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
| Input Leakage Current | Ports A to D | $\mathrm{I}_{1 \mathrm{~L} 1}$ | -10 |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}} \leqq \mathrm{V}_{\mathrm{IN}} \leqq \mathrm{V}_{\text {cc }}$ |
|  | DIO to DI3, CS, $\overline{\text { LDI }}$ | IIL2 | -10 |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leqq \mathrm{V}_{\mathrm{IN}} \leqq \mathrm{V}_{\text {CC }}$ |
| Input Current | Ports A to D | 1 |  | 2.0 |  | mA | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ (MB 88305) |
| Total IOL Output Current from 16 Output |  | ${ }^{\Sigma} \mathrm{IOL}_{\text {OL }}$ |  |  | 80 | mA | Each output current: 5mA |
| Supply Current | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{I}_{\mathrm{cc}}$ |  | 10 | 24 | mA |  |

AC CHARACTERISTICS $\left(T_{A}=-30^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ )

| Parameter |  | Symbol | Value |  |  | Unit | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| Address/Op Codes Setup Time | DI3 to DIO |  | ${ }^{t} A$ | 100 |  |  | ns | $C_{L}=80 \mathrm{pF}$ |
| Address/Op Codes Hold Time | DI3 to DIO | $\mathrm{t}_{\mathrm{B}}$ | 60 |  |  | ns | $C_{L}=20 \mathrm{pF}$ |
| Data Setup Time | DI3 to DIO (Output Mode) | ${ }^{\text {c }}$ c | 200 |  |  | ns | $C_{L}=80 \mathrm{pF}$ |
| Data Hold Time | DI3 to DIO (Output Mode) | ${ }^{\text {D }}$ | 20 |  |  | ns | $C_{L}=20 \mathrm{pF}$ |
| Data Output Delay Time | Ports A to D (Output Mode) | $\mathrm{t}_{\mathrm{PO}}$ |  |  | 700 | ns | $C_{L}=100 \mathrm{pF}$ |
| LDI Pulse Width | $\overline{\text { LDI }}$ | $t_{k}$ | 700 |  |  | ns |  |
| $\overline{\text { CS }}$ Setup/Hold Time | $\overline{\text { CS }}$ | $\mathrm{t}_{\mathrm{cs}}$ | 50 |  |  | ns |  |
| Input Data Setup/Hold Time | Ports A to D (Output Mode) | $\mathrm{t}_{\text {LPI }}$ | 100 |  |  | ns |  |
| Data Output Delay Time | DI3 to DIO (Input Mode) | ${ }^{\text {t }}$ ACC |  |  | 650 | ns | $C_{L}=80 \mathrm{pF}$ |
| Data Hold Time | DI3 to DIO (Input Mode) | $\mathrm{t}_{\mathrm{H}}$ | 0 |  | 150 | ns | $C_{L}=20 \mathrm{pF}$ |

Fig. 5 - TIMING DIAGRAM
OUTPUT MODE (WRITE MODE)


INPUT MODE (READ MODE)


## PACKAGE DIMENSIONS

PLASTIC DIP (Suffix: -P)


## CMOS INPUT/OUTPUT EXPANDER

The Fujitsu MB 88310/MB 88311 are peripheral integrated circuits that can be connected to a 4-bit or 8-bit single-chip microcomputer (MCU) to provide additional I/O ports. Besides furnishing simple I/O port expansion, the MB 88310 and MB 88311 can AND or OR port data with data from the MCU, on instruction from the MCU.
The MB 88310/MB 88311 are pseudo-bidirectional ports. They are accessed in 4-bit units, but each individual bit can be used for either input or output, and input and output can be intermixed. The interface to the MCU requires only the connection of a 4-bit interface port and a strobe signal. All output ports of the MB 88310 are open-drain; MB 88311 output ports all have pull-up resistors. The output ports on both chips are reset to the high-impedance state at power-up.

The MB 88310/MB 88311 are fabricated with silicon-gate CMOS process, and package in a 24-pin plastic DIP or plastic fat package (SOP). Also, they are powered with a single +5 V power supply, and operate over the ambient temperature range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.

## FEATURES

- CMOS Version of Fujitsu MB 88304/88305
- Four 4-bit I/O ports (16 lines)
- Four Functions: Parallel input, parallel output, AND output, and OR output
- AND and OR functions provide individual output capability
- Single-bit input/output: Input and output can be intermixed on each port
- High output drive
- Built-in power-on reset circuit
- $\overline{\mathrm{CS}}$ pin for simplified input/output expansion
- Two output circuit types: Open-drain output (MB 88310) 3-state output (MB 88311)
- Easily connectable to MCUs with 8243 interface
- Single +5 V power supply
- $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ operating temperature range
- Silicon-gate CMOS process
- Two Package Options:
- 24-pin plastic DIP (Suffix:-P)
- 24-pin plastic SOP (Suffix: -PF)


LOGIC SYMBOL


Fig. 1 - BLOCK DIAGRAM


## PIN DESCRIPTION

The MB 88310/88311 have two interfaces: One is the processor interface; $\overline{C S}, \overline{L D I}$, and DI3-DIO, which are used for the processor to communicate with the MB 88310/88311 devices. Another is the expansion I/O ports; Ports A, B, C, and D, which serve as an expansion of the processor's I/O.

Table 1 - PIN DESCRIPTION

| Symbol | Pin No. | Type | Name/Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ | 24 | - | $\mathrm{V}_{\mathbf{C C}}$ : is the +5 V power supply pin. |
| GND | 12 | - | GND: is the ground pin. |
| $\overline{\mathrm{CS}}$ | 6 | 1 | Chip Select: is a low-level-sense high-impedance input. A low level on this input selects the device. This input is TTL-compatible. |
| $\overline{\text { LDI }}$ | 7 | 1 | Load Data Input: is an edge-triggered strobe input. The operation code and address code on DIO to DI3 are latched at the $\overline{\mathrm{LDI}}$ falling edge. The data transffered via DIO to DI3 becomes valid on the rising edge of the $\overline{\mathrm{LDI}}$ input. |
| DI3 to DIO | 8 to 11 | 1/O | Data Bus: is a 4-bit bidirectional port used for interface to the MCU. The operation code and address code provided by the MCU on this port are latched at the falling edge of the $\overline{\mathrm{LD}}$ strobe input, and input/output data is transferred at the rising edge of the $\overline{\text { LDI }}$. The DI port remains in the highimpedance state except when the input operation is executed. |
| PA0 to PA3 | 2 to 5 | 1/0 | Ports A, B, C, and D are 4 -bit bidirectional ports used as expansion I/O ports. These four ports are addressed by address codes provided by the MCU. |
| PBO, PB1 to PB3 | $\begin{gathered} 1 \\ 21 \text { to } 23 \end{gathered}$ | 1/0 | When an input operation code is given by the MCU, data on the addressed port is transferred to the DIO to DI3 at the rising edge of the $\overline{\mathrm{LDI}}$. When an output operation code is provided, data on the DIO to DI3 is transferred and latched to the addressed port at the rising edge of the $\overline{\text { LDI. Logical }}$ |
| PC0 to PC3 | 20 to 17 | 1/O | addressed port at the rising edge of the $\overline{\mathrm{LDI}}$. |
| PD0 to PD3 | 16 to 13 | 1/0 | After a power-on reset, Ports $A$ to $D$ are all set to the high-impedance state. An individual port is released from the high-impedance state when the OUT, AND, or OR function is applied to it. (Since the MB 88310 has open-drain outputs, a line returns to the high-impedance state when an " 1 " is written on it.) |

## FUNCTIONAL DESCRIPTION

The four 4-bit I/O ports of the MB 88310 and MB 88311 are labelled port $A$, port $B$, port $C$, and port $D(P A, P B, P C$, and PD). They serve as expansion I/O ports for a one-chip microcomputer (MCU), and can be accessed via an MCU port. Their functions are as follows:

- Data transfer from the MCU to port A, B, C, or D
- Data transfer from port A, B, C, or D to the MCU
- ANDing of the port A, B, C, or D data with MCU data and latching of the result at port $A, B, C$, or $D$
- ORing of the port $A, B, C$, or $D$ data with MCU data and latching of the result at port A, B, C, or D

For interface to the MCU, the MB 88310 and MB 88311 have a 4 -bit interface port (DIO to DI3), a strobe input ( $\overline{\mathrm{LDI}} \mathrm{pin}$ ), and a chip select input ( $\overline{\mathrm{CS}} \mathrm{pin}$ ). The interface data consists of two 4 -bit units. The first 4 bits give the operation code (2-bits) and address code (2 bits). The second 4-bits are the input or output data. Both 4 -bit units are transferred through the interface port ( DIO to DI 3 ) on timings determined by the strobe ( $\overline{\mathrm{LDI})}$ signal. The MB 88310 or MB 88311 reads the operation code and address code from the MCU on the falling edge of the LDI signal, and sends or receives the I/O data on the rising edge of LDI.
The $\overline{\mathrm{CS}}$ pin is used to read a chip select signal from the MCU's I/O port when two or more MB 88310 or MB 88311 chips are connected to the MCU.

| Ope. Code |  | Function <br> Funct | Addr. Code |  | Port Address |
| :---: | :---: | :--- | :---: | :---: | :---: |
| DI3 | DI2 |  | DIO |  |  |
| 0 | 0 | IN (Input) | 0 | 0 | Port A (PA) |
| 0 | 1 | OUT (Output) | 0 | 1 | Port B (PB) |
| 1 | 0 | OR (Logical OR) | 1 | 0 | Port C (PC) |
| 1 | 1 | AND (Logical AND) | 1 | 1 | Port D (PD) |

## POWER-ON RESET

The MB 88310 and MB 88311 contain an internal power-on reset circuit that detects the rise of $\mathrm{V}_{\mathrm{Cc}}$ on the power supply line and holds the chip circuits in the reset state. In the reset state, the interface port (pins DIO to DI3) is set to the input state, and ports $A$ to $D$ (PA to PD) are in the high-impedance state (except that latched output ports are not reset). The $\mathrm{V}_{\mathrm{CC}}$ line must rise smoothly for the reset circuit to operate. Regardless of the input level (high of low) of the $\overline{\mathrm{LDI}}$ pin at the moment power is applied, the reset state is released at the first falling edge of the $\overline{\mathrm{LDI}}$ input. A power-on reset also occurs if the supply voltage $\left(\mathrm{V}_{\mathrm{cc}}\right)$ drops to 1 V or less, then recovers to the rated voltage.

## OUTPUT MODE (Write Mode)

Corresponding to three functions of the MiCU , the MB 88310 and MB 88311 have three output modes: data transfer output (OUT), logical OR (OR), and logical AND (AND).

- OUT

The designated port latches and outputs the 4 -bit data transferred from the MCU.

- AND

The 4-bit data transferred from the MCU is ANDed with the 4-bit data of the designated port, which then latches the result as output.

- OR

The 4-bit data transferred from the MCU is ORed with the 4-bit data of the designated port, which then latches the result as output.

The operation code and address code sent from the MCU to pins DIO to DI3 of the MB 88310 or MB 88311 are latched on the falling edge of the strobe signal at the $\overline{\mathrm{LDI}} \mathrm{pin}$. The MCU data is read on the rising edge of the strobe signal and sent to the logic circuit of the designated port, where it is processed. The MCU data is then latched as output data.

## INPUT MODE (Read Mode)

The MB 88310 and MB 88311 have only one input mode (IN), corresponding to data input by the MCU.

- IN

The input data at the port designated by the MCU is read and sent to the MCU via the interface port (DIO to DI3).

The operation and address code sent from the MCU to pins DIO to DI3 of the MB 88310 or MB 88311 are latched on the falling edge of the strobe signal at the $\overline{\mathrm{LDI}}$ pin. If the operation code specifies input, the MB 88310 or MB 88311 sends data from the port designated by the address code to the MCU via DIO to DI3.

A power-on reset places the chip in the input mode with ports $A$ to $D$ in the high-impedance state. If only the $I N$ function is used thereafter, the ports remain in the highimpedance state. Release from the high-impedance state takes place when the OUT, AND, or OR function is used.
The MB 88310 and MB 88311 are designed for easy external driving. The MB 88310 has open-drain outputs, while the MB 88311 outputs have pull-up resistors. For both chips, the input level of a port to be used for input can be read by writing a 1 and performing the IN function. Input and output can therefore be intermixed within the four bite of each of the four ports (A to D).

Fig. 2 - PORT CIRCUIT CONFIGURATION


## SINK CURRENT FROM PORTS A TO D

When $\mathrm{V}_{\mathrm{OL}} \leqq 0.45 \mathrm{~V}$, the MB 88310 and MB 88311 can sink 5 mA ( $\mathrm{I}_{\mathrm{OL}}$ ) on each of their $16 \mathrm{I} / \mathrm{O}$ lines simultaneously. When this current sinking capability is not required on all of the $1 / O$ lines, or not all of the lines have to sink 5 mA , the driving capability (sink current) of the other I/O lines can be increased according to the characteristics shown in the curve below.
For instance, if one of the $1 / O$ lines has to sink 9 mA , the total $\mathrm{I}_{\mathrm{OL}}\left(\Sigma \mathrm{I}_{\mathrm{OL}}\right)$ of all the lines can be up to 45 mA .
Example-1: How many 1/O lines with 5 TTL leads can be driven?
$\mathrm{I}_{\mathrm{OL}}=5 \times 1.6 \mathrm{~mA}=8 \mathrm{~mA}$
$\Sigma \mathrm{I}_{\mathrm{OL}} \leqq 60 \mathrm{~mA}$ (from the total $\mathrm{I}_{\mathrm{OL}}$ characteristics curve)
$60 \mathrm{~mA} / 8 \mathrm{~mA}=7 \mathrm{I} / \mathrm{O}$ lines
The chip can drive 7 lines with 5 TTL loads,

making a total of 56 mA on these lines. The remaining 4 mA can be shared among the other 9 I/O lines.

Example-2: Suppose that two of the load lines have $\mathrm{I}_{\mathrm{OL}}=$ 20 mA (at $\mathrm{V}_{\mathrm{OL}} \leqq 1 \mathrm{~V}$ ). Can the MB 88310 or MB 88311 drive the following loads?
$2 \mathrm{I} / \mathrm{O}$ lines: 20 mA (at $\mathrm{V}_{\mathrm{OL}} \leqq 1 \mathrm{~V}$ )
$8 \mathrm{I} / \mathrm{O}$ lines: $\quad 4 \mathrm{~mA}$ (at $\mathrm{V}_{\mathrm{OL}} \leqq 0.45 \mathrm{~V}$ )
6 I/O lines: 3.2 mA (at $\mathrm{V}_{\mathrm{OL}} \leqq 0.45 \mathrm{~V}$ )
Total $\mathrm{I}_{\mathrm{OL}}(2 \times 20 \mathrm{~mA})+(8 \times 4 \mathrm{~mA})+(6 \times 3.2 \mathrm{~mA})$

$$
=91.2 \mathrm{~mA}
$$

Reading the total $\mathrm{I}_{\mathrm{OL}}$ characteristic for $\mathrm{IOL}_{\mathrm{OL}}=$ 4 mA , we see that $\Sigma \mathrm{I}_{\mathrm{OL}} \leqq 93 \mathrm{~mA}$. Since 91.2 mA $\leqq 93 \mathrm{~mA}$, the chip can drive these loads.
Note: The allowable total $\mathrm{I}_{\mathrm{OL}}\left(\Sigma \mathrm{I}_{\mathrm{OL}}\right)$ depends on the maximum sink current of the lines for which $V_{\mathrm{OL}}$ must be equal to or less than 0.4 V .

## NOTICE ON USING INPUT MODE

When the MB 88310/88311 devices work in input mode with a processor which has no 8243 interface, data collision may occur between the device's DI3-DIO port and processor's data bus. In such case, the following limits should be noticed.

1. DC collision: Maximum short circuit current for DI3 DIO $=2.5 \mathrm{~mA}$.
2. AC collision: Maximum short circuit current for DI3 DIO $=30 \mathrm{~mA}$ at T2/T1 (= duty) $<0.1$ and $\mathrm{T} 2<1 \mathrm{~ms}$. (See figure below.)


Fig. 4 - TYPICAL APPLICATIONS

- INTERFACE WITH 4-BIT MICROCOMPUTER

- INTERFACE WITH 8-BIT MICROCOMPUTER

- INTERFACE WITH 4-BIT MICROCOMPUTER


NOTE: * Output port of MB 8841 should be open-drain type.

FUJITSU


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Rating | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\mathbf{I N}}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ to $+7.0^{*}$ | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ | -40 to +85 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\mathrm{stg}}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 1.0 | W |

RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{Cc}}$ | $+5 \pm 10 \%$ | V |
|  | $\mathrm{~V}_{\mathrm{SS}}$ | 0 |  |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ | -40 to +85 | ${ }^{\circ} \mathrm{C}$ |

NOTE: Permanent device damage may occur if ABSOLUTE MAXI. MUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational section of this data sheet. Exposure to ABSOLUTE MAXIMUM RATINGS conditions for extended periods may affect device reliability.
${ }^{*} V_{\text {IN }}$ should not exceed $\mathrm{V}_{\mathrm{Cc}}+$ 0.3 V .

## ELECTRICAL CHARACTERISTICS

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

| Parameter |  | Symbol | Value |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| Input Low Voltage |  |  | $V_{\text {IL }}$ | $\mathrm{V}_{\text {ss }}-0.3$ |  | 0.8 | V |  |
| Input High Voltage |  | $V_{1 H}$ | 2.2 |  | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
| Output Low Voltage | Port A to D | $\mathrm{V}_{\text {OL1 }}$ | - |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}$ |
|  |  | $\mathrm{V}_{\text {OL2 }}$ | - |  | 1.0 | V | $\mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA}$ |
| Output Low Voltage | DI0 to DI3 | $\mathrm{V}_{\text {OL3 }}$ | - |  | 0.6 | V | $\mathrm{I}_{\mathrm{OL}}=1.8 \mathrm{~mA}$ |
| Output High Voltage | Ports A to D | $\mathrm{V}_{\mathrm{OH} 1}$ | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-240 \mu \mathrm{~A}(\mathrm{MB} 88311)$ |
| Output High Voltage | DI0 to DI3 | $\mathrm{V}_{\mathrm{OH} 2}$ | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
| Input Leakage Current | Ports A to D | IIL1 | -10 |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}} \leqq \mathrm{V}_{\text {IN }} \leqq \mathrm{V}_{\text {cc }}$ |
|  | $\begin{aligned} & \text { DIO to DI3, } \\ & \text { CS, } \mathrm{LDI} \end{aligned}$ | IIL2 | -10 |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}} \leqq \mathrm{V}_{\mathrm{IN}} \leqq \mathrm{V}_{\mathrm{Cc}}$ |
| Input Current | Ports A to D | $I_{1}$ |  | 1.0 |  | mA | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}(\mathrm{MB} \mathrm{88311)}$ |
| Total IOL Output Current from 16 Output |  | $\Sigma^{1} \mathrm{OL}$ |  |  | 80 | mA | Each output current: 5mA |
| Supply Current | $V_{c c}$ | Icc1 |  | 200 | 600 | $\mu \mathrm{A}$ | All outputs open, Normal operation |
|  |  | $I_{\text {cce } 2}$ |  | 1.0 | 10 | $\mu \mathrm{A}$ | All outputs open, Standby operation, LDI cycle $=5 \mu \mathrm{~s}$ |

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

| Parameter |  | Symbol | Value |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| Address/Op Codes Setup Time | DI3 to DIO |  | ${ }^{\text {A }}$ A | 100 |  |  | ns | $C_{L}=80 \mathrm{pF}$ |
| Address/Op Codes Hold Time | DI3 to DIO | $t_{B}$ | 60 |  |  | ns | $C_{L}=20 p F$ |
| Data Setup Time | DI3 to DIO (Output Mode) | ${ }^{\text {c }}$ | 200 |  |  | ns | $C_{L}=80 p F$ |
| Data Hold Time | DI3 to DIO (Output Mode) | ${ }^{\text {D }}$ | 20 |  |  | ns | $C_{L}=20 p F$ |
| Data Output Delay Time | Ports A to D (Output Mode) | $t_{\text {PO }}$ |  |  | 700 | ns | $C_{L}=100 p \mathrm{~F}$ |
| $\overline{\text { LDI Pulse Width }}$ | $\overline{\text { LDI }}$ | $\mathrm{t}_{\mathrm{K}}$ | 700 |  |  | ns |  |
| $\overline{\text { CS }}$ Setup/Hold Time | $\overline{\mathrm{CS}}$ | ${ }^{\text {t }}$ cs | 50 |  |  | ns |  |
| Input Data Setup/Hold Time | Ports A to D (Output Mode) | ${ }_{\text {t }}^{\text {LPI }}$ | 100 |  |  | ns |  |
| Data Output Delay Time | DI3 to DIO (Input Mode) | ${ }^{\text {A ACC }}$ |  |  | 650 | ns | $C_{L}=80 \mathrm{pF}$ |
| Data Hold Time | DI3 to DIO (Input Mode) | $\mathrm{t}_{\mathrm{H}}$ | 0 |  | 150 | ns | $C_{L}=20 \mathrm{pF}$ |

Fig. 5 - TIMING DIAGRAM

OUTPUT MODE (WRITE MODE)


INPUT MODE (READ MODE)


## PACKAGE DIMENSIONS

PLASTIC DIP (Suffix: -P)
(24-LEAD PLASTIC DUAL IN-LINE PACKAGE

## PACKAGE DIMENSIONS

PLASTIC SOP (Suffix: -PF)


# MB88306 MB88307 MB88308 MB88309 

CMOS Output Expander

## DESCRIPTION

Each of the four expanders provides a serial I/O port and an 8-bit parallel output port. Data is serially loaded via the input port, converted to an 8 -bit parallel format, and latched. The latched data is then transferred to the parallel output port for distribution. The 8 -bit output port can directly drive a Light Emitting Diode (LED) display; the LED display can be expanded in byte-size increments to make any desired configuration. In terms of output drive and shift clock triggers, each expander is uniquesee description that follows.
Expandor
MB88306
MB88307
MB88308
MB88309

> Output
> CMOS 3-State NMOS Open Drain CMOS 3-State NMOS Open Drain

MB88306/7/8/9 are fabricated by a silicon-gate CMOS process and are packaged in a standard 16 -pin plastic DIP or SOP. All four expanders operate with a single +5 V power source and a 2 MHz shift clock over an ambient temperature range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.

## FEATURES

- 8-bit parallel output
- Serial input/output
- Expandable in 8-bit increments
- LED direct drive capability: 15 mA max at 1.2 V
- Two output port types:
-CMOS 3-state output (MB88306/8)
-NMOS open-drain output (MB88307/9)
- Two shift clock polarities:
—Rising-edge-triggering (MB88306/7)
-Falling-edge-triggering (MB88308/9)
- Simple interface to Fujitsu 4-bit microcomputers
- TTL compatible outputs
- Single +5 V power supply
- Silicon-gate CMOS process
- Two package options:
-16-pin plastic DIP (Suffix -P)
-16-pin plastic SOP (Suffix -PF)

Copyright © 1986 by Fujitsu Limited and Fujitsu Subsidiaries worldwide.
This document contains information considered proprietary by Fujitsu Limited, Tokyo, Japan and its subsidiaries. No part of this document may be copied or reproduced in any form or by any means, or transferred to any third party without the prior written consent of Fujitsu Limited.


[^34]B38306


Figure 2. System Interface


## PIN DESCRIPTION

Figures 1 and 2 show the pin assignment and logic symbol of the MB88306/7/8/9. Table 1 shows the pin description. The MB88306/7/8/9 have two interfaces: one is the processor interface; SI, SC (SC), RESET, LOAD, and OE inputs; the other is the expansion output port; O7-O0, and SO outputs.

Table 1: Pin Description

| Symbol | Number | Type | Name a Function |
| :---: | :---: | :---: | :---: |
| - Power Supply |  |  |  |
| $V_{\mathrm{CC}}$ 16 - +5 V dc power supply pin. <br> $\mathrm{V}_{\mathrm{SS}}$ 8 - Power supply ground pin. |  |  |  |$.$|  |
| :--- |

- Processor Interface

| SI | 14 | 1 | Serial data input to the internal shift register: A data bit on the SI pin is shifted into the MSB of the shift register at the rising edge (MB88306/7) of the shift clock SC or the falling edge (MB88308/9) of the shift clock for $\overline{\mathrm{SC}}$. The data bits are transferred from the processor or from the SO pin of the cascaded devices. |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{SC} \\ & (\widetilde{\mathrm{SC}}) \end{aligned}$ | 4 | 1 | Shift clock input for the internal shift register: The rising edge of SC (MB88306/7) or falling edge of $\overline{\mathrm{SC}}$ (MB88308/9) shifts a data bit on the SI pin into the MSB of the shift register, each bit of the shift register is shifted right, and the LSB of the shift register appears directly on the SO pin. A high level and low level and the falling edge (MB88306/7) or the rising edge (MB88308/9) keep contents of the shift register. This is a hysteresis input. |
| RESET | 15 | 1 | Preset input for the internal data latch: A low level on the $\overline{\text { RESET }}$ pin initializes the data latch in high state, and also inhibits the $\overline{L O A D}$ input. This is a hysteresis input. The $\overline{\text { RESET }}$ input does not affect the shift register and the output drain. |
| $\overline{\text { LOAD }}$ | 2 | 1 | Load enable input for the internal data latch: A low level on the $\overline{\text { LOAD }}$ pin transfers 8 -bit parallel data of the shift register into the data latch. A high level inhibits data transmission from the shift register to the data latch, to hold contents of the data latch. This input is automatically inhibited when the $\overline{\text { RESET input is activated (low). This is a }}$ hysteresis input. |
| $\overline{O E}$ | 9 | 1 | Output enable input of the output driver: A low level on the $\overline{O E}$ pin outputs 8 -bit data of the data latch on the data output pins 07-00. A high level places the 07-00 pins in high impedance state. The $\overline{\mathrm{OE}}$ pin does not control the SO output. |

- Expansion Port

| O7-O0 | $13-10$, <br> $6-3$ | 0 | Parallel data output: This is an 8-bit 3-state data output port. This port outputs 8-bit <br> data in the data latch when the OE pin is activated (low), and is placed in high <br> impedance state when the OE pin is inactive (high). This port is CMOS 3-state output <br> (MB88306/8) or NMOS open-drain output (MB88307/9). Both output drivers can <br> directly drive LEDs. The MSB and LSB of the shift register are output onto the O7 and <br> OO pins, respectively. These pins are TTL compatible. |
| :--- | :---: | :---: | :---: |
| SO | 1 | 0 | Serial data output of the internal shift register: The LSB of the shift register appears <br> directly onto the SO pin with some delay time because the SO output has no output <br> lath. This pin is used to cascade devices to expand the data output port in 8-bit units. <br> This pin is TTL compatible but is not 3-state output controlled by the OE pin. |

## FUNCTIONAL DESCRIPTION

## BLOCK FUNCTIONS

The MB88306/7/8/9 consist of a shift register, a data latch, and an output driver. Figure 1.

## Shift Registor

This is an 8-bit serial-in/parallel-out static shift register, that converts serial data loaded by the processor into 8 -bit parallel data. The rising edge (MB88306/7) or falling edge (MB88308/9) of the shift clock (SC or $\overline{\mathrm{SC}}$ ) shifts a data bit on the SI pin into the MSB of the shift register. Each bit of the shift register is shifted right (MSB $\rightarrow$ LSB), and the LSB of the shift register is shifted out onto the SO pin. Eight parallel output lines of the shift register are internally connected to the data latch inputs. The Shift register has no clear input and, after power-up, the register contents are undefined. The RESET input does not affect the shift register.

## Data Latch

This is an 8-bit D-type transparent latch that holds 8-bit parallel data transferred from the shift register. The latch has two control inputs, LOAD and RESET: The LOAD pin is a data enable input and a low level on this pin transfers contents of the shift register into the data latch. The RESET pin is a preset input and a low level on this pin initializes the data latch in the high state. When
the $\overline{\text { RESET }}$ input is active, the $\overline{\text { LOAD }}$ input is automatically inhibited.

## Output Driver

This is an 8 -bit 3 -state output driver that is driven by 8 bits of data from the data latch. The MB88306/8 have a CMOS 3-state output driver and the MB88307/9 have an NMOS open-drain output driver. Both drivers are controlled by the $\overline{O E}$ input and can directly drive LEDs ( $\mathrm{V}_{\mathrm{OL}}=1.2 \mathrm{~V}$ max at $\mathrm{IOL}^{2}=20 \mathrm{~mA}$ ). A low level on the $\overline{O E}$ pin enables 8 -bit data in the data latch onto output pins O7-O0. A high level forces the output pins to a high impedance state. The RESET input does not affect the output driver.

## SYSTEM INTERFACE

The processor and expansion-port interface for the four expanders is shown in Figure 2. As previously indicated, internal operations of the MB88306 and MB88307 are initiated on the rising edge of Shift Clock (SC) whereas, the same operations in the MB88308 and MB88309 occur on the falling edge of SC. The Serial Output (SO) pin can be used to cascade two or more expanders; an example is shown later in this data sheet.

Table 2. Expander Functions

| Mode | Control Inputs |  |  |  | Internal State |  | Data Outputs07-00 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SC ( $\overline{\mathbf{S C}}$ ) | LOAD | RESET | OE | Shift Register | Data <br> Latch |  |
|  |  |  |  |  |  |  |  |
| Shift | $\uparrow(\downarrow)$ | H | X | X | X | X | X |
| Hold | $\begin{aligned} & H / L, \\ & \downarrow(\uparrow) \end{aligned}$ | X | X | H | X | X | z |
|  |  |  |  | L |  |  | X |
| Load | $\mathrm{X}(\mathrm{X})$ | L | H | H | X | X | Z |
|  |  |  |  | L | H/L | H/L | H/L |
| Reset | X (X) | X | L | H | X | H | Z |
|  |  |  |  | L |  |  | X |

Legend:

| $H=$ High level | $Z=$ High impedance | $\uparrow=$ Rising edge |
| :--- | :--- | :--- |
| $L=$ Low level | $X=$ Don't care | $\downarrow=$ Falling edge |

## FUNCTIONAL DESCRIPTION (Continued)

## OPERATING MODES

## Initialization (Reset Mode)

After power on, contents of the shift register and data latch are undefined. The shift register can not be initialized by hardware because it has no preset input. The data latch can be preset to a high state by a low level on the RESET pin.

## Data Input (Shift a Hold Modes)

Data serially loaded by the processor through the SI pin synchronously with the shift clock, SC (MB88306/7) or SC (MB88308/9). At the rising edge of SC or the falling edge of SC, serial data on the SI pin is shifted into the MSB of the shift register. Each bit of the shift register is shifted right, and the LSB of the shift register underflows onto the SO pin. During high and low levels of SC ( $\overline{\mathrm{SC}})$, contents of the shift register are held.


## FUJITSU

## FUNCTIONAL DESCRIPTION (Continued)

## Data Output (Load Mode)

A low level on the LOAD pin transfers 8 bits of data from the shift register in parallel into the data latch. A low level on the $\overline{O E}$ pin enables the 8 -bit data in the data latch onto the output port pins 07-O0. When the LOAD pin is high, the shift register and the data latch are isolated to hold contents of the data latch. (When the RESET pin is activated, the load input is automatically inhibited.) Also, when the $\overline{O E}$ pin is inactive, the O7-OO pins are forced to a high impedance state. (The data output pins of
the MB88307/9 float when 1s are output because they have NMOS open-drain drivers.)

## APPLICATION

Figure 4 shows an example of an expanded output port configuration.

Figure 4. Expanded Output Port Configuration


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Rating |  | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| Supply Voltage | $V_{\text {CC }}$ | $\mathrm{V}_{\text {SS }}-0.3$ | $\mathrm{V}_{\text {SS }}+7.0$ | V |  |
| Input Voltage | $\mathrm{V}_{\text {IN }}$ | $\mathrm{V}_{\text {SS }}-0.3$ | $\mathrm{V}_{\text {SS }}+7.0$ | V | Should not exceed $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ | $\mathrm{V}_{\text {SS }}-0.3$ | $\mathrm{V}_{\text {SS }}+7.0$ | V | Should not exceed $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ |
| Output Low Current | loL |  | 20 | mA |  |
| Total Output Low Current | ${ }^{\text {2 }} \mathrm{OL}$ |  | 60 | mA |  |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ |  | 200 | mW |  |
| Operating Ambient Temperature | $\mathrm{T}_{\mathrm{A}}$ | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 | +150 | ${ }^{\circ} \mathrm{C}$ |  |

Note:
Permanent device damage may occur if the above ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## recommended operating conditions

| Parameter | Symbol | Value |  | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| Supply Voltage | $\mathrm{V}_{\mathrm{Cc}}$ | 4.5 | 5.5 | V | Guaranteed range |
|  | $V_{\text {SS }}$ | 0 | 0 | V |  |
| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | $0.7 \mathrm{~V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V | Non-hysteresis inputs: SI, $\overline{O E}$ |
|  | $\mathrm{V}_{\text {IHS }}$ | $0.8 \mathrm{~V}_{\text {CC }}$ | $\mathrm{V}_{C C}+0.3$ | V | Hysteresis inputs: $\overline{\text { RESET, }}$ LOAD, SC ( $\overline{\mathbf{S C}}$ ) |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ | $0.3 \mathrm{~V}_{\text {cC }}$ | V | Non-hysteresis inputs: SI, $\overline{O E}$ |
|  | $\mathrm{V}_{\text {ILS }}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ | $0.2 \mathrm{~V}_{C C}$ | V | Hysteresis inputs: $\overline{\mathrm{RESET}}, \overline{\text { LOAD }}$, SC ( $\overline{\mathbf{S C}})$ |
| Operating Ambient Temperature | $\mathrm{T}_{\text {A }}$ | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |  |

## DC CHARACTERISTICS

(Recommended operating conditions unless otherwise noted)

| Paramoter | Symbol | Pin | Condition | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max |  |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | O7-001, SO | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ | 2.4 |  |  | V |
|  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{l}_{\mathrm{OH}}=-10 \mu \mathrm{~A}$ | 4.0 |  |  | V |
| Output Low Voltage | VOL | O7-00, SO | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{l}_{\mathrm{OL}}=1.8 \mathrm{~mA}$ |  |  | 0.4 | V |
|  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{l}_{\mathrm{OL}}=5.0 \mathrm{~mA}$ |  |  | 0.6 | V |
|  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{l} \mathrm{OL}=15 \mathrm{~mA}$ |  |  | 1.2 | V |
| Input Leakage Current | ILL | $\begin{gathered} \mathrm{SI}, \mathrm{SC},(\overline{\mathrm{SC})} \\ \overline{\mathrm{RESET}, \mathrm{LOAD}, \overline{O E}} \end{gathered}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  | -10 | $\mu \mathrm{A}$ |
| High-Impedance Output Leakage Current | loz | 07-001 | $\begin{aligned} & V_{\mathrm{CC}}=5.5 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \text { Off State } \end{aligned}$ |  |  | $\pm 10$ | $\mu \mathrm{A}$ |
| Open-Drain Output Leakage Current | $l_{\text {leak }}$ | 07-002, SO | $\begin{aligned} & V_{\mathrm{CC}}=5.5 \mathrm{~V}, \\ & V_{\text {IN }}=5.5 \mathrm{~V}, \\ & \text { Off State } \end{aligned}$ |  |  | 10 | $\mu \mathrm{A}$ |
| Supply Current | Icc | Vcc | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ (Typ), <br> 5.5 V (Max), fC $=2 \mathrm{MHz}$, <br> All Outputs Open and <br> All Inputs Pulled <br> Up/Down to $\mathrm{V}_{\mathrm{CC}} / \mathrm{V}_{\mathrm{SS}}$ |  | '100 | 200 | $\mu \mathrm{A}$ |

Notes:

1. This parameter is specified for MB88307/MB88309 (CMOS 3-state output).
2. This parameter is specified for MB88306/MB88308 (NMOS open-drain output).

## AC CHARACTERISTICS

(Recommended operating conditions unless otherwise noted)
Input Timing Requirements

| Parameter | Symbol | Pin | Condition | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max |  |
| Shift Clock Frequency | $\mathrm{fc}_{\mathrm{C}}$ | SC ( $\overline{\mathrm{SC}}$ ) |  |  |  | 2 | MHz |
| Shift Clock Cycle Time | ${ }_{\text {teyc }}$ | SC ( $\overline{\mathrm{SC}}$ ) | Fig. 5 (Fig. 6) | 0.5 |  |  | $\mu \mathrm{s}$ |
| Shift Clock Pulse Width | twCH | SC ( $\overline{\mathrm{SC}}$ ) | Fig. 5 (Fig. 6) | 200 |  |  | ns |
|  | twCL |  |  |  |  |  |  |
| Shift Clock Rise/Fall Times | $\mathrm{t}_{\mathrm{cr}}$ | SC ( $\overline{\mathrm{SC}}$ ) | Fig. 5 (Fig. 6) | 10 |  | 100 | ns |
|  | $\mathrm{t}_{\mathrm{cf}}$ |  |  |  |  |  |  |
| Input Data Setup Time | ts | SI | Fig. 5 (Fig. 6) | 100 |  |  | ns |
| Input Data Hold Time | $t_{H}$ | SI | Fig. 5 (Fig. 6) | 50 |  |  | ns |
| Reset Pulse Width | $t^{+} 1$ | RESET | Fig. 7 | 100 |  |  | ns |
| Load Pulse Width | tw2 | LOAD | Fig. 7 | 200 |  |  | ns |

## AC ChARACTERISTICS

(Recommended operating conditions unless otherwise noted) (Continued)

Figure 5. Input Timing for MB88306 and MB88307


Figure 6. Input Timing for mB88308 and MB88309


Figure 7. Input Timing for All Expanders


## AC CHARACTERISTICS

(Recommended operating conditions unless otherwise noted) (Continued)

## Output Timing Responses

| Parameter | Symbol | Pin | Condition | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max |  |
| Parallel Data Output Delay Time | todit | 07-00 | Output Load: <br> $50 \mathrm{pF}+1.2 \mathrm{k} \Omega$ <br> See Fig. 8 |  |  | 500 | ns |
|  | todi1 |  |  |  |  | 200 | ns |
|  | $\mathrm{t}_{\mathrm{DOH} 2}$ |  |  |  |  | 500 | ns |
|  | $\mathrm{t}_{\mathrm{DOL} 2}$ |  |  |  |  | 200 | ns |
| Serial Data Output Delay Time | tsDH | SO |  |  |  | 500 | ns |
|  | tsDL |  |  |  |  | 200 | ns |

Figure 8. Output Timing for All Expanders
Parallel Data Output (1)- $\overline{L O A D}$ Controlled


8306-11
Parallel Data Output (2)- $\overline{O E}$ Controlled


Serial Data Output



## Section 3



Memory Controllers

| 3-2 | MB1422A | Dynamic RAM Controller LSI |
| :--- | :--- | :--- |
| 3-22 | MB1430 | 1M Dynamic RAM Controller |
| 3-23 | MB1412A | LS-TTL Error Checking and Correction Circuit |
| 3-39 | MB1426 | 16-Bit Error Checking and Correction |

## FUJITSU

## DYNAMIC RAM

 CONTROLLER LS
## DYNAMIC RAM CONTROLLER

The Fujitsu MB 1422A is a high performance DRAM controller LSI.
The MB 1422A controls address multiplexing, refresh timing and their arbitration, and realizes one chip DRAM peripheral controller.
The MB 1422A is designed to easily interface 64 K and 256 K DRAM to the system based on the 8086 or 68000 .
The MB 1422A is fabricated in an advanced low-power Schottky TTL process. The device is housed in a plastic 42 -pin Dual In-line-Package, 42 pin shrink DIP, and 44-pin PLCC.

- 256k and 64k Dynamic-RAM control capability
- Directly addresses and drives up to 44 DRAMs without external drivers
- Internal/external refresh capability
- Supports $8086(5 \mathrm{MHz}$ or 8 MHz$)$ or $68000(8 \mathrm{MHz}$ or 12.5 MHz$)$ type microprocessor
- +5V only schottky TTL technology for high performance
- Low power dissipation: 440 mW Typ.
- TTL compatible I/O
- Standard 42 pin Plastic DIP (Suffix: -P)
- Standard 42 pin Plastic Shrink DIP (Suffix: -P)
- Standard 44 pin Plastic LCC (Suffix: -PD)


## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Rating | Unit |
| :--- | :---: | :---: | :---: |
| Powery Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | +7.0 | V |
| Input Voltage | $\mathrm{V}_{\mathrm{l}}$ | -0.5 to +5.5 | V |
| Output Voltage | $\mathrm{V}_{\mathrm{O}}$ | -0.5 to +5.5 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | -25 to +85 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |

NOTE: Permanent device damage may occur if ÁBSOULUTE iníx íniviuini RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

Fig. 1 - MB 1422A BLOCK DIAGRAM


## BLOCK FUNCTIONS

Multiplexer: $\quad$ Multiplexes the CPU addresses (CA and RA) and refresh address to nine row and nine column address.
Timing Generator: Generates $\overline{\operatorname{RAS}}, \overline{\mathrm{CAS}}$ and $\overline{\mathrm{WE}}$ signals by address strobe (AS) and $\mathrm{R} / \overline{\mathrm{W}}$ signals from CPU and refresh request signal from the arbiter. Sends select signals for row, column or refresh address to multiplexer.
Refresh Counter: Generates the refresh address and counts up at each cycle.
Refresh Time Generator: Generates an internal refresh request signal.
Arbiter: Resolves the conflict of read/write and refresh cycle.

Table 1 - PIN DESCRIPTION

| Symbol | Pin |  | Type | Pin Name and Function |
| :---: | :---: | :---: | :---: | :---: |
|  | DtP | PLCC |  |  |
| MODEO/ RESET | 9 | 10 | 1 | Internal/External Refresh Select; <br> This pin is used to select refresh mode, internal refresh or external refresh. If MODEO/ $\overline{R E S E T}=$ " $H$ ", internal refresh mode is selected. <br> If MODEO/ $\overline{\operatorname{RESET}}=$ " $L$ ", external refresh mode. <br> The falling edge of MODEO/ $\overline{\operatorname{RESET}}$ resets the refresh address counter. |
| $\frac{\text { MODE } 1 /}{\text { RFRQ }}$ | 38 | 40 | 1 | Internal Interval Select/External Refresh Request; <br> When Internal Refresh mode is selected (MODEO/ $\overline{\text { RESET }}=$ " $H$ "), this pin is used as refresh interval selection. <br> If CLK $\geqq 15 \mathrm{MHz}$, it must be " L ", and if CLK -24 to 25 MHz , it must be " H ". <br> When External Refresh mode is selected (MODEO/ $\overline{\operatorname{RESET}}=$ " $L$ "), this pin is used as refresh request. And the refresh starts when MODE $1 / \overline{R E R Q}=$ " $L$ " is strobed by the falling edge of CLK. |
| $\overline{\text { AS }}$ | 40 | 42 | 1 | Address Strobe; <br> Memory access starts when $\overline{A S}=$ " $L$ " is strobed by the falling edge of CLK, and ends at the rising edge of $\overline{\mathrm{AS}}$, that is, both $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ become " H " (inactive) when $\overline{\mathrm{AS}}$ turns " H " except refresh mode. The $\overline{A S}$ must be kept " $L$ " until $\overline{R A S}$ and $\overline{\mathrm{CAS}}$ pulse widths have been satisfied for DRAM specifications. |
| $R / \bar{W}$ | 39 | 41 | 1 | Read/Write Control; <br> This pin is used to select memory read or write mode. If $R / \bar{W}=$ " $H$ ", read mode is selected. If $R / \bar{W}=$ " $L$ ", write mode. |
| $\overline{C S}$ | 42 | 44 | 1 | Chip Select; <br> This pin is used to control the states of output pins except for RDY. When $\overline{C S}=$ " $H$ ', $\overline{\text { RAS }}, \overline{C A S}, \overline{W E}$ and MA (MAO to MA8) become high impedance state. |
| BS | 41 | 43 | 1 | Bank Select; <br> This pin is used to select either of the two banks of DRAM arrays. <br> If $B S=$ " $L$ ", the lower bank ( $\overline{\mathrm{RAS}} 0$ ) is selected. <br> If $B S=$ " $H$ ", the upper bank ( $\overline{R A S} 1$ ) is selected. |
| CLK | 10 | 11 | 1 | Clock input; <br> This input provides basic timing for the internal logic. $8086(5 \mathrm{MHz}) \rightarrow \mathrm{CLK}=15 \mathrm{MHz}$ <br> $8086(8 \mathrm{MHz}) \rightarrow$ CLK $=24 \mathrm{MHz}$ $68000(8 \mathrm{MHz}) \rightarrow \mathrm{CLK}=16 \mathrm{MHz}$ $68000(12.5 \mathrm{MHz}) \rightarrow \mathrm{CLK}=25 \mathrm{MHz}$ <br> The CLK frequency should be higher or equals to 15 MHz . |
| RAO | 1 | 2 | 1 | Row Address; |
| RA1 | 3 | 4 |  | These inputs are used to generate memory row address. |
| RA2 | 5 | 6 |  |  |
| RA3 | 7 | 8 |  |  |
| RA4 | 12 | 13 |  |  |
| RA5 | 14 | 15 |  |  |
| RA6 | 16 | 17 |  |  |
| RA7 | 18 | 19 21 |  |  |

FUJITSU
Hixinixillinlill MB 1422A

Table 2 - PIN DESCRIPTION (Continuted)

| Symbol | Pin |  | Type | Pin Name and Function |
| :---: | :---: | :---: | :---: | :---: |
|  | DIP | PLCC |  |  |
| CAO <br> CA1 <br> CA2 <br> CA3 <br> CA4 <br> CA5 <br> CA6 <br> CA7 <br> CA8 | $\begin{array}{r} 2 \\ 4 \\ 6 \\ 8 \\ 13 \\ 15 \\ 17 \\ 19 \\ 21 \end{array}$ | $\begin{array}{r} 3 \\ 5 \\ 7 \\ 9 \\ 14 \\ 16 \\ 18 \\ 20 \\ 22 \end{array}$ | 1 | Column Address; <br> These inputs are used to generate memory column address. |
| $\begin{aligned} & \overline{\text { RAS } 0} \\ & \overline{\text { RAS }} 1 \end{aligned}$ | $\begin{aligned} & 37 \\ & 36 \end{aligned}$ | $\begin{aligned} & 39 \\ & 38 \end{aligned}$ | O* | Row Address Strobe; <br> These outputs are used by DRAM to strobe Row Address present on MAO to MA8. <br> Either $\overline{\mathrm{RAS}} 0$ or $\overline{\mathrm{RAS}} 1$ is selected by BS. <br> The selected $\overline{R A S}$ is issued after $\overline{A S}=$ " $L$ " is strobed by the falling edge of CLK. <br> In the refresh mode (both Internal and External), both $\overline{\mathrm{RAS}} 0$ and $\overline{\mathrm{RAS}} 1$ are issued. <br> These outputs become high impedance state if $\overline{\mathrm{CS}}=$ " H ". <br> Each output drives maximum 22 DRAMs directly without external driver. |
| $\begin{aligned} & \overline{\mathrm{CAS}} 0 \\ & \overline{\mathrm{CAS}} 1 \end{aligned}$ | $\begin{aligned} & 35 \\ & 34 \end{aligned}$ | $\begin{aligned} & 37 \\ & 36 \end{aligned}$ | O* | Column Address Strobe; <br> These outputs are used by DRAM to strobe column address, present on MA0 to MA8. <br> These outputs are issued from the CLK rising edge, which is 1.5 CLK cycles after $\overline{A S}=$ " $L$ " is strobed, with delay time of $\mathrm{t}_{\text {CASN }}$. (See Fig. 4 and 5.) <br> These outputs are not controlled by BS, i.e., both $\overline{\mathrm{CAS}} 0$ and $\overline{\mathrm{CAS}} 1$ are issued every memory access. <br> In the refresh mode (both Internal and External), these outputs are kept " H ". <br> These outputs become high impedance state if $\overline{\mathrm{CS}}=$ " H ". Each output drives maximum 22 DRAMs directly without external driver. |
| $\overline{W E}$ | 22 | 24 | O* | Write Enable; <br> This output is used by DRAM to control read or write cycle. <br> This output depends on $R / \bar{W}$ input, i.e., it is asynchronous with CLK. <br> This output drives maximum 44 DRAMs directly without external driver. |
| RDY | 23 | 25 | 0 | Ready; <br> This output identifies whether the memory arrays is refresh mode. If RDY = " L ", refresh is excuted. If RDY $=$ " H ", refresh is not executed. |
| MAO <br> MA1 <br> MA2 <br> MA3 <br> MA4 <br> MA5 <br> MA6 <br> MA7 <br> MA8 | $\begin{aligned} & 33 \\ & 31 \\ & 30 \\ & 29 \\ & 28 \\ & 27 \\ & 26 \\ & 25 \\ & 24 \end{aligned}$ | $\begin{aligned} & 35 \\ & 33 \\ & 32 \\ & 31 \\ & 30 \\ & 29 \\ & 28 \\ & 27 \\ & 26 \end{aligned}$ | O* | Memory Address; <br> These outputs are used by DRAM for address inputs, row, column and refresh row address. <br> These outputs can drive maximum 44 DRAMs directly without external driver. <br> These outputs become high impedance state if $\overline{\mathrm{CS}}=$ " H ". |

I: Input, $\mathrm{O}^{*}$ : 3-State output, O: Output

## FUNCTIONAL DESCRIPTION

## Read/Write Cycle Mode;

The memory read and write cycle starts from $\overline{\mathrm{AS}}=$ " L ". The selected $\overline{\mathrm{RAS}}$ is issued after haif cycle period from the falling edge of CLK which strobes $\overline{\mathrm{AS}}=$ " L ". The $\overline{\mathrm{CAS}}$ is issued after 1.5 cycles from $\overline{\mathrm{AS}}$ strobed. The $\overline{\mathrm{AS}}$ input must satisfy the set up time, $\mathrm{T}_{\text {ASSL }}$, referenced to the falling edge of CLK. The address at MA0 to MA8 are changed from row to column at the 3rd rising edge of CLK. The $\overline{\mathrm{WE}}$ output depends on $R / \bar{W}$ input, controlled by neither CLK nor $\overline{A S}$, i.e., if $R / \bar{W}$ changes from " $H$ " to " $L$ " in memory cycle ( $\overline{A S}=$
" $L$ "), $\overline{W E}$ is changed regardless of states of $\overline{A S}$ and CLK. Therefore, Read-Modify-Write cycle can be executed. Refer to the "APPLICATION" section below.
The bank select (BS) must not change during $\overline{A S}=$ " $L$ " because the $\overline{\mathrm{RAS}}$ 's are controlled by BS . If BS were changed during $\overline{\mathrm{AS}}=$ " L ", the both $\overline{\mathrm{RAS}}$ ( $\overline{\mathrm{RAS}} 0$ and $\overline{\mathrm{RAS}} 1$ ) would be selected during one memory access cycle. Refer to the Fig. 2.

Fig. 2 - BANK SELECTION


## Refresh Mode;

The MB 1422A provides two types of refresh modes as internal refresh mode and external refresh mode selected by MODEO/ $\overline{\text { ESSET. Both }} \overline{\mathrm{RAS}} 0$ and $\overline{\mathrm{RAS}} 1$ are issued during refresh mode Both $\overline{\mathrm{CAS}} 0$ and $\overline{\mathrm{CAS}} 1$ are set " H " until completion of the refresh cycles.
The refresh addresses are provided by internal refresh counter on MA0 to MA8 before issuing RAS.
During refresh mode (both internal and external), RDY is set " $L$ " to identify the MB 1422A is in refresh cycle.
When $\overline{A S}$ is brought " $L$ " during RDY $=$ " $L$ ", the memory access (both Read and Write Cycle) is ignored and the MB 1422A executes $\overline{\mathrm{RAS}}$-only refresh.

1. Internal Refresh Mode;

The internal refresh mode is selected by MODEO/ $\overline{\text { RESET }}$ $=$ " H " and executed by internal refresh request.
In the internal refresh mode, the refresh is automatically taken place by the specified period since internal refiest request signal is generated by the refresh time generator. The internal refresh will be completed within ten CLK cycles, therefore, the RDY remains " $L$ " until ten CLK cycles.

## 2. External Refresh Mode;

The external refresh mode is selected by MODEO/ $\overline{\operatorname{RESET}}$ $=$ " $L$ " and executed when the MODE1/ $\overline{\operatorname{REFO}}=$ " $L$ " is strobed by the falling edge of CLK.
The external refresh will be completed within twelve CLK cycles after MODE $1 / \overline{\mathrm{RFRO}}=$ " $L$ " is strobed by the falling of CLK. However, the RDY is kept " $L$ " within ten CLK cycles. Because the first falling edge of CLK after MODE $1 / \overline{\mathrm{RFRO}}=$ " $L$ " is used to check the status of $\overline{\mathrm{AS}}$ and the second falling edge is used to issue RDY signal.
If $\overline{A S}=$ " $L$ " is strobed by the first falling edge of CLK, the MB 1422A executes memory access (read or write) first and refresh mode.

## Arbitration of memory access and refresh request;

The MB 1422A arbitrates memory access and refresh request, If refresh request, either external or internal, is strobed during memory access cycle, the MB 1422A executes memory áceess cycie first and refresh cycie. Ōn the other hands, if memory access request is strobed during refresh mode the memory access request will be ignored until the end of refresh cycle.

FUNCTIONAL TRUTH TABLE

| BS | READ/WRITE CYCLE |  | REFRESH CYCLE |  | $\overline{\text { CS }}$ | MA0 to MA8 | $\overline{\text { RAS0 }}$ | CAS0 <br> CAS1 | $\overline{W E}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\text { RASO }}$ | $\overline{\text { RAS }} 1$ | $\overline{\text { RASO }}$ | $\overline{\text { RAS } 1}$ |  |  |  |  |  |
| L | Valid | H | Valid |  | L | Valid |  |  |  |
| H | H | Valid |  |  | H | High-Z |  |  |  |


| MODE0/ $\overline{\text { RESET }}$ | MODE1/ $\overline{\text { RFRO }}$ | Function |
| :---: | :---: | :---: |
| H | L | Internal Refresh mode, CLK $\geqq 15 \mathrm{MHz}{ }^{*}$ |
| H | H | Internal Refresh mode, CLK $=24$ to $25 \mathrm{MHz}{ }^{* *}$ |
| L | $\overline{\text { RFRO }}$ | External refresh mode |

*: For $8086(5 \mathrm{MHz})$ and $68000(8 \mathrm{MHz})$, the refresh is executed once in every 232 CLK cycles.
**: For $8086(8 \mathrm{MHz})$ and $68000(12.5 \mathrm{MHz})$, the refresh is executed once in every 372 CLK cycles.

## DRAM INTERFACE

## Addressing;

The MB 1422A is capable to address directly maximum 512 K address with 256 K DRAM. Fig. 3 shows the example of interfacing between MPU and MB 1422A for both 64 K and 256K DRAM system. The DRAMs require address
set-up and hold times on both row and column addresses. The MB 1422A resolves such critical timing requirement. Fig. 4 shows an example of calculation of address set up and hold times.

Fig. 3 - INTERFACING BETWEEN MPU AND DRAM


Fig. 4 - EXAMPLE OF ADDRESS SET UP AND HOLD TIME CALCULATION


## Read/Write Command;

Since the $\overline{W E}$ depends on $R / \bar{W}$, it must be taken a care to set-up and hold times for Read and Write command. Therefore, $R / \bar{W}$ must be valid before $\overline{C A S}=" L$ ", and $R / \bar{W}$ must not be changed until Read or Write command hold time
has been satisfied except for read-modify-write cycle. Fig. 5 shows an example of calculation of Read/Write command set up times.

Fig. 5 - READ/WRITE COMMAND SET UP/HOLD TIME


Set Up Time;
$t_{W C S}=\left(t_{C A S N}+1.5 t_{C Y}+t_{A S S L}\right)-\left(t_{D 1}+t_{W E H L}\right)$
$t_{\text {RCS }}=\left(\mathrm{t}_{\mathrm{CASN}}+1.5 \mathrm{t}_{\mathrm{C}} \mathrm{Y}+\mathrm{t}_{\text {ASSL }}\right)-\left(\mathrm{t}_{\mathrm{D} 1}+\mathrm{t}_{\text {WELH }}\right)$
Hold Time;
$t_{\text {RCH }}=t_{D 2}-t_{A S C A S}+t_{\text {WEHL }}$

## Initiallization;

In the single power supplied DRAM which has substrate bias generator, it is necessary $200 \mu$ s pause time to let substrate stable and after that eight dummy $\overline{\mathrm{RAS}}$ cycles must be done for initiallization of internal dynamic circuitly. Therefore, memory access is not executed correctly until the above pause time and eight dummy cycles have been satisfied. In the case of using internal refresh mode, eight $\overline{A S}$ clocks or eight refresh cycles must be applied after $200 \mu$ s
pause time.
On the other hand, in the case of using external refresh mode eight refresh cycles (keeping MODE1/ $\overline{\operatorname{RFRO}}=$ " $L$ " until eight $\overline{\operatorname{RAS}}=$ " $L$ " is detected) or eight $\overline{A S}$ cycles must be applied.
Refresh;
The MB 1422A is capable of doing refresh mode for both $2 \mathrm{~ms} / 128$ cycles and $4 \mathrm{~ms} / 256$ cycles.

FUJITSU


## MPU INTERFACE

The MB 1422A is capable of interfacing with both 8086 and 6800.
The examples of interfacing with these MPU's are shown in Fig. 6 and 7.

Fig. 6 - EXAMPLE OF INTERFACE BETWEEN MB 1422A AND 8086


Fig. 7 - EXAMPLE OF INTERFACE BETWEEN MB 1422A AND 68000


FUJITSU

## APPLICATION

Memory Access Cycle Time;
Since memory access cycle depends on $\overline{\mathrm{AS}}$, the memory cycle time can be controlled by $\overline{\mathrm{AS}}$. The minimum cycle
time can be calculated with Fig. 8.

Fig. 8 - MEMORY ACCESS CYCLE TIME


The minimum $\overline{\mathrm{AS}}$ Pulse Width must be $\mathrm{t}_{\mathrm{RSH}}+\mathrm{t}_{\mathrm{RCD}}+$ $t_{\text {RASN }}+0.5 t_{C Y}+t_{\text {ASSL }}-t_{\text {ASRAS }}$.
The maximum $\overline{\mathrm{AS}}$ pulse width must not be greater than maximum $t_{R A S}$ of DRAM.

## Read-Modify-Write;

The MB 1422A provides a capable of read-modify-write and delayed write cycle by delayed write command input on

Fig. 9 shows an example of write command on $\mathrm{R} / \overline{\mathrm{W}}$ for read-modify-write cycle. $R / \bar{W}$.

Fig. 9 - WRITE COMMAND INPUT FOR READ-MODIFY-WRITE


In the Read-Modify-Write cycle, the write command ( $\overline{W E}$ ) should be delayed with tcwD. Therefore, the write command on the $R / \bar{W}$ should be delayed.
Delay Time of $\mathbf{R} / \bar{W}$ from $\overline{A S}$ is;

$$
\mathrm{t}_{A S S L}+1.5 \mathrm{t}_{\mathrm{C}}+\mathrm{t}_{\mathrm{CASN}}+\mathrm{t}_{\mathrm{CW}}-\mathrm{t}_{\text {WEHL }} .
$$

The $t_{\text {RWL }}$ and $t_{C W L}$ must be noticed in the read-modifywrite cycle.
Therefore, $\overline{\mathrm{AS}}$ must be " $L$ " until delay time of ${ }^{t} \mathrm{CWL}$ ${ }^{t_{A S C A S}}$ and $\mathrm{t}_{\text {RWL }}{ }^{-t_{\text {ASRAS }}}$ have been satisfied.

## Refresh;

There are two ways for refreshing DRAM in the memory system as cycle steal (or distributed) refresh and burst refresh.
The MB 1422A provides both ways.
In the internal refresh mode, cycle steal refresh is taken place automatically without any external control circuit.
On the other hands, in the external refresh mode, both ways can be used by controlling MODE1/ $\overline{\mathrm{RFRQ}}$ input.

1. Cycle Steal Refresh

The cycle steal refresh is taken place by the period divided required refresh period by required refresh cycle, i.e., $4 \mathrm{~ms} / 256=15.6 \mu \mathrm{~s}$, and the refresh request should be
applied at a period of $15.6 \mu \mathrm{~s}$. In the external refresh mode the refresh period counter is necessary for this purpose.
2. Burst Refresh

The burst refresh is taken place by doing refresh for all required refresh cycles continuously, i.e., the refresh request should be applied at a period of required refresh cycles. When MODE1/ $\overline{\operatorname{RFRO}}$ is kept " $L$ " through all refresh cycles ( 256 or 128 ), one refresh cycle will be completed within seven CLK cycles because next refresh request is strobed during the refresh cycle.
Fig. 10 shows an example of burst refresh cycle with keep MODE1/ $\overline{R F R Q}=$ " $L$ " through the cycle.


## RDY Output;

The MB 1422A issues ready signal to identify whether DRAM array is ready or not. The following cautions are necessary to send RDY to MPU.

- RDY must be sent only when the DRAM array is being accessed.
- RDY must be sent synchronously with MPU operation.
- RDY must be sent before MPU starts operation, and if RDY is issued during MPU operation, RDY must be held until the completion of current MPU operation and then sent to MPU.

The Fig. 11 shows an example of external circuit to send RDY to MPU.

Fig. 11 - EXAMPLE OF RDY INTERFACE TO MPU


In this case, both set up and hold times on READY of MPU miust be satisfíied.

FUJITSU


## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Value |  | Unit |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. |  |  |
| Supply Voltage | ${ }^{*} \mathrm{~V}_{\mathrm{Cc}}$ | 4.5 | 5.0 | 5.5 | V |
| Output High Current | $\mathrm{I}_{\mathrm{OH}}$ | - | - | -3.3 | mA |
| Output Low Current | $\mathrm{I}_{\mathrm{OL}}$ | - | - | 10 | mA |
| Ambient Temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 | - | 70 | ${ }^{\circ} \mathrm{C}$ |

*: Referenced to GND

## DC CHARACTERISTICS

(Recommended Operation Conditions unless otherwise noted.)

| Parameter |  | Symbol | Value |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| Supply Current |  |  | ${ }^{\text {cc }}$ |  | 88* | 145 | mA | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$ |
| Input Low Current | Except for CLK and $\overline{C S}$ | $I_{\text {IL }}$ | , |  | -200 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IN}}=0.5 \mathrm{~V} \end{aligned}$ |
|  | CLK, $\overline{C S}$ |  |  |  | -400 |  |  |
| Input High Current |  | $\mathrm{I}_{1+1}$ |  |  | 20 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{C C}=5.5 \mathrm{~V} \\ & V_{I N}=2.4 \mathrm{~V} \end{aligned}$ |
|  |  | $\mathrm{I}_{1+2}$ |  |  | 100 |  | $\begin{aligned} & V_{c C}=5.5 \mathrm{~V} \\ & V_{I N}=5.5 \mathrm{~V} \end{aligned}$ |
| Input Clamp Voltage |  | $V_{\text {IC }}$ |  |  | -1.5 | V | $\begin{aligned} & V_{c c}=4.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA} \end{aligned}$ |
| Output Low Voltage |  | $\mathrm{V}_{\text {OL }}$ |  |  | 0.5 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA} \end{aligned}$ |
| Output High Voltage |  | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  |  | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OH}}=-3.3 \mathrm{~mA} \end{aligned}$ |
| Output Leakage Current (High-Z) |  | Ioz | -100 |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \mathrm{~V}_{\text {OUT }}=0.5 \mathrm{~V} / 2.4 \mathrm{~V} \end{aligned}$ |
| Output Short Circuit Current |  | Ios | -50 | -100* | -200 | mA | $\begin{aligned} & V_{C C}=5.5 \mathrm{~V}, \\ & V_{O U T}=0 \mathrm{~V} \end{aligned}$ |
| Input Low Voltage |  | $V_{\text {IL }}$ | - | - | 0.8 | V |  |
| Input High Voltage |  | $\mathrm{V}_{\text {IH }}$ | 2.0 | - | - | V |  |

*: All typical values are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

## AC CHARACTERISTICS

(Recommended operating conditions unless otherwise noted.)

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |
| $\overline{\text { AS }}$ Low Set up Time to CLK | $\mathrm{t}_{\text {ASSL }}$ | 10 |  |  | ns |
| $\overline{\text { FRRQ Low Set up Time to CLK }}$ | $t_{\text {RFROS }}$ | 10 |  |  | ns |
| $\overline{\mathrm{RFRO}}$ Low Hold Time to CLK | $t_{\text {RFROH }}$ | 10 |  |  | ns |
| $\overline{\text { RFRO }}$ High Set up Time to CLK | $t_{\text {REFSS }}$ | 10 |  |  | ns |
| $\overline{\text { AS }}$ High Set up Time to CLK | $\mathrm{t}_{\text {ASSH }}$ | 10 |  |  | ns |
| BS Set up Time to CLK | $\mathrm{t}_{\text {BSS }}$ | 10 |  |  | ns |
| BS Hold Time to $\overline{\text { AS }}$ | $\mathrm{t}_{\mathrm{BSH}}$ | 10 |  |  | ns |
| CLK High Time | $t_{\text {wp }}$ | 15 |  |  | ns |
| CLK Low Time | $\mathrm{t}_{\mathrm{WN}}$ | 15 |  |  | ns |
| Delay Time from CLK to $\overline{\text { RAS }}$ n | $\mathrm{t}_{\text {RASN }}$ |  | 20 | 32 | ns |
| Delay Time from $\overline{\mathrm{AS}}$ to $\overline{\mathrm{RAS}} \mathrm{n}$ | $t_{\text {ASRAS }}$ |  | 18 | 30 | ns |
| Delay Time from CLK to $\overline{\text { CAS }}$ n | ${ }^{\text {t CASN }}$ |  | 37 | 52 | ns |
| Delay Time from $\overline{\mathrm{AS}}$ to $\overline{\mathrm{CAS}} \mathrm{n}$ | $\mathrm{t}_{\text {ASCAS }}$ |  | 36 | 53 | ns |
| Delay Time from RAm to MAm | $\mathrm{t}_{\text {RAMA }}$ |  | 21 | 35 | ns |
| Delay Time from CLK to MAm | $\mathrm{t}_{\text {MAN }}$ |  | 27 | 42 | ns |
| Delay Time from CAm to MAm | ${ }^{\text {cham }}$ |  | 21 | 35 | ns |
| Delay Time from $\overline{\mathrm{AS}}$ to MAm | ${ }^{\text {t ASMA }}$ |  | 23 | 39 | ns |
| Delay Time from R/W to $\overline{W E}$ | $t_{\text {WEHL }}$ |  | 16 | 25 | ns |
|  | $t_{\text {WELH }}$ |  | 17 | 28 | ns |
| Delay Time from CLK to $\overline{\text { RASn }}$ (Refresh cycle) | $\mathrm{t}_{\text {RASRHL }}$ |  | 24 | 36 | ns |
|  | $\mathrm{t}_{\text {RASRLH }}$ |  | 25 | 37 | ns |
| Delay Time from CLK to MAm (Refresh cycle) | $t_{\text {MAR }}$ |  | 33 | 51 | ns |
| Delay Time from CLK to RDY (Refresh cycle) | $\mathrm{t}_{\text {ROYHL }}$ |  | 23 | 35 | ns |
|  | $\mathrm{t}_{\text {ROYLH }}$ |  | 21 | 32 | ns |
| Address Enable Time from $\overline{\mathrm{CS}}$ | $\mathrm{t}_{\text {PZHMA }}$ |  | 24 | 43 | ns |
|  | $t_{\text {PZLMA }}$ |  | 24 | 41 | ns |
|  | $t_{\text {PZHWE }}$ |  | 24 | 43 | ns |
|  | $\mathrm{t}_{\text {PZLWE }}$ |  | 24 | 41 | ns |
| $\overline{\text { RAS }} / \overline{\mathrm{CAS}}$ Enable Time from $\overline{\mathrm{CS}}$ | $\mathrm{t}_{\text {PZHRC }}$ |  | 20 | 38 | ns |
|  | $t_{\text {PZLRC }}$ |  | 23 | 41 | ns |
| Address Disable Time from $\overline{\mathrm{CS}}$ | $\mathrm{t}_{\text {PHZMA }}$ |  | 36 | 56 | ns |
|  | $\mathrm{t}_{\text {PLZMA }}$ |  | 32 | 48 | ns |
| $\overline{\text { WE }}$ Disable Time from $\overline{\mathrm{CS}}$ | $\mathrm{t}_{\text {PHZWE }}$ |  | 36 | 56 | ns |
|  | $t_{\text {PLZWE }}$ |  | 32 | 48 | ns |
| $\overline{\mathrm{RAS}} / \overline{\mathrm{CAS}}$ Disable Time from $\overline{\mathrm{CS}}$ | $\mathrm{t}_{\text {PHZRC }}$ |  | 33 | 48 | ns |
|  | $t_{\text {PLZRC }}$ |  | 23 | 39 | ns |
| Column Address to CAS Set up Time | $\mathrm{t}_{\text {ASC }}$ | 0 |  |  | ns |
| K̂ÃS Puis V̄Vidith (Refresh cycle) | $t_{\text {WRAS }}$ | 150 |  |  | ns |
| Delay Time from $\overline{\mathrm{RAS}}$ to $\overline{\mathrm{CAS}}$ | $t_{\text {RCA }}$ | 25 |  |  | ns |
| Row Address Hold Time | $\mathrm{t}_{\text {RAH }}$ | 20 |  |  | ns |

n; 0, 1
m; 0, 1, 2, 4, 5, 6, 7, 8

## AC CHARACTERISTICS TEST CONDITIONS

1. DELAY TIME


| Pin Name | $C_{\mathrm{L}}(\mathrm{std})$ |
| :--- | :---: |
| MAO to MA8 | 300 pF |
| $\overline{\text { WE }}$ | 300 pF |
| $\overline{\text { RAS }} 0$ and $\overline{\text { RAS }} 1$ | 200 pF |
| $\overline{\mathrm{CAS}} 0$ and $\overline{\mathrm{CAS}} 1$ | 200 pF |
| RDY | 150 pF |


2. ENABLE/DISABLE TIME


|  | Symbol | Pin Name | $\begin{aligned} & \mathrm{CL} \\ & (\mathrm{pF}) \end{aligned}$ | $\begin{aligned} & \hline V T \\ & \text { (V) } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| Disable time measurement | ${ }^{\text {P }}$ LZ | MA0 to MA8, $\bar{W} E$ | 300 | $\mathrm{V}_{\mathrm{CC}}$ |
|  |  | $\overline{\text { RAS }}$, $\overline{\mathrm{CAS}}$ | 200 |  |
|  | ${ }^{\text {P PHZ }}$ | MAO to MA8, $\bar{W} E$ | 300 | 0 |
|  |  | $\overline{\mathrm{RAS}}, \overline{\mathrm{CAS}}$ | 200 |  |
| Enable time measurement | ${ }^{\text {P }} \mathrm{Z} \mathrm{L}$ | MA0 to MA8, $\bar{W} E$ | 300 | $\mathrm{V}_{\mathrm{CC}}$ |
|  |  | तिAS, $\overline{\mathrm{CAS}}$ | 200 |  |
|  | ${ }_{\text {tPZH }}$ | MA0 to MA8, $\overline{\text { WE }}$ | 300 | 0 |
|  |  | $\overline{\text { RAS }}$, $\overline{\mathrm{CAS}}$ | 200 |  |

Including jig capacitance.


## Delay time calcuration

When the load capacitance is different from the standard value shown above, the delay time is specified according to the following equation.
$\mathrm{t}_{\mathrm{pd}(\mathrm{CL})}=\mathrm{t}_{\mathrm{pd}(\mathrm{Std})}+0.04 \times \Delta \mathrm{C}_{\mathrm{L}}, \Delta \mathrm{C}_{\mathrm{L}}=\mathrm{C}_{\mathrm{L}}-\mathrm{C}_{\mathrm{L}(\mathrm{Std})}$
Unit: $\mathrm{t}_{\mathrm{pd}}=\mathrm{ns}$
$C_{L}=p F$



FUJITSU
MB 1422A



## APPLICATION FOR 1M DRAM

The Fujitsu MB 1422A is designed to refresh all nine bits of memory addresses (MAO to MA8). It can also, control 1M DRAMs by adding some external circuits.
Refer to the application circuits described below.

Fig. 12 - ADDITIONAL EXTERNAL CIRCUIT
$\Delta t 1=t_{\text {PHL }}(L S 08)+t_{P L H}$ or $t_{P H L}(L S 157) \geqq t_{R_{A H}}$ (Row Address Hold Time)
$\Delta t 1=t_{\text {PHL }}(L S 08)+t_{P L H}$ or $t_{P H L}(L S 157) \geqq t_{R_{A H}}$ (Row Address Hold Time)
$\Delta t 2=t_{\text {PLH }}($ LSO8 $)+t_{\text {PLH }}$ or $t_{\text {PHL }}$ (LS157)
$\Delta t 2=t_{\text {PLH }}($ LSO8 $)+t_{\text {PLH }}$ or $t_{\text {PHL }}$ (LS157)

## PACKAGE DIMENSIONS



## PACKAGE DIMENSIONS



| Pin No. | Pin Name | Pin No. | Pin Name | Pin No. | Pin Name |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | GND | 15 | RA5 | 29 | MA5 |
| 2 | RA0 | 16 | CA5 | 30 | MA4 |
| 3 | CAO | 17 | RA6 | 31 | MA3 |
| 4 | RA1 | 18 | CA6 | 32 | MA2 |
| 5 | CA1 | 19 | RA7 | 33 | MA1 |
| 6 | RA2 | 20 | CA7 | 34 | VCC |
| 7 | CA2 | 21 | RA8 | 35 | MA0 |
| 8 | RA8 | 22 | CA8 | 36 | CAS1 |
| 9 | CA3 | 23 | GND | 37 | CASO |
| 10 | MODE0/RESET | 24 | WE | 38 | RAS 1 |
| 11 | CLK | 25 | RDY | 39 | RAS0 |
| 12 | GND | 26 | MA8 | 40 | MODE1/RFRQ |
| 13 | RA4 | 27 | MA7 | 41 | R/W |
| 14 | CA4 | 28 | MA6 | 42 | AS |
|  |  |  |  | 43 | BS |
|  |  |  |  | 44 | CS |

## FUJITSU

## MB1430

## DESCRIPTION

## ADVANCE INFORMATION

The Fujitsu MB1430 Dynamic RAM (DRAM) Controller is a high-performance device that provides all control functions required to implement and supervise a multiple-DRAM memory. Major functions include multiplexed address control, memory refresh, and refresh arbitration. The MB1430 is designed to operate with systems based on the MBL8086, MBL80186, and the MBL80286 (5, 8, and 10 MHz ) or the 68000 ( 8 and 12.5 MHz ) microprocesors. Interface connections for $64 \mathrm{~K}, 256 \mathrm{~K}$, and 1 -megabit DRAMs are simple and straightforward. For optimum flexibility and to provide a high order of efficiency, the MB1430 supports all useful modes of operation; these include read-modify-write, nibble, fast page, and CAS-controlled byte operations. The MB1430 is fabricated using a low-power Schottky TTL process and the device is housed in a 48-pin plastic DIP.

## FEATURES

- Full-featured control for 64 K -, 256 K -, and 1-megabit DRAMs.
- Direct address-and-drive capabilities for up to 44 DRAM devices.
- $\overline{\mathrm{CAS}}$-before- $\overline{\mathrm{RAS}}$ refresh.
- Internal/external refresh capability.
- Easy interface to MBL8086, MBL80186, MBL80286 and 68000 microprocessor-based systems.
- TTL-compatible I/O.
- Low power consumption (typically 425 mW ).
- Single +5 V supply.
- Supports multiple operating modes.

PIN CONFIGURATION

| RAO | 1 | 48 | R/W |
| :---: | :---: | :---: | :---: |
| CAO | 2 | 47 | FPC |
| RA1 | 3 | 46 | MODE1/RFRQ |
| CA1 | 4 | 45 | RAS0 |
| RA2 | 5 | 44 | RAS1 |
| CA2 | 6 | 43 | CAS0 |
| RA3 | 7 | 42 | CAS1 |
| CA3 | 8 | 41 | MAO |
| RA4 | 9 | 40 | MA1 |
| MODEO/RESET | 10 | 39 | MA2 |
| CLK | 11 | 38 | MA3 |
| GND | 12 | 37 | GND |
| $\overline{\text { AS }}$ | 13 | 36 | VCC |
| CA4 | 14 | 35 | MA4 |
| RA5 | 15 | 34 | MA5 |
| CA5 | 16 | 33 | MA6 |
| RA6 | 17 | 32 | MA7 |
| CA6 | 18 | 31 | MA8 |
| RA7 | 19 | 30 | MA9 |
| CA7 | 20 | 29 | RDY |
| RA8 | 21 | 28 | WE |
| CA8 | 22 | 27 | BAC1 |
| RA9 | 23 | 26 | BAC0 |
| CA9 | 24 | 25 | BS |

BLOCK DIAGRAM


[^35]
## FUJITSU MB 1412A EIGHT-BIT SLICE ECC LSI

The MB 1412A is an 8-bit slice Error Checking and Correction (ECC) monolithic integrated circuit fabricated in a low-power Schottky TTL process. The device is utilized in memory system designs, and is suitable for constructing 2-byte, 4 -byte, or 8 -byte ECC circuitry. The MB 1412A will detect and correct singlebit errors, and detect double-bit errors utilizing a built-in modified Hamming single-error-correction, double-error-detection (SEC-DED) code. A 64-pin square package with 100 mil pin spacing is utilized for the MB 1412A to provide high board packing density.

- 8-bit slice ECC function in one LSI.
- $100 \%$ single-bit error detection/correction and double-bit error detection.
- Simplified circuit design for 2, 4, or 8-byte memory systems. 4/8-byte system requires only 4/8 ECC circuits and 4/8 TTL SSI devices.
- Uses built-in modified Hamming SEC-DED Code.
- 4/8-byte data word requires only $7 / 8$ check bits for full SEC-DED operation.
- High speed: $31 / 47 \mathrm{nsec}$. typical for $4 / 8$-byte detect system, $40 / 56 \mathrm{nsec}$, for 4/8-byte correct.
- Low-power dissipation: 1.6 watts maximum. For 8 -byte system, 8.7 watts typical system power including peripheral circuitry.
- Low-power Schottky TTL process; single +5 volt supply.
- Space-saving 64 -pin square-pack with 100 mil pin spacing.


## ABSOLUTE MAXIMUM RATING

| Parameter | Symbol | Rating | Unit |
| :--- | :---: | :---: | :---: |
| Power Supply <br> Voltage | $\mathrm{V}_{\text {CC }}$ | 7 | V |
| Input Voltage | $\mathrm{V}_{\text {I }}$ | $-0.5 \sim+5.5$ | V |
| Temperature <br> Under Operation | $\mathrm{T}_{\text {op }}$ | $-25 \sim+85$ | ${ }^{\circ} \mathrm{C}$ |
| Temperature <br> Under Storage | $\mathrm{T}_{\text {stg }}$ | $-65 \sim+150$ | ${ }^{\circ} \mathrm{C}$ |

NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.


Small geometry bipolar integrated circuits are occasionally susceptible to damage from static voltages or electric fields. It is therefore advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltates to this device.

Fig. 1 MB 1412A BLOCK DIAGRAM


| RD: | Read Data Buffer |
| :--- | :--- |
| SG: | Syndrome Generator |
| WD: | Write Data Buffer |
| DS: | Data Selector |
| CG: | Check-bit Generator |
| CC: | Check-bit Corrector |
| $\overline{\text { S: }}$ | Syndrome Input Buffer |
| DC: | Data Corrector |
| SD: | Syndrome Decoder/Locator |

## FUNCTIONS OF BLOCK ELEMENTS

RD (Read Data Buffer)
Input buffer gate for memory read data.
SG (Syndrome Generator)
Generates syndrome for the data to be checked in the read data buffer.
WD (Write Data Buffer)
Input buffer gate for memory write data.
DS (Data Selector)
Selects RD or WD depending on the mode (" 0 " or " 1 ") of the STBC input.
CG (Check-Bit Generator)
Generates check-bits for memory data being checked.

## INPUT/OUTPUT PINS

Input Pins:
RDO-RD7 (Read Data)
Memory data inputs. READ data operation is dictated when STBC is " 0 " (low).
WD0-WD7 (Write Data)
WRITE data inputs. WRITE data operation is dictated when STBC is " 1 " (high).
SIO-SI5 (Syndrome Input)
Syndrome code inputs to read the synthesized syndrome from the previous ECC LSI (SO output) in a cascaded multi-byte ECC system configuration. The syndrome inputs for the firsi ECC LSi in the system read memory check-bit data previously generated.
$\mathrm{ClO}-\mathrm{Cl} 5$ (Check-Bit Input)
Reads check-bits into the internal Check-Bit generator in a cascaded ECC system.
$\overline{\mathrm{S}}$ (Syndrome Input Buffer)
Input buffer gate for synthesized syndrome input data.
SD (Syndrome Decoder/Locater)
Locates a data bit for correction and indicates when a one-bit error is detected.
DC (Data Corrector)
Corrects the data bit indicated as an error by the syndrome decoder.
CC (Check-bit Corrector)
Corrects one check-bit by reversing depending on the mode of RVC and $\overline{\mathrm{S}}$.

STBC (Store Byte Control)
Set "0" (low) to read RD inputs; set " 1 " (high) to read WD inputs.
$\overline{\mathrm{SO}}-\overline{\mathrm{S} 5}$ (Synthesized Syndrome Input)
Reads the synthesized syndrome code output from the last ECC LSI (SO outputs) in a cascaded multi-byte ECC system configuration. $\overline{\mathrm{SO}}-\overline{\mathrm{S} 5}$ must correspond to the order of the SOO-SO5 outputs on the same ECC LSI to accomplish syndrome decoding (see ECC system examples). In the event of a single data bit error (during memory READ ), the syndrome decoder (SD) decodes $\overline{\mathrm{SO}}-\overline{\mathrm{S} 5}$ to locate the error bit to be corrected. The binary location of the error bit is read from $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ (e.g., $\overline{\mathrm{SO}}=$ $0, \overline{\mathrm{~S} 1}=1, \overline{\mathrm{~S} 2}=0$ is binary 010 or decimal " 2 " which corresponds to input data bit " 2 ").
$\overline{\text { S6 }}$ (Synthesized Syndrome Input \#6)
Reads a synthesized syndrome bit output from a cascaded multi-byte ECC system configuration. A " 0 " input indicates that no bit error is detected within the read memory byte for the ECC IC, and forces the $\overline{\mathrm{RE} 1}$ and $\overline{\mathrm{RVC}}$ outputs high (1). A " 1 " input indicates that a 1 -bit error is detected within the read memory byte.
RVC02 (Reverse Check-Bit \#02)
A " 0 " (low) input indicates no error detected. A " 1 " (high) indicates an error is detected within the input memory data byte, and corrects the first three check bits (see Fig. 13, CO-C2). A " 0 " on syndrome data $\overline{\mathrm{SO}}$, $\overline{\mathrm{S} 1}$, or $\overline{\mathrm{S} 2}$ dictates correction of $\mathrm{CO}, \mathrm{C} 1$, or C 2 respectively. RVC36 (Reverse Check-Bit \#36)

A " 0 " (low) input indicates no correction to check-bit C3. A " 1 " (high) input performs correction of checkbit C3.

Output Pins:
SOO-SO5 (Syndrome Output)
Synthesized syndrome output code, normally connected to Syndrome Input (SI) in the next sequential ECC IC in a cascaded multi-byte ECC configuration. Syndromes are effective for the system at the output of the last ECC LSI in sequence.
COO-CO5 (Check-Bit Output)
Check-bit output code, normally connected to CheckBit Input ( CI ) in the next sequential ECC LSI in a cascaded multi-byte ECC configuration. Check-bits are effective for the system at the output of the last ECC LSI in sequence.
$\overline{R E 1}$ (Read Error One)
A " 0 " (low) indicates that a one-bit error has occurred in fetched data or check bits.
$\overline{\text { RVC }}$ (Reverse Check-Bit)
A " 0 " (low) indicates that an error in check-bit must be corrected.
D0-D7 (Data Output)
Corrected data output.

Fig. 3 PIN ASSIGNMENT TABLE

| $\begin{aligned} & \text { PIN } \\ & \text { NO. } \end{aligned}$ | 1/O | NAME | PIN <br> NO. | I/O | NAME |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | RVC02 | 33 | 0 | D7 |
| 2 | 0 | COO | 34 | 0 | D5 |
| 3 | 1 | CI1 | 35 | 0 | D3 |
| 4 | 1 | Cl 2 | 36 | 0 | D1 |
| 5 | 0 | CO2 | 37 | 0 | D0 |
| 6 | 1 | RVC36 | 38 | 1 | CIO |
| 7 | 1 | CI3 | 39 | 0 | CO1 |
| 8 | 1 | C14 | 40 | - | GND |
| 9 | 1 | CI5 | 41 | 0 | CO3 |
| 10 | 1 | WD1 | 42 | 0 | CO4 |
| 11 | 1 | WD3 | 43 | 0 | CO5 |
| 12 | 1 | WD4 | 44 | 1 | WDO |
| 13 | , | WD6 | 45 | 1 | WD2 |
| 14 | 1 | WD7 | 46 | 1 | WD5 |
| 15 | 1 | STBC | 47 | - | VCC |
| 16 | 1 | RD1 | 48 | 1 | RDO |
| 17 | 1 | RD3 | 49 | 1 | RD2 |
| 18 | 1 | RD5 | 50 | I | RD4 |
| 19 | 1 | RD7 | 51 | 1 | RD6 |
| 20 | 0 | SOO | 52 | 1 | SIO |
| 21 | 1 | SI1 | 53 | 0 | SO1 |
| 22 | 1 | S12 | 54 | - | GND |
| 23 | 0 | SO2 | 55 | 1 | SI3 |
| 24 | 0 | SO3 | 56 | , | SI4 |
| 25 | 0 | SO4 | 57 | 1 | SI5 |
| 26 | 0 | SO5 | 58 | , | S1 |
| 27 | 1 | S0 | 59 | 1 | S3 |
| 28 | 1 | S2 | 60 | , | S6 |
| 29 | , | S4 | 61 | - | VCC |
| 30 | 1 | S5 | 62 | 0 | D6 |
| 31 | 0 | RE1 | 63 | 0 | D4 |
| 32 | 0 | $\overline{\text { RVC }}$ | 64 | 0 | D2 |

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Value | $T_{\mathrm{OP}}$ |
| :---: | :---: | :---: | :---: |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5.0 \mathrm{~V} \pm 5 \%$ | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

(Recommended operating conditions unless otherwise noted)

| Parameter |  | Symbol | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| Output Low Level |  |  | $\mathrm{V}_{\mathrm{OL}}$ |  |  | 0.5 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{~V}_{I \mathrm{~L}}=0.8 \mathrm{~V} \\ & \mathrm{~V}_{1 \mathrm{H}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA} \end{aligned}$ |
| Output High Level |  | $\mathrm{V}_{\mathrm{OH}}$ | 2.7 |  |  | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{~L}}=0.8 \mathrm{~V} \\ & \mathrm{~V}_{1 \mathrm{H}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=1 \mathrm{~mA} \end{aligned}$ |
|  | RDn, WDn, $\overline{\text { Sn }}$, RVC02, RVC36 | IIL1 |  |  | 1.6 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{~L}}=0.5 \mathrm{~V}$ |
|  | STBC | IIL2 |  |  | 3.2 | mA |  |
|  | SIn, CIn | IIL3 |  |  | 4.8 | $m A$ |  |
| Input <br> High <br> Current | RDn, WDn, $\overline{\text { Sn , RVC02, RVC36 }}$ | $\mathrm{I}_{1+1}$ |  |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{1 H}=2.7 \mathrm{~V}$ |
|  | STBC | $\mathrm{I}_{1 \mathrm{H} 2}$ |  |  | 40 | $\mu \mathrm{A}$ |  |
|  | Sin, Cln | $\mathrm{I}_{1 \mathrm{H} 3}$ |  |  | 60 | $\mu \mathrm{A}$ |  |
| Input High Current |  | $1 / \mathrm{H}$ |  |  | 1 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{1 H}=5.5 \mathrm{~V}$ |
| Output Short Current |  | los | 30 |  | 120 | mA | $\mathrm{V}_{\mathrm{cc}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |
| Power Supply Current |  | ICC |  | 190 | 300 | mA | $\mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}$ |
| Input Clamp Voltage |  | $V_{\text {IC }}$ |  |  | 1.2 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, 1_{\text {IL }}=18 \mathrm{~mA}$ |

## AC CHARACTERISTICS

(Recommended operating conditions unless otherwise noted)

| Parameter | Symbol | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| (RD1 ~ RD7) to (SO0 ~ SO2) * | $\mathrm{t}_{\mathrm{pd} 1}$ |  | 14 | 19 | ns |
| (RD0 ~ RD7) to SO3, SO4 | ${ }^{\text {pd2 }}$ |  |  | 25 | ns |
| RD0 to SO5 | $\mathrm{t}_{\mathrm{pd} 4}$ |  |  | 17 | ns |
| $(\mathrm{RDO} \sim \mathrm{RD7})$ to ( $\mathrm{COO} \sim \mathrm{CO5}$ ) | $t_{p d}{ }^{\text {d }}$ |  |  | 36 | ns |
| (RD0 ~ RD7) to ( $\mathrm{DO} \sim \mathrm{D} 7$ ) | $t_{\text {pd4 }}$ |  |  | 18 | ns |
| (SIO ~SI5) to (SOO ~SO5) * | $\mathrm{t}_{\mathrm{pd} 5}$ |  | 4 | 9 | ns |
| $(\mathrm{ClO} \sim \mathrm{Cl5})$ to ( $\mathrm{COO} \sim \mathrm{CO5})^{*}$ | $\mathrm{t}_{\mathrm{pd} 6}$ |  | 4 | 9 | ns |
| (WD0 ~ WD7) to (CO0 ~ CO5) * | $\mathrm{t}_{\mathrm{pd} 7}$ |  | 25 | 36 | ns |
| (WD0 ~ WD7) to (D0 ~ D7) | $t_{\text {pd8 }}$ |  |  | 18 | ns |
| $(\overline{\mathrm{SO}} \sim \overline{\mathrm{S} 6})$ to (CO0 ~ CO5) | $\mathrm{t}_{\mathrm{pd} 9}$ |  |  | 22 | ns |
| $(\overline{S 0} \sim \overline{S 6})$ to (D0 ~ D7) * | $t_{\text {pd10 }}$ |  | 14 | 19 | ns |
| ( $\overline{\mathbf{S O}} \sim \overline{\mathrm{S}}$ ) to $\overline{\mathrm{RE}}$ | $\mathrm{t}_{\mathrm{pd} 11}$ |  |  | 22 | ns |
| ( $\overline{\mathbf{S O}} \sim \overline{\mathrm{S}}$ ) to $\overline{\mathrm{RVC}}$ | $\mathrm{t}_{\mathrm{pd} 12}$ |  |  | 21 | ns |
| RVCO2 to (COO ~ CO3) | $\mathrm{t}_{\mathrm{pd} 13}$ |  |  | 18 | ns |
| RVC36 to (COO ~ CO3) | $t_{\text {pd14 }}$ |  |  | 17 | is |
| STBC to (COO ~ CO5) | $\mathrm{t}_{\mathrm{pd} 15}$ |  |  | 36 | ns |
| STBC to (D0 ~ D7) | $\mathrm{t}_{\mathrm{pd} 16}$ |  |  | 22 | ns |
| STBC to $\overline{\text { RVC }}$ | $t_{\text {pd } 17}$ |  |  | 18 | ns |

* Note: Critical path on a chip

Fig. 4 DELAY TIME MEASUREMENT CIRCUIT


Fig. 5 INPUT SIGNAL/OUTPUT SIGNAL TIMING


## CRITICAL PATH TIMING

Critical timing paths for the MB 1412A are shown under AC Characteristics as indicated by the notation "Critical Path on Chip". In a typical, multi-chip ECC system application, system delay time would be measured from the RD input to the $D$ output for processing of the complete data input. The equation is as follows, where $\ell$ is the number of bytes in the data input:

$$
\begin{aligned}
& \mathrm{t}_{\mathrm{pd}}(R D n-D n)= \mathrm{t}_{\mathrm{pd}}(R D n-S O O)+(\ell-1) \times \\
& \mathrm{t}_{\mathrm{pd}}(\mathrm{SIO}-\mathrm{SOO})+\mathrm{t}_{\mathrm{pd}}(\overline{\mathrm{Sm}}-\mathrm{Dn})
\end{aligned}
$$

For a 4-byte system (see Figure 6), delay time from READ data (RD) to corrected data ( $D$ ) is 40 nsec typical:

$$
t_{p d}(R D-D)_{4}=14 \mathrm{~ns}+(3 \times 4 \mathrm{~ns})+14 \mathrm{~ns}=40 \mathrm{nsec}
$$

Fig. 6 CRITICAL PATH TIMING (Data Correction)

$\operatorname{Dn}(\mathrm{n}=0 \sim 7)$

## THEORY AND APPLICATION OF ECC

In most any data processing system, binary bit errors are going to occur when blocks of data are moved from one location to another. As such errors are not uncommon and can lead to entirely bogus or meaningless resuits in routine programs, it has become requisite design discipline to include ECC (Error Checking and Correction) Circuitry in main memory control logic. The MB 1412A accomplishes this in a highly integrated form which allows ECC implementation with a minimal package count.
The MB 1412A will correct one-bit errors in every input data word, and flag the occurence of two-bit errors. One-bit error correction is considered adequate, as the probability of more than a one-bit error is quite low. As an example, consider a data word of 5 -bits with the error possibility of .0001 (one in ten-thousand) per bit. The chances of an error occuring in a data word are:

$$
\begin{array}{ll}
\text { no error } & P_{0}=(1-P)^{5}=0.9995 \\
\text { one error } & P_{1}={ }_{5} C_{1} \cdot P(1-P)^{4}=0.0005 \\
\text { two errors } & P_{2}={ }_{5} C_{2} \cdot P^{2}(1-P)^{3}=0.00000025
\end{array}
$$

Thus, one-bit detection and correction and two-bit detection only should provide adequate insurance, and satisfactory system performance. When a two-bit error occurs, of course, the program must be interrupted to prevent miscalculation.
In order to detect data bit errors, memory check-bits must be stored with the data words. For 1-bit error detection of a word of $n$-bits, assume the number of check-bits required is $\mathrm{C}_{\mathrm{n}}$. The number of possible bit combinations for no error is therefore 1 (all bits, both data bits and check-bits correct); and the number of possible bit combinations for a 1-bit error is: $\mathrm{n}+\mathrm{C} \mathrm{n}$.
The number of combinations made by check-bits is 2 Cn . To detect 1 -bit errors a hundred percent, the following must be satisfied:

$$
1+\left(n+C_{n}\right) \leqslant 2 C n
$$

This means, for example, that a 1 -bit error in 16 -bits of data can be detected by five additional check-bits. Following the same calculation, 1 -bit errors in 32 -bit data words require 6 check-bits, and 64 -bit data words require 7 check bits. To detect 2 -bit errors, one additional bit is required; e.g., 6 check-bits for a 16 -bit word.
The MB 1412A is designed for use in a memory system configuration of either 2 -bytes ( 16 data bits), 4 -bytes ( 32 data bits), or 8 -bytes ( 64 data bits). Simple external gating, as shown in Figures 7 and 8, is required in the error indication and reverse check-bit circuitry.
When data is first written into memory, the ECC system does not correct or detect errors. But it does generate the necessary check-bits (as a function of the number of bytes of data in the memory system configuration) which are stored in memory along with the data bits. The check-bit code conforms to the ECC system output of the modified Hamming code check-bit generator as shown in Figure 9. The check-bit generator takes the parity of all the data bits marked by an $X$ in the rows of the input data bits.

When memory is read, both data bits and check-bits form inputs into the ECC system. Data bits are entered in parallel, one byte per ECC IC in the ECC system. The check-bits are entered into the first ECC IC in the chain, and additional ECC IC's as shown in the example in Figure 15.
These fetched check-bits are exclusive-ORed with newly generated check-bits created from the data input in order to generate a syndrome code for the fetched data as shown in Figure 9. From the syndrome code, the ECC system can determine if there is an error in the input data bits, as follows:

- If the syndrome code is all " 0 ", there is no error.
- If one syndrome bit is " 1 ", the corresponding check-bit is in error. As a result, $\overline{\mathrm{RE} 1}$ will go to " 0 " and $\overline{\mathrm{RVC}}$ will go to " 1 " so that no correction will be made in the data bits.
- If more than one syndrome bit is " 1 ", and the parity of all syndrome bits is even, a multiple error has occurred. No correction is made, and the program should be interrupted.
- If more than one syndrome bit is " 1 ", and the parity of all syndrome bits is odd, a single error has occurred in the data bits. The binary location of the error in the input data bits can be determined by decoding of the syndrome code as shown in Figure 10.
In the event of multiple errors, no data correction is made; rather the event is flagged and system software should be interrupted. As a two-bit error without ECC would normally result in program execution errors, program interruption is presumed to be the only satisfactory outcome of the multiple error detection event.
When one error is detected in the fetched check-bits, the ECC system, in effect, generates a new set of check-bits (and "ignores" the fetched check-bits) with respect to processing the input data bits.


## WRITE Mode:

A " 1 " input on STBC initiates the WRITE mode operation and tells the Data Selector (DS) to read data from the Write Data (WD) buffer (WDO-WD7 inputs). The $\overline{R V C}$ (Reverse Check Bit) and $\overline{\mathrm{RE}}$ (Read Error One) outputs of the Syndrome Decoder/Locator (SD) go high so that no error indication for the data is possible. Further, the function of the Check-bit Corrector (CC) is inhibited by feedback of the $\overline{\mathrm{RVC}}$ signal (high state) to the RVCO2 and RVC36 inputs. Data correction can not occur because the $\overline{\mathrm{RVC}}$ output is high.
The Check-bit Generator (CG) will generate check-bit data from the WRITE data transferred from the Data Selector (DS) and output it on COO-CO5 in accordance with the logic table shown in Figure 9. At the same time, the Data Corrector (DC) will transfer the WRITE data onto outputs D0-D7. Thus the WRITE data on D0-D7 can be stored in main memory along with the appropriate output check-bits corresponding to the data bits input into the ECC system.

READ Mode:
A " 0 " input on STBC indicates the READ mode operation and tells the Data Selector (DS) to transfer read data from inputs RDO-RD7 through the Read Data (RD) buffer to the Data Corrector (DC) and Check-bit Generator (CG). The Syndrome Generator (SG) will generate check-bits from the same data inputs and XOR (exclusive-OR) them with the data on SIO-SI5 (Syndrome Inputs). XORed data becomes the output on SOO-SO5 (Syndrome Output) according to the logic table shown in Figure 9. At the same time, the Check-bit Generator (CG) will generate check-bits from the input read data and will accept check-bit correction if the data from memory contains an error. Note that by performing syndrome generation and check-bit correction simultaneously, high speed operation is maintained.
A " 0 " on STBC also gates the Syndrome Decoder/Locator (SD) to decode syndrome inputs on $\overline{\mathrm{SO}}-\overline{\mathrm{S} 6}$. When syndrome data is not all " 0 ", both $\overline{\mathrm{RVC}}$ (Reverse Check-Bit) and $\overline{\text { RE1 (Read Error-One) go " } 0 \text { " (low) to indicate error }}$ detection. Logic tables are shown in Figure 10. The error bit position is indicated to the Data Corrector (DC), and the data output at D0-D7 is corrected.
$\overline{\mathrm{RVC}}$ is fedback to the RVC02 and RVC36 inputs. So when an error is detected ( $\overline{\mathrm{RVC}}=$ low), the input syndrome data from the Syndrome Buffer ( $\overline{\mathrm{S}}$ ) is gated into the Check-bit Corrector (CC). The check-bits are corrected in accordance with the logic table shown in Figure 9.

Fig. 7 ERROR INDICATION CIRCUIT

(m: Bit size of Syndrome-1)

Fig. 8 REVERSE CHECK-BIT CIRCUIT

( n : Byte size-1)

Fig. 9 LOGICAL DESCRIPTION OF SYNDROME GENERATION/DECODING AND CHECK-BIT GENERATION
Table 1 Syndrome Generation (See Note *)

| SI |  |  |  |  |  | RD |  |  |  |  |  |  |  | XOR TREE | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 2 | 3 | 4 | 5 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |  |  |
| X |  |  |  |  |  |  | X |  | X |  | X |  | X | EVEN | SOO |
|  | X |  |  |  |  |  |  | X | X |  |  | X | X | EVEN | SO1 |
|  |  | X |  |  |  |  |  |  |  | X | X | X | X | EVEN | SO2 |
|  |  |  | X |  |  | X | X | X | X | X | X | X | X | ODD | SO3 |
|  |  |  |  | X |  | X | X | X |  | X |  |  | X | ODD | SO4 |
|  |  |  |  |  | X | X |  |  |  |  |  |  |  | ODD | SO5 |

Table 2 Check-Bit Generation (See Note *)

| Cl |  |  |  |  |  |  | RD (STBC=0)/WD (STBC=1) |  |  |  |  |  |  |  | XORTREE | MODIFICATION | $\begin{aligned} & \text { OUT- } \\ & \text { PUT } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 2 | 3 | 4 |  |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |  |  |  |
| X |  |  |  |  |  |  |  | X |  | X |  | X |  | X | ODD | $\oplus$ RVC02.S0 | COO |
|  | X |  |  |  |  |  |  |  | X | X |  |  | X | X | ODD | ( ${ }^{\text {RVVC02. }} 1$ | CO1 |
|  |  | X |  |  |  |  |  |  |  |  | X | X | $x$ | X | ODD | $\oplus{ }^{\oplus} \mathrm{RVCO} 2 \cdot \mathrm{~S} 2$ | CO2 |
|  |  |  | X |  |  |  | x | X | X | X | X | X | X | X | EVEN | $\oplus$ RVC36.S3 | CO3 |
|  |  |  |  | X |  |  | X | X | X |  | X |  |  | X | EVEN |  | CO4 |
|  |  |  |  |  |  |  | X |  |  |  |  |  |  |  | EVEN |  | CO5 |

Note:

* Inputs marked " X " are gated to the XOR-TREE.
** $\oplus$ indicates XOR.

Fig. 10 SYNDROME DECODING

| Fig. 10 |  |  |  |  |  | Error data |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | IndicationError <br> 0 0 |
|  | 0 | 1 | 1 | 1 | 0 | Location |  |
|  | 0 | 0 | 1 | 1 | 0 | 0 | Data Bit 0 |
| 0 | 1 | 0 | 1 | 1 | 0 | 0 | Data Bit 1 |
| 1 | 1 | 0 | 1 | 0 | 0 | 0 | Data Bit 2 |
| 0 | 0 | 1 | 1 | 1 | 0 | 0 | Data Bit 3 |
| 1 | 0 | 1 | 1 | 0 | 0 | 0 | Data Bit 4 |
| 0 | 1 | 1 | 1 | 0 | 0 | 0 | Data Bit 5 |
| 1 | 1 | 1 | 1 | 1 | 0 | 0 | Data Bit 6 |


| For check-bit |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S |  |  |  |  |  |  | $\begin{array}{\|lr\|} \hline \text { Error } & \\ \text { Indication } & \text { Error } \\ \hline & \text { Location } \\ \hline \end{array}$ |  |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 |  |  |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | Check | - Bit 0 |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | Check | Bit 1 |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | Check | Bit 2 |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | Check | Bit 3 |

FUJITSU

## EXAMPLE OF A 2-BYTE SYSTEM

Figure 11 is a block diagram of a 2 -byte ECC system configuration, including the external gate requirements. Two MB 1412As are connected so that the bits indicated by an $X$ in the Hamming code shown in Figure 12 are exclusiveORed in the Check-Bit Generator. In the example, the 16 bit input data word is 0001110001011101 , and the checkbits generated in WRITE mode are 101000.

In the READ mode shown in Figure 13, we assume that bit 10 has been inverted (error). The data bits are gated to the exclusive-OR tree to regenerate check-bits (now 110001) which are exclusive-ORed with the original check-bits (101000). The syndrome bits (011001) are then decoded as shown which indicates an error on bit 10 of the input data. This is corrected by inverting (change " 1 " to " 0 ").

Fig. 11 TWO-BYTE ERROR CHECKING AND CORRECTION SYSTEM


Note: When ECC system is used in "Partial Write Mode", C2 must be connected to the C02 input of the external reverse check bit circuit.

Fig. 12 WRITE OPERATION IN 2-BYTE ECC SYSTEM


Fig. 13 READ OPERATION IN 2-BYTE ECC SYSTEM


FUTITSU

## EXAMPLE OF A 4-BYTE SYSTEM

In a 4-Byte ECC system, four MB 1412A LSIs are connected in a cascaded manner as shown in Figure 14. The Hamming code depicted in Figure 15 is realized from the interconnection of the LSIs as shown. Data bits marked with an X in Figure 15 are gated to an exclusive-OR tree to generate
check-bits. The WRITE mode is diagrammed in Figure 16, and READ mode is shown in Figure 17. Figure 18 diagrams a Partial WRiTE operation on the 1st and 2nd bytes, with READ mode on the 3rd and 4th.

Fig. 14 FOUR-BYTE ERROR CHECKING AND CORRECTION SYSTEM


FUJITSU


Fig. 15 FOUR-BYTE ECC CODE TABLE



Fig. 16 WRITE OPERATION (4-BYTE)


No correction is done on any byte data.

Fig. 17 READ OPERATION (4-BYTE)


Fig. 18 PARTIAL WRITE OPERATION (4-BYTE)


1. When one bit error is detected on 3rd and 4th byte data, Data and Check-bit can be corrected. (READ Data)
2. No correction is done on 1st and 2nd byte Data. (WRITE Data) 3. One bit error on check-bit need not be corrected.

## EXAMPLE OF AN 8-BYTE SYSTEM

In a 8-Byte ECC system, eight MB 1412A LSIs are connected in a cascaded manner as shown in Figure 20. The Hamming code depicted in Figure 19 is realized from the interconnection of the LSIs as shown. Data bits marked with an X in Figure 19 are gated to an exclusive.OR tree to generate check-bits.

Fig. 19 EIGHT-BYTE ECC CODE TABLE

| Byte-0 |  |  |  |  |  |  |  | Byte-1 |  |  |  |  |  |  |  | Byte-2 |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 |
|  | X |  | X |  | X |  | X |  | X |  | X |  | X |  | X |  | X |  | X |  | X |  | X |
|  |  | X | X |  |  | X | X |  |  | X | X |  |  | X | X |  |  | X | X |  |  | X | X |
|  |  |  |  | $x$ | X | X | X |  |  |  |  | X | X | X | X |  |  |  |  | X | X | X | X |
| X | X | X | X | X | X | X | X |  |  |  |  |  |  |  |  | X |  |  |  |  |  |  |  |
| X | X | X |  | X |  |  | X | $x$ | X | X | X | $x$ | X | X | $x$ |  |  |  |  |  |  |  |  |
| X |  |  |  |  |  |  |  | X | X | X |  | X |  |  | X | X | X | X | X | $x$ | X | X | X |
|  |  |  |  |  |  |  |  | X |  |  |  |  |  |  |  | X | X | X |  | X |  |  | X |


| Byte-3 |  |  |  |  |  |  |  | Byte-4 |  |  |  |  |  |  |  | Byte-5 |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 |
|  | X |  | X |  | X |  | X |  | X |  | X |  | X |  | X |  | X |  | X |  | X |  | X |
|  |  | X | X |  |  | X | X |  |  | X | X |  |  | X | X | $x$ |  |  |  |  |  |  |  |
|  |  |  |  | x | X | X | $x$ |  |  |  |  | X | X | X | X |  |  |  |  |  |  |  |  |
| X | X | X |  | X |  |  | X |  | X | X |  | X |  |  | X |  |  |  |  |  |  |  |  |
| X |  |  |  |  |  |  |  | X |  |  |  |  |  |  |  |  |  | $x$ | X |  |  | X | X |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $x$ | $x$ | X |  | $x$ |  |  | X |
| X | X | X | X | X | X | X | X |  |  |  |  |  |  |  |  |  |  |  |  | X | $x$ | X | X |
|  |  |  |  |  |  |  |  | X | X | X | X | X | X | X | X | X | $x$ | X | X | X | X | X | X |



Fig. 20 EIGHT-BYTE ERROR CHECKING AND CORRECTION SYSTEM



## PACKAGE DIMENSIONS

64-LEAD CERAMIC (RESIN SEAL WITH METAL CAP) REPEATED QUAD IN-LINE PACKAGE (CASE No.: PGA-64C-MO 1)


## DESCRIPTION

The MB1426 Error Checking and Correction (ECC) device is designed to enhance memory reliability in 16-bit systems. Using a modified Hamming Single-Error-Correction/Double-Error-Detection (SEC/DED) code, the ECC can find and correct all single-bit errors and detect all double-bit errors. The MB1426 is a TTL device fabricated in low-power Schottky and is housed in a 64-pin Pin-Grid-Array (PGA) package.

## FEATURES

- Detects and corrects all single-bit errors
- Detects all double-bit errors
- On-chip latches for memory-read, check-bit, and syndrome data
- Separate busses for CPU and memory data
- Direct read/write by ECC-through mode
- Low power Schottky TTL for high performance
- Single +5 V supply


This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

FUJITSU
Mixixinixixilul MB1426

## PIN ASSIGNMENTS



| No. | I/O | Name | No. | I/O | Name | No. | I/O | Name | No. | I/O | Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 01 | B | CD08 | 17 | B | CB1 | 33 | I | $\overline{\text { PWC0 }}$ | 49 | B | CB4 |
| 02 | I | $\overline{\text { PWC1 }}$ | 18 | B | CB2 | 34 | B | CD14 | 50 | B | CB5 |
| 03 | B | CD07 | 19 | B | MD01 | 35 | B | CD12 | 51 | B | MD00 |
| 04 | B | CD05 | 20 | B | MD03 | 36 | B | CD10 | 52 | B | MD02 |
| 05 | B | CD04 | 21 | B | MD04 | 37 | B | CD09 | 53 | B | MD05 |
| 06 | B | CD03 | 22 | B | MD06 | 38 | I | $\overline{\text { ECCTH }}$ | 54 |  | GND |
| 07 | B | CD01 | 23 | B | MD07 | 39 | B | CD06 | 55 | B | MD09 |
| 08 | O | $\overline{\text { ERR }}$ | 24 | B | MD08 | 40 |  | GND | 56 | B | MD11 |
| 09 | O | $\overline{\text { MERR }}$ | 25 | B | MD10 | 41 | B | CD02 | 57 | B | MD13 |
| 10 | T | STCB0 | 26 | B | MD12 | 42 | B | CD00 | 58 | B | MD15 |
| 11 | T | STCB1 | 27 | B | MD14 | 43 | I | ERREN | 59 | I | RCLK |
| 12 | T | STCB2 | 28 | I | $\overline{\text { BSCNT }}$ | 44 | I | $\overline{\text { EN }}$ | 60 | O | $\overline{\text { PERR }}$ |
| 13 | T | STCB3 | 29 | B | P1 | 45 | I | $\overline{\text { SLE }}$ | 61 |  | VCC |
| 14 | T | STCB4 | 30 | O | $\overline{\text { PERR1 }}$ | 46 | I | $\overline{\text { RST }}$ | 62 | B | CD15 |
| 15 | T | STCB5 | 31 | B | P0 | 47 |  | VCC | 63 | B | CD13 |
| 16 | B | CB0 | 32 | O | $\overline{\text { PERR0 }}$ | 48 | B | CB3 | 64 | B | CD11 |

B: Bidirectional pin
I: Input pin
O: Output pin

MB1426

PIN DESCRIPTIONS

| Pin No. | Designator | Function |
| :---: | :---: | :---: |
| $\begin{array}{r} 33 \\ 2 \end{array}$ | $\frac{\overline{P W C 0}}{\overline{P W C 1}}$ | Partial Write Control/Read Write Control: <br> These pins are used to control read write and they are also used to control the partial write. <br> If both $\overline{\mathrm{PWCO}}$ and $\overline{\mathrm{PWC1}}=$ " H " the read operation is selected. <br> If both $\overline{\mathrm{PWCO}}$ and $\overline{\mathrm{PWC1}}=$ "L" the word write operation is selected. <br> In the partial write mode, if $\overline{\mathrm{PWC0}}=$ " L " and $\overline{\mathrm{PWC1}}=$ " H ", the lower byte (MD0 to MD7) is written CPU data and the upper byte (MD8 to MD15) is written memory data which is latched during previous read operation. On the other hand, if $\overline{\mathrm{PWCO}}=$ " H " and $\overline{\mathrm{PWC1}}=$ " L " the lower byte is written memory data and the upper byte is written CPU data. |
| 59 | RCLK | Read Data Latch Clock: <br> This pin is used to strobe the read data from memory and latch into the internal read data latch. The rising edge of RCLK strobes read data from MD00/MD15 and check bits from CB0/CB5. <br> In the read cycle, data is strobed on the rising of RCLK. |
| 45 | $\overline{\text { SLE }}$ | Syndrome Latch Enable: <br> This pin is used to latch syndrome bits into the internal syndrome latch. The falling edge of $\overline{\text { SLE }}$ strobes and latches the syndrome bits until $\overline{\mathrm{RST}}=$ " L ". |
| 46 | $\overline{\mathrm{RST}}$ | Syndrome Latch Reset: <br> This pin is used to reset syndrome latch. If $\overline{\operatorname{RST}}=$ " $L$ ", the syndrome latch is reset and the latch is enabled to accept next string of syndrome bits. |
| 43 | ERREN | Error Enable: <br> This pin is used to enable $\overline{\operatorname{ERR}}$ and $\overline{\text { MERR }}$ outputs. <br> If $\overline{\operatorname{ERREN}}=$ " $L$ ", $\overline{\text { ERR }}$ and $\overline{M E R R}$ are set " $H$ " and disabled. |
| 44 | $\overline{E N}$ | Syndrome Output Enable: <br> This pin is used to enable syndrome outputs (STCB0 and STCB5). <br> If $\overline{\mathrm{EN}}=$ "L", STCB0/STCB5 are enabled. If $\overline{\mathrm{EN}}=$ "H", STCB0/STCB5 are disabled and in the highimpedance state. |
| 38 | $\overline{\text { ECCTH }}$ | ECC Through: <br> This pin is used to enable the ECC-through mode. <br> If $\overline{E C C T H}=$ " $L$ ", ECC-through mode is enabled and the read or write cycle is executed without regard to the ECC function. <br> When ECC is utilized, the $\overline{\text { ECCTH }}$ pin must be " H ". |
| 28 | BSCNT | Bus Control: <br> This pin is used to control the operating mode of data pins CD00/CD15 and MD00/MD15, also to disable $\overline{\text { PERRO }}, \overline{\text { PERR1 }}$ and $\overline{\text { PERR. }}$ <br> If $\overline{\mathrm{BSCNT}}=$ " $L$ " all data pins are in the input mode and $\overline{\mathrm{PERRO}}, \overline{\mathrm{PERR1}}$ and $\overline{\mathrm{PERR}}$ are disabled (set "H"). <br> If $\overline{\mathrm{BSCNT}}=$ " H ", the operating mode of these data pins is controlled by the states of $\overline{\mathrm{PWCO}}$, and $\overline{\mathrm{PWC1}}$, and $\overline{\mathrm{PERRO}}, \overline{\mathrm{PERR1}}$ and $\overline{\mathrm{PERR}}$ are enabled corresponding the the state of $\overline{\mathrm{PWCO}}$ and PWC1. |
| $\begin{array}{r} 42 \\ 7 \\ 41 \\ 6 \end{array}$ | $\begin{aligned} & \text { CD00 } \\ & \text { CD01 } \\ & \text { CD02 } \\ & \text { CD03 } \end{aligned}$ | CPU Data: <br> These pins have a common I/O capability and are connected to the CPU data bus. <br> In the write cycle, these pins are in the input mode, that is, the CPU data is input to these pins and |

PIN DESCRIPTIONS (continued)

| Pin No. | Designator | Function |
| :---: | :---: | :---: |
| $\begin{array}{r} 5 \\ 4 \\ 39 \\ 3 \\ 1 \\ 37 \\ 36 \\ 64 \\ 35 \\ 63 \\ 34 \\ 62 \end{array}$ | $\begin{aligned} & \text { CD04 } \\ & \text { CD05 } \\ & \text { CD06 } \\ & \text { CD07 } \\ & \text { CD08 } \\ & \text { CD09 } \\ & \text { CD10 } \\ & \text { CD11 } \\ & \text { CD12 } \\ & \text { CD13 } \\ & \text { CD14 } \\ & \text { CD15 } \end{aligned}$ | output to memory through MD00/MD15. <br> In a read cycle, these pins are in the output mode, that is, memory data from MD00/MD15 is output to the CPU via these pins. |
| 51 19 52 20 21 53 22 23 24 55 25 56 16 57 27 58 | MDOO MD01 MD02 MD03 MD04 MD05 MD06 MD07 MD08 MD09 MD10 MD11 MD12 MD13 MD14 MD15 | Memory Data: <br> These pins have a common I/O capability and they are connected to the memory data bus. In a write cycle, these pins are in the output mode, that is, CPU data from CD00/CD15 is output to memory through these pins. <br> In a read cycle, these pins are in the input mode, that is, memory data is input to these pins and output through CD00/CD15. |
| $\begin{aligned} & 31 \\ & 29 \end{aligned}$ | $\begin{aligned} & \text { P0 } \\ & \text { P1 } \end{aligned}$ | Parity Bit: <br> These pins have a common I/O capability and P0 and P1 correspond, respectively, to the lower byte and the upper byte. The parity bit from the CPU should be odd parity. |
| $\begin{aligned} & 16 \\ & 17 \\ & 18 \\ & 48 \\ & 49 \\ & 50 \end{aligned}$ | $\begin{aligned} & \text { CB0 } \\ & \text { CB1 } \\ & \text { CB2 } \\ & \text { CB3 } \\ & \text { CB4 } \\ & \text { CB5 } \end{aligned}$ | Check Bit: <br> These pins have a common I/O capability and are connected to the check bit memory I/O line. In a write cycle, check bit data is generated by the check bit generator using CPU data; the check-bit pattern is output to check bit memory, that is, during a write cycle, these pins operate in the output mode. <br> In a read cycle, the check-bit pattern from memory is input to these pins, that is, during a read cycle, these pins operate in the input mode. |
| $\begin{aligned} & 10 \\ & 11 \\ & 12 \\ & 13 \\ & 14 \\ & 15 \end{aligned}$ | $\begin{aligned} & \text { STCB0 } \\ & \text { STCB1 } \\ & \text { STCB2 } \\ & \text { STCB3 } \\ & \text { STCB4 } \\ & \text { STCB5 } \end{aligned}$ | Syndrome-Through Check Bit: <br> These pins output the syndrome bits when read or partial write is selected. These outputs are used to analyze an error bit in the data word (CD00/CD15) and in the check bits (CB0/CB5). In the ECC-through mode, these pins output the check bits from memory. |
| 8 | ERR | Error: <br> This pin outputs the error flag when any single- or multiple-bit error is detected. |

PIN DESCRIPTIONS (continued)

| Pin No. | Designator | Function |
| :---: | :---: | :---: |
| 9 | MERR | Multiple Error: <br> This pin outputs the multiple error flag when a multiple-bit error is detected. |
| $\begin{aligned} & 32 \\ & 30 \\ & 60 \end{aligned}$ | $\overline{\text { PERRO }}$ <br> PERR1 <br> PERR | Parity Error: <br> These pins output a parity error flag when parity error occurs on CPU data. If $\overline{\text { PERRO }}=$ " $L$ ", a parity error on CD00/CD07 and P0 occurs. If $\overline{\text { PERR1 }}=$ "L", a parity error on CD8/CD15 and P1 occurs. $\overline{\text { PERR }}=\overline{\text { PERRO }} \cdot \overline{\text { PERR1 }}$. |

## BLOCK DIAGRAM



## ANALYSIS OF BLOCK DIAGRAM

DS (Data Selector): Selects memory-read or memory-write data.

DC (Data Corrector): Corrects a single-bit error by using syndrome decoder.

LT (Latches): Latches memory-read, check-bit, and syndrome data.

ED (Error Detector): Detects single-bit or double-bit errors of memory-read data (MD00/MD15 and CB0/CB5). Single-bit or double-bit errors are determined, respectively, by the states of $\overline{\text { ERR }}$ and $\overline{M E R R}$.

SG (Syndrome Generator): Generates a syndrome-bit pattern to check memory-read data.

SD (Syndrome Decoder): Decodes syndrome-bit pattern of Syndrome Generator. When a single-bit error is detected, locates error bit and inverts the parity bit.

CSB (Control Signal Buffer): Buffers all control signals.
CG (Check Bit Generator): Generates check bit for checking memory-write data.

PG (Parity Generator): Generates odd parity bit for bus data.
PC (Parity Checker): Checks odd parity bit for bus data.
SDS (Syndrome Data Selector): Selects syndrome data or memory-check bit.

## FUNCTIONAL DESCRIPTION

The error-detecting and error-correcting capabilities of the MB1426 ECC provides the user with a high order of confidence in memory reliability. Using a modified Hamming SEC/DED code, the ECC is able to detect and correct all single-bit errors and to detect all double-bit errors, even those containing consecutive strings of 0 s and 1 s . The detect/correct cycle for single-bit errors occurs without interrupting the CPU. Error flags notify the user when an error is detected.
The MB1426 has on-chip latches for memory-read, check-bit, and syndrome data; latching of the memory data allows the user to execute a partial (byte) write. To further enhance transmission reliability, a parity generator and checker is available to the user. A brief description of the read, write, and partial-write capabilities are described in subsequent paragraphs; for a detailed analysis of operating principles, refer to the Functional Truth Tables.

## Read Cycle

The read cycle is executed by setting $\overline{\mathrm{BSCNT}}, \overline{\mathrm{PWCO}}$, and $\overline{\text { PWC1 }}$ to the High state. The data and check bits from memory are read out and latched on the rising edge of RCLK; the latched data is sent to the syndrome generator and data corrector. The syndrome bit pattern is generated and decoded by the syndrome decoder; the decoded results are then sent to the data corrector.

If a single-bit error is detected, the $\overline{\text { ERR }}$ flag is raised and the error is corrected by the data corrector; the corrected data is output to CD00/CD15: When a single-bit error is detected and $\overline{\mathrm{SLE}}$ is driven Low, the falling edge triggers the syndrome latches; this latched data is output to STCB0/STCB5 when $\overline{\mathrm{EN}}$ is driven Low. Because data is held in the syndrome latches until $\overline{\mathrm{RST}}$ is driven Low, " $\overline{\mathrm{RST}}=\mathrm{L}$ " should be executed before the syndrome data is used to identify the error-bit location.

If multiple-bit errors or a bit string (0s or 1s) error is detected, both ERR and MERR flags are raised and the latched memory data is output to CD00/CD15. For these cases, the data correction cycle is not executed.

In the read cycle, odd parity bits for bytes MD00/MD07 and MD08/MD15, respectively, are output to P0 and P1.

## Write Cycle

Write capabilities of the MB1426 include both word write and partial (byte) write; either operation can be selected by setting $\overline{\mathrm{PWC0}}$ and $\overline{\mathrm{PWC} 1}$ to the proper states-see Truth Tables that follow. If the CPU is capable of parity coding, the parity bits of P0 and P1 are utilized and, in both the word and paritial-byte write modes, the parity bits are checked.
The word write mode is executed by setting both $\overline{\text { PWCO }}$ and $\overline{\text { PWC1 }}$ to the Low state. In the word-write mode, CPU data from CD00/CD15 is transferred to the check-bit generator and to MD00/MD15. Data appearing at MD00/MD15 is output and written into memory. The check-bit generator uses the CPU data to generate the check bits and these are output to CBO/CB5. The CPU and check-bit data are written into memory during the same write cycle.
The partial write mode is executed by setting either $\overline{\mathrm{PWCO}}$ or $\overline{\mathrm{PWC1}}$ to the Low state. If $\overline{\mathrm{PWCO}}$ is Low and $\overline{\mathrm{PWC1}}$ is High, the partial write is performed on byte CD00/CD07; in reverse states, byte CD08/CD15 is affected. Before a partial write is executed, the memory and check-bit data must be latched by setting BBSCNT to the Low state; this action puts CD00/CD15, MD00/MD15, P0, and P1 in the input mode and avoids data output to the CPU and memory.

The 8-bits of CPU data to be written to memory and the data to be read from memory are sent to the check-bit generator and to MD00/MD15; the data on MD00/MD15 is written into memory. Check bits are generated from 8 -bits of CPU data and 8 -bits of memory data and the check bits are then output to CB0/CB5. The partial write operation can be summarized as follows:

- Set BBSCNT Low and latch the 16-bit memory data and 6 check bits by executing a read cycle.
- Set either $\overline{\mathrm{PWC0}}$ or $\overline{\mathrm{PWC1}}$ Low and execute a write cycle. (In this case, BSCNT should be High to change MD00/ MD15 from the input to the output mode.)
- Check bits are generated by 8 bits of CPU data and 8 bits of memory data.

FUJITSU
MB1426
mannumun

FUNCTIONAL TRUTH TABLES
CPU Bus/Memory Bus Control

| BSCNT | PWC0 | PWC1 | $\begin{aligned} & \text { CD00 to } \\ & \text { CD07, P0 } \end{aligned}$ | $\begin{aligned} & \text { CD08 to } \\ & \text { CD15, P1 } \end{aligned}$ | MD00 to MD07 | MD08 to MD15 | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | H | H | Output | Output | Input | Input | Read |
|  | L | H | Input | Input | Output ${ }^{1}$ | Output ${ }^{2}$ | Partial Write |
|  | H | L | Input | Input | Output ${ }^{2}$ | Output ${ }^{1}$ |  |
|  | L | L | Input | Input | Output | Output | Write |
| L | X | X | Input | Input | Input | Input | No function |

Notes:

1. The CPU data is written into memory.
2. Memory data from previous read cycle is written into memory.

## Syndrome Output Control

| ECCTH | PWCO | PWC1 | $\overline{\text { EN }}$ | CB0 to CB5 | STCB0 to STCB5 | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | H | H | L | Input | Syndrome | Read |
|  | L | H |  | Output | Syndrome | Partial Write |
|  | H | L |  | Output |  |  |
|  | L | L |  | Output |  | Write |
| L | X | X |  | Input | Check Bit | ECC-Through |
| X | X | X | H |  | High-Z |  |

## Hamming Code

| Check Bit | CPU Data |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |  |
| CBO |  | X |  | X |  | X |  | X |  | X |  | X |  | X |  | X | Odd |
| CB1 |  |  | X | X |  |  | X | X |  |  | X | X |  |  | X | X | Odd |
| CB2 |  |  |  |  | X | X | X | X | X | X | X |  | X |  |  | X | Even |
| CB3 | X | X | X | X | X | X | X | X | X |  |  |  |  |  |  |  | Odd |
| CB4 | X | $x$ | $x$ |  | $x$ |  |  | X |  |  |  |  | X | X | X | X | Even |
| CB5 | X |  |  |  |  |  |  |  | X | X | X | X | X | X | X | X | Odd |

## Hixumunuil MB1426

## FUNCTIONAL TRUTH TABLES (continued)

## Check Bit Generation

$\mathrm{CB} 0=\overline{\mathrm{CD01}+\mathrm{CD03}+\mathrm{CD} 05+\mathrm{CD} 07+\mathrm{CD} 09+\mathrm{CD11}+\mathrm{CD13}+\mathrm{CD15}}$
$\mathrm{CB1}=\overline{\mathrm{CD} 02+\mathrm{CD} 03+\mathrm{CD} 06+\mathrm{CD07}+\mathrm{CD10}+\mathrm{CD11}+\mathrm{CD14}+\mathrm{CD15}}$
$\mathrm{CB} 2=\mathrm{CD} 04+\mathrm{CD} 05+\mathrm{CD} 06+\mathrm{CD} 07+\mathrm{CD} 08+\mathrm{CD} 09+\mathrm{CD} 10+\mathrm{CD} 12+\mathrm{CD} 15$
$\mathrm{CB} 3=\overline{\mathrm{CDO0}+\mathrm{CD01}+\mathrm{CD} 02+\mathrm{CD} 03+\mathrm{CD} 04+\mathrm{CD} 05+\mathrm{CD} 06+\mathrm{CD} 07+\mathrm{CD} 08}$
$\mathrm{CB} 4=\mathrm{CD00}+\mathrm{CD} 01+\mathrm{CD} 02+\mathrm{CD04}+\mathrm{CD} 07+\mathrm{CD} 12+\mathrm{CD13}+\mathrm{CD} 14+\mathrm{CD} 15$
$\mathrm{CB} 5=\overline{\mathrm{CD} 00+\mathrm{CD} 08+\mathrm{CD} 09+\mathrm{CD} 10+\mathrm{CD} 11+\mathrm{CD} 12+\mathrm{CD} 13+\mathrm{CD} 14+\mathrm{CD} 15}$
Syndrome Decode

| Syndrome (STCB) | Error Bit |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | No Error |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Memory Bus Data (MD) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Check Bit (CB) |  |  |  |  |  |  |
|  | 00 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 | 13 | 14 | 15 | 0 | 1 | 2 | 3 | 4 | 5 |  |
| 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| 2 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| 3 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 4 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
| 5 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |

Error Detection and Correction

| ERR | MERR | Message | Detect | Correct |
| :---: | :---: | :--- | :---: | :---: |
| H | H | No Error | - | - |
| L | H | Single Bit Error | Yes | Yes |
| L | L | Multiple Bit Error | Yes | No |

Error Flag Control

| ERREN | $\overline{\text { ECCTH }}$ | PWC0 | $\overline{\text { PWC1 }}$ | $\frac{\text { ERR }}{\text { MERR }}$ |
| :---: | :---: | :---: | :---: | :---: |
| 0 | X | X | X | disable |
| X | 0 | X | X |  |
| 1 | 1 | 0 | 0 |  |
| 1 | 1 | 0 | 1 | enable |
|  |  | 1 | 0 |  |
|  |  | 1 | 1 |  |

MB1426

## Parity Error Flag Control

| $\overline{\text { BSCNT }}$ | $\overline{\text { PWCO }}$ | $\overline{\text { PWC1 }}$ | $\overline{\text { PERRO }}$ | $\overline{\text { PERR1 }}$ | $\overline{\text { PERR }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| H | H | H | H | H | H |
|  | L | H | enable | H |  |
|  | H | L | H | enable |  |
|  | L | L | enable |  |  |
| L | X | X | H | H | H |

H: Disable state

## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Rating | Unit |
| :--- | :---: | :---: | :---: |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 7.0 | V |
| Input Voltage | $\mathrm{V}_{\mathrm{I}}$ | -0.5 to 5.5 | V |
| Output Voltage | $\mathrm{V}_{\mathrm{O}}$ | -0.5 to 5.5 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | -25 to 85 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\mathrm{STG}}$ | -55 to 125 | ${ }^{\circ} \mathrm{C}$ |

Note:
Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational specifications of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## RECOMMENDED OPERATING CONDITIONS

| Parameter |  | Value |  |  | Symbol |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | Min | Typ | Max | Unit |  |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5.0 | 5.5 | V |
| Output High Current | $\mathrm{I}_{\mathrm{OH}}$ |  |  | -3.3 | mA |
| Output Low Current | $\mathrm{I}_{\mathrm{OL}}$ |  |  | 10 | mA |
| Ambient Temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

(Recommended Operating Conditions unless otherwise noted.)

| Parameter |  | Symbol | Value |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| Supply Current |  |  | ICC |  | 240 | 400 | mA | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| Input Low Current | Except for $\overline{\mathrm{PWCO}}$, PWC1, ECCTH | IIL |  |  | -200 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=0.5 \mathrm{~V}$ |
|  | $\begin{aligned} & \overline{\mathrm{PWC0}}, \overline{\mathrm{PWC1}}, \\ & \hline \text { ECCTH } \end{aligned}$ |  |  |  | -400 |  |  |
| Input High Current |  | $\mathrm{I}_{\mathbf{H} \mathbf{H}}$ |  |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=2.4 \mathrm{~V}$ |
|  |  | $\mathrm{I}_{\mathrm{H} 2}$ |  |  | 100 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |
| Input Clamp Voltage |  | $\mathrm{V}_{1 \mathrm{C}}$ |  |  | -1.5 | V | $V_{C C}=4.5 \mathrm{~V}, \mathrm{I}_{1}=-18 \mathrm{~mA}$ |
| Output Low Voltage |  | $\mathrm{V}_{\mathrm{OL}}$ |  |  | 0.5 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| Output High Voltage |  | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  |  | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-3.3 \mathrm{~mA}$ |
| Output Leakage Current (High-Z) |  | $\mathrm{I}_{\mathrm{Oz}}$ | -100 |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{1}=0.5 \mathrm{~V} / 2.4 \mathrm{~V}$ |
| Output Short Circuit Current |  | los |  | -60 |  | mA | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0 \mathrm{~V}$ |
| Input Low Voltage |  | $\mathrm{V}_{\text {IL }}$ |  |  | 0.8 | V |  |
| Input High Voltage |  | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 |  |  | V |  |

FUJITSU


## MB1426

AC CHARACTERISTICS (continued)
(Recommended operating conditions and AC test conditions unless otherwise noted.)

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| Delay Time from RCLK to CD, P0, P1 | $\mathrm{t}_{\text {CKCD }}$ |  | 35 | 57 | ns |
| Delay Time from RCLK to $\overline{\text { ERR }}$ | $\mathrm{t}_{\text {CKER }}$ |  | 22 | 37 | ns |
| Delay Time from RCLK to $\overline{\text { MERR }}$ | $\mathrm{t}_{\text {CKMER }}$ |  | 25 | 42 | ns |
| Delay Time from ERREN to $\overline{\text { ERR, }}$, $\overline{M E R R}$ | $\mathrm{t}_{\text {EREN }}$ |  | 11 | 21 | ns |
| MD Set Up Time referenced to RCLK | $\mathrm{t}_{\text {MDCKS }}$ | 15 |  |  | ns |
| MD Hold Time referenced to RCLK | $\mathrm{t}_{\text {MDCKH }}$ | 10 |  |  | ns |
| CB Set Up Time referenced to RCLK | $\mathrm{t}_{\text {CBCKS }}$ | 15 |  |  | ns |
| CB Hold Time referenced to RCLK | $\mathrm{t}_{\text {CBCKH }}$ | 10 |  |  | ns |
| Disable Time of MD from $\overline{\text { PWC0 }} / \overline{\text { PWC1 }}$ | $\mathrm{t}_{\text {MDZD }}$ |  | 15 | 26 | ns |
| Disable Time of CB from $\overline{\text { PWC0 }} / \overline{\text { PWC1 }}$ | $\mathrm{t}_{\text {CBZD }}$ |  | 15 | 26 | ns |
| Enable Time of CD, P0, P1 from $\overline{\mathrm{PWC0}} / \overline{\text { PWC1 }}$ | $\mathrm{t}_{\text {CDZE }}$ |  | 22 | 36 | ns |
| Delay Time from CD to MD | $\mathrm{t}_{\text {CDMD }}$ |  | 16 | 27 | ns |
| Delay Time from CD to CB | $\mathrm{t}_{\text {CDCB }}$ |  | 21 | 34 | ns |
| Delay Time from CD to $\overline{\text { PERR0 }} / \overline{\text { PERR1 }}$ | $\mathrm{t}_{\text {CDPEN }}$ |  | 22 | 35 | ns |
| Delay Time from CD to $\overline{\text { PERR }}$ | $\mathrm{t}_{\text {CDPER }}$ |  | 23 | 38 | ns |
| Delay Time from P0/P1 to $\overline{\text { PERR0}} / \overline{\text { PERR1 }}$ | $\mathrm{t}_{\text {PPEN }}$ |  | 12 | 22 | ns |
| Delay Time from P0/P1 to PERR | $t_{\text {PPER }}$ |  | 14 | 26 | ns |
| Enable Time of MD from $\overline{\mathrm{PWC}} / \overline{\text { PWC1 }}$ | $\mathrm{t}_{\text {MDZE }}$ |  | 20 | 32 | ns |
| Enable Time of CD from $\overline{\mathrm{PWC0}} / \overline{\text { PWC1 }}$ | $\mathrm{t}_{\text {CBZE }}$ |  | 20 | 32 | ns |
| Disable Time of CD, P0, P1 from $\overline{\mathrm{PWC0}} / \overline{\text { PWC1 }}$ | $\mathrm{t}_{\text {CDZD }}$ |  | 15 | 26 | ns |
| Delay Time from $\overline{\text { PWC0 }} / \overline{\text { PWC } 1 ~ t o ~} \overline{\text { PERR0 }}$, $\overline{\text { PERR1 }}$ | $\mathrm{t}_{\text {PWPEN }}$ |  | 10 | 18 | ns |
| Delay Time from $\overline{\text { PWC0 } / \overline{\text { PWC1 }} \text { to } \overline{\text { PERR }} \text { ( }{ }^{\text {a }} \text { ( }}$ | $\mathrm{t}_{\text {PWPER }}$ |  | 12 | 22 | ns |
| Enable Time of MD from $\overline{\text { BSCNT }}$ | $\mathrm{t}_{\text {BCMDZE }}$ |  | 20 | 35 | ns |
| Delay Time from $\overline{\text { SLE }}$ to STCB | $\mathrm{t}_{\text {SLEST }}{ }^{1}$ |  | 23 | 37 | ns |
| Enable Time of STCB from $\overline{\mathrm{EN}}$ | $\mathrm{t}_{\text {Stze }}{ }^{1}$ |  | 15 | 24 | ns |
| RCLK Set Up Time referenced to SLE | $\mathrm{tsSL}^{1}$ | 44 |  |  | ns |
| Delay Time from MD to CD | $\mathrm{t}_{\text {MDCDTH }}{ }^{2}$ |  | 21 | 34 | ns |
| Delay Time from MD to P0, P1 | $\mathrm{t}_{\text {MDPTH }}{ }^{2}$ |  | 28 | 48 | ns |
| Delay Time from CB to STCB | $\mathrm{t}_{\text {CBSTTH }}{ }^{2}$ |  | 18 | 30 | ns |
| RCLK Set Up Time referenced to $\overline{\text { PWC0, }} \overline{\text { PWC1 }}$ | $\mathrm{t}_{\mathrm{CKS}}{ }^{3}$ | 57 |  |  | ns |
| $\overline{\text { PWC0, }} \overline{\text { PWC1 }}$ Set Up Time referenced to $\overline{\text { BSCNT }}$ | ${ }_{\text {tSBC }}{ }^{3}$ | 10 |  |  | ns |
| Delay Time from PWC0/PWC1 to CD | $\mathrm{tSCD}^{3}$ |  | 15 | 26 | ns |

AC CHARACTERISTICS (continued)
(Recommended operating conditions and AC test conditions unless otherwise noted.)

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| RCLK Pulse Width | $t_{\text {WCK }}$ | 20 |  |  | ns |
| RST Pulse Width | $t_{\text {WRST }}$ | 20 |  |  | ns |
| SLE Pulse Width | WSLE | 20 |  |  | ns |

## Notes:

1. Syndrome Latch
2. ECC-Through Mode
3. Partial Write Mode

## AC TEST CONDITONS

Output Load:


Timing Waveform:

$\mathrm{V}_{\mathrm{IH}}=3 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V}, \mathrm{tr}=10 \mathrm{~ns}, \mathrm{tf}=\mathbf{5 n s}$

| Parameter | Symbol | RL( $\Omega$ ) | R1( $\Omega$ ) | CL(pF) | SW1 | SW2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Delay Time | $t_{\text {PLH }}$ $\mathrm{t}_{\mathrm{PHL}}$ | 1.0K | - | 50 | Off | On |
| Enable Time | $\begin{aligned} & \mathrm{t}_{\mathrm{PLZ}} \\ & \mathrm{t}_{\mathrm{PHZ}} \end{aligned}$ | 1.0K | 0.5K | 5 | $\begin{aligned} & \text { On } \\ & \text { Off } \end{aligned}$ | On On |
| Disable Time | $\begin{aligned} & \mathrm{t}_{\mathrm{PZL}} \\ & \mathrm{t}_{\mathrm{PZH}} \end{aligned}$ | 1.0K | 0.5K | 50 | $\begin{aligned} & \text { On } \\ & \text { Off } \end{aligned}$ | $\begin{aligned} & \text { On } \\ & \text { On } \end{aligned}$ |

## MB1426

TIMING DIAGRAMS
Read Mode


TIMING DIAGRAMS (continued)
Write Mode (Word Write)


TIMING DIAGRAMS (continued)
Partial Write Mode (Byte Write)


Syndrome Latch


## PACKAGE DIMENSIONS



3

## Peripheral Support Devices

## CRT Controllers

| 4-2 | MB89321A | CMOS Programmable CRT Controller |
| :---: | :---: | :---: |
| 4-2 | MB89322A | CMOS Programmable CRT Controller |
| 4-25 | MB89321B | CMOS Programmable CRT Controller |
| 4-25 | MB89322B | CMOS Programmable CRT Controller |
| Hard Disk Controller |  |  |
| 4-26 | MB89341 | Hard Disk Controller |
| Floppy Disk Controllers |  |  |
| 4-27 | MB8876A | Floppy Disk Formatter/Controller |
| 4-27 | MB8877A | Floppy Disk Formatter/Controller |
| 4-44 | MB89311 | CMOS Floppy Disk Controller/Formatter |
| 4-57 | MB4107 | Floppy Disk VFO |
| 4.65 | MB4111 | Magnetic Disk Head Amplifier |
| 4-65 | M84112 | Magnetic Disk Head Amplifier |
| 4-65 | MB4113 | Magnetic Disk Head Amplifier |
| 4-76 | MB4316 | Driver/Receiver for Disk Head Amplifier |
| Television Display Controllers |  |  |
| 4.81 | MB88303 | NMOS Television Display Controller (TVDC) |
| 4-98 | MB88313 | CMOS Television Display Controller (TVDC) |
| Protocol Controller |  |  |
| 4-122 | MB87030 | SCSI Protocol Controller |
| Unlversal Perlpheral Interface Peripherals |  |  |
| 4-130 | MBL8041AH/E/N | NMOS Universal Peripheral Interface 8-Bit Microcomputer |
| 4-147 | MBL8042H/N | NMOS Universal Peripheral Interface 8-Bit Microcomputer |
| 4-164 | MBL8742H/N | NMOS Universal Peripheral Interface 8-Bit Microcomputer |
| 4-183 | MB8868A | MOS Universal Asynchronous Receiver Transmitter (UART) |
| 4-194 | MB8867 | TTL Two-Phase Clock Generator and Driver |
| 4-194 | MB8867E | TTL Two-Phase Clock Generator and Driver |
| Selector Guide for A-to-D/D-to-A Interface Peripherals |  |  |
| $\begin{aligned} & 4-205 \\ & 4-205 \end{aligned}$ | A-to-D Converte D-to-A Converte |  |
| CMOS Peripherals |  |  |
| 4-207 | MB89237A | DMA Controller |
| 4-208 | MB89251A | Serial Data Transmitter/Recelver |
| 4-209 | MB89254 | Programmable Timer |
| 4-210 | MB89255A | Parallel Data I/O Interface |
| 4-211 | MB89259A | Programmable Interrupt Controller |
| 4-212 | MB89282 | Address Latch |
| 4-212 | MB89283 | Address Latch |
| 4-213 | MB89284A | Clock Generator |
| 4-214 | MB89286 | Data Bus Transceiver |
| 4-214 | MB89287 | Data Bus Transcelver |
| 4-215 | MB89288 | Bus Controller |
| 4-216 | MB89289 | Bus Arbiter |

## Advanced Products

## Description

The MB89321A/MB89322A Programmable CRT Controllers are single chip CMOS devices used to interface CRT raster scan displays with microcomputer systems. Both devices operate on a single +5 V power supply and have TTL-compatible I/O. The MB89321A interfaces to 6800 family microprocessors; the MB89322A to the 8080.

The MB89321A/MB89322A refresh the display by buffering information from main memory using thirty-three internal registers and keeping track of the display position of the screen. Both devices are designed to allow simple interfacing to most raster scan CRTs with a minimum of external hardware and software overhead.

Features

- Programmable Screen and Character Formats
- Cursor Control (3 types)
- Selectable Scan Modes (3 types)
- Light Pen Detection
- Refresh Memory Address Function
- Screen Partitioning (up to 4 partitions)
- Independent Paging/Scrolling for Each Screen Partition
- Smooth Scrolling (up to 4 screens simultaneously)
- Status Generation and Processor Interrupt Generation by Vertical Blanking or Light Pen
- External Sync for TV Superimposition (synchronous mode) or Interface to Other CRT Controllers (master-slave mode)
- Double-Size Vertical Display using Raster Interpolation
- 4.0 MHz Clock Rate
- Single +5 V Power Supply
- CMOS Process
- 40-pin Plastic DIP



## Functional Block Diagram


*Symbols parenthesized are applied to MB89322A.

Pin Assignment


## Pin Descriptions

MB89321A(MB89322A)

| Pin Number | Symbol | Pin Name | Function |
| :---: | :---: | :---: | :---: |
| 1 | $\mathrm{V}_{\text {SS }}$ | Ground | Ground |
| 2 | RESET | Reset | Input used for device reset. When $\overline{\text { RESET }}$ goes low: <br> - Internal counters are cleared and stopped; <br> - All outputs go low, and; <br> - Control registers and status register are cleared, other internal registers unaffected. <br> Enabled only when LPSTB is low. RESET goes high, display is initiated immediately. Control registers R30 and R31 must be initialized by software after reset is released. |
| 3 | LPSTB | Light Pen Strobe | Character detection input. When high, the memory address is loaded in the light pen register, the raster address in the light pen raster register, and the status bit set. |
| $\begin{aligned} & 4 \text { to } \\ & 17 \end{aligned}$ | MAO to MA13 | Memory Address | Refresh memory address output |
| 18 | DISPTMG | Display <br> Timing | Display timing output. Set to high during display. |
| 19 | $\begin{aligned} & \text { CUDISP/ } \\ & \text { IRQ } \end{aligned}$ | Cursor <br> Display <br> Timing/ <br> Interrupt <br> Request | Cursor display timing output/interrupt request output. Set to high during display. Setting the control register enables a high-level interrupt request signal to be output while the display timing signal is low. |
| 20 | $\mathrm{V}_{\mathrm{cc}}$ | Power Supply | +5 V power supply. |
| 21 | CLK | Clock | Clock input. Goes low during EXHSYNC in TV sync mode. |
| 22 | $\frac{\mathrm{R} / \overline{\mathrm{W}}}{(\overline{\mathrm{~W}})^{*}}$ | $\begin{aligned} & \text { Read/Write } \\ & \text { (Write) } \\ & \hline \end{aligned}$ | MPU read/write input. (MPU write input) |
| 23 | $\begin{aligned} & \mathrm{E} \\ & (\overline{\mathrm{RD}})^{*} \end{aligned}$ | Enable (Read) | MPU enable input. (MPU read input) |
| 24 | RS | Register select | Internal register select input. Normally connected to the least significant bit (AO) of the address bus. When high, selects internal registers; when low, the address register. |
| 25 | $\overline{\mathrm{CS}}$ | Chip select | Chip select input. Goes low when the MPU accesses the CRTC. |
| $\begin{aligned} & 26 \text { to } \\ & 33 \end{aligned}$ | $\begin{aligned} & \text { D7 to } \\ & \text { D0 } \end{aligned}$ | Data Bus | MPU data bus pins |
| $\begin{aligned} & 34 \text { to } \\ & 38 \end{aligned}$ | RA4 to RAO | Raster Address | Raster address output |
| 39 | HSYNC/ EXHSYNC | Hsync Output/ Hsync Input | Horizontal sync output/external horizontal sync input. When reset, becomes the horizontal sync output. |
| 40 | VSYNC/ EXVSYNC | Vsync Output/ Vsync Input | Vertical sync output/external vertical sync input. When reset, becomes the vertical sync output. |

## Internal Registers and Functions

| $\overline{\text { cs }}$ | RS | Address |  |  |  | Register 0 Number |  | Register Name | Read Write | Data Bit |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 4 | 3 | 2 | 1 |  |  | 7 |  | 65 | 4 | 32 | 1 | 0 |
| 1 | $x$ | x | $x$ | $x$ | x | $\times$ | - |  | Invalid | - |  |  |  | - |  |  |
| 0 | 0 | $\times$ | x | $\times$ | $\times$ | $\times$ | AR | Address Register | W |  |  |  |  |  |  |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | R0 | Total Number of Characters in Line (*) | W |  |  |  |  |  |  |
| 0 | 1 | 0 | 0 | 0 | 0 | 1 | R1 | Number of Characters Displayed in Line | W |  |  |  |  |  |  |
| 0 | 1 | 0 | 0 | 0 | 1 | 0 | R2 | Horizontal Sync Position (*) | w |  |  |  |  |  |  |
| 0 | 1 | 0 | 0 | 0 | 1 | 1 | R3 | Sync Signal Puise Width | w |  | V2 V1 | Vo H | $\mathrm{H}_{3} \mathrm{H} 2 \mathrm{H}$ | 1 HO |  |
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | R4 | Total Number of Lines (*) | W |  |  |  |  |  |  |
| 0 | 1 | 0 | 0 | 1 | 0 | 1 | R5 | Total Raster Adjust | W |  |  |  |  |  |  |
| 0 | 1 | 0 | 0 | 1 | 1 | 0 | R6 | Number of Lines Displayed | W |  |  |  |  |  |  |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | R7 | Vertical Sync Position (*) | W |  |  |  |  |  |  |
| 0 | 1 | 0 | 1 | 0 | 0 | 0 | R8 | Scan Mode/Skew | W |  | COD |  |  |  |  |
| 0 | 1 | 0 | 1 | 0 | 0 | 1 | R9 | Maximum Raster Address | W |  |  |  |  |  |  |
| 0 | 1 | 0 | 1 | 0 | 1 | 0 | R10 | Cursor Start Raster | W |  | B1 B0 |  |  |  |  |
| 0 | 1 | 0 | 1 | 0 | 1 | 1 | R11 | Cursor End Raster | W |  |  |  |  |  |  |
| 0 | 1 | 0 | 1 | 1 | 0 | 0 | R12 | Start Address 1 | R/W |  |  |  |  |  |  |
| 0 | 1 | 0 | 1 | 1 | 0 | 1 | R13 | Start Address 1 |  |  |  |  |  |  |  |
| 0 | 1 | 0 | 1 | 1 | 1 | 0 | R14 | Cursor | R/W |  |  |  |  |  |  |
| 0 | 1 | 0 | 1 | 1 | 1 | 1 | R15 |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 | R16 | Light Pen | R |  | - |  |  |  |  |
| 0 | 1 | 1 | 0 | 0 | 0 | 1 | R17 | Light Pen | R |  |  |  |  |  |  |
| 0 | 1 | 1 | 0 | 0 | 1 | 0 | R18 | Screen 2 Display Start Position (*) | R/W |  |  |  |  |  |  |
| 0 | 1 | 1 | 0 | 0 | 1 | 1 | R19 | Start Address 2 | R/W |  |  |  |  |  |  |
| 0 | 1 | 1 | 0 | 1 | 0 | 0 | R20 |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 0 | 1 | 0 | 1 | R21 | Screen 3 Display Start Position (*) | R/W |  |  |  |  |  |  |
| 0 | 1 | 1 | 0 | 1 | 1 | 0 | R22 | Address 3 | R/W |  |  |  |  |  |  |
| 0 | 1 | 1 | 0 | 1 | 1 | 1 | R23 | Address 3 | R/W |  |  |  |  |  |  |
| 0 | 1 | 1 | 1 | 0 | 0 | 0 | R24 | Screen 4 Display Start Position (*) | R/W |  |  |  |  |  |  |
| 0 | 1 | 1 | 1 | 0 | 0 | 1 | R25 | Start Address 4 | R/W |  |  |  |  |  |  |
| 0 | 1 | 1 | 1 | 0 | 1 | 0 | R26 | Start Address 4 |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 1 | 0 | 1 | 1 | R27 | Vertical Sync Position Fine Adjust | W |  |  |  |  |  |  |
| 0 | 1 | 1 | 1 | 1 | 0 | 0 | R28 | Light Pen Raster | R | DP |  |  |  |  |  |
| 0 | 1 | 1 | 1 | 1 | 0 | 1 | R29 | Smooth Scroll | R/W |  |  |  |  |  |  |
| 0 | 1 | 1 | 1 | 1 | 1 | 0 | R30 | Control | W | VE | VS IBI | LSY | TV P1 |  |  |
| 0 | 1 | 1 | 1 | 1 | 1 | 1 | R31 | Control/Status | R/W | SS3 | 3S52SS | 1 SSO | ORI* E | SB | SL |

*Note: Values written to these registers are one (1) less than the set values; refer to Notes on operation

## Register Description

## Address Register (AR)

Sets the number of the internal register. Unchanged until a new value is written.

Total Number of Characters in Line Register (RO)
Sets horizontal scan sync. Settings indicate number of characters, and are determined by the formula:

Total Number of Characters in Line $\times$ Character Period $=$ Horizontal Scan Period

Values written to the register are 1 less than the set values.

## Number of Characters

 Displayed in Line Register (R1)Sets the horizontal display period. Settings indicate number of characters.

## Horizontal Sync Position

 Register (R2)Sets the horizontal sync signal position. Settings indicate number of characters. Values written to the register are 1 less than the set values.

Sync Signal Pulse Width Register (R3)

| MSB |  |  |  |  |  |  |  | LS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| V3 | V2 | V1 | Vo | H3 |  |  | H |  |

Sets the sync signal pulse width. The 4 high-order bits are used for the vertical sync signal, the 4 low-order bits for the horizontal sync signal. the TV sync mode, the 4 low-order bits are used as the horizontal back porch

Total Number of Lines Register (R4)
Used the the total raster adjust register to set vertical sync (field sync is set by number of rasters). Setting is in number of lines. Values written to the register are 1 less than the set value.

Total Raster Adjust Register (R5)
Used to fine tune the vertical sync. Settings indicate number of rasters, and must be less than the maximum raster address. Vertical sync is determined by the formula:

Vertical Sync $=$ Total Number of Lines x Maximum Raster Address + Total Raster Adjust

## Number of Lines Displayed Register (R6)

Sets the vertical display period. Settings indicate number of lines.

Vertical Sync Position Register (R7)
Used with the vertical sync position fine adjust register (R27) to set vertical sync position using raster count Settings indicate number of lines. Values written to the register are 1 less than the set values.

## Scan Mode/Skew Register

(R8)


Sets cursor display signal and display timing signal skew, and the scan mode. Bit functions are as shown below:

## C1 CO CUDISP Output

| 0 | 0 | Output without skew |
| :--- | :--- | :--- |
| 0 | 1 | Skewed by <br> character 1 |
| 1 | 0 | Skewed by 2 <br> characters |
| 1 | 1 | No CUDISP output |
| D1 | DO | DISPTMG Output |
| 0 | 0 | Output without skew |
| 0 | 1 | Skewed by 1 <br> character |
| 1 | 0 | Skewed by 2 <br> characters |
| 1 | 1 | No DISPTMG output |


| I1 | IO | Scan Mode |
| :--- | :--- | :--- |
| 0 | 0 | Non-interlace mode |
| 0 | 1 | Interlace mode |
| 1 | 0 | Non-interlace mode |
| 1 | 1 | Interlace and video <br> mode |

## Maximum Raster Address Register (R9)

Sets the number of rasters in a line. In interlace and noninterlace modes, the value written is 1 less than the set value; in interlace and video mode, 2 less. Examples of settings in each mode are as follows:

Interlace mode


Raster count - 5
Value written-4
Non-interlace mode


## Register Description (Continued)

## Cursor Start Raster Register

## (R10)



Sets the cursor display mode and the display start raster. Settings indicate number of rasters. Cursor display mode bit function is as follows:

| B1 | B0 | Cursor Display <br> Mode |
| :--- | :--- | :--- |
| 0 | 0 | Displays without <br> blinking |
| 0 | 1 | No display |
| 1 | 0 | Blinks in 16-field <br> sync |
| 1 | 1 | Blinks in 32-field <br> sync |

## Cursor End Raster Register

 (R11)Sets the cursor display end raster. Settings indicate number of rasters.

Start Address Registers (R12, R13, R19, R20, R22, R23, R25, R26)
Four sets of 14-bit paired registers used to set the starting memory address for screen display that enable independent paging/scrolling when screen is partitioned. Registers are for Start Address 1 (R12, R13), Start Address 2
(R19, R20), Start Address 3
(R22, R23) and Start Address 4 (R25, R26).

## Cursor Registers (R14, R15)

14-bit paired registers used to set the cursor display memory address.

Light Pen Registers (R16, R17)
14-bit paired registers to which the memory address is written when the light pen strobe signal goes high. Memory address value must be compensated in software for delay in the light pen detection circuit.

Light Pen Raster Register (R28)


Register to which the raster address and display status bit are written when the light pen strobe signal goes high. When the light pen register or light pen raster register are written to during the display period, the display status bit is set to 1; during blank period, reset to 0 .

Vertical Sync Position Fine Adjust Register (R27)
Used to fine-tune the vertical sync signal within the line set by the vertical sync position register. Settings indicate number of rasters. Examples of settings are shown below:
Setting Value $=1$


Setting 0 must not be written as it will cause the control register to disable the vertical sync position adjust register, resulting in a vertical sync signal output of RA $=0$. The set value must be less than the maximum raster address.

## Display Start Position

 Registers (R18, R21, R24)Sets the starting line numbers for display start addresses 2,3 , and 4 when screen is partitioned. See following figure. Values written to the register are 1 less than the line number; 0 must not be written. Examples of settings are shown below:

Line
Number Display Screen

| 0 | Screen 1 <br> (Start address 1) |
| :--- | :--- |
| 2 | Screen 2 <br> (Start address 2, <br> Register 18) |
| 3 | Screen 3 |
| 4 | (Start address 3, |
| 5 | Register 21) |
| 6 |  |
| 7 | Screen 4 |
| 8 | (Start address 4, |
| 9 | Register 24) |

Value written for start position $2=2$
Value written for start position $3=3$
Value written for start position $4=7$

## Smooth Scroll Register (R29)

Sets the starting raster address within a line. Setting indicates number of rasters.
Smooth scrolling can be used in interlace and non-interlace modes only.

Settings are valid for screens specified by SS3 to SS0 of the control/status register. Settings must be less than the maximum raster address. Examples of settings are shown below:


## Register Description

(Continued)


Controls the external sync function, interrupt function, vertical sync position fine adjust function and screen
partition function. This register must be initialized by software after reset is released. Bit functions are as shown below:

| VE | VS | TV | External Sync Function |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Both VSYNC and HSYNC are in output mode. DISPTMG is active. External <br> sync operation is disabled. |
| 0 | 1 | 0 | Outputs VSYNC for odd-numbered fields only in interlace mode. No VSYNC <br> output when the programmed values of max. raster address and vertical <br> sync position are odd numbers in interlace \& video mode. |
| 1 | 0 | 0 | EXVSYNC is in input mode but external sync signal ignored. DISPTMG is <br> active. |
| 1 | 1 | 0 | EXVSYNC is in input mode and external sync signal is accepted. DISPTMG <br> goes low (disabled). |
| 0 | 0 | 1 | Disallowed |
| 0 | 1 | 1 | Disallowed |
| 1 | 0 | 1 | Both EXVSYNC and EXHSYNC are in input mode and external sync signal is <br> accepted. DISPTMG output is active. |
| 1 | 1 | 1 | Both EXVSYNC and EXHSYNC are in input mode and external sync <br> signal is accepted. DISPTMG goes low (disabled). |

## Notes:

1. When VS $=1$, DISPTMG goes low.
2. When TV $=0$, indicates master-slave mode. When TV $=1$, indicates TV sync mode.
3. In TV sync mode, the horizontal back porch must be set using the horizontal sync pulse width register.
4. In TV sync mode, the internal control is in non-interlace mode.
IB IL Interrupt Function

| 0 | 0 | None |
| :--- | :--- | :--- |
| 0 | 1 | With light pen strobe |
| 1 | 0 | With vertical blanking |
| 1 | 1 | With light pen or vertical blanking |

Note: Interrupt signal is output for CUDISP while DISPTMG is low.

| SY | Vertical Sync Position Fine Adjust Function |
| :--- | :--- |
| 0 | Vertical sync position fine adjust register disabled |
| 1 | Vertical sync position fine adjust register enabled |
| P1 | P0 |
| 0 | 0 | | Screen Partition Function |
| :--- |
| $\mathbf{0}$ |

Note: Screen address 1 is always displayed starting from line number 0 .

## Register Description <br> (Continued)



Controls the smooth scrolling and raster interpolation functions, and performs read/write of the status register. This register must be initialized by software after reset is released. Control bit functions are as follows:

## Control Bits Function

Smooth scrolling control bits; when set to 1 the smooth scrolling register is
SS3 to SS0 enabled. Bits correspond to the screens as follows:
SS3 $=$ screen 4
SS2 $=$ screen 3
SS1 = screen 2 SSO = screen 1

RI Therefore, in this case, registers related to vertical sync control must be
Raster interpolation bit. Set to 1, raster interpolation is performed. The raster counter is incremented every two rasters, doubling the vertical sync rate. reprogrammed. The raster interpolation function can't be used in external sync mode and interlace \& video mode.

## Notes:

1. "Os"" must be written to lower 3 bits of the control register.
2. Refer to diagram of "Double-Size Vertical Display" and item 6 of Notes on Operation.

## Status Bits

The functions of status bits are as follows:

## E Display Field Status

| 0 | Odd-numbered screen display, or in non-interlace mode |
| :--- | :--- |
| 1 | Even-numbered screen display |

## SB Vertical Blanking Status

| 0 | During screen display |
| :--- | :--- |
| 1 | During vertical blanking |

SL Light Pen Strobe Status

| 0 | Light pen strobe ignored |
| :--- | :--- |
| 1 | Light pen strobe accepted |

## Notes:

1. Light pen strobe status is cleared by reset or by read of the status register.
2. Vertical blanking status and light pen strobe status are set regardless of the setting of the control register interrupt function.
3. E bit is controlled by the vertical blank. Therefore, E bit status is different from normal field image, and it's update timing changes depending on number of lines displayed. To get correct status, E bit must be read immediately after the display period.

Values which may be written to internal registers are as follows:
(1) $0<\begin{gathered}\text { number of characters } \\ \text { displayed in line }\end{gathered}$ (R1)< $\begin{aligned} & \text { total number of } \\ & \text { characters in line }\end{aligned}(R 0)+1 \leq 256$
(2) 0 < number of lines displayed (R6) < total number of lines (R4) $+1 \leq 128$
(3) $0 \leq$ horizontal sync position (R2) $\leq$ total number of characters in line (R0)
(4) $0 \leq$ vertical sync position (R7) $\leq$ total number of lines (R4)
(5) $0 \leq$ cursor start raster (R10) $\leq$ cursor end raster (R11) $\leq$ maximum raster address (R9) (interlace mode and non-interlace modes)
$0 \leq$ cursor start raster (R10) $\leq$ cursor end raster (R11) $\leq$ maximum raster address (R9)+1 (interlace \& video mode)
(6) $2 \leq$ maximum raster address (R9) $\leq 30$ (interlace \& video mode only)
(7) $3 \leq$ total number of characters in line (R0) (except in non-interlace mode)
$5 \leq$ total number of characters in line (RO) (non-interlace mode only)
(8) Vertical sync position fine adjust (R27) < maximum raster address (R9)
(9) Smooth scroll (R29) $\leq$ maximum raster address (R9)

## System Block Diagram



## Programmable Values

Programmable values which can be written to registers and their respective symbols are as shown below:

| Register Number | Register Name | Programmable Value | Symbol |
| :---: | :---: | :---: | :---: |
| R0 | Total Number of Characters in Line | Characters | Nht |
| R1 | Number of Characters Displayed in Line | Characters | Nhd |
| R2 | Horizontal Sync Position | Characters | Nhsp |
| R3 | Sync Signal Pulse Width | Rasters/Characters | Nvsw/Nhsw |
| R4 | Total Number of Lines | Lines | Nvt |
| R5 | Total Raster Adjust | Rasters | Nadj |
| R6 | Number of Lines Displayed | Lines | Nvd |
| R7 | Vertical Sync Position | Lines | Nvsp |
| R8 | Scan Mode/Skew |  |  |
| R9 | Maximum Raster Address | Rasters | Nr |
| R10 | Cursor Start Raster | Rasters | $\mathrm{N}_{\text {CSTART }}$ |
| R11 | Cursor End Raster | Rasters | $\mathrm{N}_{\text {CEND }}$ |
| R12 | Start Address 1 |  | $\mathrm{N}_{\text {SI }}$ |
| R13 |  |  |  |
| R14 | Cursor |  |  |
| R15 |  |  |  |
| R16 | Light Pen |  |  |
| R17 |  |  |  |
| R18 | Screen 2 Display Start Position | Lines | $\mathrm{N}_{\mathrm{L} 2}$ |
| R19 | Start Address 2 |  | $\mathrm{N}_{\text {S2 }}$ |
| R20 |  |  |  |
| R21 | Screen 3 Display Start Position | Lines | $\mathrm{N}_{\mathrm{L} 3}$ |
| R22 | Start Address 3 |  | $\mathrm{N}_{\mathrm{s} 3}$ |
| R23 |  |  |  |
| R24 | Screen 4 Display Start Position | Lines | $\mathrm{N}_{\mathrm{L} 4}$ |
| R25 | Start Address 4 |  | $\mathrm{N}_{\text {S }}$ |
| R26 |  |  |  |
| R27 | Vertical Sync Position Fine Adjust | Rasters | Nspadj |
| R28 | Light Pen Raster |  |  |
| R29 | Smooth Scroll | Rasters | Nradj |
| R30 | Control |  |  |
| R31 | Control/Status |  |  |

## Screen Format



Line numbers are counted starting at the following addresses:
Line number $0=$ starts from memory address 0
Line number $1=$ starts from memory address Nhd
Line number 2 = starts from memory address 2Nhd
Line number $\mathrm{n}=$ starts from memory address (Nvd-1)Nhd

## Scan Mode

Examples of format during scan mode:

Non-Interlace Mode


7

| Dot clock rate | 16.128 MHz |
| :--- | :--- |
| Horizontal frequency | 15.75 kHz |
| Vertical frequency | 60.1145 Hz |

At the following clock rates and register settings, the screen format is as shown in the diagrams below:
Total number of characters in line, Register 0:
Number of characters displayed in line, Register 1:
127
Horizontal sync position, Register 2:
Sync signal pulse width, Register 3: $\quad 98$
Total number of lines, Register 4: 31
Total raster adjust, Register 5: 6
Number of lines displayed, Register 6: 25
Vertical sync position, Register 7:
Maximum raster address, Register 9: 8


## Scan Mode

## (Continued)

Interlace \& Video Modes


## Cursor Control

Examples of settings for the cursor start and end raster registers:

| 0 |  |
| :--- | :--- | :--- |
| 1 | 0 |
| 2 |  |

## TV Sync Mode

Example of a TV Sync mode circuit:


TV sync mode is used to superimpose displays on TV or video signals. In the above example a $1 / n$ fosc dot shift
will occur. Accordingly, an appropriate prescaler should be designed to avoid image resolution problems.

During HSYNC, CLK must be low (stopped).

## Master-Slave Mode

Example of a master-slave mode circuit:


Master-slavemode is used to synchronize master and slave CRT controllers. The screen formats and clock phases of the two CRTCs must match.

Since HSYNC is output, PLL can be used.

Smooth Scroll
Example of smooth scrolling display:


In the example, screen 2 is being smooth scrolled.

## Double-Size

## Vertical Display



Without raster interpolation function

Raster Address


With raster interpolation function

The vertical size of the display can be doubled using the raster interpolation function as shown in the example.

In raster interpolation, the raster address is updated every second raster.

Refer to item 6 of Notes on Operation.

## Absolute Maximum Ratings

## Recommended Operating

 ConditionsDC Characteristics
Recommended operating conditions unless otherwise noted.

| Parameter | Symbol | Rating | Unit |
| :--- | :--- | :--- | :---: |
| Input Voltage | $\mathrm{V}_{\text {IN }}$ | -0.3 to +7.0 | V |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Operating Ambient Temperature | $\mathrm{T}_{\mathrm{A}}$ | -40 to +85 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 600 | mW |

Note: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

| Parameter |  | Symbol | Value |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. | Max. | Unit |
| Supply Voltage |  | $\mathrm{V}_{\text {c }}$ | 4.5 | 5.0 | 5.5 | V |
|  |  | $V_{S S}$ |  | 0.0 |  | V |
| Input High Voltage | LPSTB, CLK | $\mathrm{V}_{\mathrm{IH} 1}$ | 2.2 |  | $V_{C C}$ | V |
|  | Other Inputs | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |
| Input Low Voltage | LPSTB, CLK | $\mathrm{V}_{\text {IL } 1}$ | -0.3 |  | 0.6 | V |
|  | Other Inputs | $\mathrm{V}_{\text {IL }}$ | -0.3 |  | 0.8 | V |
| Ambient Temperature |  | $\mathrm{T}_{\text {A }}$ | -20 | 25 | +75 | ${ }^{\circ} \mathrm{C}$ |


| Parameter |  | Symbol | Test Conditions | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max |  |
| Input High Voltage | LPSTB, CLK | $\mathrm{V}_{\mathrm{H} 1}$ |  | 2.2 |  | $V_{\text {cc }}$ | V |
|  | Other Inputs | $\mathrm{V}_{1 \mathrm{H}}$ |  | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |
| Input Low Voltage | LPSTB,CLK | $\mathrm{V}_{\text {IL1 }}$ |  | -0.3 |  | 0.6 | V |
|  | Other Inputs | $\mathrm{V}_{\text {IL }}$ |  | -0.3 |  | 0.8 | V |
| Input Leakage Current | D0 to D7, EXHSYNC, EXVSYNC | IIL | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ | -10 |  | 10 | $\mu \mathrm{A}$ |
|  | Other Inputs | $\mathrm{IL}_{1}$ | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ to 5.5 V | -2.5 |  | 2.5 | $\mu \mathrm{A}$ |
| Output High Voltage | D0 to D7 | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{l}_{\mathrm{OH}}=-205 \mu \mathrm{~A}$ | 2.4 |  |  | V |
|  | Other Outputs | $\mathrm{V}_{\mathrm{OH} 1}$ | $\mathrm{IOH}=-100 \mu \mathrm{~A}$ | 2.4 |  |  | V |
| Output Low | Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |  |  | 0.4 | V |
| Input Capacitance | D0 to D7, EXHSYNC, EXVSYNC | $\mathrm{C}_{\text {IN }}$ | $\mathrm{V}_{1 \mathrm{~N}}=0 \mathrm{~V}$ |  |  | 12.5 | pF |
|  | Other Outputs | $\mathrm{C}_{1 \mathrm{~N}_{1}}$ | $\mathrm{f}=1.0 \mathrm{MHz}$ |  |  | 10.0 | pF |
| Ouput Capacitance |  | Cout |  |  |  | 10.0 | pF |
| Power Dissipation |  | $P_{\text {D }}$ | $\begin{aligned} & V_{C C}=V_{\text {max }} \\ & f=1.0 \mathrm{MHz} \end{aligned}$ |  | 10 | 30 | mW |

## AC Characteristics

Recommended operating conditions unless otherwise noted.

Value

| Parameter |  | Symbol | Value |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Conditions | Min. | Tур. | Max. |  |
|  | Clock Period |  | $\mathrm{t}_{\mathrm{CLK}}$ |  | 250 |  |  | ns |
|  | Clock High | $t_{\text {PWCH }}$ |  | 100 |  |  | ns |
|  | Clock Low | $\mathrm{t}_{\text {PWCL }}$ |  | 100 |  |  | ns |
|  | Clock Rise | $t_{\text {cr }}$ |  |  |  | 20 | ns |
|  | Clock Fall | $\mathrm{t}_{\mathrm{CF}}$ |  |  |  | 20 | ns |
|  | Memory Address Delay | $\mathrm{t}_{\text {MAD }}$ |  |  |  | 80 | ns |
| Controller | Raster Address Delay | $\mathrm{t}_{\text {RAD }}$ |  |  |  | 100 | ns |
|  | Display Timing Delay | $t_{\text {DTD }}$ |  |  |  | 120 | ns |
|  | Cursor Timing Delay | $\mathrm{t}_{\text {CDD }}$ |  |  |  | 120 | ns |
|  | Horizontal Synchronous Delay | $t_{\text {HSD }}$ |  |  |  | 100 | ns |
|  | Vertical Synchronous Delay | $\mathrm{t}_{\text {VSD }}$ |  |  |  | 120 | ns |
|  | Clock Stop | $\mathrm{t}_{\text {CLKST }}$ |  | 100 |  |  | ns |
|  | External Horizontal Synchronous Signal Width | $t_{\text {PWHS }}$ |  | 1000 |  |  | ns |
|  | External Horizontal Synchronous Rise | $t_{H R}$ |  |  |  | 20 | ns |
| External Synchro- | External Horizontal Synchronous Fall | $\mathrm{t}_{\mathrm{HF}}$ |  |  |  | 20 | ns |
| nization | External Vertical *1 <br> Synchronous Signal Width | tpwvs/ tpwvss | (2) | $\begin{aligned} & 12201 \\ & 1750 \\ & \hline \end{aligned}$ |  |  | ns |
|  | External Vertical Synchronous Rise | $t_{\text {VR }}$ |  |  |  | 20 | ns |
|  | External Vertical Synchronous Fall | $t_{V F}$ |  |  |  | 20 | ns |
|  | External Synchronous Setup (Master-slave mode) | tvss |  | 50 |  |  | ns |
|  | Light Pen Strobe Width | $\mathrm{t}_{\text {PWLP }}$ |  | 60 |  |  | ns |
| Light Pen | Light Pen Strobe | $\mathrm{t}_{\text {LPDR }}$ | (3) |  |  | 0 | ns |
|  | Maximum Period | $\mathrm{t}_{\text {LPDF }}$ |  |  |  | 70 | ns |
|  | Enable Period | $\mathrm{t}_{\mathrm{E}}$ |  | 0.5 |  |  | $\mu \mathrm{s}$ |
|  | Enable High | $\mathrm{t}_{\text {PWEH }}$ |  | 0.22 |  |  | $\mu \mathrm{s}$ |
|  | Enable Low | $\mathrm{t}_{\text {PWEL }}$ |  | 0.21 |  |  | $\mu \mathrm{s}$ |
|  | Enable Rise | $\mathrm{t}_{\text {ER }}$ |  |  |  | 20 | ns |
|  | Enable Fall | $t_{\text {EF }}$ | [(4) MB89321A |  |  | 20 | ns |
| Interface | Address Setup | $t_{\text {AS }}$ | only] | 40 |  |  | ns |
|  | Data Delay | $\mathrm{t}_{\text {DDR }}$ |  |  |  | 120 | ns |
|  | Data Access | $\mathrm{t}_{\text {ACC }}$ |  |  |  | 160 | ns |
|  | Address Hold | $\mathrm{t}_{\text {AH }}$ |  | 10 |  |  | ns |
|  | Data Hold | $\mathrm{t}_{\mathrm{H}}$ |  | 10 |  |  | ns |
|  | Data Setup | $t_{\text {DSW }}$ |  | 60 |  |  | ns |

## AC Characteristics

(Continued)


Note: *1. External vertical synchronous signal width $\mathrm{t}_{\mathrm{pWVs}}=1000 \mathrm{~ns}+\mathrm{t}_{\text {CLK }}$ (TV sync mode)
tpwVss $=1000 \mathrm{~ns}+3$ tcLK (Master slave mode)
*2. Rising delay time when light pen strobe input in non display time

## Clock

A TTL-level input from DC to 4.5 MHz character clock should be used. An example of the clock circuit is shown below.


A circuit example for horizontal 8 -dot character mode is as follows:


## Timing Diagrams

(1) CRT Controller

(2) External synchronization


## Timing Diagrams

(Continued)


When the light pen strobe is enabled, LPSTB goes high, $\mathrm{M}+2$ is loaded into the light pen register, $N$ into the light pen raster register, and the display status bit is set.
(4) CPU Interface 1 (MB89321A only)


## Timing Diagrams

 (Continued)(5) CPU Interface 2 (MB89322A only)

(6) IRQ Timing


Notes on Operation
(1) Screen Partition Timing


This example shows typical memory addresses and raster addresses of screens 1 and 2 during screen partitioning.
Nht: Total Number of Characters in Line (R0)
Nhd: Number of Characters Displayed in Line (R1)
Nr : Maximum Raster Address (R9)
Ns1: Start Address 1 (R12, R13)
NL2: Screen 2 Display Start Position (R18)
NS2: Start Address 2 (R19, R20)

## Notes on Operation <br> (Continued)



Notes on Operation
(Continued)

## (4) Horizontal Display Period

 Setting (TV Sync Mode)The horizontal display period is determined by the timing diagrams below:

(A) and (B) indicate points where EXVSYNC is detected.

EXVSYNC is normally detected at (B). However, when EXHSYNC is generated during the horizontal display period by an equivalent pulse, detection is at (A).
(A) and (B) require at least $1,000 \mathrm{~ns}+1$ clock cycle, during which period EXVSYNC must be maintained.
(5) Screen Partitioning

The display order of partitioned screens can be changed by programming the start position registers (R18, R21, and R24) for each partitioned screen, except screen 1, which is always displayed from line 0 on the screen. (See Figure A below.)

But, when the same values are programmed to the start position registers, the partitioned screens for those start position registers aren't displayed, even if those partitioned screens are enabled by P0 and P1 bits.

Figure A

| Line No. | Display Screen | Example of Register Setting |
| :---: | :---: | :---: |
| 0 |  | Screen 3 Start Position (R21) |
| 1 | Screen 1 | $\leq$ Screen 2 Start Position (R18) |
| 2 |  | $\leq$ Screen 4 Start Position (R24) |
| 3 |  |  |
| 4 | Screen 3 | - Screen 2 Start Position Reg. |
| 5 |  | $(\mathrm{R} 18)=5$ |
| 6 |  | - Screen 3 Start Position Reg. |
| 7 | Screen 2 | $(\mathrm{R} 21)=2$ |
| 8 |  | - Screen 4 Start Position Reg. |
| 9 |  | $($ R24 $)=8$ |
| 10 | Screen 4 |  |
| 11 |  |  |

## Notes on Operation

(Continued)
(6) Raster Interpolation

At present, two versions of MB89321A/89322A are provided: One has the raster interpolation function, and another has no raster interpolation function. On MB89321A/89322A without the raster interpolation function, " 0 " must always be written to RI bit of the control/status register (R31).

Figure $B$

| Line No. | Display Screen | Example of Register Setting |
| :---: | :---: | :---: |
| 0 | Screen 1 | Screen 2 Start Position (R18) |
| 1 |  | = Screen 3 Start Position (R21) |
| 2 |  | $\leq$ Screen 4 Start Position (R24) |
| 3 |  |  |
| 4 |  | - Screen 4 Start Position Reg. |
| 5 |  | $(\mathrm{R} 24)=8$ |
| 6 |  |  |
| 7 |  | - Screens 2 and 3 aren't |
| 8 |  | displayed because the start |
| 9 | Screen 4 | screens have the same value. |
| 10 |  | In the display areas for |
| 11 |  | Screens 2 and 3, Screen 1, |
|  |  | which is displayed above those screens, is displayed. |

## Package Dimensions

Dimensions in inches (millimeters)

## 40-Lead Plastic

Dual In-Line Package
(Case No.: DIP-40P-M01)

© 1985 FUJITSU LIMITED D40005S-1C

## FUJITSU

## DESCRIPTION

The Fujitsu MB89321B/MB89322B Programmable CRT Controllers are used to interface a CRT raster-scan display with a microcomputer system. The MB89321B is pin-for-pin compatible with the 6845 controller and is designed to interface with the 6800-series of microprocessors from Motorola. The MB89322B is designed to interface with the 8080 -series of microprocessors from Intel; because the Intel bus requires separate read/write lines, the MB89322 is not a direct replacement for 6845 .
Both devices refresh the CRT display by buffering information from main memory. Eighteen internal registers track the display position on the screen and provide a realtime presentation of the video data. The interface with most raster-scan CRT displays is simple and the hardware/software overhead is minimal.
Together, the MB89321A/MB89322A and MB89321B/MB89322B controllers provide design alternatives for the bus-interface requirements shown at the bottom of this page. The MB89321 and MB89322 can be ordered with or without enhancements. Non-enhanced versions (suffix B) contains all standard features of the 6845; enhanced versions (suffix A) provide all standard features of the 6845 plus smooth scroll, additional screen partitioning, independent scrolling of screen partitions, and other convenient features.

## FEATURES

- Programmable screen and character formats
- Cursor control display: Form, Position, and Blink
- Three selectable scan modes: Interlace, Non-interlace, and Interlace with Video
- 14-bit refresh memory address output: 16 K word refresh memory addressing capability
- 5-bit raster address output: Up to 32 rasters per character
- Light pen detection: Refresh memory address capture
- Flexible bus interface: 6800 compatible bus for MB89321B, 8080 compatible bus for MB89322B
- Up to 4 MHz clock rate
- Silicon gate CMOS process/TTL compatible I/O
- Single +5 V power supply/40-pin plastic DIP (Suffix P)

| Bus Interface | MB89321A | MB89322A | MB89321B | MB89322B | 6845 |
| :--- | :---: | :---: | :---: | :---: | :---: |
| 8080 Bus Interface <br> (Intel) |  | X |  | X |  |
| 6800 Bus Interface <br> (Motorola) | X |  | X |  | X |
| Enhanced (Note) | X | X |  |  |  |
| Non-Enhanced |  |  | X | X | X |

Note:
The MB89321A and MB89322A provide all features of the 6845; however, both devices require that Registers 30 and 31 be cleared during initialization. The clearing command is not required for the 6845 or the non-enhanced (MB89321B/MB89322B) devices.


40-Pin Plastic DIP (DIP-40P-M01)


[^36]
## FUJITSU

## HARD DISK CONTROLLER

## MB89341

## DESCRIPTION

The Fujitsu MB89341 Hard Disk Controller (HDC) interfaces with a host processor and a hard disk drive unit and provides data transfers between the two units in accordance with commands loaded from the host processor. The HDC is fabricated in CMOS and is housed in a 48-pin shrink DIP.

## FEATURES

- Two programmable modulation modes: MFM and NRZ.
- High speed data transfers -

MFM: Maximum of six megabits per second (typically 5 Mbps ).
NRZ: Maximum of 12 megabits per second (typically 10 Mbps ).

- Programmable step rate -

Fast: 1-to-8 $\mu \mathrm{s}$ in eight steps.
Slow: 0.5 -to- 4 ms in eight steps.

- Multi-sector read/write and multi-track read/write.
- On-chip 8-byte FIFO for timing control of data transfers.
- On-chip memory buffer with arbitration logic.
- On-chip ECC with 32-bit fire code.
- Supports 16 drives and 16 head selections.
- Interface compatibility with Seagate ST506/412 specification and ESDI specification.
- CPU interface: Parallel data loading to register array.
- Silicon-gate CMOS process.
- Single +5 V supply.

PIN CONFIGURATION


This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

## BLOCK DIAGRAM



# FLOPPY DISK FORMATTER/CONTROLLER (FDC) 

## DESCRIPTION

The Fujitsu MB8876A and MB8877A are one-chip Floppy Disk Formatter/Controllers (FDC) which are fabricated with N -channel E/D MOS technology. They can be applied to any single density floppy disk, double density floppy disk and mini floppy disk.
The IBM3740 format and the frequency modulation (FM) recording are used for the single density

## FEATURES

- Interface to 8-bit

Microprocessor
MB8876A: Negative-logic 8-bit Data Bus
MB8877A: Positive-logic 8-bit Data Bus

- IBM Compatible Sector Format
- Automatic Track Seeking and Verification
- Both Single and Double Density Formats
a) Single Density in IBM3740 Format and FM Recording
b) Double Density in IBM System-34 Format and MFM Recording
- Programmable Single Sector/ Multiple Sectors/Entire Track Read Operation
- Programmable Single Sectorl Multiple Sectors/Entire Track Write Operation
- Programmable Side Compare Function
- Programmable Sector Length
- Programmable Head Step Rate
- Applicable to Single Density, Double Density, and Mini Floppy Disks
storage, and the IBM System-34 format and the modified frequency modulation (MFM) recording are used for the double density storage.
The MB8867A and MB8877A interface with an 8 -bit parallel microprocessor to control data transfer and mechanical operation. They are packaged in a standard 40-pin dual in-line package.


## - Programmable Head

 Engage/Head Settle Time- Double Buffered Data I/O
- DMA Data Transfer Capability
- Write Precompensation Capability
- All TTL Compatible I/O
- Single +5V Power Supply
- N-Channel Silicon-gate E/D MOS Process
- MB8876A: Upward Compatible with
Western Digital FD1791-02
- MB8877A: Upward

Compatible with Western Digital FD1793-02

- Two Package Options
-40-pin Ceramic DIP (Suffix: -C)
-40-pin Plastic DIP (Suffix: -P)


PLASTIC DIP DIP-40P-M01

## PIN ASSIGNMENT



This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

[^37]
## MB8876A/MB8877A

## PIN DESCRIPTIONS

| Pin No. | Symbol | Pin Name | I/O | Description |
| :---: | :---: | :---: | :---: | :---: |
| 20 | $V_{S S}$ | Power Supply | 1 | Ground (GND) |
| 21 | $\mathrm{V}_{\mathrm{CC}}$ | wer Supply | 1 | +5V DC supply |
| 24 | CLK | Clock | 1 | 2-MHz fixed frequency clock signal (1-MHz for mini-floppy disk). |
| 19 | $\overline{\mathrm{MR}}$ | Master Reset | 1 | Signal for resetting the FDC. |
| 22 | TEST | Test | 1 | Signal for setting the FDC into a test mode. |
| 1,40 | NC | Non Connection | - | These pins are not used. |

## MPU INTERFACE PINS

| 37 | $\overline{\text { DDEN }}$ | Double Density | 1 | Signal for selectina a FDC operation mode: <br> When $\overline{\mathrm{DDEN}}=0$, the double density operation mode is selected. <br> When DDEN $=1$, the single density operation mode is selected. <br> This input must be fixed while the FDC is in busy state. |
| :---: | :---: | :---: | :---: | :---: |
| 3 | $\overline{\text { CS }}$ | Chip Select | 1 | Signal for controlling the DALs: When $\overline{\mathrm{CS}}=0$, the DALs are activated and data transfer between the FDC and the MPU is enabled. When $\overline{C S}=1$, the DALs are in high impedance state and data transfer is inhibited. (i.e., $\overline{R E}$ and $\overline{W E}$ are ignored.) |
| 4 | $\overline{\mathrm{RE}}$ | Read Enable | 1 | Strobe signal provided when data is read from internal registers: When $\overline{C S}=\overline{R E}=0$, data can be read from internal registers. |
| 2 | $\overline{W E}$ | Write Enable | 1 | Strobe signal provided when data is written into internal registers: When $\overline{C S}=\overline{W E}=0$, data can be written internal registers. |
| 5, 6 | $A_{0}, A_{1}$ | Register Select Line | 1 | Signal for addressing an internal register among Command Register (CR), Status Register (STR), Track Register (TR), Sector Register (SCR) and Data Register (DR): Refer to table of REGISTER SELECTION (p. 6). |
| 7~14 | $\begin{aligned} & \overline{\mathrm{DAL}}_{0} \sim \overline{\mathrm{DAL}}_{7} \\ & \mathrm{DAL}_{0} \sim \mathrm{DAL}_{7} \\ & \hline \end{aligned}$ | Data Access Line | I/O | 8-bit bidirectional bus for transferring 8-bit data between the FDC and the MPU. MB8876A: negative logic/MB8877A: positive logic. |
| 38 | DRQ | Data Request | 0 | Signal for informing the MPU of a DR status: Read operation: DRQ $=1$ shows the DR is filled with a 8 -bit data from a disk, and the FDC is requesting for the MPU to read the data. Write operation: $\mathrm{DRQ}=1$ shows the DR is empty, and the FDC is requesting for the MPU to write the next data into the DR. |
| 39 | IRQ | Interrupt Request | 0 | Interrupt signal to the MPU: IRQ is set when a Command is completed or the TYPE IV Command is executed. IRQ is reset when the next Command is written or the STR is read. |

## FLOPPY DISK INTERFACE PINS Disk Head Control Signa!

| 15 | STEP | Step Move | 0 | Step pulse signal for moving a disk head. |
| :---: | :---: | :--- | :---: | :--- |
| 16 | DIRC | Direction | 0 | Signal for indicating a direction of disk head moving to the FDD: <br> DIRC = 0 shows the head moves toward outside. DIRC $=1$ shows <br> the head moves toward inside. |
| 28 | HLD | Head Load | 0Signal for loading a disk head: When HLD $=1$, the head is <br> engaged on the disk. When HLD $=0$, the head is released from <br> the disk. |  |

Disk Head Control Signal (Continued)

| Pin No. | Symbol | Pin Name | 1/0 | Description |
| :---: | :---: | :---: | :---: | :---: |
| 23 | HLT | Head Load Timing | 1 | Signal for informing a disk head status: HLT $=1$ shows a disk head is in an enagaged state. HLT is set when a disk head has been settled or a head settle time pre-determined by one shot circuit has elapsed after HLD $=1$. |
| 34 | TROO | Track 00 | 1 | Signal for informing whether a disk head is positioned on Track No. 00 or not: $\overline{\text { TROO }}=0$ shows Track No. 00 is detected during track seaking operation. |
| 32 | READY | Ready | 1 | Signal for informing the FDC of a disk drive status: READY $=1$ shows the disk drive is ready for operation, and only when READY $=1$, read/write operation for disk can be executed. READY $=0$ shows the disk drive is not ready, and neither read/write operation cannot be executed. However, seek operation is executed regardless of this signal. |
| 35 | $\overline{\mathrm{P}}$ | Index Pulse | 1 | Signal for informing the FDC of an index hole of disk being detected in the FDD. |

## Disk Read Operation Signal

| 25 | RG | Read Gate | O | Signal for informing synchronization between RCLK and <br> RAWREAD to an external VFO circuit: RG $=1$ 1 show the FDC has <br> found out a SYNC byte during disk reading operation. |
| :---: | :---: | :--- | :---: | :--- |
| 26 | RCLK | Read Clock | I | A data window signal which is generated in an external VFO <br> circuit out of Read Data. |
| 27 | RAWREAD | Raw Read | I | A raw read data signal transferred from the FDD. |

## Disk Write Operation Signal

| 30 | WG | Write Gate | O | Signal for indicating data is being written into a disk. <br> 17 EARLY |
| :---: | :---: | :--- | :---: | :--- |
| Early Shift | O | Signal for indicating early pre-compensation of data write timing <br> to a disk: EARLY = 1 shows a serial data to be transmitted via <br> the WD pin to a disk must be shifted earlier. |  |  |
| 18 | LATE | Late Shift | O | Signal for indicating later pre-compensation of data write timing <br> to a disk: LATE = 1 shows a serial data to be transmitted via the <br> WD pin to a disk must be shifted later. |
| 31 | WD | Write Data | O | A write data signal transferred to the FDD. |
| 29 | TG43 | Track Greater <br> Than 43 | O | Signal for indicating a head position of a disk: TG43 = 1 shows <br> the head is located on any Track No. 44 thru 76. TG43 = 0 shows <br> the head is located on any Track No. 0 thru 43. |
| 33 | $\overline{\text { WF/VFOE }}$ | Write Fault/Variable <br> Frequency Oscil- <br> lator Enable | I/O | Input signal for informing a fault is detected during write operation <br> for a disk (during WG = 1). Output signal for informing the FDC <br> is reading a disk (during WG = 0). |
| 34 | $\overline{\text { WPRT }}$ | Write Protect | 1 | Signal for inhibiting write operation for disk. |

## MB8876A/MB8877A

## REGISTER SELECTION

| Chip Select | Address |  | Selected Register |  | Data Access Line Status |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CS}}$ | $A_{1}$ | $A_{0}$ | Read Mode ( $\overline{\mathrm{RE}}=0$ ) | Write Mode ( $\overline{W E}=0$ ) | $\begin{aligned} & \overline{\overline{\mathrm{DAL}}_{7}} \sim \overline{\mathrm{DAL}}_{0} \\ & \overline{\mathrm{DAL}} \sim \overline{\mathrm{DAL}_{0}} \end{aligned}$ |
| 1 | * | * | Deselected | Deselected | High Impedance |
| 0 | 0 | 0 | Status Register (STR) | Command Register (CR) | Enabled |
| 0 | 0 | 1 | Track Register (TR) | Track Register (TR) | Enabled |
| 0 | 1 | 0 | Sector Register (SCR) | Sector Register (SCR) | Enabled |
| 0 | 1 | 1 | Data Register (DR) | Data Register (DR) | Enabled |

*: Don't care

## MB8876A/MB8877A BLOCK DIAGRAM



* MB 8876A: Negative Logic
** MB 8877A: Positive Logic


## FUNCTIONAL BLOCK DESCRIPTION

## INTERNAL REGISTERS

- Command Register (CR)

An 8 -bit write-only register, holds the command which is being executed. This register should not be loaded when the BUSY flag is set (BUSY =1) unless the execution of the current command is to be overridden, using the Force Interrupt command.

- Status Register (STR)

An 8-bit read-only register, holds the device status information. The contents of STR are automatically updated according to the status of the executing Command. After the STR is read, the IRQ output is usually reset ( $\mathrm{IRQ}=0$ ) except for the Type IV Command.

- Data Register (DR)

An 8-bit read/write used as a holding register during Disk Read and Write operations. In Disk Read operations, the serial data assembled in the Data Shift Register is transferred to the DR, where it is made available to the data bus. In Disk Write operations, parallel data from the data bus is written into the DR where it is transferred to Data Shift Register. In a Seek Command, the data written into the DR holds the address of the desired Track address.

- Data Shift Register (DSR)

An 8-bit shift register which cannot be accessed directly through the data bus. The DSR assembles serial data from the RAW READ input during Read operations and transfers the data to the DR. In Write operations, the DSR receives data from the DR and serially transfers it out through the WRITE DATA output.

- Track Register (TR)

An 8-bit read/write register, holds the track number of the current disk head position for Restore, Seek, Step, Step-In and Step-Out Commands (i.e. TYPE 1 Commands), and is updated during the Command execution. The TR contents are compared with the track number (recorded in the disk's ID field) dur-
ing Read, Write, and Verify operations. The TR should not be written to when the device is busy (BUSY = 1).

## - Sector Register (SCR)

An 8 -bit read/write register, holds the address of the desired sector number. The sector number is written into the SCR prior to the Read and Write Data Command execution. It should not be written to during busy (BUSY = 1). Executing the Read Address Command causes the SCR to be loaded with the track number from the ID field.

## OTHER FUNCTIONAL BLOCKS

- Cycle Redundancy Check (CRC) Logic

This logic is used for checking or generating the 16-bit Cycle Redundancy Check that is in the ID and Data fields used for error detection. The polynominal is: $\mathrm{G}(\mathrm{X})=\mathrm{X} 16+\mathrm{X} 12+\mathrm{X} 5+1$.

- Arithmetic/Logic Unit (ALU)

The ALU is a serial comparator, incrementer, and decrementer used for register comparisons and modifications with the disk record ID fields.

## - Address Mark (AM) Detection Circuit

A circuit to detect specific bit pattern data in the serial data from a disk (i.e. Index Mark, ID Address Mark, Data Address Mark).

## - Data Modulator

A circuit to modulate data to be written onto a disk in the specific recording format: Single density recording format: Frequency Modulation (FM) Double density recording format: Modified Frequency Modulation (MFM)

- Programmable Logic Array (PLA) for Commands A micro-program to generate control signals (Commands) which control the FDC operation: The size of micro-program is approximately $232 \times 19$ bits.


## MB8876A/MB8877A

## BIT STRUCTURES OF COMIMANDS

MB8876A/MB8877A

|  |  | BITS |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| TYPE | COMMAND | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| I | Restore | 0 | 0 | 0 | 0 | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| I | Seek | 0 | 0 | 0 | 1 | h | V | $\mathrm{r}_{1}$ | r |
| I | Step | 0 | 0 | 1 | u | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| I | Step In | 0 | 1 | 0 | u | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| I | Step Out | 0 | 1 | 1 | u | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| II | Read Sector | 1 | 0 | 0 | m | S | E | C | 0 |
| II | Write Sector | 1 | 0 | 1 | m | S | E | C | a |
| III | Read Address | 1 | 1 | 0 | 0 | 0 | E | 0 | 0 |
| IIII | Read Track | 1 | 1 | 1 | 0 | 0 | E | 0 | 0 |
| III | Write Track | 1 | 1 | 1 | 1 | 0 | E | 0 | 0 |
| IV | Force Interrupt | 1 | 1 | 0 | 1 | $\mathrm{I}_{3}$ | $\mathrm{I}_{2}$ | $\mathrm{I}_{1}$ | $\mathrm{I}_{0}$ |

NOTE: Bits shown in TRUE form.
TABLE 1. STEPPING RATES


## TYPE I COMMANDS

h = Head Load Flag (Bit 3)
$h=1$, Load head at beginning
$h=0$, Unload head at beginning
$\mathbf{V}=$ Verify flag (Bit 2)
$V=1$, Verify on destination track
$\mathrm{V}=0$, No verify
$\mathrm{r}_{1} \mathrm{r}_{0}=$ Stepping motor rate (Bits $\mathbf{1 . 0}$ )
Refer to Table 1 for rate summary
$u=$ Update flag (Bit 4)
$u=1$, Update Track register
$u=0$, No update

| TYPE II \& III COMMANDS |
| :--- |
| $m=$ Multiple Record flag (Bit 4) |
| $m=0$, Single Record |
| $m=1$, Multiple Records |
| $a_{0} \mathbf{f}=$ Data Address Mark (Bit 0 ) |
| $a_{0}=0, F B$ (Data Mark) |
| $a_{0}=1$, F8 (Deleted Data Mark) |
| $E=15 \mathrm{~ms}$ Delay (2MHz) |
| $E=1,15 \mathrm{~ms}$ delay |
| $E=0$, no 15 ms delay |
| $S=$ Side Select Flag |
| $S=0$, Compare for Side 0 |
| $S=1$, Compare for Side 1 |
| $C=$ Side Compare Flag |
| $C=0$, diable side select compare |
| $C=1$, enable side select compare |


| TYPE IV COMMAND |
| :--- |
| $\mathbf{I i}=$ Interrupt Condition flags (Bits 3-0) |
| $10=1$, Not-Ready to Ready Transition |
| $11=1$, Ready to No-Ready Transition |
| $12=1$, Index Pulse |
| $13=1$, Immediate Interrupt |
| $13-I_{0}=0$, Terminate with no Interrupt |

## STATUS REGISTER SUMMARY

| Command | Status Bit |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| All Type I | Not Ready | Write Protect | Head Loaded | Seek Error | CRC Error | Track 0 | Index | Busy |
| Read Sector | Not Ready | 0 | Record Type | Rec not Found | CRC Error | Lost Data | DRQ | Busy |
| Write Sector | Not Ready | Write Protect | Write Fault | Rec not Found | CRC Error | Lost Data | DRQ | Busy |
| Read Address | Not Ready | 0 | 0 | Rec not Found | CRC Error | Lost Data | DRQ | Busy |
| Read Track | Not Ready | 0 | 0 | 0 | 0 | Lost Data | DRQ | Busy |
| Write Track | Not Ready | Write Protect | Write Fault | 0 | 0 | Lost Data | DRQ | Busy |

## STATUS DESCRIPTION FOR TYPE I COMMANDS

| Bit | Name | Meaning |
| :--- | :--- | :--- |
| S7 | Not Ready | This bit when set indicates the drive is not ready. When reset it indicates that the drive is ready. <br> This bit is an inverted copy of the Ready input and logically 'ored' with MR. |
| S6 | Protected | When set, indicates Write Protect is activated. This bit is an inverted copy of WRPT input. |
| S5 | Head Loaded | When set, it indicates the head is loaded and engaged. This bit is a logical "and" of HLD and HLT <br> signals. |
| S4 | Seek Error | When set, the desired track was not verified. This bit is reset to 0 when updated. |
| S3 | CRC Error | CRC encountered in ID filed. |
| S2 | Track 00 | When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted copy of the <br> TR00 input. |
| S1 | Index | When set, indicates index mark detected from drive. This bit is an inverted copy of the IP input. |
| S0 | Busy | When set command is in progress. When reset no command is in progress. |

## STATUS DESCRIPTION FOR TYPE II AND III COMMANDS

| Bit | Name | Meaning |
| :--- | :--- | :--- |
| S7 | Not Ready | This bit when set indicates the drive is not ready. When reset, it indicates that the drive is ready. <br> This bit is an inverted copy of the Ready input and 'ored' with MR. The Type II and III Commands <br> will not execute unless the drive is ready. |
| S6 | Write Protect | On Read Record: Not Used. On Read Track: Not Used. On any Write: It indicates a Write Protect. <br> This bit is reset when updated. |
| S5 | Record Typel <br> Write Fault | On Read Record: It indicates the record-type code from data field address mark. 1 = Deleted Data <br> Mark. 0 = Data Mark. On any Write: It indicates a Write Fault. This bit is reset when updated. |
| S4 | Record Not <br> Found (RNF) | When set, it indicates that the desired track, sector, or side were not found. This bit is reset when <br> updated. |
| S3 | CRC Error | If S4 is set, an error is found in one or more ID fields; otherwise it indicates error in data field. <br> This bit is reset when updated. |
| S2 | Lost Data | When set, it indicates the computer did not respond to DRQ in one byte time. This bit is reset to <br> zero when updated. |
| S1 | Data Request | This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Read Operation or <br> the DR is empty on a Write operation. This bit is reset to zero when updated. |
| S0 | Busy | When set, command is under execution. When reset, no command is under execution. |

## MB8876A/MB8877A

TRACK FORMAT


TP


NOTE: *: Shows to have missing clock.
**: Shows the ID field
${ }^{* * *}$ : Shows the cyclic Redundancy check polynomial $G(X)=X^{\circ}+X^{5}+X^{12}+X^{16}$
***: See the most right column for its byte numbers and data.

## SECTOR FORMAT

| SECTOR |  |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{gathered} \text { (FM) } \\ \text { or } \\ \text { (MFM) } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ID FIELD |  |  |  |  |  |  |  |  | DATA FIELD |  |  |  |  |  |  |
| SYC | ID AM | TRACK <br> NUMBER | SIDE NUMBER | SECTOR NUMBER | SECTOR LENGTH | CRC 1 | CRC 2 | GAP 2 | SYNC | DATA AM | DATA | CRC 1 | CRC 2 | GAP 3 |  |
| $\begin{gathered} 6 \\ \text { bytes } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 11 \\ \text { bytes } \end{gathered}$ | $\begin{gathered} 6 \\ \text { bytes } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | * | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} \hline 27 / 42 / 58 \\ \text { bytes } \end{gathered}$ |  |
| $\begin{gathered} 12 \\ \text { bytes } \end{gathered}$ | $\begin{gathered} 4 \\ \text { bytes } \end{gathered}$ | $\stackrel{1}{\text { byte }}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\begin{gathered} 22 \\ \text { bytes } \end{gathered}$ | $\begin{gathered} 12 \\ \text { bytes } \end{gathered}$ | $\begin{gathered} 4 \\ \text { byte } \end{gathered}$ | * | $\begin{gathered} 1 \\ \text { byte } \end{gathered}$ | $\stackrel{1}{\text { byte }}$ | 54/84/116 bytes |  |
|  |  | 4 |  |  |  |  | (00) H <br> (01) H <br> (02) H <br> (03) H <br> (01) H <br> (01) H <br> (01) H <br> (00) H <br> (01)H <br> $(00) \mathrm{H}$ | for 128 for 256 412 Byte for 1024 <br> (1A) H fo (0F)H for $(08) \mathrm{H}$ for or Side 0 or Side 1 <br> (4A) H fo | Bytes/Se <br> Bytes/Se <br> s/Secto <br> Bytes/S <br> 26 Sec <br> 15 Sect <br> 8 Secto <br> of single <br> of double <br> Track | or data tor data data ctor dat <br> r/Track <br> r/Track Track f <br> ide of d side dis <br> thru Tra | ormat format rmat <br> uble-sid <br> k 74** | disk |  |  |  |

NOTE *: Byte number of this column is defined in the SECTOR LENGTH column.
**: "H" after parentheses show that the parenthesized figures are hexa-decimal.
**: Track 75 and 76 are usually used for correction.
MB8876A/MB8877A TYPICAL SYSTEM CONSTRUCTION


## MB8876A/MB8877A

## IBM 3740 Format

This single-density (FM) format utilizes 128 bytes/ sector. The bytes to be generated by the system MPU for use in the execution of the Write Track command are shown below.


Notes: 1. This pattern must be written 26 times per track.
2. Continue writing Hex FF until FDC completes sequence and generates INTRQ interrupt.

IBM System 34 Format
This double-density (MFM) format utilizes 256 bytes/ sector. The bytes to be generated by the system MPU for use in the execution of the Write Track command are shown below.


Notes: 1. This pattern must be written 26 times per track.
2. Continue writing Hex 4 E until FDC completes sequence and generates INTRQ interrupt.

## ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Rating | Unit |
| :--- | :---: | :---: | :---: |
| Voltage on any pin | $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{IN}}, \mathrm{V}_{\mathrm{OUT}}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ to $\mathrm{V}_{\mathrm{SS}}+7.0$ | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\mathrm{Stg}}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

Note: Permanent device damage may occur if Absolute Maximum Ratings are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Vaiue |  |  | Unit | Operating Temperature |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.75 | 5.00 | 5.25 | V | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
|  | $\mathrm{V}_{\text {SS }}$ | - | 0 | - |  |  |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | - | 0.8 | V |  |

## DC CHARACTERISTICS

(Recommended Operating Conditions unless otherwise noted.)

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| Output High Voltage ( $\mathrm{l}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ ) | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | - | V |
| Output Low Voltage ( $\mathrm{l} \mathrm{OL}=1.8 \mathrm{~mA}$ ) | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.4 | V |
| Three-State (Off-State) Input Current ( $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ to 2.4) | ${ }^{\text {ITSI }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Input Leakage Current (See Note 1) | IIN1 | - | - | 2.5 | $\mu \mathrm{A}$ |
| Input Leakage Current (See Note 2) | IIN2 | - | - | 100 | $\mu \mathrm{A}$ |
| Output Leakage Current for Off-State ( $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ ) | ILOH | - | - | 10 | $\mu \mathrm{A}$ |
| Power Consumption | $P_{D}$ | - | - | 350 | mW |

Note1) Except for HLT, $\overline{T E S T}, \overline{W F}, \overline{W P R T}$, and $\overline{\text { DDEN. }}$ (VIN $=0$ to 5.25 V )
2) For HLT, TEST, $\overline{\mathrm{WF}}, \overline{\mathrm{WPRT}}$, and $\overline{\mathrm{DDEN}}$. $\left(\mathrm{V}_{\mathrm{IN}}=0\right.$ to 5.25 V$)$

## MB8876A/MB8877A

## AC CHARACTERISTICS

(Recommended Operating Conditions unless otherwise noted.)

## MPU Read Timing (From FDC)

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| Address Setup Time | $\mathrm{t}_{\text {SET }}$ | 50 | - | - | ns |
| Address Hold Time | $\mathrm{t}_{\mathrm{HLD}}$ | 10 | - | - | ns |
| $\overline{R E}$ Pulse Width | $t_{\text {RE }}$ | 280 | - | - | ns |
| DRQ Reset Time | $t_{\text {DRR }}$ | - | - | 250 | ns |
| IRQ Reset Time | $\mathrm{I}_{\text {IRR }}$ | - | - | 500 | ns |
| Data Delay Time ( $\mathrm{C}_{\mathrm{L}}=25 \mathrm{pF}$ ) | t ${ }_{\text {DACC }}$ | - | - | 250 | ns |
| Data Hold Time ( $\mathrm{C}_{L}=25 \mathrm{pF}$ ) | ${ }^{\text {D }}$ DOH | 50 | - | 150 | ns |
| DRQ Service Time (RCLK Cycle $=2 \mu \mathrm{~S}$ ) | tseVr | - | - | 13.5* | $\mu \mathrm{s}$ |

*: These values are doubled when CLK $=1 \mathrm{MHz}$.

## READ TIMING



MPU Write Timing (To FDC)

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| Address Setup Time | $\mathrm{t}_{\text {SET }}$ | 50 | - | - | ns |
| Address Hold Time | $\mathrm{t}_{\text {HLD }}$ | 10 | - | - | ns |
| $\overline{\text { WE Pulse Width }}$ | ${ }^{\text {t WE }}$ | 200 | - | - | ns |
| DRQ Reset Time | t DRR | - | - | 250 | ns |
| INTRQ Reset Time | IIRR | - | - | 500 | ns |
| Data Setup Time | $\mathrm{t}_{\text {DS }}$ | 250 | - | - | ns |
| Data Hold Time | ${ }_{\text {t }}^{\text {DH }}$ | 0 | - | - | ns |
| DRQ Service Time ( $\overline{\mathrm{DDEN}}=$ " L ") | tsevW | - | - | 11.5* | $\mu \mathrm{S}$ |

*: These values are doubled when CLK $=1 \mathrm{MHz}$.

## WRITE TIMING


*: These values are doubled when CLK $=1 \mathrm{MHz}$.

MB8876A/MB8877A

FDC Read Data Timing (From Disk)

| Parameter |  | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| RAWREAD Pulse Width |  |  | $t_{\text {PW }}$ | 100 | - | 250* | ns |
| Clock Setup Time |  | to | 40 | - | - | ns |
| Clock Hold Time for MFM |  | ${ }^{\text {t }}$ CD | 40 | - | - | ns |
| Clock Hold Time for FM |  | $\mathrm{t}_{\mathrm{CS}}$ | 40 | - | - | ns |
| RAWREAD Cycle Time | MFM | ${ }^{\text {t }} \mathrm{BC}$ | - | $2^{*}, 3^{*}$ or $4^{*}$ | - | $\mu \mathrm{S}$ |
|  | FM |  | - | $2^{*}$ or $4^{*}$ | - | $\mu \mathrm{S}$ |
| RCLK High Pulse Width | MFM | $t_{\text {A }}$ | 0.8 | 1* | 20 | $\mu \mathrm{S}$ |
|  | FM |  | 0.8 | 2* | 20 | $\mu \mathrm{S}$ |
| RCLK Low Pulse Width | MFM | $t_{B}$ | 0.8 | 1* | 20 | $\mu \mathrm{S}$ |
|  | FM |  | 0.8 | 2* | 20 | $\mu \mathrm{S}$ |
| RCLK Cycle Time | MFM | ${ }^{t} \mathrm{C}$ | - | 2* | - | $\mu \mathrm{S}$ |
|  | FM |  | - | 4* | - | $\mu \mathrm{S}$ |

*: These values are double when CLK $=1 \mathrm{MHz}$.

READ DATA TIMING


FDC Write Data Timing (To Disk)

| Parameter | Symbol | Conditions |  | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max |  |
| Write Data Pulse Width | ${ }^{\text {tw }}$ W** | CLK $=2 \mathrm{MHz}$ | FM | 450 | 500 | 550 | ns |
|  |  |  | MFM | 150 | 200 | 250 |  |
| Write Gate To Write Data | ${ }^{\text {t }}$ WG** | $\mathrm{CLK}=2 \mathrm{MHz}$ | FM | - | 2 | - | $\mu \mathrm{S}$ |
|  |  |  | MFM | - | 1 | - |  |
| Write Gate off from WD | ${ }^{\prime}$ WF** | CLK $=2 \mathrm{MHz}$ | FM | - | 2 | - | $\mu \mathrm{S}$ |
|  |  |  | MFM | 1 | - | 2 |  |
| Early (Late) to Write Data | $\mathrm{t}_{5}$ | CLK $=2 \mathrm{MHz}$ | MFM | 125 | - | - | ns |
| Early (Late) from Write Data | $t_{H}$ | CLK $=2 \mathrm{MHz}$ | MFM | $-50 *$ | - | - | ns |
| WD Valid to CLK | ${ }^{t} 1$ | CLK $=1 \mathrm{MHz}$ | MFM | 200 | - | - | ns |
|  |  | CLK $=2 \mathrm{MHz}$ | MFM | 30 | - | - |  |
| WD Valid after CLK | ${ }^{\text {t }}$ 2 | CLK $=1 \mathrm{MHz}$ | MFM | 50 | - | - | ns |
|  |  | $\mathrm{CLK}=2 \mathrm{MHz}$ | MFM | 50 | - | - |  |

*: This value, $-50 \mathrm{~ns}(\mathrm{~min})$ indicated that Early (Late) signal changes $50 \mathrm{~ns}(\mathrm{~min})$ before WD falls down in worst case. See DISK DATA OUTPUT TIMING.
**: All times are doubled when CLK $=1 \mathrm{MHz}$.

## WRITE DATA TIMING



## MB8876A/MB8877A

## OTHER TIMINGS

| Parameter |  | Symbol |  | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| CLK Low Pulse Width |  |  | $\mathrm{t}_{\mathrm{CD} 1}$ | 230 | - | 20000 | ns |
| CLK High Pulse Width |  | ${ }^{\text {t CD2 }}$ | 200 | - | 20000 | ns |
| STEP Pulse Width | MFM | ${ }^{\text {tSTP }}$ | 2* | - | - | $\mu \mathrm{S}$ |
|  | FM |  | 4* | - | - | $\mu \mathrm{S}$ |
| DIRC Setup Time |  | ${ }_{\text {t IIR }}$ | 12* | - | - | $\mu \mathrm{S}$ |
| $\overline{\text { MR Pulse Width** }}$ |  | $\mathrm{t}_{\mathrm{MR}}$ | 50* | - | - | $\mu \mathrm{S}$ |
| $\overline{\text { IP Pulse Width }}$ |  | $t_{\text {IP }}$ | 10* | - | - | $\mu \mathrm{S}$ |
| $\overline{\text { WF Pulse Width }}$ |  | twF | 10* | - | - | $\mu \mathrm{S}$ |
| CLK Cycle Time |  | ${ }_{\text {t }}^{\text {CYC }}$ | - | 0.5* | - | $\mu \mathrm{S}$ |

*: These Values are doubled when CLK $=1 \mathrm{MHz}$.
**: During Master Reset, CLK of more than 10 cycles are required.

## OTHER TIMINGS



CLK


PACKAGE DIMENSIONS Dimensions in inches (millimeters)
40-LEAD CERAMIC (METAL SEAL) DUAL IN-LINE PACKAGE (Case No.: DIP-40C-A01)

© 1986 FUJITSU LIMITED D40006S-1C

## 40-LEAD PLASTIC DUAL IN-LINE PACKAGE

 (Case No.: DIP-40P-M01)

Advanced Products

The Fujitsu MB89311 is a floppy disk controller/formatter (FDC) designed as an enhanced version of the conventional MB8877A.

The MB89311 is designed based on the MB8877A architecture. Some inconveniences of the MB8877A are eliminated on the MB89311, and several new commands are added. It can support micro- ( $3^{\prime \prime}$ or $3.5^{\prime \prime}$ double-density), mini- (5.25" double-density), and standard ( $8^{\prime \prime}$ single- or double-density), floppy disk drives. When combined with the MB4107 variable frequency oscillator (VFO), an economical floppy disk drive interface can be created with a minimum of parts.

The MB89311 is fabricated by the silicon-gate CMOS process, and packaged in a 28 -pin plastic DIP. It has TTL compatible inputs/outputs. Operation is with a single +5 V power supply with low power consumption.

Single +5 V power supply

- TTL compatible I/O
- IBM \& ISO compatible disk formats
- Track seeking with automatic verification


## Enhancements

- Silicon-gate CMOS process
- 28-pin plastic DIP (Suffix -P)
- Built-in programmable write precompensation
(125ns/250ns for all tracks at CLK $=8 \mathrm{MHz}, 250 \mathrm{~ns} / 500 \mathrm{~ns}$ at CLK $=4 \mathrm{MHz}$ )
- For lost data error, abnormal termination after sector read or write completion
- Extended mode commands: Read-after-seek, write-afterseek, delay, and format commands are added.
- Multiple-sector read/write operation
- Track read/write/initialize operation
- Program/DMA data transfer
- Single density/double density
- No restrictions on the RCLK frequency in gap between ID and data fields
- Step rate: $\mathbf{1 m s}$ to $\mathbf{3 0 m s}$, Settling time: 15 ms to $\mathbf{6 0 m s}$
- Record length: 128, 256, 512, 1024, 2048, 4096, and 8192 bytes/sector


Logic Symbol and Pin Assignment


Block Diagram


[^38]
## Pin Descriptions

|  | The MB89311 FDC has two <br> interfaces: One is the <br> processorinterface; MR, <br> and A1 \& A0 inputs, D7-D0 <br>  | IRQ outputs which are used <br> for the processor to control <br> the FDC. The other is the <br> floppy disk drive (FDD) <br> interface; STEP, DIREC/RG, |
| :--- | :--- | :--- |
| Power Supply \& Clock |  |  |

## Register Set

The MB89311 FDC contains the following five registers to execute commands and indicate status:

- Command register (CR)
- Status register (STR)
- Track register (TR)
- Sector register (SR)
- Data register (DR)

These registers are addressed by register select lines A1 and AO under RE and WE control.

## Command Words

The FDC's operations are defined by commands, that

## Register Selection

A1 AO Read Mode ( $\overline{\operatorname{RE}}=0$ ) Write Mode ( $\overline{\mathrm{WE}}=0$ )

| 0 | 0 | Status register | Command register |
| :--- | :--- | :--- | :--- |
| 0 | 1 | Track register | Track register |
| 1 | 0 | Sector register | Sector register |
| 1 | 1 | Data register | Data register |

are divided into four groups: Types I, II, III, and IV. Each group contains one to five command(s). Each command has flags that define detailed operation of the command.

The FDC has two command modes, the 8877 mode (which
emulates the MB8877 command set) and the extended mode (in which additional commands can be used). Either of these two modes can be selected by the assign command.

Command Summary (1): 8877 Mode Command Set

| Type | Name | Code |  |  |  |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MSB |  |  |  |  | LSB |  |  |  |
|  | Restore | 0 | 0 | 0 | 0 | X | V |  | 1 r 0 | Moves head to track 0. |
|  | Seek | 0 | 0 | 0 | 1 | X | V |  | 1 ro | Moves head to a desired track. |
| 1 | Step | 0 | 0 | 1 | u | X | V |  | 1 ro | Moves head one track. |
|  | Step-in | 0 | 1 | 0 | u | X | V |  | 1 ro | Moves head one track to inside. |
|  | Step-out | 0 | 1 | 1 | u | X | V |  | 1 rO | Moves head one track to outside. |
| II | Read data | 1 | 0 | 0 | m | S | E | C | L | Reads data (data field) from disk. |
| 1 | Write data | 1 | 0 | 1 | m | S | E |  | a0 | Writes data (data field) to disk. |
|  | Read address | 1 | 1 | 0 | 0 | 0 | E | 0 | 0 | Reads ID field from disk. |
| III | Read track | 1 | 1 | 1 | 0 | 0 | E | 0 | 0 | Reads all data from one track. |
|  | Write track | 1 | 1 | 1 | 1 | 0 | E | 0 | 0 | Writes all data to one track. |
|  | Assign parameter | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | Selects operation timing. |
| IV | Assign mode | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | Selects operation mode. |
|  | Force interrupt | 1 | 1 | 0 | 1 | 13 | 12 |  | 110 | Generates interrupt (IRQ). |

## Functional Description (Continued)

| Comm <br> Type | Name | Code |  |  |  |  |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MSB |  |  |  | LSB |  |  |  |  |
|  | Restore | 0 | 0 | 0 | 0 | 0 | V | 0 | 0 | Moves head to track 0. |
|  | Seek | 0 | 0 | 0 | 1 | 0 | V | 0 | 0 | Moves head to a desired track. |
| 1 | Step | 0 | 0 | 1 | u | 0 | V | 0 | 0 | Moves head one track. |
|  | Step-in | 0 | 0 | 1 | u | 0 | V | 0 | 1 | Moves head one track to inside. |
|  | Step-out | 0 | 0 | 1 | u | 0 | V | 1 | 0 | Moves head one track to outside. |
|  | Read-after-seek | 0 | 1 | 0 | 0 | S | 1 | C | L | Reads one sector data after seek. |
| 11 | Write-after-seek | 0 | 1 | 1 | 0 | S | 1 | C | a0 | Writes one sector data after seek. |
|  | Read data | 1 | 0 | 0 | m | S | E | C | L | Reads data (data field) from disk. |
|  | Write data | 1 | 0 | 1 | m | S | E | C | a0 | Writes data (data field) to disk. |
|  | Read address | 1 | 1 | 0 | 0 | 0 | E | 0 | 0 | Reads ID field from disk. |
|  | Read track | 1 | 1 | 1 | 0 | 0 | E | 0 | 0 | Reads all data from one track. |
|  | Write track | 1 | 1 | 1 | 1 | 0 | E | 0 | 0 | Writes all data to one track. |
|  | Format | 1 | 1 | 1 | 1 | 0 | E | 0 | 1 | Formats disk. |
|  | Delay | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | Generates interrupt after a set time. |
|  | Assign parameter | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | Selects operation timing. |
| IV | Assign mode | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | Selects operation mode. |
|  | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Resets FDC. |
|  | Force interrupt | 1 | 1 | 0 | 1 | 13 | 12 | 11 | 10 | Generates interrupt (IRQ). |

Flag Summary

| Type | Symbol | Function |
| :--- | :--- | :--- |
|  | $\frac{\mathrm{u}}{}$ | Update of track register |
| I | V | Verify at destination track |
| r1, r0 | Step rate of STEP pulse |  |
| II | $\frac{\mathrm{m}}{\mathrm{S}}$ | Multiple sectors |
|  | a 0 | Side number |
| III | C | Data address mark |
| IV | Side compare |  |

## Status Words

Status words, which are automatically held in the status register, show the status of the executing command, executed command, and conditions of the FDD. The system processor can monitor the FDC operations
and FDD conditions, reading the status register.

When the FDC receives a command, the status register is automatically preset at the
start of the command execution. Each status bit is internally updated (set or reset) during the command execution, and the status word is established at the completion of the command.

| Status Word Summary |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Notes: Rec. $=$ Record, N/F = Not Found
D/M N/F = Data Mark Not Found. This status bit is valid in extended mode only. In 8877 mode, this bit is " 0 ".

Functional Description
(Continued)

Status Bit Function Summary

| Command | Status | Status <br> Bit | Function |
| :---: | :---: | :---: | :---: |
| Type 1 | Not Ready | STR7 | 1 = FDD is not ready: Not Ready = READY + MR. |
|  | Write Protect | STR6 | $1=$ Write operation is inhibited: Write Protect = WPRT. |
|  | Seek Error | STR4 | 1 = Verify operation was unsuccessful. |
|  | CRC Error | STR3 | 1 = CRC check error occurred. |
|  | Track 00 | STR2 | 1 = Disk head is positioned at track 0: Track 00 $=$ TR00. |
|  | Index | STR1 | 1 = Index hole was detected. Index = INP |
|  | Busy | STR0 | 1 = FDC is executing a command. |
| Type II <br>  <br> Type III | Not Ready | STR7 | 1 = FDD is not ready. Not Ready = READY + MR. |
|  | Write Protect |  | $1=$ Write operation is inhibited. Write Protect = WPRT. |
|  | Data Mark Not Found* | STR6 | 1 = Data mark was not found within required byte interval after ID mark detection. |
|  | Record Type | STR5 | 1 = Data address mark was deleted data mark. |
|  | Record Not Found | STR4 | 1 = Desired track and sector were not found. |
|  | CRC Error | STR3 | 1 = CRC check error occurred. |
|  | Lost Data | STR2 | 1 = Data was not read from or written to data register within required time interval. |
|  | Data Request | STR1 | 1 = DRQ is currently active. Data Request = DRQ. |
|  | Busy | STR0 | 1 = FDC is executing a command. |

*For read data and read-after-seek commands in extended mode only.

## Absolute

Maximum Ratings (Note)

Rating

| Parameter | Symbol | Min | Max | Unit | Note |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ | $\mathrm{~V}_{\mathrm{SS}}+7.0$ | V |  |
|  | $\mathrm{~V}_{\mathrm{SS}}$ |  | 0 | V |  |
| Input Voltage | $\mathrm{V}_{\text {IN }}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ | $\mathrm{~V}_{\mathrm{SS}+7.0}$ | V | Should not exceed <br> $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Output Voltage | $\mathrm{V}_{\mathrm{OUT}}$ | $\mathrm{V}_{\mathrm{SS}}-0.3$ | $\mathrm{~V}_{\mathrm{SS}}+7.0$ | V | Should not exceed <br> $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\mathrm{STG}}$ | -55 | +150 | ${ }^{\circ} \mathrm{C}$ |  |

Note: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability

Recommended

## Operating

## Conditions

|  |  | Value |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Parameter | Symbol | Min | Typ | Max | Unit | Note |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5.0 | 5.5 | V |  |
|  | $\mathrm{~V}_{\mathrm{SS}}$ |  | 0 | V |  |  |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ | -40 |  | +85 | ${ }^{\circ} \mathrm{C}$ |  |

## DC Characteristics

(Recommended operating conditions unless otherwise noted).
$\left(\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}\right.$
$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

|  |  | Value |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Parameter | Symbol | Min | Max | Unit | Test Condition |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | 0.8 | V |  |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.2 | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA}$ |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| Input Leakage Current | $\mathrm{I}_{\mathrm{IL}}$ | -10 | +10 | $\mu \mathrm{~A}$ | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| Output Leakage Current | $\mathrm{I}_{\mathrm{OFL}}$ | -10 | +10 | $\mu \mathrm{~A}$ | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{OUT}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| Standby Current | $\mathrm{I}_{\mathrm{CC}}$ |  | 10 | mA |  |
| Input Capacitance | $\mathrm{C}_{\mathrm{IN}}$ |  | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=\mathrm{OV}$ |
| Output Capacitance | $\mathrm{C}_{\mathrm{OUT}}$ |  | 20 | pF | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| IO Capacitance | $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ |  | 20 | pF | All pins except |
| measured pin are OV |  |  |  |  |  |

## AC Characteristics

(Recommended operating conditions unless otherwise noted).
$\left(\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}\right.$,
$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

CPU Read Timing (from FDC)

| Parameter | Symbol | Value |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| Address Setup Time (to $\overline{\mathrm{RE}}$ ! $)$ | $\mathrm{t}_{\text {SET }}$ | 50 |  | ns |  |
| Address Hold Time (from( $\overline{\mathrm{RE}} \uparrow$ ) | $t_{\text {HLD }}$ | 15 |  | ns |  |
| RE Pulse Width | $t_{\text {RE }}$ | 150 |  | ns |  |
| Data Delay Time (from $\overline{\mathrm{RE}}$ ) | $t_{\text {DACC }}$ |  | 120 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| Data Hold Time (from $\overline{\mathrm{RE}} \dagger$ ) | $\mathrm{t}_{\mathrm{DOH}}$ | 10 | 75 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| DRQ Service Time (from DRQ to $\overline{\mathrm{RE}}$ ) | $\mathrm{t}_{\text {SEVR }}$ |  | 13.5 | $\mu \mathrm{S}$ | $\mathrm{t}_{\mathrm{C}}=2 \mu \mathrm{~s}$ |
| DRQ Release Time (from RE! to DQR!) | $t_{\text {DRR }}$ |  | 150 | ns |  |
| IRQ Release Time (from RE! to IRQ!) | $t_{\text {IRR }}$ |  | 500 | ns |  |

## CPU Write Timing (to FDC)

| Parameter | Symbol | Value |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| Address Setup Time (to $\overline{\mathrm{WE}}$ ) | $\mathrm{t}_{\text {SET }}$ | 50 |  | ns |  |
| Address Hold Time (from WEt) | $\mathrm{t}_{\text {HLD }}$ | 10 |  | ns |  |
| WE Pulse Width | $t_{\text {WE }}$ | 100 |  |  |  |
| Data Setup Time (to $\overline{\mathrm{WE}} \mathrm{t}$ ) | $\mathrm{t}_{\mathrm{DS}}$ | 100 |  | ns |  |
| Data Hold Time (from $\overline{\mathrm{WE}}$ ) | $t_{\text {DH }}$ | 0 |  | ns |  |
| DRQ Service Time (from DRQ to $\overline{W E} \uparrow$ ) | $\mathrm{t}_{\text {SEVW }}$ |  | 9.5* | $\mu \mathrm{s}$ |  |
| DRQ Release Time (from WEd to DQR) | $t_{\text {DRR }}$ |  | 150 | ns |  |
| IRQ Release Time (from WE! to IRQ!) | $\mathrm{t}_{\text {IRR }}$ |  | 500 | ns |  |

[^39]
## AC Characteristics

(Continued)
(Recommended operating conditions unless otherwise noted.)
$\left(\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%\right.$, $\mathrm{GND}=0 \mathrm{~V}$,
$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

FDC Read Timing (from FDD)

| Parameter | Symbol | Value |  |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| RAW READ Pulse Width | $t_{\text {PW }}$ | 100 |  |  | ns |  |
| RAW READ Cycle Time | $t_{B C}$ |  | *2,*3 |  | $\mu \mathrm{S}$ | MFM |
|  |  |  | *2, * |  |  | FM |
| RCLK Setup Time (from RCLK Change to to RAW READ!) | $t_{D}$ | 40 |  |  | ns |  |
| RCLK Hold Time (from RAW READ! to RCLK Change) | ${ }^{\text {t }}$ CD | 40 |  |  | ns |  |
| RCLK High Time | $t_{\text {A }}$ | 0.8 | 1* | 8 | $\mu \mathrm{S}$ | MFM |
|  |  | 0.8 | 2* | 8 |  | FM |
| RCLK Low Time | $\mathrm{t}_{\mathrm{B}}$ | 0.8 | 1* | 8 | $\mu \mathrm{s}$ | MFM |
|  |  | 0.8 | 2* | 8 |  | FM |
| RCLK Cycle Time | $\mathrm{t}_{\mathrm{C}}$ |  | 2* |  | $\mu \mathrm{s}$ | MFM |
|  |  |  | 4* |  |  | FM |

* These values are doubled when the CLK $=4 \mathrm{MHz}$.

FDC Write Timing (to FDD)

| Parameter | Symbol | Value |  |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| WD Pulse Width | $t_{\text {wo }}$ | 450 | 500 | 550 | ns | CLK $=8 \mathrm{MHz}$, FM |
|  |  | 200 | 250 | 300 |  | CLK $=8 \mathrm{MHz}, \mathrm{MFM}$ |
| WG Setup Time (from WGt to WDt) | ${ }^{\text {twg }}$ |  | 2 |  | $\mu \mathrm{S}$ | CLK $=8 \mathrm{MHz}$, FM |
|  |  |  | 1 |  |  | CLK $=8 \mathrm{MHz}, \mathrm{MFM}$ |
| WG Hold Time (from WD! to WG!) | $t_{\text {wF }}$ |  | 2 |  | $\mu \mathrm{S}$ | CLK $=8 \mathrm{MHz}$, FM |
|  |  | 1 |  | 2 |  | CLK $=8 \mathrm{MHz}, \mathrm{MFM}$ |
| WD Output Delay | tcwo | 20 |  | 100 | ns |  |

## AC Characteristics

(Continued)
(Recommended operating conditions unless otherwise noted.)
$\left(V_{C C}=+5 \mathrm{~V} \pm 10 \%, G N D=0 \mathrm{~V}\right.$, $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

Other Timing

| Parameter | Symbol | Value |  |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| CLK Cycle Time | $\mathrm{t}_{\mathrm{CrC}}$ | 125 |  | 500 | ns |  |
| CLK Low Time | ${ }^{\text {c }} \mathrm{CD} 1$ | 55 |  | 250 | ns |  |
| CLK High Time | $\mathrm{t}_{\mathrm{CD} 2}$ | 55 |  | 250 | ns |  |
| STEP Pulse Width | $\mathrm{t}_{\text {STP }}$ | $6^{*}$ |  |  | $\mu \mathrm{S}$ | MFM |
|  |  | 12* |  |  |  | FM |
| DIRC Setup Time | $t_{\text {DIRS }}$ | 12* |  |  | $\mu \mathrm{s}$ |  |
| DIRC Hold Time | $\mathrm{t}_{\text {DIRH }}$ | $6 *$ |  |  | $\mu \mathrm{s}$ |  |
| $\overline{\text { MR Pulse Width }}$ | $\mathrm{t}_{\text {MR }}$ | $50^{*}$ |  |  | $\mu \mathrm{s}$ |  |
| IP Pulse Width | $\mathrm{t}_{\text {IP }}$ | $10^{*}$ |  |  | $\mu \mathrm{s}$ |  |

* These values are doubled when CLK $=4 \mathrm{MHz}$.


## Timing Diagrams

CPU Read Timing Diagram


CPU Write Timing Diagram


## Timing Diagrams

## (Continued)

DRQ, IRQ Service and Release Timing Diagram


FDC Read Timing Diagram


FDC Write Timing Diagram


Timing Diagrams
(Continued)
Other Timing Diagram


Package Dimensions
Dimensions in Inches (millimeters)

## 28-Lead Plastic

 Dual In-Line Package(Case No.: DIP-28P-M02)


Dimensions in
inches (millimeters)
© 1986 FUJITSU LIMITED D28006S-1C

## MB 4107

## FLOPPY DISK VFO

The Fujitsu MB 4107 is a variable-frequency oscillator (VFO) IC for use in floppy-disk interfaces. It provides a complete data separation function, with a minimum of external parts and no adjustments, and can be used with a variety of disk controllers. It locks onto the read signal from the disk drive, which normally has jitter due to rotation speed variations and peak shifting, and produces a stable read signal for the controller. It also produces a window signal, which can be used to differentiate the clock and data pulses in the read signal.
The MB 4107 includes functions for sync field detection, automatic loop filter gain switching, and address and index mark detection.

- The analog VFO (PLL) circuitry allows a wide read margin for the data separator.
- Can be connected to both 8 -inch and 5 -inch floppy disk drives using the same external components.
- Handless both double-density (MFM) and single-density (FM) disks.
- Can be used with various floppy disk controllers such as the MB 8876A, MB 8877A, FD1791, and $\mu$ PD 765.
- The discrimination function for gap and sync fields prevents incorrect locking on the gap field.
- The quick sync function (high gain) in the sync field is automatically switched to the stable
tracking function (low gain).
- Because the sync pattern detector (data: $\mathbf{0 0}_{\mathbf{H}}$, clock: $\mathrm{FF}_{\mathrm{H}}$ ) and the IBM format mark detector control PLL gain, the index, ID, and data fields can be locked onto without special control signals.
- A master clock is generated for the floppy disk controller, to prevent spikes when switching between 8 - and 5 -inch floppy disks.
- External circuitry requires very few components, and no adjustments.
Internal clock: 7 resistors, 5 capacitor, 1 crystal or ceramic resonator
External clock: 5 resistors, 3 capacitors

Fig. 1 - BLOCK DIAGRAM


Fig. 2 - PIN ASSIGNMENT


## TABLE 1 - PIN FUNCTION

| Pin No. | Symbol | Function |
| :---: | :---: | :---: |
| 1 | MIN | Selects type of floppy disk as follows: <br> - 5-inch floppy disk (MIN) High <br> - 8-inch floppy disk (STD) Low |
| 2 | FM | Selects the disk density as follows: <br> - Single density (FM system) High <br> - Double density (MFM system) Low |
| 3 | RR | Read data signal for the FDC, including both clock and data pulses. |
| 4 | DW | Data window signal for separating the $\overline{\mathrm{RR}}$ signal into data and clock pulses. |
| 5 | DA | Input for indicating a data field. When DA goes high, the PLL is kept as a low gain. Either RG or DA is used, but not both, and the unused pin is kept low. |
| 6 | RG | Read Gate (MB 8877A system) or VCO Sync ( $\mu$ PD765 system) input. When a high signal is applied to this pin, PLL is kept at a low gain. |
| 7 | WCK | The $\mu$ PD 765 system FDC write clock pulse is output from this pin as follow: <br> -8-inch/MFM T=1 $\mu \mathrm{s}$ <br> -8-inch/FM T $=2 \mu \mathrm{~s}$ <br> - 5-inch/MFM T $=2 \mu \mathrm{~s}$ <br> - 5 -inch/FM $\quad \mathrm{T}=4 \mu \mathrm{~s}$ |
| 8 | CK | The FDC clock pulse is output from this pin as follows: <br> - MB 8877A system $/ 8$-inch 2 MHz <br> - MB 8877 A system $/ 5$-inch 1 MHz <br> - $\mu$ PD 765 system $/ 8$-inch $\quad 8 \mathrm{MHz}$ <br> $-\mu$ PD 765 system $/ 5$-inch $\quad 4 \mathrm{MHz}$ |
| 9 | CSEL | Selects the FDC type shown below (an internal pull-up resistor is provided): <br> - MB 8877A, FD 1791 system High <br> - $\mu$ PD 765 system Low |
| 10 | X2 | (1) Inverter output for the quartz oscillator <br> (2) This pin is open when a $8-\mathrm{MHz}$ external clock is used. |
| 11 | X1 | (1) Inverter input for the quartz oscillator <br> (2) Input pin when an $8-\mathrm{MHz}$ external clock is used. |
| 12 | DGND | Ground for digital circuits |
| 13 | RD | Input for the source read data from the FDD |
| 14 | AGND | Ground for analog circuits such as VCO and filter amplifier |
| $\begin{aligned} & 15 \\ & 16 \end{aligned}$ | $\begin{aligned} & \text { C1 } \\ & \text { C2 } \end{aligned}$ | An external capacitor for setting VCO oscillating frequency is connected to these pins. |

## TABLE 1 - PIN FUNCTION (cont'd)

| Pin No. | Symbol | Function |
| :---: | :---: | :--- |
| 17 | AV $_{\text {CC }}$ | Power supply for analog circuits such as the VCO and filter amplifier. |
| 18 | VCO | VCO control current input. |
| 19 | AO | Output pin for the low pass filter (LPF) amplifier in the VFO (PLL) circuit. |
| 20 | AI | Input pin for the LPF amplifier in the VFO (PLL) circuit |
| 21 | HO | Output pin to be externally connected to the LPF amplifier. This pin is selected at <br> frequency lock after a sync field is detected. A high signal decreases the VCO frequency <br> and a low signal increases it. (High gain) |
| 22 | LO | Output pin to be externally connected to the LPF amplifier. This pin is selected after <br> frequency lock, for phase synchronization. A high signal delays the VCO phase, and a <br> low signal advances it. (Low gain) |
| 23 | TEST | Used for the LSI function test. It is normally open or pulled up. |
| 24 | DV CC | Power supply pin for digital circuits. |

TABLE 2 - MAXIMUM RATINGS $\left(T_{A}=25^{\circ} \mathrm{C}\right)$

| Item | Symbol | Condition | Rating | Unit |
| :--- | :--- | :--- | :--- | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ |  | 7 | V |
| Logic input voltage | $\mathrm{V}_{\text {IN }}$ |  | 7 | V |
| Power dissipation | $\mathrm{P}_{\mathrm{D}}$ | $\mathrm{T} \leqq 75^{\circ} \mathrm{C}$ | 550 | mW |
| Storage temperature | $\mathrm{T}_{\text {STG }}$ |  | $-55 \sim+125$ | ${ }^{\circ} \mathrm{C}$ |

## TABLE 3 - RECOMMENDED OPERATING CONDITIONS

| Item | Symbol | MIN | TYP | MAX | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.75 | 5.00 | 5.25 | V |
| Operating temperature range | $\mathrm{T}_{\text {OP }}$ | -20 | 25 | 75 | ${ }^{\circ} \mathrm{C}$ |

TABLE 4 - ELECTRICAL CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )
(Recommended operating conditions unless otherwise noted)

| Item | Symboi | Condition |  | Value |  |  | Unit | Applicable pin | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max |  |  |  |
| Supply current | Icc | $\mathrm{V}_{\mathrm{cc}}=5.25 \mathrm{~V}$ |  | - | 70 | 100 | mA | $\mathrm{V}_{\mathrm{cc}}$ | - |
| High level input voltage | $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{\mathrm{cc}}=4.75-5.25 \mathrm{~V}$ |  | 2.0 | - | - | V | MIN, FM <br> DA, RG <br> CS, X1 <br> RD | *3 |
| Low level input voltage | $V_{\text {IL }}$ |  |  | - | - | 0.8 | V |  | *3 |
| High level input current | $\mathrm{I}_{1} \mathrm{H}$ | $\mathrm{V}_{\mathrm{cc}}=5.25 \mathrm{~V}, \mathrm{~V}_{1}=2.7 \mathrm{~V}$ |  | - | - | 20 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { FM, DA } \\ & \text { RG, X1 } \\ & \text { RD } \end{aligned}$ | - |
| Current at maximum input voltage | 11 | $\mathrm{V}_{\mathrm{Cc}}=5.25 \mathrm{~V}, \mathrm{~V}_{1}=7.0 \mathrm{~V}$ |  | - | - | 0.1 | mA |  | - |
| Low level input current | IIL | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{1}=0.4 \mathrm{~V}$ |  | -400 | -20 | - | $\mu \mathrm{A}$ |  | - |
| Open-circuit input voltage | $V_{\text {IP }}$ |  |  | 4.85 | 5.0 | - | V | MIN, CS | - |
| Low level input current | IILP | $\mathrm{V}_{1}=0 \mathrm{~V}$ |  | -1.1 | -0.6 | - | mA |  | - |
| High level output voltage 1 | Voh1 | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-1.2 \mathrm{~mA}$ |  | 2.7 | 3.3 | - | V | $\overline{\mathrm{RR}}$, DW | $* 1$ <br> $* 3$ |
| Low level output voltage 1 | Vol1 | $\mathrm{V}_{\mathrm{cc}}=4.75 \mathrm{~V}$ | $\mathrm{I}_{\mathrm{OL}}=12 \mathrm{~mA}$ | - | 0.28 | 0.4 | V |  |  |
|  |  |  | $\mathrm{I}_{\mathrm{OL}}=24 \mathrm{~mA}$ | - | 0.35 | 0.5 | V |  |  |
| Short-circuit output current 1 | los1 | $\mathrm{V}_{\mathrm{cc}}=5.25 \mathrm{~V}$ |  | -30 | - | -160 | mA |  | $* 1$ $* 3$ |
| High level output voltage 2 | $\mathrm{V}_{\mathrm{OH} 2}$ | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ |  | 2.7 | 3.3 | - | V | WCK, CK | $* 1$ $* 3$ |
| Low level output voltage 2 | Vol2 | $\mathrm{V}_{\mathrm{cc}}=4.75 \mathrm{~V}$ | $\mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}$ | - | 0.28 | 0.4 | V |  |  |
|  |  |  | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ | - | 0.35 | 0.5 | V |  |  |
| Short-circuit output current 2 | los2 | $\mathrm{V}_{\mathrm{Cc}}=5.25 \mathrm{~V}$ |  | -20 | - | -110 | mA |  | $* 1$ $* 3$ |
| High level output voltage 3 | Vонз | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ |  | 2.7 | 3.3 | - | V | X2 | $* 1$ $* 3$ |
| Low level output voltage 3 | Vol3 | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=1 \mathrm{~mA}$ |  | - | 0.28 | 0.4 | V |  | $* 2$ $* 3$ |
| High output voltage | $\mathrm{V}_{\mathrm{HH}}$ | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |  | 3.3 | 3.7 | - | V | HO | *1 |
| Low output voltage | V LH | $\mathrm{IOL}=1 \mathrm{~mA}$ |  | - | 2.0 | 2.4 | V |  | *2 |
| High output voltage | $\mathrm{V}_{\mathrm{HL}}$ | $\mathrm{I}_{\mathrm{OH}}=-0.2 \mathrm{~mA}$ |  | 3.8 | 4.2 | - | V | LO | *1 |
| Low output voltage | $V_{\text {LL }}$ | $\mathrm{I}_{\mathrm{OL}}=0.2 \mathrm{~mA}$ |  | - | 1.5 | 1.9 | V |  | *2 |
| VCO free run frequency | $\mathrm{f}_{\mathrm{FR}}$ |  |  | 1.6 | 2.0 | 2.4 | MHz |  | - |

NOTE: *1 The output stage is set high. *2 The output stage is set low. $\quad{ }^{*} 3 \mathrm{~T}_{\mathrm{A}}=-20^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$

Fig. 3 - STANDARD EXTERNAL CIRCUITS (MB 4107)


NOTE: 1. $C_{3}( \pm 5 \%), R_{5}( \pm 1 \%)$, otherwise $C( \pm 10 \%), R( \pm 5 \%)$
2. Since the $8-\mathrm{MHz}$ internal and $8-\mathrm{MHz}$ external clocks require precision of $\pm 1 \%$, a ceramic resonator can be used when WCK and CK do not require a high precision.

TIMING CHARTS


NOTES: 1. The above times are doubled for 5 -inch floppy disks.
2. $C=$ clock pulse, $D=$ data pulse

## STANDARD CONNECTIONS FDD AND FDC

I READ GATE, VCO SYNC USED


II DATA REQUEST USEC


8 inch: $T_{C}=100 \mu \mathrm{~s} \pm 20 \% \quad 5$ inch: $T_{C}=200 \mu \mathrm{~s} \pm 20 \%$


8 inch: $T_{C}=100 \mu \mathrm{~s} \pm 20 \%$
5 inch: $\mathrm{T}_{\mathrm{C}}=200 \mu \mathrm{~s} \pm 20 \%$

## PACKAGE DIMENSIONS



## MAGNETIC DISK HEAD AMPLIFIER

The Fujitsu MB 4111/MB 4112/MB 4113 is a monolithic bipolar integrated circuit optimized for high performance application to disk head systems.

The MB 4111/MB 4112/MB 4113 is featured with the following four major functions to interface with four magnetic heads.

* Write Amplifier Circuit
* Read Amplifier Circuit
* $\overline{\text { RAS }}$ (safety) Circuit
* Selection Decode Circuit

Also, the MB 4111/MB 4112/MB 4113 has three modes, Read, Write and Idle.
The MB 4111/MB 4113 is suitable for mounting directly on the arm of movable disk head.
The MB 4112 is suitable for mounting on the PC board interfacing the fixed disk head.

ABSOLUTE MAXIMUM RATINGS (*: Referenced to ground)

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}{ }^{*}$ | 7.0 | V |
| Supply Voltage | $\mathrm{V}_{\mathrm{EE}}{ }^{*}$ | -5.5 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |

Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| Supply Voltage <br> (Read/Write/Idle) | $\mathrm{V}_{\mathrm{Cc}}$ | 5.7 | 6.0 | 6.3 | V |
| Supply Voltage <br> (Read/Write/Idle) | $\mathrm{V}_{\mathrm{EE}}$ | -4.2 | -4.0 | -3.8 | V |

Ambient temperature: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$


## PIN NAMES

| No. | Symbol | Name |
| :---: | :---: | :---: |
| 1 | $\mathrm{~V}_{\mathrm{EE}}$ | Supply Voltage |
| 2 | $\mathrm{HS}_{1}$ | Head Select 1 |
| 3 | $\mathrm{~V}_{\mathrm{CC}}$ | Supply Voltage |
| 4 | US | Unsafe |
| 5 | WC | Write Current |
| 6 | NC | Non-connection* |
| 7 | NC | Non-connection* |
| 8 | NC | Non-connection* |


| No. | Symbol | Name |
| :---: | :---: | :---: |
| 9 | DX | Data X |
| 10 | DY | Data Y |
| 11 | $\mathrm{HS}_{2}$ | Head Select 2 |
| 12 | $\mathrm{~V}_{\mathrm{EE}}$ | Supply Voltage |
| 13 | GND | Ground |
| 14 | WS | Write Select |
| 15 | H 11 | Head 1 |
| 16 | H 12 |  |


| No. | Symbol | Name |
| :---: | :---: | :---: |
| 17 | H 31 | Head 3 |
| 18 | H 32 |  |
| 19 | H 01 | Head 0 |
| 20 | H 02 |  |
| 21 | H 21 | Head 2 |
| 22 | H 22 |  |
| 23 | $\overline{\mathrm{CS}}$ | Chip Select |
| 24 | GND | Ground |

Note: NCs should be left open any time.

## TEST CONDITIONS

| Parameter | Symbol | Mode |  | Value | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | Read/Write/Idle |  | $6.0 \pm 1.0 \%$ | V |
|  | $V_{\text {EE }}$ |  |  | $-4.0 \pm 1.0 \%$ |  |
| Head Inductance | $L_{n}$ | Read/Write | DC | 0 (short) | $\mu \mathrm{H}$ |
|  |  |  | AC | 9.0 |  |
| Write Select Voltage | $\mathrm{V}_{\text {ws }}$ | Write |  | $3.5 \pm 1.0 \%$ | V |
|  |  | Read |  | $0.0 \pm 0.01$ |  |
| Chip Select Voltage | $\mathrm{V}_{\mathrm{cs}}$ | Read/Write |  | $0.0 \pm 0.01$ | V |
|  |  | Idle |  | $6.0 \pm 1.0 \%$ |  |
| Unsafe Voltage | $\mathrm{V}_{\text {us }}$ | Read/Write/Idle |  | $6.0 \pm 1.0 \%$ | V |
| Termination Resistor | $\mathrm{R}_{\mathrm{L} 1}$ | Read/Write/Idle |  | $200 \pm 1.0 \%$ | $\Omega$ |
|  | $\mathrm{R}_{\mathrm{L} 2}$ |  |  | $100 \pm 1.0 \%$ |  |
| Write Current | Iwc | Write |  | $40.0 \pm 1.0 \%$ | mA |
|  |  | Read |  | $0.0 \pm 0.2$ |  |
| Ambient Temperature | $\mathrm{T}_{\mathrm{A}}$ | Read/Write/Idle |  | $25.0 \pm 2.0$ | ${ }^{\circ} \mathrm{C}$ |

Fig. 1 - TEST CIRCUIT


Note: NCs should be left open.

## ELECTRICAL CHARACTERISTICS

| Parameter | Symbol | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| Supply Current | Icc | 12 | 16 | 20 | mA | Selected |
|  |  |  |  | 100 | $\mu \mathrm{A}$ | Non Selected |
| Supply Current | $I_{\text {ee }}$ | -70 |  |  | mA | Selected |
|  |  | -45 |  |  |  | Non Selected |

## MODE SELECT

| Parameter | Sybmol | Mode | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |  |
| $\overline{\text { CS }}$ Input High Voltage | $\mathrm{V}_{\text {IHC }}$ | Idle | 5.7 | 6.0 | 6.3 | V | $-50 \mu \mathrm{~A}<\mathrm{I}_{\text {cs }}<0 \mu \mathrm{~A}$ |
| $\overline{\mathrm{CS}}$ Input Low Voltage | $V_{\text {ILC }}$ | Read/Write | 0.0 | 0.35 | 0.7 | V |  |
| $\overline{\text { CS }}$ Input High Current | $\mathrm{I}_{\text {IHC }}$ | Idle | -70 |  |  | $\mu \mathrm{A}$ |  |
| $\overline{\text { CS }}$ Input Low Current | $I_{\text {ILC }}$ | Read/Write | -1.3 | -1.0 | -0.6 | mA | $\mathrm{V}_{\mathrm{Cs}}=0 \mathrm{~V}$ |
| WS Input High Voltage | $V_{\text {IHW }}$ | Write/Idle | 3.2 | 3.5 | 3.8 | V |  |
| WS Input Low Voltage | $V_{\text {ILW }}$ | Read/Idle | 0 | 0.1 | 0.2 | V |  |
| WS Input High Current | $\mathrm{I}_{\text {IHW1 }}$ | Write/Idle | 0.7 |  | 2.8 | mA | Transition Unsafe OFF |
|  | $\mathrm{I}_{\text {IHW2 }}$ | Write/Idle | 0.7 |  | 3.5 | mA | Transition Unsafe ON |
| WS Input Low Current | IILW | Read/Idle |  |  | 0.1 | mA |  |
| Switching Delay | ${ }^{\text {tso }}$ | All Modes |  |  | 500 | ns |  |

## TOTAL HEAD INPUT CURRENT

| Parameter | Symbol | Mode | Value |  |  | Unit | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |  |
| Input Current | 11 | Write |  |  | 3.0 | mA | $V_{C T}=3.5 \mathrm{~V}$ |
| Input Current | $I_{12}$ | Read |  |  | 0.16 | mA | $\mathrm{V}_{\mathrm{CT}}=0 \mathrm{~V}$ |
| Input Current | $1 / 3$ | Idle |  |  | 0.5 | mA | $V_{C T}$ High or Low |

MB 4112 FUSITSU
MB 4113 Hinmix

## HEAD SELECT

| Parameter | Symbol | Condition | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| HS Input High Voltage | $\mathrm{V}_{\text {IHH }}$ | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | -0.96 |  | -0.81 | V |
| HS Input Low Voltage | $V_{\text {ILH }}$ | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | -1.85 |  | -1.65 | V |
| HS Input High Current | $I_{\text {IHH }}$ |  |  |  | 240 | $\mu \mathrm{A}$ |
| HS Input Low Current | $I_{\text {ILH }}$ |  |  |  | 30 | $\mu \mathrm{A}$ |
| Switching Delay | ${ }^{\text {SSDH }}$ |  |  |  | 100 | ns |

## HEAD SELECTION TABLE

| Head No. | CS | HS1 | HS2 |
| :---: | :---: | :---: | :---: |
| - | High | - | - |
| 0 | Low | High | High |
| 1 | Low | Low | High |
| 2 | Low | High | Low |
| 3 | Low | Low | Low |

## READ MODE

| Parameter |  | Symbol | Condition | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min |  | Typ | Max |  |
| Differential Gain | $\begin{aligned} & \text { MB } 4111 \\ & \text { MB } 4113 \end{aligned}$ |  | $A_{V}$ | $\begin{aligned} & V_{1 N}=1 \mathrm{mVp}-\mathrm{p}, 0 \mathrm{~V} \\ & D C, f=300 \mathrm{KHz} \end{aligned}$ | 22.0 | 35.0 | 46.0 | V/V |
|  | MB 4112 | 5.0 |  |  | 9.0 | 12.5 |  |  |
| Common Mode Rejection Ratio |  | CMRR | $\begin{aligned} & V_{\text {IN }}=5 \mathrm{mVp}-\mathrm{p}, 0 \mathrm{~V} \\ & \mathrm{DC}, \mathrm{f} \leqq 5 \mathrm{MHz} \end{aligned}$ | 45 |  |  | dB |  |
| Power Supply Rejection Ratio |  | $S V_{\text {RR }}$ | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}, \mathrm{f} \leqq 5 \mathrm{MHz}$ | 45 |  |  | dB |  |
| Band Width |  | BW | $Z_{\text {IN }}=0 \Omega(-3 \mathrm{~dB})$ | 35 |  |  | MHz |  |
| Channel Noise | $\begin{aligned} & \text { MB } 4111 \\ & \text { MB } 4113 \end{aligned}$ | $\mathrm{V}_{\mathrm{n}}$ | $\begin{aligned} & \mathrm{V}_{\text {IN }}=0 \mathrm{~V}, \\ & \mathrm{Z}_{\mathrm{IN}}=0 \Omega, \\ & 10 \mathrm{MHz} \text { Power Band } \\ & \text { Width } \end{aligned}$ |  |  | 5.4 | $\mu \mathrm{V}$ RMS |  |
|  | MB 4112 |  |  |  |  | 20 |  |  |
| Input Current |  | IIN | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ |  |  | 40 | $\mu \mathrm{A}$ |  |
| Input <br> Capacitance | $\begin{aligned} & \text { MB } 4111 \\ & \text { MB } 4113 \end{aligned}$ | $\mathrm{C}_{1}$ |  |  |  | 18.8 | pF |  |
|  | MB 4112 |  |  |  |  | 16.0 |  |  |
| Differential Input Resistance | $\begin{aligned} & \text { MB } 4111 \\ & \text { MB } 4112 \\ & \hline \end{aligned}$ | $\mathrm{R}_{\mathrm{D}}$ |  | 585 | 750 | 915 | $\Omega$ |  |
|  | MB 4113 |  |  | 380 | 480 | 580 |  |  |
| Output Offset Voltage | $\begin{aligned} & \text { MB } 4111 \\ & \text { MB } 4113 \end{aligned}$ | $\mathrm{V}_{\text {OFF }}$ |  | -100 |  | 100 | mV |  |
|  | MB 4112 |  |  | -50 |  | 50 |  |  |
| Unsafe Current |  | lu | $\mathrm{V}_{\text {US }}=6.0 \mathrm{~V}, \mathrm{I}_{\mathrm{Wc}}=45 \mathrm{~mA}$ | 40 |  | 45 | mA |  |
| Dynamic Range | $\begin{aligned} & \text { MB } 4111 \\ & \text { MB } 4113 \\ & \hline \end{aligned}$ | D | DC input voltage where gain is $90 \%$ of gain with $0.5 \mathrm{mVp}-\mathrm{p}$ input signal | 6 |  |  | mVp-p |  |
|  | MB 4112 |  |  | 30 |  |  |  |  |
| Channel Separation |  | $S_{1}$ | See Note | 40 |  |  | dB |  |
| Common Mode Output Voltage |  | $\mathrm{V}_{0}$ |  | -0.75 | -0.60 | -0.45 | V |  |

Note: $V_{\text {IN }}=1 \mathrm{mVp}-\mathrm{p}, \mathrm{f}=300 \mathrm{KHz}, 3$ Channel driven.

## WRITE MODE

| Parameter |  | Symbol | Condition | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min |  | Typ | Max |  |
| Write Current |  |  | Iwc |  |  |  | 50 | $\mathrm{mA}$ |
| Current Gain |  | A | $I_{W C}=50 \mathrm{~mA}$ | 0.95 |  |  |  |
| Write Current Voltage |  | $\mathrm{V}_{\mathrm{wc}}$ | $I_{W C}=45 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{EE}}+0.3$ |  | $V_{E E}+1$ | V |
| Differential Input Voltage |  | $V_{\text {IN }}$ |  | 0.225 |  |  | V |
| DX DY Input Current |  | $I_{\text {IN }}$ | $\begin{aligned} & -0.75 \mathrm{~V} \leqq \mathrm{~V}_{D X} \leqq-0.45 \mathrm{~V} \\ & -0.75 \mathrm{~V} \leqq \mathrm{~V}_{D Y} \leqq-0.45 \mathrm{~V} \end{aligned}$ | -2.0 |  | 2.0 | mA |
| Unsafe Current |  | Ius | $\begin{aligned} & \mathrm{L}=7 \mu \mathrm{H}, \\ & \mathrm{f}=1.2 \mathrm{MHz}, \mathrm{I}_{\mathrm{WC}}=20 \mathrm{~mA} \end{aligned}$ |  |  | 0.1 | mA |
|  |  | $\begin{aligned} & \mathrm{L}=9 \mu \mathrm{H}, \\ & \mathrm{f}=0 \mathrm{MHz}, \mathrm{I}_{\mathrm{WC}}=30 \mathrm{~mA} \end{aligned}$ | 20 |  |  |  |
| Head Current Transition Time |  |  | ${ }^{\text {T }}$ | $\begin{aligned} & \mathrm{L}=0 \mu \mathrm{H}, \mathrm{f}=5 \mathrm{MHz} \\ & \mathrm{I}_{\mathrm{WC}}=50 \mathrm{~mA} \end{aligned}$ |  | 5 | 10 | ns |
| Head Current Hysterisis |  | $t_{\text {HY }}$ | $\begin{aligned} & \mathrm{L}=0 \mu \mathrm{H}, \mathrm{f}=5 \mathrm{MHz} \\ & \mathrm{I}_{\mathrm{WC}}=50 \mathrm{~mA} \end{aligned}$ |  |  | 2.0 | ns |
| Unselected Head Current |  | lop | $\begin{aligned} & \mathrm{L}=9 \mu \mathrm{H}, \mathrm{f}=2 \mathrm{MHz}, \\ & \mathrm{I}_{\mathrm{WC}}=50 \mathrm{~mA} \end{aligned}$ |  |  | 1.5 | mA |
| Unsafe Switching Delay Time | MB 4111 <br> MB 4112 | $t_{\text {USD }}$ | $\begin{aligned} & \mathrm{L}=9 \mu \mathrm{H}, \\ & \mathrm{f}=6.0 \mathrm{MHz} \text { to } 0 \mathrm{MHz} \end{aligned}$ | 0.5 |  | 4.0 | $\mu \mathrm{s}$ |
|  |  |  | $\begin{aligned} & \mathrm{L}=7 \mu \mathrm{H}, \\ & \mathrm{f}=0 \mathrm{MHz} \text { to } 1.2 \mathrm{MHz} \end{aligned}$ |  |  | 1.0 |  |
|  | MB4113 |  | $\begin{aligned} & \mathrm{L}=5 \mu \mathrm{H}, \mathrm{I}_{\mathrm{WC}}=30 \mathrm{~mA} \\ & \mathrm{f}=7.5 \mathrm{MHz} \text { to } 0 \mathrm{MHz} \end{aligned}$ | 0.3 |  | 4.0 |  |
|  |  |  | $\begin{aligned} & \mathrm{L}=3.5 \mu \mathrm{H}, \mathrm{I}_{\mathrm{WC}}=15 \mathrm{~mA} \\ & \mathrm{f}=0 \mathrm{MHz} \text { to } 3.0 \mathrm{MHz} \end{aligned}$ |  |  | 1.0 |  |
| Differential Head Voltage | $\begin{aligned} & \text { MB } 4111 \\ & \text { MB } 4113 \end{aligned}$ | $V_{\text {DIF }}$ | $\begin{aligned} & I_{\mathrm{WC}}=45 \mathrm{~mA} \\ & \mathrm{~L}=9 \mu \mathrm{H} \end{aligned}$ | 6.2 |  | 7.2 | V |
|  | MB 4112 |  | $\begin{aligned} & I_{W C}=45 \mathrm{~mA} \\ & L=9 \mu \mathrm{H} \end{aligned}$ | 8.0 |  | 9.0 |  |

## WRITE CURRENT WAVEFORMS

Conditions: $\mathrm{L}=9 \mu \mathrm{H}, \mathrm{I}_{\mathrm{wc}}=40 \mathrm{~mA}$
MB 4111


50ns/div

Conditions: $\mathrm{L}=7 \mu \mathrm{H}, \mathrm{I}_{\mathrm{WC}}=40 \mathrm{~mA}$
MB 4111


50ns/div

MB4112


50ns/div

MB 4112


50ns/div

## DISK HEAD APPLICATION NOTES


*USAGE IN COMBINATION WITH MB 4316 (BUS SWITCHING CIRCUIT)

*FAULT DETECTION CIRCUITRY


## PACKAGE DIMENSIONS



## Advanced Products

## Description

The Fujitsu MB4316 is designed for the MB4111/MB4112 Disk Head Amplifier's Driver/Receiver.

## Features

- Data inputs and Control inputs are CML level inputs.
- On-chip Write Current Source which is adjustable by changing an external resister.



## Block Diagram

 and Pin Assignment

| Absolute Maximum Rating | Parameter | Symbol | Rating | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  | Supply Voltage | $\mathrm{V}_{\text {EE1 }}$ | -7.0-0 | V |
|  |  | $\mathrm{V}_{\text {EE2 }}$ | -15.0-0 | V |
|  | Output Terminal Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 0-9.0 | V |
|  | Input Voltage | $\mathrm{V}_{\text {IN }}$ | -5.0-0 | V |
|  | Write Current | $I_{\text {WG }}$ | 0-60 | mA |
|  | Power Dissipation | $P_{D}$ | 580 | mW |
|  | Operating Temperature | Ta | 0-70 | ${ }^{\circ} \mathrm{C}$ |
|  | Storage Temperature | Tstg | -55-150 | ${ }^{\circ} \mathrm{C}$ |

## Recommended Operating Conditions

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- |
| Supply voltage | $\mathrm{V}_{\mathrm{EE} 1}$ | $-5.2 \pm 5 \%$ | V |
|  | $\mathrm{~V}_{\mathrm{EE} 2}$ | $-12.0 \pm 5 \%$ | V |
| Output Terminal Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $-6.0 \pm 5 \%$ | V |
| External Resistance | $\mathrm{R}_{\mathrm{EXT} 1}$ | $700 \pm 2 \%$ | $\Omega$ |


| Pin Function Table | Pin No. | Symbol | Functions |
| :---: | :---: | :---: | :---: |
|  | 1 | $\mathrm{V}_{\mathrm{EE} 2}$ | Power Supply (-12 V) |
|  | 2 | G1 | Gain of output Amplifier (Receiver) is specified with an External resister between G1 and G2. |
|  | 3 | G2 |  |
|  | 4 | $\mathrm{R}_{\text {WD }}$ | This input specifies Data level in write mode. |
|  | 5 | $\overline{\text { WT }}$ | WC switch. When it is at CML low level, WC is active. |
|  | 6 | WC | Write Current Source Output |
|  | 7 | $\mathrm{R}_{\mathrm{WC}}$ | Write Current is specified with resister between $R_{W C}$ and $\mathrm{V}_{\mathrm{EE} 2}$ (See Block Diagram). ( $\mathrm{I}_{\mathrm{WC}}=5.4 \mathrm{~V} / \mathrm{R}_{\mathrm{EXT}}$ ) |
|  | 8 | GND | Ground |
|  | 9 | $\mathrm{V}_{\mathrm{EE} 1}$ | Power Supply ( -5.2 V ) |
|  | 10 | WD | Write Data, driven by complementary signal of CML level. |
|  | 11 | $\overline{\text { WD }}$ | Write Data, driven by complementary signal of CML level. |
|  | 12 | DX |  |
|  | 13 | DY | Data Bus |
|  | 14 | $\overline{\mathrm{RD}}$ | Read/Write mode Switch. When it is at CML low level, read mode is selected, and at high level, write mode is selected. |
|  | 15 | OUT | Output for read data |
|  | 16 | OUT | Output for read data |


| Electrical Characteristics$\left(\mathrm{V}_{\mathrm{EE} 1}=-5.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{EE} 2}=-12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\right)$ |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameters | Symbol | Conditions |  |  | Min. | Typ. | Max. | Unit |
| Power Supply Current | $\mathrm{IEE1}^{1}$ | $\mathrm{V}_{\mathrm{EE} 1}=-5.46 \mathrm{~V}, \mathrm{~V}_{\mathrm{EE} 2}=-12.6 \mathrm{~V}$ |  | 1 | - | - | 65 | mA |
|  | IEE2R |  |  | 1 | - | - | 15 | mA |
|  | $\mathrm{I}_{\text {EE2W }}$ |  |  | 1 | - | - | 10 | mA |
| Input Current | $\underline{\text { I } \overline{\text { I }}}$ | $\mathrm{V}_{\mathrm{EE} 1}=-5.46 \mathrm{~V}$ | $\mathrm{V}_{\text {RD }}=-0.81 \mathrm{~V}$, | 1 | - | - | 0.2 | mA |
|  | IIWD |  | $\mathrm{V}_{\mathrm{WD}}=-0.81 \mathrm{~V}$ | 1 | - | - | 0.9 | mA |
|  | IWD | $\mathrm{V}_{\mathrm{EE} 2}=-12.6 \mathrm{~V}$ | $\mathrm{V}_{\text {WD }}=-0.81 \mathrm{~V}$ | 1 | - | - | 0.9 | mA |
|  | $\mathrm{I}_{\text {IWT }}$ |  | $\mathrm{V}_{\overline{\mathrm{RD}}}=-1.71 \mathrm{~V}$, | 1 | - | - | 0.15 | mA |
| Output Voltage | $\mathrm{V}_{\mathrm{wc}}$ | $V_{\text {RD }}=-0.89 \mathrm{~V}$, | $\mathrm{V}_{\overline{W T}}=-1.75 \mathrm{~V}$ | 1 | 4.9 | 5.4 | 5.9 | V |
|  | $\mathrm{V}_{\text {DXH }}$ | $\begin{aligned} & V_{\overline{R D}}=0.96 \mathrm{~V} \\ & V_{\overline{W T}}=1.65 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\overline{\mathrm{WD}}}=-0.96 \mathrm{~V}$ | 1 | -0.59 | - | -0.45 | V |
|  | $V_{\text {DXL }}$ |  | $\mathrm{V}_{\mathrm{WD}}=-0.96 \mathrm{~V}$ | 1 | -0.75 | - | -0.61 | V |
|  | $V_{\text {DYH }}$ |  |  | 1 | -0.59 | - | -0.45 | V |
|  | $\mathrm{V}_{\text {DYL }}$ |  | $\mathrm{V}_{\overline{\mathrm{WD}}}=-0.96 \mathrm{~V}$ | 1 | -0.75 | - | -0.61 | V |
| DxDy Differential Output Voltage | $\left\|V_{x y}\right\|$ | $\left\|V_{D X}-V_{D Y}\right\|$ |  | 1 | 160 | - | - | mV |
| Voltage Gain | $A_{V}$ | $\mathrm{V}_{1}=100 \mathrm{mV} \mathrm{VPP}, \mathrm{f}=5 \mathrm{MHz}$ |  | 2 | 0.95 | 1.1 | 1.25 | V/V |
| Band Width | BW |  |  | 2 | 30 | - | - | MHz |
|  | $\mathrm{t}_{\text {PLH1 }}$ | $\overline{\mathrm{WT}} \rightarrow \mathrm{RWC}$ |  | 3 | - | - | 350 | ns |
| Delay Time | $\mathrm{t}_{\text {PLH1 }}$ |  |  | 3 | - | - | 100 | ns |
|  | $\mathrm{t}_{\text {PLH2 }}$ | $R D \rightarrow D X, D Y$ |  | 4 | - | - | 200 | ns |
|  | $\mathrm{t}_{\text {PLH2 }}$ |  |  | 4 | - | - | 100 | ns |

## Measurement Diagram

1. 


2.

3.

4.


|  | Bias |  |
| :--- | :--- | :--- |
| Output | $\mathbf{V}_{\text {wD }}$ | $\mathbf{V}_{\text {wD }}$ |
| DX | -0.89 V | -1.75 V |
| DY | -1.75 V | -0.89 V |

## Package Dimensions

Dimensions in inches (millimeters)

16-Lead Ceramic (Cerdip) Dual In-Line Package Dip-16C-C02



## Description

The Fujitsu MB88303 NMOS Television Display Controller (TVDC) is an interface LSI that displays 180 alphanumeric characters ( 20 characters $\times 9$ lines) in white on a TV screen. The characters overlay the picture on the TV screen.

While designed to operate in conjunction with the Fujitsu MB8840/8850 and MB88400/88500 single-chip 4-bit microcomputers, the MB88303 TVDC can also be interfaced to a wide range of 4 - and 8 -bit microprocessors.

The MB88303 allows simple interface to almost any TV display (raster scan CRT with horizontal and vertical scanning) regardless of interlace or non-interlace scan.

The MB88303 is fabricated with N-channel silicon-gate E/D MOS process, and packaged in a 22-pin plastic DIP. Also, it is powered by a single +5 V power supply, and operates over a temperature range of $-30^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$.

Features

- Character display controller available for NTSC, PAL and SECAN TV sets
- 20 character x 9 -line screen format (Max. 180 characters/ screen)
- 5x7-dot matrix character format (1-dot horizontal and 2-dot vertical spacings)
- 64-character set
- Programmable character size: 4 widths and 4 heights
- Programmable display start position: 57 horizontal and 64 vertical positions
- Programmable character blinking control
- Automatic inter-dot filling function for improved smoothness
- Black-level background output for improved clarity
- $180 \times 7$-bit display data RAM
- $448 \times 5$-bit character generator ROM
- Four control registers
- 3-bit general-purpose opendrain latched output
- On-chip clock generator for external RC-network
- Single +5 V power supply
- Wide operating temperature range: $-30^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- N-channel silicon-gate E/D MOS process
- 22-pin plastic DIP (Suffix -P)


Pin Assignment And Logic Symbol



## Block Diagram



| Pin Description | Symbol | Pin No. | Type | Function |
| :---: | :---: | :---: | :---: | :---: |
| Power Supply | $\mathrm{V}_{\text {CC }}$ | 22 | - | +5 V power supply pin. |
|  | $\mathrm{V}_{\text {SS }}$ | 11 | - | Ground pin. |
| Clock | EX | 9 | 1 | RC-network externally connected to these pins from O |
|  | X | 10 | 0 | chip oscillator 6 MHz clock generator. |
| Processor Interface | RESET | 1 | 1 | Reset input: A low level on RESET stops the TVDC and initializes its internal control registers to the following states: Horizontal Display Position Register: Cleared. Vertical Display Position Register: Cleared. Display/Character Control Register : Cleared. (consisting of Horizontal Character Size, Vertical Character Size, and Blinking Registers) General-Purpose Output Register : Set. |
|  |  |  |  | As a result, the output pins are clamped in the following states: VOW = "L", VOB = "H", DO2 = DO1 = DO0 ="H" |
|  |  |  |  | The address register and display memory are not affected by RESET. |
|  |  |  |  | This pin is a non-TTL compatible hysteresis input with an internal pull up. |
|  | ADM | 13 | 1 | Address mode select input for writing data to the internal registers and the display memory: A low level on ADM activates the Direct Address mode. A high level on ADM activates the Address Increment mode. |
|  |  |  |  | This pin is a TTL compatible input with an internal pull up. |
|  | LDI | 12 | 1 | Write strobe input for multiplexed address/data: |
|  |  |  |  | Direct Address Mode: At the leading edge of LDI, an 8-bit address on DA7-DAO is automatically latched into the internal address register. At the trailing edge of LDI, a 7 -bit data on DA6-DA0 is written into an internal control register or an internal display memory location that is designated by the address latched at the leading edge. |
|  |  |  |  | Address Increment Mode: At the leading edge of LDI, the address register is automatically incremented. At the trailing edge of LDI, a 7-bit data on DA6-DA0 is written into an internal control register or a display memory location that is indicated by the address register. |
|  |  |  |  | This is a non-TTL compatible input with an internal pull up. |
|  | DA7-DA0 | 21-14 | 1 | 8-bit parallel multiplexed address/data input: An address/data on DA7-DAO is written into the internal registers or the display memory at the LDI transition. The address/data input format is <br> DA7: the most significant bit (MSB) <br> DAO: the least significant bit (LSB) |
|  |  |  |  | These pins are TTL compatible with internal pull up. |

Pin Description
(Continued)
Television Interface

| Symbol | Pin No. | Type | Function |
| :---: | :---: | :---: | :---: |
|  | 8 | 1 | Horizontal synchronization input: $\overline{\text { HSYNC }}$ pulses are supplied by the TV set connected. This signal is the same as the horizontal sync signal of the TV display, which controls display start position. |
| HSYNC |  |  | The MB88303 starts to output character bit patterns on the VOW output, triggered by HYSNC pulse. |
|  |  |  | This pin is a non-TTL compatible hysteresis input with an internal pull up. |
|  | 7 | 1 | Vertical synchronization input: $\overline{\text { VSYNC }}$ pulses are supplied by the TV set connected. This signal is the same as the vertical sync signal of TV display, which controls display starts position. |
| $\overline{\text { VSYNC }}$ |  |  | The MB88303 starts to output character bit patterns on the VOW output, triggered by VSYNC pulse. |
|  |  |  | This pin is a non-TTL compatible hysteresis input with an internal pull up. |
| vow | 5 | 0 | White-level video signal output: The device serially outputs character dot patterns on VOW synchronously with HYSNC pulses. This signal is used for brightness modulation of the TV display. This signal is superimposed on the normal TV video signal. |
|  |  |  | This pin is a TTL compatible output. |
| $\overline{\text { VOB }}$ | 6 | 0 | Black-level video signal output: This signal is supplied to the TV to improve clarity of displayed characters when BLK and BLKB bits of the blinking register are set. |
|  |  |  | This pin is a TTL compatible output. |
| DO2-DO0 | 4-2 | 0 | 3-bit parallel output port: Data written into the general output register appears on pins $\mathrm{DO}_{2}-\mathrm{DO}_{0}$ |
|  |  |  | These signals are used for other attribute control to TV. |
|  |  |  | These are latched open-drain outputs. |

## Functional Description

## Screen Format and Character Format

The MB88303 TVDC supports the display of 9 lines of 20 characters per line，or a total of up to 180 alphanumeric characters，as shown in Figure 1.

The characters are formed in a $5 \times 7$－dot matrix，with a 1 －dot
space between characters and a 2－dot space between lines． Screen Format also shows the relative on－screen size of the displayed elements．Figure 2 shows the character format．

## Character Patterns and Codes

The MB88303 has a built－in 5 x 7－dot matrix character
generator ROM．Fig．6（a）shows internal character patterns in the character generator，which are automatically modifed by ＂filling＂function and displayed on the screen as shown in Figure 3（b）．The character patterns are encoded as shown in Table 1.

Figure 1．Screen Format



NUMBERS $\mathbf{0}$ to 179 INDICATE DISPLAY MEMORY ADDRESSES．

Figure 2．Character Format


## Note：

Refer to Page 10 for an explanation of the difference between blanks and back－ ground．

Table 1．Character Codes

| $\text { CH3-O } 0$ |  | 1 | 2 | 3 |
| :---: | :---: | :---: | :---: | :---: |
| 0 | A | N | 0 | $\dagger$ |
| 1 | B | 0 | 1 | 1 |
| 2 | C | P | 2 | $\leftarrow$ |
| 3 | D | Q | 3 | $\rightarrow$ |
| 4 | E | R | 4 | ＋ |
| 5 | F | S | 5 | － |
| 6 | G | T | 6 | ＊ |
| 7 | H | U | 7 | 1 |
| 8 | 1 | V | 8 | ＝ |
| 9 | $J$ | W | 9 | \＆ |
| A | K | X | ？ | 年（kanji） |
| B | L | Y | ！ | 月（kanji） |
| C | M | Z |  | $)^{\text {日（kanji）}}$ |
| D | （raised dot） |  |  | （comma） |
| E | $\square$ | － |  |  |
| F | （blank） | ［ | 1 | （Telephone） |

Functional Description （Continued）

Figure 3（a）．Internal Character Dot Patterns
（Character Generator ROM Patterns）

Figure 3（b）．Displayed Character Dot Patterns
（Format with＂Filling＂Function）

## ABCDEFGHIJKLM • $\quad$ I NOPQRSTUUWXYZ：I 0123456789？！＇$\quad$ ）中山 $\leftarrow \rightarrow+$＊／＝\＆年月日，～合

## Functional Description

 (Continued)
## Address Structure

All addresses are 8-bit words. Addresses from 0 [00000000] to 179 [10110011] indicate the display memory locations.
Addresses from 180
[10110100] to 183 [10110111] are used for the control registers. Figure 4 shows the memory map. Selected addresses are input through pins DA7 to DAO. Addresses 184 above cannot be used.

## Display Memory

The display memory is a $180 \times$ 7-bit RAM. Bits 5 to 0 (CH5CHO ) are character code storage; Bit 6 (BC) can be set to " 1 " to enable blinking, and reset to zero to disable blinking.

Figure 5 shows the word structure; refer to Character Codes table for character codes (see page 5). Selected character codes and blinking control bit are input through pins DA6 to DAO.

## Control Registers Horizontal Display Position Register [HP5 to HP0]

This register (address 180) stores the horizontal position of the start of the diplay on the TV screen. The values (000000) to (000110) cannot be used for the horizontal display position register. Since the RESET input clears this register, a value must be set after every RESET input. Figure 6 shows the horizontal display position register. For the display starting position control, see page 9.

## Vertical Display Position Register [VP5 to VP0]

This register (address 181) stores vertical position of the start of the display on the TV screen. Since the RESET input clears this register, a value must be set after every RESET input. Figure 7 shows the vertical display position register. For the display starting position control see page 9.

Figure 4. Display Memory \& Control Register Map

| ADDRESS |
| :--- |

Figure 5. Display Memory Word Format


Figure 6. Horizontal Display Position Register Format


Figure 7. Vertical Display Position Register Format


## Functional Description (Continued)

## Display Control Register

(1) Horizontal Character Size Register [HSZ1 and HSZO]
These bits indicate the width of the characters. Character width is selectable from 4 values determined by setting HSZ1 and HSZO as shown in Table 2. The reset input rests both bits to zero.

Note: $T$ is the period of oscillation frequency $Q$. When the oscillation frequency is Q [ Hz ], the period at that time $\mathrm{T}[\mathrm{s}]$ is $1 / \mathrm{Q}$.
(2) Vertical Character Size Register [VSZ1 and VSZO]
These bits indicate the height of the characters. Character height is selectable from 4 values by setting VSZ1 and VSZ0 as shown in Table 3. The reset input rests both bits to zero.

Note: 1H (horizontal line) $=$ $63.5 \mu \mathrm{~s}$. One screen at non-interlace scan is 262.5 H .
(3) Blinking Register [BLK, BLKB and BLINK]

- Display Blanking Bit [BLK]

This bit indicates the status of the characters display. When BLK is zero, no data is displayed; to enable display, set BLK to " 1 ". The reset input resets BLK to zero.

- Background Blanking Bit [BLKB]
This bit indicates the status of the background display. When BLKB is zero, background is not displayed regardless of data content; to enable background display, set BLKB to 1. The reset input resets BLKB to zero.
- Blinking Enable Bit [BLINK]

This bit turns blinking on and off. When BLINK is zero, blinking is disabled regardless of blink control bit value of the display memory input; when BLINK is " 1 ", blinking is enabled, provided that the blink control bit of the display memory is set to " 1 ". The reset input resets BLINK to zero.

Figure 8. Display Control Register Format


Table 2. Horizontal Character Size

| Code |  | Size |  | Size |
| :---: | :---: | :---: | :---: | :---: |
| HSZ1 | HSZO | Character | Dot | ```Charac- ter (when Q = 6MHz, T=167ns)``` |
| 0 | 0 | 10T | 2 T | $1.67 \mu \mathrm{~s} \quad 0.33 \mu \mathrm{~s}$ |
| 0 | 1 | 20 T | 4 T | $3.34 \mu \mathrm{~s} \quad 0.67 \mu \mathrm{~s}$ |
| 1 | 0 | 30T | 6 T | $5.01 \mu \mathrm{~s} \quad 1.0 \mu \mathrm{~s}$ |
| 1 | 1 | 40T | 8 T | $6.68 \mu \mathrm{~s} \quad 1.34 \mu \mathrm{~s}$ |

Table 3. Vertical Character Size

| Code |  | Size |  |
| :---: | :---: | :---: | :---: |
| VSZ1 | VSZO | Character | Dot |
| 0 | 0 | 14H | 2 H |
| 0 | 1 | 28 H | 4H |
| 1 | 0 | 42 H | 6 H |
| 1 | 1 | 56H | 8 H |

Figure 9. General Output Register Format


Figure 10(a). Direct Address Mode Timing


Functional Description (Continued)

## General Output Register

This is a 3-bit latched output; data written to DO2 to DOO is output to the open drain terminals DO2 to DO0. The reset input sets DO2 to DO0 lines to " 1 ".

## Data Input

MB88303 has two modes for writing data to the control regiskers and display memory. The modes are switched by the ADM input.

## Direct Address Mode

This mode is enabled when input to the ADM terminal is low. When the input signal to the LDI terminal goes high, data on DA7 to DAO are latched to the address register. When the LDI terminal signal goes low, 7 bits of data, DA6 to DAO, are written to the memory specified by the memory address register. Fig. 10(a) is the timing diagram.

## Address Increment Mode

This mode is enabled when input to the ADM terminal is high. When the input signal to the LDI terminal goes high, the data currently latched to the address register are incremented. When the LDI terminal signal goes low, 7 bits of data, DA6 to DA0, are written to the memory specified by the address register after incrementing.
Fig. 10(b) is the timing diagram.

## Reset

1. The following internal registers are cleared by RESET.
Horizontal character size register: HSZ1 = HSZO = "0"
Horizontal display position register:
HP5 to HPO = "0"
Vertical character size register:
VSZ1 = VSZ0 = "0"
Vertical display position register:
VP5 to VPO = " 0 "
Blinking register: BLINK = BLKB = BLK = " 0 "

Figure 10(b). Address Increment Mode Timing


Figure 11. Display Start Position


Note: If $T(s)$ is the period when the oscillating frequency is $\mathrm{fc}(\mathrm{Hz}), \mathrm{H}$ will be equal tolone period of the horizontal synchronization signal.
2. General output register (DO outputs) is set by RESET.
DO2 = DO1 = DO0 = "1" ("H")
3. VOW and $\overline{\mathrm{VOB}}$ outputs are initialized by RESET as follows:
VOW = "L", $\overline{\mathrm{VOB}}=$ "H" (Blanks are displayed on the screen.)
No character is displayed on the TV screen until "BLK" bit (Bit 4 of Blinking Register) is set to " 1 ".
4. Address register and Display data memory are not affected by RESET.

Functional Description
(Continued)

## Display Starting Position Control

The horizontal and vertical display starting points on the TV screen are determined by specifying the position at which the black background display begins. This is done with the values of addresses HP5 to HPO and VP5 to VP0 as shown in Fig. 6 and Fig. 7.

The horizontal starting position HS and the vertical start position VS may be found using the following equations:
HS $=T \times 4\left[2^{5} \times H P 5+2^{4} \times\right.$ $\mathrm{HP} 4+2^{3} \times \mathrm{HP} 3+2^{2} \times \mathrm{HP}^{2}$ $+2 \times \mathrm{HP} 1+\mathrm{HPO})+\mathrm{Pl}$
VS $=\mathrm{H} \times 4\left(2^{5} \times \mathrm{VP} 5+2^{4} \times\right.$
$\mathrm{VP} 4+2^{3} \times \mathrm{VP} 3+2^{2} \times \mathrm{VP} 2+2 \times$ VP1 + VP0)
where: $\mathrm{P}=$ width of character, from Table 4;
$T=1 / \mathrm{fc}[\mathrm{fc}=$ oscillating frequency; 6 MHz typ.] $H=$ period of horizontal synchronization signal [63.5 $\mu \mathrm{s}$ typ.]

## Blinking Control

The MB88303 supports blinking of any desired character(s) on the screen. Blinking affects only those characters for which the blinking bit is set to 1 . Display is on for approximately 0.5 s and off for the same period (vertical synchronization pulse $\times 64$ ).

Table 4. P Values

| HSZ1 | HSZO | P |
| :--- | :--- | :--- |
| 0 | 0 | 9 |
| 0 | 1 | 10 |
| 1 | 0 | 11 |
| 1 | 1 | 12 |

Figure 12(a). Dot Filling Examples


Figure 12(b). Simple $5 \times 7$ Matrix [Left] \& with "Filling" Function [Right]


Blinking can be set as follows:

1. Set the blinking enable bit of the display control register to 1 .
2. Set the blink control bit to 1 for the position of the display memory corresponding to the character for which blinking is desired.

## "Filling" Function

"Filling" is the process whereby dot matrix displays like those in (A) of Fig. 12(a) ' $a$; are filled out to the form shown in (B) by the display of an intermediate dot. As can be seen from Fig. 12(b) "filling" results in a smoother and more pleasing shape than can be attained with an ordinary $5 \times 7$-dot matrix.

Functional Description (Continued)

## Display Output Timing

Fig 13. shows the timing for VOW and VOB for the overlayed portion of a display consisting of the letter " A ", a "blank" (character code OF), "background" (character code 2 E ), and the letter " B ", with the display blinking and background blanking set to 1 .
Note that the display of the background changes during the "BLANK" character when the $\overline{\mathrm{VOB}}$ line goes high.
Difference Between Blanks and Background
Note: In Fig. 14(b) which shows a screen of characters overlaying the picture of a
woman, a blank (character code OF) displays differently from background (character code $2 E$ ), depending on whether $\overline{\mathrm{VOB}}$ is used or not.

In Fig. 14(b) both pictures display the letter " $A$ ", a "blank", a "background", the letter " $B$ ", and a "blank".

In the right picture of Fig. 14(b), where VOB is on, the character displays are bounded by a black frame, so that the spaces between characters display as black. Where a blank is displayed, a $5 \times 7$-dot portion of the TV picture is visible. The
background display is black.

In the left picture of Fig. 14(b), were VOB is off, the TV picture is visible everywhere on the screen except where the characters display in white. Here, blanks and background are displayed identically. Note that the broken lines have been drawn in to indicate where the frames would be displayed if they were displayed on the screen.

Figure 13. Display Output Timing


Fig 14(a). Display of TV Picture


Fig 14(b). Display of Character on TV Picture


Notes:

1. For $\overline{\text { HSYNC }}$ and $\overline{\text { VSYNC }}$ input signals, both cycle and rise/fall times must be constant. 2. Character output during the blanking period of TV should be inhibited. If not, character shapes may change. So, blanks should be written for memory addresses which cannot be displayed on the screen.

Functional Description
(Continued)

Figure 15. Application Example


## Absolute Maximum Ratings

| Parameter | Symbol | Pin | Rating | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{C C}$ | $V_{C C}$ | $\mathrm{V}_{S S}-0.3$ to $\mathrm{V}_{\text {SS }}+7.0$ | V |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | EX, $\overline{\text { RESET, ADM, }}$ <br> LDI, DAT-DAO | $\mathrm{V}_{\mathrm{SS}}-0.3$ to $\mathrm{V}_{\mathrm{SS}}+7.0$ | V |
| Output Voltage | $V_{\text {OUT }}$ | VOW, VOB | $\mathrm{V}_{\mathrm{SS}}-0.3$ to $\mathrm{V}_{\text {SS }}+7.0$ | V |
|  |  | DO0-DO2 | $\mathrm{V}_{S S}-0.3$ to $\mathrm{V}_{\text {SS }}+15$ |  |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ |  | -30 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ |  | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ |  | 600 | mW |

Note: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

Recommended Operating
Conditions

| Parameter | Symbol | Pin | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. | Max. |  |
| Supply Voltage | $\mathrm{V}_{\text {CC }}$ | $V_{C C}$ | 4.5 | 5.0 | 5.5 | V |
|  | $\mathrm{V}_{\text {SS }}$ | $\mathrm{V}_{\text {SS }}$ | - | 0 |  |  |
|  | $\mathrm{V}_{\text {IH }}$ | DA7-DA0, ADM | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |
| Input High Voltage | $\mathrm{V}_{1 \mathrm{HS}}$ | $\begin{aligned} & \text { RESET, } \frac{\text { LDI }}{} \\ & \text { VSYNC, } \end{aligned}$ | 3.0 |  | $\mathrm{V}_{\text {CC }}$ | V |
| Input Low Voltage | $V_{\text {IL }}$ | DA7-DAO, ADM RESET, LDI VSYNC, HSYNC, EX | -0.3 |  | 0.8 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ |  | -30 |  | +70 | ${ }^{\circ} \mathrm{C}$ |
| Operating Clock Frequency | $\mathrm{f}_{\mathrm{c}}$ | EX, X |  |  | 6.7 | MHz |

## DC Characteristics

(Recommended operating conditions unless otherwise noted.)

| Parameter | Symbol | Pin | Value |  |  | Unit | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. | Max. |  |  |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | VOW, $\overline{\mathrm{VOB}}$ | 2.4 | - | - | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A} \end{aligned}$ |
|  |  | DO2-DO0 | Open Drain |  |  |  |  |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | VOW, $\overline{\mathrm{VOB}}$ | - | - | 0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{OL}}=1.8 \mathrm{~mA} \\ & \hline \end{aligned}$ |
|  |  | DO2-DO0 | - | - | 0.4 |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OL}}=1.8 \mathrm{~mA}, \\ & \text { with } 5 \mathrm{k} \Omega \text { external } \\ & \text { pull-up resistor } \end{aligned}$ |
| Output Leakage Current | $\mathrm{I}_{\text {leak }}$ | DO2-DO0 | - | - | 50 | $\mu \mathrm{A}$ | $V_{C C}=5.5 \mathrm{~V}$, <br> $\mathrm{V}_{\mathrm{OH}}=13.2 \mathrm{~V}$, <br> at OFF state with with $5 \mathrm{~K} \Omega$ external pull-up resistor |
| Input Leakage Current | $I_{\text {IL }}$ | RESET, LDI, ADM, VSYNC, HSYNC, DA7-DAO | - | - | -60 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V} \end{aligned}$ |
| Supply Current | ${ }^{\text {ICc }}$ | $\mathrm{V}_{\mathrm{Cc}}$ | - | 80 | 120 | mA | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, <br> All outputs open, <br> $\mathrm{f}_{\mathrm{c}}=6.7 \mathrm{MHz}$, <br> reset state |

## AC Characteristics

(Recommended operating conditions unless otherwise noted.)

| Parameter | Symbol | Pin | Value |  | Unit | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. |  |  |
| LDI Pulse Width | $t_{\text {WLDI }}$ | LDI | 5 |  | $\mu \mathrm{s}$ | Fig. 15, Fig. 18 |
| LDI Rise/Fall Time | $\begin{aligned} & \mathrm{t}_{\mathrm{rLDI}} \\ & \mathrm{t}_{\mathrm{fLDI}} \\ & \hline \end{aligned}$ | LDI |  | 1 | $\mu \mathrm{s}$ | Fig. 15, Fig. 18 |
| ADM Setup Time | $\mathrm{t}_{\text {AS }}$ | ADM | 0.5 |  | $\mu \mathrm{s}$ | Fig. 15, Fig. 18 |
| ADM Hold Time | $t_{\text {AH }}$ | ADM | 2 |  | $\mu \mathrm{s}$ | Fig. 15, Fig. 18 |
| Address/Data Setup Time | $t_{\text {S }}$ | DA0 to DA7 | 0.5 |  | $\mu \mathrm{s}$ | Fig. 15, Fig. 18 |
| Address/Data Hold Time | $\mathrm{t}_{\mathrm{H}}$ | DA0 to DA7 | 2 |  | $\mu \mathrm{s}$ | Fig. 15, Fig. 18 |
| DO Output Delay Time | $t_{\text {DD }}$ | DO0 to DO2 |  | 0.6 | $\mu \mathrm{s}$ | Fig. 16, Fig. 18 |
| RESET Pulse Width | $\mathrm{t}_{\text {RST }}$ | RESET | 4 |  | $\mu \mathrm{s}$ | Fig. 17, Fig. 18 |
| RESET Setup Time | $\mathrm{t}_{\text {RSTS }}$ | RESET | 1 |  | $\mu \mathrm{s}$ | Fig. 17, Fig. 18 |
| RESET Hold Time | $\mathrm{t}_{\text {RSTH }}$ | RESET | 3 |  | $\mu \mathrm{s}$ | Fig. 17, Fig. 18 |

Figure 15. Address/Data Input Timing


I] DONT Care

Figure 16. DO Output Timing


Figure 17. $\overline{\text { RESET Input Timing }}$


Notes:

1. If $\mathrm{t}_{\mathrm{RSTS}}$ spec. ( $1 \mu \mathrm{~s}$ min.) is not met, the MB88303 cannot be reset.
2. If $\mathrm{t}_{\mathrm{RSTH}}$ spec. ( $3 \mu \mathrm{~s}$ min.) is not met, then the TV screen will be disturbed. This is caused by the undefined data on the DA line written into internal registers and display memory at LDI's high-to-low transition during RESET = " $L$ ". This case occurs, for example, when RESET goes high just after LDI goes low, shown at top, right diagram. This unacceptable RESET timing is caused when the device is reset separately from the processor connected to the device. However, when LDI level is fixed high or low during reset (i.e. $\overline{R E S E T}=$ " $L$ ") shown at bottom right diagram, the TV screen is not disturbed.

LDI


Figure 18. AC Test Conditions

## Input Conditions

TIming Reference Levels:
3.0V for a logic " 1 " (RESET, LDI)

2.0V for a logic "1" (ADM, DA7-DA0)
0.8 V for a logic " 0 "

## Output Conditions

## Timing Reference Levels:

2.4 V for a logic "1"
0.4 V for a logic " 0 "

## Output Load CIrcuit:

$R_{L}=4 k \Omega$
$\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$
(including scope and jig capacitances)
*with external $5 \mathrm{k} \Omega$ pull-up resistor at DO2-DO0
for $t_{D D}$


Figure 19. RC-Network Oscillator Circuit


Note: The clock frequency (fc) has wide variation from device to device. The clock frequency also considerably depends on the ambient temperature and supply voltage.
Therefore, to limit the clock frequency within the specified range, it is required to adjust it with the external resistor in advance.

I/OCircuit Configuration

| Pin | Type | Circuit Diagram |
| :--- | :--- | :--- |$\quad$| Characteristics |
| :--- |

Package Dimensions Dimensions in inches (millimeters)

22-Lead Plastic Dual In-Line Package DIP-22P-M02



## MB88313 <br> CMOS Television Display Controller (TVDC)

## DESCRIPTION

The Fujitsu MB88313 CMOS Television Display Controller (TVDC) is a programmable interface LSI device, which displays 16 alphanumeric and symbol characters of a 32 -character set in four colors on a standard color TV (NTSC, PAL, SECAM, etc.) screen under control of a general 4 or 8 -bit microcomputer.

The MB88313 contains a display memory ( $16 \times 8$ bit static RAM), an address counter, six programmable control registers, a character generator ( $5 \times 7 \times 32$-bit mask ROM), and a clock generator. 16 characters, of which codes are written into the display memory, and displayed on the TV screen, superimposed on the picture. Various screen features, such as screen format, character size, display start position, character attributes (color and blink), are controlled by programming the control registers using control commands serially loaded by the processor. The standard TVDC's character generator contains the Fujitsu standard character set. User designed character patterns are also acceptable on the mask ROM. The on-chip clock generator oscillates with an external RC or LC network.

The MB88313 is fabricated with the silicon-gate CMOS process, and packaged in a standard 16-pin plastic DIP or SOP. It operates with a single +5 V power supply and 7 MHz clock over the ambient temperature range of $-30^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$.

The MB88313 is suitable for display of simple character information on the TV screen, such as TV channel numbers, voice volume, VTR tape remainder and recording date and time, for which LCD or LED displays have been used.

## FEATURES

- External synchronization type character display controller
- Display method: Characters are superimposed on the picture of a TV screen synchronized with TV HSYNC and VSYNC signals
- Command drive method: Display memory and internal registers are programmed by eight 8 -bit control commands serially loaded by the processor
- Programmable screen format:
-8 characters $\times 2$ lines
-16 characters $x 1$ line
- Fixed character format: $5 \times 7$ dot matrix with automatic rounding function
- 32 mask programmable character patterns:
-Fujitsu standard character set
-User-designed character set


Plastic DIP (Suffix -P) DIP-16P-M02


Plastic SOP (Suffix -PF) FPT-16P-M02

FEATURES (Continued)

- Programmable character size:
-4 selections for width
-4 selections for height
- Programmable display position:
-29 selections for horizontal position
-31 selections for vertical position
- Programmable screen controls:
-Screen format control
-Background control
-Blink control
-Color control
- Interfaceable to general 4 \& 8-bit microprocessors
- Interfaceable to standard color TV (NTSC, PAL, SECAM, etc.), standard monochrome TV sets, and interlace \& non-interlace CRTs
- Seven programmable registers [address counter \& control registers]
- $5 \times 7 \times 32$-bit mask ROM [character generator]
- $16 \times 8$-bit static RAM [display memory]
- On-chip clock generator for external RC/LC components
- Silicon-gate CMOS process
- Single +5 V power supply
- TTL compatible I/O ports
- Up to 7 MHz clock
- $-30^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ operating temperature range
- Two package options:
-16-pin DIP (Suffix -P)
-16-pin SOP (Suffix -PF)

PIN ASSIGNMENT AND LOGIC SYMBOL


8313-3
This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.


8313-4

## BLOCK DIAGRAM



## PIN DESCRIPTION

The MB88313 TVDC has two interfaces: One is the processor interface consisting of, $\overline{\text { CS, SCLK, and SI inputs which are used for the }}$ processor to serially load control commands into the TVDC. The other is the television interface, consisting of, HSYNC and VSYNC inputs and VOC, VOB and DO2-DOO outputs which are used for the TVDC to display characters on the TV screen.

## Table 1. Pin Description

| Symbol | Number | Type | Name \& Function |  |
| :--- | :---: | :---: | :--- | :--- |
| - Power Supply \& Clock |  |  |  |  |
| $\mathrm{V}_{\mathrm{CC}}$ | 16 | - | +5 V dc power supply pin. |  |
| $\mathrm{V}_{\mathrm{SS}}$ | 8 | - | Power supply ground pin. |  |
| EX <br> X | 7 | 1 | Oscillator input/output: With an external capacitor (C) and resistor (R) or, inductor (L) <br> and capacitors (C) connected to the EX and X pins, the on-chip oscillator generates <br> the internal clock. A clock frequency is determined by the values of R and C, or L and C . |  |
| TEST | 6 | 0 | O | Test output: This output pin is enabled in the test mode, which is used for the shipping <br> test purposes only at Fujitsu. In the normal operation mode, this output pin is low, <br> and may be left open. |

## - Processor Interface

| RESET | 1 | 1 | Reset input: A low level on the $\overline{\text { RESET pin stops the TVDC's operations, initializes the }}$ <br> internal control registers and clamps the outputs as follows: <br> 1. Horizontal/vertical character size registers, horizontal/vertical display position <br> registers, screen control register and general output register are all cleared. <br> 2. All inputs are inactive. <br> 3. VOC and DO2-DOO output pins are clamped low, and $\overline{\text { VOB }}$ is clamped high. <br> The display memory is not affected by the $\overline{\text { RESET. The command shift register, }}$ <br> command register and address counter are undefined after a reset. <br> After the $\overline{\text { RESET pin is driven high, the TVDC restarts its display operations. This pin is }}$ <br> a hysteresis input. |
| :--- | :---: | :---: | :---: |
| $\overline{\text { CS }}$ | 3 | 1 | Chip select input: A low level on the $\overline{\text { CS pin resets the internal SCLK counter, and }}$ <br> enables the command shift register to receive serial data through the SI input pin. |
| SCLK | 4 | I | Shift clock input: The rising edge of the SCLK moves data on the SI pin into the <br> command shift register, and also increments the internal SCLK counter. |
| SI | 5 | 1 | Serial command input: A command bit on the SI pin is shifted into the MSB of the <br> command shift register at the rising edge of the SCLK. At the eighth rising edge, which <br> is counted by the internal SCLK counter, an 8-bit command word is latched into the <br> command register. |

- Television Interface

| $\overline{\text { HYSNC }}$ | 14 | 1 | Horizontal sync input: Horizontal synchronization pulse signal (negative pulse) provided <br> by TV set should be applied to this input pin. The TVDC outputs character and <br> background signals (VOC and $\overline{\text { VOB }) ~ s y n c h r o n o u s l y ~ w i t h ~ t h i s ~ s i g n a l . ~ T h i s ~ p i n ~ i s ~ a ~}$ <br> hysteresis input. |
| :---: | :---: | :---: | :--- |
| $\overline{\text { VSYNC }}$ | 15 | 1 | Vertical sync input: Vertical synchronization pulse signal (negative pulse) provided by <br> TV set should be applied to this input pin. The TVDC outputs character and background <br> signals (VOC and $\overline{\text { VOB) synchronously with this signal. This pin is a hysteresis input. }}$ |

PIN DESCRIPTION (Continued)

| Symbol | Number | Type |  |
| :---: | :---: | :---: | :---: |
| VOC | 10 | 0 | Name \& Function <br> $\overline{\text { VOB }}$ <br> Video output for character: This pin outputs a high level for character dot patterns, and <br> is clamped low during the reset mode, standby mode, and non-display mode, <br> disabling character display on the TV screen. |
| DO2-DOO | 9 | 0 | Video output for background: This pin outputs a low level for background or edge <br> portion of character dot matrix during the background or edge mode, respectively. <br> The $\overline{\text { VOB output is clamped high during the reset mode, standby mode, non-display }}$ <br> mode, and non-background/edge mode, disabling background and edge displays on <br> the TV screen. |
| $13-11$ | $O$ | Data outputs: These outputs are controlled by the GOC bit: When GOC $=0$ (i.e., the <br> general output mode), a 3-bit data in the on-chip general output register is output at <br> these output pins. These are used for general control outputs. When GOC $=1$ (i.e., the <br> color display mode), the attribute code bits AC1 and ACO are output at the DO1 and <br> DOO pins, respectively. These are used as color control data. The remaining bit of the <br> general output register appears at the DO2 pin. |  |

## BLOCK DESCRIPTION

## Refer to Block Diagram on page 3.

The MB88313 TVDC contains the following main functional blocks:

- Clock generator
- Character generator
- Display memory
- Address counter
- Command shift register and

Register command register

- Six control registers


## Clock Generator

The MB88313 has an on-chip clock generator, which provides a basic timing clock to internal circuits. The clock frequency is determined by external RC or LC network.

For synchronization, the clock supply to the internal circuit is stopped while the HSYNC is low. The clock generator is stopped during the standby mode, which is initiated by software (Command 6).

## Character Generator

The MB88313 has a $5 \times 7 \times 32$ bit mask ROM as a character generator, which stores thirty-two $5 \times 7$-dot character patterns encoded into character codes. The character generator defines a character set. The standard MB88313 has the Fujitsu standard character set shown in Figure 15. Those characters are indicated by character codes shown in Table 5. A user-designed character set is also programmed on the mask ROM using metal option. But character codes, (OF)H and (1F)H are reserved as "blank" and "background" codes.

## Display Memory

The MB88313 has a $16 \times 8$ bit static RAM as a display memory, which stores 16 character codes and their attribute codes to be displayed on the TV screen. The 16 memory locations are addressed by a 4 -bit address counter (A3-A0). Figure 1 shows the display memory map: Each memory word is divided into two fields: The lower 5 bits ( $\mathrm{CH} 4-\mathrm{CH} 0$ ) defines a character code, and the upper 3 bits (AC2-AC0) defines its attribute codes (color code and blink code). Each field of a word addressed by the address counter is written separately by the processor using Commands 0 and 6 respectively. See Table 1. The display memory is not affected by RESET, and is retained during the standby mode.

## Register Set

The MB88313 contains a register set consisting of an address counter, command shift register, command register, and six control registers, which are programmed using control commands or directly loaded by the processor. See Table 1.

## Command Shift Register and Command Register (CM7CMO)

The command shift register is an 8 -bit serial-in/parallel-out shift register that assembles serial command bits (provided by the processor through the SI input synchronously with the SCLK input) into an 8 -bit command word during the command load operation.

The command register is an 8 -bit write-only register that holds control commands transferred in parallel from the command shift register. The transferred 8 -bit command word is output to

## MB88313

## BLOCK DESCRIPTION (Continued)

the command decoder to generate internal control signals. Figure 2 shows the command shift register and command register configuration.

Both registers are undefined after a reset, and hold the current state during the standby mode.

## Address Counter (A3-AO)

The address counter is a 4-bit binary counter which addresses a display data memory location written by Commands 0 and 6. The address counter is preset by Command 1, and is automatically incremented by Command 0 . Figure 3 shows the address counter format. The address counter is undefined after a reset, and holds the current state during the standby mode.

## Horizontal Display Position Register (HP4-HPO)

The horizontal display position register is a 5 -bit write-only register which selects one of 29 horizontal positions from where the first character (including blank and background) begins to appear on the screen. This control register is programmed by the processor using Command 2, and cleared by RESET. Figure 4 shows the horizontal position register format. During the standby mode, this register holds the current state.

## BLOCK DESCRIPTION (Continued)

## Vertical Display Position Register (VP4-VP0)

The vertical display position register is a 5 -bit write-only register which selects one of 31 vertical positions from which the first character (including blank and background) begins to appear on the screen. This control register is programmed by the processor
using Command 3, and is cleared by RESET. Figure 5 shows the vertical position register format. During the standby mode, this register holds the current state.


Figure 3. Address Counter Format
MSB

| A3 | A2 | A1 | AOB |
| :---: | :---: | :---: | :---: |

Note:
Address counter is programmed by Command 1.
Figure 4. Horizontal Position Register Format
MSB

| HP4 | HP3 | HP2 | HP1 | HPO |
| :--- | :--- | :--- | :--- | :--- |

Figure 5. Vertical Position Register Format


Notes:

1. $\left.V P=H \times 4 \times\left(2^{5} V P 4+2^{4} V P 3+2^{3} V P 2+2^{2} V P 1+2 V P 0\right)+1\right)$ Where, VP: Vertical display start position; referred to the rising edge of VSYNC
H : Horizontal sync cycle time; $\mathrm{H}=63.5$ [ $\mu \mathrm{s}$ ]
2. Vertical position register is programmed by Command 3.

Notes:

1. $\mathrm{HP}=\mathrm{T} \times\left(4 \times\left(2^{5} \mathrm{HP} 4+2^{4} \mathrm{HP} 3+2^{3} \mathrm{HP} 2+2^{2} \mathrm{HP} 1+2 \mathrm{HPO}\right)+\mathrm{P}\right)$

Where, $P=10,11,12$ and 13 for (HS1, HSO) $=(0,0),(0,1),(1,0)$ and
$(1,1)$, respectively
HP: Horizontal display start position; referenced to the rising edge of HSYNC
$T$ : Clock Cycle time; $T(S)=1 / \mathrm{fc}[\mathrm{Hz}]$
2. Horizontal position register is programmed by Command 2.

Table 3. DO Outputs in Color Dispiay Mode

| Video Signal |  | DO Outputs |  |  | Display |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { VOB }}$ | VOC | D02 = $\mathbf{C O 2}$ | D02 = AC1 | DOO = ACO |  |
| X | 1 | X | 0 | 0 | Character |
|  |  |  | 0 | 1 |  |
|  |  |  | 1 | 0 |  |
|  |  |  | 1 | 1 |  |
| 1 | 0 | 0 | 0 | X | Blank |
| 0 |  |  |  |  | (Background) |

## BLOCK DESCRIPTION (Continued)

## Horizontal Character Size Register (HS1 and HSO)

The horizontal character size register is a 2 -bit write-only register which selects one of 4 character widths. This control register is programmed by the processor using Command 4, and cleared by RESET. Figure 6 shows the horizontal character size register format. During the standby mode, this register holds the current state.

## Vertical Character Size Register (VS1 and VSO)

The vertical character size register is a 2 -bit write-only register which selects one of 4 character heights. This control register is programmed by the processor using Command 4, and cleared by RESET. Figure 7 shows the vertical character size register format. During the standby mode, this register holds the current state.

## Screen Control Register (SC4-SC0)

The screen control register is a 5 -bit write-only register which controls screen features: Screen format, display mode, and blinking. This control register is programmed by the processor using Command 5, and cleared by RESET. Figure 8 shows the screen control register format and bit functions. During the standby mode, this register holds the current state.

## Note:

When the display is disabled (SCO $=0$ ), the background must be also disabled (SC1 = 0).

## General Output Register (GO2-GO0)

The general output register is a 3-bit write-only output register which latches 3 -bit output data written into by Command 7. Depending on the general output register control bit GOC, the TVDC has two output modes for the DO2-DOO pins. During the general output mode ( $G O C=$ " 0 "), the latched data appears at

Figure 6. Horizontal Character Size Register Format


| Horizontal <br> Size Code | Horizontal <br> Character <br> Size (Width) | Horizontal <br> Dot Size |  |
| :--- | :--- | :--- | :--- |
| HS1 | HSO | 10 T | $2 T$ |
| 0 | 0 | $20 T$ | $4 T$ |
| 0 | 1 | $30 T$ | $6 T$ |
| 1 | 0 | $40 T$ | $8 T$ |
| 1 | 1 |  |  |

## Notes:

1. T: Clock cycle time; $T[s]=1 / \mathrm{fc}[\mathrm{Hz}]$
2. Horizontal character size register is programmed by Command 4.

| Figure 7. Vertical Character Size Register Format |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB | LSB |  |  |  |  |  |
| VS1 | VSo |  |  |  |  |  |
|  |  | Vertical Size Code |  | Vertical Character Size (Height) | Vertical Dot Size |  |
|  |  | VS1 | VSO |  |  |  |
|  |  | 0 | 0 | 14H | 2H |  |
|  |  | 0 | 1 | 28 H | 4H |  |
|  |  | 1 | 0 | 42H | 6H |  |
|  |  | 1 | 1 | 56 H | 8 H | 8313-8 |
| Notes: |  |  |  |  |  |  |
|  |  | 1. H: Horizontal sync cycle time; $\mathrm{H}=63.5$ [ $\mu \mathrm{s}$ ] <br> 2. Vertical character size register is programmed by Command 4. |  |  |  |  |

BLOCK DESCRIPTION (Continued)


Screen control register is programmed by Command 5 .


## BLOCK DESCRIPTION (Continued)

the DO2-DOO output pins. During the color display mode (GOC $=$ " 1 "), the color code bits AC1 and AC0 stored in each attribute field of the display memory are automatically output on the DO1 and the DO0 pins respectively while the VOC output is high. When the VOC is low, the DO1 and DOO pins are clamped low. The GO2 bit only appears at the DO2 in the color display mode. See Table 3. Controlling RGB signals by the DO1 and DOO and VOC, four-colored characters can be displayed.

This control register and control bit GOC are programmed by the processor using Command 7, and cleared by RESET. Figure 9 shows the general output register format. During the standby mode and non-display mode, the DO2-DOO output are clamped low, regardless of the general output mode or the color display mode.

## FUNCTIONAL DESCRIPTION

The MB88313 TVDC is an external synchronization type programmable character display controller. Under control of a 4 or 8 -bit general microprocessor, it displays 16 characters of 32 character set with various character attributes (color and blink)
and screen features (screen format, character size, and display position) on a standard monochrome or color TV screen, superimposed on the picture. The MB88313 can interface to NTSC, PAL and SECAM standard color TV set, and also to the raster scan type CRT, regardless of interlace or noninterlace scan.

The MB88313 has three operation modes; the active mode, standby mode and reset mode. The active mode operations are described on pages 10-16. Both Standby mode operations, and Reset mode operations are described starting on page 17.

## Active Operations

Character \& attribute codes and feature control codes are written into the on-chip display memory and control registers by the processor using control commands, respectively. The control commands are serially loaded into the on-chip command register through the processor interface pins, $\overline{\text { CS, SCLK, and SI. Accord- }}$ ing to the programmed character \& attribute codes and control codes, the MB88313 issues the character \& background video signals from the VOC and VOB pins synchronously with HSYNC and VSYNC, signals provided by the TV set. Also, the DO2DOO outputs are used as color control or other general control signals to the TV set.

## INPUT/OUTPUT CIRCUITS

| TYPE | PIN | MB88306/308 | MB88307/309 |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { n } \\ & \\ & \hline \underline{\mathbf{n}} \end{aligned}$ | $\begin{aligned} & \overline{\overline{O O A D}} \\ & \mathrm{SC}(\overline{\mathrm{SC}}) \\ & \overline{\operatorname{RESET}} \end{aligned}$ | HYSTERESIS INPUT |  |
|  | $\begin{aligned} & \overline{O E} \\ & \mathrm{SI} \end{aligned}$ |  |  |
| $\begin{aligned} & \frac{n}{2} \\ & \frac{1}{5} \end{aligned}$ | $0_{7}-0_{0}$ | CMOS 3-STATE OUTPUT | NMOS OPEN-DRAIN OUTPUT |
|  | So |  | NMOS OPEN-DRAIN OUTPUT |

## FUNCTIONAL DESCRIPTION (Continued)

## Command Load Operation

The processor serially loads 8 -bit commands into the TVDC's command shift register using the processor inputs, CS, SCLK and S!. The loaded command is parallel latched into the command register. According to the command, control data is written into a designated memory location, address counter, or control register.

Figures 10 and 11 show the command register configuration and command load timing: A low level on the CS pin initializes the SCLK counter and enables the command shift register to receive command words. Then, synchronously with the SCLK shift clock input, an 8 -bit command word is serially loaded into the command shift register through the SI input pin. At the rising edge of SCLK, a command bit on the SI pin is shifted into the MSB of the command shift register and at the same time the command shift register bits are right shifted. The rising edge of SCLK is
counted by the SCLK counter, and at the eighth rising edge, the 8 -bit command word is latched into the command register, where the first-in bit is the LSB and the last-in bit is the MSB. After that, the command is decoded to generate internal control signals.
Note:
In successive command loading a few hundred ns after completion of one command loading, the next loading should not be made.

## Display Operations

According to programmed display memory and control registers, the MB88313 issues video signals, VOC and VOB for character patterns synchronously with HSYNC and VSYNC signals supplied by the TV set, and also outputs feature control signals on the DO2-DOO pins.


Figure 11. Command Load Timing


FUNCTIONAL DESCRIPTION (Continued)

## Screen Format Control

The MB88313 can display 16 characters in the format of 16 characters $x 1$ line (with one-dot horizontal spacing) or 8 characters $\times 2$ lines (with one-dot horizontal \& two-dot vertical spacings) on the TV screen. Either format can be selected by controlling the SC3 bit using Command 5: SC3 = " 1 " for 16 characters $\times 1$ line, and SC3 = " 0 " for 8 characters $\times 2$ lines. Figure 12 shows the two screen formats.

## Character Format and Automatic Rounding Function

The character patterns are formatted as $5 \times 7$ dot matrix, stored in the on-chip character generator mask ROM. Figure 13 shows the character format. But, on the actual TV screen, this format is modified by the automatic rounding function. See Figure 14-1: When the internal original dot pattern (i.e., raw output signal from the character generator) contains diagonally aligned dots, a dot is automatically inserted between every diagonal dot to
smooth the character form. Figure $14-2$ shows an example of this rounding function.

## Character Patterns and Codes

The MB88313 has a character set of 32 character patterns, which is defined by the on-chip character generator mask ROM. Figure 15 shows the standard character set. Each character pattern is encoded as shown in Table 5. The MB88313 can also have user-designed character set (except blank and background) by programming the mask ROM.

## Display Mode Control (Character/Background Control)

One of four display modes can be selected by the five screen control bits SC4-SCO using Command 5, as shown in Table 4. Figure 16 shows examples of the display states, as well as the VOC and $\overline{V O B}$ output timing signals on line $A A^{\prime}$ for character codes of 1, 2, blank, background, 3, and 4 in the three display modes, except the non-display mode.

Figure 12. Screen Format


Note:
Each box represents one character display area ( $5 \times 7$ dots). The hexadecimals represent display memory addresses.
Table 4. Display Mode Control

| Screen Control Bits |  |  |  |  | Display Modes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SC4 | SC3 | SC2 | SC1 | sco |  |
| X | X | X | X | 0 | Non Display Mode: No characters nor background are displayed |
| X | 0 | X | 0 | 1 | Non-Background/Edge Mode: Characters are displayed, nor background |
| X | 0 | 0 | 1 | 1 | Edge Mode: Edged characters are displayed |
| X | 0 | 1 | 1 | 1 | Background Mode: Characters with black background are displayed |

## FUNCTIONAL DESCRIPTION (Continued)

## Display Start Position Control

The horizontal and vertical display start positions on the TV screen are defined by the horizontal and vertical display position registers. Programming these control registers using Commands 2 and 4, the display start position (HP, VP) can be determined. For the horizontal position, 29 selections, and for the vertical position, 31 selections are possible. Figure 17 shows the definition of the display start position.

The horizontal display start position HP (from the rising edge of HSYNC to the falling edge of VOB) and the vertical display start position VP (from the rising edge of VSYNC to the falling edge of $\overline{\mathrm{VOB}}$ ) are calculated from programmed values of HP5 to HPO and VP5 to VPO using the following equations:
$H P=T \times 4 \times\left[\left(2^{5} \times H P 5+2^{4} \times H P 4+2^{3} \times H P 3+2^{2} \times\right.\right.$ $H P 2+2 \times H P 1+H P O)+P]$
$V P=H \times 4 \times\left(2^{5} \times V P 5+2^{4} \times V P 4+2^{3} \times V P 3+2^{2} \times\right.$ $V P 2+2 \times V P 1+V P 0)$

Where: $P=9,10,11,12$ for (HS1, HSO) $=(0,0),(0,1),(1,0)$, and $(1,1)$ respectively
$\mathrm{T}=$ Clock (oscillation) cycle time [ 7 MHz max.]
$H=$ Horizontal sync cycle time [63.5 $\mu \mathrm{s}$ typ.]

## Character Size Control

The character width and height on the TV screen are defined by the horizontal and vertical character size registers. Programming these control registers using Command 4 , the character size can be determined. As shown in Tables 6 and 7, 4 selections are possible for each of the horizontal and vertical sizes.

Figure 14-1. Automatic Rounding Function (Algorithm)
Algorithm (I)


## Blink Control

The MB88313 can blink any desired character(s) on the TV screen. Blinking function is enabled when the SC4 bit of the screen control register is set to " 1 ". Blinking effects only those characters for which the AC2 bit (blink control bit) is set to " 1 ". Blinking characters appear for approximately 0.5 s and disappear for the same period (vertical sync pulse cycle time $\times 64$ ).

Blinking can be set as follows:

1. Preset a display memory address where the character blink is required, using Command 1.
2. Set the AC2 bit (blink control bit) of the location of the address, using Command 6.
3. Set the SC4 bit (blink enable bit) of the screen control register, using Command 5.


Figure 14-2. Automatic Rounding Function (Example)
internal dot pattern

displayed dot pattern


FUNCTIONAL DESCRIPTION (Continued)


Table 5. Standard Character Codes


FUNCTIONAL DESCRIPTION (Continued)


## FUNCTIONAL DESCRIPTION (Continued)



Table 6. Horizontal Character Size

| Horizontal Size Code |  | Horizontal <br> Character Size (Width) | Horizontal Dot 8Ize |
| :---: | :---: | :---: | :---: |

Note:
T: Clock cycle time
$\mathrm{T}[\mathrm{s}]=1 / \mathrm{fc}[\mathrm{Hz}]$
Table 7. Vertical Character Size

| Vertical Size Code |  | Vortical <br> Character Size (Height) | Vertical Dot Size |
| :---: | :---: | :---: | :---: |
| vs1 | vso |  | 2 H |
| 0 | 0 | 28 H | 4 H |
| 0 | 1 | 42 H | 6 H |
| 1 | 0 | 56 H | 8 H |
| 1 | 1 |  |  |

## Note:

H: Horizontal sync cycle time $\mathrm{H}=63.5[\mu \mathrm{~s}]$

MB88313

Functional Description (Continued)

## Color Control

The MB88313 has a color display mode, in which color control signals are output on the DO1 and DO0 pins, in addition to the VOC and VOB signals. The color display mode is initiated by setting the GOC bit to " 1 " using Command 7. During this mode, the color code bits AC1 and ACO stored in each attribute field of the display memory are automatically output on the DO1 and DOO pins respectively, while the VOC output is high. When the VOC is low, the color control signals are clamped low. Controlling RGB signals of the color TV set by the VOC, DO1 and DOO signals, characters are displayed in four of eight colors shown in Table 8. One of four colors is selected for each character by writing color codes to each attribute field of the display memory. Four colors to be displayed are selected by a combination of connections between MB88313's VOC/DO1/DO0 and TV's RGB pins.

Figure 18 shows an example circuit for selecting character colors: green, cyanogen, yellow and white.

In this example circuit, the $\overline{\mathrm{VOB}}$ (background) signal is used to inhibit all TV color video signals $\mathrm{R}^{\prime} \mathrm{G}^{\prime} \mathrm{B}^{\prime}$ simultaneously. When
the $\overline{\mathrm{VOB}}$ is low, the $R^{\prime} G^{\prime} B^{\prime}$ signals are all disabled to create a black background. When the VOB is high, the $\mathrm{R}^{\prime} \mathrm{G}^{\prime} \mathrm{B}^{\prime}$ signals are enabled to display TV signal. The VOC (character) signal and the DO1 \& DO0 (i.e., AC1 \& AC0) color code outputs are used to enabie coior character signals R, G, B, respectively, RGB and $R^{\prime} G^{\prime} B^{\prime}$ signals control $(R)(G)(B)$ signals of the CRT in parallel.

Table 8. Displayable Colors

| $\mathbf{R}$ | $\mathbf{G}$ | $\mathbf{B}$ | Displayed Colors |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | Black |
| 0 | 0 | 1 | Blue |
| 0 | 1 | 0 | Green |
| 0 | 1 | 1 | Cyanogen |
| 1 | 0 | 0 | Red |
| 1 | 0 | 1 | Magenta |
| 1 | 1 | 0 | Yellow |
| 1 | 1 | 1 | White |

Figure 18. TV Interface Configuration (Example)


FUNCTIONAL DESCRIPTION (Continued)
Table 9. Color Control (in Color Display Mode: GOC = "1")

| Video Signals |  | Color Control Codes |  | Displayed Colors |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { VOB }}$ | VOC (G) | $\mathbf{A C 1 ~ = ~ D 0 1 ~ ( R ) ~}$ | $\mathbf{A C O}=\mathbf{D O O}(\mathrm{B})$ |  |
| X | 1 | 0 | 0 | Green (RB: disabled) |
|  |  | 0 | 1 | Cyanogen (R: disabled) |
|  |  | 1 | 0 | Yellow (B: disabled) |
|  |  | 1 | 1 | White (RGB: enabled) |
| 1 | 0 | 0 | 0 | Blank (RGB: disabled, $\mathrm{R}^{\prime} \mathrm{G}^{\prime} \mathrm{B}^{\prime}$ : enabled) |
| 0 |  | 0 | 0 | Black (Background) (RGB and $\mathrm{R}^{\prime} \mathrm{G}^{\prime} \mathrm{B}^{\prime}$ : disabled) |

## Standby Operation

The MB88313 has a low power standby mode (i.e., clock stop mode) which is initiated by software. A logic " 1 " on the STP bit stops the on-chip clock generator, reducing the power dissipation, and sets the internal states and input/output pin states, as follows:

1. All internal control registers, display memory, address counter, and command shift \& command registers keep their current states.
2. All input pins are inactive.
3. Output pins hold the states before the standby mode.

During the standby mode, characters disappear on the TV screen.

When the STP bit is reset to " 0 ", the clock generator restarts, and characters reappear on the screen. The STP is controlled by Command 6 .

## Notes:

1. When the STP bit is reset and the clock generator restarts, the vertical display position of each character is disturbed in the first screen field. To avoid this problem, the following procedure is recommended when resetting the STP bit:
1) Before resetting, disable the screen display, resetting the SCO bit with Command 5 .
2) Reset the STP bit using Command 6.
3) At least 16.7 ms after resetting the STP bit, set the SC0 bit, enabling the screen display.
2. When set/reset the STP bit using Command 6, the AC2-ACO bits addressed by the current address counter may change also.

## Reset Operation

A low level on the RESET pin stops the TVDC's operations, and initializes its internal control registers and input/output pins to the following states:

1. All internal control registers are cleared.
2. All input pins are inactive.
3. VOC and DO2-DO1 output pins are clamped low, and $\overline{\mathrm{VOB}}$, clamped high.

The display memory data is not affected by RESET. The command shift register, command register, and address counter are undefined after RESET.

During the reset mode, characters are not displayed on the TV screen because the output pins are deactivated as mentioned in item 3 above.

After the RESET pin is driven high, the TVDC restarts its normal operations. But, VOC, $\overline{\text { VOB, and DO2-DO1 outputs remain de- }}$ activated, that is, no character is displayed on the TV screen, until the SCO screen enable bit is set in the screen control register.

## COMMAND DESCRIPTION

## Command Set

The MB88313's display memory, address counter, and control registers are programmed using control commands. The MB88313 can accept eight 8 -bit display control commands. These commands are serially loaded into the command register by the processor, and write their operand field data (control codes) into the display memory, address counter, and control registers. According to the programmed registers and memory, the MB88313 displays characters on the TV screen. The command format and functions are shown in Table 10. The upper 3 bits define op code, and the lower 5 bits are operand (control code).

## Command 0 (Character Code Set)

Command 0 writes its lower 5 bits (character code: $\mathrm{CH} 4-\mathrm{CHO}$ ) into character code field of a display memory location indicated by the address counter, and then increments the address counter. For the command format, see Table 6.

## Command 1 (Address Preset)

Command 1 writes the lower 4 bits (display memory address: A3-A0) into the address counter, which addresses a display memory location into which Commands 0 and 6 write character and attribute codes. For the command format, see Table 10.

## Note:

Bit 4 should be " 0 ".

## Command 2 (Horizontal Display Position Control)

Command 2 writes its lower 5 bits (horizontal display position code: HP4-HPO) into the horizontal display position register. Values of (00000) to (00010) can not be used as HP4-HPO. For the command format, see Table 10.

## Command 3 (Vertical Display Position Control)

Command 3 writes its lower 5 bits (vertical display position code: VP4-VP0) into the vertical display position register. For the command format, see Table 10.

## Command 4 (Character Size Control)

Command 4 writes its lower 2 bits (horizontal character size code: HS1 and HSO) and the next 2 bits (vertical character size code: VS1 and VSO) into the horizontal character size register and the vertical character size register, respectively. For the command format, see Table 10.

## Note:

Bit 4 should be " 0 ".

## Command 5 (Screen Control)

Command 5 writes its lower 5 bits (screen control bits: SC4SCO) into the screen control register to control various screen features. For the command format, see Table 10.

## Command 6 (Attribute Control)

Command 6 writes its lower 3 bits (attribute codes: AC2 and AC1-AC0) into the attribute field of a display memory location indicated by the address counter. Note that this command does not increment the address counter, differently from Command 0. This command sets/resets Bit 4 to initiate/release the standby mode (clock stop mode). Bit 3 should be " 0 ". For the command format, see Table 10.

## Command 7 (General Output Control)

Command 7 writes its lower 3 bits (general output data: GO2GOO) into the general output register, and sets/resets Bit 4 (general output control bit: GOC). For the command format, see Table 10.

## NOTICE

1. The test mode is initiated by test mode command (code $=00111 \mathrm{XXX}$ ), and is released by a low level on the GSYNC pin. In the test mode, output operations of the VOC, $\overline{\mathrm{VOB}}$ and DO2-DO1 pins are different from in the normal operation mode.
2. The MB88313 may enter the test mode when a control command, which is wrongly transferred due to noises, matches the test mode command.
3. When the command transmission from the processor to the MB88313 fails on the way due to noises, the command word must be retransferred after once making $\overline{\mathrm{CS}}$ high and then returning low.

COMMAND DESCRIPTION (Continued)
Table 10. Command Set Summary

| Command Number | Command Word Format |  |  |  |  |  | Name \& Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Opecode Field | Operand Field |  |  |  |  |  |
|  | MSB | LSB |  |  |  |  |  |
| 0 | 000 | CH 4 | CH3 | CH2 | CH1 | CHO | Character code set: Write operand field data (character code: $\mathrm{CH}_{4}-\mathrm{CHO}$ ) into the character code field of the display memory. |
| 1 | 001 | 0 | A3 | A2 | A1 | AO | Address preset: Write operand field data (display memory address: A3-A0) into the address counter to indicate memory locations. |
| 2 | 010 | HP4 | HP3 | HP2 | HP1 | HPO | Horizontal display position control: Write operand field data (position code: HP4-HPO) into the horizontal display position register. |
| 3 | 011 | VP4 | VP3 | VP2 | VP1 | VPO | Vertical display position control: Write operand field data (position code: VP4-VPO) into the vertical display position register. |
| 4 | 100 | 0 | VS1 | VS0 | HS1 | HSO | Character size control: Write operand field data (horizontal \& vertical character size codes: HS1 \& 0, VS1 \& 0 ) into the horizontal and vertical character size registers. |
| 5 | 101 | SC4 | SC3 | SC2 | SC1 | SC0 | Screen control: Write operand field data (screen control codes: SC4-SC0) into screen control register. |
| 6 | 110 | STP | 0 | AC2 | AC1 | ACO | Attribute control: Write operand field data (clock stop code: STP, attribute codes: AC2-AC0) into the attribute field of the display memory, and the standby mode (clock stop mode) control bit. |
| 7 | 111 | GOC | 0 | GO2 | GO1 | GOO | General output control: Write operand field data (GOC, GO2-GOO) into the general output register (GO2-GOO) and its control bit (GOC). |

ABSOLUTE MAXIMUM RATINGS $\dagger$

| Parameter | Symbol | Rating |  |  | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\text {SS }}-0.3$ |  | $\mathrm{V}_{\text {SS }}+7.0$ | V |  |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | $\mathrm{V}_{\mathrm{Ss}}-0.3$ |  | $\mathrm{V}_{\mathrm{ss}}+7.0$ | V | Should not exceed $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ |
| Output Voltage | $V_{\text {OUT }}$ | $\mathrm{V}_{\text {Ss }}-0.3$ |  | $\mathrm{V}_{\text {Ss }}+7.0$ | V | Should not exceed $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ |
| Power Dissipation | PD |  |  | 600 | mW |  |
| Operating Ambient Temperature | $\mathrm{T}_{\mathrm{A}}$ | -30 |  | +70 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 |  | +150 | ${ }^{\circ} \mathrm{C}$ |  |

†Permanent device damage may occur if the above ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability

RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Value |  |  | Unit | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| Supply Voltage | $V_{\text {cC }}$ | 4.5 | 5.0 | 5.5 | V | $\mathrm{V}_{\text {CC }}$ |
|  | $\mathrm{V}_{S S}$ |  | 0 |  | V |  |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $0.8 \times \mathrm{V}_{\mathrm{CC}}$ |  | $\mathrm{V}_{\mathrm{Cc}}+0.3$ | V | $\overline{\text { RESET, }} \overline{\text { CS, }}$, SCLK, SI HSYNC, VSYNC |
| Input Low Voltage | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{ss}}-0.3$ |  | $0.2 \times \mathrm{V}_{\mathrm{CC}}$ | V | $\overline{\text { RESET, }} \overline{\mathrm{CS}}$, SCLK, SI HSYNC, VSYNC |
| Operating Ambient Temperature | $\mathrm{T}_{\mathrm{A}}$ | -30 |  | 70 | ${ }^{\circ} \mathrm{C}$ |  |

## DC CHARACTERISTICS

(Recommended operating conditions, unless otherwise noted.)

| Parameter | Symbol | Pin | Condition | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Typ. | Max. |  |
| Output High <br> Voltage | VOH | $\begin{aligned} & \text { DO2-DOO, } \\ & \text { VOC, VOB } \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{l}_{\mathrm{OH}}=-200 \mu \mathrm{~A} \end{aligned}$ | 2.4 |  |  | V |
|  |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \end{aligned}$ | 4.0 |  |  | V |
| Output Low Voltage | VOL | $\begin{aligned} & \text { DO2-DOO, } \\ & \text { VOC, VOB } \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{l}_{\mathrm{OL}}=1.8 \mathrm{~mA} \end{aligned}$ |  |  | 0.4 | V |
|  |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{l} \mathrm{OL}=3.2 \mathrm{~mA} \end{aligned}$ |  |  | 0.6 | V |
| Input Leakage Current | IIL. | RESET | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V} \end{aligned}$ |  | -20 | -60 | $\mu \mathrm{A}$ |
|  |  | $\begin{gathered} \overline{\text { CS, SCLK, }} \\ \text { SI HSYNC, } \\ \overline{\text { VSYNC }} \end{gathered}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V} \end{aligned}$ |  | -20 | -60 | $\mu \mathrm{A}$ |
|  |  | EX | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V} \\ & \hline \end{aligned}$ |  | -10 | -20 | $\mu \mathrm{A}$ |
| Supply Current | Icc | $\mathrm{V}_{\mathrm{cc}}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \text { (Typ.) } \\ & \mathrm{fc}=6 \mathrm{MHz} \\ & \text { (Active) } \\ & \text { Reset state } \\ & \text { All outputs open } \\ & \hline \end{aligned}$ |  | 8.0 |  | mA |

## aC CHARACTERISTICS

(Recommended operating conditions, unless otherwise noted.)

## Clock Timing

| Parameter | Symbol | Pin/Port | Condition | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Typ. | Max. |  |
| Clock Frequency | $\mathrm{f}_{\mathrm{c}}$ | EX, X | RC-network OSC, LC-network OSC Figure 19 | 4.0 |  | 7.0 | MHz |

## Input Timing

| Parameter | Symbol | Pin | Condition | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Max. |  |
| Shift Clock Pulse Width | ${ }^{\text {twCH }}$ | SCLK | Figure 20 | 300 |  | ns |
|  | twCL |  |  | 300 |  |  |
| Shift Clock <br> Rise/Fall Times | $\mathrm{t}_{\mathrm{cr}}$ | SCLK | Figure 20 |  | 200 | ns |
|  | $\mathrm{t}_{\mathrm{cf}}$ |  |  |  | 200 |  |
| Shift Clock Cycle Time | ${ }^{\text {t }} \mathrm{CYC}$ | SCLK | Figure 20 | 1000 |  | ns |
| Shift Clock Start Time | tss | SCLK | Figure 20 | 200 |  | ns |
| Shift Clock Hold Time | $\mathrm{t}_{\mathrm{HS}}$ | SCLK | Figure 20 | 1000 |  | ns |
| Input Data <br> Setup Time | tsu | SI | Figure 20 | 200 |  | ns |
| Input Data Hold Time | $t_{H}$ | SI | Figure 20 | 50 |  | ns |
| Chip Select End Time | $t_{\text {EC }}$ | $\overline{\text { CS }}$ | Figure 20 | 1000 |  | ns |
| Chip Select Rise/Fall Times | $\mathrm{t}_{\text {cra }}$ | $\overline{\text { CS }}$ | Figure 20 |  | 200 | ns |
|  | $\mathrm{t}_{\text {cfic }}$ |  |  |  |  |  |
| Horizontal <br> Sync Valid Time | $\mathrm{t}_{\text {HSDF }}{ }^{1}$ | HSYNC | Figure 21 | 200 |  | ns |
|  | $\mathrm{t}_{\text {HSDR }}{ }^{2}$ |  |  | 200 |  |  |

Notes:

1. The rising edge of HSYNC is not counted during $t_{H S D F}$ period to calculate the vertical display position.
2. The rising edge of HSYNC is counted during $\mathrm{t}_{\text {HSDR }}$ period to calculate the vertical display position.

## Output Timing

| Parameter | Symbol | Pin | Condition | Malue |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| General <br> Output Delay <br> Time | tDD | DO2-DOO | 5 k $\Omega$ External <br> Pull-Up <br> Figure 22 |  | Max. | Unit |

## AC CHARACTERISTICS

(Recommended operating conditions, unless otherwise noted.) (Continued)
Figure 19. Clock Circuit Configurations


Figure 20. Input Timing (Processor Interface)


Figure 21. Input Timing (Television Interface)


Figure 22. Output Timing


## PACKAGE DIMENSIONS



## DESCRIPTION

The MB87030 SCSI Protocol Controller (SPC) is a CMOS LSI circuit specifically designed to control a Small Computer Systems Interface (SCSI). The SPC can serve as either an Initiator or Target for the SCSI; thus, it can be used as an I/O controller or as a host adapter. To use the device in the most effective manner, it is recommended that the user be thoroughly familiar with the SCSI protocol. For detailed information in these areas, the user should request the "Users Guide for' MB87030 SCSI" from the nearest Sales Office of Fujitsu.
The SPC is designed to control all SCSI interface signals and virtually all interface control procedures. Used as an 8- or 16-bit peripheral, the device provides high-level control for almost all SCSI configurations.
To achieve optimum performance and interface flexiblity, the SPC contains an 8-byte First In First Out (FIFO) data buffer register and a 24-bit transfer byte counter. Independent data busses for the CPU and the DMA controller plus separate input/output pins for all control signals greatly reduces the possiblity of a "busy" condition. Data transfers can be executed in either the synchronous or asynchronous mode with a maximum offset of 8 -bytes.

## FEATURES

- Independent data transfer bus for CPU and DMA controller
- Full support for SCSI control
- Serves as either Initiator or Target device
- Synchronous mode transfer with a programmable offset of up to eight bytes
- In synchronous mode, data transfer speed programmable at four rates
- Data transfer rates of up to 4 megabytes per second
- Eight-byte data buffer register
- 24-bit transfer byte counter
- Compatible with single-ended and/or differential alternative for SCSI
- Single +5 V supply
- Low power dissipation
- TTL-compatible I/O
- 88-Pin Ceramic Repeated Quad-In-Line Package


This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid it is advised that normal precautions be taken to avoid
application of any voltage higher than maximum rated application of any voltage higher than
voltages to this high impedance circuit.

PIN ASSIGNMENTS


| Pin <br> No. | 1/0 | Signal Name | Pin <br> No. | I/O | Signal Name | Pin <br> No. | 1/0 | Signal Name | Pin <br> No. | 1/0 | Signal Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | HIM | 23 | 0 | SDBOP | 45 | 1 | A1 | 67 | 0 | SDBE5 |
| 2 | I/O | HDBO | 24 | 0 | SDBE7 | 46 | 1 | A2 | 68 | 0 | SDBE4 |
| 3 | 1/O | 1 | 25 | 1 | SDBI7 | 47 | 1 | A3 | 69 | 1 | SDBI4 |
| 4 | I/O | 2 | 26 | 0 | SDBE6 | 48 | I/O | D4 | 70 | 0 | SDBO3 |
| 5 | I/O | 3 | 27 | 0 | SDBO5 | 49 | I/O | D5 | 71 | 1 | SDBI2 |
| 6 | I/O | 4 | 28 | 1 | SDBI5 | 50 | I/O | D6 | 72 | 0 | SDBO1 |
| 7 | 1/O | 5 | 29 | 0 | SDBO4 | 51 | 1/O | D7 | 73 | 0 | SDBEO |
| 8 | I/O | 6 | 30 | 0 | SDBE3 | 52 | 1/O | DP | 74 | 1 | SDBIO |
| 9 | 1/O | 7 | 31 | 1 | SDBI3 | 53 | 0 | INTR | 75 | 1 | $\overline{\mathrm{RST}}$ |
| 10 | 1/O | P | 32 | 0 | SDBO2 | 54 | 1 | I/OI | 76 | 0 | DREQ |
| 11 | 0 | INIT | 33 | 0 | SDBE2 | 55 | 1 | C/DI | 77 | 1 | $\overline{\text { WT }}$ |
| 12 | 0 | TARG | 34 | 1 | SDBI1 | 56 | 1 | SELI | 78 | 1 | $\overline{\text { WTG }}$ |
| 13 | 0 | 1/OO | 35 | 0 | SDBE1 | 57 | 1 | MSG1 | 79 | 1/0 | D2 |
| 14 | 0 | C/DO | 36 | 0 | SDBOO | 58 | 1 | REQI | 80 | 1/0 | D3 |
| 15 | 0 | SELO | 37 | 1 | $\overline{\mathrm{CS}}$ | 59 | 1 | RSTI | 81 | Power Supply | VSS |
| 16 | 0 | MSGO | 38 | 1 | $\overline{\text { CLK }}$ | 60 | 1 | ACKI | 82 | Power Supply | VDD |
| 17 | 0 | REQO | 39 | 1 | $\overline{\mathrm{RD}}$ | 61 | 1 | BSYI | 83 | Power Supply | VDD |
| 18 | 0 | RSTO | 40 | 1 | $\overline{\text { RGD }}$ | 62 | 1 | ANTI | 84 | Power Supply | VSS |
| 19 | 0 | ACKO | 41 | 1 | DRESP | 63 | 1 | SDBIP | 85 | Power Supply | VSS |
| 20 | 0 | BSYO | 42 | 1/O | D0 | 64 | 0 | SDBO7 | 86 | Power Supply | VDD |
| 21 | 0 | ATNO | 43 | 1/0 | D1 | 65 | 0 | SDBO6 | 87 | Power Supply | VDD |
| 22 | 0 | SDBEP | 44 | 1 | A0 | 66 | 1 | SDBI6 | 88 | Power Supply | VSS |

## PIN DESCRIPTIONS

| Pin Number | Designator | Function |
| :---: | :--- | :--- |
| $\begin{array}{c}82,83, \\ 86,87\end{array}$ | V | +5D power supply |
| 81,84, | $V_{\text {SS }}$ | Ground (0V) |
| 85,88 |  |  |$)$

PIN DESCRIPTIONS (Cont'd)

| Pin Number | Designator | Function |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 53 | INTR | Requests an interrupt to indicate completion of an SPC internal operation or the occurrence of an error. <br> Interrupt masking is allowed except for an interrupt caused by the RSTI input (reset condition is SCSI). <br> When an interrupt request is permitted, the INTR signal remains active until the cause of the interrupt is cleared. |  |  |  |  |  |
| $\begin{aligned} & 25 \\ & 66 \\ & 28 \\ & 69 \\ & 31 \\ & 71 \\ & 34 \\ & 74 \\ & 63 \end{aligned}$ | $\begin{aligned} & \text { SDBI7 } \\ & \text { SDBI6 } \\ & \text { SDBI5 } \\ & \text { SDBI4 } \\ & \text { SDBI3 } \\ & \text { SDBI2 } \\ & \text { SDBI1 } \\ & \text { SDBIO } \\ & \text { SDBIP } \end{aligned}$ | Used as input for the SCSI data bus. <br> MSB: SDBI7 <br> LSB: SDBIO <br> Odd parity bit: SDBIP <br> Parity checking for the SCSI data bus is programmable. |  |  |  |  |  |
| $\begin{aligned} & 64 \\ & 65 \\ & 27 \\ & 29 \\ & 70 \\ & 32 \\ & 72 \\ & 36 \\ & 23 \end{aligned}$ | $\begin{aligned} & \text { SDBO7 } \\ & \text { SDBO6 } \\ & \text { SDBO5 } \\ & \text { SDBO4 } \\ & \text { SDBO3 } \\ & \text { SDBO2 } \\ & \text { SDBO1 } \\ & \text { SDBO0 } \\ & \text { SDBOP } \end{aligned}$ | Used as outputs to the SCSI data bus. <br> MSB: SDBO7 <br> LSB: SDBO0 <br> Odd parity bit: SDBOP <br> If the bus driver is an open collector device, these signals should be applied directly to the driver circuit. <br> If the bus driver is a three-state device, these signals are used as data and the SDBE7-SDBE0 and SDBEP signals are used as drive-enable signals. |  |  |  |  |  |
| $\begin{aligned} & 24 \\ & 26 \\ & 67 \\ & 68 \\ & 30 \\ & 33 \end{aligned}$ | SDBE7 <br> SDBE6 <br> SDBE5 <br> SDBE4 <br> SDBE3 <br> SDBE2 | Used as drive enable signals (corresponding to respective bit positions) when a three statebuffer is used for the SCSI data bus. <br> SDBE7-SDBE0 and SDBEP correspond to SDBO7-SDBO0 and SDBOP, respectively. The relationship with respect to the SCSI bus status is shown below. |  |  |  |  |  |
| 35 73 | SDBE0 | SCSI bus status |  | (ID) | (ID) | (ID) | (ID) |
| 22 | SDBEP |  |  | 'L' | 'L' | 'L' | 'L' |
|  |  |  |  | 'H' | 'L' | 'H' | 'L' |
|  |  | Sele | election | D | D | 'H' | 'H' |
|  |  | Information | SPC $\rightarrow$ SCSI | D | D | 'H' | 'H' |
|  |  | - (ID) indicates a bit positions corresponding to the SCSI bus device ID, and (ID) indicates the other bit position. <br> - D denotes that valid information is sent out. |  |  |  |  |  |

## PIN DESCRIPTIONS (Cont'd)



PIN DESCRIPTIONS (Cont'd)

| Pin Number | Designator | Function |
| :---: | :---: | :---: |
| 76 | DREQ <br> (cont'd) | ```Input operation (SCSI) \(\downarrow\) SDBI7 to SDBIO and SDBIP pins \(\downarrow\) SPC internal data buffer register (8 bytes) \(\downarrow\) HDB7 to HDB0, and HDBP pins \(\downarrow\) External buffer memory``` <br> In an output operation, DREQ becomes active to request a data transfer from the external buffer memory when the SPC internal data buffer register has free space available. In an input operation, it becomes active to request a data transfer to the external buffer memory when the SPC internal buffer memory contains valid data. |
| 41 | DRESP | Used as a response signal to the above data transfer request signal (DREQ) in DMA mode during a data transfer cycle. <br> Pin DRESP must be refreshed with an applied pulse after each byte transferred. <br> In an output operation, SPC uses the trailing edge of the DRESP signal for sampling data on the HDB7-HDB0 and HDBP bus lines. <br> In an input operation, SPC holds data to be transferred onto HDB7-HDB0 and HDBP bus lines until the trailing edge of the DRESP signal. |
| 9 | HDB7 | Three-state, bidirectional data bus for transferring data to-or-from the external buffer |
| 8 | HDB6 | memory in DMA mode. |
| 7 | HDB5 | MSB: HDB7 |
| 6 | HDB4 | LSB: HDB0 |
| 5 | HDB3 | Odd parity bit: HDBP |
| 4 | HDB2 | The data transmission direction depends on the HIN input signal. |
| 3 | HDB1 | HIN HDBn Operation |
| $\begin{gathered} 2 \\ 10 \end{gathered}$ | $\begin{aligned} & \text { HDBO } \\ & \text { HDBP } \end{aligned}$ | 'L' Input mode Output <br> 'H' Output mode Input |
| 1 | HIN | This signal indicates transmission direction along data bus lines HDB7-HDB0 and HDBP in DMA transfer mode. <br> To be executed, transmission direction must be properly coordinated with internal operation of the SPC. <br> When the HIN signal is Low, data bus lines HDB7-HDB0 and HDBP are put in the high impedance state (input mode). When the HIN signal is High, they are switched to the output mode. |

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| Rating |  | Values |  |  |
| :--- | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| Supply Voltage | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{SS}}{ }^{2}-0.5$ | 7.0 | V |
| Input Voltage | $\mathrm{V}_{\mathrm{I}}$ | $\mathrm{V}_{\mathrm{SS}}{ }^{2}-0.5$ | $\mathrm{~V}_{\mathrm{DD}}+0.5$ | V |
| Output Voltage | $\mathrm{V}_{\mathrm{O}}$ | $\mathrm{V}_{\mathrm{SS}}{ }^{2}-0.5$ | $\mathrm{~V}_{\mathrm{DD}}+0.5$ | V |
| Storage Temperature (Ceramic) | $\mathrm{T}_{\mathrm{stg}}$ | -65 | +150 | ${ }^{\circ} \mathrm{C}$ |
| Temperature Under Bias <br> (Ceramic) | $\mathrm{T}_{\text {bias }}$ | -40 | +125 | ${ }^{\circ} \mathrm{C}$ |
| Output Current ${ }^{3}$ | $\mathrm{I}_{\mathrm{OS}}$ | -40 | +70 | mA |

## Notes:

1. Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of the SCSI User's Guide. Absolute maximum rating conditions for extended periods may affect device reliability.
2. $V_{S S}=0 \mathrm{~V}$.
3. Not more than one output may be shorted at a time for a maximum duration of one second.

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Values |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Unit |
|  |  | 4.75 | 5.0 | 5.25 | V |
|  | $\mathrm{V}_{\mathrm{IH}}$ | 2.2 |  |  | V |
|  | $\mathrm{V}_{\mathrm{IL}}$ |  |  | 0.8 | V |
|  | $\mathrm{T}_{\mathrm{A}}$ | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

DC CHARACTERISTICS (Recommended Operating Conditions unless otherwise noted)

| Parameter | Symbol | Condition | Values |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| Power Supply Current | $\mathrm{I}_{\text {DDS }}$ | Steady state ${ }^{1}$ |  |  | 100 | $\mu \mathrm{A}$ |
| Power Dissipation | PD |  |  | 300 |  | mW |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{IOH}=-0.4 \mathrm{~mA}$ | 4.2 |  | $V_{D D}$ | V |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{LL}}=3.2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{SS}}$ |  | 0.4 | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ |  | 2.2 |  |  | V |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ |  |  |  | 0.8 | V |
| Input Leakage Current | $\mathrm{I}_{\mathrm{LI}}$ | $V_{1}=0-V_{D D}$ | -10 |  | 10 | $\mu \mathrm{A}$ |
| Input Leakage Current | $\mathrm{I}_{\text {LZ }}$ | $\begin{gathered} 3 \text {-state } \\ V_{1}=0-V_{D D} \end{gathered}$ | -10 |  | 10 | $\mu \mathrm{A}$ |

Note:

1. $\mathrm{v}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{IL}}=\mathrm{v}_{\mathrm{SS}}$

CAPACITANCE $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=\mathrm{V}_{1}=0 \mathrm{~V}, \mathrm{f}=1 \mathrm{MHz}\right.$ )

| Parameter |  | Values |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | Symbol | Min | Typ | Max | Unit |
| Input Pin Capacitance |  |  |  | 9 | pF |
| Output Pin Capacitance | $\mathrm{C}_{\mathrm{OUT}}$ |  |  | 9 | pF |
| I/O Pin Capacitance | $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ |  |  | 11 | pF |

## PACKAGE DIMENSIONS



# MBL8041A/H/E/N <br> NMOS Universal Peripheral Interface 8 -Bit Microcomputer 

## Description

The MBL8041A Universal Peripheral Interface is a single-chip 8bit microcomputer based on a 8-bit parallel microprocessor chip.

The MBL8041A is fabricated with an N -channel silicongate MOS process. The MBL8041A has a 1 Kx 8 bit ROM for program memory, a $64 \times 8$ bit RAM for data memory, 18 I/O ports, an 8-bit timer/counter and clock generator on the chip, and is powered by single +5 V supply.

The MBL8041A is designed to operate as a slave Processor, which receives commands and data from the master processor, controls peripheral devices and transfers input data from peripheral devices to the master processor. And by using the MBL8041A an intelligent peripheral controller can be designed freely.

## Features

> Processor:
> 8-bit parallel processing
> Register:
> One 8-bit Status Register
> (for Interface with master processor)
> Two 8-bit Data Bus Butfer
> Registers (for Input/Output)
> Memory:
> 1Kx8 bit ROM (for program
> memory)
> 64x8 bit RAM (for data
> memory)
> I/O:
> One 8-bit Bidirectional Data
> Bus
> Two 8-bit Bidirectional I/O
> Ports
> Two Test Inputs
> Clock Source:
> Clock Generator (with External Crystal Resonator) or External Clock

- 8-Bit Interval Timer/Event Counter
- Low-power Standby Operation Capability
- Power-on Reset Capability (with External Capacitor)
- Instruction Set:

93 Instructions (217 Instruction Codes)

- 1-byte Instruction (about 70\%),
2-byte Instruction (about 30\%)
- 1-cycle or 2-cycle instruction (1 cycle $=2.5 \mu \mathrm{~s}$ at 6 MHz XTAL )
- Technology: N-channel Silicon-gate E/D MOS Process
- Two Package Options: Standard 40-pin Ceramic (Suffix-C) or Plastic DIP (Suffix-P)
- Equivalent: Intel 8041A

Portions reprinted by permission of Intel Corporation, Copyright © 1986 Intel Corporation. Compilation and additional materials Copyright© 1986 by Fujitsu Limited, Tokyo, Japan, and Fujitsu Microelectronics, Inc., Santa Clara, California, U.S.A. Fujitsu Limited is a licensee of Intel Corporation and authorized to produce alternate source products.


## Block Diagram



Pin Assignment

*These pins are internally pulled up

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

Pin Descriptions

| Pin No. | Name | Symbol | Description |
| :---: | :---: | :---: | :---: |
| 1 | Test 0 | $\mathrm{T}_{0}$ | Conditional Input for Conditional Branch |
| 2 | Crystal 1 | XTAL 1 | Input pin for the internal Clock Generator to be connected to one terminal of the external crystal. Also, this pin can be used as the input from an external clock source. |
| 3 | Crystal 2 | XTAL 2 | Input pin for the internal Clock Generator to be connected to the other terminal of the external crystal. (Note: The XTAL 1 and XTAL 2 input levels are not TTL compatible). |
| 4 | Reset | RESET | Input which resets and forces the MPU to be initialized. (Note: This input level is not TTL compatible). |
| 5 | Single Step | $\overline{\text { SS }}$ | Input pin used for single step operation. |
| 6 | Chip Select | $\overline{\text { CS }}$ | Input pin used for the master processor to select the UPI. |
| 7 | External Address | EA | Input pin used for controlling program memory access. Holding EA high forces all program memory fetches to reference external memory. Useful for emulation and debug, and essential for testing and program verification. |
| 8 | Read Strobe | RD | A Strobe input used to enable the MBL8041A to be read contents of the Data Bus Buffer register or Status register. |
| 9 | Address "0" | $\mathrm{A}_{0}$ | An Address input to determine whether read/write data or read/ write commands. <br> $A_{0}=$ " $L$ " indicates data read or write. <br> $A_{0}=$ " $H$ " indicates status read or command write. |
| 10 | Write Strobe | WR | A strobe input used to enable the MBL8041A to be written into its Data Bus Buffer register. |
| 11 | Sync | SYNC | A clock output pin indicating the MBL8041A instruction cycle. This pin is used when a synchronization signal is required for external circuits. |
| $\begin{aligned} & \hline 12 \\ & \text { thru } \\ & 19 \end{aligned}$ | Data Bus | $\begin{aligned} & \hline \mathrm{DB}_{0} \\ & \text { thru } \\ & \mathrm{DB}_{7} \end{aligned}$ | 8-bit bidirectional I/O port used to interface the MBL8041A to the master processor. |
| $\underline{20}$ | Ground | $\mathrm{V}_{\text {S }}$ | Ground terminal. |
| $\begin{aligned} & 21 \\ & \text { thru } \\ & 24 \end{aligned}$ | Port 2 | $\begin{aligned} & \mathrm{P} 2_{0} \\ & \text { thru } \\ & \mathrm{P} 2_{3} \end{aligned}$ | Lower 4 bits of the quasi-bidirectional I/O port (Port 2). These function as interface port with the 1/O expander (MBL8243) when an expansion I/O executes instruction. During single step operation upper 2 bits of the program fetch address are output on $\mathrm{P}_{0}$ and $\mathrm{P} 2_{1}$. |
| 25 | Program | PROG | A strobe signal output pin for an I/O expander (MBL8243) used, when performing an expansion I/O instruction. |
| 26 | Power Supply | $V_{D D}$ | Power supply Pin ( +5 V ) for internal RAM. |
| $\begin{aligned} & \hline 27 \\ & \text { thru } \\ & 34 \\ & \hline \end{aligned}$ | Port 1 | $\begin{aligned} & \mathrm{P} 1_{0} \\ & \text { thru } \\ & \mathrm{P} 1_{7} \\ & \hline \end{aligned}$ | Quasi-bidirectional I/O ports (Port 1). During single step operation, the next program fetch address (Lower 8 bits) is output. |
| $\begin{aligned} & \hline 35 \\ & \text { thru } \\ & 38 \end{aligned}$ | Port 2 | $\begin{aligned} & \mathrm{P}_{2} \\ & \text { thru } \\ & \mathrm{P}_{2}{ }_{7} \\ & \hline \end{aligned}$ | Upper 4 bits of the quasi-bidirectional I/O port (Port 2). These function as the flag output pins $\left(\mathrm{P2}_{4}\right.$ and $\left.\mathrm{P}_{5}\right)$ and DMA pins ( $\mathrm{P} 2_{6}$ and $\mathrm{P}_{7}$ ) according to instructions. |
| 39 | Test 1 | $\mathrm{T}_{1}$ | This pin as the following functions according to instruction: <br> 1. Event Input pin for the Event Counter. <br> 2. Condition Input pin for Conditional Branch. |
| 40 | Power Supply | $\mathrm{V}_{\mathrm{CC}}$ | Power supply pin (+5V). |

## System Interface

Interface between
MBL8041A and Master Processor

The master processor and MBL8041A are interfaced through the data bus buffer.

MBL8041A has 2 internal DBB (Data Bus Buffer) registers. It is determined by the address line and strobe signal which register is accessed.

Flag 1 ( F 1 ) is set when a command is written ( $A_{0}=1$ ), and reset when data is written ( $\mathrm{A}_{0}=0$ ).

The master processor can read only data from the output DBB register, and cannot read and check data or commands which the master processor has written itself.

When MBL8041A writes data to the output DBB with the OUT $D B B, A$ instruction, $O B F$ is set.

When DBB is read (CS = RE = $A_{0}=0, W R=1$ ) by the master processor, OBF is reset. IBF is set when the master processor writes in the DBB, and reset when MBL8041A reads the data from the DBB with IN A, DBB instruction.

The internal status of the MBL8041A does not change even when the status register contents is read out.

| $\mathbf{C S}$ | $\overline{R D}$ | $\overline{\text { WR }}$ | $\mathbf{A}_{\mathbf{0}}$ | Description |
| :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | 0 | Read DBB (Output) register. |
| 0 | 0 | 1 | 1 | Read Status Register. |
| 0 | 1 | 0 | 0 | Write DBB (Input) register (Data). |
| 0 | 1 | 0 | 1 | Write DBB (Input) register (Command). |
| 1 | x | x | x | Invalid. |



## Resident Data Memory <br> Map (RAM)

(Hex)
0
1
2
3
4
5
6
7
8
9

16


## Status Register (PSW)

The Status Register is an 8-bit register configured as shown in the following figure. The upper four bits are used for flags to indicate the status of the MPU and when a sub-routine call or an interrupt occurs, the contents of the program counter is transferred to one of the 8 register pairs of the Stack Register as determined by the lower three bits of the Status Register.

The remaining one bit is an unused bit.

## Flags

C (Carry): When an overflow occurs in the Accumulator, this bit is set to " 1 ".

AC (Auxiliary Carry): When an overflow occurs from Bit 3 to Bit 4 in the accumulator, this bit is set to " 1 ".
$F_{0}$ (User Flag): This flag can be controlled as a user flag by the proper instruction.

BS (Bank select): This flag can be controlled to select a
Register Bank by an instruction. When $B S=0$, the Register Bank 0 is selected. When $\mathrm{BS}=1$, the Register Bank 1 is selected.

## Stack Register (8 Level Capability)

The Stack Register has 16 bytes of memory area in the built-in RAM. The stack Register consists of eight levels, i.e. a Stack level consists of two bytes as shown below.

SP (Stack Pointer): In the diagram below, "SP" indicates a Stack Pointer address to be used for the next sub-routine call or interrupt. "SP" is given as an 8bit code from the lower three bits of Status Register as follows:

$\mathrm{PC}_{n}$ (Program Counter): " $\mathrm{PC}_{n}$ " indicates the content of the $n$-th bit in the Program Counter.

Interrupt Processing (IBF Interrupt, Timer/Counter Interrupt)
There are two types of interrupt: the IBF interrupt and Timer/Counter interrupt.

If an interrupt occurs when the system is in "interrupt enable" status, the interrupt flag is set as soon as the current instruction is completed.

When the interrupt processing begins, the Status and Program Counter contents are first stored in the stack. Then, operation jumps to Address 3 in the case of the IBF interrupt and Address 7 in the case of a timer interrupt.

After the interrupt has been processed by a user program and RETR (Return and Restore Status) instruction has been executed, the Status and Program Counter contents stored in the stack are restored, the interrupt flag is reset and the system is ready to accept the next interrupt request.

A Timer/Counter interrupt request occurs when the Timer/Counter overflow flag is set due to Timer/Counter overflow.

However, since the Timer/Counter interrupt request is masked by the IBF interrupt request, IBF interrupt has first priority.

The Timer/Counter interrupt is enabled after the IBF interrupt has been executed and the system has become ready to receive the next interrupt request.


## Operation Flow Chart



Interrupt Flow Chart


## Instruction Set Summary

## Accumulator



Note 1: The accumulator value is adjusted to form $B C D$ digits following the binary addition of $B C D$ numbers. Operation Code X: Table 1
Flag*: This flag is set or reset in the state after executed instruction
Input/Output

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Input port to A | IN A,P1 | 09 | 1 | 2 | - | - | ( A$) \leftarrow(\mathrm{P} 1)$ |
|  | IN A,P2 | OA | 1 | 2 | - | - | (A) $\leftarrow\left({ }^{\text {P2 }}\right.$ ) |
| Output A to port | OUTL P1,A | 39 | 1 | 2 | - | - | $(\mathrm{P} 1) \leftarrow(\mathrm{A})$ |
|  | OUTL P2,A | 3A | 1 | 2 | - | - | $(\mathrm{P} 2) \leftarrow(\mathrm{A})$ |
| AND immediate to port | ANL P1, \#data | 99 | 2 | 2 | - | - | $(\mathrm{P} 1) \leftarrow(\mathrm{P} 1)$ AND data |
|  | ANL P2, \# data | 9A | 2 | 2 | - | - | $(\mathrm{P} 2) \leftarrow(\mathrm{P} 2)$ AND data |
| OR immediate to port | ORL P1, \#data | 89 | 2 | 2 | - | - | $(\mathrm{P} 1) \leftarrow(\mathrm{P} 1)$ OR data |
|  | ORL P2,\# data | 8A | 2 | 2 | - | - | $(\mathrm{P} 2) \leftarrow$ (P2) OR data |
| Input DBB to A clear IBF | IN A,DBB | 22 | 1 | 1 | - | - | (A) $\leftarrow(\mathrm{DBB}),(\mathrm{IBF}) \leftarrow 0$ |
| Output A to DBB, set OBF | OUT DBB,A | 02 | 1 | 1 | - | - | (DBB) $\leftarrow$ (A), (OBF) $\leftarrow 1$ |
| A7~4 to bits 7~4 of Status | MOV STS,A | 90 | 1 | 1 | - | - | (STS7 ~ 4) $\leftarrow(A 7 \sim 4)$ |
| Input Expander port to A | MOVD A,Pp | OX | 1 | 2 | - | - | $\left(A_{3} \sim 0\right) \leftarrow\left(P_{P}\right),(A 7 \sim 4) \leftarrow 0$ |
| Output A to Expander port | MOVD Pp,A | 3 X | 1 | 2 | - | - | $\left(\mathrm{P}_{\mathrm{P}}\right) \leftarrow(\mathrm{A} 3 \sim 0)$ |
| AND A to Expander port | ANLD $P_{p}, A$ | 9 X | 1 | 2 | - | - | $\left(\mathrm{P}_{\mathrm{P}}\right) \leftarrow\left(\mathrm{P}_{\mathrm{P}}\right)$ AND $(\mathrm{A} 3 \sim 0)$ |
| OR A to Expander port | ORLD $\mathrm{P}_{\mathrm{p}}, \mathrm{A}$ | 8 X | 1 | 2 | - | - | $\left(\mathrm{P}_{\mathrm{P}}\right) \leftarrow\left(\mathrm{P}_{\mathrm{P}}\right) \mathrm{OR}(\mathrm{A} 3 \sim 0)$ |

[^40]
## Instruction Set Summary

(Continued)

## Data Moves

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Move register to A | MOV A,Rr | FX | 1 | 1 | - | - | $(\mathrm{A})-(\mathrm{Rr})$ |
| Move data memory to $A$ | MOV A,@RO | FO | 1 | 1 | - | - | (A) - ((RO) ) |
|  | MOV A,@R1 | F1 | 1 | 1 | - | - | (A) - ( R 1$)$ ) |
| Move immediate to $A$ | MOV A, \# data | 23 | 2 | 2 | - | - | (A) - data |
| Move A to register | MOV Rr,A | AX | 1 | 1 | - | - | $(\mathrm{Rr})-(\mathrm{A})$ |
| Move A to data memory | MOV @RO,A | A0 | 1 | 1 | - | - | $((\mathrm{RO}))-(A)$ |
|  | MOV ©R1,A | A1 | 1 | 1 | - | - | ((R1)) - (A) |
| Move immediate to register | MOV Rr, \#data | $B X$ | 2 | 2 | - | - | (Rr) - data |
| Move immediate to data memory | MOV @RO, \#data | B0 | 2 | 2 | - | - | ((RO)) - data |
|  | MOV ©R1, \#data | B1 | 2 | 2 | - | - | ((R1)) - data |
| Move PSW to A | MOV A,PSW | C7 | 1 | 1 | - | - | (A) - (PSW) |
| Move A to PSW | MOV PSW,A | D7 | 1 | 1 | * | - | (PSW) - (A) |
| Exchange A and register | XCH A,Rr | 2X | 1 | 1 | - | - | $(\mathrm{A})=(\mathrm{Rr})$ |
| Exchange $A$ and data memor | XCH A,@RO | 20 | 1 | 1 | - | - | (A) $=((\mathrm{RO}))$ |
|  | XCH A, ©R1 | 21 | 1 | 1 | - | - | $(\mathrm{A}) \leftrightarrows((\mathrm{R} 1))$ |
| Exchange digit of A and data memory | XCHD A,@RO | 30 | 1 | 1 | - | - | $(\mathrm{A} 3 \sim 0)=\left((\mathrm{R}) \mathrm{S}^{\sim} \sim 0\right)$ |
|  | XCHD A,@R1 | 31 | 1 | 1 | - | - | $(\mathrm{A} 3 \sim 0)=((\mathrm{R} 1) 3 \sim 0)$ |
| Move to A from current page | MOVP A,@A | A3 | 1 | 2 | - | - | $(\mathrm{A})-((\mathrm{A}))$ within page |
| Move to A from Page 3 | MOVP3 A,@A | E3 | 1 | 2 | - | - | $(\mathrm{A})-((\mathrm{A})$ ) within page 3 |

Operation Code X: Table 1
Flag*: This flag is set or reset in the state after executed instruction.

## Timer/Counter

| Operation | Mnemonic | OP <br> Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | c | AC |  |
| Read Timer/Counter | MOV A, $T$ | 42 | 1 | 1 | - | - | (A) - (T) |
| Load Timer/Counter | MOV T, A | 62 | 1 | 1 | - | - | $(T)-(A)$ |
| Start Timer | STRT T | 55 | 1 | 1 | - | - |  |
| Start Counter | STRT CNT | 45 | 1 | 1 | - | - |  |
| Stop Timer/Counter | STOP TCNT | 65 | 1 | 1 | - | - |  |
| Enable Timer/ Counter Interrupt | EN TCNTI | 25 | 1 | 1 | - | - |  |
| Disable Timer/ Counter Interrupt | DIS TCNTI | 35 | 1 | 1 | - | - |  |

## Control

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | c | AC |  |
| Enable DMA Handshake Lines | EN DMA | E5 | 1 | 1 | - | - |  |
| Enable IBF Interrupt | ENI | 05 | 1 | 1 | - | - |  |
| Disable IBF interrupi | Dis i | 15 | 1 | 1 | - | - |  |
| Enable Master Interrupts | EN FLAGS | F5 | 1 | 1 | - | - |  |
| Select register bank 0 | SEL RBO | C5 | 1 | 1 | - | - | (BS) $\leftarrow 0$ |
| Select register bank 1 | SEL RB1 | D5 | 1 | 1 | - | - | $(B S) \leftarrow 1$ |
| No Operation | NOP | 00 | 1 | 1 | - | - |  |

## Instruction Set Summary <br> (Continued)

## Register

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | c | AC |  |
| Increment register Increment data memory | INC Rr | 1X | 1 | 1 | - | - | $(\mathrm{Rr})-(\mathrm{Rr})+1$ |
|  | INC@Ro | 10 | 1 | 1 | - | - | $((\mathrm{RO}))-(\mathrm{R} 0))+1$ |
|  | INC@R1 | 11 | 1 | 1 | - | - | $((R 1)) \cdot((R 1))+1$ |
| Decrement register | DEC Rr | cx | 1 | 1 | - | - | $(\mathrm{Rr})-(\mathrm{Rr}) \quad 1$ |

Operation Code X: Table 1
Subroutine

|  | OP |  |  |  | Flag |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Operation | Mnemonic | Code | Byte | Cycle | C | AC | Note |  |
| Jump to Subroutine | CALL addr | $\% 4$ | 2 | 2 | - | - | Note (2) |  |
| Return | RET | 83 | 1 | 2 | - | - | Note (3) |  |
| Return and restore status | RETR | 93 | 1 | 2 | $*$ | $*$ | Note (4) |  |

Operation Code \%: Table 3
Flag*: This flag is set or reset in the state after executed instruction.
Flags

|  | OP |  |  |  | Flag |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Operation | Mnemonic | Code | Byte | Cycle | C | AC | Note |
| Clear Carry | CLR C | 97 | 1 | 1 | Z | - | (C) -0 |
| Complement Carry | CPL C | A7 | 1 | 1 | CP | - | (C) - (C) |
| Clear Flag 0 | CLR F0 | 85 | 1 | 1 | - | - | (F0) -0 |
| Complement Flag 0 | CPL F0 | 95 | 1 | 1 | - | - | (F0) - (F0) |
| Clear Flag $\mathbf{1}$ | CLR F1 | A5 | 1 | 1 | - | - | (F1) - 0 |
| Complement Flag 1 | CPL F1 | B5 | 1 | 1 | - | - | (F1) - (F1) |

Flag Z: Reset CP: Invert
Branch

| Operation | Mnemonic | OP <br> Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Jump unconditional | JMP addr | \%4 | 2 | 2 | - | - | Unconditional Branch |
| Jump indirect | JMPP@A | B3 | 1 | 2 | - | - | Unconditional Branch Note (5) |
| Decrement register and jump | DJNZ Rr, addr | EX | 2 | 2 | - | - | $(\mathrm{Rr}) \neq 0$ Note (6) |
| Jump on Carry = 1 | JC addr | F6 | 2 | 2 | - | - | $(C)=1$ |
| Jump on Carry $=0$ | JNC addr | E6 | 2 | 2 | - | - | $(C)=0$ |
| Jump on A Zero | JZ addr | C6 | 2 | 2 | - | - | $(\mathrm{A})=0$ |
| Jump on A not Zero | JNZ addr | 96 | 2 | 2 | - | - | (A) $\ddagger 0$ |
| Jump on T0 = 1 | JTO addr | 36 | 2 | 2 | - | - | $(\mathrm{TO})=1$ |
| Jump on T0 $=0$ | JNTO addr | 26 | 2 | 2 | - | - | $(\mathrm{TO})=0$ |
| Jump on T1 = 1 | JT1 addr | 56 | 2 | 2 | - | - | $(\mathrm{T} 1)=1$ |
| Jump on T1 = 0 | JNT1 addr | 46 | 2 | 2 | - | - | $(\mathrm{T} 1)=0$ |
| Jump on FO = 1 | JF0 addr | B6 | 2 | 2 | - | - | $(\mathrm{FO})=1$ |
| Jump on F1 = 1 | JF1 addr | 76 | 2 | 2 | - | - | $(\mathrm{F} 1)=1$ |
| Jump on Timer Flag $=1$, <br> Clear Flag | JTF addr | 16 | 2 | 2 | - | - | $(T F)=1$ |
| Jump on IBF Flag $=0$ | JNIBF addr | D6 | 2 | 2 | - | - | $(\mathrm{IBF})=0$ |
| Jump on OBF Flag $=1$ | JOBF addr | 86 | 2 | 2 | - | - | $(\mathrm{OBF})=1$ |
| Jump on Accumulator Bit | JBb addr | \%2 | 2 | 2 | - | - | $(\mathrm{Ab})=1$ |

## Operation Code \%: Table 3 X: Table 1

Note 2: Call addr
((SP)) - (PC), (PSW7~4)
$(S P)-(S P)+1$
(PC9~8) - $\mathrm{A}_{\mathrm{H}}$
$\left(\right.$ PC7~0) $-A_{L}$

Note 3: RET
(SP) - (SP) -
$(\mathrm{PC})-((\mathrm{SP}))$
Note 4: RETR
(SP) - (SP) -
$(\mathrm{PC})-((\mathrm{SP}))$
(PSW7~4) - ((SP))

Note 5: JMMP @ (PC7~0) - ((A))

Note 6: DJNZ Rr, addr
$(R r)-(R r)-1$
if ( Fr ) $\ddagger 0$ (PC7~0) - addr
if $(\mathrm{Rr})=0$ Execute next instruction

## Instruction Set Summary <br> (Continued)

| Mnemonic | Rr | RO | R1 | R2 | R3 | R4 | R5 | R6 | R7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADD A, Rr |  | 63 | 69 | 6A | 6B | 6 C | 6D | 6E | 6F |
| ADDC A,Rr |  | 78 | 79 | 7A | 7B | 7 C | 7D | 7E | 7F |
| ANL A,Rr |  | 58 | 59 | 5A | 5B | 5C | 5D | 5E | 5F |
| DEC Rr |  | C8 | C9 | CA | CB | CC | CD | CE | CF |
| DJNZ Rr, addr |  | E8 | E9 | EA | EB | EC | ED | EE | EF |
| INC Rr |  | 18 | 19 | 1A | 1B | 1C | 1D | 1E | 1 F |
| MOV A,Rr |  | F8 | F9 | FA | FB | FC | FD | FE | FF |
| MOV Rr,A |  | A8 | A9 | AA | AB | AC | AD | AE | AF |
| MOV Rr, \# data |  | B8 | B9 | BA | BB | BC | BD | BE | BF |
| ORL A, Rr |  | 48 | 49 | 4A | 4B | 4C | 4D | 4E | 4F |
| XCH A, Rr |  | 28 | 29 | 2A | 2 B | 2C | 2D | 2E | 2 F |
| XRL A, Rr |  | D8 | D9 | DA | DB | DC | DD | DE | DF |



| O.P.Code Of Expander Port Access (Table 2) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | PP | P4 | P5 | P6 | P7 |
| ANLD Pp.A |  | 9 C | 9 D | 9 E | 9 F |
| MOVD A. Pp |  | OC | OD | OE | OF |
| MOVD $P_{P}, \mathrm{~A}$ |  | 3 C | 3D | 3 E | 3 F |
| ORLD $P_{P}, A$ |  | 8C | 8D | 8E | 8 F |


O.P Code of JMP, CALL, JBb (Table 3)

First Byte Second Byte

$A_{H} ;$ Address $A_{9}, A_{8}$
$A_{L} ;$ Address $A_{7}$ to $A_{0}$
$B_{b}$; b-th Bit on Accumulator

## Instruction Codes

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | NOP |  | $\begin{aligned} & \text { OUT } \\ & \text { DBB,A } \end{aligned}$ | $\begin{gathered} \text { ADD } \\ \text { A, } \end{gathered}$ | $\begin{aligned} & \text { JMP } \\ & 0 \times \times \end{aligned}$ | $\begin{gathered} \text { EN } \\ 1 \end{gathered}$ |  | $\underset{\text { A }}{\text { DEC }}$ |  | $\underset{\mathrm{A}, \mathrm{P} 1}{\mathbb{N}}$ | $\underset{\mathrm{A}, \mathrm{P} 2}{\mathbb{N}}$ |  | $\underset{\text { A,P4 }}{\text { MOVD }}$ | $\underset{\text { A,P5 }}{\substack{\text { MOVD }}}$ | $\begin{gathered} \text { MOVD } \\ \text { A,PP6 } \end{gathered}$ | $\begin{aligned} & \text { MOVD } \\ & \text { A,P7 } \end{aligned}$ |
| 1 | INC (a) RO | $\underset{(\omega \mathrm{R} \mid}{\substack{\text { INC }}}$ | $\begin{aligned} & \text { JBO } \\ & \text { addr } \end{aligned}$ | $\begin{gathered} \text { ADDC } \end{gathered}$ | $\begin{aligned} & \text { CALL } \\ & 0 \times x \end{aligned}$ | $\begin{gathered} \text { DIS } \\ 1 \end{gathered}$ | JTF addr | $\underset{A}{\text { INC }}$ | $\begin{gathered} \text { INC } \\ \text { RO } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R1 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R2 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R3 } \end{gathered}$ | $\begin{aligned} & \text { INC } \\ & \text { R4 } \end{aligned}$ | $\begin{gathered} \text { INC } \\ \text { R5 } \end{gathered}$ | $\begin{aligned} & \text { INC } \\ & \text { R6 } \end{aligned}$ | $\begin{gathered} \text { INC } \\ \text { R7 } \end{gathered}$ |
| 2 | $\begin{gathered} \mathrm{XCH} \\ \mathrm{~A}, \mathrm{Q} \mathrm{RO} \end{gathered}$ | $\underset{A, @ R 1}{\mathrm{XCH}}$ | $\stackrel{\mathbb{N}, \mathrm{DBB}}{\substack{\mathrm{~N}}}$ | $\underset{\mathrm{A}, *}{\mathrm{MOV}}$ | $\underset{1 \times x}{J M P}$ | $\begin{gathered} \text { EN } \\ \text { TCNT1 } \end{gathered}$ | JNTO addr | $\underset{A}{\text { CLR }}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{RO} \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 1 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 3 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 4 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 5 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R6} \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \hline \end{aligned}$ |
| 3 | $\begin{aligned} & \mathrm{XCHD} \\ & \mathrm{~A}, \mathrm{QRO} \end{aligned}$ | $\begin{aligned} & \mathrm{XCHD} \\ & \mathrm{~A}, \odot \mathrm{R}_{1} \end{aligned}$ | $\begin{gathered} \text { JB1 } \\ \text { addr } \end{gathered}$ |  | $\begin{aligned} & \text { CALL } \\ & 1 \times \times \end{aligned}$ | $\begin{gathered} \text { DIS } \\ \text { TCNT1 } \end{gathered}$ | $\begin{aligned} & \text { JTO } \\ & \text { addr } \end{aligned}$ | $\begin{gathered} \mathrm{CPL} \\ \mathrm{~A} \end{gathered}$ |  | $\begin{aligned} & \text { OUTL } \\ & \mathrm{P}_{1, \mathrm{~A}} \end{aligned}$ | $\begin{aligned} & \text { OUTL } \\ & \text { P2,A } \end{aligned}$ |  | MOVD P4,A | $\begin{gathered} \text { MOVD } \\ \text { P5,A } \end{gathered}$ | $\begin{gathered} \text { MOVD } \\ \text { P6.A } \end{gathered}$ | $\begin{gathered} \text { MOVD } \\ \text { P7,A } \end{gathered}$ |
| 4 | ORL <br> A,@RO | $\begin{aligned} & \text { ORL } \\ & \mathrm{A}, \oplus \mathrm{C}_{1} \end{aligned}$ | $\underset{A, T}{M O V}$ | $\begin{aligned} & \text { ORL } \\ & \mathrm{A}, * \end{aligned}$ | $\begin{aligned} & \text { JMP } \\ & 2 \times x \end{aligned}$ | $\begin{aligned} & \text { STRT } \\ & \text { CNT } \end{aligned}$ | JNT1 addr | $\underset{A}{\text { SWAP }}$ | $\begin{aligned} & \text { ORL } \\ & \text { A,RO } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \mathrm{A}, \mathrm{R} 1 \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \mathrm{A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A,R3 } \end{aligned}$ | ORL A,R4 | $\begin{aligned} & \text { ORL } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A,R6 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \mathrm{A}, \mathrm{R} 7 \end{aligned}$ |
| 5 | $\begin{gathered} \text { ANL } \\ \text { A,@RO } \end{gathered}$ | $\underset{A, @ R 1}{A N L}$ | $\begin{aligned} & \text { JB2 } \\ & \text { addr } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,* } \end{aligned}$ | $\begin{aligned} & \text { CALL } \\ & 2 \times x \end{aligned}$ | $\begin{gathered} \text { STRT } \\ \hline \end{gathered}$ | $\begin{gathered} \text { JT1 } \\ \text { addr } \end{gathered}$ | $\begin{gathered} \text { DA } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & \mathrm{A}, \mathrm{RO} \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R1 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \mathrm{A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R3 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R4 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A,R6 } \end{aligned}$ | $\underset{\text { ANL }}{\underset{A N}{ }}$ |
| 6 | $\begin{gathered} \text { ADD } \\ \text { A,@RO } \end{gathered}$ | $\begin{gathered} \text { ADD } \\ A_{1, @ R 1} \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { TA } \end{gathered}$ |  | JMP $3 \times x$ | $\begin{aligned} & \text { STOP } \\ & \text { TCNT } \end{aligned}$ |  | $\underset{\text { ARC }}{ }$ | $\begin{aligned} & \text { ADD } \\ & \text { A,RO } \end{aligned}$ | $\begin{gathered} A, R 1 \end{gathered}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R2 } \end{aligned}$ | $\begin{gathered} \text { ADD } \\ A, R 3 \end{gathered}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R4 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,R6 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & A, R 7 \end{aligned}$ |
| 7 | ADDC <br> A,@RO | ADDC <br> A,@R1 | $\begin{aligned} & \text { JB3 } \\ & \text { addr } \end{aligned}$ |  | $\begin{aligned} & \text { CALL } \\ & 3 \times x \end{aligned}$ |  | JF1 <br> addr | $\begin{gathered} \text { RR } \\ \text { A } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A, RO } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R1 } \end{gathered}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A,R2 } \end{aligned}$ | $\underset{A, R 3}{A D D C}$ | $\underset{\mathrm{A}, \mathrm{R} 4}{\mathrm{ADDC}}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R5 } \end{gathered}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A,R6 } \end{aligned}$ | $\begin{gathered} \text { ADDC } \\ \text { A,R7 } \end{gathered}$ |
| 8 |  |  |  | RET |  | $\begin{gathered} \text { CLR } \\ \text { FO } \end{gathered}$ | JOBF addr |  |  | $\begin{aligned} & \text { ORL } \\ & \text { P1,* } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { P2, } \end{aligned}$ |  | $\begin{aligned} & \text { ORLD } \\ & \text { P4,A } \end{aligned}$ | ORLD P5,A | ORLD P6,A | ORLD P7.A |
| 9 | $\begin{gathered} \text { MOV } \\ \text { STS, A } \end{gathered}$ |  | $\begin{aligned} & \text { JB4 } \\ & \text { addr } \end{aligned}$ | RETR |  | $\begin{aligned} & \mathrm{CPL} \\ & \mathrm{FO} \end{aligned}$ | $\begin{aligned} & \mathrm{JNZ} \\ & \text { addr } \end{aligned}$ | $\begin{gathered} \text { CLR } \\ \text { C } \end{gathered}$ |  | $\begin{aligned} & \text { ANL } \\ & \text { P1,* } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { P2,* } \end{aligned}$ |  | $\begin{gathered} \text { ANLD } \\ \text { P4,A } \end{gathered}$ | ANLD <br> P5,A | $\begin{gathered} \text { ANLD } \\ \text { P6,A } \end{gathered}$ | $\begin{aligned} & \text { ANLD } \\ & \text { P7,A } \end{aligned}$ |
| A | $\begin{aligned} & \text { MOV } \\ & \text { @RO,A } \end{aligned}$ | MOV <br> ©R1,A |  | $\begin{gathered} \text { MOVP } \\ \text { A, ©A } \end{gathered}$ |  | $\begin{aligned} & \text { CLR } \\ & \text { F1 } \end{aligned}$ |  | $\begin{gathered} \text { CPL } \\ \text { C } \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & \text { RO,A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R1,A } \end{aligned}$ | MOV | $\begin{aligned} & \text { MOV } \\ & \text { R3,A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R4, A } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R5,A } \end{aligned}$ | MOV R6, A | $\begin{aligned} & \text { MOV } \\ & \text { R7,A } \end{aligned}$ |
| B | $\begin{aligned} & \text { MOV } \\ & \text { @RO, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { ©R1,* } \end{aligned}$ | $\begin{aligned} & \text { JB5 } \\ & \text { addr } \end{aligned}$ | JMPP <br> @A |  | $\begin{gathered} \text { CPL } \\ \text { F1 } \end{gathered}$ | $\begin{aligned} & \text { JFO } \\ & \text { addr } \end{aligned}$ |  | $\begin{aligned} & \text { MOV } \\ & \text { RO,* } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R1, } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R2,* } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R3,* } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R4, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R5,* } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \mathrm{R} 6, * \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R7,* } \end{aligned}$ |
| C |  |  |  |  |  | $\begin{aligned} & \text { SEL } \\ & \text { RBO } \end{aligned}$ | $\underset{\text { addr }}{\mathrm{JZ}}$ | $\begin{gathered} \text { MOV } \\ \text { A,PSW } \end{gathered}$ | $\begin{aligned} & \text { DEC } \\ & \text { RO } \end{aligned}$ | $\begin{gathered} \text { DEC } \\ \text { R1 } \end{gathered}$ | $\begin{aligned} & \text { DEC } \\ & \text { R2 } \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { R3 } \end{aligned}$ | $\begin{gathered} \text { DEC } \\ \text { R4 } \end{gathered}$ | $\begin{aligned} & \text { DEC } \\ & \text { R5 } \end{aligned}$ | $\begin{gathered} \text { DEC } \\ \text { R6 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R7 } \end{gathered}$ |
| D | $\begin{gathered} \text { XRL } \\ \text { A, ©RO } \end{gathered}$ | $\begin{gathered} \text { XRL } \\ \text { A,@R1 } \end{gathered}$ | $\begin{aligned} & \text { JB6 } \\ & \text { addr } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, } \end{aligned}$ |  | SEL | JNIBF addr | $\begin{aligned} & \text { MOV } \\ & \text { PSW,A } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,RO } \end{aligned}$ | $\begin{aligned} & \mathrm{XR}, \mathrm{R} 1 \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R2 } \end{aligned}$ | $\begin{aligned} & \text { XRL }, R 3 \end{aligned}$ | $\underset{\mathrm{A}, \mathrm{R3}}{\mathrm{XRL}}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R6 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,R7 } \end{aligned}$ |
| E |  |  |  | MOVP3 A,@A |  | $\begin{aligned} & \text { EN } \\ & \text { DMA } \end{aligned}$ | JNC <br> addr | $\begin{gathered} \text { RL } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \text { DJNZ } \mathrm{Ro}, \text { addf } \end{aligned}$ | $\begin{gathered} \text { DJNZ } \\ \text { R1,addr } \end{gathered}$ | $\begin{array}{c\|c} \text { DJNZ } \\ \text { R2,addr } \end{array}$ | $\begin{gathered} \text { DJNZ } \\ \text { R3,addr } \end{gathered}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R4,addr } \end{aligned}$ | DJNZ <br> R5,addr | $\begin{gathered} \text { DJNZ } \\ \text { R6,addr } \end{gathered}$ | $\begin{aligned} & \text { DJNZ } \\ & \text { R7,addr } \end{aligned}$ |
| F | $\begin{gathered} \text { MOV } \\ \text { A,@RO } \end{gathered}$ | $\underset{\text { A,@R1 }}{\substack{\text { MOV }}}$ | $\begin{gathered} \text { JB7 } \\ \text { addr } \end{gathered}$ |  |  | $\begin{gathered} \mathrm{EN} \\ \text { FLAGS } \end{gathered}$ | $\underset{\text { addr }}{\text { JC }}$ | $\underset{\text { A }}{\text { RLC }}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,RO } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R2 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R3 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R4 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R5 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R6 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,R7 } \end{aligned}$ |

[^41]
$\square 2$ Byte, 2 Cycle Instruction

| Absolute Maximum <br> Ratings | Parameter | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- | :--- |
|  | Supply Voltage | $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}$ | -0.3 to +7.0 | V |
|  | $\mathrm{~V}_{\mathrm{IN}}$ | -0.3 to +7.0 | V |  |
| Input Voltage | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |  |
| Operating Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |  |
|  | $\mathrm{P}_{\mathrm{D}}$ | 1.5 | W |  |
| Storage Temperature |  |  |  |  |
| Power Dissipation |  |  |  |  |

Note: Permanent device damage may occur if the above Absolute Maximum Ratings are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

| Recommended Operating <br> Conditions | Parameter | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- | :--- |
|  | Supply Voltage | $\frac{V_{C C}, V_{D D}}{V_{S S}}$ | $+5.0 \pm 10 \%$ | V |
|  | Operating Temperature |  | 0 | V |

DC Characteristics

| $\begin{aligned} & \left(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}\right. \\ & \left.=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\right) \end{aligned}$ | Parameter |  | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min. | Max. |  |
|  | Input Low Voltage | All Except XTAL1, 2, $\overline{\text { RESET }}$ | $V_{\text {IL }}$ |  | -0.3 | 0.8 | V |
|  |  | XTAL1,2, RESET | $\mathrm{V}_{\text {LL }}$ |  | -0.3 | 0.6 | V |
|  | Input High Voltage | All Except XTAL1, 2, $\overline{\text { RESET }}$ | $\mathrm{V}_{\mathrm{IH}}$ |  | 2.0 | $\mathrm{V}_{\text {CC }}$ | V |
|  |  | XTAL1,2, $\overline{\text { RESET }}$ | $\mathrm{V}_{1+1}$ |  | 3.8 | $\mathrm{V}_{\mathrm{CC}}$ | V |
|  |  | $\mathrm{DB}_{0}$ to $\mathrm{DB}_{7}$ | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |  | 0.45 | V |
|  | Output Low Voltage | $\begin{aligned} & \text { P10-P17, P20-P27 } \\ & \text { SYNC } \end{aligned}$ | $\mathrm{V}_{\mathrm{OL} 1}$ | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |  | 0.45 | V |
|  |  | PROG | $\mathrm{V}_{\text {OL2 }}$ | $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ |  | 0.45 | V |
|  | Output High Voltage | $\mathrm{DB}_{0}$ to $\mathrm{DB}_{7}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 |  |  |
|  | Output High Voltage | All other outputs | $\mathrm{V}_{\mathrm{OH} 1}$ | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}$ | 2.4 |  |  |
|  | Input Leakage Current | $\begin{aligned} & \mathrm{T}_{0}, \mathrm{~T}_{1}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{CS}}, \\ & \mathrm{~A}_{0}, \mathrm{EA} \end{aligned}$ | IIL | $\mathrm{V}_{\mathrm{SS}} \leqq \mathrm{V}_{\mathrm{IN}} \leqq \mathrm{V}_{\mathrm{CC}}$ |  | $\pm 10$ | $\mu \mathrm{A}$ |
|  | Output Leakage Current | $\begin{aligned} & \mathrm{DB}_{0} \text { to } \mathrm{DB}_{7} \\ & \text { (High } Z \text { State) } \end{aligned}$ | Jol | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+0.45 \mathrm{~V} \leqq \\ & \mathrm{~V}_{\mathrm{IN}} \leqq \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |  | $\pm 10$ | $\mu \mathrm{A}$ |
|  | Input Low Current | $\begin{aligned} & \mathrm{P}_{0} \text { to } \mathrm{P} 1_{7} \\ & \mathrm{P}_{0} \text { to } \mathrm{P}_{7} \\ & \hline \end{aligned}$ | $I_{\text {LI }}$ | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |  | 0.5 | mA |
|  |  | RESET, $\overline{\text { SS }}$ | $\mathrm{LLIT}^{\text {l }}$ | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |  | 0.2 | mA |
|  | $\mathrm{V}_{D D}$ Supply Current |  | $I_{\text {D }}$ |  |  | 15 | mA |
|  | Supply Current |  | $\begin{aligned} & \mathrm{I}_{\mathrm{CC}}+ \\ & \mathrm{I}_{\mathrm{DD}} \\ & \hline \end{aligned}$ |  |  | 125 | mA |

## AC Characteristics

( $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}$ $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ )

Data Bus Buffer Register Read (Refer to the Fig. 1)

| Parameter |  | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. |  | Max. |  |
| $\overline{\overline{C S}, A_{0} \text { Setup Time (to } \overline{\mathrm{RD}} \text { ) }}$ |  |  | $t_{\text {AR }}$ |  | 0 |  | ns |
| $\overline{\overline{C S}}, \mathrm{~A}_{0}$ Hold Time (from $\overline{\mathrm{RD}}$ ) |  | $t_{\text {RA }}$ |  | 0 |  | ns |
| RD Pulse Width |  | $t_{\text {RR }}$ |  | 250 |  | ns |
| Data Delay Time (from $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ ) |  | $t_{A D}$ | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |  | 225 | ns |
| Data Delay Time (from $\overline{\mathrm{RD}}$ ) |  | $t_{\text {RD }}$ | $C_{L}=150 \mathrm{pF}$ |  | 225 | ns |
| Data Floating Time (from $\overline{\mathrm{RD}}$ ) |  | $t_{\text {DF }}$ |  |  | 100 | ns |
| Recovery Time |  | $t_{\text {RV }}$ |  | 300 |  | ns |
| Cycle Time | MBL8041AN | ${ }^{t}{ }_{C Y}$ | * | 2.5 | 15.0 | $\mu \mathrm{s}$ |
|  | MBL8041AE |  | ** | 1.875 | 15.0 | $\mu \mathrm{s}$ |
|  | MBL8041AH |  | *** | 1.36 | 15.0 | $\mu \mathrm{s}$ |

${ }^{*} \mathrm{t}_{\mathrm{CY}}=2.50 \mu \mathrm{~s}$ at 6 MHz XTAL ( N version)
${ }^{* *} \mathrm{t}_{\mathrm{Cr}}=1.875 \mu$ s at 8 MHz XTAL (E version)
${ }^{* *} \mathrm{t}_{\mathrm{CY}}=1.36 \mu \mathrm{~s}$ at 11 MHz XTAL (H version)
Data Bus Buffer Register Write (Refer to the Fig. 2)

| Parameter | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. |  |
| $\overline{\overline{C S}, A_{0} \text { Setup Time (to } \overline{\mathrm{WR}} \text { ) }}$ | $t_{\text {AW }}$ |  | 0 |  | ns |
| $\overline{\overline{C S}}, \mathrm{~A}_{0}$ Hold Time (to WR) | $t_{\text {WA }}$ |  | 0 |  | ns |
| $\overline{\text { WR Pulse Width }}$ | $t_{\text {ww }}$ |  | 250 |  | ns |
| Data Setup Time (to WR) | $t_{\text {dw }}$ |  | 150 |  | ns |
| Data Hold Time (to WR) | $t_{\text {WD }}$ |  | 0 |  | ns |

Port 2 (Refer to the Fig. 3)*
MBL8041AN MBL8041AE MBL8041AH

| Parameter | Symbol | Min. | Max. | Min. | Max. | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Port Control Setup befor Falling Edge of PROG T (to PROG) |  | 100 |  | 105 |  | 110 |  | ns |
| Port Control Hold after Falling Edge of PROG Time (from PROG) | $t_{\text {PC }}$ | 60 |  | 80 |  | 100 |  | ns |
| Output Data Setup Time (to PROG) | $t_{\text {DP }}$ | 200 |  | 210 |  | 250 |  | ns |
| Output Data Hold Time (from PROG) | $t_{\text {PD }}$ | 20 |  | 45 |  | 65 |  | ns |
| Input Data Hold Time (from PROG) | $t_{\text {PF }}$ | 0 | 150 | 0 | 150 | 0 | 150 | ns |
| PROG Time P2 Input Must be Valid | $t_{\text {PR }}$ |  | 650 |  | 700 |  | 810 | ns |
| PROG Pulse Width | $\mathrm{t}_{\text {PP }}$ | 700 |  | 1150 |  | 1200 |  | ns |

*at 6 MHz XTAL for N version
at 8 MHz XTAL for $E$ version
at 11 MHz XTAL for $H$ version

## AC Characteristics

DMA Characteristics (Refer to the Fig. 4)

| Parameter | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. |  |
| DACK Setup Time (to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | $t_{\text {ACC }}$ |  | 0 |  | ns |
| DACK Hold Time (from $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | ${ }^{\text {c }}$ CAC |  | 0 |  | ns |
| Input Data Delay Time (from $\overline{\text { DACK) }}$ | $\mathrm{t}_{\mathrm{ACD}}$ | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |  | 225 | ns |
| DRQ Clear Time (from $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | ${ }^{\text {t }} \mathrm{CRQ}$ |  |  | 200 | ns |

AC Test Conditions
$\mathrm{V}_{\text {IL }}=0.8 \mathrm{~V}$ (All except XTAL1, 2, RESET)
$=0.6 \mathrm{~V}$ (XTAL1, 2, RESET)
$V_{I H}=2.0 \mathrm{~V}$ (All except XTAL1, 2, RESET) $=3.8 \mathrm{~V}$ (XTAL1. 2. RESET)
$\mathrm{V}_{\mathrm{OL}}=0.45 \mathrm{~V}$
$\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$
Output Load
D0-D7
$C_{L}=150 \mathrm{pF}$
$C_{L}=80 \mathrm{pF}$
All other outputs: $C_{L}=80 \mathrm{pF}$

## Timing Diagram

Figure 1. Data Bus Buffer (DBB) Read Operation


Figure 2. Data Bus Buffer (DBB) Write Operation


## Timing Diagram

(Continued)
Figure 3. Port 2 (Lower 4 Bits) Operation in Connection with I/O Expander


Figure 4. DMA Operation


## Oscillation Circuits


*Including capacitances

External Clock Drive


[^42]
## Package Dimensions

Dimensions in inches (millimeters)

## 40-Lead Ceramic

 (Metal Seal) Dual In-Line Package (Case No.: DIP-40C-A01)

$$
\text { © } 1986 \text { FUJITSU LIMITED D40006S-1C }
$$

## 40-Lead Plastic

## Dual In-Line Package

(Case No.: DIP-40P-M01)



© 1985 FUJITSU LIMITED D40005S-1C

The MBL8042 Universal Peripheral Interface is a single-chip 8-bit microcomputer based on an 8-bit parallel microprocessor chip.

The MBL8042 is fabricated with an N-channel silicon-gate MOS process. The MBL8042 has a $2 \mathrm{~K} \times 8$-bit ROM for program memory, a $128 \times 8$-bit RAM for data memory, 18 I/O ports, an 8 -bit timer/ counter and clock generator on the chip, and is powered by single +5 V .supply.

The MBL8042 is designed to operate as a slave processor, which receives commands and data from the master processor, controls peripheral devices and transfers input data from peripheral devices to the master processor. By using the MBL8042 an intelligent peripheral controller can be designed freely.

## Features

```
| Processor:
    8-bit parallel processing
- Register:
    One 8-bit Status Register
    (for Interface with master
    processor)
    Two 8-bit Data Bus Buffer
    Registers (for Input/Output)
\square}\mathrm{ Memory
    - 2K x }8\mathrm{ bit ROM (for
        program memory)
    - 128 x 8 bit RAM (for data
        memory)
    - I/O:
        One 8-bit Bidirectional Data
    Bus
    Two 8-bit Bidirectional I/O
    Ports
    Two Test Inputs
    | Clock Source:
    Clock Generator (with
    External Crystal Resonator)
    or External Clock
- Processor:
8-bit parallel processing
One 8-bit Status Register
(for Interface with master processor)
```

```
Registers (for Input/Output)
- Memory
- \(2 \mathrm{~K} \times 8\) bit ROM (for
\(-128 \times 8\) bit RAM (for data memory)
One 8-bit Bidirectional Data
Bus
Ports
Two Test Inputs
Clock Generator (with
External Crystal Resonator)
or External Clock
```

- 8-Bit Interval Timer/Event Counter
- Low-power Standby Operation Capability
- Power-on Reset Capability (with External Capacitor)
- Instruction Set: 93 Instructions
(217 Instruction Codes)
- 1-byte Instruction (about 70\%), 2-byte Instruction (about 30\%)
- 1-cycle or 2-cycle Instruction (1 cycle = $2.5 \mu \mathrm{~s}$ at 6 MHz XTAL )
- Technology:

N-channel Silicon-gate E/D MOS Process

- Two Package Options: Standard 40-pin Ceramic (Suffix-C) or Plastic DIP (Suffix-P)
- Equivalent: Intel 8042



## M푼8042H/界

## Block Diagram



Pin Assignment

*These pins are internally pulled up
This device contains circuitry to protect the inputs
against damage due to high static voltages or elec-
tric fields. However, it is advised that normal precau-
tions be taken to avoid application of any voltage
higher than maximum rated voltages to this high im-
pedance circuit.

## Pin Descriptions

| Pin No. | Name | Symbol | Description |
| :---: | :---: | :---: | :---: |
| 1 | Test 0 | $\mathrm{T}_{0}$ | Conditional Input for Conditional Branch |
| 2 | Crystal 1 | XTAL 1 | Input pin for an internal Clock Generator connected to external crystal. Also, this pin can be used as input from an external clock source. |
| 3 | Crystal 2 | XTAL 2 | Input pin for an internal Clock Generater connected to external crystal. <br> (Note: The XTAL 1 and XTAL 2 input levels are not TTL compatible). |
| 4 | Reset | RESET | Resets and forces the MPU to be initialized. (Note: This input level is not TTL compatible). |
| 5 | Single Step | $\overline{\text { SS }}$ | Input pin used for single step operation. |
| 6 | Chip Select | $\overline{C S}$ | Input pin used for the master processor to select the UPI. |
| 7 | External Address | EA | Input pin used for controlling program memory access. Holding EA high forces all program memory fetches to reference external memory. Useful for emulation and debug, and essential for testing and program verification. |
| 8 | Read Strobe | $\overline{\mathrm{RD}}$ | Strobe input enables the MBL8042 to read contents of the Data Bus Buffer register or Status register. |
| 9 | Address "0" | $\mathrm{A}_{0}$ | Address input to read/write data or read/write commands. <br> $A_{0}=$ " $L$ " indicates data read or write. <br> $A_{0}=$ " H " indicates status read or command write. |
| 10 | Write Strobe | WR | Strobe input enables the MBL8042 to write data into its Data Buffer register. |
| 11 | Sync | SYNC | A clock output pin indicating the MBL8042 instruction cycle. This pin is used when a synchronization signal is required for external circuits. |
| $\begin{aligned} & \hline 12 \\ & \text { thru } \\ & 19 \end{aligned}$ | Data Bus | $\begin{aligned} & \hline \mathrm{DB}_{0} \\ & \text { thru } \\ & \mathrm{DB}_{7} \end{aligned}$ | 8-bit bidirectional I/O port used to interface the MBL8042 to the master processor. |
| 20 | Ground | $\mathrm{V}_{S S}$ | Ground terminal. |
| $\begin{aligned} & 21 \\ & \text { thru } \\ & 24 \end{aligned}$ | Port 2 | $\begin{aligned} & \mathrm{P} 2_{0} \\ & \text { thru } \\ & \mathrm{P} 2_{3} \end{aligned}$ | Lower 4 bits of the quasi-bidirectional I/O port (Port 2). These function as interface port with the I/O expander (MBL8243) when an expansion I/O executes instruction. During single step operation upper 3 bits of the program fetch address are output on P20, P21, P22. |
| 25 | Program | PROG | A strobe signal output pin for an I/O expander (MBL8243) used, when performing an expansion I/O instruction. |
| 26 | Power Supply | $V_{\text {DD }}$ | Power supply pin ( +5 V ) for internal RAM. |
| $\begin{aligned} & \hline 27 \\ & \text { thru } \\ & 34 \end{aligned}$ | Port 1 | $\begin{aligned} & \mathrm{P} 1_{0} \\ & \text { thru } \\ & \mathrm{P} 1_{7} \\ & \hline \end{aligned}$ | Quasi-bidirectional I/O ports (Port 1). During single step operation, the next program fetch address (Lower 8 bits) is output. |
| $\begin{aligned} & \hline 35 \\ & \text { thru } \\ & 38 \\ & \hline \end{aligned}$ | Port 2 | $\begin{aligned} & \hline \mathrm{P}_{4} \\ & \text { thru } \\ & \mathrm{P} 2_{7} \\ & \hline \end{aligned}$ | Upper 4 bits of the quasi-bidirectional I/O port (port 2). These function as the flag output pins $\left(\mathrm{P}_{4}\right.$ and $\left.\mathrm{P}_{5}\right)$ and DMA pins ( $\mathrm{P}_{6}$ and $\mathrm{P}_{7}$ ) according to instructions. |
| 39 | Test 1 | $\mathrm{T}_{1}$ | This pin has the following functions according to instruction: <br> 1. Event Input pin for the Event Counter. <br> 2. Condition Input pin for Conditional Branch. |
| 40 | Power Supply | $\mathrm{V}_{\mathrm{CC}}$ | Power supply pin (+5V). |

System Interface

The master processor and MBL8042 are interfaced through the data bus buffer.

MBL8042 has 2 internal DBB (Data Bus Buffer) registers. The register to be accessed is determined by the address line and strobe signal.

Flag 1 ( F 1 ) is set when a command is written ( $A_{0}=1$ ), and reset when data is written ( $\mathrm{A}_{0}=0$ ).

The master processor can read only data from the output DBB register, and cannot read and check data or commands which the master processor has written itself.

When MBL8042 writes data to the output DBB with the OUT DBB, $A$ instruction, OBF is set.

When DBB is read ( $\overline{C S}=R D=$ $A_{0}=0, W R=1$ ) by the master processor, OBF is reset. IBF is set when the master processor writes to the DBB, and reset when MBL8042 reads data from the DBB with IN A, DBB instruction.

The internal status of the MBL8042 does not change when the status register contents are read out. $\overline{\text { CS }} \quad \overline{\text { RD }} \quad \overline{\text { WR }} \quad \mathbf{A}_{0} \quad$ Description

| 0 | 0 | 1 | 0 | Read DBB (Output) register. |
| :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | 1 | Read Status Register. |
| 0 | 1 | 0 | 0 | Write DBB (Input) register (Data). |
| 0 | 1 | 0 | 1 | Write DBB (Input) register (Command). |
| 1 | x | x | x | Invalid. |

Interface between MBL8042 and Master Processor

Resident Data Memory
Map (RAM)


Status Register (PSW)
The Status Register is an 8-bit register configured as shown in the following figure. The upper four bits are used for flags to indicate the status of the MPU and when a sub-routine call or an interrupt occurs, the contents of the program counter is transferred to one of the 8 register pairs of the Stack Register as determined by the lower three bits of the Status Register. The remaining one bit is an unused bit.

## Flags

C (Carry): When an overflow occurs in the Accumulator, this bit is set to " 1 ".

AC (Auxiliary Carry): When an overflow occurs from Bit 3 to Bit 4 in the accumulator, this bit is set to " 1 ".
$F_{0}$ (User Flag): This flag can be controlled as a user flag by the proper instruction.

BS (Bank Select): This flag can be controlled to select a Register Bank by an instruction. When BS $=0$, Register Bank 0 is selected. When BS = 1 , the Register Bank 1 is selected.

## Stack Register (8 Level

 Capability)The Stack Register has 16 bytes of memory area in the built-in RAM. The stack Register consists of eight levels, i.e. a Stack level consists of two bytes as shown below.

SP (Stack Pointer): In the diagram below, "SP" indicates a Stack Pointer address to be used for the next sub-routine call or interrupt. " SP " is given an 8 -bit code from the lower three bits of Status Register as follows:

$\mathrm{PC}_{\mathrm{n}}$ (Program Counter): " $\mathrm{PC}_{n}$ " indicates the contents of the $n$-th bit in the Program Counter.

## Interrupt Processing (IBF Interrupt, Timer/Counter Interrupt)

There are two types of interrupt: the IBF interrupt and Timer/Counter interrupt.

If an interrupt occurs when the system is in "interrupt enable" status, the interrupt flag is set as soon as the current instruction is completed.

When the interrupt processing begins, the Status and Program Counter contents are
first stored in the stack.
Then, operation jumps to Address 3 in the case of the IBF interrupt and Address 7 in the case of a timer interrupt.

After the interrupt has been processed by a user program and RETR (Return and Restore Status) instruction has been executed, the Status and Program Counter contents stored in the stack are restored, the interrupt flag is reset and the system is ready to accept the next interrupt request.

A Timer/Counter interrupt request occurs when the Timer/Counter overflow flag is set due to Timer/Counter overflow.

However, since the Timer/Counter interrupt request is masked by the IBF interrupt request, IBF interrupt has first priority.

The Timer/Counter interrupt is enabled after the IBF interrupt has been executed and the system has become ready to receive the next interrupt request.


Operation Flow Chart


Interrupt Flow Chart


Instruction Set Summary
Accumulator

| Operation | Mnemonic | OP <br> Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Add register to $\mathbf{A}$ | ADD A, Rr | 6X | 1 | 1 | * | * | $(A) \longleftarrow(A)+(R r)$ |
| Add data memory to $A$ | ADD A, @R0 | 60 | 1 | 1 | * | * | $(A) \longleftarrow(A)+((R 0))$ |
|  | ADD A, @R1 | 61 | 1 | 1 | * | * | $(A) \longleftarrow(A)+((R 1))$ |
| Add immediate to $A$ | ADD A, \#data | 03 | 2 | 2 | * | * | $(A) \leftarrow(A)+$ data |
| Add register to A with Carry | ADDC A, Rr | 7X | 1 | 1 | * | * | $(A) \leftarrow(A)+(R r)+C$ |
| to A with Carry | ADDC A, @RO | 70 | 1 | 1 | * | * | $(A) \leftarrow(A)+((R 0))+C$ |
|  | ADDC A, @R1 | 71 | 1 | 1 | * | * | $(A) \leftarrow(A)+((R 1))+C$ |
| Add immediate to A with Carry | ADDC A, \#data | 13 | 2 | 2 | * | * | $(A) \leftarrow(A)+$ data $+C$ |
| AND register to A | ANL A, Rr | 5X | 1 | 1 | - | - | (A) - (A) AND (Rr) |
| AND data memory to A | ANL A, @R0 | 50 | 1 | 1 | - | - | $(A)-(A) A N D ~(R O)$ |
|  | ANL A, @R1 | 51 | 1 | 1 | - | - | $(A) \leftarrow(A)$ AND (R1) |
| AND immediate to A | ANL A, \#data | 53 | 2 | 2 | - | - | $(A) \leftarrow(A)$ AND data |
| OR register to $A$ | ORL A, Rr | 4X | 1 | 1 | - | - | (A) - (A) OR (Rr) |
| OR data memory to A | ORL A, @RO | 40 | 1 | 1 | - | - | $(A) \leftarrow(A) O R((R 0))$ |
|  | ORL A, @R1 | 41 | 1 | 1 | - | - | $(\mathrm{A})-(\mathrm{A}) \mathrm{OR}((\mathrm{R} 1))$ |
| OR immediate to $A$ | ORL A, \#data | 43 | 2 | 2 | - | - | $(A)-(A)$ OR data |
| Exclusive OR data memory to A | XRL A, Rr | DX | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A}) \times \mathrm{OR}(\mathrm{Rr})$ |
|  | XRL A, @RO | D0 | 1 | 1 | - | - | $(\mathrm{A})-(\mathrm{A}) \mathrm{XOR} \mathrm{( } \mathrm{RO})$ ) |
|  | XRL A, @R1 | D1 | 1 | 1 | - | - | $(\mathrm{A})-(\mathrm{A}) \mathrm{XOR}((\mathrm{R} 1))$ |
| Exclusive OR immediate to $A$ | XRL A, \#data | D3 | 2 | 2 | - | - | $(A) \rightarrow(A)$ XOR data |
| Increment A | INC A | 17 | 1 | 1 | - | - | $(A)-(A)+1$ |
| Decrement A | DEC A | 07 | 1 | 1 | - | - | $(A) \leftarrow(A)-1$ |
| Clear A | CLR A | 27 | 1 | 1 | - | - | $(\mathrm{A})-0$ |
| Complement A | CPL A | 37 | 1 | 1 | - | - | $(\mathrm{A})-(\bar{A})$ |
| Decimal Adjust A | DA A | 57 | 1 | 1 | * | - | Note (1) |
| Swap nibbles of $A$ | SWAP A | 47 | 1 | 1 | - | - | $(A 7 \sim 4) \rightleftarrows(A 3 \sim 0)$ |
| Rotate A Left | RL A | E7 | 1 | 1 | - | - | $\begin{aligned} & 7 \\ & \begin{array}{\|l\|l\|l} \hline 7 & \\ \hline \end{array} \end{aligned}$ |
| Rotate A Left through Carry | RLC A | F7 | 1 | 1 | * | - | $\square_{7} \square^{\square 1}$ |
| Rotate A Right | RR A | 77 | 1 | 1 | - | - | 7 - |
| Rotate A Right through Carry | RRC A | 67 | 1 | 1 | * | - | C |

Note 1: The accumulator value is adjusted to form BCD digits following the binary addition of BCD numbers. Operation Code X: Table 1
Flag*: This flag is set or reset in the state after executed instruction.
Input/Output

| Operation | Mnemonic | OP Code | Byte | Cycle | Fiag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Input port to A | IN A, P1 | 09 | 1 | 2 | - | - | ( A$) \leftarrow(\mathrm{P} 1)$ |
|  | IN A, P2 | 0A | 1 | 2 | - | - | (A) - (P2) |
| Output A to port | OUTL P1, A | 39 | 1 | 2 | - | - | $(\mathrm{P} 1)-(\mathrm{A})$ |
|  | OUTL P2, A | 3A | 1 | 2 | - | - | $(\mathrm{P} 2)-(\mathrm{A})$ |
| AND immediate to port | ANL P1, \#data | 99 | 2 | 2 | - | - | $(\mathrm{P} 1)$ - (P1) AND data |
|  | ANL P2, \#data | 9A | 2 | 2 | - | - | $(\mathrm{P} 2)-(\mathrm{P} 2)$ AND data |
| OR immediate to port | ORL P1, \#data | 89 | 2 | 2 | - | - | (P1) - (P1) OR data |
|  | ORL P2, \#data | 8A | 2 | 2 | - | - | (P2) - (P2) OR data |
| Input DBB to A, clear IBF | IN A, DBB | 22 | 1 | 1 | - | - | (A) - (DBB), (IBF)-0 |
| Output A to DBB, set OBF | OUT DBB, A | 02 | 1 | 1 | - | - | $(\mathrm{DBB})-(\mathrm{A}),(\mathrm{OBF})-1$ |
| A7~4 to bits 7~4 of Status | MOV STS, A | 90 | 1 | 1 | - | - | $(S T S 7) \sim 4) \leftarrow(A 7 \sim 4)$ |
| Input Expander port to A | MOVD A, $\mathrm{P}_{\mathrm{P}}$ | OX | 1 | 2 | - | - | $(A 3 \sim 0)-\left(P_{P}\right),(A 7 \sim 4)-0$ |
| Output A to Expander port | MOVD $P_{P}, A$ | 3 X | 1 | 2 | - | - | $\left(P_{P}\right)-(A 3 \sim 0)$ |
| AND A to Expander port | ANLD $P_{P}, A$ | 9x | 1 | 2 | - | - | $\left(P_{P}\right)-\left(P_{P}\right)$ AND ( ${ }^{\text {3 }} \sim 0$ ) |
| OR A to Expander port | ORLD $P_{P}, A$ | 8X | 1 | 2 | - | - | $\left(P_{P}\right)-\left(P_{P}\right)$ OR ( $\left.\mathrm{A} 3 \sim 0\right)$ |

[^43]
## Instruction Set Summary <br> (Continued)

Data Moves

| Operation | Mnemonic | OP Code | Byto | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Move register to $A$ | MOV A, Rr | FX | 1 | 1 | - | - | (A) - (Rr) |
| Move data memory to $A$ | MOV A, @RO | FO | 1 | 1 | - | - | (A) - ((R0)) |
|  | MOV A, @R1 | F1 | 1 | 1 | - | - | (A) - ( R 1$)$ ) |
| Move immediate to $A$ | MOV A, \#data | 23 | 2 | 2 | - | - | (A) - data |
| Move $A$ to register | MOV Rr, A | AX | 1 | 1 | - | - | $(\mathrm{Rr})-(\mathrm{A})$ |
| Move A to data memory | MOV @RO, A | AO | 1 | 1 | - | - | $((\mathrm{RO}) \mathrm{)}$ - (A) |
|  | MOV @R1, A | A1 | 1 | 1 | - | - | $((\mathrm{R} 1)$ ) - (A) |
| Move immediate to register | MOV Rr, \#data | $B X$ | 2 | 2 | - | - | (Rr) - data |
| Move immediate to data memory | MOV @RO, \#data | B0 | 2 | 2 | - | - | ((R0)) - data |
|  | MOV @R1, \#data | B1 | 2 | 2 | - | - | ((R1)) - data |
| Move PSW to A | MOV A, PSW | C7 | 1 | 1 | - | - | $(\mathrm{A})-(\mathrm{PSW})$ |
| Move A to PSW | MOV PSW, A | D7 | 1 | 1 | * | * | (PSW) - (A) |
| Exchange A and register | XCH A, Rr | 2 X | 1 | 1 | - | - | $(\mathrm{A}) \leftrightarrows(\mathrm{Rr})$ |
| Exchange $A$ and data memory | XCH A, @RO | 20 | 1 | 1 | - | - | (A) $二((R 0))$ |
|  | XCH. A, @R1 | 21 | 1 | 1 | - | - | $(\mathrm{A})=((\mathrm{R} 1))$ |
| Exchange digit of A and data memory | XCHD A, @RO | 30 | 1 | 1 | - | - | $(\mathrm{A} 3 \sim 0) \leftrightharpoons\left((\mathrm{RO}) 3{ }^{\sim} 00\right.$ |
|  | XCHD A, @R1 | 31 | 1 | 1 | - | - | $(\mathrm{A} 3 \sim 0) \leftrightharpoons((\mathrm{R} 1) 3 \sim 0)$ |
| Move to A from current page | MOVP A, @A | A3 | 1 | 2 | - | - | (A) - ( A$)$ ) within page |
| Move to A from Page 3 | MOVP3 A, @A | E3 | 1 | 2 | - | - | $(\mathrm{A})-((\mathrm{A}))$ within page 3 |

Operation Code X: Table 1
Flag*: This flag is set or reset in the state after executed instruction.

## Timer/Counter

| Operation | Mnemonic | OP <br> Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Read Timer/Counter | MOV A, T | 42 | 1 | 1 | - | - | (A) - (T) |
| Load Timer/Counter | MOV T, A | 62 | 1 | 1 | - | - | $(T)-(A)$ |
| Start Timer | STRT T | 55 | 1 | 1 | - | - |  |
| Start Counter | STRT CNT | 45 | 1 | 1 | - | - |  |
| Stop Timer/Counter | STOP TCNT | 65 | 1 | 1 | - | - |  |
| Enable Timer/ Counter Interrupt | EN TCNTI | 25 | 1 | 1 | - | - |  |
| Disable Timer/ Counter Interrupt | DIS TCNTI | 35 | 1 | 1 | - | - |  |

## Control

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Enable DMA Handshake Lines | EN DMA | E5 | 1 | 1 | - | - |  |
| Enable IBF Interrupt | EN I | 05 | 1 | 1 | - | - |  |
| Disable IBF Interrupt | DIS I | 15 | 1 | 1 | - | - |  |
| Enable Master Interrupts | EN FLAGS | F5 | 1 | 1 | - | - |  |
| Select register bank 0 | SEL RBO | C5 | 1 | 1 | - | - | (BS) - 0 |
| Select register bank 1 | SEL RB1 | D5 | 1 | 1 | - | - | (BS) - 1 |
| No Operation | NOP | 00 | 1 | 1 | - | - |  |

Instruction Set Summary
(Continued)

## Register

| Operation | Mnemonic | OP <br> Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | c | AC |  |
| Increment register | INC Rr | 1X | 1 | 1 | - | - | $(\mathrm{Rr})-(\mathrm{Rr})+1$ |
| Increment data memory | INC@RO | 10 | 1 | 1 | - | - | $((\mathrm{RO}))-((\mathrm{RO}))+1$ |
|  | INC@R1 | 11 | 1 | 1 | - | - | $((\mathrm{R} 1))-((\mathrm{R} 1))+1$ |
| Decrement register | DEC Rr | CX | 1 | 1 | - | - | $(\mathrm{Rr})-(\mathrm{Rr})-1$ |

Operation Code X: Table 1
Subroutine

|  | OP |  |  |  | Flag |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Operation | Mnemonic | Code | Byte | Cycle | C | AC | Note |
| Jump to Subroutine | CALL addr | $\% 4$ | 2 | 2 | - | - | Note (2) |
| Return | RET | 83 | 1 | 2 | - | - | Note (3) |
| Return and restore status | RETR | 93 | 1 | 2 | $*$ | $*$ | Note (4) |

Operation Code \%: Table 3
Flag*: This flag is set or reset in the state after executed instruction.
Flags

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Clear Carry | CLR C | 97 | 1 | 1 | Z | - | (C) -0 |
| Complement Carry | CPL C | A7 | 1 | 1 | CP | - | (C) $-(\bar{C})$ |
| Clear Flag 0 | CLR F0 | 85 | 1 | 1 | - | - | (FO) -0 |
| Complement Flag 0 | CPL F0 | 95 | 1 | 1 | - | - | (FO) - (FO) |
| Clear Flag 1 | CLR F1 | A5 | 1 | 1 | - | - | (F1) -0 |
| Complement Flag 1 | CPL F1 | B5 | 1 | 1 | - | - | $(\mathrm{F} 1)-(\overline{\mathrm{F} 1})$ |

Flag Z: Reset CP: Invert

## Branch

| Operation | Mnemonic | OP Code | Byte | Cycle | Flag |  | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Jump unconditional | JMP addr | \%4 | 2 | 2 | - | - | Unconditional Branch |
| Jump indirect | JMPP @ A | B3 | 1 | 2 | - | - | Unconditional Branch Note (5) |
| Decrement register and jump | DJNZ Rr,addr | EX | 2 | 2 | - | - | $(\mathrm{Rr}) \neq 0$ Note (6) |
| Jump on Carry = 1 | JC addr | F6 | 2 | 2 | - | - | (C) $=1$ |
| Jump on Carry $=0$ | JNC addr | E6 | 2 | 2 | - | - | (C) $=0$ |
| Jump on A Zero | JZ addr | C6 | 2 | 2 | - | - | $(\mathrm{A})=0$ |
| Jump on A not Zero | JNZ addr | 96 | 2 | 2 | - | - | $(\mathrm{A}) \neq 0$ |
| Jump on T0 = 1 | JT0 addr | 36 | 2 | 2 | - | - | (T0) $=\mathrm{H}$ |
| Jump on T0 $=0$ | JNTO addr | 26 | 2 | 2 | - | - | (TO) $=\mathrm{L}$ |
| Jump on T1 $=1$ | JT1 addr | 56 | 2 | 2 | - | - | $(\mathrm{T} 1)=\mathrm{H}$ |
| Jump on T1 $=0$ | JNT1 addr | 46 | 2 | 2 | - | - | $(\mathrm{T} 1)=\mathrm{L}$ |
| Jump on F0 = 1 | JFO addr | B6 | 2 | 2 | - | - | $(\mathrm{FO})=1$ |
| Jump on F1 $=1$ | JF1 addr | 76 | 2 | 2 | - | - | $(F 1)=1$ |
| $\begin{aligned} & \text { Jump on Timer Flag }=1 \text {, } \\ & \text { Clear Flag } \end{aligned}$ | JTF addr | 16 | 2 | 2 | - | - | $(\mathrm{TF})=1$ |
| Jump on IBF Flag $=0$ | JNIBF addr | D6 | 2 | 2 | - | - | (IBF) $=0$ |
| Jump on OBF Flag $=1$ | JOBF addr | 86 | 2 | 2 | - | - | $(\mathrm{OBF})=1$ |
| Jump on Accumulator Bit | JBb addr | \%2 | 2 | 2 | - | - | $(\mathrm{Ab})=1$ |

Operation Code X: Table 1 $\%$ : Table 3

Note 2: Call addr

$$
\begin{aligned}
& ((S P))-(P C),(P S W 7 \sim 4) \\
& (S P)-(S P)+1 \\
& (P C 10 \sim 8)-A_{H} \\
& (P C 7 \sim 0)-A_{L}
\end{aligned}
$$

Note 3: RET

$$
\begin{aligned}
& (S P)-(S P)-1 \\
& (P C)-((S P))
\end{aligned}
$$

Note 4: RETR

$$
\begin{aligned}
& (S P)-(S P)-1 \\
& (P C)-((S P)) \\
& (P S W 7 \sim 4) \leftarrow((S P))
\end{aligned}
$$

Note 5: JMPP @

$$
(P C 7 \sim 0)-((A))
$$

Note 6: DJNZ Rr, addr

$$
(R r)-(R r)-1
$$

if $(\mathrm{Rr}) \neq 0(\mathrm{PC} 7 \sim 0) \leftarrow$ addr
if $(\mathrm{Rr})=0$ Execute next instruction

Instruction Set Summary
(Continued)


OP Code Of JMP, CALL, JBb (Table 3)

$A_{H} ;$ Address $A_{10}, A_{9}, A_{8}$
$A_{L} ;$ Address $A_{7}$ to $A_{0}$
$B_{b} ; b$-th Bit on Accumulator

## Instruction Codes

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | c | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | NOP |  | $\begin{aligned} & \text { OUT } \\ & \text { DBB, } \end{aligned}$ | $\begin{gathered} \text { ADD } \\ \text { A, \# } \end{gathered}$ | $\begin{aligned} & \text { JMP } \\ & 0 \times x \end{aligned}$ | $\underset{i}{\text { EN }}$ |  | $\underset{\mathrm{A}}{\mathrm{DEC}}$ |  | $\begin{gathered} \text { IN } \\ A, P 1 \end{gathered}$ | $\begin{gathered} \text { IN } \\ \mathrm{A}, \mathrm{P} 2 \end{gathered}$ |  | $\begin{gathered} \text { MOVD } \\ \text { A, P4 } \end{gathered}$ | $\begin{aligned} & \text { MOVD } \\ & \text { A, P5 } \end{aligned}$ | $\begin{aligned} & \text { MOVD } \\ & \text { A, P6 } \end{aligned}$ | $\begin{aligned} & \text { MOVD } \\ & \text { A, P7 } \end{aligned}$ |
| 1 | $\begin{aligned} & \text { INC } \\ & \text { @RO } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { @R1 } \end{aligned}$ | $\begin{aligned} & \text { JBO } \\ & \text { addr } \end{aligned}$ | $\begin{gathered} \text { ADDC } \\ \text { A, \# } \end{gathered}$ | $\begin{aligned} & \text { CALL } \\ & 0 \times x \end{aligned}$ | DIS | JTF addr | $\underset{A}{\text { INC }}$ | $\begin{aligned} & \text { INC } \\ & \text { RO } \end{aligned}$ | $\begin{gathered} \text { INC } \\ \text { R1 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R2 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R3 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R4 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R5 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R6 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R7 } \end{gathered}$ |
| 2 | $\begin{gathered} \mathrm{XCH} \\ \text { A, @R0 } \end{gathered}$ | $\begin{gathered} \text { XCH } \\ \text { A, @R1 } \end{gathered}$ | $\begin{gathered} \text { IN } \\ \mathrm{A}, \mathrm{DBB} \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { A, \# } \end{gathered}$ | $\begin{aligned} & \text { JMP } \\ & 1 \times \mathrm{x} \end{aligned}$ | $\begin{gathered} \text { EN } \\ \text { TCNTI } \end{gathered}$ | JNTO addr | $\underset{\mathrm{A}}{\mathrm{CLR}}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{RO} \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 1 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 3 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 4 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 5 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 6 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 7 \end{aligned}$ |
| 3 | $\begin{aligned} & \text { XCHD } \\ & \text { A, @RO } \end{aligned}$ | $\begin{aligned} & \text { XCHD } \\ & \text { A, @R1 } \end{aligned}$ | $\begin{aligned} & \text { JB1 } \\ & \text { addr } \end{aligned}$ |  | $\begin{aligned} & \text { CALL } \\ & 1 \times x \end{aligned}$ | $\begin{gathered} \text { DIS } \\ \text { TCNTI } \end{gathered}$ | $\begin{aligned} & \text { JTO } \\ & \text { addr } \end{aligned}$ | $\underset{A}{\mathrm{CPL}}$ |  | $\begin{aligned} & \text { OUTL } \\ & \text { P1, A } \end{aligned}$ | $\begin{aligned} & \text { OUTL } \\ & \text { P2, A } \end{aligned}$ |  | movd <br> P4, A | $\begin{aligned} & \text { MOVD } \\ & \text { P5, A } \end{aligned}$ | MOVD <br> P6, A | $\begin{gathered} \text { MOVD } \\ \text { P7, A } \end{gathered}$ |
| 4 | $\begin{aligned} & \text { ORL } \\ & \text { A, @R0 } \end{aligned}$ | $\begin{gathered} \text { ORL } \\ \text { A, @R1 } \end{gathered}$ | $\begin{gathered} \mathrm{MOV} \\ \mathrm{~A}, \mathrm{~T} \end{gathered}$ | $\begin{aligned} & \text { ORL } \\ & \text { A, \# } \end{aligned}$ | $\begin{aligned} & \text { JMP } \\ & 2 \times \mathrm{x} \end{aligned}$ | STRT | JNT1 addr | $\begin{aligned} & \text { SWAP } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A, RO } \end{aligned}$ | ORL <br> A, R1 | $\begin{aligned} & \text { ORL } \\ & \text { A, R2 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A, R4 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A, R5 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A, R6 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A, R7 } \end{aligned}$ |
| 5 | $\begin{gathered} \text { ANL } \\ \text { A, @RO } \end{gathered}$ | $\begin{gathered} \text { ANL } \\ \text { A, @R1 } \end{gathered}$ | $\begin{aligned} & \text { JB2 } \\ & \text { addr } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, \# } \end{aligned}$ | $\begin{aligned} & \text { CALL } \\ & 2 \times x \end{aligned}$ | $\underset{T}{\text { STRT }}$ | JT1 addr | $\begin{gathered} \text { DA } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \mathrm{ANL} \\ & \mathrm{~A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \mathrm{A}, \mathrm{R} 4 \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \mathrm{A}, \mathrm{RS} \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R6 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R7 } \end{aligned}$ |
| 6 | $\begin{gathered} \text { ADD } \\ \text { A, @RO } \end{gathered}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, @R1 } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \mathrm{T}, \mathrm{~A} \end{gathered}$ |  | JMP $3 \times \mathrm{x}$ | $\begin{aligned} & \text { STOP } \\ & \text { TCNT } \end{aligned}$ |  | $\underset{A}{\text { RRC }}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R2 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R4 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R6 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R7 } \end{aligned}$ |
| 7 | $\begin{aligned} & \text { ADDC } \\ & \text { A, @RO } \end{aligned}$ | ADDC <br> A, @R1 | $\begin{aligned} & \text { JB3 } \\ & \text { addr } \end{aligned}$ |  | $\begin{aligned} & \text { CALL } \\ & 3 x \times x \end{aligned}$ |  | JF1 addr | $\begin{gathered} \text { RR } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A, R2 } \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A, R3 } \end{aligned}$ | ADDC <br> A, R4 | $\begin{aligned} & \text { ADDC } \\ & \text { A, R5 } \end{aligned}$ | $\begin{gathered} \text { ADDC } \\ \text { A, R6 } \end{gathered}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A, R7 } \end{aligned}$ |
| 8 |  |  |  | RET | $\mathrm{JMP}_{4 \times \mathrm{x}}$ | $\begin{gathered} \text { CLR } \\ \text { F0 } \end{gathered}$ | JOBF addr |  |  | $\begin{aligned} & \text { ORL } \\ & \text { P1, \# } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { P2, \# } \end{aligned}$ |  | $\begin{aligned} & \text { ORLD } \\ & \text { P4, A } \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \text { P5, A } \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \text { P6, A } \end{aligned}$ | $\begin{aligned} & \text { ORLD } \\ & \text { P7, A } \end{aligned}$ |
| 9 | $\begin{gathered} \text { MOV } \\ \text { sTs, A } \end{gathered}$ |  | JB4 addr | RETR | $\begin{gathered} \text { CALL } \\ 4 \times \mathrm{x} \end{gathered}$ | $\begin{aligned} & \text { CPL } \\ & \text { FO } \end{aligned}$ | JNZ addr | $\underset{\mathrm{C}}{\mathrm{CLR}}$ |  | ANL P1, \# | $\begin{aligned} & \text { ANL } \\ & \text { P2, \# } \end{aligned}$ |  | $\begin{gathered} \text { ANLD } \\ \text { P4, A } \end{gathered}$ | $\begin{gathered} \text { ANLD } \\ \text { P5, A } \end{gathered}$ | $\begin{gathered} \text { ANLD } \\ \text { P6, A } \end{gathered}$ | $\begin{aligned} & \text { ANLD } \\ & \text { P7, A } \end{aligned}$ |
| A | $\begin{gathered} \text { MOV } \\ @ R O, \text { A } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ @ R 1, A \end{gathered}$ |  | MOVP <br> A, @A | $\begin{aligned} & \mathrm{JMP} \\ & 5 \times \mathrm{x} \end{aligned}$ | $\underset{F 1}{\text { CLR }}$ |  | $\stackrel{\mathrm{CPL}}{\mathrm{C}}$ | MOV <br> RO, A | MOV <br> R1, A | MOV <br> R2, A | MOV <br> R3, A | MOV <br> R4, A | MOV R5, A | MOV R6, A | MOV <br> R7, A |
| B | $\begin{gathered} \text { MOV } \\ \text { @RO, \# } \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & \text { @R1, } \end{aligned}$ | $\begin{aligned} & \text { JB5 } \\ & \text { addr } \end{aligned}$ | JMPP <br> @A | $\begin{aligned} & \text { CALL } \\ & 5 \times x \end{aligned}$ | $\begin{gathered} \mathrm{CPL} \\ \mathrm{~F} 1 \end{gathered}$ | JFO addr |  | $\begin{aligned} & \text { MOV } \\ & \text { RO, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R1, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R2, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R3, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R4, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R5, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R6, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R7, \# } \end{aligned}$ |
| C |  |  |  |  | JMP $6 \times \times$ | $\begin{aligned} & \text { SEL } \\ & \text { RBO } \end{aligned}$ | $\underset{\text { addr }}{\mathrm{JZ}}$ | $\begin{gathered} \mathrm{MOV} \\ \mathrm{~A}, \mathrm{PSW} \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { RO } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R1 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R2 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R3 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R4 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R5 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { RG } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R7 } \end{gathered}$ |
| D | $\begin{gathered} \text { XRL } \\ \text { A, @RO } \end{gathered}$ | $\begin{gathered} \text { XRL } \\ \text { A, @R1 } \end{gathered}$ | JB6 addr | $\begin{aligned} & \text { XRL } \\ & \text { A, \# } \end{aligned}$ | $\begin{aligned} & \text { CALL } \\ & 6 \times x \end{aligned}$ | $\begin{aligned} & \text { SEL } \\ & \text { RB1 } \end{aligned}$ | JNIBF addr | $\begin{gathered} \text { MOV } \\ \text { PSW, A } \end{gathered}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & A, R 1 \end{aligned}$ | $\begin{aligned} & \mathrm{XRL} \\ & \mathrm{~A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \mathrm{XRL} \\ & \mathrm{~A}, \mathrm{R} 4 \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R5 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R6 } \end{aligned}$ | $\begin{gathered} \text { XRL } \\ \mathrm{A}, \mathrm{RT} \end{gathered}$ |
| E |  |  |  | MOVP3 A.@A | $\begin{aligned} & \text { JMP } \\ & 7 \times x \end{aligned}$ | $\begin{aligned} & \text { EN } \\ & \text { DMA } \end{aligned}$ | JNC addr | $\begin{gathered} \text { RL } \\ \text { A } \end{gathered}$ | $\begin{gathered} \text { DJNZ } \\ \text { RO, addr } \end{gathered}$ | $\begin{gathered} \text { DJNZ } \\ \text { R1, addr } \end{gathered}$ | DJNZ <br> R2, addr | DJNZ R3, addr | $\begin{gathered} \text { DJNZ } \\ \text { R4, addr } \end{gathered}$ | DJNZ <br> R5, addr | $\begin{gathered} \text { DJNZ } \\ \text { R6, addr } \end{gathered}$ | $\begin{gathered} \text { DJNZ } \\ \text { R7, addr } \end{gathered}$ |
| F | $\begin{gathered} \text { MOV } \\ \text { A, @RO } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { A, @R1 } \end{gathered}$ | JB7 addr |  | $\begin{aligned} & \text { CALL } \\ & 7 \times x \end{aligned}$ | $\begin{gathered} \text { EN } \\ \text { FLAGS } \end{gathered}$ | JC addr | $\underset{\text { A }}{\text { RLC }}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, R2 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, R4 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, R5 } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, R6 } \end{aligned}$ | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{~A}, \mathrm{R} 7 \end{aligned}$ |

\#: Immediate data
$\square$ 1 Byte, 1 Cycle Instruction
$\square$ 1 Byte, 2 Cycle Instruction
$\square$ 2 Byte, 2 Cycle Instruction

## Absolute Maximum Ratings

## Recommended Operating Conditions

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to +7.0 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 1.5 | W |

Note: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational specifications of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}$ | $+5.0 \pm 10 \%$ | V |
| Operating Temperature | $\mathrm{V}_{S S}$ | 0 | V |

## DC Characteristics

( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{\mathrm{DD}}$ $=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ )

| Parameter |  | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Max. |  |
| Input Low Voltage | All Except XTAL1, 2, $\overline{\text { RESET }}$ | $\mathrm{V}_{\text {IL }}$ |  | -0.3 | 0.8 | V |
|  | XTAL1,2, $\overline{\text { RESET }}$ | $\mathrm{V}_{\text {LL }}$ |  | -0.3 | 0.6 | V |
| Input High Voltage | All Except XTAL1, 2, $\overline{\text { RESET }}$ | $\mathrm{V}_{1 \text { H }}$ |  | 2.0 | $\mathrm{V}_{\mathrm{cc}}$ | V |
|  | XTAL1,2, RESET | $\mathrm{V}_{\mathrm{IH} 1}$ |  | 3.8 | $\mathrm{V}_{C C}$ | V |
| Output Low Voltage | $\mathrm{DB}_{0}$ to $\mathrm{DB}_{7}$ | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |  | 0.45 | V |
|  | P10-P17, P20-P27 SYNC | $\mathrm{V}_{\text {OL1 }}$ | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |  | 0.45 | V |
|  | PROG | $\mathrm{V}_{\mathrm{OL} 2}$ | $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ |  | 0.45 | V |
| Output High Voltage | $\mathrm{DB}_{0}$ to $\mathrm{DB}_{7}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{IOH}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 |  |  |
|  | All other outputs | $\mathrm{V}_{\mathrm{OH} 1}$ | $\mathrm{IOH}=-50 \mu \mathrm{~A}$ | 2.4 |  |  |
| Input Leakage Current | $\begin{aligned} & \mathrm{T}_{0}, \mathrm{~T}_{1}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{CS}}, \\ & \mathrm{~A}_{0}, \mathrm{EA} \end{aligned}$ | IIL | $\mathrm{V}_{\text {SS }} \leqq \mathrm{V}_{\text {IN }} \leqq \mathrm{V}_{\text {CC }}$ |  | $\pm 10$ | $\mu \mathrm{A}$ |
| Output Leakage Current | $\begin{aligned} & \mathrm{DB}_{0} \text { to } \mathrm{DB}_{7} \\ & \text { (High Z State) } \end{aligned}$ | $\mathrm{I}_{\text {OL }}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+0.45 \mathrm{~V} \leqq \\ & \mathrm{~V}_{\mathrm{IN}} \leqq \mathrm{~V}_{\mathrm{CC}} \\ & \hline \end{aligned}$ |  | $\pm 10$ | $\mu \mathrm{A}$ |
| Input Low Current | $\begin{aligned} & \mathrm{P1}_{0} \text { to } \mathrm{P} 1_{7} \\ & \mathrm{P}_{2} \text { to } \mathrm{P2}_{7} \\ & \hline \end{aligned}$ | $\mathrm{I}_{\mathrm{L}}$ | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |  | 0.5 | mA |
|  | RESET, $\overline{\mathrm{SS}}$ | LIII | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |  | 0.2 | mA |
| $V_{D D}$ Supply Current |  | $\mathrm{I}_{\mathrm{DD}}$ |  |  | 15 | mA |
| Supply Current |  | $\begin{aligned} & \mathrm{I}_{\mathrm{CC}}{ }^{+} \\ & \mathrm{I}_{\mathrm{DD}} \end{aligned}$ |  |  | 125 | mA |

## AC Characteristics

$\left(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}$
$=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ )

## Data Bus Buffer Register Read (Refer to the Fig. 1)

| Parameter | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. |  |
| $\overline{\overline{C S}, \mathrm{~A}_{0} \text { Setup Time (to RD) }}$ | $t_{\text {AR }}$ |  | 0 |  | ns |
| $\overline{\overline{C S}}, \mathrm{~A}_{0}$ Hold Time (from $\overline{\mathrm{RD}}$ ) | $t_{\text {RA }}$ |  | 0 |  | ns |
| $\overline{\text { RD Pulse Width }}$ | $t_{\text {RR }}$ |  | 160 |  | ns |
| Data Delay Time (from $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ ) | $t_{\text {AD }}$ | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |  | 130 | ns |
| Data Delay Time (from $\overline{\mathrm{RD}}$ ) | $t_{\text {RD }}$ | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |  | 130 | ns |
| Data Floating Time (from $\overline{\mathrm{RD}}$ ) | $t_{\text {DF }}$ |  |  | 85 | ns |
| Cycle Time MBL8042N |  | * | 2.5 | 15.0 | $\mu \mathrm{s}$ |
| MBL8042H |  | ** | 1.25 | 15.0 | $\mu \mathrm{s}$ |

${ }^{*} \mathrm{t}_{\mathrm{CY}}=2.50 \mu \mathrm{~s}$ at 6 MHz XTAL ( N version)
${ }^{* *} \mathrm{t}_{\mathrm{CY}}=1.25 \mu \mathrm{~s}$ at 12 MHz XTAL (H version)
Data Bus Buffer Register Write (Refer to the Fig. 2)

| Parameter | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. |  |
| $\overline{\overline{C S}}, \mathrm{~A}_{0}$ Setup Time (to $\overline{\mathrm{WR}}$ ) | $t_{\text {AW }}$ |  | 0 |  | ns |
| $\overline{\overline{C S},} \mathrm{~A}_{0}$ Hold Time (from $\overline{\mathrm{WR}}$ ) | $t_{\text {wa }}$ |  | 0 |  | ns |
| WR Pulse Width | $t_{\text {ww }}$ |  | 160 |  | ns |
| Data Setup Time (to WR) | $t_{\text {dw }}$ |  | 130 |  | ns |
| Data Hold Time (from WR) | $t_{\text {wD }}$ |  | 0 |  | ns |

Port 2 (Refer to the Fig. 3)*

| Parameter | Symbol | MBL8042 N |  | MBL8042H |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| Port Control Setup before Falling Edge of PROG Time (to PROG) | ${ }^{\text {t }}$ CP | 100 |  | 110 |  | ns |
| Port Control Hold after Falling Edge of PROG Time (from PROG) | $t_{\text {PC }}$ | 60 |  | 100 |  | ns |
| Output Data Setup Time (to PROG) | $t_{\text {DP }}$ | 200 |  | 250 |  | ns |
| Output Data Hold Time (from PROG) | $t_{\text {PD }}$ | 20 |  | 65 |  | ns |
| Input Data Hold Time (f́rom PROG) | $\mathrm{t}_{\text {PF }}$ | 0 | 150 | 0 | 150 | ns |
| PROG Time P2 Input Must be Valid | $t_{\text {PR }}$ |  | 650 |  | 810 | ns |
| PROG Pulse Width | $\mathrm{t}_{\mathrm{pP}}$ | 700 |  | 1200 |  | ns |

*at 6 MHz XTAL for N version
at 12 MHz XTAL for H version

## AC Characteristics

(Continued)
DMA Characteristics (Refer to the Fig. 4)

| Parameter | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. |  |
| DACK Setup Time (to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | $\mathrm{t}_{\text {ACC }}$ |  | 0 |  | ns |
| $\overline{\text { DACK }}$ Hold Time (from $\overline{\mathrm{RD}}, \overline{\mathrm{WF}}$, | $\mathrm{t}_{\mathrm{CAC}}$ |  | 0 |  | ns |
| Input Data Delay Time (from $\overline{\text { DACK }}$ ) | $\mathrm{t}_{\text {ACD }}$ | $C_{L}=150 \mathrm{pF}$ |  | 130 | ns |
| DRQ Clear Time (from RD, WR) | $t_{C R Q}$ |  |  | 100 | ns |

AC Test Conditions
$\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ (All except XTAL1, 2, $\overline{\text { RESET }}$ )
$=0.6 \mathrm{~V}$ (XTAL1, 2, RESET)
$\mathrm{V}_{\mathrm{IH}}=2.0 \mathrm{~V}$ (All except XTAL1, 2, RESET)
$=3.8 \mathrm{~V}$ (XTAL1, 2, RESET)
$\mathrm{V}_{\mathrm{OL}}=0.45 \mathrm{~V}$
$\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$
Output Load
D0-D7
$\begin{aligned}: C_{L} & =150 p F \\ \text { All other outputs: } & C_{L}=80 p F\end{aligned}$

## Timing Diagram

Figure 1. Data Bus Buffer (DBB) Read Operation


Figure 2. Data Bus Buffer (DBB) Write Operation


## Timing Diagram

(Continued)
Figure 3. Port 2 (Lower 4 Bits) Operation in Connection with I/O Expander


Figure 4. DMA Operation


Oscillation Circuits
Crystal Oscillator
External Clock Driver


Package Dimensions Dimensions in inches (millimeters)

## 40-Lead Ceramic

(Metal Seal)

## Dual In-Line Package

## (Case No.: DIP-40C-A01)



Dimensions in inches (millimeters)

## 40-Lead Plastic

 Dual In-Line Package (Case No.: DIP-40P-M01)
© 1985 FUUITSU LIMITED D40005S-1C

## DESCRIPTION

The Fujitsu MBL8742 Universal Peripheral Interface (UPI) is an 8-bit microcomputer that uses a $2 \mathrm{~K} \times 8$-bit Electrically Programmable Read Only Memory (EPROM). Besides the EPROM program memory, the microprocessing circuits are supported by a $256 \times 8$-bit static RAM, 18 I/O lines, an 8 -bit timer counter, and a clock generator. The device can be ordered in either of two speed versions: N -version for operation at 6 MHz and H -version for operation at 12 MHz . For either frequency, the operating temperature is $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

The MBL8742 is fabricated using an N-channel polysilicon-gate MOS process and is housed in a 40-pin ceramic windowed DIP. A single +5 -volt supply is required for basic operation; the EPROM requires an ultraviolet (UV) light source for erasure and a 21 -volt supply for programming.

Using the EPROM program memory, the MBL8742 is ideally suited for such applications as system evaluation, system prototyping, and low-volume production work.

## FEATURES

- Processor: 8-bit Microprocessing Unit (MPU)
- Memories: $2 \mathrm{~K} \times 8$-bit Program Memory (EPROM) $256 \times 8$-bit Data Memory (static RAM) - 8-level Stack - 8 pairs of Working Registers
- I/O: One 8-bit Bidirectional Data Bus Two 8-bit Bidirectional I/O Ports Two Test Inputs
- Master Processor Interface: One 8-bit Status Register Two 8-bit Data Bus Buffer Registers
- DMA Handshake Capability
- 8-bit Timer/Event Counter
- Clock Source: Internal Clock Generator (with external Crystal) or External Clock
- Single-step Operation
- Low-power RAM Retention Mode
- Power-on Reset Capability (with External Capacitor)
- Instruction Cycle: $1.25 \mu \mathrm{~s} / 12 \mathrm{MHz}$ (MBL8742H) and $2.5 \mu \mathrm{~s} / 6 \mathrm{MHz}$ (MBL8742N)
- Instruction Set: 93 Instructions with 217 Instruction Codes
- Single +5 V Power Supply
- Operating Temperature Range: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$



## Pin Assignment

$$
\begin{aligned}
& \text { *These pins are internally pulled up. }
\end{aligned}
$$

[^44]
## FEATURES (Cont)

- N-channel Silicon-gate MOS Process
- Standard 40-pin Ceramic DIP (Suffix-C)
- Compatible with Intel 8742
- Replaceable with MBL8041A/42 and Intel 8041A/42


## BLOCK DIAGRAM



PIN DESCRIPTIONS

| Pin No. | Symbol | Function |
| :---: | :---: | :--- |
| 40 | $\mathrm{~V}_{\mathrm{CC}}$ | +5 Vdc power supply input. |
| 26 | $\mathrm{~V}_{\mathrm{DD}}$ | +5Vdc power supply input for internal RAM. <br> This pin is also used as the power supply input when programming the EPROM. |
| 20 | $\mathrm{~V}_{\mathrm{SS}}$ | Ground terminal. |
| 1 | T0 | Input used for conditional branching. |
| 39 | T 1 | This pin performs the following functions: <br> - Event input pin for the event counter. <br> - Conditional input pin for conditional branch. |

## PIN DESCRIPTIONS (Cont)

| Pin No. | Symbol | Function |
| :---: | :---: | :---: |
| 2 | XTAL 1 | Input connection for external crystal. <br> This pin can also be used as an input from an external clock source. |
| 3 | XTAL 2 | Input connection for external crystal. <br> (Note: The XTAL 1 and XTAL 2 input levels are not directly TTL compatible with a TTL clock source. An open-collector drive with an appropriate pullup is required to properly interface the two circuits.) |
| 4 | RESET | Input that resets and initializes the MPU. <br> (Note: This input level is not TTL compatible.) |
| 5 | $\overline{\text { SS }}$ | Input used for single step operation. |
| 6 | $\overline{\mathrm{CS}}$ | Chip select input. |
| 7 | EA | Input used for controlling program memory access. Holding EA high forces all program memory fetches to reference external memory. Useful for emulation and debug, and essential for testing and program verification. |
| 8 | $\overline{\mathrm{RD}}$ | Strobe that enables a read operation from data bus buffer or status register. |
| 9 | A0 | Address input to determine whether read/write data or read/write commands. <br> $A 0=$ "L" indicates data read or write. <br> $A 0=$ " H " indicates status read or command write. |
| 10 | $\overline{\mathrm{WR}}$ | Strobe that enables a write operation to data bus buffer register. |
| 11 | SYNC | An output synchronized with the MBL8742 clock. This pin is used when a synchronization signal is required for external circuits. |
| 12-19 | D0-D7 | 8-bit bidirectional I/O port used to interface the MBL8742 to the master processor. |
| 21-24 | P20-P23 | Lower 4 bits of the 8-bit quasi-bidirectional I/O port (Port 2). These pins function as an interface port with the I/O expander (MBL8243) when an expansion I/O is used to execute instructions. During single step operation the upper 3 bits of the program address are output on P20, P21, P22. |
| 35-38 | P24-P27 | Upper 4 bits of the 8-bit quasi-bidirectional I/O port (Port 2). These function as the flag output pins (P24 and P25) and DMA pins (P26 and P27) according to the executed instruction. <br> P24: OBF (Output Data Buffer Register Full) output <br> P25: $\overline{\mathrm{IBF}}$ (Input Data Buffer Register Full) output <br> P26: DRQ (DMA Request) output <br> P27: DACK (DMA Acknowledge) input |
| 25 | PROG | Strobe output signal when performing an expansion I/O instruction with an I/O expander such as the MBL8243. <br> Used as a programming input when writing to the EPROM. |
| 27-34 | P10-P17 | 8-bit Quasi-bidirectional I/O ports (Port 1). During single step operation, the next program fetch address (Lower 8 bits) is output from these pins. |

## FUNCTIONAL DESCRIPTION

## System Interface

The data, command, and status interface between the master processor and the MBL8742 is provided by two Data Bus Buffer(DBB) registers and a status register. Selection logic for these registers is shown in Table 1; a simplified interface is shown in Figure 1. Referring to the interface drawing, note that the master processor can read data from the output buffer register and write data into the input buffer register. When the MBL8742 executes an "OUT DBB, A" instruction, data is written into the DBB and the Output Buffer Full (OBF) flag is set. When data is read from the DBB by the master processor, OBF is reset. If the master processor writes into DBB, the Input Buffer Full ( $\overline{\mathrm{IBF}}$ ) flag is set and is reset when the MBDL8742 reads the data. Reading the status register is nondestructive and does not affect internal operation of the MBL8742.

Table 1. Selection Logic

| $\overline{\mathbf{C S}}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ | $\mathbf{A O}$ | DESCRIPTION |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 1 | 0 | Read DBB (Output) register. |
| 0 | 0 | 1 | 1 | Read STS (Output) register <br> (Status) |
| 0 | 1 | 0 | 0 | Write DBB (Input) register <br> (Data). |
| 0 | 1 | 0 | 1 | Write DBB (Input) register <br> (Command). |
| 1 | x | x | x | Invalid. |

Figure 1. Interface Between MBL8742 and Master Processor


## Program Status Word (PSW)

As shown in the following diagram and associated text, the upper four bits of the PSW are used as flags to indicate MPU status. The lower three bits are used to select register pairs in the RAM stack when servicing a subroutine call or an interrupt. The flag bits ( $C, A C, F_{0}$, and $B S$ ) are defined below; the stack pointer bits $\left(\mathrm{SP}_{0}-\mathrm{SP}_{2}\right)$ are defined in the next paragraph. The remaining bit in the PSW is unused.


## Flag Bits

C (Carry): When an accumulator overflow occurs during an ALU operation, this bit is set to ' 1 '.

AC (Auxiliary Carry): When an accumulator overflow from bit 3 to bit 4 occurs during an addition, this bit is set to " 1 ".
$F_{0}$ (User Flag): With the proper instruction, this flag can be user-designated; the $F_{0}$ flag can also be checked from the MPU as bit 2 of the Status Register.
BS (Bank Select): With the proper instruction, the BS flag indicates selection of a Register Bank. When set to " 0 ", Register Bank 0 is selected; when set to " 1 ", Register Bank 1 is selected. Refer to the RAM memory map that follows.

## Stack Register (8-Level Capability)

The Stack Register has 16 bytes of memory area in the built-in RAM. The stack Register consists of eight levels, that is, a stack level consists of two bytes as shown in the following diagram.

$\mathbf{P C}_{\boldsymbol{n}}$ (Program Counter): In the above figure, " $\mathrm{PC}_{\mathrm{n}}$ " indicates the content of the $n$-th bit in the Program Counter.

## RESIDENT DATA MEMORY MAP (RAM)



## IIM Mixililixil MBL8742H/N

## Interrupt Processing

There are two types of interrupt: $\overline{\text { IBF }}$ interrupt and Timer/ Counter interrupt. If an interrupt occurs when the system is in "interrupt enable" status, the interrupt flag is set as soon as the current instruction is completed and interrupt processing starts.

First, the upper four bits of the Status Word and content of the Program Counter are stored in the stack. The program then jumps to address " 3 " in the case of an $\overline{\mathrm{IBF}}$ interrupt and address " 7 " in the case of a Timer/Counter interrupt.

After the interrupt has been processed by a user program and a RETR (Return and Restore Status) instruction has been executed, the Status Word and Program Counter contents stored in the stack are restored, the interrupt flag is reset, and the system is ready to accept the next interrupt request.
A Timer/Counter interrupt request occurs when the Timer/Counter overflow flag is set due to Timer/Counter overflow. However, since the Timer/Counter interrupt request is masked by the $\overline{\mathrm{IBF}}$ interrupt request, an $\overline{\mathrm{IBF}}$ interrupt has first priority.
The Timer/Counter interrupt is enabled after the $\overline{\mathrm{IBF}}$ interrupt has been executed and the system is now ready to receive the next interrupt request. Operational and interrupt flowcharts are shown on the following page.

## PROGRAMMING AND VERIFYING THE EPROM

The MBL8742 uses an internal $2 \mathrm{~K} \times 8$ EPROM for program memory. A description of the pins used for programming and verifying operation of the EPROM are repeated here for user convenience. Procedural steps for programming and verification follow the pin functions.

## Pin Descriptions

| Symbol | Function |
| :---: | :--- |
|  <br> XTAL2 | Input clock signal (1-to-3MHz) |
| RESET | Initializes internal registers. <br> Input address data to the data bus is inter- <br> nally latched on the rising edge of RESET. |
| T0 | When T0 is Low, program mode is selected. <br> When T0 is High, verify mode is selected. |
| EA | When 18-volts is applied to this pin, the <br> program and verify modes are enabled. |
| Bus (D7-D0) | Lower 8-bits for address and data inputs in <br> the program mode; data output in the verify <br> mode. |
| P22-P20 | Upper address inputs. |


| Symbol | Function |
| :---: | :--- |
| $V_{D D}$ | +5 -volt power supply. |
| PROG | Input programming pulses. |
| $A 0 \& \overline{C S}$ | Clamp both of these inputs low. |

## Programming Procedures

Step 1: Initialize circuits as follows.

- Apply +5 V to $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}, \mathrm{T} 0$ and EA pins. Let Bus (D7-D0) and PROG pins float.
- Apply OV to $\overline{\mathrm{RESET}}, \mathrm{AO}$, and $\overline{\mathrm{CS}}$ pins.
- Use internal oscillator or an external source to generate a 1-to-3MHz clock.

Step 2: Select program mode by setting T0 to 0 V .
Step 3: Set EA to 18 V to enable program or verify mode.
Step 4: Input address as follows.

- Bus (D7-D0): 8 low-order bits
- P22 to P20: 3 high-order bits

Step 5: Set $\overline{\text { RESET }}$ to +5 V to internally latch address inputs.
Step 6: Input write data to bus.
Step 7: Turn on programming power supply and set $V_{D D}$ to 21-volts.

Step 8: Apply 0 -volts to the PROG pin and then apply a programming pulse of 18 -volts for 50 -milliseconds. Again apply 0 -volts to the pin and then let it float.

Step 9: Turn off programming power supply ( $\mathrm{V}_{\mathrm{DD}}$ from 21 V to 5 V ) and let Bus (D7-D0) float.
Step 10: Select verify mode by setting TO to 5 V .
Step 11: Read and verify bus data. If data cannot be verified, repeat steps 2 through 10.

Step 12: Set RESET to OV. If all desired addresses haven't been written yet, repeat steps 4 through 11.
Step 13: Set EA to 5V to terminate programming procedure.

## ERASING THE EPROM

Data written into the EPROM can be erased by applying ultraviolet light rays with a wavelength of 2537 angstroms. With UV light source directly above the transparent lid at a distance of 2 -to-3 centimeters. The time for complete erasure is between 15 -and- 20 minutes for most commercial lamps. The recommended amount of UV radiation is $10 \mathrm{Wsec} / \mathrm{cm}^{2}$; the luminous intensity on the package surface is designed to be approximately $12000 \mathrm{uW} / \mathrm{cm}^{2}$.

If the package surface is soiled by grease, adhesives, or other light inhibitors, the erasing time will increase. Before attempting to erase data, it is recommended that surfaces be cleaned with alcohol or some other detergent that will not damage the package.


Table 2. Instruction Set Summary
ACCUMULATOR INSTRUCTIONS

| Operation | Mnemonic | $\begin{aligned} & \text { OP } \\ & \text { code } \end{aligned}$ | Byte | Cycle | Flag |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Add register to A | ADD A, Rr | 6X3 | 1 | 1 | *2 | *2 | $(\mathrm{A}) \leftarrow(\mathrm{A})+(\mathrm{Rr})$ |
| Add data memory to A | ADD A, @R0 | 60 | 1 | 1 | *2 | * 2 | $(\mathrm{A}) \leftarrow(\mathrm{A})+((\mathrm{RO}))$ |
|  | ADD A, @R1 | 61 | 1 | 1 | *2 | * ${ }^{2}$ | $(\mathrm{A}) \leftarrow(\mathrm{A})+((\mathrm{R} 1))$ |
| Add immediate to A | ADD A, \#data | 03 | 2 | 2 | * 1 | * 2 | $(A) \leftarrow(A)+$ data |
| Add register to A with Carry | ADDC A, Rr | $7 \mathrm{X}^{3}$ | 1 | 1 | * 1 | * ${ }^{2}$ | $(\mathrm{A}) \leftarrow(\mathrm{A})+(\mathrm{Rr})+(\mathrm{C})$ |
| Add data memory to A with Carry | ADDC A, @R0 | 70 | 1 | 1 | *1 | *2 | $(A) \leftarrow(A)+((R 0))+(C)$ |
|  | ADDC A, @R1 | 71 | 1 | 1 | *1 | * ${ }^{2}$ | $(A) \leftarrow(A)+((R 1))+(C)$ |
| Add immediate to A with Carry | ADDC A, \#data | 13 | 2 | 2 | * 1 | *2 | $(A) \leftarrow(A)+$ data $+(C)$ |
| AND register to A | ANL A, Rr | $5 \mathrm{X}^{3}$ | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A})$ AND $(\mathrm{Rr})$ |
| AND data memory to $A$ | ANL A, @RO | 50 | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A})$ AND ( $(\mathrm{RO} 0)$ ) |
|  | ANL A, @R1 | 51 | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A})$ AND $((\mathrm{R} 1))$ |
| AND immediate to A | ANL A, \#data | 53 | 2 | 2 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A}) \mathrm{AND}$ data |
| OR register to $A$ | ORL A, Rr | $4 \mathrm{X}^{3}$ | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A}) \mathrm{OR}(\mathrm{Rr})$ |
| OR data memory to $A$ | ORL A, @R0 | 40 | 1 | 1 | - | - | $(A) \leftarrow(A) O R((R 0))$ |
|  | ORL A, @R1 | 41 | 1 | 1 | - | - | $(A) \leftarrow(A) O R((R 1))$ |
| OR immediate to A | ORL A, \#data | 43 | 2 | 2 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A})$ OR data |
| Exclusive OR register to $A$ | XRL A, Rr | DX3 | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A}) \mathrm{XOR}(\mathrm{Rr})$ |
| Exclusive OR data memory to A | XRL A, @R0 | D0 | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A}) \mathrm{XOR}((\mathrm{RO}))$ |
|  | XRL A, @R1 | D1 | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A}) \mathrm{XOR}($ (R1)) |
| Exclusive OR immediate to $A$ | XRL A, \#data | D3 | 2 | 2 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{A}) \mathrm{XOR}$ data |
| Increment A | INC A | 17 | 1 | 1 | - | - | $(A) \leftarrow(A)+1$ |
| Decrement A | DEC A | 07 | 1 | 1 | - | - | (A) $\leftarrow(A)-1$ |
| Clear A | CLR A | 27 | 1 | 1 | - | - | (A) $\leftarrow 0$ |
| Complement A | CPL A | 37 | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow(\overline{\mathrm{A}})$ |
| Decimal Adjust A | DA A | 57 | 1 | 1 | * | - | Note 2 |
| Swap digits of $A$ | SWAP A | 47 | 1 | 1 | - | - | $(A 7-4) \rightleftarrows(A 3-0)$ |
| Rotate A Left | RL A | E7 | 1 | 1 | - | - |  |
| Rotate A Left through Carry | RLC A | F7 | 1 | 1 | * 1 | - |  |
| Rotate A Right | RR A | 77 | 1 | 1 | - | - |  |
| Rotate A Right through Carry | RRC A | 67 | 1 | 1 | * 1 | - |  |

## INPUT/OUTPUT INSTRUCTIONS

| Input port to A | IN A, P1 | 09 | 1 | 2 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{P} 1)$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | IN A, P2 | OA | 1 | 2 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{P} 2)$ |
| Output A to port | OUTL P1, A | 39 | 1 | 2 | - | - | $(\mathrm{P} 1) \leftarrow(\mathrm{A})$ |
|  | OUTL P2, A | 3A | 1 | 2 | - | - | $(\mathrm{P} 2) \leftarrow(\mathrm{A})$ |
| AND immediate to port | ANL P1, \#data | 99 | 2 | 2 | - | - | $(\mathrm{P} 1) \leftarrow(\mathrm{P} 1)$ AND data |
|  | ANL P2, \#data | 9A | 2 | 2 | - | - | $(\mathrm{P} 2) \leftarrow(\mathrm{P} 2)$ AND data |
| OR immediate to port | ORL P1, \#data | 89 | 2 | 2 | - | - | $(\mathrm{P} 1) \leftarrow(\mathrm{P} 1)$ OR data |
|  | ORL P2, \#data | 8A | 2 | 2 | - | - | $(\mathrm{P} 2) \leftarrow(\mathrm{P} 2)$ OR data |
| Input DBB to A, clear IBF | IN A, DBB | 22 | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{DBB}),(\mathrm{IBF}) \leftarrow 0$ |
| Output A to DBB, set OBF | OUT DBB, A | 02 | 1 | 1 | - | - | $(\mathrm{DBB}) \leftarrow(\mathrm{A}),(\mathrm{OBF}) \leftarrow 1$ |
| A7-4 to bits 7-4 of Status | MOV STS, A | 90 | 1 | 1 | - | - | (STS7-4) ヶ (A7-A4) |

FUJITSU

## INPUT/OUTPUT INSTRUCTIONS (Continued)

| Operation | Mnemonic | $\begin{gathered} \text { OP } \\ \text { code } \end{gathered}$ | Byte | Cycle | Flag |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Input Expander port to A | MOVD A, Pp | OX ${ }^{4}$ | 1 | 2 | - | - | $\begin{aligned} & \hline \hline \text { (A3-0) } \leftarrow(\mathrm{Pp}), \\ & (\mathrm{A} 7-4) \leftarrow 0 \end{aligned}$ |
| Output A to Expander port | MOVD Pp, A | $3 X^{4}$ | 1 | 2 | - | - | $(\mathrm{Pp}) \leftarrow(\mathrm{A} 3-0)$ |
| AND A to Expander port | ANLD Pp, A | $9{ }^{4} 4$ | 1 | 2 | - | - | $(\mathrm{Pp}) \leftarrow(\mathrm{Pp})$ AND ( $\mathrm{A} 3-0$ ) |
| OR A to Expander port | ORLD Pp, A | $8{ }^{4}$ | 1 | 2 | - | - | $(\mathrm{Pp}) \leftarrow(\mathrm{Pp})$ OR ( $\mathrm{A} 3-0$ ) |

DATA MOVE INSTRUCTIONS

| Move register to A | MOV A, Rr | $\mathrm{FX}^{3}$ | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{Rr})$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Move data memory to $A$ | MOV A, @R0 | F0 | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow((\mathrm{RO}))$ |
|  | MOV A, @R1 | F1 | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow((\mathrm{R} 1))$ |
| Move immediate to A | MOV A, \#data | 23 | 2 | 2 | - | - | (A) $\leftarrow$ data |
| Move A to register | MOV Rr, A | $\mathrm{AX}^{3}$ | 1 | 1 | - | - | $(\mathrm{Rr}) \leftarrow(\mathrm{A})$ |
| Move A to data memory | MOV @RO, A | A0 | 1 | 1 | - | - | $((\mathrm{RO}) \mathrm{)} \leftarrow(\mathrm{~A})$ |
|  | MOV @R1, A | A1 | 1 | 1 | - | - | $((\mathrm{R} 1) \mathrm{)} \leftarrow(\mathrm{~A})$ |
| Move immediate to register | MOV Rr, \#data | $\mathrm{BX}^{3}$ | 2 | 2 | - | - | $(\mathrm{Rr}) \leftarrow$ data |
| Move immediate to data memory | MOV @RO, \#data | B0 | 2 | 2 | - | - | $((\mathrm{RO})) \leftarrow$ data |
|  | MOV @R1, \#data | B1 | 2 | 2 | - | - | $((\mathrm{R} 1)) \leftarrow$ data |
| Move PSW to A | MOV A, PSW | C7 | 1 | 1 | - | - | $(\mathrm{A}) \leftarrow(\mathrm{PSW})$ |
| Move A to PSW | MOV PSW, A | D7 | 1 | 1 | * 1 | * 1 | $(\mathrm{PSW}) \leftarrow(\mathrm{A})$ |
| Exchange $A$ and register | XCH A, Rr | $2 \mathrm{X}^{3}$ | 1 | 1 | - | - | $(\mathrm{A}) \rightleftarrows(\mathrm{Rr})$ |
| Exchange $A$ and data memory | XCH A, @RO | 20 | 1 | 1 | - | - | $(A) \rightleftarrows((R 0))$ |
|  | XCH A, @R1 | 21 | 1 | 1 | - | - | $(\mathrm{A}) \rightleftarrows((\mathrm{R} 1))$ |
| Exchange digit of A and data memory | XCHD A, @R0 | 30 | 1 | 1 | - | - | $(\mathrm{A} 3-0) \rightleftarrows((\mathrm{RO}) 3-0)$ |
|  | XCHD A, @R1 | 31 | 1 | 1 | - | - | $(\mathrm{A} 3-0) \rightleftarrows((\mathrm{R} 1) 3-0)$ |
| Move to A from current page | MOVP A, @A | A3 | 1 | 2 | - | - | $(\mathrm{A}) \leftarrow((\mathrm{A})$ ) within page |
| Move to A from Page 3 | MOVP3A, @A | E3 | 1 | 2 | - | - | $(\mathrm{A}) \leftarrow((\mathrm{A}))$ within page 3 |

## TIMER/COUNTER INSTRUCTIONS

| Read Timer/Counter | MOV A, T | 42 | 1 | 1 | - | - | $(A) \leftarrow(T)$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Load Timer/Counter | MOV T, A | 62 | 1 | 1 | - | - | $(T) \leftarrow(A)$ |
| Start Timer | STRT T | 55 | 1 | 1 | - | - |  |
| Start Counter | STRT CNT | 45 | 1 | 1 | - | - |  |
| Stop Timer/Counter | STOP TCNT | 65 | 1 | 1 | - | - |  |
| Enable Timer/Counter Interrupt | EN TCNTI | 25 | 1 | 1 | - | - |  |
| Disable Timer/Counter Interrupt | DIS TCNTI | 35 | 1 | 1 | - | - |  |

## CONTROL INSTRUCTIONS

| Enable DMA Handshake Lines | EN DMA | E5 | 1 | 1 | - | - |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Enable IBF Interrupt | EN I | 05 | 1 | 1 | - | - |  |
| Disable IBF Interrupt | DIS I | 15 | 1 | 1 | - | - |  |
| Enable Master Interrupts | EN FLAGS | F5 | 1 | 1 | - | - |  |
| Select register bank 0 | SEL RB0 | C5 | 1 | 1 | - | - | $(B S) \leftarrow 0$ |
| Select register bank 1 | SEL RB1 | D5 | 1 | 1 | - | - | $(B S) \leftarrow 1$ |
| No Operation | NOP | 00 | 1 | 1 | - | - |  |

REGISTER INSTRUCTIONS

| Increment register | INC Rr | $1 X^{3}$ | 1 | 1 | - | - | $(\mathrm{Rr}) \leftarrow(\mathrm{Rr})+1$ |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| Increment data memory | INC @R0 | 10 | 1 | 1 | - | - | $((\mathrm{RO})) \leftarrow((\mathrm{RO}))+1$ |
|  | INC @R1 | 11 | 1 | 1 | - | - | $((\mathrm{R} 1)) \leftarrow((\mathrm{R} 1))+1$ |
| Decrement register | DEC Rr | $\mathrm{CX}^{3}$ | 1 | 1 | - | - | $(\mathrm{Rr}) \leftarrow(\mathrm{Rr})-1$ |

SUBROUTINE INSTRUCTIONS

| Operation | Mnemonic | $\begin{gathered} \text { OP } \\ \text { code } \end{gathered}$ | Byte | Cycle | Flag |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | C | AC |  |
| Jump to Subroutine | CALL addr | \%45 | 2 | 2 | - | - | Note 6 |
| Return | RET | 83 | 1 | 2 | - | - | Note 7 |
| Return and restore status | RETR | 93 | 1 | 2 | *1 | * 1 | Note 8 |

FLAGS INSTRUCTIONS

| Clear Carry | CLR C | 97 | 1 | 1 | $\mathrm{Z}^{1}$ | - | (C) $\leftarrow 0$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Complement Carry | CPL C | A7 | 1 | 1 | CP1 | - | $(\mathrm{C}) \leftarrow(\overline{\mathrm{C}})$ |
| Clear Flag 0 | CLR FO | 85 | 1 | 1 | - | - | (FO) $\leftarrow 0$ |
| Complement Flag 0 | CPL F0 | 95 | 1 | 1 | - | - | $(\mathrm{FO}) \leftarrow(\overline{\mathrm{FO}})$ |
| Clear Flag 1 | CLR F1 | A5 | 1 | 1 | - | - | $(\mathrm{F} 1) \leftarrow 0$ |
| Complement Flag 1 | CPL F1 | B5 | 1 | 1 | - | - | $(\mathrm{F} 1) \leftarrow(\overline{\mathrm{F} 1})$ |

BRANCH INSTRUCTIONS

| Jump unconditional Jump indirect | JMP addr JMPP @A | $\begin{gathered} \hline \% 4^{5} \\ \text { B3 } \end{gathered}$ | $\begin{aligned} & 2 \\ & 1 \end{aligned}$ | 2 2 | - | - | Unconditional Branch Unconditional Branch (Note 9) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Decrement register and jump | DJNZ Rr, addr | EX ${ }^{3}$ | 2 | 2 | - | - | $(\mathrm{Rr}) \neq 0$ (Note 10) |
| Jump on Carry = 1 | JC addr | F6 | 2 | 2 | - | - | (C) $=1$ |
| Jump on Carry $=0$ | JNC addr | E6 | 2 | 2 | - | - | $(\mathrm{C})=0$ |
| Jump on A Zero | JZ addr | C6 | 2 | 2 | - | - | $(\mathrm{A})=0$ |
| Jump on A not Zero | JNZ addr | 96 | 2 | 2 | - | - | $(\mathrm{A}) \neq 0$ |
| Jump on T0 = 1 | JTO addr | 36 | 2 | 2 | - | - | (TO) $=\mathrm{H}$ |
| Jump on T0 $=0$ | JNT0 addr | 26 | 2 | 2 | - | - | (TO) $=\mathrm{L}$ |
| Jump on T1 = 1 | JT1 addr | 56 | 2 | 2 | - | - | (T1) $=\mathrm{H}$ |
| Jump on T1 $=0$ | JNT1 addr | 46 | 2 | 2 | - | - | ( T 1 ) $=\mathrm{L}$ |
| Jump on FO=1 | JF0 addr | B6 | 2 | 2 | - | - | (FO) $=1$ |
| Jump on F1 = 1 | JF1 addr | 76 | 2 | 2 | - | - | $(\mathrm{F} 1)=1$ |
| Jump on Timer Flag = 1, Clear Flag | JTF addr | 16 | 2 | 2 | - | - | $(\mathrm{TF})=1$ |
| Jump on IBF Flag $=0$ | JNIBF addr | D6 | 2 | 2 | - | - | $(\mathrm{IBF})=0$ |
| Jump on OBF Flag = 1 | JOBF addr | 86 | 2 | 2 | - | - | $(\mathrm{OBF})=1$ |
| Jump on Accumulator Bit | JBb addr | \% $2^{5}$ | 2 | 2 | - | - | $(A b)=1$ |

## Notes:

1. Flag status

* = Set or reset flag bit to the state it was in before instruction execution.
$Z=$ Reset flag bit.
$\mathrm{CP}=$ Complement flag bit.

2. The accumulator value is adjusted to form $B C D$ digits following the binary addition of $B C D$ numbers.
3. Refer to Table 3.
4. Refer to Table 4
5. Refer to Table 5.
6. CALL addr
((SP)) $\leftarrow$ (PC), (PSW7-4)
$(\mathrm{SP}) \leftarrow(\mathrm{SP})+1$
$\left(\right.$ PC10-8) $\leftarrow A_{H}$
$\left(\right.$ PC7-0) $\leftarrow A_{L}$
7. RET
$(\mathrm{SP}) \leftarrow(\mathrm{SP})-1$
$(\mathrm{PC}) \leftarrow((\mathrm{SP}))$
8. RETR
$(\mathrm{SP}) \leftarrow(\mathrm{SP})-1$
$(\mathrm{PC}) \leftarrow((\mathrm{SP}))$
(PSW7-4) $\leftarrow((S P))$
9. JMPP@A $($ PC7-0) $\leftarrow((A))$
10. DJNZ Rr, addr
$(\mathrm{Rr}) \leftarrow(\mathrm{Rr})-1$
if $(\mathrm{Rr}) \neq 0(\mathrm{PC} 7-0) \leftarrow$ addr
if $(R r)=0$ Execute next instruction

Table 3. OP Code for Register Access

| Mnemonic | Rr | R0 | R1 | R2 | R3 | R4 | R5 | R6 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| R7 |  |  |  |  |  |  |  |  |
| ADD A, Rr | 68 | 69 | $6 A$ | $6 B$ | $6 C$ | $6 D$ | $6 E$ | $6 F$ |
| ADDC A, Rr | 78 | 79 | $7 A$ | $7 B$ | $7 C$ | $7 D$ | $7 E$ | $7 F$ |
| ANL A, Rr | 58 | 59 | $5 A$ | $5 B$ | $5 C$ | $5 D$ | $5 E$ | $5 F$ |
| DEC Rr | C8 | C9 | CA | CB | CC | CD | CE | CF |
| DJNZ Rr, addr | E8 | E9 | EA | EB | EC | ED | EE | EF |
| INC Rr | 18 | 19 | 1A | 1B | 1C | 1D | 1E | $1 F$ |
| MOV A, Rr | F8 | F9 | FA | FB | FC | FD | FE | FF |
| MOV Rr, A | A8 | A9 | AA | AB | AC | AD | AE | AF |
| MOV Rr, \#data | B8 | B9 | BA | BB | BC | BD | BE | BF |
| ORL A, Rr | 48 | 49 | $4 A$ | 4B | 4C | $4 D$ | $4 E$ | $4 F$ |
| XCH A, Rr | 28 | 29 | $2 A$ | 2B | 2C | $2 D$ | $2 E$ | $2 F$ |
| XRL A, Rr | D8 | D9 | DA | DB | DC | DD | DE | DF |

Bit $\begin{array}{llllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$


Table 4. OP Codes for Expander Port Access

| Mnemonic | Rr | P4 | P5 | P6 |
| :--- | :--- | :--- | :--- | :--- |
| P7 |  |  |  |  |
| ANLD Pp, A | $9 C$ | $9 D$ |  |  |
| MOVD A, Pp | 9F |  |  |  |
| MOVD Pp, A | OC | OD | OE | OF |
| ORLD Pp, A | 8C | 8D | 8 BE | 3F |

Bit $\begin{array}{llllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$

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

Table 5. OP Codes for JMP, CALL, and JBb

## First Byte

Second Byte

Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: |
| $A_{H}$ | 0 | 0 | 1 | 0 | 0 |  |  |



Bit $\begin{array}{lllllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$
CALL


Bit $\begin{array}{llllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$

| $A_{H}$ | 1 | 0 | 1 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- |



JBb

$A_{\mathbf{H}}=$ Address $A_{10}, A_{9}, A_{8} \quad A_{L}=$ Address $A_{7}$ to $A_{0} \quad B b=b^{\text {th }}$ bit of accumulator

## INSTRUCTION CODES

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | NOP |  | $\begin{aligned} & \text { OUT } \\ & \text { DBB,A } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, \# } \end{aligned}$ | $\begin{aligned} & \text { JMP } \\ & 0 \times \times \mathrm{x} \end{aligned}$ | $\underset{1}{\text { EN }}$ |  | $\underset{\text { A }}{\text { DEC }}$ |  | $\begin{aligned} & \text { IN } \\ & \mathrm{A}, \mathrm{P} 1 \end{aligned}$ | $\begin{gathered} \mathbb{N}, \\ A, P 2 \end{gathered}$ |  | $\begin{aligned} & \text { MOVD } \\ & \text { A, P4 } \end{aligned}$ | $\begin{gathered} \text { MOVD } \\ \text { A, P5 } \end{gathered}$ | $\begin{aligned} & \text { MOVD } \\ & \text { A, P6 } \end{aligned}$ | $\begin{aligned} & \text { MOVD } \\ & \text { A, P7 } \end{aligned}$ |
| 1 | INC @RO | INC @R1 | JBO addr | $\begin{gathered} \text { ADDC } \\ \text { A, \# } \end{gathered}$ | $\begin{aligned} & \text { CALL } \\ & 0 \times \times \times \end{aligned}$ | DIS | JTF addr | $\begin{gathered} \text { INC } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \text { INC } \\ & \text { RO } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { R1 } \end{aligned}$ | $\begin{gathered} \text { INC } \\ \text { R2 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R3 } \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { R4 } \end{gathered}$ | $\begin{aligned} & \text { INC } \\ & \text { R5 } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { R6 } \end{aligned}$ | $\begin{gathered} \text { INC } \\ \text { R7 } \end{gathered}$ |
| 2 | $\begin{gathered} \mathrm{XCH} \\ \text { A, @R0 } \end{gathered}$ | $\begin{gathered} \mathrm{XCH} \\ \mathrm{~A}, @ \mathrm{R} 1 \end{gathered}$ | $\begin{gathered} \mathrm{IN} \\ \mathrm{~A}, \mathrm{DBB} \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { A, \# } \end{gathered}$ | $\begin{aligned} & \text { JMP } \\ & 1 \times \times x \end{aligned}$ | $\begin{gathered} \text { EN } \\ \text { TCNTI } \end{gathered}$ | JNTO addr | $\underset{A}{\text { CLR }}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{RO} \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 1 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 3 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 4 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 5 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 6 \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{R} 7 \end{aligned}$ |
| 3 | XCHD <br> A, @RO | $\begin{aligned} & \mathrm{XCHD} \\ & \text { A, @R1 } \end{aligned}$ | JB1 addr |  | $\begin{aligned} & \text { CALL } \\ & 1 \times \times \end{aligned}$ | $\begin{gathered} \text { DIS } \\ \text { TCNTI } \end{gathered}$ | $\begin{aligned} & \text { JTO } \\ & \text { addr } \end{aligned}$ | $\underset{A}{C P L}$ |  | OUTL <br> P1, A | OUTL P2, A |  | $\begin{aligned} & \text { MOVD } \\ & \text { P4, A } \end{aligned}$ | MOVD P5, A | MOVD P6, A | MOVD P7, A |
| 4 | $\begin{aligned} & \text { ORL } \\ & \text { A. @RO } \end{aligned}$ | $\begin{gathered} \text { ORL } \\ \text { A, @R1 } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { A, T } \end{gathered}$ | ORL A, \# | $\begin{aligned} & \text { JMP } \\ & 2 \times x \end{aligned}$ | $\begin{aligned} & \text { STRT } \\ & \text { CNT } \end{aligned}$ | JNT1 addr | $\underset{A}{\text { SWAP }}$ | $\begin{aligned} & \text { ORL } \\ & \text { A, RO } \end{aligned}$ | ORL <br> A, R1 | $\begin{aligned} & \text { ORL } \\ & \text { A, R2 } \end{aligned}$ | $\begin{aligned} & \text { ORL } \\ & \text { A, R3 } \end{aligned}$ | ORL <br> A, R4 | ORL <br> A. R5 | ORL <br> A, R6 | $\begin{aligned} & \text { ORL } \\ & \text { A, R7 } \end{aligned}$ |
| 5 | $\begin{gathered} \text { ANL } \\ \text { A, @RO } \end{gathered}$ | $\begin{gathered} \text { ANL } \\ \text { A, @R1 } \end{gathered}$ | JB2 addr | $\begin{gathered} \mathrm{ANL} \\ \mathrm{~A}, \# \end{gathered}$ | $\begin{aligned} & \text { CALL } \\ & 2 \times x \times \end{aligned}$ | $\underset{T}{S T R T}$ | JT1 addr | $\begin{gathered} \mathrm{DA} \\ \mathrm{~A} \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R2 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R4 } \end{aligned}$ | $\begin{aligned} & \text { ANL } \\ & \text { A, R5 } \end{aligned}$ | $\begin{gathered} \mathrm{ANL} \\ \mathrm{~A}, \mathrm{R} 6 \end{gathered}$ | $\begin{aligned} & \text { ANL } \\ & \text { A. R7 } \end{aligned}$ |
| 6 | $\begin{gathered} \text { ADD } \\ \text { A, @RO } \end{gathered}$ | $\begin{gathered} \text { ADD } \\ \text { A, @R1 } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { T, A } \end{gathered}$ |  | $\begin{aligned} & \text { JMP } \\ & 3 \times x \end{aligned}$ | $\begin{aligned} & \text { STOP } \\ & \text { TCNT } \end{aligned}$ |  | $\underset{A}{\text { RRC }}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R2 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R4 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R5 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A, R6 } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \mathrm{A}, \mathrm{R} 7 \end{aligned}$ |
| 7 | $\begin{aligned} & \text { ADDC } \\ & \text { A, @RO } \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A, @R1 } \end{aligned}$ | JB3 addr |  | $\begin{aligned} & \text { CALL } \\ & 3 \times x \end{aligned}$ |  | JF1 addr | $\begin{gathered} \text { RR } \\ \text { A } \end{gathered}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A, R2 } \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A, R3 } \end{aligned}$ | $\begin{gathered} \text { ADDC } \\ \text { A, R4 } \end{gathered}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A, R5 } \end{aligned}$ | $\begin{gathered} \text { ADDC } \\ \text { A, R6 } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { A, R7 } \end{gathered}$ |
| 8 |  |  |  | RET | $\underset{4 \times \mathrm{MP}}{ }$ | $\begin{aligned} & \text { CLR } \\ & \text { F } \end{aligned}$ | JOBF addr |  |  | ORL P1, \# | $\begin{aligned} & \text { ORL } \\ & \text { P2, \# } \end{aligned}$ |  | $\begin{aligned} & \text { ORLD } \\ & \text { P4, } \end{aligned}$ | $\begin{aligned} & \text { URLD } \\ & \text { P5, A } \end{aligned}$ | ORLD | $\begin{aligned} & \text { ORLD } \\ & \text { P7, A } \end{aligned}$ |
| 9 | $\begin{aligned} & \text { MOV } \\ & \text { STS, A } \end{aligned}$ |  | $\begin{aligned} & \text { JB4 } \\ & \text { addr } \end{aligned}$ | RETR | $\begin{aligned} & \text { CALL } \\ & 4 \times x \end{aligned}$ | $\begin{aligned} & \text { CPL } \\ & \text { FO } \end{aligned}$ | $\begin{aligned} & \text { JNZ } \\ & \text { addr } \end{aligned}$ | $\begin{gathered} \text { CLR } \\ \text { C } \end{gathered}$ |  | ANL P1, \# | $\begin{aligned} & \text { ANL } \\ & \text { P2, \# } \end{aligned}$ |  | $\begin{aligned} & \text { ANLD } \\ & \text { P4, A } \end{aligned}$ | $\begin{aligned} & \text { ANLD } \\ & \text { PS, A } \end{aligned}$ | $\begin{aligned} & \text { ANLD } \\ & \text { P6, A } \end{aligned}$ | $\begin{aligned} & \text { ANLD } \\ & \text { PT, A } \end{aligned}$ |
| A | $\begin{gathered} \text { MOV } \\ @ R 0, A \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { @R1, A } \end{gathered}$ |  | $\begin{aligned} & \text { MOVP } \\ & \text { A, @A } \end{aligned}$ | $\begin{aligned} & \mathrm{JMP} \\ & 5 \mathrm{x} x \end{aligned}$ | $\underset{\text { F1 }}{\text { CLR }}$ |  | $\begin{gathered} \text { CPL } \\ \mathrm{C} \end{gathered}$ | MOV <br> RO, A | MOV <br> R1, A | MOV <br> R2, A | MOV <br> R3, A | $\begin{aligned} & \text { MOV } \\ & \text { R4, A } \end{aligned}$ | MOV <br> R5, A | MOV <br> R6, A | MOV <br> R7, A |
| B | $\begin{gathered} \text { MOV } \\ \text { @RO, \# } \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { @R1, \# } \end{gathered}$ | JB5 addr | JMPP @A | $\begin{aligned} & \text { CALLL } \\ & 5 \times x \end{aligned}$ | $\begin{gathered} \text { CPL } \\ \text { F1 } \end{gathered}$ | $\begin{aligned} & \text { JFO } \\ & \text { addr } \end{aligned}$ |  | $\begin{aligned} & \text { MOV } \\ & \text { RO, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R1, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R2, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R3, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R4, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R5, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R6, \# } \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { RT, \# } \end{aligned}$ |
| C |  |  |  |  | $\begin{aligned} & \text { JMP } \\ & 6 \times x \end{aligned}$ | $\begin{aligned} & \text { SEL } \\ & \text { RBO } \end{aligned}$ | $\underset{\text { addr }}{\mathrm{JZ}}$ | $\begin{gathered} \mathrm{MOV} \\ \mathrm{~A}, \mathrm{PSW} \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { RO } \end{gathered}$ | DEC | $\begin{aligned} & \text { DEC } \\ & \text { R2 } \end{aligned}$ | $\begin{gathered} \text { DEC } \\ \text { R3 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R4 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R5 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R6 } \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { R7 } \end{gathered}$ |
| D | $\begin{gathered} \text { XRL } \\ \text { A, @RO } \end{gathered}$ | $\begin{gathered} \text { XRL } \\ \text { A. @R1 } \end{gathered}$ | JB6 addr | $\begin{aligned} & \text { XRL } \\ & \text { A, \# } \end{aligned}$ | CALL $6 \times x$ | $\begin{aligned} & \text { SEL } \\ & \text { RBB } \end{aligned}$ | JNIBF addr | $\begin{aligned} & \text { MOV } \\ & \text { PSW. A } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, RO } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R1 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R2 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R3 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R4 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R5 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A, R6 } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A. R7 } \end{aligned}$ |
| E |  |  |  | MOVP3 <br> A.@A | $\begin{aligned} & \text { JMP } \\ & 7 \times x \end{aligned}$ | $\begin{aligned} & \text { EN } \\ & \text { DMA } \end{aligned}$ | JNC addr | $\begin{gathered} \text { RL } \\ \text { A } \end{gathered}$ | $\begin{gathered} \text { DJNZ } \\ \text { RO, addr } \end{gathered}$ | $\begin{gathered} \text { DJNZ } \\ \text { R1, addr } \end{gathered}$ | $\begin{gathered} \text { DJNZ } \\ \text { R2, addr } \end{gathered}$ | $\begin{gathered} \text { DJNZ } \\ \text { R3, addr } \end{gathered}$ | $\begin{gathered} \text { DJNZ } \\ \text { R4, addr } \end{gathered}$ | $\begin{gathered} \text { DJNZ } \\ \text { R5, addr } \end{gathered}$ | DJNZ <br> R6, addr | DJNZ <br> R7, addr |
| F | $\begin{aligned} & \text { MOV } \\ & \text { A, @RO } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { A, @R1 } \end{gathered}$ | $\begin{aligned} & \text { JB7 } \\ & \text { addr } \end{aligned}$ |  | $\begin{aligned} & \text { CALL } \\ & 7 \times x \end{aligned}$ | $\begin{aligned} & \text { EN } \\ & \text { FLAGS } \end{aligned}$ | JC <br> addr | $\underset{A}{\text { RLC }}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, RO } \end{aligned}$ | MOV <br> A, R1 | MOV <br> A, R2 | MOV <br> A, R3 | $\begin{aligned} & \text { MOV } \\ & \text { A, R4 } \end{aligned}$ | MOV <br> A. R5 | MOV <br> A. R6 | $\begin{aligned} & \text { MOV } \\ & \text { A, R7 } \end{aligned}$ |

## Legend:

$=$ Immediate data
$=1$ Byte, 1 Cycle Instruction
$\square=1$ Byte, 2 Cycle Instruction
$=2$ Byte, 2 Cycle Instruction

MBL8742H/N

## ELECTRICAL CHARACTERISTICS

Absolute Maximum Ratings

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$, <br> $\mathrm{V}_{\mathrm{DD}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to +7.0 | V |
| Ambient Operating <br> Temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 1.5 | W |

Note:
Permanent device damage may occur if the above ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the

## Recommended Operating Conditions

| Parameter |  | Value |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | Symbol | Min | Typ | Max | Unit |
|  | $\mathrm{V}_{\mathrm{CC}}$, <br> $\mathrm{V}_{\mathrm{DD}}$ | 4.5 | 5.0 | 5.5 | V |
|  | $\mathrm{~V}_{\mathrm{SS}}$ |  | 0 |  | V |
| Operating <br> Temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 |  | +70 | ${ }^{\circ} \mathrm{C}$ |

conditions as detailed in the operational sections of this data sheet Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## DC Characteristics

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Parameter |  | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min |  | Max |  |
| $\mathrm{V}_{\mathrm{DD}}$ Supply Current |  |  | IDD |  |  | 20 | mA |
| Supply Current |  | $\mathrm{I}_{\mathrm{CC}}+\mathrm{I}_{\mathrm{DD}}$ |  |  | 150 | mA |
| Input Low Voltage | All except XTAL1, 2, $\overline{\text { RESET }}$ | $\mathrm{V}_{\text {IL }}$ |  | -0.3 | 0.8 | V |
|  | XTAL1, 2, $\overline{\text { RESET }}$ | $\mathrm{V}_{\text {IL } 1}$ |  | -0.3 | 0.6 | V |
| Input High Voltage | All except XTAL1, 2, $\overline{\text { RESET }}$ | $\mathrm{V}_{\mathrm{IH}}$ |  | 2.0 | $\mathrm{V}_{\mathrm{cc}}$ | V |
|  | XTAL1, 2, $\overline{\text { RESET }}$ | $\mathrm{V}_{\mathrm{IH} 1}$ |  | 3.8 | $\mathrm{V}_{\mathrm{cc}}$ | V |
| Output Low Voltage | $\mathrm{D}_{0}$ to $\mathrm{D}_{7}$ | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |  | 0.45 | V |
|  | P10 to P17, P20 to P27, SYNC | $\mathrm{V}_{\text {OL1 }}$ | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |  | 0.45 | V |
|  | PROG | $\mathrm{V}_{\mathrm{OL} 2}$ | $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ |  | 0.45 | V |
| Output High Voitage | $\mathrm{D}_{0}$ to $\mathrm{D}_{7}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ | 2.4 |  | V |
|  | All other outputs | $\mathrm{V}_{\mathrm{OH} 1}$ | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}$ | 2.4 |  | V |
| Input Leakage Current | $\mathrm{T}_{0}, \mathrm{~T}_{1}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{CS}}, \mathrm{AO}, \mathrm{EA}$ | IIL | $\mathrm{V}_{\mathrm{SS}} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |  | $\pm 10$ | $\mu \mathrm{A}$ |
| Output Leakage Current | $\mathrm{D}_{0}$ to $\mathrm{D}_{7}$ (High-impedance) | $\mathrm{IOL}^{\text {a }}$ | $\begin{gathered} \mathrm{V}_{\mathrm{SS}}+0.45 \mathrm{~V} \leq \\ \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}} \end{gathered}$ |  | $\pm 10$ | $\mu \mathrm{A}$ |
| Input Low Current | P10 to P17; P20 to P27 | $\mathrm{I}_{1}$ | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |  | 0.5 | mA |
|  | $\overline{\text { RESET, }} \overline{\text { SS }}$ | $\mathrm{I}_{\text {LI } 1}$ | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |  | 0.2 | mA |

## AC Characteristics (DBB Read Operation)

( $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ )

| Parameter |  | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Max |  |
| $\overline{\mathrm{CS}}, \mathrm{A} 0$ Setup Time (to $\overline{\mathrm{RD}} \downarrow$ ) |  | $t_{\text {AR }}$ |  | 0 |  | ns |
| $\overline{\text { CS, }}$ AO Hold Time (to $\overline{\mathrm{RD}} \uparrow$ ) |  | $t_{\text {RA }}$ |  | 0 |  | ns |
| $\overline{\mathrm{RD}}$ Pulse Width |  | $t_{\text {RR }}$ |  | 160 |  | ns |
| Data Delay Time (from $\overline{\mathrm{CS}}, \mathrm{AO}$ ) |  | $t_{\text {AD }}$ | $C_{L}=150 \mathrm{pF}$ |  | 130 | ns |
| Data Delay Time (from $\overline{\mathrm{RD}} \downarrow$ ) |  | $\mathrm{t}_{\mathrm{RD}}$ | $C_{L}=150 \mathrm{pF}$ |  | 130 | ns |
| Data Floating Time (from $\overline{\mathrm{RD}} \uparrow$ ) |  | $t_{\text {DF }}$ |  |  | 85 | ns |
| Cycle Time | MBL8742N | $\mathrm{t}_{\mathrm{CY}}$ | 6MHz (N-version) | 2.5 | 15.0 | $\mu \mathrm{s}$ |
|  | MBL8742H |  | 12 MHz (H-version) | 1.25 | 15.0 | $\mu \mathrm{s}$ |

Timing Diagram for Data Bus Buffer (DBB) Read Operation:


## AC Characteristics (DBB Write Operation)

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

| Parameter | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |
| $\overline{\mathrm{CS}}, \mathrm{AO}$ Setup Time (to $\overline{\mathrm{WR}} \downarrow$ ) | $\mathrm{t}_{\mathrm{AW}}$ |  | 0 |  | ns |
| $\overline{\text { CS, }}$ AO Hold Time (from $\overline{W R} \uparrow$ ) | $t_{\text {WA }}$ |  | 0 |  | ns |
| $\overline{\text { WR Pulse Width }}$ | $t_{\text {ww }}$ |  | 160 |  | ns |
| Data Setup Time (to $\overline{\mathrm{WR}} \uparrow$ ) | $t_{\text {bw }}$ |  | 130 |  | ns |
| Data Hold Time (from WR $\uparrow$ ) | $t_{\text {WD }}$ |  | 0 |  | ns |

Timing Diagram for Data Bus Buffer (DBB) Write Operation:


## AC Characteristics (Operation with I/O Expander)

$\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\right)$

| Parameter | Symbol | MBL8742N |  | MBL8742H |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Port Control Setup Time (to PROG $\downarrow$ ) | $\mathrm{t}_{\mathrm{CP}}$ | 100 |  | 110 |  | ns |
| Port Control Hold Time (from PROG $\downarrow$ ) | $t_{\text {PC }}$ | 60 |  | 100 |  | ns |
| Input Data Delay Time (from PROG $\downarrow$ ) | $t_{\text {PR }}$ |  | 650 |  | 810 | ns |
| Input Data Hold Time (from PROG $\uparrow$ ) | $t_{\text {PF }}$ | 0 | 150 | 0 | 150 | ns |
| Output Data Setup Time (to PROG $\uparrow$ ) | ${ }^{\text {t }}$ P | 200 |  | 250 |  | ns |
| Output Data Hold Time (from PROG $\uparrow$ ) | $t_{\text {PD }}$ | 20 |  | 65 |  | ns |
| PROG Pulse Width | $t_{\text {PP }}$ | 700 |  | 1200 |  | ns |

Timing Diagram for Port 2 (lower 4 bits) Operation in Connection With I/O Expander:


MBL8742H/N

## AC Characteristics (DMA Operation)

$\left(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ )

| Parameter | Symbol | Test Conditions | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |
| $\overline{\text { DACK }}$ Setup Time (to $\overline{\mathrm{RD}} \downarrow, \overline{\mathrm{WR}} \downarrow$ ) | $t_{\text {ACC }}$ |  | 0 |  | ns |
| $\overline{\text { DACK }}$ Hold Time (from $\overline{\mathrm{RD}} \uparrow, \overline{\mathrm{WR}} \uparrow$ ) | $t_{\text {CAC }}$ |  | 0 |  | ns |
| Input Data Delay Time (from $\overline{\text { DACK }} \downarrow$ ) | $\mathrm{t}_{\mathrm{ACD}}$ | $C_{L}=150 \mathrm{pF}$ |  | 130 | ns |
| DRQ Clear Time (from $\overline{\mathrm{RD}} \downarrow, \overline{\mathrm{WR}} \downarrow$ ) | ${ }^{\text {t CRQ }}$ |  |  | 100 | ns |

## Timing Diagram for DMA Operation:



TEST CONDITIONS
$\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ (All except XTAL1, 2, $\overline{\text { RESET }}$ )
$=0.6 \mathrm{~V}$ (XTAL1, 2, $\overline{\text { RESET }})$
$V_{I H}=2.0 \mathrm{~V}$ (All except XTAL1, 2, $\left.\overline{\text { RESET }}\right)$
$=3.8 \mathrm{~V}$ (XTAL1, 2, $\overline{\mathrm{RESET}}$ )
$\mathrm{V}_{\mathrm{OL}}=0.45 \mathrm{~V}$
$\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$
OUTPUT LOAD
D0 to D7: $C_{L}=150 \mathrm{pF}$
All other outputs: $C_{L}=80 \mathrm{pF}$

Oscillation Circuits


## ELECTRICAL CHARACTERISTICS FOR PROGRAMMING

DC Characteristics ${ }^{1,2}$
( $T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=21 \pm 0.5 \mathrm{~V}$ or $5 \mathrm{~V} \pm 5 \%$ )

| Parameter | Symbol | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $\mathrm{V}_{\mathrm{DD}}$ Program Voltage High Level | $\mathrm{V}_{\text {DDH }}$ | 20.5 | 21.5 | V |
| $\mathrm{V}_{\text {DD }}$ Program Voltage Low Level | $V_{\text {DDL }}$ | 4.75 | 5.25 |  |
| PROG Program Voltage High Level | $\mathrm{V}_{\mathrm{PH}}$ | 17.5 | 18.5 | V |
| PROG Program Voltage Low Level | $\mathrm{V}_{\mathrm{PL}}$ | - | 0.2 |  |
| EA Program/Verify Voltage High Level | $\mathrm{V}_{\text {EAH }}$ | 17.5 | 18.5 | V |
| EA Program/Verify Voltage Low Level | $V_{\text {EAL }}$ | - | 5.25 |  |
| $V_{\text {DD }}$ High Voltage Supply Current | IDD | - | 30.0 | mA |
| PROG High Voltage Supply Current | $\mathrm{I}_{\text {PROG }}$ | - | 16.0 |  |
| EA High Voltage Supply Current | $I_{\text {EA }}$ | - | 1.0 |  |

Notes:

1. High Level Voltage ( $\mathrm{V}_{\mathrm{DDH}}, \mathrm{V}_{P H}$ ) should not be applied to $\mathrm{V}_{\mathrm{DD}}$ and $P R O G$ pins unless $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ and $E A=18 \mathrm{~V} \pm 0.5 \mathrm{~V}$.
2. $\mathrm{V}_{\mathrm{DD}}$, PROG, and EA should not exceed the above specified range, including overshoot and undershoot.

## AC Characteristics

( $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=21 \pm 1.0 \mathrm{~V}$ or $5 \mathrm{~V} \pm 5 \%$ )

| Parameter | Symbol | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| Address setup time (before $\overline{\text { RESET }} \uparrow$ ) | $\mathrm{t}_{\text {AW }}$ | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ | - |  |
| Address hold time (after RESET $\uparrow$ ) | $t_{\text {WA }}$ | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ | - |  |
| Input data setup time (before $\overline{\text { PROG }} \uparrow$ ) | $t_{\text {bW }}$ | $4 \cdot \mathrm{t}_{C Y}$ | - |  |
| Input data hold time (after $\overline{\text { PROG }} \downarrow$ ) | $t_{\text {WD }}$ | $4 \cdot \mathrm{t}_{C Y}$ | - |  |
| $\overline{\text { RESET }}$ hold time (after EA $\downarrow$ ) | $t_{\text {PH }}$ | $4 \cdot \mathrm{t}_{\mathrm{Cr}}$ | - |  |
| $\mathrm{V}_{\text {DD }}$ setup time (before PROG $\uparrow$ ) | tvodw | $4 \cdot t_{C Y}$ | - |  |
| $V_{\text {DD }}$ hold time (before PROG $\downarrow$ ) | $\mathrm{t}_{\text {VDDH }}$ | 0 | - |  |
| Program pulse width | $t_{\text {PW }}$ | 50 | 60 | ms |
| TO setup time (before RESET $\uparrow$ ) | $t_{\text {Tw }}$ | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ | - |  |
| TO hold time (after $\mathrm{V}_{\mathrm{DD}} \downarrow$ ) | $t_{\text {WT }}$ | $4 \cdot \mathrm{t}_{C Y}$ | - |  |
| Data output delay time (after TO $\uparrow$ ) | $t_{\text {DO }}$ | - | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ |  |
| RESET pulse width (to Latch Address) | $t_{\text {ww }}$ | $4 \cdot t_{C Y}$ | - |  |
| $V_{D D}$ and PROG rise/fall time | tr/tf | 0.5 | 2.0 | $\mu \mathrm{s}$ |
| MPU cycle time | $\mathrm{t}_{\mathrm{Cr}}$ | 5.0 | - | $\mu \mathrm{s}$ |
|  | $t_{\text {RE }}$ | $4 \cdot{ }^{\text {ct }}$ C | - |  |
| EA setup time (before RESET $\uparrow$ ) | $t_{\text {EA }}$ | 10 | - | ms |

Timing Diagram for Programming/Verify Mode:


## PACKAGE DIMENSIONS

40-Lead Ceramic (Metal Seal)
Dual In-Line Package (Case No.: DIP-40C-A04)




## Description

The Fujitsu MB8868/A is a programmable Universal Asynchronous Receiver/Transmitter (UART), fabricated with an N -channel silicon gate MOS technology. All control pins, input pins and output pins are TTL compatible. The UART interfaces asynchronous serial data channels from terminals or other peripherals to the parallel data of a microprocessor, computer, or other terminal. Parallel data is converted by the transmitter section of the UART into a serial word consisting of the data as well as start, parity, and stop bit(s). Serial data is converted by the receiver section of the UART into parallel data. The receiver section verifies correct code transmission by parity checking and active reception of a valid stop bit. The UART can be programmed to accept word lengths of 5, 6, 7 , or 8 bits. Even or odd parity can be set. Parity generation and checking can be inhibited.

One, one and one-half, or two stop bits can be set when transmitting a 5-bit code.

## Features

- Full or Half Duplex Operation
- Completely Programmable
- Start Bit Generated

Automatically

- Data and Clock

Synchronization Performed Automatically

- Data Received/Transmitted Status Automatically Generated
- Complete Static Circuity
- TTL Compatible I/O
- Three-State Output Capability
- Single Power Supply: +5V
- Standard 40-Pin Dual InLine Package
- Functionally Compatible with Western Digital TR1863 and AMI S1602




## Pin Assignment



## Absolute Maximum Ratings (See Note)

| Rating | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- |
| $\mathrm{V}_{\mathrm{CC}}$ Pin Potential to $\mathrm{V}_{\mathrm{SS}}$ Pin | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | $\mathrm{~V}_{\mathrm{DC}}$ |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to +7.0 | $\mathrm{~V}_{\mathrm{DC}}$ |
| Output Voltage | $\mathrm{V}_{\mathrm{O}}$ | -0.3 to +7.0 | $\mathrm{~V}_{\mathrm{DC}}$ |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storate Temperature | $\mathrm{T}_{\mathrm{stg}}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

Note: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. It is advised that normal precautions be taken to avoid applications of any voltages higher than maximum rated voltages to this high impedance circuit.

## Recommended Operating

 Conditions(Referenced to $V_{S S}$ )

| Parameter | Symbol | Value |  |  | Unit | Operating Temperature |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.75 | 5.0 | 5.25 | V | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
|  | $\mathrm{V}_{\text {SS }}$ | 0.0 | 0.0 | 0.0 | V |  |
| Logic Input High Voltage | $\mathrm{V}_{\text {IH }}$ | 2.2 | - | $\mathrm{V}_{C C}$ | V |  |
| Logic Input Low Voltage | $V_{\text {IL }}$ | -0.3 | - | +0.8 | V |  |

## DC Characteristics

(Recommended operating conditions unless otherwise noted)

| Parameter | Symbol | Value |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |
| Input Leakage Current $\left(\mathrm{V}_{\text {IN }}=0 \text { to } 5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}\right)$ | LLI | - | - | 350 | $\mu \mathrm{A}$ |
| Output Leakage Current for 3-State $\left(\mathrm{V}_{\mathrm{OUT}}=0 \mathrm{~V}\right.$ to $\left.\mathrm{V}_{\mathrm{CC}}, \mathrm{SFD}=\mathrm{RRD}=\mathrm{V}_{\mathrm{IH}}\right)$ | l Lz | -20 | - | +20 | $\mu \mathrm{A}$ |
| Output Low Voltage ( $\mathrm{ILL}=1.8 \mathrm{~mA}$ ) | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.4 | V |
| Output High Voltage ( $\mathrm{IOL}=-200 \mu \mathrm{~A}$ ) | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | - | V |
| $\mathrm{V}_{\text {CC }}$ Supply Current | $\mathrm{I}_{\mathrm{CC}}$ | - | 70 | - | mA |

## AC Characteristics

(Recommended operating ranges unless otherwise noted)

| Parameter | Symbol | Value |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |
| Clock Frequency for RRC and TRC (Duty $\mathrm{Cycle}=50 \%$ ) | $f_{C}$ | DC | - | 800 | kHz |
| CRL Pulse Width, High | $\mathrm{t}_{\text {pwC }}$ | 200 | - | - | ns |
| THRL Pulse Width, Low | $\mathrm{t}_{\text {PWT }}$ | 180 | - | - | ns |
| DRR Pulse Width, Low | $\mathrm{t}_{\text {PWR }}$ | 180 | - | - | ns |
| MR Pulse Width, High | $\mathrm{t}_{\text {PWM }}$ | 150 | - | - | ns |
| Coincidence Time (Fig. 4 and Fig. 8) | $\mathrm{t}_{\mathrm{C}}$ | 180 | - | - | ns |
| Hold Time (Fig. 4 and Fig. 8) | $t_{H}$ | 20 | - | - | ns |
| Setup Time (Fig. 4 and Fig. 8) | $\mathrm{t}_{\text {SET }}$ | 0 | - | - | ns |
| Propagation Delay Time, High to Low, Output ( $\mathrm{C}_{\mathrm{L}}=130 \mathrm{pF}+1 \mathrm{TTL}$ ) | $\mathrm{t}_{\text {pdo }}$ | - | - | 350 | ns |
| Propagation Delay Time, Low to High, Output $\left(C_{L}=130 \mathrm{pF}+1 \mathrm{TTL}\right)$ | $\mathrm{t}_{\text {pd1 }}$ | - | - | 350 | ns |

## Pin Descriptions

| Pin Name | Pin Number | Description |
| :---: | :---: | :---: |
| RRD | 4 | Receiver Register Disconnect |
|  |  | A high logic level, $\mathrm{V}_{\mathrm{IH}}$, on this pin disconnects the Receiver Holding Register outputs from the data outputs $\mathrm{RR}_{8}-\mathrm{RR}_{1}$ on pins 5-12. |
| $\begin{aligned} & \mathrm{RR}_{8} \text { thru } \\ & \mathrm{RR}_{1} \end{aligned}$ | $\begin{aligned} & 5,6,7,8,9,10, \\ & 11,12 \end{aligned}$ | Receiver Holding Register Data |
|  |  | These are the parallel outputs from the Receiver Holding Register if the RRD input is an input low level, $\mathrm{V}_{\text {IL }}$. Data is right justified for character formats of less than eight bits, with RR $_{1}$ being the least significant bit. Unused MSB's are forced to a low logic output level, $\mathrm{V}_{\mathrm{OL}}$. |
| PE | 13 | Parity Error |
|  |  | This output pin goes to a high level, $\mathrm{V}_{\mathrm{OH}}$, if the received parity does not agree with that programmed by the Even Parity Enable input (pin 39). |
|  |  | With each character transferred to the Receiver Holding Register, this output is updated. The status Flag Disconnect input (pin 16) allows additional PE lines to be tied together by providing an output disconnect capability. |

## Pin Descriptions <br> (Continued)

Pin Name Pin Number Description

| FE | Framing Error |
| :--- | :--- | :--- |
|  | This output pin goes to a high level, V ${ }_{\text {OH }}$, if the received |
| character has no valid Stop bit. With each character |  |
| transferred to the Receiver Holding Register, this output is |  |
|  | updated. The Status Flag Disconnect input (pin 16) allows |
| additional FE lines to be tied together by providing an output |  |
| disconnect capability. |  |

FUJITSU

Pin Descriptions (Continued)

| Pin Name | Pin Number | Description |
| :---: | :---: | :---: |
| TRO | 25 | Transmitter Register Output |
|  |  | This output line transmits the Transmitter Register contents [Start bit, Data bits, Parity bit, and Stop bit(s)] serially. This output remains at a high level, $\mathrm{V}_{\mathrm{OH}}$, when no data is being transmitted. Therefore, the start of transmission is determined by the transition of the Start bit from a high level to a low level voltage, $\mathrm{V}_{\mathrm{OL}}$. |
| $\begin{aligned} & \mathrm{TR}_{1} \text { thru } \\ & \mathrm{TR}_{8} \end{aligned}$ | $\begin{aligned} & 26,27,28,29, \\ & 30,31,32,33 \end{aligned}$ | Transmitter Register Data Inputs |
|  |  | The THRL strobe loads each character on these lines into the Transmitter Holding Register. If $W \mathrm{LS}_{1}$ and $\mathrm{WLS}_{2}$ have selected a character of less than 8 bits, the character is then right-justified to the least significant bit, $\mathrm{TR}_{1}$, with the excess bits not used. A high input level, $\mathrm{V}_{\mathbb{I}}$, will cause a high output level, $\mathrm{V}_{\mathrm{OH}}$, to be transmitted. |
| $\overline{\text { CRL }}$ | 34 | Control Register Load |
|  |  | When this input is at a high level, $\mathrm{V}_{1 \mathrm{H}}$, the control bits $\left(\mathrm{WLS}_{1}\right.$, $\mathrm{WLS}_{2}$, EPE, PI, SBS), are loaded into the Control Register. This input may be either strobed or hard wired to a high level. |
| $\overline{\mathrm{PI}}$ | 35 | Parity Inhibit |
|  |  | When this input is at a high level, $\mathrm{V}_{\mathrm{IH}_{\mathrm{H}}}$, parity generation and verification circuitry are inhibited and the PE output will be held to a low level, $\mathrm{V}_{\text {OL }}$. In the inhibit condition, the Stop bit(s) will follow the last data bit on transmission. |
| SBS | 36 | Stop Bit(s) Select |
|  |  | A high level, $\mathrm{V}_{1 H}$, on this input will select two Stop bits, and a low level, $\mathrm{V}_{\mathrm{IL}}$, will select one Stop bit. If 5 -bit long words are selected, a high level, $\mathrm{V}_{\mathrm{IH}}$, will generate one and one-half Stop bits. |
| $W_{L S}$, WLS $_{2}$, EPE, TRC |  | Word Length Select (WLS $\mathbf{W}_{1}$ WLS $\mathbf{W}_{\text {) }}$ <br> The state of these two inputs determines the character length (exclusive of parity) as follows: |


| WLS $_{2}$ | WLS | Word Length |
| :---: | :---: | :---: |
| $V_{I H}$ | $V_{I H}$ | 8 bits |
| $V_{I H}$ | $V_{I L}$ | 7 bits |
| $V_{I L}$ | $V_{I H}$ | 6 bits |
| $V_{I L}$ | $V_{I L}$ | 5 bits |

## Even Parity Enable (EPE)

A high level, $\mathrm{V}_{\mathrm{IH}}$, on this input will select even Parity, while a low level, $\mathrm{V}_{\text {IL }}$, selects odd Parity.

Transmitter Register Clock (TRC)
The frequency of this ciock is 16 times the desired transmitter shift rate.

## Timing Diagrams



Timing for Status Flag, RR $_{1}$, thru RR $\mathbf{B}_{8}$ and DR (Detail \#1)


Timing Diagrams
(Continued)


Data Input Load Cycle (Detail \#2)


## Timing Diagrams (Continued)

## Transmitter Output Timing (1) (Detail \#3)

TRC


## Notes:

(1) When the positive transition of THRL is $\geq 500 \mathrm{~ns}$ before the falling edge of TRC (CF2 in the figure), then TRE is enabled at CF2. But when $500 \mathrm{~ns}>$ (1) $>0 \mathrm{~ns}$, then TRE is invalid between CF2 and CF3.
(2) THRE goes low during 500 ns Max. from the postive transition of THRL.
(3) TRE goes low during 500 ns Max. from the first falling edge of TRC after THRE goes low with TRE high.
(4) TRO goes low (START BIT) during 500 ns Max. from the first rising edge of TRC after TRE goes low.
(5) THRE goes high during 500 ns Max. from the falling edge of TRC after Start bit is enabled.

Transmitter Output Timing (2) (Detail \#4)

TRC


Notes:
(2) ~ (5) Refer to Notes in Detail \#3
(6) TRE goes high during 500 ns Max. from the 15th rising edge of TRC after Stop bit is enabled.

## Timing Diagrams

(Continued)

## Other Timing Diagrams

Input After Master Reset


Status Flag Output


Control Register Load Cycle


Data Output


## Package Dimensions

(Dimensions in millimeters)

## 40-Lead Ceramic (Metal Seal) Dual In-Line Package DIP-40C-A01



© 1986 FUJITSU LIMITED D40006S-1C

40-Lead Plastic Dual In-Line Package DIP-40P-M01


# TTL TWO-PHASE <br> CLOCK GENERATOR AND DRIVER 

## TWO-PHASE MICROPROCESSOR CLOCK

The Fujitsu MB 8867 is an advanced Microprocessor Clock Generator/Driver LSI manufactured with Fujitsu's bipolar TTL process. The circuit generates non-overlapping two-phase clock signals for the Fujitsu MBL 6800 microprocessor unit or similiar single +5 volt MPU's. Additionally, two-phase TTL clock signals synchronized with the MPU clock are provided, as well as an MPU data strobe, reset/clock controls for the memory interrupt, and an automatic power-up reset. With the MB 8867, the entire MPU timing system can be designed with one chip and a minimum of external components.

A built-in oscillator permits external timing control by a crystal; or RC network timing can be utilised for less critical applications. In the former; the internal frequency divider is rate selectable, so that the output frequency is either $1 / 4$ or $1 / 16$ of the source frequency.

Driver circuits are included on the MB 8867 which eliminates the need for external buffer gates and reduces system package count. Output drivers are short-circuit protected.

- Single chip two -phase clock generator with on-chip drivers
- Short-circuit protected outputs
- Complete MPU system timing network including dynamic memory refresh
- Single +5 V power supply
- Low power consumption: 450 mW typ.
- Reliable TTL process
- Two-phase TTL clock signals
- Data strobe for memory control synchronization
- Automatic power-up and manual reset
- Clock controls for memory interrupt
- Crystal or RC network frequency source
- Selectable source frequency options
- Works with high speed microprocessors
- Standard 24 pin package
- Minimum external components required

ABSOLUTE MAXIMUM RATINGS (See NOTE)

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ Pin Potential to GND Pin | $\mathrm{V}_{\mathrm{CC}}$ | +7 Max. | V |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.5 to +5.5 | V |
| Output Voltage | $\mathrm{V}_{\mathrm{O}}$ | -0.5 to +5.5 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | -25 to +125 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\mathrm{stg}}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

NOTE: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet.


Small geometry bipolar integrated circuits are occasionally susceptible to damage from static voltages or electric fields. It is therefore advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this device.

## INTRODUCTION

The MB 8867 provides the two-phase clock signal input for the MBL 6800 microprocessor or any similiar timing signal required in a microcomputer system. The IC incorporates the necessary logic to ensure that these clock signals ( $\phi_{1}$ and $\phi_{2}$ ) are non-overlapping; and, additionally, the MB 8867 is designed to accomodate direct connection to high capacitive loads (typically 170 pF ) without additional buffering.
Most high speed microprocessor controlled systems utilize dynamic random access memories in order to minimize

## DESCRIPTION OF PINS

$$
X T_{1}, X T_{2}
$$

Two pins are provided for the connection of an external crystal. The crystal selected should be either four or sixteen times the desired output clock frequency. Small picofarad capacitors are provided internally in the oscillator circuitry. However, for fine oscillation control, an additional small capacitor ( 3 pf to 10 pf ) in series with the crystal may be used.

## EXT. IN (TTL input)

This input is used for an external RC network to provide timing control when a crystal is not utilized. Note that, like the crystal source, the input frequency will be either four or sixteen times the desired output clock frequency. See the APPLICATIONS INFORMATION section of this data sheet for proper external component connection.

## M. CLK (TTL output)

Provides a reference clock driver for external memory synchronous with $\phi_{2}$. The frequency is identical to the output clock frequency ( $\phi_{1}, \phi_{2}$ ), but is not affected by switching R. REQ (refresh cycle).

## 2M, 4M (TTL outputs)

2 M and 4 M are pulse train drivers with frequencies of two times and four times the output clock ( $\phi_{1}, \phi_{2}$ ) frequency, respectively. When R. SEL is low, EXT. IN and 4 M are in opposite phase. Therefore, ring oscillation can be generated without an external crystal by inserting an appropriate RC network between 4M and EXT. IN. See the APPLICATIONS INFORMATION section of this data sheet for circuit information.

RC
Provides automatic power-up reset function by utilizing an external RC network. $\overline{R E S E T}$ goes low with the rising edge of $\phi_{1}$ when RC is less than 0.8 V ; $\overline{R E S E T}$ goes high when RC is greater than $2 / 3 \mathrm{~V}_{\mathrm{cc}}$. Therefore, automatic power-up reset is obtained by providing a delay slower than the rise time of $\mathrm{V}_{\mathrm{cc}}$.

## INH (TTL input)

Used to control internal oscillation. The oscillator is operational when $\overline{\mathrm{NH}}$ is brought high (open); the oscillator is inhibited when $\overline{\text { INH }}$ is brought low.
system cost and power consumption. A major design problem in such systems is to provide dynamic RAM refresh timing signals synchronized with the operation of the MPU. The MB 8867 solves this problem with its refresh control pins, $\bar{R}$. REO and R. GRANT (Refresh Request and Refresh Grant).

In the pin description below, all TTL compatible inputs and outputs are indicated by "TTL input" or "TTL output" and later refered to in the characteristic tables by these terms.

## R. SEL (TTL input)

When R. SEL is high (open), the one-by-four frequency divider is operational; when R. SEL is low, the divider is bypassed. As an example, a 16 MHz external time source will generate a 1 MHz output clock frequency if $R$. SEL is high.
$\phi_{1}, \phi_{2}$
MPU output clock drivers. $\phi_{1}$ and $\phi_{2}$ have non-overlapping control.

## $\phi_{1}$ TTL, $\phi_{2}$ TTL (TTL outputs)

TTL level output clock drivers synchronized with $\phi_{1}$ and $\phi_{2}$, respectively.

## DATA STB (TTL output)

Data strobe signal for memory read and write operations. DATA STB goes high one cycle of the 4 M output frequency after $\phi_{2}$ goes high; DATA STB goes low just before $\phi_{2}$ goes low. If M . RDY is not interrupted, DATA STB will maintain its high state during the last quarter cycle of $\phi_{2}$.

## RESIN, $\overline{R E S I N}$ (TTL outputs)

Provides manual input reset. After reset, RESIN is brought low and RESIN is open. Manual reset occurs when these states are reversed. An internal flip-flop prevents switch-on chattering.
$\overline{\text { RESET }}$ (TTL output open-collector)
Open-collector output pin to provide the reset function.
R. REQ, (TTL input) R. GRANT (TTL output)

These pins provide memory refresh control. $\overline{\text { R. REQ }}$ is usually kept high. To start the refresh cycle, $\bar{R}$. REO is brought low, and then R. GRANT goes high at the next falling edge of the memory clock. Then $\overline{\mathrm{R} . \mathrm{REO}}$ is brought high, and R. GRANT will go low at the next falling edge of the memory clock. $\phi_{1}$ will stay high and $\phi_{2}$ will stay low during refresh. R. GRANT may be connected to the three state control of the MPU system to provide refresh for dynamic memories and DMA (Direct Memory Access) in the "cycle steal" mode.

## M. RDY, (TTL input) M. GRANT (TTL output)

Provided for low speed memory control. $\overline{\mathrm{M} . \text { RDY }}$ is usually kept high. When $\bar{M}$. RDY is brought low, M. GRANT goes low on the next falling edge of 4 M . The high state of $\phi_{2}$ is extended for the period that M. GRANT is low. At the same

MB 8867
time, the high state of M.CLK and DATA STB are maintained. This permits a long time period for memory read operations.
Vcc
Connected to the +5 V supply. By-pass capacitors are
recommended if the supply rail is long in order to reduce supply impedance.

## GND 1, GND 2

Two ground terminals are provided in order to reduce internal impedance paths.


Fig. 2-SYSTEM TIMING DIAGRAM

- MEMORY INTERRUPT TIMING

NORMAL REFRESH REQUEST INTERRUPT MEMORY READY INTERRUPT


- POWER-UP RESET TIMING


GUARANTEED OPERATING CONDITIONS
(Referenced to GND)

| Parameter | Symbol | Value |  |  | Unit | Operating <br> Temperature |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| Supply Voltage | $V_{\mathrm{CC}}$ | 4.75 | 5.0 | 5.25 | V |  |
| Input High Voltage (TTL inputs) | $\mathrm{V}_{1 \mathrm{HT}}$ | 2 |  |  | V | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Input High Voltage (RC) | $\mathrm{V}_{I H R}$ | 4.5 |  |  | V |  |

## DC CHARACTERISTICS *

(Full Guaranteed Operating Ranges unless otherwise noted.)

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |
| Output High Voltage $\begin{aligned} & \phi_{1}, \phi_{2}\left(I_{\mathrm{OH}}=-0.2 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}\right) \\ & \mathrm{TTL} \text { outputs except } \overline{\mathrm{RESET}}\left(\mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}\right) \end{aligned}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 4.95 \\ & 2.4 \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| Output Low Voltage $\begin{aligned} & \phi_{1}, \phi_{2}\left(\mathrm{I}_{\mathrm{OL}}=1.8 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}\right) \\ & \mathrm{TTL} \text { inputs }\left(I_{\mathrm{OL}}=16 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}\right) \end{aligned}$ | $\mathrm{V}_{\text {OL }}$ |  |  | $\begin{aligned} & 0.3 \\ & 0.4 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| Input Clamp Diode Voltage <br> TTL inputs ( $I_{I C}=-12 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ ) | $V_{\text {IC }}$ |  |  | 1.5 | V |
| Input High Current <br> EXT IN ( $\left.\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=2.4 \mathrm{~V}\right)$ <br> R.REQ, M.RDY, RESIN <br> $\overline{R E S I N}, R . S E L, \overline{I N H} \quad\left(V_{C C}=4.75 \mathrm{~V}, V_{I N}=2.4 \mathrm{~V}\right)$ <br> $R C\left(V_{C C}=5.25 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=5.25 \mathrm{~V}\right)$ | $I_{\text {IH }}$ | -100 |  | 40 <br> 10 | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| Input Low Current <br> EXT IN ( $\left.\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=0.4 \mathrm{~V}\right)$ <br> $\overline{\text { R.REQ }}, \overline{M . R D Y}$, RESIN, $\overline{R E S I N}$ <br> $\left(\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \quad \mathrm{~V}_{1 \mathrm{~N}}=0.4 \mathrm{~V}\right.$ ) <br> R.SEL, $\overline{\text { INH }}\left(\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=0.4 \mathrm{~V}\right)$ | IIL |  |  | $\begin{aligned} & -1.6 \\ & -3.2 \\ & -4.8 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Power Supply Current $\begin{aligned} & \left(\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{XT}_{2}=0 \mathrm{~V}\right) \\ & \left(\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{XT}_{2}=0 \mathrm{~V}\right) \end{aligned}$ | Icc | 60 |  | 160 | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Output High Current $\overline{\mathrm{RESET}}\left(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V}\right)$ | IOH |  |  | 250 | $\mu \mathrm{A}$ |
| Output Short Circuit Current $\begin{aligned} & \phi_{1}, \phi_{2}\left(\mathrm{~V}_{\mathrm{OL}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}\right) \\ & \mathrm{TTL} \text { inputs except } \overline{\mathrm{RESET}}\left(\mathrm{~V}_{\mathrm{OL}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}\right) \end{aligned}$ | Ios | $\begin{aligned} & -33 \\ & -18 \end{aligned}$ |  | $\begin{aligned} & -100 \\ & -55 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |

* Unused terminals are left open.

AC CHARACTERISTICS
(Full Guaranteed Operating Ranges unless otherwise noted.)


Fig. 3-AC TEST CONDITIONS

TTL Input Waveform



Fig. 4-TIMING DIAGRAM (1)


Fig. 5-TIMING DIAGRAM (2)


Fig. 6-TIMING DIAGRAM (3)


## TYPICAL CHARACTERISTICS CURVES





- except inputs with pull-up resistor

Fig. 8 - $I_{\text {IN }}$ INPUT CURRENT vs $V_{\text {IN }}$ INPUT VOLTAGE *

Fig. $9-I_{\mathrm{OL}}$ OUTPUT LOW CURRENT vs $V_{\text {OL }}$ OUTPUT LOW VOLTAGE(TTL OUTPUTS)


Fig. 13 - $\mathrm{I}_{\mathrm{OH}}$ OUTPUT HIGH CURRENT


Fig. 14 - $\mathrm{C}_{\mathrm{L} \phi}$ LOAD CAPACITANCE


## APPLICATIONS INFORMATION

## 1. Crystal Oscillator:

The crystal oscillator circuitry is shown in Fig. 15. Oscillations between the serial $\left(f_{0}\right)$ and parallel ( $f_{\infty}$ ) resonant frequency of the crystal can be generated. Pico farad capacitors ( $\mathrm{C}_{10}, \mathrm{C}_{20}$ ) are diffused on-chip. Therefore, oscillation can be generated by simply connecting an external capacitor ( $C_{2} \sim 50_{\mathrm{p}} \mathrm{F}$ ) from $X \mathrm{~T}_{2}$ to ground. Normally, a crystal with a resonant frequency of four or sixteen times the desired output clock driver frequency is used. The selection depends on whether the R. SEL pin is high (16X) or low (4X).

External crystal specifications:

| Oscillator Frequency | $22 \mathrm{MHz} \max$. |
| :--- | :--- |
| Load Capacitance | $10 \sim 30 \mathrm{pF}$ |
| Equivalent Resistance | 75 ohms max. |
| Resonant Power | 4 mW max. |

Fig. 15-Oscillation Circuitry


Typical Frequency of Crystal Oscillator

| Clock <br> Frequency <br> $(\mathrm{MHz})$ | Cycle <br> Time <br> (ns) | Inherent Frequency of <br> Crystal Oscillator (MHz) |  |
| :---: | :---: | :---: | :---: |
|  | R.SEL=H | R.SEL $=$ L |  |
| 1.00 | 1000 | 16.00 | - |
| 1.33 | 750 | 21.33 | - |
| 2.00 | 500 | - | 8.00 |

Fig. 16-Standard Capacitance for Crystal Oscillator


## 2. $\phi_{1}, \phi_{2}$ Clock Driver Circuit

The output clock driver circuit is shown in Fig. 17.
These circuits are designed to drive capacitive loads with a high amplitude pulse train. The pull-up resistor $\mathbf{R}_{\mathrm{p}}$ has a nominal value of 500 ohms, and is on-chip in order to swing $\phi_{1}, \phi_{2}$ up to $\mathrm{V}_{\mathrm{Cc}}$. When $\phi_{1}, \phi_{2}$ are grounded, $\mathrm{R}_{\mathrm{s}}(10 \mathrm{ohms})$ and $\mathrm{O}_{4}$ protect the output driver $\mathrm{Q}_{3}$.

Fig. 17-Clock Driver Circuitry


## 3. Input Controls

All input controls ( $\overline{\mathrm{INH}}, \mathrm{R} . \mathrm{SEL}, \overline{\mathrm{R} . \text { REO }}, \overline{\mathrm{M} . \text { RDY, RESIN, }}$ $\overline{\text { RESIN }}$ ) are TTL compatible. To simplify system packaging, all these pins have internal pull-up resistors so that they may be left open (unconnected) if desired.

Fig. 18-CLOCK GENERATION USING CRYSTAL


Fig. 19-CLOCK GENERATION USING EXTERNAL "RC" NETWORK


NOTE: When both $\overline{1 N H}$ and R.SEL are held low, the circuit between EXT. IN and 4 M forms a five stage serial invertor. The osillation frequency of this ring oscillator is controlled by the external 3 K ohm resistor.

## APPLICATIONS INFORMATION (cont'd)

Fig. 20-REFRESH CONTROL APPLICATION


Fig. 21-LOW SPEED MEMORY APPLICATION


NOTE: *1. Values depend upon memory speed. For $1 \mu$ s cycle time, use 100 pF and $25 \mathrm{~K} \Omega$.
*2. Inverter for address selection may be used.

## PACKAGE DIMENSIONS



## SELECTOR GUIDE

ANALOG-TO-DIGITAL CONVERTERS

| Device Number | Description | Resolution (bits) | Linearlity (\%) | Analog Input Voltage Range (V) | Conversion Speed | Supply Voltage (V) | Max. Supply Current (mA) | I/O Level | Package | Alternate Source |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MB4052 ${ }^{1}$ | Bipolar 4-ch. 8-bit A/D Converter: Successive approximation technique, Serial output | 8 | $\pm 0.19$ | 3 Modes: 0 to 0.625, 0 to 2.5, 0 to 10 | $\begin{aligned} & 100 \mu \mathrm{~s} / \\ & \text { ch Max } \end{aligned}$ | $\begin{aligned} & \hline 3.5-6.0 \\ & \text { or } \\ & 8.0-18 \end{aligned}$ | $\begin{aligned} & 30 \text { at } \\ & V_{C C}=6 \mathrm{~V} \end{aligned}$ | TTL/ CMOS, Open Collector | $\begin{aligned} & \text { DIP-16C-C02 } \\ & \text { DIP-16P-M02 } \end{aligned}$ | - |
| MB40532 | Bipolar 6-ch. A/D Converter Subsystem: Single slope method, Pulse width output, scale correction | - | $\pm 0.2$ | $\begin{aligned} & 0 \text { to }\left(V_{C C}-2\right), \\ & 5.25 \mathrm{Max}^{2} \end{aligned}$ | $\begin{aligned} & 350 \mu / \\ & \text { ch Max } \end{aligned}$ | $\begin{aligned} & 4.75 \\ & \text { to } 15 \end{aligned}$ | 10 | TTL | $\begin{aligned} & \text { DIP-16C-C02 } \\ & \text { DIP-16P-M01 } \\ & \text { FPT-16P-M01 } \end{aligned}$ | $\mu A 9708$ |
| MB4056 ${ }^{3}$ | Bipolar 8-channel, successive approximation technique, Serial output | 6 | 0.19 | $\begin{aligned} & 0 \text { to } 1.25 \text {; } \\ & 0 \text { to } 5 \end{aligned}$ | $100 \mu /$ channel max | $\begin{aligned} & 4.75 \text { to } \\ & 18 \end{aligned}$ | 40 | TTL | DIP-20P-M01 | - |
| MB4063 ${ }^{2}$ | MB4053 with onchip voltage divider | - | $\pm 0.2$ | $\begin{aligned} & 0 \text { to }\left(\mathrm{V}_{\mathrm{CC}}-2\right), \\ & 5.25 \text { Max } \end{aligned}$ | $\begin{aligned} & 350 \mu \mathrm{~s} / \\ & \text { ch Max } \end{aligned}$ | - | - | TTL | DIP-16C-C02 DIP-16P-M01 FPT-16P-M01 | - |
| $\begin{array}{r} \hline \text { MB40547-73 } \\ -8^{3} \end{array}$ | Bipolar High Speed 1-ch. 8-bit A/D Converter: Fullyparallel comparison method | $\begin{aligned} & \hline 8 \\ & 8 \end{aligned}$ | $\begin{aligned} & \pm 0.4 \\ & \pm 0.2 \end{aligned}$ | $\begin{aligned} & V_{c c} \text { to } \\ & \left(V_{c c}-2\right) \end{aligned}$ | $\begin{aligned} & 20 \\ & \text { MSPS } \end{aligned}$ | $\begin{aligned} & \hline-5.2 \\ & \pm 5 \% \end{aligned}$ | -280 | $\begin{aligned} & 10 \mathrm{~K} \\ & \mathrm{ECL} \end{aligned}$ | DIP-24C-A01 | - |
| MB40576 ${ }^{3}$ | Bipolar High Speed 1-ch. 6-bit A/D Converter: Fullyparallel comparison method | 6 | $\pm 0.8$ | $\mathrm{V}_{\mathrm{Cc}}$ to ( $\mathrm{VCC}^{-2}$ ) <br> 1V Width | $\begin{aligned} & 20 \\ & \text { MSPS } \end{aligned}$ | $\begin{aligned} & +5.0 \\ & \pm 5 \% \end{aligned}$ | 80 | TTL | DIP-16P-M04 | - |

DIGITAL-TO-ANALOG CONVERTERS

| MB4072 ${ }^{2}$ | 8 -bit High Speed Multiplying D/A Converter: High-Z open-collector outputs | 8 | $\pm 0.2$ | $\begin{aligned} & -10 \text { to }+18 \\ & \left(V_{S}= \pm 15 \mathrm{~V}\right) \end{aligned}$ | 150 ns | $\begin{aligned} & \pm 4.5 \\ & \text { to } \\ & \pm 18 \end{aligned}$ | $\begin{aligned} & \begin{array}{l} 3.8 \text { for } \\ \mathrm{V}_{\mathrm{s}}^{+}=15 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{s}}^{-7.8 ~ f o r ~} \\ -15 \mathrm{~V} \end{array} \end{aligned}$ | Any | $\begin{aligned} & \text { DIP-16C-C02 } \\ & \text { DIP-16P-M02 } \\ & \text { FPT-16P-M02 } \end{aligned}$ | DAC-08 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{r} \hline \text { MB40748-83 } \\ -93 \\ \hline \end{array}$ | 10-bit High Speed D/A Converter | 10 | $\begin{aligned} & \pm 0.2 \\ & \pm 0.1 \end{aligned}$ | 0 to -1 | $\begin{aligned} & 30 \\ & \text { MSPS } \end{aligned}$ | $\begin{aligned} & -5.2 \\ & \pm 5 \% \end{aligned}$ | -90 | $\begin{aligned} & 10 \mathrm{~K} \\ & \mathrm{ECL} \end{aligned}$ | DIP-24C-A01 | - |
| MB40776 ${ }^{3}$ | 6-bit High Speed D/A Converter: Suitable for digital TV | 6 | $\pm 0.8$ | $\begin{aligned} & V_{C C} \text { to } \\ & \left(V_{C C}-1\right) \end{aligned}$ | 20 MSPS | $\begin{aligned} & +5 \\ & \pm 5 \% \end{aligned}$ | 65 | TTL | DIP-16P-M04 | - |
| MB40778 ${ }^{3}$ | 8-bit High Speed D/A Converter: Suitable for digital TV | 8 | $\pm 0.2$ | $\begin{aligned} & V_{C C} \text { to } \\ & \left(V_{C C}-1\right) \end{aligned}$ | 30 <br> MSPS | $\begin{aligned} & +5 \\ & \pm 5 \% \end{aligned}$ | 75 | TTL | DIP-18P-M01 | - |
| MB407883 | 10-bit Ulitra High Speed D/A Converter: Pin compatible with MB40748 | 10 | $\pm 0.2$ | 0 to -1 | $\begin{aligned} & 125 \\ & \text { MSPS } \end{aligned}$ | $\begin{aligned} & -5.2 \\ & \pm 5 \% \end{aligned}$ | -135 | $\begin{aligned} & \hline 10 \mathrm{~K} \\ & \mathrm{ECL} \end{aligned}$ | DIP-24C-A01 | - |

Notes:

1. $T_{A}=-30^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
2. $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
3. $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

CMOS PERIPHERALS

## SOON TO BE AVAILABLE

## INTRODUCTION

The MB892xx series of CMOS peripherals are presently being developed with engineering samples already available on all of the devices. This CMOS family of peripherals is specifically aimed at reducing system power consumption. The advanced information provided in this document represents the functional design targets of Fujitsu, and may change without notice. For the most current parametric data and other technical information, the user should contact the nearest Fujitsu Sales Office-refer to the back of this Data Book.

## FUJITSU

## DMA CONTROLLER

## DESCRIPTION

The Fujitsu MB89237A Direct Memory Access (DMA) Controller performs memory-to-memory and memory-to-I/O data transmissions with virtually no control burden on the CPU. The device can handle up to four DMA channels and is functionally compatible with the Intel 8237A NMOS device. The MB89237A is fabricated in CMOS and is housed in a 40-pin plastic DIP. The MB89237 is an ideal choice for applications where minimum control overhead is required and data throughput is of primary importance.

PIN CONFIGURATION


Note:
This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

## BLOCK DIAGRAM



# SERIAL DATA TRANSMITTER/ RECEIVER 

## DESCRIPTION

The Fujitsu MB89251A Serial Data Transmitter/Receiver provides a duplex communications link between serial-data peripherals and the master processing system. The MB89251A supports both synchronous and asynchronous modes of operation and provides data transfer rates of up to 240K-bps. The MB89251A is fabricated in CMOS and is housed in a 28 -pin plastic DIP. The device is functionally compatible with the Intel 8251A NMOS device.

## PIN CONFIGURATION



## BLOCK DIAGRAM

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.


## DESCRIPTION

The Fujitsu MB89254 Programmable Timer provides three totally independent timer channels. The user can select one of six operating modes for each channel and a variety of output waveforms (pulse, squarewave, etc). Under program direction, the timer serves as a "special-effects" generator and can be used for flag control, special system-control functions, and other supervisory chores. The MB89254 is fabricated in CMOS and is housed in a 24 -pin plastic DIP. The device is functionally compatible with the Intel 8254 NMOS device.

## PIN CONFIGURATION



## BLOCK DIAGRAM



This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

## PARALLEL DATA I/O INTERFACE

## DESCRIPTION

The Fujitsu MB89255A Parallel Data I/O Interface provides an 8-bit bi-directional data-bus port and three 8-bit parallel I/O ports. Two of the I/O ports provide data transfers in byte segments whereas the other port is split with the upper and lower nibbles being transferred by separate busses. Thus, the MB89255A can be easily interfaced to hybrid 4-bit/8-bit systems. The user can choose either of three operating modes and can set or reset the state of each port bit. The MB89255A is fabricated in CMOS and is housed in a 40-pin plastic DIP. The device is functionally compatible with the Intel 8255A NMOS device.

PIN CONFIGURATION


## BLOCK DIAGRAM



[^45]
## FUJITSU

## INTERRUPT

 CONTROLLER
## DESCRIPTION

The Fujitsu MB89259A Interrupt Controller is capable of prioritizing eight interrupt inputs and, in a cascade configuration, up to 64 interrupts can be handled without excessive delay. Each interrupt input is identified by a programmed vector that corresponds to the active input. The user can program the device for edge or level triggering to activate the interrupt. The MB89259A is fabricated in CMOS and is housed in a 28 -pin plastic DIP. The device is functionally compatible with the Fujitsu MBL8259A NMOS device and the Intel 8259A NMOS device.

PIN CONFIGURATION


BLOCK DIAGRAM


[^46]
## FUJITSU

## ADDRESS LATCHES

## DESCRIPTION

Both the Fujitsu MB89282 and MB89283 are 8-bit address latches. The MB89282 provides non-inverted outputs and those of the MB89283 are inverted. The devices are fabricated in CMOS and are housed in a 20-pin plastic DIP. The address latches are functionally compatible with the Fujitsu bipolar MBL8282/MBL8283 devices and the Intel bipolar 8282/8283 devices.

PIN CONFIGURATIONS


These devices contain circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to these high impedance circuits.

## BLOCK DIAGRAMS



## DESCRIPTION

The Fujitsu MB89284A Clock Generator generates a system clock and provides ready and reset signals for the MBL8086, MBL8088, and MBL8089 microprocessors. The device is fabricated in CMOS and is housed in a 20-pin plastic DIP. The MB89284A is functionally compatible with the Fujitsu bipolar MBL8284A device and the Intel bipolar 8284A.

PIN CONFIGURATION


BLOCK DIAGRAM


This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

## DESCRIPTION

The Fujitsu MB89286/MB89287 Data Bus Transceivers serve as buffers between the local data bus of the processor and the system data bus. Outputs of the MB89286 are non-inverting whereas, for the MB89287, the outputs are inverted. Both devices are fabricated in CMOS and each is housed in a 20-pin plastic DIP. The bus transceivers are functionally compatible with the Fujitsu bipolar MBL8286/MBL8287 devices and the Intel bipolar 8286/8287 devices.

PIN CONFIGURATIONS


These devices contain circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to these high impedance circuits.

BLOCK DIAGRAMS


## MB89288



## DESCRIPTION

The Fujitsu MB89288 Bus Controller receives and decodes status signals from either of several microprocessors (MBL8086, MBL8088, MBL8089, MBL80186, or MBL80188) and provides command/control signals to memory and I/O devices. The MB89288 controller is fabricated in CMOS and is housed in a 20-pin plastic DIP. The MB89288 is functionally compatible with the Fujitsu bipolar MBL8288 bus controller and the Intel bipolar 8288 device.

## PIN CONFIGURATION



## BLOCK DIAGRAM



[^47]
## DESCRIPTION

The Fujitsu MB89289 Bus Arbiter is designed for use in multi-processor systems where conflicts of bus-access are likely to occur. When multiple bus masters request simultaneous access to the system bus, the MB89289 monitors these requests, assigns priorities, and grants access in an orderly manner. The MB89289 bus arbiter is fabricated in CMOS and is housed in a 20-pin plastic DIP. The MB89289 is functionally compatible with the Fujitsu bipolar MBL8289 arbiter and the Intel bipolar 8289 device.

PIN CONFIGURATION


## BLOCK DIAGRAM



This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

## Section 5



Local Area Network (LAN) Products

## FUJITSU

ETHERNET ENCODER/DECODER

## ETHERNET ENCODER/DECODER

The Fujitsu MB 502A is an Ethernet* Encoder/Decoder designed to meet all the requirements of the Ethernet Blue Book specification and fabricated with high-speed ECL and Schottky TTL technology.
The encoder converts serial binary data into complementary Manchester code. The decoder converts Manchester code into binary data and synchronous clock signals. The decoding method is a digital phase locked loop with dual bandwidth which allows both fast lock-on and a small amount of jitter. Typical acquisition is eight bits or better. A key feature of the decoder design is its capability to recover distorted input signals. The MB 502A is packaged in a 24-pin ceramic standard DIP.

## FEATURES

- Full Ethernet compatibility
- Manchester encode and decode
- Level conversion: transceiver level to/from TTL level
- Carrier detection
- Large distortion recovery: $\pm 20 \mathrm{~ns}$
- Dual bandwidth phase locked loop: allows fast acquisition
- Loopback "CONFIDENCE" test feature
- Built-in clock generator
- Small external parts count: all passive external components
- High-speed ECL and Schottky TTL technology
- Single power supply: +5 V
- Low power dissipation: 750mW typ.
- 24-pin standard Dual In-line Ceramic Package



[^48]Fig. 1 BLOCK DIAGRAM


PIN ASSIGNMENT TABLE

| Group | Pin Number | Symbol | Pin Name | I/O | Level | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Power Group | 12 | GND | Power supply | 1 |  | Ground |
|  | 24 | $\mathrm{V}_{\mathrm{cc}}$ |  | 1 |  | +5V DC power supply |
| Cable Group | $\begin{aligned} & 18 \\ & 19 \end{aligned}$ | RXDATA+ RXDATA- | Receive data pair | $1$ | ECL differential | Interfacing to receive pair of the transceiver cable. |
|  | $\begin{aligned} & 20 \\ & 21 \end{aligned}$ | TXDATA+ <br> TXDATA- | Transmit data pair | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | ECL differential | Interfacing to transmit pair of the transceiver cable. |
|  | $\begin{aligned} & 22 \\ & 23 \end{aligned}$ | $\begin{aligned} & \text { COL+ } \\ & \text { COL- } \end{aligned}$ | Collision presence pair | $1$ | ECL differential | Interfacing to collision presence pair of the transceiver cable. |
| EDLC <br> Group | 8 | TEN | Transmit encode enable | 1 | TTL | Input for encoding and TXDATA $\pm$ enable. |
|  | 9 | TXD | Transmit serial data | 1 | TTL | Input for transmit data to be encoded onto the Ethernet coax. |
|  | 10 | TCKN | Transmit data clock | 0 | TTL | Stable 10 MHz clock output for transmit bit stream. |
|  | 11 | RXD | Receive serial data | 0 | TTL | Output of received and decoded bit stream. |
|  | 13 | RCKN | Receive data clock | 0 | TTL | Clock output to strobe RXD. |
|  | 14 | XCOL | Collision presence | 0 | TTL | Duplication of the collision presence pair (COL $\pm$ ). |
|  | 15 | XCD | Receive carrier detect | 0 | TTL | Carrier detect function of the decoder. |
|  | 16 | LBC | Loopback command | 1 | TTL | Input to command the MB502A to operate in loopback mode. |
| Oscillator Group | $\begin{aligned} & \hline 4 \\ & 5 \\ & 6 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { OSC. OUT } \\ & \text { OSC. IN } \\ & \text { OSC. REF } \end{aligned}$ | Oscillator pins | $\begin{aligned} & 0 \\ & 1 \\ & 0 \end{aligned}$ | ECL | Pins for direct connection of discrete oscillator components. |
| Others | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{RC} \\ & \mathrm{C} \end{aligned}$ | Capacitor pins | - | $\overline{\mathrm{ECL}}$ | Pins for direct connection of a capacitor. |
|  | 3 | NC | Non-connection (PLL test) | 0 | ECL | Output pin for PLL testing purpose only. |
|  | 7 | $\overline{\text { RESET }}$ | FF test | 1 | TTL | Input pin to initialize flip-flops for testing purpose only. |
|  | 17 | $\overline{\text { DCLINK }}$ | DC/AC coupling select for transceiver pairs | 1 | TTL | Input to select DC/AC coupling of transceiver cable pairs. |

FUJITSU


## FUNCTIONAL DESCRIPTION

The MB 502A has five major functions; encode, decode, collision, master clock generation and loopback.

## ENCODE

The encoder section of the MB 502A is a simple circuit which performs an appropriate exclusive-OR between the transmit clock and transmit data using latches to reduce the skew of TXDATA $\pm$ outputs. The encoder sends the transmit clock (TCKN) to the Data Link controller. Then an encode enable signal (TEN) and data (TXD) are returned from the Data Link controller.

## DECODE

The decoder performs three functions. First, it decodes data using the differential receive inputs (RXDATA+ and RXDATA-) of the transceiver cable. Next is the carrier detect function. The carrier is derived from the receive inputs and passed to the Data Link controller from the XCD output. The last function is the stripping of the first several bits (eight bits maximum) of the packet. This is not a part of the Ethernet Physical Layer specification. The receive clock (RCKN) is actually inhibited for 6 or 7 clock cycles to allow the PLL (phase locked loop) to gain acquisition. This function was designed into the Encoder/Decoder because the EDLC (Ethernet Data Link Controller, MB 8795B) is a byte oriented device, and the function is more appropriately

## SIGNAL PIN DESCRIPTION

## CABLE GROUP

RXDATA $\pm$ (receive serial data pair, inputs)
These are the inputs to the decoder. They receive Manchester coded signals which the transceiver encounters on the Ethernet coax.
The input circuit is a differential receiver and can receive voltages of 0 to $\mathrm{V}_{\mathrm{cc}}$. The differential receiver has two operation modes; DC coupled operation and AC coupled operation, which are selected by DCLINK input.
In DC coupled operation ( $\overline{\text { DCLINK }}$ is low), the differential threshold is typically OV . The differential input voltage of more than 0.2 V is regarded as high level and the differential input voltage of less than -0.2 V is regarded as low level.
In AC coupled operation ( $\overline{\text { DCLINK }}$ is high), the differential threshold is typically -0.2 V . A differential input voltage of more than -0.05 V is regarded as high level and a differential input voltage of less than -0.4 V is regarded as low level.
The receiver circuit is designed to supply a high level to the decoder when RXDATA+ and RXDATA- are not receiving data but are just short-circuited through a transformer coil or left unconnected. However, when RXDATA $\pm$ are receiving data, the differential threshold is typically OV to minimize receiving distortion.
TXDATA $\pm$ (transmit data pair, outputs)
These are the outputs of the encoder. They transmit Manchester coded signals to the transceiver.
The driver output circuit is an emitter-follower and
provided in the Encoder/Decoder which is bit oriented.
The decoder PLL has excellent distortion handling capability. It is designed to recover $\pm 20 \mathrm{~ns}$ exercised.

## COLLISION

The collision detect inputs (COL+ and COL-) are simply converted to a TTL level signal (XCOL). The latching and timing functions for this signal are provided in the EDLC (MB 8795B).

## MASTER CLOCK GENERATION

The oscillator generates and supplies a 100 MHz master clock signal to the encoder and decoder.
Discrete oscillator components such as a crystal may be directly connected to the provided oscillator pins.
The oscillation frequency must be 100 MHz with a tolerance of less than $\pm 0.01 \%$ to meet the Ethernet specification because one tenth of the oscillation frequency is the transmit bit rate.

## LOOPBACK

A loopback input is provided to allow all encoding and decoding functions to be exercised without using the transceiver cable. During loopback operation, the encoded data is routed internally to the decoder, the transmit outputs are idle, and the receive and collision inputs are ignored.
requires a pull-down resistor ( $270 \Omega$ typ.). It can drive a transceiver cable differential impedance of $78 \Omega$.

The differential transmitter outputs (TXDATA+ and TXDATA-) also have the ability to emulate a transformer drive. This is actually implemented to reduce the current involved in a transformer termination of the transmit outputs in the transceiver which has a DC resistance of zero ohms. After the encoding function stops, the transmitter outputs gradually return to a $O V$ differential between the two output wires. The returning time is determined by an external capacitor
$\mathrm{COL} \pm$ (collision presence pair, inputs)
This pair of signals indicates the presence of a collision generated by the transceiver.
The input circuit is a differential receiver and can receive voltages of $O V$ to $V_{c c}$. The differential receiver has two operation modes; DC coupled operation and AC coupled operation, which are selected by $\overline{\text { DCLINK }}$ input.
In DC coupled operation ( $\overline{\text { DCLINK }}$ is low), the differential threshold is typically $0 V$. A differential input voltage of more than 0.2 V is regarded as high level and a differential input voltage of less than -0.2 V is regarded as low level.
In AC coupled operation ( $\overline{D C L I N K}$ is high), the differential threshold is typically -0.2 V . A differential input voltage of more than -0.05 V is regarded as high
level and a differential input voltage of less than -0.4 V is regarded as low level.
The receiver circuit is designed to supply a high level to the level converter when COL+ and COL- are not receiving data but are just short-circuited through a transformer coil or left unconnected.
Unlike RXDATA $\pm$, the differential threshold is set to -0.2 V even when COL $\pm$ are receiving data.

## EDLC GROUP

TEN (transmit encode enable, input)
This is an input to the on-chip Manchester encoder and enables TXDATA pair. Input high enables TXDATA pair; input low makes TXDATA pair idle (high).
TXD (transmit serial data, input)
This is an input to the on-chip Manchester encoder and provides data to be encoded.
Serial binary data must be supplied to this input synchronously with the falling edge of TCKN (transmit data clock).
This input is enabled when TEN (transmit encode enable) is high.

TCKN (transmit data clock, output)
10 MHz clock output for the transmit serial binary data. This is stable one-tenth of the master clock frequency. See TXD (transmit serial data) description.
RXD (receive serial data, output)
This is an output of the on-chip Manchester decoder and provides decoded data from Ethernet coax to a Data Link controller.
This output is synchronous with the falling edge of RCKN (receive data clock).
RCKN (receive data clock, output)
Clock output to strobe RXD (receive serial data). See RXD (receive serial data) description.
At the beginning of a packet, RCKN is inhibited for 6 or 7 clock cycles to allow the PLL to gain acquisition. And at the end of a packet, RCKN is inhibited for 1 clock cycle.
During idle state, this output generates a 10 MHz clock signal.
XCOL (collision presence, output)
This is a TTL duplication of the collision presence pair ( $C O L \pm$ ). The transceiver connected to Ethernet coax supplies a high level or differential voltage of OV to $\mathrm{COL} \pm$ when collision is not seen on the coax. It supplies a 10 MHz square wave signal to $\mathrm{COL} \pm$ when collision is detected. Accordingly, XCOL outputs high level when collision is not seen and outputs a 10 MHz square wave signal during collision presence.
XCD (receive carrier detect, output)
This output provides carrier detect function of the Manchester decoder. This signal is used by a Data Link controller receiver as a data acquisition enable signal and by a Data Link controller transmitter as transmition permission information.
Output is low when the Ethernet coax is idle.

## LBC (loopback command, input)

High level input to this pin dictates loopback mode operation. During the loopback mode operation, XCOL output is high level, TXDATA+ output is high level, RXDATA $\pm$ inputs are ignored
and the data supplied to TXD (transmit serial data) when TEN (transmit encode enable) is high is encoded, supplied to the Manchester decoder through the internal route and output from RXD (receive serial data), RCKN (receive data clock) and XCD (receive carrier detect).

## OSCILLATOR GROUP

OSC.OUT, OSC.IN AND OSC.REF (oscillator pins) A 100 MHz crystal is to be placed between OSC.IN and OSC.OUT.
An LC tank circuit is to be placed between OSC. IN and OSC.REF to assure start-up in the proper harmonic of the crystal.
OSC.OUT is an emitter-follower output and requires a pull-down resistor ( $330 \Omega$ typ.). A phase adjusting capacitor is to be placed in parallel with the pull-down resistor to make the delay through the oscillator close to 10 ns to increase the efficiency of the crystal.
As a design recommendation, connection wires should be as short as possible.

## OTHERS

RC and C (capacitor pins)
A capacitor placed between these pins provides the timing for the transformer emulation of the transmit pair.
In AC coupled operation ( $\overline{\text { DCLINK }}$ is high), after data transmission, TXDATA- goes high with rise time determined by the time-constant of the internal resistor and the connected capacitor. When a 470 pF capacitor is connected, the rise time of TXDATA- is typically $0.8 \mu \mathrm{~s}(20 \%$ to $80 \%)$.

Because pin C is connected to $\mathrm{V}_{\mathrm{cc}}$ on chip, DC voltage must never be supplied to this pin.
$\overline{D C L I N K}$ (DC/AC coupling select for transceiver pair)
This input is to select DC/AC coupling of transceiver cable pairs. Low level selects DC coupling. High level selects AC coupling and makes both TXDATA+ and TXDATA- high during idle state to prevent the transformer from saturation. See CABLE GROUP description.
This pin must be stuck at high or low level. It may be connected directly to $\mathrm{V}_{\mathrm{Cc}}$ or ground.
$\overline{\text { RESET ( }}$ (FF testing purpose only) This input pin is to initialize flip-flops for testing purposes only and must be connected to $\mathrm{V}_{\mathrm{cc}}$ or stuck at high level in a normal operation.
NC (non-connection)
This output pin is for testing purposes only and must be left open in a normal operation.

FUJITSU

## ABSOLUTE MAXIMUM RATINGS*

| Rating | Symbol | Value | Unit |
| :--- | :--- | :--- | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to 7.0 | V |
| TTL Level Input Voltage | $\mathrm{V}_{\text {ITTL }}$ | -0.3 to 7.0 | V |
| Receiver Input Voltage | $\mathrm{V}_{\text {IR }}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |
| Driver Output Voltage | $\mathrm{V}_{\mathrm{ODV}}$ | $\mathrm{V}_{\mathrm{CC}}(\mathrm{max})$ | V |
| Driver Output Current | $\mathrm{I}_{\mathrm{ODV}}$ | -40.0 to 0 | mA |
| Oscillator Input Voltage | $\mathrm{V}_{\text {IOSC }}$ | $\mathrm{V}_{\mathrm{CC}}-4$ to $\mathrm{V}_{\mathrm{CC}}$ <br> and more than -0.3 | V |
| Oscillator Output Current | $\mathrm{I}_{\mathrm{OOSC}}$ | -20.0 to 0 | mA |
| Operating Temperature | $\mathrm{T}_{\text {OP }}$ | -25 to 100 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -65 to 125 | ${ }^{\circ} \mathrm{C}$ |

* Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as destailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.


## RECOMMENDED OPERATING CONDITIONS

| Parameter |  | Symbol | Value | Operating Temperature |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage |  | $\mathrm{V}_{\mathrm{cc}}$ | $5.0 \mathrm{~V} \pm 5 \%$ | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| TTL High Level Output Current |  | $\mathrm{IOH}^{\text {I }}$ | -0.4 mA to 0 mA |  |
| TTL Low Level Output Current |  | $\mathrm{IOL}^{\text {l }}$ | 0 mA to 8 mA |  |
| Receiver Input Voltage |  | $V_{\text {IR }}$ | OV to $\mathrm{V}_{\mathrm{cc}}$ |  |
| Driver Terminator |  | $\mathrm{R}_{\text {LD }}$ | $270 \Omega$ |  |
| Differential Load |  | $\mathrm{R}_{\text {DLD }}$ | $78 \Omega$ |  |
| Oscillator Terminator |  | $\mathrm{R}_{\text {Losc }}$ | $330 \Omega$ and 33 pF parallel ${ }^{*}$ |  |
| Crystal for Oscillator |  | $\mathrm{f}_{\times \text {TAL }}$ | $100 \mathrm{MHz} \pm 0.01 \%^{* *}$ |  |
| Capacitor placed between C and RC pins |  | $\mathrm{C}_{\text {TX }}$ | 470pF |  |
| LC Tank Constant | Inductance | Losc | $0.15 \mu \mathrm{H}$ |  |
|  | Capacitance | Cosc | 33 pF * |  |

[^49]
## DC CHARACTERISTICS

(Recommended operating conditions unless otherwise noted.)

| Parameter | Symbol | Condition |  | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathrm{V}_{\mathrm{cc}}(\mathrm{V})$ | min. | typ. | max. |  |
| High Level Input Voltage ${ }^{* 1}$ | $\mathrm{V}_{1 \mathrm{H}}$ |  |  | 2.0 |  |  | V |
| Low Level Input Voltage ${ }^{1}$ | $V_{\text {IL }}$ |  |  |  |  | 0.8 | V |
| Input Clamp Voltage ${ }^{1}$ | $V_{\text {IC }}$ | $I_{1 L}=-18 m A$ | 4.75 | -1.5 |  |  | V |
| High Level Output Voltage ${ }^{\text {2 }}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | 4.75 | 2.7 |  |  | V |
| Low Level Output Voltage ${ }^{2}$ | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{IOL}^{\text {a }}=8 \mathrm{~mA}$ | 4.75 |  |  | 0.5 | V |
| High Level Input Current ${ }^{* 1}$ | $\mathrm{I}_{1 \mathrm{H}}$ | $\mathrm{V}_{1 \mathrm{H}}=2.7 \mathrm{~V}$ | 5.25 |  |  | 20 | $\mu \mathrm{A}$ |
| Low Level Input Current ${ }^{* 1}$ | IIL | $V_{1 L}=0.4 \mathrm{~V}$ | 5.25 | -100 |  |  | $\mu \mathrm{A}$ |
| Output Short Current ${ }^{*}$ | Ios | $\mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}$ | 5.25 | -100 |  | -20 | mA |
| High Level Differential Input Voltage ${ }^{*}$ | $V_{\text {IHD }}$ | $\frac{V_{I R+}-V_{1 R-}}{\text { DCLINK }=0 \mathrm{~V}}$ |  | 0.2 |  |  | V |
| Low Level Differential Input Voltage ${ }^{3}$ | $V_{\text {ILD }}$ | $\frac{V_{\text {IR }+}-V_{\text {IR }-}}{\text { DCLINK }}=0 \mathrm{~V}$ |  |  |  | -0.2 | V |
| High Level Differential Input Voltage ${ }^{*}{ }^{4}$ | $V_{\text {IHD }}$ | $\begin{aligned} & V_{\text {IR }+}-V_{1 R-} \\ & \text { DCLINK }=4.5 \mathrm{~V} \end{aligned}$ |  | -0.05 |  |  | V |
| Low Level Differential Input Voltage ${ }^{*}$ | $V_{\text {ILD }}$ | $\begin{aligned} & V_{1 \mathrm{R}+}-V_{1 \mathrm{R}-} \\ & \text { DCLINK }=4.5 \mathrm{~V} \end{aligned}$ |  |  |  | -0.4 | V |
| High Level Differential Input Voltage ${ }^{* 5}$ | $V_{\text {IHD }}$ | $\begin{aligned} & V_{\text {IR }+}-V_{1 R-} \\ & \text { DCLINK }=4.5 \mathrm{~V} \end{aligned}$ |  | 0.2 |  |  | V |
| Low Level Differential Input Voltage ${ }^{* 5}$ | VILD | $\begin{aligned} & V_{1 R+}-V_{1 R-} \\ & \text { DCLINK }=4.5 \mathrm{~V} \end{aligned}$ |  |  |  | -0.2 | V |
| High Level Input Current ${ }^{*}{ }^{3}$ | $\mathrm{I}_{1} \mathrm{HR}$ | $\begin{aligned} & V_{\mathrm{IR}}=5.25 \mathrm{~V} \\ & \text { DCLINK }=0 \mathrm{~V} \end{aligned}$ | 5.25 |  |  | 0.7 | mA |
| Low Level Input Current ${ }^{* 3}$ | ! iLf | $\begin{aligned} & \mathrm{V}_{\mathrm{IR}}=0 \mathrm{~V} \\ & \overline{\text { DCLINK }}=0 \mathrm{~V} \end{aligned}$ | 5.25 | -1.5 |  |  | mA |

Note: 1: Applicable to TTL input pins. (TEN, TXD, LBC, $\overline{\text { DCLINK }}$ and $\overline{\text { RESET }})$
2: Applicable to TTL output pins. (TCKN, RXD, RCKN, XCOL and XCD)
3: Applicable to COL $\pm$ and RXDATA $\pm$.
4: Applicable to RXDATA $\pm$ while XCD output is low (idle state) and COL $\pm$.
5: Applicable to RXDATA $\pm$ while XCD output is high.

## DC CHARACTERISTICS (Cont’d)

(Recommended operating conditions unless otherwise noted.)

| Parameter | Symbol | Condition |  | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathrm{V}_{\mathrm{cc}}(\mathrm{V})$ | min. | typ. | max. |  |
| High Level Output Voltage *1 | $\mathrm{V}_{\text {OHTX }}$ |  | 5.0 |  | 4.1 |  | V |
| Low Level Output Voltage*1 | V OLTX |  | 5.0 |  | 3.3 |  | V |
| High Level Differential Output Voltage *1 | $\mathrm{V}_{\text {OHD }}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{O}+}-\mathrm{V}_{\mathrm{O-}} \\ & \text { DCLINK } \end{aligned}$ |  | 0.55 |  | 1.0 | V |
| Low Level Differential Output Voltage *1 | V OLD | $\frac{\mathrm{V}_{\mathrm{O+}}-\mathrm{V}_{\mathrm{O}--}}{\text { DCLINK }}=0 \mathrm{~V}$ |  | -1.0 |  | -0.55 | V |
| Oscillator Reference Voltage*2 | $V_{B B}$ |  | 5.0 |  | 3.7 |  | V |
| High Level Input Current*3 | $\mathrm{I}_{\mathrm{IHO}}$ | $\mathrm{V}_{1 H}=4.1 \mathrm{~V}$ | 5.0 |  |  | 150 | $\mu \mathrm{A}$ |
| High Level Output Voltage*4 | $\mathrm{V}_{\text {оно }}$ | OSC.IN is open | 5.0 |  | 4.15 |  | V |
| Low Level Output Voltage *4 | Volo | $\mathrm{V}_{\text {Iosc }}=4.1 \mathrm{~V}$ | 5.0 |  | 3.3 |  | V |
| RC Internal Resistor | $\mathrm{R}_{\text {RC }}$ | $\mathrm{V}_{\mathrm{RC}}=0.5 \mathrm{~V}$ | 0.5 | 25 | 50 | 100 | k $\Omega$ |
| Power Supply Current | $I_{\text {cc }}$ | All signal pins are open. | 5.25 |  |  | 220 | mA |

Note: 1: Applicable to TXDATA $\pm$.
These pins are connected to ground through $270 \Omega$ resistor. And $78 \Omega$ resistor is placed between these pins.
2: Applicable to OSC.REF.
3: Applicable to OSC.IN.
4: Applicable to OSC.OUT.
This pin is connected to ground through a $330 \Omega$ resistor.

## AC CHARACTERISTICS

## TRANSMIT TIMING

(Recommended operating conditions unless otherwise noted. $\mathbf{v}_{\mathbf{C C}}=5.0 \mathrm{~V}$ )

| Parameter | Symbol | Condition |  | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Fig. | min. | typ. | max. |  |
| TCKN Cycle Time | $\mathrm{t}_{\mathrm{ct} \text { TC }}$ |  | 2,3 | 99.99 | 100.00 | 100.01 | ns |
| TCKN Low Time | $t_{\text {wLTC }}$ |  | 2,3 | 40 | 50 |  | ns |
| TCKN High Time | $\mathrm{t}_{\text {wHTC }}$ |  | 2, 3 | 40 | 50 |  | ns |
| TXDATA $\pm$ Encode Time | $\mathrm{t}_{\mathrm{pd} \text { d }} \mathrm{X}$ |  | 2,3 5,6 |  | 95 |  | ns |
| TXDATA $\pm$ Output Rise Time | $\mathrm{trTX}_{\text {r }}$ |  | 5,6 |  | 2.0 |  | ns |
| TADATA $\pm$ Output Fall Time | $\mathrm{t}_{\text {fTX }}$ |  | 5,6 |  | 2.0 |  | ns |
| TXDATA-Low Level Hold Time | ${ }_{\text {t LTX }}$ | $\begin{aligned} & C_{T X}=470 \mathrm{pF} \\ & \text { DCLINK }=V_{\mathrm{Cc}} \end{aligned}$ | 5,6 |  | 3 |  | $\mu \mathrm{s}$ |
| TXDATA- Idling Rise Time | $t_{\text {ritx }}$ | $\begin{aligned} & \mathrm{C}_{\mathrm{TX}}=470 \mathrm{pF} \\ & (20 \% \sim 80 \%) \\ & \hline \text { DCLINK }=\mathrm{V}_{\mathrm{Cc}} \end{aligned}$ | 5,6 |  | 0.8 |  | $\mu \mathrm{s}$ |
| TXD, TEN Setup Time | $\mathrm{t}_{\text {suT }} \times$ |  | 4 | 20 |  |  | ns |
| TXD, TEN Hold Time | $t_{\text {hd }}$ ( ${ }^{\text {a }}$ |  | 4 | 0 |  |  | ns |



FUJITSU
K|x W|x
MB 502A

## AC CHARACTERISTICS (Cont'd)

## RECEIVE TIMING

(Recommended operating conditions unless otherwise noted. $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}$ )

| Parameter | Symbol | Condition |  | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Fig. | min. | typ. | max. |  |
| RCKN Cycle Time in Idle | $\mathrm{t}_{\mathrm{ctRC}}$ |  | 2,3 | 99.99 | 100.00 | 100.01 | ns |
| RCKN Low Time | $t_{\text {wLRC }}$ |  | 2,3 | 35 | 50 |  | ns |
| RCKN High Time | $\mathrm{t}_{\mathrm{wHRC}}$ |  | 2,3 | 35 | 50 |  | ns |
| RCKN Delay Time | $\mathrm{t}_{\text {pHLRC }}$ |  | 2,3,7 |  | 120 |  | ns |
| XCD ON Delay Time | $\mathrm{t}_{\mathrm{pLHCD}}$ |  | 2,3,7 |  | 80 | 110 | ns |
| XCD OFF Delay Time | $\mathrm{t}_{\mathrm{pHLCD}}$ |  | 2,3,7 |  | 230 |  | ns |
| XCD Low Hold Time | $t_{\text {hd LCD }}$ |  | 2,3 | 0 | 10 |  | ns |
| XCD High Hold Time | $t_{\text {hd }}{ }_{\text {HCD }}$ |  | 2,3 |  | 120 |  | ns |
| XCD Low Setup Time | $\mathrm{t}_{\text {suLCD }}$ |  | 2, 3 |  | 80 |  | ns |
| RXD Setup Time | $t_{\text {suRXD }}$ |  | 2, 3 | 20 | 60 |  | ns |
| RXD Hold Time | $t_{\text {hdR }}$ XD |  | 2, 3 | 10 | 20 |  | ns |

## RECEIVE TIMING DIAGRAM



Note: _-_ Threshold manipulation in AC coupled operation

FUJITSU

## AC CHARACTERISTICS (Cont'd)

## RECEIVE TIMING DIAGRAM (Cont'd)



## AC CHARACTERISTICS (Cont'd)

Loopback timing
(Recommended operating conditions unless otherwise noted. $\mathrm{V}_{\mathbf{c c}}=5.0 \mathrm{~V}$ )

| Parameter | Symbol | Condition |  | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Fig. | min . | typ. | max. |  |
| LBC Receiving Data Purge Time | $\mathrm{t}_{\mathrm{pgLBC}}$ |  | 2, 3, 4 |  | 230 |  | ns |
| LBC Receiving Data Accept Time | tacLBC |  | 2, 3, 4 |  | 80 |  | ns |
| DATA Through Time | $\mathrm{t}_{\text {pHLTRU }}$ |  | 2, 3, 4 |  | 280 |  | ns |
| TEN Wait Time | $t_{\text {wtEN }}$ |  | 2, 3, 4 | 0 |  |  | ns |

In Loopback mode operation, COL $\pm$ and RXDATA $\pm$ inputs are ignored, TXDATA + and XCOL are high level and XCD, RCKN and RXD functions are in the same manner as a normal receive operation.


## AC CHARACTERISTICS (Cont'd)

COLLISION TIMING
(Recommended operating conditions unless otherwise noted. $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}$ )

| Parameter | Symbol | Condition |  | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Fig. | min. | typ. | max. |  |
| COL to XCOL <br> Propagation Delay Time | $t_{\text {pLH }}$ | $\overline{\text { DCLINK }}=0 \mathrm{~V}$ | 2,3,7 |  | 9 | 30 | ns |
| COL to XCOL <br> Propagation Délay Time | $\mathrm{t}_{\mathrm{pHL}}$ | $\overline{\text { DCLINK }}=0 \mathrm{~V}$ | 2,3,7 |  | 11 | 30 | ns |

COLLISION TIMING DIAGRAM

## AC CHARACTERISTICS (Cont'd)

AC TEST CONDITIONS

Fig. 2 TTL OUTPUT LOAD CIRCUIT


Fig. 3 TTL OUTPUT WAVEFORM


Threshold voltage $=1.5 \mathrm{~V}$

Fig. 4 TTL INPUT WAVEFORM


$$
\begin{aligned}
& V_{I H}=3 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{~L}}=0 \mathrm{~V} \\
& \mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=10 \mathrm{~ns} \\
& \text { Threshold voltage }=1.5 \mathrm{~V}
\end{aligned}
$$

## AC CHARACTERISTICS (Cont'd)

## AC TEST CONDITIONS (Cont'd)

Fig. 5 TXDATA $\pm$ OUTPUT LOAD CIRCUIT


Fig. 6 TXDATA $\pm$ OUTPUT WAVEFORM


Fig. 7 RXDATA+, COL+ INPUT WAVEFORM

$V_{1 H}=3.5 \mathrm{~V}, V_{I L}=1.5 \mathrm{~V}$
$t_{r}=t_{f}=2.0 \mathrm{~ns}$
RXDATA-, COL- Input voltage $=2.5 \mathrm{~V}(\mathrm{DC})$
$\overline{\text { DCLINK }}=0 \mathrm{~V}$ (DC coupling)

## TYPICAL CHARACTERISTICS CURVES

Fig. 8
TXDATA $\pm$


Fig. 10
TTL-OUTPUT
High Level Output Current vs. High Level Output Voltage


Fig. 12


Fig. 9
RXDATA $\pm$, COL $\pm$
Input Current vs. Input Voltage


Fig. 11
TTL-OUTPUT
Low Level Output Current vs. Low Level Output Voltage


Fig. 13
OSC.IN
Input Current vs. Input Voltage


Fig. 14
COL $\pm$ to XCOL TRANSFER (Receiver Threshold) Output Voltage vs. Differential Input Voltage


Fig. 16
TTL-INPUT THRESHOLD
TTL Input Threshold vs. Power Supply Voltage


Fig. 18
TXDATA- LOW LEVEL HOLD TIME
TXDATA- Low Level Hold Time
TXDATA- Idling Rise Time
vs. RC Capacitance


Fig. 15
COL $\pm$ to XCOL TRANSFER (Receiver Threshold) Output Voltage vs. Differential Input Voltage


Fig. 17
RC to TXDATA- TRANSFER
Output Voltage vs. RC Input Voltage


Fig. 19
COL $\pm$ to XCOL PROPAGATION DELAY TIME Propagation Delay Time vs.


## APPLICATION INFORMATION

Fig. 20 TYPICAL APPLICATION CIRCUIT


Note: $39 \Omega$ resistors must be balanced less than $1 \%$.

Fig. 21 TYPICAL COMPONENT LAYOUT


## PACKAGE DIMENSIONS



## MB8795B

Ethernet Data Link Controller

## Description

The Fujitsu MB8795B Ethernet Data Link Controller (EDLC) manufactured with Fujitsu's Advanced CMOS Technology, is designed for Ethernet* Local Area Network Systems and to be used with Fujitsu's MB502A Ethernet Encoder/Decoder (EED).

The MB8795B EDLC provides the user with a low power implementation of the Data Link Layer of the Ethernet Blue Book Specification. High throughput is possible via the separate data ports, while low cost implementations are also possible by tying the ports together.

The host system communicates with the MB8795B EDLC using the command and status registers accessed through the control port. Functions provided include complete transmit and receive control, and interrupt masking.

- Implementing Ethernet Blue Book Specification
- Function to generate and remove preamble and CRC
- Conversion between serial and parallel Data
- Four modes of address recognition
Accept no packet, Physical Address/Multicast-group Address/Broadcast Address, Physical Address/Multicast Address, Accept all packets
- Random exponential backoff to recover from collisions
- Three separate data ports providing flexible interface; Transmit, Receive, Control Ports
- Optional parity check on transmit byte stream
- Odd parity generated for receive byte stream
- Low power, advanced silicon gate CMOS technology
- Space saving 64 -pin pin grid array package

Note: *Ethernet is a trademark of Xerox Corp.


## MB8795B

Block Diagram


## Pin Assignment



## Pin Assignment

(Continued)

| PIN <br> No. | 110 | Pin Name | PIN No. | $1 / 0$ | Pin Name | PIN No. | $1 / 0$ | Pin Name | PIN No. | $1 / 0$ | Pin Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | TEM | 17 | I | $\overline{\text { WRC }}$ | 33 | 1 | TD2 | 49 | 1/O | IOD6 |
| 2 | O | RRDY | 18 | 1 | WRB | 34 | 1 | TD0 | 50 | 1 | RDA |
| 3 | 1 | RSTB | 19 | 1 | $\overline{C E}$ | 35 | 0 | TPOK | 51 | 1 | RDB |
| 4 | 0 | RD0 | 20 | 1 | WRA | 36 | 1 | TSTB | 52 | 1 | RDC |
| 5 | O | RD2 | 21 | 0 | TINT | 37 | 0 | RDIS | 53 | 1 | RST |
| 6 | 0 | RD3 | 22 | 0 | RINT | 38 | 1 | ROEN | 54 | $\mathrm{V}_{\text {SS }}$ | GND |
| 7 | 0 | RD5 | 23 | 0 | PRST | 39 | 0 | RD1 | 55 | 1 | RCKN |
| 8 | 0 | RD7 | 24 | O | TM | 40 | $\mathrm{V}_{\text {SS }}$ | GND | 56 | 1 | XCOL |
| 9 | O | RPAR | 25 | 1 | RXD | 41 | 0 | RD4 | 57 | 1 | XCD |
| 10 | 1 | SA1 | 26 | 1 | TCKN | 42 | 0 | RD6 | 58 | O | LBC |
| 11 | 1 | SA3 | 27 | 0 | TXD | 43 | 0 | REOF | 59 | 1 | TEOF |
| 12 | 1/0 | IOD0 | 28 | 0 | TEN | 44 | 1 | SAO | 60 | 1 | TD6 |
| 13 | I/O | IOD2 | 29 | 1 | TPAR | 45 | 1 | SA2 | 61 | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| 14 | I/O | IOD3 | 30 | 1 | TD7 | 46 | I/O | IOD1 | 62 | 1 | TD3 |
| 15 | I/O | IOD5 | 31 | 1 | TD5 | 47 | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{CC}}$ | 63 | 1 | TD1 |
| 16 | 1/O | IOD7 | 32 | 1 | TD4 | 48 | I/O | IOD4 | 64 | 0 | TRET |

## Absolute Maximum Ratings

|  |  | Value |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Rating | Symbol | Min. | Max. | Unit |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{GND}-0.3^{*} 7.0$ | V |  |
| Input and Output Voltage | $\mathrm{V}_{1}, \mathrm{~V}_{\mathrm{OUT}}$ | $\mathrm{GND}-0.3^{*}$ | $\mathrm{~V}_{\mathrm{CC}}+0.3^{*}$ | V |
| Storage Temperature | $\mathrm{T}_{\mathrm{STG}}$ | -55 | 150 | ${ }^{\circ} \mathrm{C}$ |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |

Note: *0.3 V is for stable state. For transit state, 0.5 V is allowed. ( 20 to 30 nsec .)

Note: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet.

## Capacitance

$\underset{f=1}{\substack{T_{A} \\ f=1 \\ M H Z}}$

|  |  | Value |  |  |
| :--- | :--- | :--- | :--- | :--- |
| Parameter | Symbol | Min. | Typ. | Max. |
| Unit |  |  |  |  |
| Input Capacitance | $\mathrm{C}_{I N}$ |  | 8 | pF |
| Output Capacitance | $\mathrm{C}_{\mathrm{OUT}}$ |  | 8 | pF |
| Bus Capacitance | $\mathrm{C}_{1 / \mathrm{O}}$ |  | 12 | pF |

## Recommended

 Operating Conditions|  |  | Value |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5.0 | 5.5 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

## DC Characteristics

|  |  | Value |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| Power Supply Current <br> (For Stable State; $\left.\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{IL}}=\mathrm{GND}\right)$ | $\mathrm{I}_{\mathrm{CC}}$ | 0 | 0.1 | mA |  |
| Output High Voltage $\left(\mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | 4.0 | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| Output Low Voltage $\left(\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}\right)$ | $\mathrm{V}_{\mathrm{OL}}$ | GND | 0.4 | V |  |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.2 |  | V |  |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ |  | 0.8 | V |  |
| Input Leakage Current $\left(\mathrm{V}_{\mathrm{I}}=0 \mathrm{~V}\right.$ to $\left.\mathrm{V}_{\mathrm{CC}}\right)$ | $\mathrm{I}_{\mathrm{LI}}$ | -10 | 10 | $\mu \mathrm{~A}$ |  |
| Input Leakage Current for Bus Pins <br> $\left(\mathrm{V}_{1}=0 \mathrm{~V}\right.$ to $\left.\mathrm{V}_{\mathrm{CC}}\right)$ | $\mathrm{I}_{\mathrm{LZ}}$ | -40 | 40 | $\mu \mathrm{~A}$ |  |

## AC Characteristics

## Control Register Read Timing

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |
| Read Pulse Width | $\mathrm{t}_{\mathrm{RW}}$ | 35 |  |  | ns |
| Read Address Pulse Width | $\mathrm{t}_{\text {RAW }}$ | 35 |  |  | ns |
| Read Access Time ( $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ ) | $\mathrm{t}_{\mathrm{RA}}$ |  |  | 110 | ns |
| Read Address Access Time ( $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ ) | $t_{\text {RAA }}$ |  |  | 150 | ns |
| Read Turn-off Delay Time ( $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ ) | $t_{\text {Rz }}$ | 10 |  |  | ns |
| Read Address Turn-off Delay Time $\left(\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}\right)$ | $t_{\text {RAZ }}$ | 20 |  |  | ns |
| Address Register Read Access Time ( $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ ) | $t_{\text {ARRA }}$ |  |  | 300 | ns |
| Address Register Read Address Turn-off Delay Time ( $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ ) | $t_{\text {ARRAZ }}$ | 20 |  |  | ns |
| Address Register Read Address Setup Time | $t_{\text {ARRAS }}$ | 15 |  |  | ns |
| Address Register Read Address Hold Time | $t_{\text {ARRAH }}$ | 90 |  |  | ns |

Control Register Write Timing

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |
| Write Pulse Width | ${ }^{\text {tww }}$ | 35 |  |  | ns |
| Write Address Set-up Time | ${ }^{\text {w was }}$ | 30 |  |  | ns |
| Write Data Set-up Time | twos | 15 |  |  | ns |
| Write Address Hold Time | ${ }_{\text {twah }}$ | 40 |  |  | ns |
| Write Data Hold Time | $\mathrm{t}_{\text {WDH }}$ | 80 |  |  | ns |
| Test Pin Delay Time ( $\mathrm{CL}=50 \mathrm{pF}$ ) | ${ }_{\text {t }}$ |  |  | 150 | ns |
| Transmit Status Register Reset Delay Time ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | ${ }_{\text {t }}^{\text {TS }}$ |  |  | 150 | ns |
| Receive Status Register Reset Delay Time $\left(\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\right)$ | $t_{\text {RS }}$ |  |  | 150 | ns |
| Reset Register Reset Delay Time $\left(\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\right)$ | $\mathrm{t}_{\mathrm{R}}$ |  |  | 220 | ns |

## AC Characteristics

 (Continued)
## Transmit Timing

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |
| TSTB Pulse Width TCKN Pulse Width TCKN Frequency | ${ }^{\text {t }}$ tstBW ttcknw $f_{\text {TCKN }}$ | $\begin{aligned} & 35 \\ & 35 \end{aligned}$ |  | 10.2 | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \\ & \mathrm{MHz} \end{aligned}$ |
| Transmit Data Set-up Time Transmit Data Hold Time | $\begin{aligned} & \mathrm{t}_{\mathrm{TDS}} \\ & \mathrm{t}_{\text {TDH }} \\ & \hline \end{aligned}$ | $\begin{aligned} & 20 \\ & 25 \end{aligned}$ |  |  | ns ns |
| $\overline{\text { TEM }}$ Delay Time High ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {TEM }}$ |  |  | 100 | ns |
| TEM Delay Time Low ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | ${ }_{\text {tem }}$ |  |  | 150 | ns |
| TEM Delay Time Low (Sync.) ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {TEMLS }}$ |  |  | 170 | ns |
| TEN Delay Time ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {TEN }}$ |  |  | 55 | ns |
| TXD Delay Time ( $\mathrm{C}_{L}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {TXD }}$ |  |  | 70 | ns |
| TPOK Delay Time ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {TPOK }}$ |  |  | 150 | ns |
| TRET Delay Time ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | ${ }_{t}^{\text {tret }}$ |  |  | 140 | ns |
| TINT Delay Time (Transmit) ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {TINTT }}$ |  |  | 160 | ns |

Receive Timing

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |
| RCKN Pulse Width RCKN Frequency | ${ }_{\text {t }}^{\text {RCKNW }}$ ( | 35 |  | 10.2 | ns <br> MHz |
| RSTB Pulse Width | fRCKN $\mathrm{t}_{\mathrm{RSTBW}}$ | 35 |  | 10.2 |  |
| ROEN Pulse Width | $\mathrm{t}_{\text {ROENW }}$ | 35 |  |  | ns |
| Receive Data Set-up Time | $\mathrm{t}_{\text {RDS }}$ | 20 |  |  | ns |
| Receive Data Hold Time | $\mathrm{t}_{\text {RDH }}$ | 10 |  |  | ns |
| RRDY Delay Time High (Sync.) ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $t_{\text {RRDYHS }}$ |  |  | 650 | ns |
| Receive Data Delay Time (Sync.) ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {RDDS }}$ |  |  | 650 | ns |
| RRDY Delay Time High ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {RRDYH }}$ |  |  | 100 | ns |
| RRDY Delay Time Low ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {RRDYL }}$ |  |  | 65 | ns |
| Receive Data Delay Time ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {RD }}$ | 10 |  | 100 | ns |
| ROEN Access Time ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {RoENA }}$ |  |  | 80 | ns |
| ROEN Turn-off Delay Time ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $t_{\text {Roenz }}$ | 10 |  |  | ns |
| RDIS Delay Time ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {RDIS }}$ |  |  | 120 | ns |
| PRST Delay Time ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {PRST }}$ |  |  | 120 | ns |
| RINT Delay Time ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $t_{\text {RINT }}$ |  |  | 160 | ns |
| TINT Delay Time (Rcv) ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) | $\mathrm{t}_{\text {TINTR }}$ |  |  | 190 | ns |

Timing Diagram
Control Register Read
Registers 0~7, F


Address Registers 8~D


## Control Register Write



## Timing Diagram

 (Continued)

Timing Diagram
Timing Dia
(Continued)
Receive


XXX

Timing Diagram
(Continued)
Receive (Continued)


## Functional Description

The MB8795B EDLC is designed as two distinct sections, a transmitter and a receiver. Each section provides a small amount of asynchronous buffering, provisions for byte parity (which can be ignored), preamble generation/stripping, CRC generation/checking, and conversion between serial and parallel data. In addition, the transmitter provides contention resolution by means of binary exponential backoff. Finally, the receiver provides various modes of address recognition.

## Transmitter

The block diagram on page 2 shows the various functions the transmitter performs.

## Asynchronous FIFO

A two-byte FIFO provides a minimum amount of elastic buffering for the transmit byte data. Two signals are used for the byte controls. The first signal, TEM, indicates that the input register is full. The second signal, TSTB, is the input register data strobe. On the rising edge of this strobe input, the eight data bits, the parity bit and the 'end of frame' (TEOF) bit are latched into the input register. Strobes are ignored while the register is full.
The TRET signal indicates that a collision has occurred and that the packet in progress should be restarted. The buffer management would typically flush any buffers and reset its pointers to the beginning of the packet. Note that on the block diagram the asynchronous FIFO is cleared by this signal.

The TPOK signal indicates that successful transmission of the packet has been completed and the transmitter is ready for the next packet. This signal goes high when transmission of the packet is complete.

Note: The TPOK signal remains low long enough after the last byte is strobed into the FIFO, so the FIFO can be emptied and the CRC appended. Therefore the buffer management must remain
prepared to reset its pointers in the case of a late collision.

## Transmit Parallel/Serial Conversion

This section has a shift register for parallel to serial data conversion, a preamble generator, and a sychronization circuit for the collision and carrier detect signals. Also included is the optional 'ODD' parity check that is performed on the byte data supplied to the CRC generator. The parity check provides added security against internal chip failures due to undetected bad data transmissions.

## Transmit CRC

The 32-bit CRC generator as defined in the Ethernet Specification.

## Backoff

A pseudo-random number generator (17-bits), clocked at the bit rate so that distances between stations becomes part of the randomizing function, is sampled at the time of collision and counted down at the slot-time rate (512-bits) defined in the Ethernet specification, which provides a binary exponential backoff from collisions.

## Transmitter State Machine

The state machine provides the major sequencing of events for the transmitter including idle, preamble, data, CRC, interframe gap, jam, and backoff. It also provides indicators for various error conditions.

## Receiver

Refer to the block diagram for the relation of the sections. (See page 2).

## Asynchronous FIFO

A six byte FIFO is provided so that when in diagnostic mode a minimum size packet ( 6 byte destination address and 4 byte CRC) can be received even in systems where the buffer management is half duplex. The data, parity and 'end of frame' bit are tri-stated with signal ROEN, a low true enable. The 'receive byte
ready' (RRDY) indicates a byte is available to the host system. RSTB is a low true clock whose falling edge causes RRDY to be false and whose rising edge causes the data in the register to be removed. See the timing charts for further clarification.

## CRC Trap

All received bytes are delayed by four bytes so that the last bytes of the received packet (CRC) can be removed. After four bytes are received the trap will put one byte into the asynchronous FIFO for each subsequent byte received, thereby always maintaining four bytes in the trap. At the 'end of frame' the four bytes in the trap are the CRC and they are never put into the asynchronous FIFO.

## Receive Serial/Parallel Conversion

This section has a shift register for data serial to parallel conversion, a circuit to recognize the end of preamble, and an odd parity check circuit.

## Receive CRC

The 32-bit CRC checking register and comparison logic as described in the Ethernet specification.

## 6 Byte Address RAM

A 48-bit storage RAM used for comparing with the Destination Address Field of the incoming packets (the first 48 bits after the preamble).

## Receiver State Machine

The state machine provides the major sequencing through the receiver states including idle, address recognition, data, and holding as a discarded packet completes. It also provides indicators of various error conditions.

Functional Description
(Continued)

## Command/Status/Interrupt

This section has fifteen registers, a register address decoder, and gating for interrupt conditions. Each register is one byte length. The host system communicates with the MB8795B EDLC using these registers accessed through the control port.

Interrupt conditions are defined by setting the registers of Transmit Marks and Receive Masks.

## Register Description

The Register in the MB8795B EDLC can be accessed via the control port with their address assigned by the signals

SAO-3. (SAO represents the LSB of the address.) The address signals SA0-3 are activated by both the chip enable signal CE and, write signals WRA, WRB, WRC, or, read signals RDA, RDB, RDC. A brief description of each register is given in the table below.

## Register Description

| 0 |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | XMIT STAT | RD | $\begin{aligned} & \hline \text { RDY } \\ & \text { For } \\ & \text { PKT } \end{aligned}$ | NET BUSY | XMIT RECVD | SHORTED | UNDERFLOW | COLL | $\begin{aligned} & 16 \\ & \mathrm{COLL} \end{aligned}$ | PAR ERR |
|  |  | WR | - | - | - | - | CLR UNDERFLOW | $\begin{aligned} & \text { CLR } \\ & \text { COLL } \end{aligned}$ | $\begin{aligned} & \text { CLR } \\ & 16 \\ & \text { COLL } \end{aligned}$ | $\begin{aligned} & \text { CLR } \\ & \text { PAR } \\ & \text { ERR } \end{aligned}$ |
| 1 | XMIT MASKS | RD/WR | MASK STATUS 7 |  | MASK STATUS 5 | - | MASK STATUS 3 | MASK STATUS 2 | MASK STATUS 1 | MASK STATUS 0 |
| 2 | REC STATU | RDWR | $\begin{aligned} & \text { PKT } \\ & \text { OK } \end{aligned}$ | - | - | RESET PKT | SHORT PKT | ALIGN ERR | CRC ERR | OVER- <br> FLOW <br> ERR |
|  |  |  | $\begin{aligned} & \text { CLR } \\ & \text { PKT } \end{aligned}$ | - | - | - | $\begin{aligned} & \text { CLR } \\ & \text { ERR } \end{aligned}$ | $\begin{aligned} & \text { CLR } \\ & \text { ERR } \end{aligned}$ | $\begin{aligned} & \text { CLR } \\ & \text { ERR } \end{aligned}$ | $\begin{aligned} & \text { CLR } \\ & \text { ERR } \end{aligned}$ |
| 3 | REC MASKS | RD/WR | MASK STATUS 7 |  | - | MASK STATUS 4 | MASK STATUS 3 | MASK STATUS 2 | MASK STATUS 1 | MASK STATUS 0 |
| 4 | TMODE + COLL ATTEMPT | RD/WR | 3 | 2 | 1 | 0 | IGNORE PARITY | TM | LBC | DIS- <br> ABLE CONTNT |
|  | Collision Attempts, Read Only |  |  |  |  |  |  |  |  |  |
| 5 | RMODE | RD/WR | TST | - | - | $\begin{aligned} & \text { ADD } \\ & \text { SIZE } \end{aligned}$ | $\begin{aligned} & \text { ENA } \\ & \text { SHORT } \\ & \text { PKT } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ENA } \\ & \text { RST } \end{aligned}$ | ADD ENA1 | ADD ENAO |
| 6 | RESET | Write Only | RESET | - | - | - | - | - | - | - |
| 7 | TDR1 | Read Only | TDR7 | TDR6 | TDR5 | TDR4 | TDR3 | TDR2 | TDR1 | TDR0 |



## Register Description

(Continued)

## Transmit Status-Address $\mathbf{0 0 H}$ <br> This register indicates the status of the transmitter.

## Bit 7

Read-Ready for Packet-A copy of the Transmit Packet Successful (TPOK) signal pin. For use in systems where the processor handles the transmit buffer management.

Write-no effect.
Bit 6
Read-Net Busy-A copy of the Receive Carrier Detect (XCD) input.
Write-no effect.

## Bit 5

Read-Transmitted Packet was Received-Indicates that shortly after transmission was completed a good packet was received by the receiver. This is used to indicate selfreception of the packet, which allows the software to take advantage of the hardware address matching even in systems which are designed for half duplex operation. This bit is cleared as each transmission begins.
Write-no effect.

## Bit 4

Read-Shorted-Set if the Receive Carrier Detect (XCD) stops during packet transmission. Either a collision or shorted coax can cause the bit to be set. This bit is cleared as each transmission begins.
-Write-no effect.

## Bit 3

Read-Underflow-Set when data to be transmitted is not available to the parallel to serial converter before the converter is empty. Transmission is aborted immediately while bytes will be accepted from the FIFO until an EOF is encountered.

Write-0, no effect; 1 , clear the error condition.

Bit 2
Read-Collision-Set when a collision terminates transmission of a packet.
Write-0, no effect; 1 , clear the error condition.

Bit 1
Read-16 Collisions-Set when the 16th collision for a single packet aborts transmission. Bytes are strobed through FIFO normally to discard the packet.
Write-0, no effect; 1, clear the error condition.

## Bit 0

Read-Parity Error-Set when the parallel to serial converter detects a parity error in the data. If parity check is enabled transmission is aborted while the bytes continue to be strobed from the FIFO, until EOF.
Write-0, no effect; 1, clear the error condition.

## Transmit Masks_Address $\mathbf{0 1 H}$

The interrupt conditions which define the signal at TINT are defined by setting the bits of this register.

$$
\begin{aligned}
& \text { Bit } 7-\mathrm{Rd} / \mathrm{Wr}-\text { Gates 'Ready } \\
& \text { For Packet' }
\end{aligned}
$$

Bit 6-no bit, read as 0
Bit 5—Rd/Wr-Gates 'Transmit Received'
Bit 4-no bit, read as 0 .
Bit 3-Rd/Wr-Gates Underflow'
Bit 2—Rd/Wr—Gates 'Collision'
Bit 1-Rd/Wr-Gates ' 16 Collisions'
Bit 0-Rd/Wr-Gates 'Parity Error'

Receive Status-Address $\mathbf{0 2 H}$
This register indicates the status of the receiver.

## Bit 7

Read-Packet OK-Set when CRC of a legal length packet received is correct.
Write-0, no effect; 1 , clear the error condition.

## Bit 6

not used
Bit 5
not used
Bit 4
Read-Reset Packet-Set when a packet is received successfully and the field type is 0900 H . The bit is cleared at the beginning of the next packet reception. The bit is set only if the Node ID matches, not multicast or broadcast. Reset packets are recognized in any Address Match mode from NONE to PROMISCUOUS.
Write-no effect

## Bit 3

Read-Short Packet-Set if a packet does not meet the minimum length requirements of the Ethernet specification.
Write-0, no effect; 1, clear condition.

Bit 2
Read-Alignment Error-Set if a packet has bad CRC at the last octet boundary and the number of bits are not divisible by eight.
Write-0, no effect; 1, clear condition.

Bit 1
Read-CRC Error-Set if the CRC does not verify at the end of the packet.
Write-0, no effect; 1, clear the error condition.

Bit 0
Read-Overflow-Set if the internal asynchronous FIFO is full when a byte is available from the serial to parallel converter.
Write-0, no effect; 1, clear error condition.

## Register Description

(Continued)

## Receive Masks-Address 03H

The interrupt conditions which define the signal at RINT are defined by setting the bits of this register.
Bit 7-Rd/Wr—Gates 'Packet OK'
Bit 6-no bit, read as 0 .
Bit 5-no bit, read as 0 .
Bit 4—Rd/Wr—Gates 'Reset Packet'
Bit 3-Rd/Wr-Gates 'Short Packet'
Bit 2-Rd/Wr—Gates 'Alignment Error'
Bit 1-Rd/Wr-Gates 'CRC Error'
Bit0—Rd/Wr-Gates 'Overflow'

## Transmit Mode—Address 04H

Bits 7-4
Read Only-Collision Attempts - Indicates the number of collisions occured before the last packet was sent (or aborted). This is a testing aid as the number is cleared at the beginning of a subsequent transmission.

## Bit 3

Rd/Wr-Ignore Parity-if set this bit prevents the setting of the Parity Error condition.

## Bit 2

Rd/Wr-TM—A bit whose complement is available as signal pin TM. Intended to control the power to the transceiver or any other function external to the chip.

## Bit 1

Rd/Wr-LBC-A bit whose complement is available as signal pin LBC. Intended to control the loopback function of the Encoder/Decoder or any other function external to the chip.

## Bit 0

Rd/Wr-Disable ContentionWhen this bit is set the transmitter disregards Receive Carrier Detect. This special function would only be used if the MB8795B EDLC were used in a two wire point to point link, in true full duplex
operation. In this case the Collision Detect signal (a low level will inhibit the start of transmission) acts as carrier sense for the transmitter while collisions during transmissions are ignored.

Receive Mode-Address 05H Bit 7
$\mathrm{Rd} / \mathrm{Wr}$ - Test Mode-For chip testing this bit:

1) Inhibits the receiver from accumulating CRC. The last four bytes of a packet are shifted into the CRC register and checked without being modified.
2) Changes the backoff algorithm so that the pseudorandom number generator is disabled and the number to backoff becomes $2^{n-1}+1$, where n is the number of collisions. Also, the slot time is reduced to one (1) byte.

Bit 6
not used.
Bit 5
not used.
Bit 4
Rd/Wr-Address Size-When set this bit reduces the Node ID address match to 5 bytes instead of the normal 6. This is used where the node is performing some multiplex function on the least significant byte of the destination address.

## Bit 3

Rd/Wr-Short Packet EnableFor testing, when this bit is set the receiver will successfully receive any packet of ten (10) bytes or more. This function is used in half duplex systems for the loopback check and can be used by all testing programs to reduce testing time.

Bit 2
$\mathrm{Rd} / \mathrm{Wr}$-Reset Enable-When this bit is zero, the checking done for the special type field is disabled.

Bit 1-0
Rd/Wr-Address Match Mode-

- Mode0-accept no packets
- Mode 1-accept Node ID packets, multicasts which match the first three bytes of the Node ID packets, and broadcast packets.
- Mode 2-accept Node ID packets, and all multicasts including broadcast of course
- Mode 3-promiscuous, accept all packets.


## Reset-Address $\mathbf{0 6 H}$

Bit 7
Write Only-Reset-This latch is writeable and will hold the device in the reset state while set. It is set by the external reset pin RST being low. After power up the software should first initialize all the modes and masks, and then clear the reset.

Bit 6-0
not used

## TDR LSB—Address 07耳

Bits 7-0
Read Only - contains the least significant 8 bits of the TDR register which counts how many bits were successfully transmitted. Counting stops on collision or drop of carrier. Count is reset with each transmission.

## Node ID—Addresses 10-15H

These 6 bytes are Rd/Wr and represent the address against which th frame addresses are matched during Address
Match Modes 1 and 2. Bit 0 of address 10 H is equivalent to the multicast bit.

## TDR MSB—Address 17H

Bits 7-6
not used
Bits 5-0
Read Only-Contains the most significant six bits of the TDR register which was described above.

## Register Description (Continued)

## Interface Signal Description

## Power Group

$\mathrm{V}_{\mathrm{CC}}-+5 \mathrm{~V}$ power supply (two pins)
GND-ground (two pins)

## Control Group

CE (Chip enable, low active input)
This active low signal gates all control port reads and writes.

RDA,RDB, $\overline{\operatorname{RDC}}$ (Control read, inputs)
These two active high and one active low signals are ANDed with CE to form read signals inside the MB8795B EDLC.

WRA,WRB, WRC (Control write, inputs)
These two active high and one active low signals are ANDed with CE to form write strobes inside the MB8795B EDLC. One of the signals is intended to be a clock so that address, data, and other controls will be stable when the internal write is active.

SAO-3 (Control port address, input)
These four signals address the 16 possible registers of the MB8795B EDLC. SAO is the least significant bit of the address.

1OD0-7 (Control port data, 3state outputs and inputs)
These eight signals are the bidirectional data used to read and write the 16 possible internal registers of the MB8795B EDLC.

## Transmit Group

TD0-7 (Transmit data bytes, inputs)
Eight bits of data to be transmitted.

TPAR (Transmit data parity, input)
Optional parity accompanying the transmit byte data.

TEOF (Transmit data end of frame, input)
Required data bit which signals the last byte of the frame. After the byte having this bit is sent, CRC transmission will start.

TEM (Transmit byte register not empty, output)
Indicates that the asynchronous FIFO has no room for a byte.

TSTB (Transmit byte register strobe, positive edge-trigger input)
Strobes the transmit data into the asynchronous FIFO.

TRET (Transmit packet retransmit packet, output)

Indicates that a collision or underflow has occurred. Buffer management logic should discard any remaining bytes of the current packet and then restart transmission of the packet.

TPOK (Transmit packet successful, output)
Indicates to the buffer management that it will not be required to retransmit the current packet again and thus can proceed to the next packet.

## Recelve Group

RD0-7 (Receive data bytes, 3state outputs)
Eight bits of data being received.

RPAR (Receive data parity, 3state output)
Odd parity computed on the incoming data stream.

REOF (Receive data end of frame, 3-state output)
A tenth data bit which accompanies the last byte of the frame, which is only present if reception was successful. Successful reception means that a packet had good CRC, appropriate length and an address match in the current mode.
$\overline{\text { ROEN }}$ (Receive byte output enable, low active input)
3 -state enable for the ten data bits above. This allows multiplexing the receive data port with the transmit and control ports in low cost systems.

RRDY (Receive byte ready, output)
Indicates that a byte is available at the output of the async FIFO.

RSTB (Receive byte strobe, positive edge trigger input)
Strobes the receive data out of the async FIFO to the host system.

RDIS (Receive packet discard, output)
Indicates that the bytes received so far should be discarded because of bad address, bad length or bad CRC. This signal and the REOF output are mutually exclusive.

## Physical Link Group

RCKN (Receive data clock, negative edge trigger input)
This signal is generated by the Ethernet Encoder/Decoder (EED) MB502A. It is a strobe frequency source for the receive bit clock and is used to strobe RXD.

RXD (Receive serial data, input)
Decoded data from the MB502A EED.

TCKN (Transmit data clock, negative edge trigger input)
Generated by the MB502A
EED as a strobe frequency source for the transmit bit clock.

TEN (Transmit encode enable, output)
High true enable for
Manchester encoding. This signal is strobed and stable at the same time as TXD.

TXD (Transmit serial data, output)
Serial data to be encoded onto the Ethernet Coax. Gated by TEN

XCD (Receive carrier detect, input)
Carrier detect signal of the decoder. Used by the receiver as data gate and by the transmitter as contention information.

Register Description

XCOL (Collision presence, input)
A TTL copy of the Collision presence pair of the transceiver cable. The idle state is indicated by a logic " 1 " and the collision is indicated by a 10 MHz square wave.

LBC (Loopback Control, output)
A copy of a software setable latch used to command the MB502A EED to operate in Loopback mode.

## MIsc. Group

PRST (Packet reset, output)
Indicates that a complete and legal packet of type 0900 H was received. This is intended to be used as a remote reset function.
$\overline{\text { RINT }}$ (Receive interrupt, output)
A logic " 0 " indicates the receiver interrupt condition coincides with its corresponding mask bit.

TINT (Transmitter interrupt, output)
Same as $\overline{\text { RINT }}$ for transmitter interrupt.
$\overline{\text { RST }}$ (Reset, low active input)
TM (Test mode, output)
A copy of a software loadable latch. Intended to control a circuit to turn the Transceiver power on and off.

Timing Diagram

*Note 1: This period could be as great as $11 / 2$ byte times.

Timing Diagram
(Continued)
Transmit Good Packet (2)

*Note 1: Must be less than $\approx 5.0 \mu \mathrm{sec}$. to guarantee minimum packet spacing.
*Note 2: This could be $1 / 2-21 / 2$ byte times.

## Timing Diagram

(Continued)
Transmit Collision—First Fifteen Collisions only

*Note 1: Must be less than $\approx 5.0 \mu \mathrm{sec}$. to guarantee minimum backoff time.


Receive


Timing Diagram
(Continued)
Receive-Address Mismatch, Overflow Error, CRC Error, Packet Length Error



Package Dimensions
Dimensions in inches (millimeters)

## 64-LEAD CERAMIC (METAL SEAL) PIN GRID ARRAY PACKAGE (CASE No.: PGA-64C-A02)



## Section 6



## general purpose digital signal processor

The Fujitsu MB 8764 is a general purpose silicon-gate CMOS digital signal processor (DSP) integrated circuit. The MB 8764 features a high-speed pipelined multiplier, supports concurrent operations with compound instructions and multiple data paths, offers flexible and expandable memory options and has an on-chip DMA channel.

With its high-speed operation, the MB 8764 gives high throughput in various applications, such as telecommunications, signal processing and image processing.

Being packaged in the 88 -pin pin grid array, the MB 8764 allows a complex system to be built with the external program ROM and data RAM accessed through dedicated address and data buses.

- General purpose high-speed digital signal processing
- High speed operation
- 100 ns cycle time
- Parallel pipelined multiply function
- 16 bits $\times 16$ bits $\rightarrow 26$ bits
- Divide function
- 26 bits $\div 16$ bits $\rightarrow 16$ bits
- Program ROM
- 1024 words $\times 24$ bits
- Internal (mask-programmed) and external ROM selectable
- Part of the program ROM can be used for constant data storage
- Two built-in $128 \times 16$ bits RAMs
- Expansion RAM function
- Expandable up to 1024 words $\times 16$ bits
- Two access speed rates can be selected
- Numerous I/O functions
- 16-bit parallel interface
- Three input modes and two output modes including DMA
- Powerful instruction set using compound instructions
- One level of subroutine nesting (multi-level nesting can be programmed)
- Two levels of loop nesting (multi-level nesting can be programmed)
- Compound instructions (for example, an arithmetic/logic instruction combined with a move instruction) enable concurrent processing
- 15 arithmetic/logic instructions
- Addressing
- Direct addressing
- Indexed addressing
- Immediate addressing
- Virtual shift addressing
- Silicon-gate CMOS process
- Single 5 volt power supply, TTL I/O interface (except pins for clock signals)
- 88-pin space-saving pin grid array package
- Support tool, including cross-assembly software and evaluation board

Fig. 1 - BLOCK DIAGRAM


## FUNCTION OF BLOCK

| Block | Function |
| :---: | :---: |
| Clock generator | This block generates a cycle clock ( $\overline{\phi 3}$ ) used for internal operations. The clock pulses can be generated by supplying a clock signal from an external circuit through external pins CK1 and CK2, or by a crystal resonator and capacitors connected to CK1 and CK2. The master clock (MCLK) obtained by either of the above two methods has the same frequency as that of the CK1/CK2 clock and generates a cycle clock $\overline{\phi 3}$ having the frequency of the machine cycle (which is half the MCLK frequency). All internal operations are timed by the cycle clock $\overline{\phi 3}$. |
| Sequence control block | This block controls the DSP instruction execution sequence. The program counter ( PC ) is reset to address 0 by the $\overline{\mathrm{RST}}$ pulse, and is incremented by 1 at each leading edge of $\overline{\phi 3}$ after $\overline{\mathrm{RST}}$ is turned off. The PC output is connected to the address input of the internal microinstruction ROM (IROM) via the ROM pointer (DPR), and the ROM data is read out sequentially according to the PC value. |
|  | The DPR value is also output through PA9 to PAO to the outside to permit access to an external ROM (EROM). Data from the EROM is input to the MB 8764 through P23 to PO. At any given time, either the IROM or EROM can be used, and the choice is controlled by the IRM input. The IROM is a mask ROM with a capacity of 1,024 words $\times 24$ bits. The ROM that has the same organization can be used for the EROM. The IROM and EROM are functionally identical. The ROM output data is transferred to the instruction register IRO at the beginning of a cycle (that is, at the leading edge of $\overline{\phi 3}$ ), moved to the instruction register IR1 at the beginning of the following cycle, then decoded and executed. |
|  | To perform a branch instruction, address can be loaded into PC through IRO and the IBUS, and the PC value can be saved in RAM or in another register through the IBUS. PCS is single PC stack used for subroutine execution. Two loop counters, CO and C 1 , are provided to facilitate the handling of loops. |
|  | This block also has a cycle counter (CYC) that controls execution of multi-cycle instructions. This counter automatically stops incrementing PC during execution of a multi-cycle instruction. |

## FUNCTION OF BLOCK (Cont'd)



## PIN ASSIGNMENT

Fig. 2 - PIN ASSIGNMENT


| No. | Name | No. | Name | No. | Name | No. | Name | No. | Name | No. | Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | PA1 | 16 | EAO | 31 | $\mathrm{D}_{14}$ | 46 | P23 | 61 | EA7 | 76 | CK2 |
| 2 | PAO | 17 | - | 32 | $\overline{\text { REQ }}$ | 47 | P21 | 62 | EA9 | 77 | TST |
| 3 | P22 | 18 | EA3 | 33 | BCT | 48 | P18 | 63 | ECE | 78 | PA9 |
| 4 | P20 | 19 | EA5 | 34 | $\overline{\text { RCK }}$ | 49 | P16 | 64 | $\mathrm{D}_{2}$ | 79 | PA6 |
| 5 | P19 | 20 | EA6 | 35 | $\overline{\text { RST }}$ | 50 | P15 | 65 | $\mathrm{D}_{4}$ | 80 | PA4 |
| 6 | P17 | 21 | EA8 | 36 | $\overline{\mathrm{FLO}}$ | 51 | P13 | 66 | $\mathrm{D}_{7}$ | 81 | GND |
| 7 | P14 | 22 | EWE | 37 | WCK | 52 | P10 | 67 | $\mathrm{D}_{9}$ | 82 | $V_{\text {CC }}$ |
| 8 | P12 | 23 | $\mathrm{D}_{0}$ | 38 | ESS | 53 | P8 | 68 | $\mathrm{D}_{10}$ | 83 | $V_{C C}$ |
| 9 | P11 | 24 | $\mathrm{D}_{1}$ | 39 | CK1 | 54 | P6 | 69 | $\mathrm{D}_{12}$ | 84 | GND |
| 10 | P9 | 25 | $\mathrm{D}_{3}$ | 40 | IRM | 55 | P3 | 70 | $\mathrm{D}_{15}$ | 85 | GND |
| 11 | P7 | 26 | $\mathrm{D}_{5}$ | 41 | PA8 | 56 | P1 | 71 | $\overline{\mathrm{ACT}}$ | 86 | $V_{C C}$ |
| 12 | P5 | 27 | $\mathrm{D}_{6}$ | 42 | PA7 | 57 | EA1 | 72 | $\overline{\text { AIF }}$ | 87 | $V_{C C}$ |
| 13 | P4 | 28 | $\mathrm{D}_{8}$ | 43 | PA5 | 58 | - | 73 | $\overline{F L 1}$ | 88 | GND |
| 14 | P2 | 29 | $\mathrm{D}_{11}$ | 44 | PA3 | 59 | EA2 | 74 | $\overline{\mathrm{AOF}}$ |  |  |
| 15 | PO | 30 | $\mathrm{D}_{13}$ | 45 | PA2 | 60 | EA4 | 75 | $\overline{\text { ASL }}$ |  |  |


| No. | Name | 1/0 | Function |
| :---: | :---: | :---: | :---: |
| 78 | PA9 | Output | Program address MSB |
| 41 | PA8 | Output | Program address BIT8 |
| 42 | PA7 | Output | Program address BIT7 |
| 79 | PA6 | Output | Program address BIT6 |
| 43 | PA5 | Output | Program address BIT5 |
| 80 | PA4 | Output | Program address BIT4 |
| 44 | PA3 | Output | Program address BIT3 |
| 45 | PA2 | Output | Program address BIT2 |
| 1 | PA1 | Output | Program address BIT1 |
| 2 | PAO | Output | Program address LSB |
| 46 | P23 | 1/O | Instruction MSB |
| 3 | P22 | 1/0 | Instruction BIT22 |
| 47 | P21 | 1/0 | Instruction BIT21 |
| 4 | P20 | 1/0 | Instruction BIT20 |
| 5 | P19 | 1/0 | Instruction BIT19 |
| 48 | P18 | 1/0 | Instruction BIT18 |
| 6 | P17 | 1/0 | Instruction BIT17 |
| 49 | P16 | 1/0 | Instruction BIT16 |
| 50 | P15 | 1/0 | Instruction BIT15 |
| 7 | P14 | 1/0 | Instruction BIT14 |
| 51 | P13 | 1/0 | Instruction BIT13 |
| 8 | P12 | 1/0 | Instryction BIT12 |
| 9 | P11 | 1/0 | Instrüction BIT11 |
| 52 | P10 | 1/0 | Instruction BIT10 |
| 10 | P9 | 1/0 | Instruction BIT9 |
| 53 | P8 | 1/0 | Instruction BIT8 |
| 11 | P7 | 1/0 | Instruction BIT7 |
| 54 | P6 | 1/0 | Instruction BIT6 |
| 12 | P5 | 1/0 | Instruction BIT5 |
| 13 | P4 | 1/0 | Instruction BIT4 |


| No. | Name | 1/0 | Function |
| :---: | :---: | :---: | :---: |
| 55 | P3 | 1/0 | Instruction BIT3 |
| 14 | P2 | 1/0 | Instruction BIT2 |
| 56 | P1 | 1/0 | Instruction BIT1 |
| 15 | PO | 1/0 | Instruction LSB |
| 39 | CK1 | Input | Master clock input pin 1 |
| 76 | CK2 | Input | Master clock input pin 2 |
| 35 | RST | Input | Initialization |
| 40 | IRM | Input | Internal/external ROM switching |
| 77 | TST | Input | Internal ROM test mode |
| 62 | EA9 | Output | Expansion RAM address MSB |
| 21 | EA8 | Output | Expansion RAM address |
| 61 | EA7 | Output | Expansion RAM address |
| 20 | EA6 | Output | $\begin{aligned} & \text { Expansion RAM } \\ & \text { address } \end{aligned}$ |
| 19 | EA5 | Output | Expansion RAM address |
| 60 | EA4 | Output | Expansion RAM BIT4 address |
| 18 | EA3 | Output | Expansion RAM address BIT3 |
| 59 | EA2 | Output | Expansion RAM address BIT2 |
| 57 | EA1 | Output | Expansion RAM address BIT1 |
| 16 | EAO | Output | Expansion RAM address LSB |
| 70 | D15 | 1/0 | Data bus I/O MSB |
| 31 | D14 | 1/0 | Data bus I/O BIT14 |

## ABSOLUTE MAXIMUM RATINGS*1

| Parameter | Symbol | Rating |  | Unit |
| :--- | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| Power supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | $-0.3^{* 2}$ | 7.0 | V |
| Input voltage | $\mathrm{V}_{\mathrm{I}}$ | $-0.3^{* 2}$ | $\mathrm{~V}_{\mathrm{CC}}+0.3^{* 2}$ | V |
| Output voltage | $\mathrm{V}_{\mathrm{O}}$ | $-0.3^{* 2}$ | $\mathrm{~V}_{\mathrm{CC}}+0.3^{* 2}$ | V |
| Operating temperature | $\mathrm{T}_{\mathrm{OP}}$ | 0 | 85 | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature | $\mathrm{T}_{\mathrm{STG}}$ | -55 | 150 | ${ }^{\circ} \mathrm{C}$ |

Note: *1 Permanent device damage may occur if the absolute maximum ratings are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
*2 This value applies in a steady condition. It may be 0.5 V in a transient condition (for 20 to 30 ns ).

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Condition |  |  | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| Power supply voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5.0 | 5.5 | V |
| Operating temperature | $\mathrm{T}_{\mathrm{OP}}$ | 0 |  | 85 | ${ }^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

(Recommended Operating Conditions unless otherwise specified.)

| Parameter | Symbol | Condition | Min | Typ | Max | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| Input high voltage | $\mathrm{V}_{I H}$ | Other than CK1, CK2 | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}+0.3$ | V |
|  | $\mathrm{~V}_{\mathrm{IHCK}}$ | $\mathrm{CK1,CK2}$ | 4.0 |  | $\mathrm{~V}_{\mathrm{CC}}+0.3$ | V |
| Input low voltage | $\mathrm{V}_{\mathrm{IL}}$ | Other than CK1, CK2 | -0.3 |  | 0.8 | V |
|  | $\mathrm{~V}_{\mathrm{ILCK}}$ | $\mathrm{CK} 1, \mathrm{CK} 2$ | -0.3 |  | 0.6 | V |
| Output high voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | 2.7 |  | $\mathrm{~V}_{\mathrm{CC}}$ | V |
| Output low voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ |  |  | 0.4 | V |
| Input leakage current | $\mathrm{I}_{\mathrm{LI}}$ | $\mathrm{V}_{1}=0$ to 5.5 V | -25 |  | 25 | $\mu \mathrm{~A}$ |
| Input leakage current <br> (Three-state pin input) | $\mathrm{I}_{\mathrm{LZ}}$ | $\mathrm{V}_{1}=0$ to 5.5 V | -40 |  | 40 | $\mu \mathrm{~A}$ |
| Static power supply current |  |  |  | 1 |  | mA |
| Power supply current | $\mathrm{I}_{\mathrm{CCS}}$ |  |  | 60 |  | mA |

## CAPACITANCE

$\left(\mathrm{V}_{\mathrm{cc}}=\mathrm{V}_{1}=0 \mathrm{~V}, \mathrm{f}_{\mathrm{M}}=8 \mathrm{MHz}\right)$

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input pin | $\mathrm{C}_{\text {IN }}$ |  |  | 5 | pF |
| Output pin | $\mathrm{C}_{\mathrm{OUT}}$ |  |  | 5 | pF |
| I/O pin | $\mathrm{C}_{1 / \mathrm{O}}$ |  |  | 8 | pF |

## AC CHARACTERISTICS

## EXTERNAL CLOCK TIMING

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Cycle time *1 | $\mathrm{t}_{\mathrm{CYC}}$ | 100 |  |  | ns |
| High voltage pulse width | $\mathrm{t}_{\mathrm{CKH}}$ | 20 |  |  | ns |
| Low voltage pulse width | $\mathrm{t}_{\mathrm{CKL}}$ | 20 |  | ns |  |

Note: *1 Value when ERAM (extended RAM) is not used. When ERAM is used, follow the specifications for the ERAM interface AC characteristics. This note also applies to the following AC characteristics.

Fig. 3 - EXTERNAL CLOCK TIMING DIAGRAM

## CK1

 (INPUT)

INTERNAL OSCILLATOR (Crystal oscillator connected)

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Cycle time | $\mathrm{t}_{\mathrm{CYC}}$ | 100 |  |  | ns |
| Crystal frequency | $\mathrm{f}_{\mathrm{Cyc}}$ |  | 16 | 20 | MHz |

RESET INPUT TIMING

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Power-on reset ${ }^{* 1}$ | $\mathrm{t}_{\text {PRST }}$ |  | 1 |  | ms |
| MCLK setup ${ }^{2}$ | $\mathrm{t}_{\text {RSTS }}$ | 20 |  |  | ns |
| MCLK hold ${ }^{* 2}$ | $\mathrm{t}_{\text {RSTH }}$ | 15 |  |  | ns |
| Reset input pulse width | $\mathrm{t}_{\text {RSTW }}$ | $\mathrm{t}_{\text {CYC }}+35$ |  | ns |  |

Note: *1 The time specification for power-on reset applies to the internal oscillation mode. In the external clock mode, the reset pulse must be entered so that the leading edge of MCLK ( $\overline{\mathrm{CK} 2}$ ) can be produced while $\overline{\mathrm{RST}}=0$.
*2 In the external clock mode, MCLK is considered to be $\overline{\text { CK2 }}$ (the inversion of the clock input from CK2). This note also applies to the following AC characteristics.

Fig. 4 - RESET INPUT TIMING DİAGRAM


EXTERNAL ROM INTERFACE TIMING

| Parameter | Symbol | Condition | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Address output delay (from MCLK pulse) | $\mathrm{t}_{\mathrm{PAD}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 60 | 75 | ns |
| Address output hold (from MCLK pulse) | $\mathrm{t}_{\mathrm{PAH}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 20 |  |  | ns |
| Data hold time (to address) | $\mathrm{t}_{\mathrm{PHA}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 0 |  |  | ns |
| Data setup (before MCLK pulse) | $\mathrm{t}_{\mathrm{PS}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 10 | 10 |  | ns |

Fig. 5 - EXTERNAL ROM INTERFACE TIMING DIAGRAM


Note: ${ }^{*} t_{\text {PAC }}$ is the address access time provided by the specification of the external ROM.

FUJITSU


FLAG ( $\overline{F L O}$ and $\overline{F L 1}$ ) INPUT TIMING

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Setup time | $\mathrm{t}_{\mathrm{FLS}}$ | 15 |  |  | ns |
| Hold time | $\mathrm{t}_{\mathrm{FLH}}$ | 30 |  |  | ns |
| Pulse width ${ }^{1}$ | $\mathrm{t}_{\text {FLW }}$ | $\mathrm{t}_{\mathrm{CYC}}+45$ |  |  | ns |

Note: ${ }^{*} 1 \mathrm{t}_{\mathrm{FLW}}(\mathrm{Min})=2 \times \mathrm{t}_{\mathrm{CYC}}+45$ when ERAM is used with ESS $=1$.
Fig. 6 - FLAG INPUT TIMING DIAGRAM


EXPANSION RAM INTERFACE TIMING (ESS = 0, Read Cycle)

| Parameter | Symbol | Condition | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Address output delay | $\mathrm{t}_{\mathrm{EAD}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 50 | 60 | ns |
| Address output hold | $\mathrm{t}_{\mathrm{EAH}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 10 | 13 |  | ns |
| Chip enable output delay | $\mathrm{t}_{\mathrm{CED}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 57 | 70 | ns |
| Chip enable output hold | $\mathrm{t}_{\mathrm{CEH}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 17 | 19 |  | ns |
| Output disable | $\mathrm{t}_{\mathrm{DHZ}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 0 |  |  | ns |
| Data input setup time | $\mathrm{t}_{\mathrm{ERDS}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 30 | 25 |  | ns |
| Data input hold time | $\mathrm{t}_{\text {ERDH }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 0 |  |  | ns |

Fig. 7 - EXPANSION RAM INTERFACE TIMING DIAGRAM (ESS = 0, Read Cycle)


Note: ${ }^{*} t_{\text {ERAA }}$ is the address access time provided by the specification of the expansion RAM.
${ }^{* *} t_{\text {ERCA }}$ is the chip select access time provided by the specification of the expansion RAM.

MB 8764

EXPANSION RAM INTERFACE TIMING (ESS = 1, Read Cycle)

| Parameter | Symbol | Condition | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Address output delay | $\mathrm{t}_{\mathrm{EAD}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 50 | 60 | ns |
| Address output hold | $\mathrm{t}_{\mathrm{EAH}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 10 | 13 |  | ns |
| Chip enable output delay | $\mathrm{t}_{\mathrm{CED}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 57 | 70 | ns |
| Chip enable output hold | $\mathrm{t}_{\mathrm{CEH}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 17 | 19 |  | ns |
| Data input setup time | $\mathrm{t}_{\mathrm{ERDS}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 30 | 25 |  | ns |
| Data input hold time | $\mathrm{t}_{\text {ERDH }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 0 |  |  | ns |

Fig. 8 - EXPANSION RAM INTERFACE TIMING DIAGRAM (ESS = 1, Read Cycle)


Note: ${ }^{*} t_{\text {ERAA }}$ is the address access time provided by the specification of the expansion RAM. ${ }^{* *}$ terca is the chip select access time provided by the specification of the expansion RAM.

FUJITSU

EXPANSION RAM INTERFACE TIMING (ESS = 0, Write Cycle)

| Parameter | Symbol | Condition | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address output delay | $t_{\text {EAD }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 50 | 60 | ns |
| Address output hold | $t_{\text {EAH }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 10 | 13 |  | ns |
| Address hold (after EWE) | $t_{\text {WEA }}$ | $C_{L}=50 \mathrm{pF}$ | 5 |  |  | ns |
| Chip enable output delay | $\mathrm{t}_{\text {CED }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 57 | 70 | ns |
| Chip enable output hold | $\mathrm{t}_{\text {ceh }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 17 | 19 |  | ns |
| Write enable output delay | $\mathrm{t}_{\text {WED }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 40 | 50 | ns |
| Write enable output hold | $\mathrm{t}_{\text {WEH }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 5 |  | 35 | ns |
| Write enable pulse width | $t_{\text {WEW }}$ | $C_{L}=50 \mathrm{pF}$ | $\frac{\mathrm{t}_{\mathrm{CYC}}}{2}-30$ |  |  | ns |
| Data output delay | ${ }^{t}$ DD | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  | 52 | 70 | ns |
| Data setup (before EWE) | $t_{\text {DSW }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ | $\frac{\mathrm{t}_{\mathrm{cYc}}}{2}-50$ |  |  | ns |
| Data hold (after EWE) | $t_{\text {DHW }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ | 5 |  |  | ns |
| Data output active delay | ${ }^{\text {t }}$ DAC | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  | 52 | 70 | ns |

Fig. 9 - EXPANSION RAM INTERFACE TIMING DIAGRAM (ESS = 0, Write Cycle)


## EXPANSION RAM INTERFACE TIMING (ESS = 1, Write Cycle)

| Parameter | Symbol | Condition | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address output delay | $t_{\text {EAD }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 50 | 60 | ns |
| Address output hold | $\mathrm{t}_{\text {EAH }}$ | $C_{L}=50 \mathrm{pF}$ | 10 | 13 |  | ns |
| Address output hold (after EWE) | $t_{\text {wEA }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 25 |  | ns |
| Chip enable output delay | $\mathrm{t}_{\text {CED }}$ | $C_{L}=50 \mathrm{pF}$ |  | 57 | 70 | ns |
| Chip enable output hold | $\mathrm{t}_{\text {CEH }}$ | $C_{L}=50 \mathrm{pF}$ | 17 | 19 |  | ns |
| Write enable output delay | twEd | $C_{L}=50 \mathrm{pF}$ |  |  | 50 | ns |
| Write enable output hold | $t_{\text {WEH }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 10 |  | 35 | ns |
| Write enable pulse width | $t_{\text {WEW }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | $\mathrm{t}_{\mathrm{CYC}}-40$ |  |  | ns |
| Data output active delay | $t_{\text {DAC }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  | 57 | 75 | ns |
| Data setup (during EWE) | $t_{\text {DSW }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ | $\mathrm{t}_{\mathrm{CYC}}-65$ |  |  | ns |
| Data hold (after EWE) | $\mathrm{t}_{\text {DHW }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ | 5 |  |  | ns |

Fig. 10-EXPANSION RAM INTERFACE TIMING DIAGRAM (ESS = 1, Write Cycle)


P MODE AND D MODE INPUT TIMING

| Parameter | Symbol | Condition | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { AIF }}$ setup | $t_{\text {AFS }}$ |  | 30 |  |  | ns |
| $\overline{\text { AIF }}$ hold | $\mathrm{t}_{\text {AFH }}$ |  | 20 |  |  | ns |
| $\overline{\text { AIF pulse width * } 1}$ | $\mathrm{t}_{\text {AFW }}$ |  | $\mathrm{t}_{\mathrm{CYC}}+50$ |  |  | ns |
| $\overline{\text { ACT }}$ fall delay | $t_{\text {ACT }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 70 | ns |
| $\overline{\text { ACT }}$ reset delay | $t_{\text {Actro }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 70 | ns |
| $\overline{\mathrm{RCK}}$ input enable | $t_{\text {RCKAC }}$ |  | 0 |  |  | ns |
| $\overline{\mathrm{RCK}}$ pulse width | $\mathrm{t}_{\text {RCKW }}$ |  | 40 |  |  | ns |
| $\overline{\text { RCK }}$ enable setup | $t_{\text {des }}$ |  | 35 |  |  | ns |
| $\overline{\mathrm{RCK}}$ enable hold | $\mathrm{t}_{\text {DEH }}$ |  | 25 |  |  | ns |
| Data setup | $\mathrm{t}_{\text {DDS }}$ |  | 25 |  |  | ns |
| Data hold | $\mathrm{t}_{\text {DDH }}$ |  | 25 |  |  | ns |
| $\overline{\text { ACT }}$ reset setup | $\mathrm{t}_{\text {Actris }}$ |  | 60 |  |  | ns |
| $\overline{\text { ACT }}$ reset hold | $\mathrm{t}_{\text {Actre }}$ |  | 10 |  |  | ns |

Note: * ${ }^{1} \mathrm{t}_{\text {AFW }}(\mathrm{Min})=2 \times \mathrm{t}_{\mathrm{CYC}}+50$ when ERAM is used with ESS $=1$.

Fig. 11 - $P$ MODE AND D MODE INPUT TIMING DIAGRAM


A MODE INPUT TIMING

| Parameter | Symbol | Condition | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { AIF }}$ setup | $\mathrm{t}_{\text {AFS }}$ |  | 30 |  |  | ns |
| $\overline{\text { AIF }}$ hold | $t_{\text {AFH }}$ |  | 20 |  |  | ns |
| $\overline{\text { AIF pulse width *1 }}$ | $t_{\text {AFW }}$ |  | $\mathrm{t}_{\mathrm{CYC}}+50$ |  |  | ns |
| $\overline{\text { ACT }}$ fall delay | $t_{A C T}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 70 | ns |
| $\overline{\text { ACT }}$ reset delay | $\mathrm{t}_{\text {ACtir }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 70 | ns |
| $\overline{\text { RCK }}$ input enable | $t_{\text {RCKAC }}$ |  | 0 |  |  | ns |
| $\overline{\mathrm{RCK}}$ pulse width | $\mathrm{t}_{\text {RCKW }}$ |  | 40 |  |  | ns |
| $\overline{\mathrm{RCK}}$ enable hold | $\mathrm{t}_{\text {AEH }}$ |  | 25 |  |  | ns |
| $\overline{\text { RCK enable setup }}$ | $t_{\text {des }}$ |  | 35 |  |  | ns |
| $\overline{\text { RCK }}$ enable hold | $t_{\text {DEH }}$ |  | 25 |  |  | ns |
| Address setup | $t_{\text {ADS }}$ |  | 25 |  |  | ns |
| Address hold | $t_{\text {ADH }}$ |  | 25 |  |  | ns |
| Data setup | $\mathrm{t}_{\text {DDS }}$ |  | 25 |  |  | ns |
| Data hold | $\mathrm{t}_{\mathrm{DDH}}$ |  | 25 |  |  | ns |
| $\overline{\mathrm{ACT}}$ reset setup | $\mathrm{t}_{\text {ACTRS }}$ |  | 60 |  |  | ns |
| $\overline{\text { ACT }}$ reset hold | $\mathrm{t}_{\text {Actrin }}$ |  | 10 |  |  | ns |

Note: ${ }^{*} 1 \mathrm{t}_{\mathrm{AFW}}(\mathrm{Min})=2 \times \mathrm{t}_{\mathrm{CYC}}+50$ when ERAM is used with ESS $=1$.

Fig. 12 - A MODE INPUT TIMING DIAGRAM


## I MODE OUTPUT TIMING

| Parameter | Symbol | Condition | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { REO }}$ output delay | $\mathrm{t}_{\text {REQ }}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 75 | ns |
| $\overline{\text { AOF output delay }}$ | $t_{\text {AOF }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 65 | ns |
| $\overline{\mathrm{BCT}}$ level 0 setup | $t_{\text {BLS }}$ |  | 40 |  |  | ns |
| $\overline{\text { BCT }}$ level 0 hold | $t_{\text {BLH }}$ |  | 15 |  |  | ns |
| $\overline{B C T}$ level 1 setup | $\mathrm{t}_{\mathrm{BHS}}$ |  | 40 |  |  | ns |
| $\overline{B C T}$ level 1 hold | $\mathrm{t}_{\text {BHH }}$ |  | 15 |  |  | ns |
| $\overline{\text { BCT }}$ level 1 pulse width *1 | $\mathrm{t}_{\text {BHW }}$ |  | $\mathrm{t}_{\mathrm{CYC}}+55$ |  |  | ns |
| $\overline{\text { WCK fall delay }}$ | $\mathrm{t}_{\text {WCKD }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 65 | ns |
| $\overline{\text { WCK }}$ rise delay | twCKu | $\mathrm{C}_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 65 | ns |
| Address output delay | $t_{\text {AUD }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 85 | ns |
| Data output delay | $t_{\text {DUD }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}^{\text {c }}$ |  |  | 80 | ns |
| Data output disable | $t_{\text {DDD }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 70 | ns |
| Address setup | $\mathrm{t}_{\text {ADOS }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}^{\text {c }}$ | 170 |  |  | ns |
| Address hold | $\mathrm{t}_{\text {ADOH }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ | 65 |  |  | ns |
| Data setup | $\mathrm{t}_{\text {DOS }}$ | $C_{L}=50 \mathrm{pF}+1 \mathrm{TTL}$ | 170 |  |  | ns |
| Data hold | $\mathrm{t}_{\mathrm{DOH}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}+1 \mathrm{TTL}$ | 65 |  |  | ns |

Note: ${ }^{*} 1 \mathrm{t}_{\mathrm{BHW}}(\mathrm{Min})=2 \times \mathrm{t}_{\mathrm{CYC}}+55$ when ERAM is used with ESS $=1$.

Fig. 13 - I MODE OUTPUT TIMING DIAGRAM


FUJITSU

## E MODE OUTPUT TIMING

| Parameter | Symbol | Condition | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{R E Q}$ output delay | $\mathrm{t}_{\mathrm{REQ}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 75 | ns |
| $\overline{B C T}$ level 0 setup | $\mathrm{t}_{\mathrm{BLS}}$ |  | 40 |  |  | ns |
| $\overline{\mathrm{BCT}}$ level 0 hold | $\mathrm{t}_{\mathrm{BLH}}$ |  | 15 |  |  | ns |
| $\overline{\mathrm{BCT}}$ level 1 setup | $\mathrm{t}_{\mathrm{BHS}}$ |  | 40 |  |  | ns |
| $\overline{\mathrm{BCT}}$ level 1 hold | $\mathrm{t}_{\mathrm{BHH}}$ |  | 15 |  |  | ns |
| $\overline{B C T}$ level 1 pulse width *1 | $\mathrm{t}_{\mathrm{BHW}}$ |  | $\mathrm{t}_{\mathrm{CYC}}+55$ |  |  | ns |
| Output active delay | $\mathrm{t}_{\mathrm{BCA}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 85 | ns |
| Address output from fall of $\overline{\mathrm{ASL}}$ | $\mathrm{t}_{\mathrm{DSA}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 85 | ns |
| Data output from rise of $\overline{\mathrm{ASL}}$ | $\mathrm{t}_{\mathrm{DSD}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 85 | ns |
| Output inactive | $\mathrm{t}_{\mathrm{BCD}}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}+1 \mathrm{TTL}$ |  |  | 70 | ns |

Note: *1 $\mathrm{t}_{\mathrm{BHW}}(\mathrm{Min})=2 \times \mathrm{t}_{\mathrm{CYC}}+55$ when ERAM is used with $\mathrm{ESS}=1$.

Fig. 14 - E MODE OUTPUT TIMING DIAGRAM


AC CHARACTERISTICS MEASUREMENT CONDITIONS

| Parameter | Symbol | Condition |
| :--- | :---: | :---: |
| Power supply voltage | $\mathrm{V}_{\mathrm{DD}}$ | $5 \mathrm{~V} \pm 10 \%$ |
| Ambient temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 to $85^{\circ} \mathrm{C}$ |

Fig. 15 - AC CHARACTERISTICS MEASUREMENT WAVEFORMS


## APPLICATION INFORMATION

Fig. 16 - EXAMPLE OF MB 8764 APPLICATION CIRCUIT (with 1K-word External ROM and 1K-word External RAM)


## INSTRUCTION SET

ARITHMETIC AND LOGIC INSTRUCTIONS

| Mnemonic | Processing performed | Mnemonic | Processing performed |
| :--- | :--- | :---: | :--- |
| NOP | No operation | ABS | $\|D\| \rightarrow D$ |
| $A D D$ | $A+B \rightarrow D$ | NEG | $-D \rightarrow D$ |
| MLT | $A \times B \rightarrow D$ | SRA | Shift D right arithmetic $\rightarrow D$ |
| SUB | $B-A \rightarrow D$ | SLA | Shift D left arithmetic $\rightarrow D$ |
| MSM | $D+A \times B \rightarrow D$ | AND | $D \cap A \rightarrow D$ |
| $M R D$ | $D-A \times B \rightarrow D$ | ORA | $D \cup A \rightarrow D$ |
| SUM | $D+A \rightarrow D$ | $D I V$ | $D \div A \rightarrow D$ |
| $R E D$ | $D-A \rightarrow D$ | $C O M$ | $\bar{D} \rightarrow D$ |

## TRANSFER INSTRUCTIONS

| Mnemonic |  | Processing performed |
| :---: | :---: | :---: |
| LTB: (Arithmetic/logic instruction) | \$a, \$b | ROMT $\rightarrow$ A, BRAM/ERAM $\rightarrow$ B |
| LAB: (Arithmetic/logic instruction) | \$a, \$b | ARAM $\rightarrow$ A, BRAM/ERAM $\rightarrow$ B |
| MAB: (Arithmetic/logic instruction) | \$a, \$b | ARAM $\rightarrow$ BRAM/ERAM |
| MBA: (Arithmetic/logic instruction) | \$a, \$b | BRAM/ERAM $\rightarrow$ ARAM |
| MOV: (Arithmetic/logic instruction) | \$a, Reg [:Reg. . ] | IRAM/ERAM $\rightarrow$ Register |
| MOV: (Arithmetic/logic instruction) | \# \$d, Reg [:Reg. .] | Immediate data (d) $\rightarrow$ Register |
| MOV: (Arithmetic/logic instruction) | Reg, Reg [:Reg. .] | Register $\rightarrow$ Register |
| LDI: (Arithmetic/logic instruction) | \# \$d | $\mathrm{d} \rightarrow \mathrm{A}$ |
| LIB: (Arithmetic/logic instruction) | \# \$d | $d \rightarrow A, B R A M \rightarrow B$ |

## JUMP INSTRUCTIONS

| Mnemonic |  | Processing performed |
| :---: | :---: | :---: |
| JMP: (Arithmetic/logic instruction) | \# \$d | Unconditional jump ( $\mathrm{d} \rightarrow \mathrm{PC}$ ) |
| JOC: (Arithmetic/logic instruction) | \# \$d, flag | Conditional jump ( $\mathrm{d} \rightarrow \mathrm{PC}$ ) |
| JOC: (Arithmetic/logic instruction) | \$a, flag | Conditional jump (IRAM/ERAM $\rightarrow$ PC) |
| JSR: (Arithmetic/logic instruction) | \# \$d | Jump to subroutine (PC $\rightarrow$ PCS, $\mathrm{d} \rightarrow \mathrm{PC}$ ) |
| RTS: (Arithmetic/logic instruction) |  | Return from subroutine |

## MISCELLANEOUS INSTRUCTIONS

| Mnemonic |  | Processing performed |
| :---: | :---: | :---: |
| CLR: [Reg [:Reg...] ...] |  | Clear register |
| SET: [Reg [:Reg...] . . .] |  | Set register |
| MXY: (Arithmetic/logic instruction) | $\# \$ \mathrm{~d}_{1}, \# \mathrm{Sd}_{2}$ | $X+d_{1} \rightarrow X, Y+d_{2} \rightarrow Y$ |
| LIY: (Arithmetic/logic instruction) | \# \$d | $d \rightarrow A, B R A M \rightarrow B, Y+1 \rightarrow Y$ |
| AVP: (Arithmetic/logic instruction) | \# \$d | $V P+d \rightarrow V P$ |
| LVP: (Arithmetic/logic instruction) | \# \$d | $\mathrm{d} \rightarrow \mathrm{VP}$ |
| ADY: (Arithmetic/logic instruction) |  | $Y+Y S \rightarrow Y$ |
| GXY: (Arithmetic/logic instruction) |  | $X S \rightarrow X, Y S \rightarrow Y$ |
| SXY: (Arithmetic/logic instruction) | \# \$d | $d \rightarrow C 1, X \rightarrow X S, Y \rightarrow Y S, O \rightarrow X, O \rightarrow Y$ |
| NOP: (Arithmetic/logic instruction) |  | No operation |

## PACKAGE DIMENSIONS

## 88-LEAD CERAMIC (METAL SEAL) REPEATED QUAD IN-LINE PACKAGE

 (CASE No.: RIT-88C-A01)

## DESCRIPTION

The Fujitsu MB87064 is a general-purpose LSI silicon gate Digital Signal Processor (DSP). The device is fabricated in low-power CMOS and features a high-speed pipelined multiplier, supports concurrent operations with compound instructions and multiple data paths, and offers flexible and expandable memory options. The MB87064 is housed in a 42-pin DIP.
Except for some changes in the instruction set and minor modifications in the hardware, the low-cost MB87064 DSP is a functional clone for Fujitsu's fullfeatured MB8764 DSP. The low-cost MB87064 is particularly useful in systems where the additional features of the MB8764 are simply not required. Since basic functions of the two parts are identical, this data sheet describes only those differences that affect system design. For complete functional detail pertaining to hardware and software, it is recommended that the user obtain data sheets for both parts (MB87064 and MB8764). If further information regarding Digital Signal Processing is desired, the user should request "Support Documentation for the MB8764" from the nearest Fujitsu sales office.
Both the MB87064 and the MB8764 are well suited for applications such as telecommunications, imaging work, and other signal-processing functions that require extensive computations and complex analysis.


This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

Table 1. Comparison of Features (MB87064 and MB8764)

| Item | MB8764 | MB87064 |
| :---: | :---: | :---: |
| Hardware Architecture | Common Hardware Architecture <br> - Parallel pipelined multiply function 16 bits $\times 16$ bits $\rightarrow 26$ bits <br> - Divide function 26 bits $\div 16$ bits $\rightarrow 16$ bits |  |
| Instruction Set | MB8764 Instruction Set | Basically the same as the MB8764 but with few modifications |
| Operation <br> Cycle Time | 100ns |  |
| Package | PGA88 Ceramic ${ }^{1}$ LCC84 Ceramic | DIP42 Ceramic ${ }^{1}$ |
| Program ROM | Internal (mask-programmable) ROM of 1024 words $\times 24$ bits |  |
|  | External ROM of 1024 words $\times 24$ bits selectable | No External ROM function |
| Data RAM | Built-in 2 blocks of 128 words $\times 16$ bits Expansion RAM up to 1024 words $\times 16$ bits |  |
| I/O Functions | 16-bit Parallel Interface |  |
|  | Three Input Modes Two Output Modes | Two Input Modes One Output Mode (Brand-new) |
| Addressing | Same Addressing Functions <br> - Direct Addressing <br> - Immediate Addressing <br> - Indexed Addressing <br> - Virtual Shift Addressing |  |
| Support Tools | Common Support Tools <br> - Evaluation Board <br> - Softwares (Assemblers, Linkers, Software Simulators, Monitor) <br> - In-Circuit Emulation Board² |  |
| Applications | - Flexible system with external program memory <br> - Small Volume Production with Internal/External ROM <br> - System evaluation before Production | - High Volume Production with Mask ROM |

## Notes:

1. Plastic package is scheduled for the future.
2. Soon to be available.

MB87064

BLOCK DIAGRAM


Control flag


| Pin No. | Designator | Function |  | Pin No. | Designator | Function |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Input/Output Pins: |  |  |  | Output Pins: |  |
| 09 | D15 | Data bus | Bit 15 (MSB) | 22 | EA9 | Expansion RAM Address | MSB |
| 08 | D14 | Data bus | Bit 14 | 23 | EA8 | Expansion RAM Address | Bit 8 |
| 07 | D13 | Data bus | Bit 13 | 24 | EA7 | Expansion RAM Address | Bit 7 |
| 06 | D12 | Data bus | Bit 12 | 25 | EA6 | Expansion RAM Address | Bit 6 |
| 05 | D11 | Data bus | Bit 11 | 26 | EA5 | Expansion RAM Address | Bit 5 |
| 04 | D10 | Data bus | Bit 10 | 27 | EA4 | Expansion RAM Address | Bit 4 |
| 03 | D9 | Data bus | Bit 9 | 28 | EA3 | Expansion RAM Address | Bit 3 |
| 02 | D8 | Data bus | Bit 8 | 29 | EA2 | Expansion RAM Address | Bit 2 |
| 01 | D7 | Data bus | Bit 7 | 30 | EA1 | Expansion RAM Address | Bit 1 |
| 41 | D6 | Data bus | Bit 6 | 31 | EAO | Expansion RAM address | LSB |
| 40 | D5 | Data bus | Bit 5 | 34 | $\overline{\text { EWE }}$ | ERAM Write Clock Output |  |
| 39 | D4 | Data bus | Bit 4 | 33 | $\overline{\mathrm{ECE}}$ | ERAM Chip Enable Output |  |
| 38 | D3 | Data bus | Bit 3 | 11 | CK1 | Master Clock Input Pin 1 |  |
| 37 | D2 | Data bus | Bit 2 | 12 | CK2 | Master Clock Input Pin 2 |  |
| 36 | D1 | Data bus | Bit 1 | 13 | $\overline{\text { RST }}$ | Initialization Input |  |
| 35 | D0 | Data bus | Bit 0 (LSB) | 16 | $\overline{\text { AIF }}$ | Data Input Request |  |
| 10 | GND | Circuit Ground |  | 17 | $\overline{\mathrm{RCK}}$ | Data Read Clock Input |  |
| 32 | GND | Circuit Ground |  | 18 | $\overline{\text { ACT }}$ | Data Input Enable Output |  |
| 42 | $\mathrm{V}_{\mathrm{CC}}$ | +5V Power Supply |  | 20 | REQ | Data Bus Request Output |  |
| 21 | $\mathrm{V}_{\mathrm{CC}}$ | +5B Power Supply |  | 19 | $\overline{\text { BCT }}$ | Data Bus Output Enable Input |  |
|  |  |  |  | 14 | $\overline{\mathrm{FLO}}$ | Flag Input |  |
|  |  |  |  | 15 | $\overline{\text { FL1 }}$ | Flag Input |  |

## PIN MODIFICATIONS

Based on the pin configuration of the MB8764, the following modifications have been made for the MB87064.
Removal of pins caused by no external ROM:

$$
\begin{aligned}
& \text { PA9 ~ PA0 }(10 \text { pins }) \\
& \text { IRM (1 pin) } \\
& \text { P23 ~ PO (24 pins }) \\
& \text { TST (1 pin) }
\end{aligned}
$$

Removal of pins caused by reduction/modification of input/output mode:

$$
\begin{aligned}
& \overline{\mathrm{ASL}}(1 \mathrm{pin}) \\
& \overline{\mathrm{AOF}}(1 \mathrm{pin}) \\
& \overline{\mathrm{WCK}}(1 \mathrm{pin})
\end{aligned}
$$

Removal of pins caused by modification of external RAM speed control (hardware $\rightarrow$ software):

$$
\overline{\mathrm{ESS}}(1 \mathrm{pin})
$$

Removal of unneeded power/ground pins:
GND (2 pins)
$V_{C C}$ (2 pins)

## FUNCTIONAL DESCRIPTION

## Program Memory

The program for the MB87064 is provided from the internal (mask-programmed) ROM with a capacity of 1024 words $\times 24$ bits. The MB87064 cannot access external ROM.

## Input/Output Modes

## Input Modes

Two operating modes ( D and P ) are used to input data from an external device to the MB87064. The function and timing specification for the two input modes are the same as those in the MB8764. The selected input mode is loaded into the mode (DMM) register by the program.

## Output Mode

Only one output mode is provided to transfer data from the MB87064 to an external peripheral. The output mode in the MB87064 is a modified version of the E mode in the MB8764. Output mode timing is shown in the following diagram.

Output Mode Timing


## Registers/Flags

## Register Omission

Input address register EIA, output address register EA, unit register $U$, and address mode register ADM are not required in the MB87064.

## New Registers and Flags

ESS Flag. Because the ESS pin has been removed, the MB87064 controls ERAM access speed by the ESS flag which,
in turn, is controlled by the SET/CLR instructions. The lowspeed mode (ESS = 1) is specified by the "SET ESS" instruction. It is cleared by the "CLR ESS" instruction and the highspeed mode (ESS $=0$ ) is then specified. When the device is reset, the high-speed mode is selected by default.

Because the ESS pin has been removed, the MB87064 controls ERAM access speed through the ESS flag. A two cycle access is selected by setting the ESS flag (ESS =1). and the single cycle access is selected by clearing the ESS flag (ESS = 0).
ESS is cleared upon reset ( $\mathrm{ESS}=0$ ).

TRC Register. The TRC register is a 1-bit register used to control the truncation of the multiplication result. The TRC Register is controlled by the SET/CLR instructions.
When TRC is set to " 1 ", the multiplication result is truncated to 26 -bits without rounding. When TRC is set to " 0 ", the result is rounded to 26 -bits. (Same as the MB8764.)


When TRC $=1$ (Round is omitted)


PCT Register. In the MB8764, even when operating in the CLIP mode with the overflow flag set, if two maximum negative numbers are multiplied together $[(8000 \mathrm{H}) \times(8000 \mathrm{H})]$, the resulting output from the D register to IBUS is $(0000 \mathrm{H})$. Also, if positive or negative overflows occur, the resulting
output may not be the maximum positive or negative values [ $(8000 \mathrm{H})$ or $(7 \mathrm{FFFH})]$. The MB87064 selects the PCT (protect mode) to avoid this overflow problem. The protect mode is controlled by the "PCT" flag. The "PCT" flag is set by the "SET PCT" instruction and cleared by the "CLR PCT" instruction.

The "PCT" flag is also cleared by a reset input. As with the MB8764, the normal mode is selected when the "PCT" flag is cleared.

EXA Register. The MB8764 outputs the contents of page register PGM and data pointer register DPE to the EA9 ~ EA0 pins regardless of ERAM access.
The MB87064 outputs the contents of PGM and DPE when ERAM is being accessed and outputs the contents of EXA when the I/O bus is being accessed for data transfer to-or-from an external circuit.

- The contents of EXA Register

IBUS


- Timing Specifications
- When ERAM is accessed: Same as MB8764 (input/output)
- When I/O bus is accessed: See the following timing diagram:

Input (P Mode/D Mode)


## Output (New Mode)



## Chip Enable Control Output (ECE)

In the MB8764, $\overline{\text { ECE }}$ is always set to " 0 " (expansion RAM enable state) except when the I/O bus is being accessed for data transfer to-or-from an external circuit. In the MB87064, ECE is set to " 0 " only when ERAM is being accessed. This modification helps to reduce the power consumption of ERAM.

## Hi-Impedance State of EA9 ~ EA0

Pins EA9 ~EA0 are placed in the high-impedance state when
neither ERAM nor I/O bus is accessed. This avoids address bus conflicts when multiple DSPs are used.

## Reset Input According to $\overline{\mathrm{FLO}}$ and $\overline{\mathrm{FL1}}$ Status

The Reset signal ( $\overline{\mathrm{RST}}$ ) must be input while $\overline{\mathrm{FLO}}$ and $\overline{\mathrm{FL1}}$ are set to " 1 ". The operation of the reset input flag is the same as the MB8764.

SET ADM CLR ADM

The following instructions are added:

| SET ESS | CLR ESS |  |
| :--- | :--- | :--- |
| SET | TRC | CLR TRC |
| SET PCT | CLR PCT |  |

Object code of SET instruction


| $\mathbf{a}$ | $\mathbf{b}$ | $\mathbf{c}$ | $\mathbf{d}$ | $\mathbf{e}$ | $\mathbf{f}$ | $\mathbf{g}$ | $\mathbf{h}$ | set register |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DMM |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | PCT |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | VS |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | ESS |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | CLP |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | TRC |$\leftarrow$ new

Object code of CLR instruction


| $\mathbf{a}$ | $\mathbf{b}$ | $\mathbf{c}$ | $\mathbf{d}$ | $\mathbf{e}$ | $\mathbf{f}$ | $\mathbf{g}$ | $\mathbf{h}$ | $\mathbf{i}$ | $\mathbf{j}$ | $\mathbf{k}$ | $\mathbf{l}$ | $\mathbf{m}$ | $\mathbf{n}$ | $\mathbf{o}$ | $\mathbf{p}$ | $\mathbf{q}$ | $\mathbf{r}$ | $\mathbf{s}$ | cleared register |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $\mathbf{D}$ |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | F0 |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | F1 |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DMC |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | A |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | B |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | X |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Y |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DMM |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PCT |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | IF |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | OF |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | VS |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | ESS |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | OV |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | CLP |

- multiple registers can be specified
- execution cycle: one


## MOV Instruction

According to the EXA register addition, the destination of EXA register is added to the following MOV instruction:

MOV[:arithmetic/logic operation]\$a(8)[([Y][E])],Reg[:Reg[…]...]
machine code
MSB LSB

a: RAM address c: operation
t: destination

|  |  |  |  |  | destination register |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 | 0 | 0 | EO |
| 0 | 1 | 0 | 0 | 0 | 0 | A |
| 0 | 0 | 1 | 0 | 0 | 0 | B |
| 0 | 0 | 0 | 1 | 0 | 0 | $D$ |
| 0 | 0 | 0 | 0 | 1 | 0 | EXA (lower 10 bits of RAM data) |

- Two or more destination registers can be selected at once.


## MOV Instruction (Cont.)

- An arithmetic/logic operation cannot be performed when the destination register is $D$.
According to EXA register addition, the processing of " $d \rightarrow$ EXA" is added.


## MOV \#\$d,Reg

machine code
MSB LSB


| $t$ |  | processing | mnemonic |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | $d \rightarrow E O$ |
| 0 | 0 | 1 | output instruction |
| 0 | 1 | 0 | MOV \#\$d,EO |
| 0 | 1 | 1 | $d \rightarrow D$ |
| 1 | 0 | 1 | $d$ (lower ten bits) $\rightarrow$ EXA |

## Note:

Though the EA register does not exist, this instruction does exist in the MB87064 to maintain compatibility of output instruction with MB8764. This instruction is only effective as an output instruction and the processing of " $d \rightarrow E A$ " is ignored.

## ELECTRICAL CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS ${ }^{1}$

| Parameter |  | Value |  |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Symbol | Min | Max | Unit |
|  |  | $-0.3^{2}$ | 6.0 | V |
| Input Voltage | $\mathrm{V}_{\mathrm{I}}$ | $-0.3^{2}$ | $\mathrm{~V}_{\mathrm{CC}}+0.3^{2}$ | V |
| Output Voltage | $\mathrm{V}_{\mathrm{O}}$ | $-0.3^{2}$ | $\mathrm{~V}_{\mathrm{CC}}+0.3^{2}$ | V |
| Operating Temperature | $\mathrm{T}_{\text {OP }}$ | -40 | 85 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 | 150 | ${ }^{\circ} \mathrm{C}$ |

## Notes:

1. Permanent device damage may occur if the absolute maximum ratings are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
2. This value applies for a steady-state condition. The incremental voltage can be increased to a value of 0.5 V for periods not to exceed 20 -to- 30 nanoseconds.

## RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| Power Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5.0 | 5.5 | V |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | -40 |  | 85 | ${ }^{\circ} \mathrm{C}$ |

DC CHARACTERISTICS
(Recommended Operating Conditions unless otherwise specified.)
Operating Temperature Range $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| Parameter | Symbol | Condition | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | Other than CK1, CK2 | 2.2 |  | $V_{C C}+0.3$ | V |
|  | $V_{\text {IHCK }}$ | CK1, CK2 | 4.0 |  | $V_{C C}+0.3$ | V |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | Other than CK1, CK2 | -0.3 |  | 0.8 | V |
|  | $\mathrm{V}_{\text {ILCK }}$ | CK1, CK2 | -0.3 |  | 0.6 | V |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | 2.7 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ | 0 |  | 0.4 | V |
| Input Leakage Current | $l_{\text {LI }}$ | $\mathrm{V}_{1}=0$ to 5.5 V | -10 |  | 10 | $\mu \mathrm{A}$ |
| Input Leakage Current (Three-state Pin Input) | ILZ | $V_{1}=0$ to 5.5 V | -20 |  | 20 | $\mu \mathrm{A}$ |
| Static Power Supply Current | Iccs |  |  | 10 |  | $\mu \mathrm{A}$ |
| Power Supply Current | $I_{\text {cc }}$ | $\mathrm{f}_{\mathrm{OP}}=8 \mathrm{MHz}$ |  | 50 |  | mA |

Operating Temperature Range $=\mathbf{- 4 0} \mathrm{C}$ to $85^{\circ} \mathrm{C}$

| Parameter | Symbol | Condition | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | Other than CK1, CK2 | 2.8 |  | $V_{C C}+0.3$ | V |
|  | $\mathrm{V}_{\text {IHCK }}$ | CK1, CK2 | 4.0 |  | $V_{C C}+0.3$ | V |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | Other than CK1, CK2 | -0.3 |  | 0.8 | V |
|  | $V_{\text {ILCK }}$ | CK1, CK2 | -0.3 |  | 0.6 | V |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{IOH}=-0.4 \mathrm{~mA}$ | 2.7 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ | 0 |  | 0.4 | V |
| Input Leakage Current | $I_{L I}$ | $\mathrm{V}_{1}=0$ to 5.5 V | -25 |  | 25 | $\mu \mathrm{A}$ |
| Input Leakage Current (Three-state Pin Input) | ILZ | $\mathrm{V}_{1}=0$ to 5.5 V | -40 |  | 40 | $\mu \mathrm{A}$ |
| Static Power Supply Current | Iccs |  |  | 50 |  | $\mu \mathrm{A}$ |
| Power Supply Current | ICC | $\mathrm{f}_{\mathrm{OP}}=8 \mathrm{MHz}$ |  | 60 |  | mA |

## INPUT/OUTPUT CAPACITANCE

$\left(\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{1}=0 \mathrm{~V}, \mathrm{f}_{\mathrm{OP}}=8 \mathrm{MHz}\right)$

| Parameter | Symbol | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| Input Pin | $\mathrm{C}_{\mathrm{IN}}$ |  |  | 6 | pF |
| Output Pin | Cout |  |  | 6 | pF |
| I/O Pin | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  |  | 8 | pF |

## Package Dimension



## FUJITSU

ADPCM DIGITAL SIGNAL PROCESSOR

## DESCRIPTION

The Fujitsu MB87067/MB87068 Digital Signal Processor (DSP) consists of two MB8764 DSPs each with an applications-specific program in the internal ROM. Together, the MB87067/MB87068 chip set provides all coding/decoding functions required to process Adaptive Pulse Code Modulation (ADPCM) signals. The MB87067 provides the encoding function and the MB87068 provides the decoding function. Under direction of the ADPCM programs stored in the two devices, the chip set allows the user to implement a CCITT standard ADPCM CODEC without any program development work. For complete electrical characteristics and functional detail of the MB8764 DSP, the user should refer to the current data sheet and, for additional DSP support, contact the nearest Sales Office of Fujitsu.

## FEATURES

- High-performance design based on MB8764 DSP (Same electrical and timing specifications.)
- CCITT standard ADPCM coding/decoding (Selectable $\mu$-law/A-law PCM).
- MB87067 provides u-law PCM bit-steal function: 7-bit decode function and bit-steal receiving function.
- ADPCM bit-steal function with transmit/receive signaling.
- TTL interface.
- Silicon gate CMOS fabrication process.


Ceramic Package

RIT-88C-A01

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

- Single 5-volt power supply.
- 88-pin grid array (PGA) package.


## PIN ASSIGNMENTS



| No. | Name | No. | Name | No. | Name | No. | Name | No. | Name | No. | Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | PA1 | 16 | EAO | 31 | D14 | 46 | P23 | 61 | EA7 | 76 | CK2 |
| 2 | PA0 | 17 | - | 32 | $\overline{\mathrm{REQ}}$ | 47 | P21 | 62 | EA9 | 77 | TST |
| 3 | P22 | 18 | EA3 | 33 | $\overline{\text { BCT }}$ | 48 | P18 | 63 | ECE | 78 | PA9 |
| 4 | P20 | 19 | EA5 | 34 | RCK | 49 | P16 | 64 | D2 | 79 | PA6 |
| 5 | P19 | 20 | EA6 | 35 | $\overline{\text { RST }}$ | 50 | P15 | 65 | D4 | 80 | PA4 |
| 6 | P17 | 21 | EA8 | 36 | FLO | 51 | P13 | 66 | D7 | 81 | GND |
| 7 | P14 | 22 | EWE | 37 | WCK | 52 | P10 | 67 | D9 | 82 | VCC |
| 8 | P12 | 23 | D0 | 38 | ESS | 53 | P8 | 68 | D10 | 83 | VCC |
| 9 | P11 | 24 | D1 | 39 | CK1 | 54 | P6 | 69 | D12 | 84 | GND |
| 10 | P9 | 25 | D3 | 40 | IRM | 55 | P3 | 70 | D15 | 85 | GND |
| 11 | P7 | 26 | D5 | 41 | PA8 | 56 | P1 | 71 | $\overline{\text { ACT }}$ | 86 | VCC |
| 12 | P5 | 27 | D6 | 42 | PA7 | 57 | EA1 | 72 | $\overline{\text { AIF }}$ | 87 | VCC |
| 13 | P4 | 28 | D8 | 43 | PA5 | 58 | - | 73 | $\overline{\mathrm{FL1}}$ | 88 | GND |
| 14 | P2 | 29 | D11 | 44 | PA3 | 59 | EA2 | 74 | AOF |  |  |
| 15 | P0 | 30 | D13 | 45 | PA2 | 60 | EA4 | 75 | $\overline{\text { ASL }}$ |  |  |

PIN DESCRIPTIONS

| Pin No. | Designator | Function | MB87067 | MB87068 |
| :---: | :---: | :---: | :---: | :---: |
| 70 | $\begin{aligned} & \text { D15 } \\ & \text { D14 } \end{aligned}$ | Data Bus MSB Data Bus BIT14 | $\mu$-law/A-law select |  |
| 31 |  |  | 7-bit coding select | */* |
| 30 | D13 | Data Bus BIT13 | *** | *** |
| 69 | D12 | Data Bus BIT12 | ** | */* |
| 29 | D11 | Data Bus BIT11 | */* | ** |
| 68 | D10 | Data Bus BIT10 | */* | ** |
| 67 | D9 | Data Bus BIT9 | *** | ** |
| 28 | D8 | Data Bus BIT8 | ** | ** |
| 66 | D7 | Data Bus BIT7 | PCM in/* | * / PCM out |
| 27 | D6 | Data Bus BIT6 | PCM in/ * | * / PCM out |
| 26 | D5 | Data Bus BIT5 | PCM in/* | * / PCM out |
| 65 | D4 | Data Bus BIT4 | PCM in/ * | * / PCM out |
| 25 | D3 | Data Bus BIT3 | PCM in/ADPCM out | ADPCM in/ PCM out |
| 64 | D2 | Data Bus BIT2 | PCM in/ADPCM out | ADPCM in/ PCM out |
| 24 | D1 | Data Bus BIT1 | PCM in/ADPCM out | ADPCM in/ PCM out |
| 23 | D0 | Data Bus LSB | PCM in/ADPCM out | ADPCM in/ PCM out |
| 34 | $\overline{\text { RCK }}$ | Data read clock |  |  |
| 33 | $\overline{\mathrm{BCT}}$ | Data bus output enable |  | signal |
| 72 | $\overline{\text { AIF }}$ | Data input request |  |  |
| 37 | $\overline{\text { WCK }}$ | Data write clock |  |  |
| 74 | $\overline{\text { AOF }}$ | Output data type specification |  |  |
| 71 | $\overline{\text { ACT }}$ | Input enable |  |  |
| 62 | EA9 | Expansion RAM address MSB | PCM bit steal out | ADPCM bit steal out |
| 36 | $\overline{\mathrm{FLO}}$ | Flag input | Signaling input | Set to "1" |
| 73 | $\overline{\mathrm{FL1}}$ | Flag input |  | on/off |
| 35 | $\overline{\text { RST }}$ | Initialization |  |  |
| 39 | CK1 | Master clock input pin 1 |  | lock |
| 76 | CK2 | Master clock input pin 2 |  | lock |
| 40 | IRM | Internal/External ROM switching |  |  |
| 77 | TST | Internal ROM test mode |  |  |
| 75 | $\overline{\text { ASL }}$ | Data output type specification |  |  |
| 38 | ESS | ERAM speed select |  |  |
| 22 | EWE | ERAM write clock |  |  |
| 63 | $\overline{E C E}$ | ERAM chip enable |  |  |
| 32 | $\overline{\mathrm{REQ}}$ | Data bus request |  |  |

Legend:
*Unused pin

## APPLICATIONS



## PACKAGE DIMENSIONS



# SERIAL INTERFACE 

## DESCRIPTION

The Fujitsu MB87069 is a dedicated Serial Interface Adapter (SIA) that provides cost-effective interface support between the Fujitsu MB8764 Digital Signal Processor (DSP), PCM CODECs, and general purpose microprocessors. Some interface examples are shown later in this document.

## FEATURES

- Supports MB8764 for interface of PCM CODEC and microprocessor
- Serial I/O functions (dual input/output lines)
- Conversion circuits for $\mu$-law/A-law data to linear data and vice-versa
- Interface circuit for microprocessor
- Software-controlled operations from MB8764 or microprocessor
- Silicon-gate CMOS process
- 64-pin Pin Grid Array (PGA) package


This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

## PIN ASSIGNMENTS

| $\begin{gathered} 28 \\ 0 \end{gathered}$ | $\begin{gathered} 27 \\ 0 \end{gathered}$ | $\begin{gathered} 26 \\ 0 \end{gathered}$ | $\begin{gathered} 25 \\ 0 \end{gathered}$ | $\begin{gathered} 24 \\ 0 \end{gathered}$ | $\begin{gathered} 23 \\ 0 \end{gathered}$ | $\begin{gathered} 22 \\ 0 \end{gathered}$ | $\begin{gathered} 21 \\ 0 \end{gathered}$ | $\begin{gathered} 20 \\ 0 \end{gathered}$ | O19 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 |  |
|  | 0 | 0 | - | 0 | 0 | O | 0 | 0 | 018 |
|  |  |  |  |  | GND |  |  |  |  |
| 300590 |  |  |  |  |  |  |  |  | 0017 |
| 310600 |  |  |  |  |  |  |  |  | 9016 |
| 32 O 10 VDD |  |  | (TOP VIEW) |  |  |  |  |  | 8015 |
|  |  |  |  |  |  |
| 330620 |  |  |  |  |  |  |  |  |  |  | vDD O47O14 |  |  |
| 340630 |  |  |  |  |  |  |  |  | 6013 |
| 350640 |  |  |  |  |  |  |  |  | 5012 |
|  | O | O | 0 | GND | 0 | O | $\bigcirc$ | O | 011 |
|  | 37 | 38 | 39 | 40 |  | 42 | 43 | 44 |  |
| $\bigcirc$ | O | $\bigcirc$ | $\bigcirc$ | 0 | O | $\bigcirc$ | O | $\bigcirc$ |  |
|  | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |  |


| Pin <br> No. | I/O | Pin <br> Name | Pin <br> No. | I/O | Pin <br> Name | Pin <br> No. | I/O | Pin <br> Name | Pin <br> No. | I/O | Pin <br> Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Output | XBCT | 17 | I/O | CLOB | 33 | Output | XCK3 | 49 | Input | BSIA |
| 2 | Output | XAIF | 18 | I/O | SYOB | 34 | Output | XASL | 50 | Output | SODB |
| 3 | Input | XACT | 19 | Input | BSIB | 35 | Output | XFLO | 51 | Input | AD2 |
| 4 | I/O | D15 | 20 | Input | AD1 | 36 | Output | XRCK | 52 | Input | XMCE |
| 5 | I/O | D12 | 21 | Input | AD0 | 37 | Inut | XREQ | 53 | Input | XMWE |
| 6 | I/O | D11 | 22 | I/O | DB7 | 38 | I/O | D14 | 54 | - | GND |
| 7 | I/O | D8 | 23 | I/O | DB6 | 39 | I/O | D13 | 55 | I/O | DB4 |
| 8 | I/O | D6 | 24 | I/O | DB5 | 40 | - | GND | 56 | I/O | DB2 |
| 9 | I/O | D5 | 25 | I/O | DB3 | 41 | I/O | D10 | 57 | I/O | DB0 |
| 10 | I/O | D3 | 26 | I/O | DB1 | 42 | I/O | D9 | 58 | Input | SIDB |
| 11 | I/O | D2 | 27 | Output | XIRQ | 43 | I/O | D7 | 59 | Output | IBSA |
| 12 | I/O | D0 | 28 | Output | IBSB | 44 | I/O | D4 | 60 | Input | SIDA |
| 13 | Input | XEWE | 29 | Input | SYIB | 45 | I/O | D1 | 61 | - | VCC |
| 14 | Input | EA0 | 30 | Input | CLIB | 46 | Input | XRCE | 62 | Input | MCLK |
| 15 | I/O | SYOA | 31 | Input | CLIA | 47 | - | VCC | 63 | Input | XRST |
| 16 | I/O | CLOA | 32 | Input | SYIA | 48 | Output | SODA | 64 | Output | XDRS |

## BLOCK DIAGRAM



## BLOCK ANALYSIS

## Registers RA1 and RA2

These two 8-bit shift registers generate parallel data input from serial input port A. Register RA2 is only used for 16-bit inputs; the lower 8 bits are stored in RA1 and the upper 8 bits are stored in RA2.

## Registers RB1 and RB2

These two registers perform the same function for serial input port B as RA1 and RA2 perform for port A.

## Non-Linear to Linear Converter (NL $\rightarrow \mathbf{L}$ )

Converts $\mu$-law/A-law data to linear data.

## Registers SA1 and SA2

When data is received from the MB8764, these registers perform a parallel-to-serial conversion and transfer the data to serial input port A. Register SA2 is only used for 16-bit data; in this case, the lower 8 bits are stored in SA1 and the upper 8 bits are stored in SA2.

## Registers SB1 and SB2

These two registers perform the same function for serial input port B as SA1 and SA2 perform for port A.

## Linear to Non-Linear Converter ( $\mathbf{L} \rightarrow \mathbf{N L}$ )

Converts linear data to $\mu$-law/A-law data.

## Registers IR1 and IR2

Buffer interface registers for MB8764.

## Registers OR1 and OR2

These two interface registers are used when data is transferred from the MB8764 DSP to the microprocessor.

## Registers ST2, ST10, and ST11

These registers perform handshake interface functions between the microprocessor and the SIA.

## Control (CTRL) Register

This register specifies the operating mode of the SIA.

TYPICAL APPLICATIONS
Interface Between MB8764 (DSP) and MB6021/22
(CODEC) With MB87069 (SIA)


Interface Between MB87069 and Microprocessor (MC6800)


SYSTEM CONFIGURATIONS

## Echo Canceller



Microprocessor Interface Circuit


32 kbps ADPCM CODEC


## PACKAGE DIMENSIONS



## Section 7

ROM Code Development Procedure


## ROM CODE DEVELOPMENT

All 4-bit Microcomputers and some 8-bit microcomputers from Fujitsu are available with a mask ROM; thus, the Customer can develop a proprietary system that is efficient and very cost-effective. The ROM can be submitted in the form of an EPROM or the Customer can submit the device actually used to develop the code (MBL8742, MBL8749H, or equivalent). The code submittal must be accompanied by a Data Release Form that specifies mask options, package markings, delivery expectations, production quantities, and other relevant data.

The submitted code is processed by Fujitsu and returned to the Customer in the form of an EPROM for code verification. Before code submittal, the Customer can choose either of two options.

Option 1: If there is absolute certainty that the code is accurate and there will be no changes, the Customer can commit the code to production. In this case, Fujitsu will design the mask, finalize the package specifications, and produce the part in production quantities. As shown in the ROM Code Development Flowchart, the Customer assumes all risks for accuracy of code supplied to Fujitsu.

Option 2: After code verification, the Customer may choose to wait for engineering samples before committing the code to production assuring Customer control of production device configuration. However, the wait for production parts is extended.

For simple codes or for those with minor deviations from working samples, a risk order may be justified. Likewise, if tried-and-proven codes are being processed by Fujitsu to save time or money, a risk order will expedite production. For design prototypes or for systems with complex control features, the non-risk order is recommended.

The Customer should review the following flowchart and become familiar with ROM-code development procedures. All required code-development forms are available at Fujitsu Sales Offices or the Customer can simply contact the FMI Sales Representative for additional information.

FLOWCHART OF ROM CODE DEVELOPMENT


## Section 8

## Quality Assurance and Reliability

## Quaiity Control at Fujitsu

Quality control for all Fujitsu products is an integrated process that crosses all lines of the manufacturing cycle. The QC process begins with incoming inspection of all raw materials and ends with shipping tests and reliability tests following final test of the finished product. Prior to warehousing, Fujitsu products have been subjected to the scrutiny of man, machine, and technology and are ready to serve the Customer in the designated application.

## QUALITY CONTROL FLOWCHART



## Legend:

Production processTest/InspectionO Production process and test/Inspection
$\diamond Q C$ gate (sampling)
Note:
The flow sequence may vary slightly with individual product type.

## Section 9

\section*{| Ordering Information |
| :--- | :--- |}


| 9-2 | Product Marking |
| :--- | :--- |
| $9-2$ | Ordering Codes |
| $9-3$ | Office Locations |

## Ordering Information

Product Marking


## Ordering Codes



MB Device type is Fujitsu Internal Number
MBL Device type is Second Source

Note: Regarding ordering code, please contact your Fujitsu Sales Office for more information.

## Package Codes

| Ceramis |  | Plastic |  |
| :---: | :---: | :---: | :---: |
| Package Type | Package Code | Package Type | Package Code |
| LCC (Leaderless Chip Carrier) | CV | LCC (Leaderless Chip Carrier) | PV |
| PGA (Pin Grid Array) | CR | PGA (Pin Grid Array) | PR |
| DIP (Side Brazed) ${ }^{1}$ | C | DIP (Dual Inline Package) | P |
| DIP (CERDIP) ${ }^{2}$ | Z | Shrink DIP | PSH |
| Shrink DIP | CSH | Flat | PF |
| Flat | CF |  |  |

1

2


## Headquarters Locations

World Headquarters
Fujlisu Limited
Furukawa Sogo Bldg., 6-1
Marunouchi 2-chrome, Chlyoda-ku
Tokyo 100, Japan
Phone National (03) 216-3211
International (Int'I Prefix)
81-3-216-3211
Telex: 2224361 FT TOR J
North/South American Headquarters
Fujitsu Microelectronics, Inc.
3320 Scott Blvd.
Santa Clara, Ca. 95054-3197
Phone: (408) 562-1000
Telex: (910) 338-0190
FUJITSU SNTA

European Headquarters
Fujlitsu Mikroelektronik $\mathbf{G m b H}$
Arabella Center 9, OG./A
Lyoner Strabe 44-48 D-6000
Frankfurt 71, F.R. Germany
Phone: 069/66 320
Telex: 0411963

## AsianIPacific Headquarters

Fujitsu Microelectronics FMP
805 Tsim Sha Tsul Centre
West Wing 66
Mody Road, Kowloon
Hong Kong
Phone: 852-3-7320100
Telex: 31959 FUJIS HX

## Sales Office Locations - USA

## HEADQUARTERS

Fujitsu Microelectronics, Inc. 3320 Scott Boulevard
Santa Clara, CA 95054-3197
(408) 562-1000

TWX: 910-338-0190

## NORTHERN

CALIFORNIA
Fujltsu Microlectronics, Inc.
595 Millich Drive
Sulte 210
Campbell, CA 95008
(408) 865-5600

TWX: (910) 590-8003
SOUTHERN
CALIFORNIA
Fujitsu Microelectronics, Inc.
840 Newport Center Drtive
Suite 460
Newport Beach, CA 92660
(714) 720-9688

TWX: (910) 595-1587

## ATLANTA

Fujitsu Microelectronics, Inc.
3169 Holcomb Bridge
Suite 506
Norcross, GA 30071
(404) 449-8539

TWX: (810) 766-4542

## BOSTON

Fujitsu Microelectronics, Inc.
57 Wells Avenue
Newton Centre, MA 02159
(617) 964-7080

TWX: (710) 335-7701

## CHICAGO

Fujitsu Microelectronics, Inc. 1501 Woodfield Road Suite 202, South Bldg. IV Schaumburg, IL 60195
(312) 885-1500

TWX: 910-687-7378

## DALLAS

Fuiltsu Microelectronics, Inc. 1101 East Arapaho Road Sulte 225
Richardson, TX 75081
(214) 669-1616

TWX: (910) 867-9434

## MINNEAPOLIS

Fujitsu Microelectronics, Inc. 3460 Washington Avenue
Eagan, MN 55122
(612) 454-0323

TELEX: 201-670

## NEW YORK

Fulitsu Microelectronics, Inc. 601 Veterans Memorial Highway Suite P
Hauppauage, NY 11788
(516) 361-6565

TWX: 510-227-1049


## France

Fujitsu Mikroelektronik
Bureau de Liaison
Tour Rosny II
93118 Rosny Sous Bois Cedex
Phone: (1) 48551646
Telex: 231684
Italy
Fujitsu Microelectronics Italia
SRL
Centro Direzionalo Milanofiori Palazzo A2
1-20090 Assago - Milano
Phone: 39-2-824-6170
FAX: 39-2-824-6189

## Netherlands

Fujltsu Component Europe, B.V.

Rijnkade 19B, 1382 GS,
Weesp,
The Netherlands
Phone:
31-2940-18748/18914
Telex: 44-11966
North Germany
Fujitsu Mikroelektronik GmbH
Lyoner Strasse 44-48
Arabella Center 9.OG/A
D-6000 Frankfurt-Niederrad
71
Phone: (0 69) 66320
Telex: 411963
Fax: (0 69) 6632122

## Scandinavia

Fujitsu Microelectronics Ltd.
Industrigaten 2A, plan 7
s-112 46 Stockholm
Sweden
Phone: 878500 67/68
Telex: 13411 FNAB
Fax: 8531634

South Germany
Fujitsu Mikroelektronik GmbH Arbeostrasse 5
D-8057 Eching bel Muenchen
Phone: (0 89) 3191015
Telex: 5213905

## United Kingdom

Fujitsu Microelectronics Ltd.
Hargrave House
Belmont Road
Maldenhead
Berkshire SL6 6NE
Phone: (06 28) 76100
Telex: 848955

## Representatives/Distributors - Europe

## Austria

Atel Electronics
Eitnergasse 6
1232 Wien
Phone: (222) 861531
Telex: 112344

## Belgium

ERIAT SA
International S.A.
Rue de Fraisiers 89
4410 Herstal-Vottem
Phone: (41) 274263
Telex: 41782

## Denmark

Nordisk Elektronik AS
Transformervej 17
2370 Herlev
Phone: (02) 842000
Telex: 35200

## Finland

Gadelius OY
Kaupintie 18
00440 Helsinki
Phone: (80) 5626644
Telex: 121274
OY Comdax AB
Itaelahderkato 23A
00210 Helsinkl 21
Phone: (90) 0670277
Telex: 125876
France
ERN
237 rue de Foumy
Z. A. Buc
78530 Buc
Phone: (33) 9560011
Microram
6. reu le Corbusier
Silic 424
94583 Rungis Cedex
Phone: (1) 6868170
Telex: 206952
Germany
MHV Microhalbleiter GmbH
Jaegerweg 10
8012 Ottobrunn
Phone: (0 89 ) 6096068
Telex: 5213807
Italy
Konton S.p. a.
Via G. Fantoli, $16 / 15$
20138 Milano, Italy
Phone: (02) 50722174
Telex: 312288 Kontmi
Netherlands
P \& T Electronics Int. B.V.
Esse Baan 77
P.O. Box 329
2900 LJ Capelle A/D ljessel
Phone: (31) 10501444
Telex: 26096
Microtronica
Kaap de Goede Hooplaan II
3526 AR Utrecht
Phone: $(030) 880084$
Telex: 40744

Norway
Odin Electronics AS
EDV Griegsvei 2
1472 Fjellhamar
P.O. Box 72
Phone: (02) 703730
Telex: 19 732

Sweden
Saxab
Nax
P.O. Box 4115
17104 Solna
Phone: (08) 985140
Telex: 17 912

Switzerland
Eijapex AG
Hardstrasse 72
5430 Wettingen
Phone: (0 56 ) 263052
Telex: 58068

## Spain

Diode
Edificio lberia Mart
Avda. de Brasil 5
Madrid 20
Phone: (1) 4553686
Telex: 42148

Litton Precision
Condes del Val 8
28030 Madrid
Phone: (1) 2501507
Telex: 44730

United Kingdom
Ambar Components Ltd.
Rabans Close
Aylesbury Bucks
HP 19 3RS
Phone: (0296) 34141

Hawke
Amotex House
45 Hawworth Road
Sunbury
Midox
TW 16 SDA
Phone: 19797799
Telex: 923592

North America

## Alabama

The Novus Group, Inc. 14005 Coy's Drive Huntsville, AL 35803 (205) 881-2207

## Arizona

Thom Luke Sales 2940 North 67th Place Suite H
Scottsdale, AZ 85251
(602) 941-1901

## California

Harvey King, Inc.
6393 Nancy Ridge Drive San Diego, CA 92121
(619) 587-9300

Hi-Tech Rep Company
31332 Via Colinas
Suite 109
Westlake Village, CA 91362
(818) 706-2916

Hi-Tech Rep Company
1111 El Camino Real
Suite 104
Tustin, CA 92680
(714) 730-9561

Norcomp, Inc.
3350 Scott Blvd.
Suite 24
Santa Clara, CA 95054 (408) 727-7707

## Canada

Great Northern Technology 3700 Gilmore Way Suite 425
Burnaby, BC V5G 4M8
Pipe Thompson Limited 5468 Dundas Street W. Suite 206 Islington, Ontario M9B 6E3 (416) 236-2355

Pipe Thompson Limited RR2 North Gower Ottawa, Ontario KOA 2 TO (613) 258-4067

Pipe Thompson Limited 769 Madeleine Street Laval, Quebec H7P 3W6 (514) 628-1393

Connecticut
Contech Sales, Inc. 70 White Turkey Road Suite 8
Brookfield, CT 06804
(203) 743-8936

## Florida

Semtronic Associates, Inc. 657 Maitland Avenue Altamonte Springs, FL 32701 (305) 831-8233

Semtronic Associates, Inc.
1467 S. Missouri Avenue Clearwater, FL 33516 (813) 461-4675

Semtronic Assoclates, Inc. 3471 N.W. 55th Street Ft. Lauderdale, FL 33309 (305) 731-2484

## Georgia

The Novus Group, Inc. 4556 Canda Drive Lilburn, GA 30247 (404) 381-1015

## Iowa

Electromec Sales 1500 2nd Avenue Sulte 205
Cedar Rapids, IA 52403 (319) 362-6413

## Idaho

Cascade Components
2419 W. State Street
Suite 10
Boise, ID 83702
(208) 343-9886

Illinois
Beta Technology
510 Mitchell Road
Glendale Heights, IL 60139
(312) 790-9886

## Indiana

Fred A. Dorsey and Associates
6525 East 82nd Street Suite 112
Indianapolis, IN 46250
(317) 842-0060

## Kansas

Kebco, Inc.
16047 East Kellog
Wichita, KS 67230
(316) 733-1301

Massachusetts
Mill-Bern Associates 120 Cambridge Street Suite 8
Burlington, MA 01803
(617) 273-1313

## Maryland

Component Sales 106 Old Court Road Suite 204
Baltimore, MD 21208
(301) 484-3647

Michigan
AP Associates
9903 Webber
P.O. Box 777

Brighton, MI 48116
(313) 229-6550

Minnesota
Electromec Sales 1601 East Highway 13 Suite 200
Burnsville, MN 55337
(612) 894-8200

Missouri
Kebco, Inc.
1810 Craig Road
Suite 102
St. Louis, MO 63146 (314) 576-4111

North Carolina
The Novus Group, Inc.
4234 Bertram Drive
Raleigh, NC 27604
(919) 872-3966

New Jersey
BGR Associates
Evesham Commons 525 Route 73, Ste 100 Marlton, NJ 08053 (609) 983-1020

Technical Applications Marketing
2 Ridgedale Avenue
Suite 370
Cedar Knolls, NJ 07927
(201) 285-9094

## New York

Quality Components
116 Fayette Street
Manilus, NY 13104
(315) 682-8885

Quality Components 3343 Harlem Road Buffalo, NY 14225 (716) 837-5430

Technical Applications
Marketing
1757 Veterans Memorial Hwy Sulte 408
South Hauppauge, NY 11722 (516) 348-0800

## Ohio

Bear Marketing
3623 Brecksville Road
P.O. Box 427

Richfield, OH 44286
(216) 659-3131

Bear Marketing
1563 E . Dorothy Lane
Sulte 104
Kettering, OH 45429 (513) 229-5877

## Oklahoma

Genzel Sales Associates
4135 South 100 East Avenue
Suite 101
Tulsa, OK 74146
(918) 622-7744

## Oregon

L-Squared Limited 4540 S.W. Hall Blvd Beaverton, OR 97005 (503) 644-8555

## Puerto Rico

Semtronics Association Mereantil Plaza Building Suite 816
Hato Rey, PR 00918

## Texas

Technical Marketing, Inc. 3320 Wiley Post Road Carroliton, TX 75006

Technical Marketing, Inc. 9027 Northgate Blvd.
Suite 140
Austin, TX 78758
Technical Marketing, Inc.
2901 Wilcrest Drive
Suite 139
Houston, TX 77042

## Utah

Front Range Marketing
2520 S. State Street
Suite 117
Salt Lake City, UT 84115
(801) 364-6481

## Washington

L-Squared Limited
10502 Riviera Place, NE
Seattle, WA 98125 (206) 526-0641

## Wisconsin

Beta Technology
9401 Beloit Street
Suite 304 C
Milwaukee, WI 53227
(414) 543-6609

## South America

Brasil
HI-TECH Industrial Ltd.
801 Conj. 111-121 Brooklin
Sao Paulo, Brasil 04571

Coselbra Industrial Ltda.
R. Olinda 280

04761 Sao Paulo Brasil SP.

## Minnesota

Diplomat Electronics
14920 28th Ave. N.
Plymouth, MN 55441
(612) 559-2500

Marshall Industries
3800 Annapolis Lane
Plymouth, MN 55441
(612) 559-2211

Time Electronics
7488 West 78th Street
Bloomington, MN 55435
(612) 944-9192

## Missouri

Time Electronics
330 Sovereign Court
St. Louis, MO 63011
(314) 391-6444

North Carolina
Marshall Industries
5221 North Boulevard
Raleigh, NC 27604
(919) 878-9882

Time Electronics
9800L Southern Pine BIvd.
Charlotte, NC 28210
(704) 522-7600

New Jersey
Diplomat Electronics
490 S. River View Drive
Totawa, NJ 07512
(201) 785-1830

Marshall Industries
101 Fairfield Road
Fairfield, NJ 07006
(201) 882-0320

Marshall Industries
1021 Gaither Drive
Mt. Laurel, NJ 08054
(609) 234-9100

Milgray
3002 Greentree Exec. Campus
Suite B
Marlton, NJ 08053
(609) 983-5010

Vantage Electronics
23 Sebago Street
Clifton, NJ 07013
(201) 777-4100

New York
Current Components 215 Marcus Boulevard Hauppauge, NY 11787
(516) 273-2600

Diplomat Electronics
110 Marcus Drive
Melville, NY 11747
(516) 454-6400

129 Brown Street
Johnson City, NY 13790
(607) 798-1611

Marshall Industries 1280 Scottsville Road Rochester, NY 14624
(716) 235-7620

Marshall Industries
275 Oser Ave.
Hauppauge, NY 11788
(516) 273-2424

Mast Distributors

## 215 Marcus Blvd.

Hauppauge, NY 11788
(516) 273-4422

Milgray
77 Schmidt Blvd.
Farmingdale, NY 11788 (516) 420-9800

Milgray
57 Monroe Ave.
Pittsford, NY 14534
(716) 385-9330

Rome Electronics
216 Erie Boulevard, E.
Rome, NY 13440
(315) 337-5400

Vantage Electronics
356 Veterans Memorial High-

## way

Commack, NY 11725
(516) 543-2000

## Ohio

Marshall Industries
6212 Executive Blvd.
Dayton, OH 45424
(513) 236-8088

Marshall Industries
5905B Harper Road
Solon, OH 44139
(216) 248-1788

## Milgray

6155 Rockside Road
Cleveland, OH 44131
(216) 881-8800

## Reptron

404 E. Wilson Bridge Road
Suite A
Worthington, OH 43085
(614) 436-6675

Time Electronics
6175H Shamrock Court
Dublin, OH 43017
(614) 761-1100

## Oklahoma

Radio Inc.
1000 South Main
Tulsa, OK 74119
(918) 587-9123

## Oregon

Marshall Industries
8230 S. W. Nimbus Avenue
Beaverton, OR 97005
(503) 644-5050

Time Electronics
16125 SW 72nd Avenue
Portland, OR 97224
(503) 684-3780

Western Microtechnology
1800 N.W. 169th Place
Suite B300
Beaverton, OR 97006
(503) 629-2082

## Pennsylvania

Time Electronics
600 Clark Ave.
King of Prussia, PA 19406
(215) 337-0900

## Texas

Diplomat Electronics
2201 Denton Drive
Sulte 104
Austin, TX 78758
(512) 836-8707

Diplomat Electronics 340 Midcourt Road
Suite 128
Carroliton, TX 75006
(214) 980-1888

Marshall Industries
4025 Chenault
Carrollton, T× 75006
(214) 233-5200

Marshall Industries
7250 Langtry
Houston, TX 77040
(713) 895-9200

Marshall Industries
8504 Cross Park Drive
Austin, TX 78754
(512) 458-5654

Milgray
17060 Dallas Parkway
Suite 105
Dallas, TX 75248
(214) 248-1603

Time Electronics
2210 Hatton
Suite 101
Carrollton, TX 75006
(214) 241-7441

Time Electronics
10450 Stancliffe Blvd.
Suite 110
Houston, TX 77099
(713) 530-0800

## Utah

Diplomat Electronics 3007 South West Temple Salt Lake City, UT 84115 (801) 486-4134

Marshall Industries
466 Lawndale Drive
Sulte C
Salt Lake City, UT 84115
(801) 485-1551

Time Electronics
2446 Progress Drive
Salt Lake City, UT 84119
(810) 973-8181

## Washington

Marshall Industries
14102 NE 21st Street
Bellevue, WA 98007
(206) 747-9100

Time Electronics
8601 Willows Road
Redmond, WA 98052
(206) 882-1600

Western Microtechnology
14636 NE 95th Street
Redmond, WA 98052
(206) 881-6737

## Wisconsin

Classic Components
2925 S. 160th Street
New Berlin, WI 53151
(414) 786-5300

Marsh Electronics
1563 S. 101st Street
Milwaukee, WI 53214
(414) 475-6000

Marshall Industries
235 North Executive Drive

## Suite 305

Brookfield, WI 53005
(414) 797-7260

## Canada

Carsten Electronics
3791 Victoria Park Ave.
Scarborough, Ontario M1W
3K6
(416) 495-7705

ITT Multicomponents
300 North Rivermede Road
Concord, Ontario
Canada L4K 2 Z4
(416) 736-1048

Space Electronics
5651 Rue Ferrier Street
Montreal, Quebec H4P 2K5
(514) 697-8676

Space Electronics
3070 Kingsway
Vancouver, B.C. V5R 5 J 7
(604) 438-5545

## Alabama

Marshall Industries
3313 S. Memorial Highway

## Suite 121

Huntsville, AL 35801
(205) 881-9235

## Arizona

Insight Electronics 1525 W. University Drive Sulte 105
Tempe, AZ 85281
(602) 829-1800

Marshall Industries
835 W. 22nd Street
Tempe, AZ 85281
(602) 968-6181

Western Microtechnology
7848 E. Redfield Drive
Sulte 17
Scottsdale, AZ 85260
(602) 948-4240

California
Image Electronics
5310 Derry Street

## Suite $\times$

Agoura, CA 91301
(818) 707-0911

Image Electronics 1342 Bell Ave. Tustin, CA 92680 (714) 730-0303

Insight Electronics 28035 Dorothy Drive Suite 220
Agoura Hills, CA 91301
(818) 707-2100

Insight Electronics
3505 Cadillac Drive
Costa Mesa, CA 92626 (714) 556-6890

Insight Electronics 6885 Flanders Drive Suite G
San Diego, CA 92126
(619) 587-0471.

Marshall Industries 9674 Telstar Ave. EI Monte, CA 91731 (818) 442-7204

Marshall Industries 336 Los Coches Street Milpitas, CA 95035 (408) 943-4600

Marshall Industries 10105 Carroll Canyon Road San Dlego, CA 92131 (619) 578-9600

Marshall Industries
9710 Desoto Avenue
Chatsworth, CA 91311 (818) 407-4100

Marshall Industries
The Morgan
Irvine, CA 92718
(714) 458-5308

Marshall Industries 3039 Kilgore Avenue Rancho Cordova, CA 95670 (916) 635-9700

Time Electronics 1339 Moffett Park Drive Sunnyvale, CA 94086 (408) 734-9888

Time Electronics 9751 Independence Ave. Chatsworth, CA 91311
(818) 998-7200

Time Electronics 2410 E. Cerritos Ave. Anaheim, CA 92806
(714) 937-0911

Time Electronics
19210 S. Van Ness Ave. Torrance, CA 90501
(213) 320-0880

Western Microtechnology 10040 Bubb Road
Cupertino, CA 95014 (408) 725-1660

## Colorado

Diplomat Electronics 3974 Youngfield Street Wheatridge, CO 80033
(303) 422-9229

Marshall Industries
12351 N. Grant Road
Suite A
Thorton, CO 80241
(303) 451-8444

Time Electronics
7399 S . Tucson Way
Suite A-7
Inglewood, CO 80112
(303) 799-8851

## Connecticut

Marshall Industries
20 Sterling Barnes Park N.
Wallingford, CT 06492
(202) 265-3822

## Milgray

378 Boston Post Road
Orange, CT 06477
(203) 795-0711

Time Electronics 1701 Milldale Road
Chesire, CT 06410 (203) 271-3200

## Florida

Diplomat Electronics 1300 N. W. 65th Place Ft. Lauderdale, FL 33309 (305) 974-8700

Diplomat Electronics 2120 Calumet Street Clearwater, FL 33515 (813) 443-4514

Etek Electronics
1490 NW 79th Avenue
Miami, FL 33126
(309) 593-1188

Marshall Industries
4205 34th Street, SW
Orlando, FL 32805
(305) 841-1878

Marshall Industries
1101 NW 62nd Street
Suite 360 D
Ft. Lauderdale, FL 33309
(305) 928-0661

Milgray
1850 Lee Road
Suite 104
Winter Park, FL 32789
(305) 647-5747

Reptron
33320 N. W. 53rd Street
Sulte 206
Ft. Lauderdale, FL 33309
(305) 735-1112

Reptron
13700 McCormick Drive
Tampa, FL 33624
(813) 855-4656

Time Electronics
6610 NW 21st Avenue
Ft. Lauderdale, FL 33309
(305) 974-4800

Time Electronics
4405 Vineland Road
Suite C15
Orlando, FL 32811
(305) 841-6565

## Georgia

Marshall Industries
4350 J International Blvd.
Norcross, GA 30093
(404) 923-5750

Milgray
17 Dunwoody Park
Suite 102
Atlanta, GA 30338
(404) 393-9666

Reptron
3040 H Business Park Drive
Norcross, GA 30071
(404) 446-1300

Time Electronics
5555 Oakbrook Parkway
Sulte 535
Norcross, GA 30093
(404) 448-4448

## Illinois

Classic Components
3336 Commerclal Ave.
Northbrook, IL 60062
(312) 272-9650

Marshall Industries
1261 Wiley Road
Suite F
Schaumburg, IL 60195
(312) 490-0155

Time Electronics
945 N. Edgewood Drive
Suite $\mathbf{G}$
Wood Dale, IL 60191
(312) 350-0610

## Indiana

Marshall Industries
6990 Corporate Drive
Indianapolis, IN 46278
(317) 297-0483

## Kansas

Marshall Industries 8321 Melrose Drive Lenexa, KS 66214 (913) 492-3121

## Milgray

6901 W. 63rd Street
Overland Park, KS 66202
(913) 236-8800

## New Mexico

RAM Electronics
135 Virginia NE.
Albuquerque, NM 87108
(505) 262-0888

## Massachusetts

Interface Electronics
228 South Street
Hopkinton, MA 01748
(617) 435-6858

Marshall Industries
One Wilshire Road
Burlington, MA 01803
(617) 272-8200

## Milgray

79 Terrace Hall Avenue
Burlington, MA 01803
(617) 272-6800

RC Components
222 Andover Street
Wilmington, MA 01887
(617) 273-1860

Time Electronics
10A Centennial Drive
Peabody, MA 01960
(617) 532-6200

## Maryland

Diplomat Electronics
9150 Rumsey
Suite A6
Columbia, MD 21045
(301) 995-1226

Marshall Industries
8445 Helgerman
Gaithersburg, MD 20877
(301) 840-9450

Milgray
9801 Broken Land Parkway
Columbia, MD 21045
(301) 995-6169

Vantage Electronics
6925 R. Oakland Mills Road
Columbia, MD 21045
(301) 995-0444

## Michigan

Marshall Industries
31076 Schoolcraft Road
Livonia, Ml 48150
(313) 525-5850

Reptron
34403 Glendale
Livonia, MI 48150
(313) 525-2700

## FUJITSU LIMITEI

Communications and Electronics
6-1, Marunouchi 1-chome, Chiyoda-ku, Tokyo 100, Japan
Phone: National (03) 216-3211 International (Int'I Prefix) 81-3-216-3211 Telex: J22833 Cable: :"FUJITSULIMITED TOKYO"

[^50]
[^0]:    * Multibus is a patented bus of Intel.

[^1]:    Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

[^2]:    *Multibus is a patented bus of Intel.

[^3]:    Temperature Range:
    ESR (Equivalent Series Resistance):

[^4]:    * To guarantee recognition at next clock.

[^5]:    Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

[^6]:    *Trade Mark of Intel Corporation, USA

[^7]:    *Mnemonics © Intel Corporation, 1978

[^8]:    *Mnemonics © Intel Corporation, 1978

[^9]:    Temperature Range:
    0 to $70^{\circ} \mathrm{C}$
    ESR (Equivalent Series Resistance):
    CO (Shunt Capacitance of Crystal):
    CL (Load Capacitance):
    Drive Level:

[^10]:    Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

[^11]:    Shaded areas a indicate instructions not available in MBL 8086, 88 microsystems.

    * Note: Clock cycles shown for byte transfer. For word operations, add 4 clock cycles for all memory transfers.

[^12]:    Shaded areas indicate instructions not available in MBL 8086, 88 microsystems.

[^13]:    *Trade Mark of Intel Corporation, USA

[^14]:    *Trade Mark of Intel Corporation, USA

[^15]:    *Trade Mark of Intel Corporation, USA
    Portions Reprinted by permission of Intel Corporation
    © Intel Corporation, 1980

[^16]:    * Trade Mark of Intel Corporation

    Portions Reprinted by permission of Intel Corporation (C) Intel Corporation, 1980

[^17]:    * Trade Mark of Intel Corporation

[^18]:    * Trade Mark of Intel Corporation

[^19]:    * Trade Mark of Intel Corporation
    ** Note: Master/Slave in ICW4 is only used in the buffered mode.

[^20]:    *Trade Mark of Intel Corporation
    Portions Reprinted by permission of Intel Corporation
    © Intel Corporation, 1983

[^21]:    * Trade Mark of Intel Corporation, USA

[^22]:    *Trade Mark of Intel Corporation
    Portion Reprinted by permission of Intel Corporation
    © Intel Corporation, 1983

[^23]:    *in some system configurations it is possible for a non-I/O Processor to have access to more than one Multi-Master System Bus, see Intel's 8289 Application Note.

[^24]:    **Note that even a higher priority arbiter which is acquiring the bus through BPRN will momentarily drop CBRQ until it has acquired the bus.

[^25]:    \#: Immediate data
    H ; Higher 4 bits
    L; Lower 4 bits

[^26]:    *: 6 MHz XTAL (N-Version), 8 MHz XTAL (E-Version), 11 MHz XTAL (H-Version) Load Conditions: BUS: $\mathrm{C}_{\mathrm{L}}=$ 150 pF ; Other Outputs $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$.
    **: Load Conditions $C_{L}=20 \mathrm{pF}$, High Impedance
    $* * *: \mathrm{t}_{\mathrm{CY}}=2.5 \mu \mathrm{~s}\left(6 \mathrm{MHz}\right.$ XTAL N -Version), $\mathrm{t}_{\mathrm{CY}}=1.875 \mu \mathrm{~s}\left(8 \mathrm{MHz}\right.$ XTAL E-Version), $\mathrm{t}_{\mathrm{CY}}=1.36 \mu \mathrm{~s}(11 \mathrm{MHz}$ XTAL H-Version)

[^27]:    Notes:

    1. Load Conditions: BUS $C_{L}=150 \mathrm{pF}$, Other Outputs $C_{L}=80 \mathrm{pF}, 1 \mathrm{TTL}$
    2. Load Conditions $C_{L}=20 \mathrm{pF}$, High impedance

    1 Falling edge
    1 Rising edge

[^28]:    Notes:

    1. Load Conditions: BUS: $C_{L}=150 \mathrm{pF}$, Other Outputs: $C_{L}=80 \mathrm{pF}, 1 \mathrm{TTL}$
    2. Load Conditions: BUS: $C_{L}=20 p F$, High impedance
    t: Falling edge
    : Rising edge
[^29]:    * Trade Mark of Intel Corporation

    Portions Reprinted by permission of Intel Corporation
    © Intel Corporation, 1980

[^30]:    * Trade Mark of Intel Corporation

    Portions Reprinted by permission of Intel Corporation © Intel Corporation, 1980

[^31]:    * Under development

[^32]:    This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

[^33]:    This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

[^34]:    This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

[^35]:    This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

[^36]:    This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

[^37]:    FUJITSU reserves the right to change products and specifications without notice. This information does not convey any license under patent rights of FUJITSU LTD. or others.

[^38]:    This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

[^39]:    * This value is doubled when CLK $=4 \mathrm{MHz}$.

[^40]:    Operation Code X: Table 2

[^41]:    \#: Immediate data

[^42]:    * Both high and low times should be more than $35 \%$ of the cycle time, and rise and fall times should be less than

[^43]:    Operation Code X: Table 2

[^44]:    This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

[^45]:    This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit.

[^46]:    This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid it is advised that normal precautions be taken to avoid
    application of any voltage higher than maximum rated voltages to this high impedance circuit.

[^47]:    This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is advised that normal precautions be taken to avoid it is advised that normal precautions be taken to avoid
    application of any voltage higher than maximum rated application of any voltage higher than
    voltages to this high impedance circuit.

[^48]:    *Ethernet is a trade mark of Xerox Corp. U.S.A.

[^49]:    * The values of the oscillator capacitors may have to be tuned for a particular components layout. Both capacitors should be adjusted for maximum voltage at OSC.IN.
    However, once the correct values are determined for that layout, any more tuning will not be necessary for each board.
    ** 5 th overtone series resonant.

[^50]:    For further information please contact:

    ## FUJITSU LIMITED

    Semiconductors Marketing: Furukawa Sogo Bldg., 6-1, Marunouchi 2-chome, Chiyoda-ku, Tokyo 100, Japan Phone: National (03) 216-3211 International (Int'I Prefix) 81-3-216-3211 Telex: 2224361 FTTOR J
    FUJITSU MICROELECTRONICS, INC.: 3320 Scott Blvd., Santa Clara, CA95054-3197, U.S.A. Phone: 408-562-1000 Telex: 910-338-0190 FUJITSU SNTA
    FUJITSU MIKROELEKTRONIK GmbH.:
    Arabella Center 9, OG./A, Lyoner Straße 44-48 D-6000 Frankfurt 71, F.R. Germany Phone: 069/66 320 Telex: 0411963
    FUJITSU MICROELECTRONICS PACIFIC ASIA LIMITED:
    805 Tsim Sha Tsui Centre, West Wing 66, Kowloon, Hong Kong
    Phone: 3-732-0100 Telex: 31959 FUJIS HX

