# SYSTEM REFERENCE GUIDE 



## APC System Reference Guide

## LIMITED WARRANTY <br> AND LIABILITY DISCLAIMER

NEC Information Systems, Inc. products are warranted in accordance with the terms of the applicable NEC Information Systems, Inc. products specification. Product performance is affected by system configuration, software, the application, customer data, and operator control of the system among other factors. While NEC Information Systems, Inc. products are considered to be compatible with most systems, the specific functional implementation by customers of the products may vary.

Therefore, the suitability of a product for a specific application must be determined by the customer and is not warranted by NEC Information Systems, Inc.

This manual is as complete and factual as possible at the time of printing, however, the information in this manual may have been updated since that time. NEC Information Systems, Inc. reserves the right to change the functions, features, or specifications of its products at any time, without notice.

NEC Information Systems, Inc. has prepared this document for use by NECIS employees and customers. The information contained herein is the property of NECIS and shall not be reproduced in whole or in part without prior written approval from NECIS.

# First Printing - September 1982 

Revised - December 1982
Revised - March 1983

Copyright 1982
NEC Information Systems, Inc.
5 Militia Drive
Lexington, MA 02173
Printed in U.S.A.

## FEDERAL COMMUNICATIONS COMMISSION RADIO FREQUENCY INTERFERENCE STATEMENT

"WARNING: This equipment generates, uses and can radiate radio frequency energy and if not installed and used in accordance with the instructions manual, may cause interference to radio communications. It has been tested and found to comply with the limits for a Class A Computing device pursuant to Subpart J of Part 15 of FCC Rules, which are designed to provide protection against such interference. Operation of the equipment in a residential area is likely to cause interference in which case, the user will be required to take whatever measures may be required to correct the interference."

## Manufacturer's Instructions and User's Responsibility to Prevent Radio Frequency Interference

## Manufacturer's Instructions

The user must observe the following precautions when installing and operating this device:

1. Operate the equipment in strict accordance with the manufacturer's instructions for the model.
2. Ensure that the unit is plugged into a properly grounded wall outlet and that the power cord supplied with the unit is used and not modified.
3. Ensure that the unit is always operated with the factory-installed cover set on the unit.
4. Make no modifications to the equipment which would affect its meeting the specified limits of the Rules.
5. Properly maintain the equipment in a satisfactory state of repair.

## User's Responsibility

The user has the ultimate responsibility to correct problems arising from harmful radio-frequency emissions from equipment under his control. If this equipment does cause interference to radio or television reception, which can be determined by turning the equipment off and on, the user is encouraged to try to correct the interference by one of the following measures. All of these responsibilities and any others not mentioned are exclusively at the expense of the user.

1. Change in orientation of the receiving device antenna.
2. Change in orientation of the equipment.
3. Change in location of equipment.
4. Change in equipment power source.

If these attempts are unsuccessful, install one or all of the following devices:

1. Line isolation transformers
2. Line filters
3. Electro-magnetic shielding

If necessary, the user should consult the dealer, NEC, or an experienced radio/television technician for additional suggestions. The user may find the following booklet prepared by the Federal Communications Commission to be helpful: "How to Identify and Resolve Radio-TV Interference Problems." This booklet is available from the U.S. Government Printing Office, Washington, D.C. 20402, Stock No. 004-000-00345-4.
"Note: The operator of a computing device may be required to stop operating his device upon finding that the device is causing harmful interference and it is in the public interest to stop operation until the interference problem is corrected."

## Contents

Page
PREFACE ..... xiii
CHAPTER 1 HARDWARE OVERVIEW
CHAPTER 2 PROCESSOR PCB
2.1 MOTHER BOARD/CARD CAGE INTERFACE ..... 2-3
2.2 MICROPROCESSOR ..... 2-13
2.3 DIRECT MEMORY ACCESS ..... 2-14
2.4 INTERVAL TIMER ..... 2-19
2.5 INTERRUPT CONTROL ..... 2-20
2.6 MEMORY ..... 2-26
2.6.1 Main Memory ..... 2-27
2.6.2 Battery-Backed Memory ..... 2-28
2.6.3 Read Only Memory ..... 2-29
2.7 PARALLEL PRINTER CONTROL ..... 2-29
2.7.1 Interface ..... 2-29
2.7.2 Programming Considerations ..... 2-29
2.8 KEYBOARD ..... 2-38
2.8.1 Keyboard Layout and Scan Codes ..... 2-39
2.8.2 Interface ..... 2-41
2.9 CALENDAR AND CLOCK GENERATOR ..... 2-42
2.9.1 Circuit Description ..... 2-43
2.9.2 Programming Considerations ..... 2-44
2.10 JUMPER SETTINGS ..... 2-44
CHAPTER 3 CONTROLLER PCB
3.1 MOTHER BOARD/CARD CAGE INTERFACE ..... 3-1
3.2 CRT DISPLAY CONTROL ..... 3-4
3.2.1 Display Buffer Memory ..... 3-5
3.2.2 Programming Considerations ..... 3-8
3.3 CRT DISPLAY UNIT ..... 3-18
3.4 FLEXIBLE DISK DRIVE CONTROLLER ..... 3-21
3.4.1 Programming Considerations ..... 3-24
3.4.2 Drive A and B Interface ..... 3-37

## Contents (cont'd)

Page
3.5 FDD UNIT ..... 3-39
3.5.1 Specifications ..... 3-39
3.5.2 Interface ..... 3-40
3.5.3 Terminations and Jumper Settings ..... 3-40
3.6 SERIAL I/O COMMUNICATIONS CONTROLLER ..... 3-43
3.6.1 Specifications ..... 3-43
3.6.2 Circuit Description ..... 3-43
3.6.3 Interface ..... 3-43
3.6.4 Programming Considerations ..... 3-43
3.6.4.1 Asynchronous Operating Mode ..... 3-50
3.6.4.2 Synchronous Operating Mode ..... 3-53
3.6.4.3 Business Machine Operating Mode ..... 3-57
3.6.5 Status Word Format ..... 3-59
3.7 SOUND CONTROL ..... 3-60
3.7.1 Interface ..... 3-61
3.7.2 Programming Considerations ..... 3-62
3.8 ARITHMETIC PROCESSING UNIT ..... 3-62
3.9 JUMPER SETTINGS ..... 3-64
CHAPTER 4 POWER SUPPLY
APPENDIX A INTEGRATED CIRCUIT DATA SHEETS
A1 16-BIT MICROPROCESSOR ..... A1-1
A2 PROGRAMMABLE COMMUNICATION INTERFACES ..... A2-1
A3 SINGLE/DOUBLE DENSITY FLOPPY DISK CONTROLLER ..... A3-1
A4 GRAPHICS DISPLAY CONTROLLER ..... A4-1
APPENDIX B LOGIC AND SCHEMATIC DIAGRAMS

## Contents (cont'd)

APPENDIX C PROGRAMMABLE ARRAY LOGIC DECODING SPECIFICATIONS<br>APPENDIX D CHARACTER CODE AND KEYBOARD INFORMATION<br>APPENDIX E I/O PORT ADDRESSES AND INSTRUCTIONS<br>APPENDIX F HARDWARE SPECIFICATIONS

List of Illustrations
Figure Title Page
1-1 System Block Diagram ..... 1-2
2-1 Processor PCB ..... 2-1
2-2 Processor PCB Block Diagram ..... 2-2
2-3 Mother Board/Card Cage Interface ..... 2-3
2-4 Processor Timing ..... 2-8
2-5 DMA Timing ..... 2-9
2-6 RDY Signal Timing ..... 2-10
2-7 RFSH Signal Timing ..... 2-10
2-8 Processor ${ }^{\text {Interface Circuits }}$ ..... 2-11
2-9 Device Interface Circuits ..... 2-12
2-10 DMA Command and Mode Registers ..... 2-16
2-11 DMA Request and Mask Register ..... 2-17
2-12 DMA Status Register ..... 2-19
2-13 Interval Timer Block Diagram ..... 2-19
2-14 Interrupt Control Block Diagram ..... 2-21
2-15 Interrupt Initialization Command Words ..... 2-24
2-16 Interrupt Operation Command Words ..... 2-25
2-17 System Memory Map ..... 2-26
2-18 Main Memory Block Diagram ..... 2-27
2-19 Battery-Backed Memory Block Diagram ..... 2-28
2-20 Parallel Printer Control Block Diagram ..... 2-30
2-21 Parallel Printer Cable Connections ..... 2-32
2-22 Parallel Printer Controller Interface Timing ..... 2-36
2-23 Parallel Printer Controller Interface at Paper Out Status ..... 2-37
2-24 Keyboard Block Diagram ..... 2-38
2-25 Keyboard Layout ..... 2-39
2-26 Keyboard Interface ..... 2-41
2-27 Clock/Calendar Block Diagram ..... 2-43
2-28 Clock/Calendar Format ..... 2-45
2-29 Processor PCB Jumper Settings ..... 2-46
3-1 Controller PCB ..... 3-2
3-2 Controller PCB Block Diagram ..... 3-3
3-3 CRT Display Control Block Diagram ..... 3-5
3-4 Character-Code Representation in the Character Code Buffer Memory ..... 3-5

## List of Illustrations (cont'd)

FigureTitlePage3-5 Bit Map for Character Attribute Code ..... 3-6
3-6 Display Buffer Memory Map ..... 3-7
3-7 Relationship Between Character Code, Character-Attribute Code, Display Position, and Video Screen ..... 3-8
3-8 GDC Status Register Bit Map ..... 3-9
3-9 Monochrome-CRT Display Interface ..... 3-19
3-10 Color-CRT Display Interface ..... 3-20
3-11 FDC Block Diagram ..... 3-22
3-12 FDC Timing Diagram ..... 3-24
3-13 FDD Signal Connector Interface and Pin Assignments ..... 3-41
3-14 FDD Power Connector Interfce and Pin Assignments ..... 3-42
3-15 FDD Termination Resistor Modules, Location and Installation ..... 3-42
3-16 FDD Jumper, Location and Proper Setting ..... 3-43
3-17 Serial I/O Communications Controller Block Diagram ..... 3-45
3-18 Communications Controller Cable Connections ..... 3-49
3-19 Asynchronous Mode Instruction Word ..... 3-51
3-20 Command Instruction Word Format ..... 3-51
3-21 Communications Controller, Circuit for Asynchronous Operation ..... 3-52
3-22 Synchronous Mode Instruction Word ..... 3-54
3-23 Communications Controller, Circuit for Synchronous Operation Using External Clock ..... 3-54
3-24 Communications Controller, Circuit for Synchronous Operation Using Internal Clock ..... 3-55
3-25 Communications Controller, Circuit for Business Machine Clock ..... 3-57
3-26 Communications Controller, Status Word Format ..... 3-59
3-27 Sound Control Block Diagram ..... 3-60
3-28 Location of Sound Interface Connectors ..... 3-61
3-29 Controller PCB Jumper Settings ..... 3-65
4-1 System Power Supply Block Diagram ..... 4-2
4-2 Power Supply Interconnection Diagram ..... 4-3
D-1 APC GRPH1 Characters ..... D-6
D-2 APC GRPH2 Characters ..... D-7
D-3 Keyboard Layout Showing Hex Codes for Special Keys ..... D-8

## List of Tables

Table Title Page
2-1 Card Cage Socket Contact Assignments ..... 2-4
2-2 DMA Instructions ..... 2-14
2-3 Timer Commands ..... 2-20
2-4 Interrupt Lines ..... 2-21
2-5 Interrupt Control Commands Summary ..... 2-22
2-6 Parallel Printer Connectors Pin Assignments ..... 2-31
2-7 Parallel Printer Interface Signals ..... 2-33
2-8 Parallel Printer Controller Instruction ..... 2-35
2-9 Parallel Printer Controller Instruction Sequence ..... 2-36
2-10 Keyboard Scan Codes ..... 2-39
2-11 Keyboard Interface Lines ..... 2-42
2-12 Clock/Calendar Instruction Format ..... 2-44
3-1 Attribute Description for Character Attribute Code ..... 3-6
3-2 GDC I/O-Address and Bit Map ..... 3-9
3-3 Contents of the GDC Status Register ..... 3-10
3-4 GDC Symbols ..... 3-11
3-5 GDC Commands ..... 3-14
3-6 GDC Command Constants ..... 3-18
3-7 Bit Description of the FDC Main Status Register ..... 3-23
3-8 FDC Symbols ..... 3-24
3-9 FDC Commands ..... 3-27
3-10 FDC Status Register 0 ..... 3-33
3-11 FDC Status Register 1 ..... 3-34
3-12 FDC Status Register 2 ..... 3-35
3-13 FDC Status Register 3 ..... 3-36
3-14 FDC Register I/O Addresses and Functions ..... 3-36
3-15 Output Signals ..... 3-37
3-16 Input Signals ..... 3-38
3-17 FDD Specifications ..... 3-39
3-18 Serial I/O Communications Controller Specifications ..... 3-44
3-19 Serial I/O Commands ..... 3-46
3-20 Serial I/O Connector Pin Assignments ..... 3-47
3-21 Serial I/O Device Interface Connector Pin Descriptions ..... 3-48

## List of Tables (cont'd)

Table Title Page
3-22 $\quad 8251 \mathrm{~A}$ Instruction ..... 3-50
3-23 Communications Controller, Baud Rate Coding During Asynchronous Operation ..... 3-53
3-24 Communications Controller, Baud Rate Coding During Synchronous Operation ..... 3-56
3-25 Communications Controller, Baud Rate Coding During Operations with Business Machine Clocking ..... 3-58
3-26 Sound Interface Pin Assignments ..... 3-61
3-27 Sound Programming Read/Write Format ..... 3-62
3-28 Sound Control Commands ..... 3-62
3-29 Sound Scale Commands ..... 3-63
4-1 Power Supply Pin Command Assignments ..... 4-4
C-1 Identification and Location of PAL Device ..... C-1
C-2 PFB01B Inputs/Outputs ..... C-2
C-3 PFB02B Inputs/Outputs ..... C-3
C-4 PFC01 Inputs/Outputs ..... C-4
C-5 NMS02 Inputs/Outputs ..... C-5
D-1 Code Table ..... D-2
D-2 ASCII Special Characters ..... D-3
D-3 APC Special Characters ..... D-4
D-4 Quick Reference Guide for ASCII Special Character/APC Spe- cial Character Association ..... D-5
E-1 I/O Port Address and Instructions for the DMA Controller ..... E-2
E-2 I/O Port Addresses and Instructions for the Interrupt Controller ..... E-4
E-3 I/O Port Addresses and Instructions for the Internal Timer ..... E-5
E-4 I/O Port Addresses and Instructions for the Serial I/O Commun- ications Controller Number 1 ..... E-6
E-5 I/O Port Addresses and Instructions for the Serial I/O Commun- ications Controller Number 2 ..... E-6
E-6 I/O Port Addresses and Instructions for the DMA Address Registers ..... E-7
E-7 I/O Port Addresses and Instructions for the CRT Controller ..... E-7

## List of Tables (cont'd)

Table Title Page
E-8 I/O Port Addresses and Instructions for the Graphics Display Controller ..... E-8
E-9 I/O Port Addresses and Instructions for the Keyboard Controller ..... E-8
E-10 I/O Port Addresses and Instructions for the FDD Controller ..... E-8
E-11 I/O Port Addresses and Instructions for the Clock and Calendar ..... E-9
E-12 I/O Port Address and Instruction for the BBM Enable ..... E-9
E-13 I/O Port Addresses and Instructions for the APU ..... E-9
E-14 I/O Port Address and Instruction for the Power Off Control ..... E-9
E-15 I/O Port Addresses and Instructions for the Sound Control ..... E-10
E-16 I/O Port Addresses and Instructions for the Timer ..... E-10
E-17 I/O Port Addresses and Instructions for the ODA Controller Number 1 ..... E-11
E-18 I/O Port Addresses and Instructions for the IDA Controller ..... E-11
E-19 I/O Port Addresses and Instructions for the Communications Adapter ..... E-12
E-20 I/O Port Addresses and Instructions for the ASOP Controller ..... E-12

## Preface

This system reference guide provides hardware design and interface information for programmers, engineers, designers, and others who need to know how the APC is designed.

Chapter 1, Hardware Overview, familiarizes you with the Advanced Personal Computer and defines the principal components and devices.

Chapter 2, Processor PCB, includes descriptions and technical information for the devices contained on the Processor PCB along with programming considerations where appropriate.

Chapter 3, Controller PCB, includes information similar to that in Chapter 2 for the devices contained on the Controller PCB.

Chapter 4, Power Supply, contains detailed specifications for the system power source.

Appendices A to F include hardware reference information such as IC data sheets, logic diagrams, and data summaries.

## List of Abbreviations

| A | Ampere | ISR | Read Inservice Register |
| :---: | :---: | :---: | :---: |
| ALE | Address Latch Enable | KB | Kilobyte |
| APC | Advanced Personal | LED | Light Emitting Diode |
|  | Computer | LSB | Least Significant Bit |
| APU | Arithmetic Processing Unit | LSI | Large-Scale Integration |
| AT | Abnormal Termination | MB | Megabyte |
| BBM | Battery-Backed Memory | MFM | Modified Frequency |
| CMOS | Complementary Metal |  | Modulation |
|  | Oxide Semiconductor | MHz | Megahertz |
| CPU | Central Processing Unit | MOS | Metal Oxide |
| CRT | Cathode Ray Tube |  | Semiconductor |
| CS | Code Segment | ms | Millisecond |
| DCH | Device Control | MSB | Most Significant Bit |
| DIP | Dual In-line Package | ns | Nanosecond |
| DMA | Direct Memory Access | NT | Normal Termination |
| DMC | Direct Memory Access Cycle | OCW | Operational Command Word |
| DS | Data Segment | ODA | Output Device Adapter |
| EPROM | Erasable Programmable Read-Only Memory | PAL | Programmable Array Logic |
| ES | Extra Segment | PCB | Printed Circuit Board |
| FDC | Flexible Disk Drive | POF | Power Off Control |
|  | Controller | RAM | Random Access Memory |
| FDD | Flexible Disk Drive | ROM | Read-Only Memory |
| FIFO | First-In First-Out | rpm | Revolutions Per Minute |
| FM | Frequency Modulation | SS | Stack Segment |
| GDC | Graphic Display Controller | SW | Switch |
| HEX | Hexadecimal | TTL | Transistor/Transistor |
| Hz | Hertz |  | Logic |
| IC | Integrated Circuit, | USART | Universal Synchronous/ |
|  | Interrupt Code, Invalid |  | Asynchronous Receiver/ |
|  | Command |  | Transmitter |
| ICW | Initialization Command | V | Volt |
|  | Word | VFO | Variable Frequency |
| I/O | Input/Output |  | Oscillator |
| IP | Instruction Pointer | W | Watt |
| IRR | Read Interrupt Register | $\mu \mathrm{s}$ | Microsecond |

## Chapter 1

## Hardware Overview



The NEC Advanced Personal Computer (APC) has two basic components: a Main Unit and a Keyboard. The Keyboard, which cable-connects to the Main Unit, is common to all APC models. The Main Unit, which houses the Central Processing Unit (CPU), memory, visual display, sound output, and peripheral controllers, is available in three models: (1) a Monochrome Cathode Ray Tube (CRT) Display with one 8 -inch Flexible Disk Drive (FDD), (2) a Monochrome CRT Display with two 8 -inch FDDs, and (3) a Color CRT Display with two 8-inch FDDs. Several options and accessories are available to enhance performance or to adapt the APC for special applications.

Figure 1-1 is a block diagram of the APC. The Main Unit, the heart of the APC, has a CRT Display, one or two 8-inch FDDs, an ON/OFF switch, and several controls associated with the CRT Display. Three Input/Output (I/O) cable connectors are available at the rear of the cabinet.

The CPU, memory, and basic control logic are contained in the Main Unit on two quad-layered Printed Circuit Boards (PCB): a Processor PCB (G9PFBU) and a Controller PCB (G9PFCU). These PCBs plug into a mother board interface bus that has the space and power for up to three additional (optional) PCBs.

The Processor PCB contains as standard equipment:

- A 16-bit 8086 Microprocessor
- An 8288 Bus Controller with 20-bits of addressing, making one megabyte (MB) of memory accessible
- 128 kilobytes (KB) (standard) of Random Access Memory (RAM)
- 8 KB of Read-Only Memory (ROM)
- 4 KB of CMOS Battery-Backed Memory, which remains refreshed for at least two years without ac power
- A 4-channel Direct Memory Access (DMA) Controller


Figure 1-1 System Block Diagram

- A 15 -channel Interrupt System
- Printer and Keyboard Controllers
- Calendar-and-Clock Controller, which keeps track of the month, date, day of week, hour, minute, and second, and runs on battery power when ac power is off, thus preserving the time/date setting.

The Controller PCB contains as standard equipment:

- CRT Display Control, which can generate 250 predefined characters and allows you to create and store on disk any number of sets of 256 other special characters
- Flexible Disk Drive Controller (FDC) to coordinate the reading of and the writing to one or two 8-inch flexible disks
- Alarm and Music Sound Programming System, which enables you to select alarm tones and generate music across two octaves, with selected tempos, volumes, and tone characteristics
- Serial Communications Adapter, which is a Universal Synchronous/ Asynchronous Receiver/Transmitter (USART), enabling the APC to communicate with almost any type of communications device.

The APC power supply is a 100 -watt, 5 -voltage-level switching regulator. It furnishes dc levels to all components - except to the CRT which has its own power unit - and has sufficient reserve capacity to handle future expansion. The power supply has a software-controlled Power-Off control (POF) circuit that enables you to turn off the system locally or remotely.
One or two 8 -inch FDDs are integrated into the Main Unit. The FDC (NEC $\mu$ PD765) can read from or write to dual-sided double-density disks (which store up to 1 MB of unformatted data) or single-sided single-density flexible disks (which can store about 260 KB of unformatted data). The disk drive is a compact, highperformance, energy-efficient design featuring direct drive by a dc motor. Head loading and positioning is microprocessor-controlled for greater accuracy and minimum wear and damage to the media surface. Variable Frequency Oscillation (VFO) is employed to improve data transfer.

The APC comes equipped with a 12 -inch (diagonal) green-phosphor monochrome CRT or a 12 -inch 8 -color CRT. Either unit has a self-contained power supply. Both have a reduced glare surface and a high resolution screen. Standard alphanumeric characters are composed from an 8-by-19 dot matrix, allowing a display of 25 lines of 80 characters. Special symbols can be designed by the user with a dot matrix of up to 8-by-16.

The CRT Display has considerable versatility and provides you with capabilities for scrolling, partitioning (and scrolling within selected partitions), overbar, vertical bar, underscore, highlighting, blinking, and reverse video. The Color CRT Display has all these attributes plus a choice from eight colors.

With the special-character generator, you can design up to 256 characters dot-bydot, which can be saved on disk as one or more special character sets. Using a dot matrix printer, these special characters can be printed and displayed, making the APC especially adaptable to users who use non-Roman alphabets or scientific symbols.

The APC also offers an optional Graphics Adapter based on the NEC $\mu$ PD 7220. This self-contained single PCB plugs into the Main Unit and simplifies graphics applications, such as area shading, simulated movement, and solid or dashed lines, either straight or curved. By employing the Graphics Adapter with selected software packages, you can generate graphs, bar graphs, and three-dimensional pictures.

Also optional are two NEC printers. The Dot Matrix Printer provides rapid, high quality printing at a low cost. It prints in both directions at 100 characters per second on a 80 -to- 136 -character column width. It prints special and graphic characters as well as standard alphanumeric characters.

The other printer is the NEC Model 3530 Spinwriter ${ }^{\circledR}$, which produces high quality fully-formed characters. This printer features interchangeable print elements that contain up to 128 characters and are offered in several dozen type styles and symbol sets. It prints 35 characters per second at 10,12 , and 15 characters per inch or proportional spacing. It also prints bidirectionally and offers word processor functions, such as automatic underlining, shadowing, bold face printing, as well as several paper-handling accessories.

The standard APC comes equipped with 128 KB of RAM, which resides on the Processor PCB. With the optional memory-expansion kits, RAM can be expanded to 640 KB .

The asynchronous, synchronous serial I/O communications adapter is a standard feature of the APC. The interface is supported by the NEC 8251A Communications Controller, a USART, that is used as a peripheral and is programmed by the microprocessor to communicate using virtually any serial or parallel datatransmission technique, at programmable baud rates. For communications interface requirements beyond this standard controller, NEC offers special-purpose I/O Controllers on plug-in boards.

The Keyboard is not housed in the Main Unit; it attaches to the rear of the Main Unit with a single five-foot, coiled cable. The Keyboard has 109 keys, including a numeric keypad and 22 programmable function keys that facilitate data and word processing. Each function key has two shift-modes, making available 44 userdefinable functions with one or two keystrokes.

## NOTE

Only 32 of the 44 user-definable functions can be character strings.

## Chapter 2

## Processor PCB

The Processor PCB (G9PFBU) fits vertically in the Main Unit and is 11 inches long by $9 \frac{1}{2}$ inches high (see Figure 2-1). It is composed of four sandwiched layers, including the signal, ground, and dc-power internal planes. It plugs into the third slot of the card cage with a 100 -contact edge connector on the bottom of the PCB.


Figure 2-1 Processor PCB
As shown in Figure 2-1, three cable connectors are on the Processor PCB; two are 26-pin connectors and the third is a 2-pin header connector. The Keyboard interface uses one of the 26 -pin connectors, while the other connector provides a parallel printer (or other such device) interface. Battery power is supplied by the 2-pin connector.

The principal functional components and their interrelationships are shown on the block diagram of the Processor PCB (see Figure 2-2). The major elements of the PCB consist of the following functional areas:

- An NEC $\mu$ PD8086 microprocessor, which is

1) Fully compatible with the Intel 8086 microprocessor
2) Capable of addressing one MB of memory
3) Driven by an NEC $\mu$ PD 8284 clock generator at 4.9152 MHz

- A 20-bit bidirectional address bus, 16 bits of which serve also as the data bus, and related buffers, controls, and ports
- A DMA controller to permit high speed data transmission between input/ output devices without intervention of the microprocessor


Figure 2-2 Processor PCB Block Diagram

- A 15-channel interrupt controller to govern access to the microprocessor and data bus
- 8 KB ( $4 \mathrm{~K} \times 16$ bits) of ROM, which carry out self-testing and flexible-disk bootstrap loading.
- 128 KB of RAM organized into sixteen $64 \mathrm{~K} \times 1$ dynamic-memory chips, plus two more for parity check
- 4 KB ( $2 \mathrm{~K} \times 16$ bits) of CMOS Battery-Backed Memory (BBM)
- Keyboard control logic, which controls and conveys data from the Keyboard to the data bus
- Parallel printer control, which interfaces with a connector on the APC rear panel for connection of a printer or similar device
- Calendar and clock generator, supported by NEC $\mu$ PD1990AC, which is battery-protected and generates day, month, day of the week, hour, minute, and second information.


### 2.1 MOTHER BOARD/CARD CAGE INTERFACE

The Mother Board contains five card-edge socket connectors, each having 100 contacts, 50 on a side (see Figure 2-3). All contacts are connected as a bus to each PCB socket.


Figure 2-3 Mother Board/Card Cage Interface
Table 2-1 lists the contact assignments for each socket. All signals on these contacts are Transistor/Transistor Logic (TTL) compatible. Time relationships between various contacts in the card cage bus are shown in Figures 2-4 through 2-7. I/O equivalent circuits for the affected contacts and devices are shown in Figures 2-8 and 2-9.

Table 2-1 Card Cage Socket Contact Assignments

| PIN <br> NUMBER | NAME | READ/ <br> WRITE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { R1, R50 } \\ & \text { L1, L50 } \end{aligned}$ | GND |  | Signal Ground |
| $\begin{aligned} & \text { R2, R49 } \\ & \text { L2, L49 } \end{aligned}$ | $+5 \mathrm{~V}$ |  | +5 Vdc Supply |
| $\begin{aligned} & \text { R3, R48 } \\ & \text { L3, L48 } \end{aligned}$ | +12 V |  | +12 V Supply |
| R47, L47 | -12 V |  | -12 V Supply |
| R46, L46 | -5 V |  | -5 V Supply |
| R4 | POF | W | Power Off Control. Goes high to command power supply off. |
| $\begin{aligned} & \text { R5, L5 } \\ & \text { R6, L7 } \\ & \text { R8 } \\ & \text { R9, L9 } \\ & \text { R10, L10 } \\ & \text { R12 } \end{aligned}$ | IR0 to <br> IR14 | R | Interrupt Request 0 Through 14. These 15 lines carry interrupt requests to the processor. When an I/O device requires processor intervention, it signals the $\mu$ PD8259A interrupt controller, which activates one of the 15 interrupt lines to the processor; the interruptrequest signal is maintained until acknowledgement from the processor. IR0 has the highest priority and IR15 the lowest priority. These lines are active Low. |
| $\begin{aligned} & \text { R13, R14 } \\ & \text { R15, R16 } \end{aligned}$ | $\begin{aligned} & \text { DRQ0 to } \\ & \text { DRQ3 } \end{aligned}$ | R | DMA Request 0 Through 3. These lines transmit requests by I/O devices for DMA service. These signals remain active until DMA acknowledgement is active on a corresponding DACK line. Channel assignments are $0=$ CRT, $1=$ FDD, $2=$ Graphics, $3=$ AUX. |
| $\begin{aligned} & \text { L13, L14 } \\ & \text { L15, L16 } \end{aligned}$ | $\begin{aligned} & \text { DACK0 } \\ & \text { to DACK3 } \end{aligned}$ | W | DMA-Request Acknowledgement 0 Through 3. These lines signify that the DMA controller has acknowledged the DMA request on a corresponding DRQ line. DACK lines are active High. |

Table 2-1 Card Cage Socket Contact Assignments (cont'd)

| PIN NUMBER | NAME | READ/ WRITE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| R20 | TC | W | Terminal Count. This line carries to the I/O device a one-clock-duration pulse indicating that the terminal count for the DMA channel has been reached. This pulse is active High. |
| R21 | PHIO | W | System Clock. The pulse of the clock is transmitted on this line; the clock period is about $200 \mathrm{nsec}(4.9152 \mathrm{MHz})$ and its duty cycle is 33 percent. |
| L21 | IRST | W | Initial Reset. When this line goes High, every device in the system is initialized. This line is activated at power on. |
| R22 | IOW | W | I/ O Write. A Low on this line instructs the I/O device to receive data from the data bus. Either the DMA controller or processor can activate the line. |
| L22 | RDY | R | Ready. A High on this line indicates that data has been received by an I/O device or memory, or that preparation of data is complete. It is pulled Low by a device to lengthen I/O memory cycles, allowing slower devices to adjust to the I/O channel. |
|  |  |  | NOTE <br> There is an Interval-Ready signal within the G9PFBU PCB; it activates when memory access from the processor or DMA controller clashes with the memory-refresh cycle. |

Table 2-1 Card Cage Socket Contact Assignments (cont'd)

| PIN <br> NUMBER | NAME | READ/ WRITE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| R23 | IOR | W | I/O Read. A Low on this line instructs the I/O device to transmit its data to the data bus. This instruction can come from either the DMA controller or the processor. |
| L23 | DMC | W | DMA Cycle. A High on this line indicates the processor has been inhibited, thus giving system-bus control to the DMA controller. |
| R24 | MRQ | W | Memory Request. When this line is Low, it indicates the memory cycle is in operation. The line is inactive (High) during memoryrefresh cycles. |
| L24 | MR | W | Memory Read. This line instructs the additional memory to transmit its data onto the data bus. Either the processor or DMA controller can activate this signal, which is active Low. |
| R25 | RFSH | W | Memory Refresh. When this line is Low, dynamic memory is refreshed. |
| L25 | MW | W | Memory Write. When Low, this line instructs the selected memory to receive the data on the data bus. It is activated by either the DMA controller or processor. |
| R26 | BHE | W | Bus High Enable. When Low, this line indicates that the most significant half of the data line is ready to be read. This line is not used during DMA cycles. |
| L26 | ALE | W | Address Latch Enable. When activated by the processor or DMA control, the signal on this line latches the address on the bus. |

Table 2-1 Card Cage Socket Contact Assignments (cont'd)

| PIN <br> NUMBER | NAME | READ/ WRITE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| R27 | DT/R | W | Data Transmit or Receive. This line indicates data transfer direction. When High, direction is processor to I/O or memory; when Low, direction is I/O or memory to processor. |
| L27 | CLK0 | w | Communication Clock. This line, which is energized by the 8253-5 Programmable Interval Timer, conveys a synchronizing variable frequency clock to the communications control. |
| R30 | A0 | W | Address Bit 0. When this line is active (High), the memory or I/O device associated with the least significant half of the data is enabled to read or transmit its data. |
| R31, L30 R32, L31 R33, L32 L33 | A1 to A7 | W | Address Bits 1 Through 7. These seven lines address the memory or I/O device. These signals are latched. |
| R34, L34 | AD0 to | W | Address and Data Lines 0 Through 15. These |
| R35, L35 | AD15 |  | 16 lines are bidirectional and time multi- |
| R36, L36 |  |  | plexed to convey address or data to the |
| $\begin{aligned} & \text { R37, L37 } \\ & \text { R38, L38 } \end{aligned}$ |  |  | address or data buses. |
| $\begin{aligned} & \text { R38, L38 } \\ & \text { R39, L39 } \end{aligned}$ |  |  |  |
| R40, L40 |  |  |  |
| R41, L41 |  |  |  |
| $\begin{aligned} & \text { R42, L42 } \\ & \text { R43, L43 } \end{aligned}$ | A16 to A19 | W | Address Lines 16 Through 19. These four lines, used for addressing the memory, increase the number of address lines to twenty, allowing access to one megabyte of memory. |



Figure 2-4 Processor Timing


Figure 2-5 DMA Timing


Figure 2-6 RDY Signal Timing


NOTE: THE *RFSH' AND *RAS SIGNALS ARE GENERATED IN THE MEMORY FROM THE RFSH SIGNAL.

Figure 2-7 RFSH Signal Timing

1. A0 TO A19, IRQ, IOR, IOW, BHE, IRST, PHIO

2. RDY

3. DACK


Figure 2-8 Processor Interface Circuits

2. IRST

3. IRQ, IOR, IOW, BHE, DACK

4. RDY

5. IR0 TO IR11, DRQ0 TO DRQ1 (LS TTL)

Figure 2-9 Device Interface Circuits

### 2.2 MICROPROCESSOR

The functional heart of the Processor PCB is the NEC $\mu$ PD8086 Microprocessor, an NEC-manufactured device physically and logically interchangeable with the Intel 8086.

The 8086 is a high-performance 16-bit CPU packaged in a single 40-pin Dual In-line Package (DIP) chip. It has a direct addressing capability to 1 MB of memory on a 20 -bit address bus, of which bits 0 through 15 are time-multiplexed for the 16 -bit data bus. It is driven at a 4.9152 MHz clock rate and is used in maximum operating mode (using an external 8288 bus controller).

In general, the 8086 processes a program by repeated cycling through four clock steps, T1 through T4:

T1 fetches an instruction from memory
T2 reads in any required operand
T3 executes the instruction
T4 writes any required result.
In the 8086, two separate processors perform these steps independently and simultaneously: (1) an execution unit that executes instructions, and (2) a bus interface unit that fetches instructions and queues them up for use by the execution unit.

All registers and data paths within the execution unit are 16 bits wide for fast operation. A 16-bit arithmetic-logic unit manages the general registers and instruction operands and maintains status and control flags. The execution unit is a strictly internal device and has no connection to the outside world. All instructions and memory access operations are accomplished by the bus interface unit.

The bus interface unit functions as a good secretary by anticipating the needs of the execution unit and lining up sequential instructions for ready access. These instructions are stored in an internal queue RAM with a capacity of six bytes. The bus interface unit is programmed to keep this RAM filled, fetching two bytes at a time from even addresses and one byte at a time from odd addresses. When the execution unit requests a memory or I/O read or write, the bus interface unit discontinues instruction fetching and responds to the execution unit request. If the instruction executed calls for control transfer to another location, the bus interface unit empties the queue RAM, fetches the instruction from the new location, and feeds it directly to the execution unit. Then the bus interface unit proceeds to refill the queue RAM from sequential instructions from the new location.

The $1,048,576$ bytes of available memory space are addressed as if divided into logical segments of up to 64 KB each. The 8086 has direct access to four segments at a time, each of which has a base address carried in one of four segment registers: the Code Segment (CS), Data Segment (DS), Stack Segment (SS), and Extra Segment (ES). The Instruction Pointer (IP) register contains the present offset distance in bytes, which completes the logical address of the next address to be processed. The result of this memory organization is that the 20 -bit physical memory address can be defined by a logical address consisting of two 16 -bit bytes, the first specifying the base address of the selected segment and the second specifying the relative address within that segment, counting from the base address. To convert a logical address to a physical address, first shift the base address byte 4 bits to the left by multiplying it by sixteen, then add the result to the offset byte.

### 2.3 DIRECT MEMORY ACCESS

Because it bypasses processor intervention, DMA provides a much faster way of moving data between I/O devices and memory. Supported by the NEC LSI 8237-5 DMA Controller, DMA employs 16 address lines and 4 bits of page addressing, thus enabling it to address one megabyte of memory. Although the DMA is a synchronous device, it can interface with low-speed memory or I/O devices by using the external Ready line.

The four DMA channels are assigned as follows:
Channel 0 CRT
Channel 1 FDD
Channel 2 Reserved for graphic operations option
Channel 3 Future.
See Table 2-2 for a list of instructions and I/O addresses. Figures 2-10, 2-11, and 2-12 show the DMA registers.

Table 2-2 DMA Instructions

| INSTRUCTION | READ/ <br> WRITE | $\begin{gathered} \text { I/O } \\ \text { ADDRESS } \end{gathered}$ | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Write Command | W | 09 | K | D | W | P | T | C | A | M M |
| Write Mode | W | 1B | M S 1 | M S 0 | I | A | T R 1 | T R 0 | C S 1 | C S 0 |

Table 2-2 DMA Instructions (cont'd)

| INSTRUCTION | READ/ WRITE | $\begin{gathered} \text { I/O } \\ \text { ADDRESS } \end{gathered}$ | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 76 | 5 | 4 | 3 | 2 | 1 | 0 |
| Write RQ Register | W | 19 |  | - - | - |  | - | R B | C S 1 | C S 0 |
| Write Single Mask | W | 0B |  | - |  |  | - | M | C S 1 | C S 0 |
| Write All Mask | W | 1 F |  | - - | - | - | M B 3 | M B 2 | M B 1 | M B 0 |
| Read Status | R | 09 |  | $\begin{array}{ll}\text { R } & \mathrm{R} \\ \mathrm{Q} & \mathrm{Q} \\ 3 & \\ & 2\end{array}$ | R Q 1 | R Q 0 | T C 3 | T C 2 | T C 1 | T <br>  <br> 0 |
| CH0 DMA Address | R/W | 01 |  | $\begin{array}{ll} 7 & \text { A6 } \\ 15 \mathrm{~A} 14 \end{array}$ | $\begin{aligned} & \text { A5 } \\ & \text { A13 } \end{aligned}$ | $\begin{aligned} & \mathrm{A} 4 \\ & \mathrm{~A} 12 \end{aligned}$ | $\begin{aligned} & \text { A3 } \\ & \text { A11 } \end{aligned}$ | $\begin{array}{ll} \mathrm{A} 2 \mathrm{~A} \\ \mathrm{~A} 10 \mathrm{~A} \end{array}$ | $\begin{aligned} & \text { A1 } \\ & \text { A9 } \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { A8 } \end{aligned}$ |
| CH0 DMA Count | R/W | 11 |  | $\begin{aligned} & V 7 \text { W6 } \\ & 515 \mathrm{~W} 14 \end{aligned}$ | $\begin{aligned} & \text { W5 } \\ & + \text { W13 } \end{aligned}$ | $\begin{aligned} & \mathrm{W} 4 \\ & \mathrm{~W} 12 \end{aligned}$ | $\begin{aligned} & \text { W3 } \\ & \text { W11 } \end{aligned}$ | W2 W W10 W | $\begin{aligned} & \text { W1 } \\ & \text { W9 } \end{aligned}$ | $\begin{aligned} & \text { w0 } \\ & \text { W8 } \end{aligned}$ |
| CH1 DMA Address | R/W | 03 |  | $\begin{aligned} & 7 \mathrm{~A} 6 \\ & .15 \mathrm{Al4} \end{aligned}$ |  | $\begin{aligned} & \mathrm{A} 4 \\ & \mathrm{~A} 12 \end{aligned}$ |  | $\begin{array}{ll} \mathrm{A} 2 \mathrm{~A} \\ \mathrm{~A} 10 \mathrm{~A} \end{array}$ | $\begin{aligned} & \text { A1 } \\ & \text { A9 } \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { A8 } \end{aligned}$ |
| CH1 DMA Count | R/W | 13 |  | $\begin{aligned} & \mathrm{V7} \text { W6 } \\ & \text { V15 W } 14 \end{aligned}$ |  | $\begin{aligned} & \text { W4 } \\ & \text { W12 } \end{aligned}$ | $\begin{aligned} & \text { W3 } \\ & \text { W11 } \end{aligned}$ | W2 W W10 W | $\begin{aligned} & \text { W1 } \\ & \text { W9 } \end{aligned}$ | $\begin{aligned} & \text { w0 } \\ & \text { w8 } \end{aligned}$ |
| CH2 DMA Address | R/W | 05 |  | $\begin{aligned} & 7 \mathrm{~A} 6 \\ & 15 \mathrm{Al} 14 \end{aligned}$ |  |  | $\begin{aligned} & \text { A3 } \\ & \text { A11 } \end{aligned}$ | $\begin{aligned} & \text { A2 A } \\ & \text { A10 A } \end{aligned}$ | $\begin{aligned} & \text { A1 } \\ & \text { A9 } \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { A8 } \end{aligned}$ |
| CH2 DMA Count | R/W | 15 |  | $\begin{array}{ll} V 7 \text { W6 } \\ \text { V15 W14 } \end{array}$ | W5 $4 \mathrm{~W} 13$ | $\begin{aligned} & \mathrm{W} 4 \\ & \mathrm{~W} 12 \end{aligned}$ | $\begin{aligned} & \text { W3 } \\ & \text { W11 } \end{aligned}$ | $\begin{aligned} & \text { W2 } \\ & \text { W10 II } \end{aligned}$ | $\begin{aligned} & \text { W1 } \\ & \text { wV9 } \end{aligned}$ | $\begin{aligned} & \text { W0 } \\ & \text { w8 } \end{aligned}$ |
| CH3 DMA Address | R/W | 07 |  | $\begin{array}{ll} 7 & \text { A6 } \\ 15 \mathrm{Al4} \end{array}$ |  |  | $\begin{aligned} & \text { A3 } \\ & \text { A11 } \end{aligned}$ | $\begin{array}{ll} \mathrm{A} 2 \mathrm{~A} \\ \mathrm{~A} 10 \mathrm{~A} \end{array}$ | $\begin{aligned} & \text { A1 } \\ & \text { A9 } \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { A } \end{aligned}$ |
| CH3 DMA Count | R/W | 17 |  | $\begin{aligned} & \text { N7 W6 } \\ & \text { N15 W14 } \end{aligned}$ | W5 W13 | W4 W12 | $\begin{gathered} \text { W3 } \\ 2 \text { W11 } \end{gathered}$ | $\begin{aligned} & \text { W2 y } \\ & \text { W10 } \end{aligned}$ | $\begin{aligned} & \text { W1 } \\ & \text { W9 } \end{aligned}$ | $\begin{aligned} & \text { W0 } \\ & \text { W8 } \end{aligned}$ |

Table 2-2 DMA Instructions (cont'd)

| INSTRUCTION | READ/ WRITE | I/O <br> ADDRES | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CH0 Page Register | W | 38 | 0 | 0 | 0 | 0 | A | A 18 | A 17 |  |
| CH1 Page Register | W | 3A | 0 | 0 | 0 | 0 | A 19 | A 18 | A 17 | A 16 |
| CH2 Page Register | W | 3C | 0 | 0 | 0 | 0 | A 19 | A | A 17 | A 16 |
| CH3 Page Register | W | 3E | 0 | 0 | 0 | 0 | A 19 | A 18 | A 17 | A 16 |
| Read Temp Register | R | 1D | D 7 | D 6 | D 5 | D | D 3 | D 2 | D 1 | D 0 |
| Master Clear | W | 1D | - | - | - | - | - | - | - | - |



Figure 2-10 DMA Command and Mode Registers

MODE REGISTER


Figure 2-10 DMA Command and Mode Registers (cont'd)

## REQUEST REGISTER



SOFTWARE REQUESTS WILL BE SERVICED ONLY IF THE CHANNEL IS IN BLOCK MODE.
Figure 2-11 DMA Request and Mask Register

## MASK REGISTER



THE INSTRUCTION, WHICH SEPARATELY SETS OR CLEARS THE MASK BITS, IS SIMILAR IN FORM TO THAT USED WITH THE REQUEST REGISTER.


ALL FOUR BITS OF THE MASK REGISTER MAY ALSO BE WRITTEN WITH A SINGLE COMMAND.

Figure 2-11 DMA Request and Mask Register (cont'd)

STATUS REGISTER


THIS INFORMATION INCLUDES WHICH CHANNELS HAVE REACHED A TERMINAL COUNT AND WHICH CHANNELS HAVE A PENDING DMA REQUEST. BITS 0 THROUGH 3 ARE SET EVERY TIME A TC IS REACHED BY THAT CHANNEL OR AN EXTERNAL EOP IS APPLIED. THESE BITS ARE CLEARED UPON RESET AND ON EACH STATUS READ.

Figure 2-12 DMA Status Register

### 2.4 INTERVAL TIMER

The NEC $\mu$ PD8253-5 Programmable Interval Timer has three timer counter outputs: Channel 0 is attached to interrupt-request Channel 3; Channel 1 is sent to the synchronous/asynchronous communications controller on the Controller PCB (see Chapter 3); Channel 2 is not used. Figure 2-13 is a block diagram of the interval timer. Table 2-3 lists the timer commands.


Figure 2-13 Interval Timer Block Diagram

Table 2-3 Timer Commands

| INSTRUCTION | READ/ WRITE | $\begin{gathered} \text { I/O } \\ \text { ADDRESS } \end{gathered}$ | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Load Counter 0 | W | 29 | C 7 C 15 | C6 | $\begin{aligned} & \mathrm{C} 5 \\ & \mathrm{Cl} \end{aligned}$ |  | $\begin{aligned} & \mathrm{C} 3 \\ & \mathrm{C} 11 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 2 \\ & \mathrm{C} 10 \end{aligned}$ |  | $\begin{aligned} & \mathrm{C} 0 \\ & \mathrm{C} 8 \end{aligned}$ |
| Load Counter 1 | W | 2B | C 7 C 15 |  | $\begin{aligned} & \text { C5 } \\ & \text { C13 } \end{aligned}$ | C4 |  |  |  | $\begin{aligned} & \mathrm{C} 0 \\ & \mathrm{C} 8 \end{aligned}$ |
| Mode Set | W | 2F | S C 1 | S C 0 | R L 1 | R L 0 |  | M1 | M0 | B C D |
| Timer Reset | W | 46 | X | X | X | X |  | $\begin{aligned} & \mathrm{T} \\ & \mathrm{M} \end{aligned}$ | X | X |
| X: Don't care. |  |  |  |  |  |  |  |  |  |  |

### 2.5 INTERRUPT CONTROL

This interrupt function is controlled by two 8259 Metal Oxide Semiconductor (MOS) devices; each can handle up to eight vectored priority interrupts, as shown in Figure 2-14. The first 8259 device (master) supports IR0 through IR6, with IR7 cascaded from the second 8259 device (slave), which supports IR7 through IR14. These 15 available interrupt lines are assigned to service specific devices in order of priority. Table 2-4 lists the interrupt lines.

There are two interactions between the processor and the interrupt controller. The first is the acknowledgement process, during which the processor transmits acknowledgement of the interrupt request to the interrupt controller. During the second process, the interrupt controller transmits a byte of data to the processor (see Table 2-4).

Control commands issued by the processor, consisting of Initialization Command Words (ICW) and Operational Command Words (OCW), are summarized in Table 2-5 and shown in Figures 2-15 and 2-16. Table 2-5 also includes poll mode, read interrupt register (IRR), read inservice register (ISR), and interrupt register words that are read into the data bus by the interrupt controller when so commanded.


Figure 2-14 Interrupt Control Block Diagram
Table 2-4 Interrupt Lines

| DEVICE | INTERRUPT REQUEST LINE | ASSIGNMENT | INTERRUPT <br> VECTOR BYTE |
| :---: | :---: | :---: | :---: |
| Master | IR0 | Not used | T7 T6 T5 T4 T3 0 0 0 |
|  | IR1 | Communication | T7 T6 T5 T4 T3 0001 |
|  | IR2 | Not used | T7 T6 T5 T4 T3 0 1 0 |
|  | IR3 | Timer | T7 T6 T5 T4 T3 0 1 1 |
|  | IR4 | Keyboard | T7 T6 T5 T4 T3 1 100 |
|  | IR5 | Not used | T7 T6 T5 T4 T3 1 1001 |
|  | IR6 | Not used | T7 T6 T5 T4 T3 1110 |
| Slave | IR7 | Printer | T7 T6 T5 T4 T3 0 0 0 |
|  | IR8 | Not used | T7 T6 T5 T4 T3 0001 |
|  | IR9 | Not used | T7 T6 T5 T4 T3 0 1 0 |
|  | IR 10 | CRT | T7 T6 T5 T4 T3 0111 |
|  | IR11 | FDD | T7 T6 T5 T4 T3 1 1000 |
|  | IR 12 | Not used | T7 T6 T5 T4 T3 1 1001 |
|  | IR13 | Not used | T7 T6 T5 T4 T3 11100 |
|  | IR14 | APU | T7 T6 T5 T4 T3 1 1 1 |

Table 2-5 Interrupt Control Commands Summary

| DEVICE | INSTRUCTION | READ/ WRITE | $\begin{gathered} \text { I/O } \\ \text { ADDRESS } \end{gathered}$ | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Master | ICW 1 | W | 20 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
|  | ICW 2 | W | 22 | T7 | T6 | T5 | T4 | T3 | 0 | 0 | 0 |
|  | ICW 3 | W | 22 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | ICW 4 | w | 22 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
|  | OCW 1 | W | 22 |  | M6 | M5 | M4 | M3 | M2 | M1 | M0 |
|  | OCW 2 | w | 20 | R | $\mathrm{S}$ | $\begin{gathered} \mathrm{E} \\ \mathrm{O} \\ \mathrm{I} \end{gathered}$ | 0 | 0 | L2 | L1 | L0 |
|  | OCW 3 | w | 20 | 0 | E S M | S $M$ $M$ $M$ | 0 | 1 | P | P | R I S |
|  | Poll Mode | R | 20 | I | - | - | - | - | W2 | W1 | wo |
|  | Read IRR | R | 20 |  | I R 6 | I R 5 | I R 4 | I R 3 | I R 2 | I R 1 | I R 0 |
|  | Read ISR | R | 20 |  | I S 6 | I S 5 | I S 4 | I S 3 | I S 2 | I S 1 | I S 0 |
|  | Read Mask | R | 22 |  | M6 | M5 | M4 | M3 | M2 | M1 | M0 |
| Slave | ICW 1 | W | 28 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
|  | ICW 2 | w | 2A | T7 | T6 | T5 | T4 | T3 | 0 | 0 | 0 |
|  | ICW 3 | w | 2 A | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
|  | ICW 4 | w | 2 A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |

Table 2-5 Interrupt Control Commands Summary (cont'd)

| DEVICE | INSTRUCTION | READ/ WRITE | I/O <br> ADDRESS | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|  | OCW 1 | W | 2A | M14 M13 M12 M11 M10 M9 M8 M7 |  |  |  |  |  |  |  |
|  | OCW 2 | W | 28 | R | $\begin{aligned} & \mathrm{S} \\ & \mathrm{~L} \end{aligned}$ | $\begin{gathered} \mathrm{E} \\ \mathrm{O} \\ \mathrm{I} \end{gathered}$ |  | 0 | L2 | L1 | L0 |
|  | OCW 3 | W | 28 | 0 | $\begin{gathered} \mathrm{E} \\ \mathrm{~S} \\ \mathrm{M} \end{gathered}$ | S M M | 0 | 1 | P | R R | R I S |
|  | Poll Mode | R | 28 | I | - | - | - | - | W2 | W1 | wo |
|  | Read IRR | R | 28 | IR 14 | $\begin{aligned} & \text { IR } \\ & 13 \end{aligned}$ | IR 12 | $\begin{aligned} & \text { IR } \\ & 11 \end{aligned}$ | $\begin{aligned} & \text { IR } \\ & 10 \end{aligned}$ | IR 9 | IR | IR 7 |
|  | Read IRR | R | 28 | IS 14 | IS 13 | IS 12 | $\begin{aligned} & \text { IS } \\ & 11 \end{aligned}$ | $\begin{aligned} & \text { IS } \\ & 10 \end{aligned}$ | IS 9 | IS 8 | IS 7 |
|  | Read Mask | R | 2A | M14 M13 M12 M11 M10 M9 M8 M7 |  |  |  |  |  |  |  |

ICW1


ICW2
D7

| T7 | T6 | T5 | T4 | T3 | A10 | A9 | A8 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |



INTERRUPT VECTOR ADDRESS SET ALL "0"

ICW3 (MASTER)


1: IR INPUT HAS A SLAVE
0: IR INPUT DOES NOT HAVE A SLAVE
S0 TO S6 $=\mathbf{0}, \mathrm{S} 7=1$
ICW3 (SLAVE)


SLAVE ID
SET ALL TO " 1 "
ICW4


Figure 2-15 Interrupt Initialization Command Words

OCW1


Figure 2-16 Interrupt Operation Command Words

### 2.6 MEMORY

Figure 2-17 is the system memory map that shows how the memory space addresses are allocated.


Figure 2-17 System Memory Map

### 2.6.1 Main Memory

The Processor PCB contains 128 KB ( 64 Kwords: 16 bits of data, 18 bits wide, with 1 bit parity for each 8 bits)' of RAM, organized into eighteen $64 \mathrm{~K} \times 1$-bit dynamic memory chips. Figure 2-18 is a block diagram of the circuit. The RAM is refreshed during the non-memory-access cycle, and its access time is 200 ns. Parity check is carried out with two additional memory chips. A detected parity error lights the D4 red Light Emitting Diode (LED), located near the top edge of the Processor PCB.

As shown in Figure 2-17, the main memory is expandable to a maximum of 640 KB , of which 256 KB can be supported by the present APC equipment configuration.


Figure 2-18 Main Memory Block Diagram

### 2.6.2 Battery-Backed Memory

The BBM is composed of 4 K (two $2 \mathrm{~K} \mathrm{X} \mathrm{8-bit} \mathrm{chips)} \mathrm{of} \mathrm{Complementary} \mathrm{Metal} \mathrm{Oxide}$ Semiconductor (CMOS) static RAM and is addressable from A0000 through C0000 hexadecimal (HEX) in 324 K visible sections of memory, each section containing the same data. The APC uses partial address decoding of this 128 KB of memory, which results in 4 KB of BBM. The BBM contains system information and is protected from loss for at least two years by the battery that plugs into the Processor PCB.

As shown in Figure 2-19, the BBM read/write operation is identical to that of the main memory except for a BBM write protect circuit that safeguards the BBM from unintentional data manipulation.


Figure 2-19 Battery-Backed Memory Block Diagram

The BBM write protect command I/O port address is 59(HEX). A logical" 1 " on the Least Significant Bit (LSB) position on the data bus enables writing to the BBM; a " 0 " sets the BBM for write protection.

### 2.6.3 Read Only Memory

The Processor PCB contains 8K of ROM in two 4K x 8-bit Erasable Programmable Read-Only Memory (EPROM) chips. The ROM has two functions: flexible disk self-testing and bootstrap loading. As shown in Figure 2-17, the ROM occupies the 8 K addresses from FE000 through FFFFF and is visible in eight duplicate 8 K sections from F0000 through FFFFF. At APC power-on, the 8086 code segment and instruction-pointer registers are set to $\operatorname{FFFF}$ (HEX) and 0000(HEX) addresses respectively for loading and auto self-test, instructions for which are resident in the ROM.

### 2.7 PARALLEL PRINTER CONTROL

This portion of the logic provides an I/O TTL interface with an external parallel-data-bus printer.

As shown in Figures 2-20 and 2-21, the parallel printer control consists of an NEC $\mu$ PD8255A Programmable Peripheral Controller that interfaces with connector CN2 through LS244 drivers. A flat-type 26-conductor cable connects the CN2 board connector to a connector at the rear of the main unit that, in turn, goes to the printer. The pin connections are listed in Table 2-6. The interface is adaptable to either an Output Device Adapter (ODA) or Centronics-type printer by setting appropriate jumpers on TM2, TM3, and TM4 on the Processor PCB (see Figure 2-29).

### 2.7.1 Interface

Table 2-7 lists the interface lines.

### 2.7.2 Programming Considerations

The 8255 A device is operated in the APC as Mode 0 (basic I/O) in the Group A ports (Port A and upper 4 lines of Port C), and Mode 1 (strobed) in the Group B ports (Port B and lower 4 lines of Port C). The eight lines of Port B (PB0 through PB7) carry the strobed data to the printer; I/O control line levels are from Ports A and C .

Programming and execution of the 8255 is accomplished using the instructions described in Tables 2-8 and 2-9. Figures 2-22 and 2-23 show interline timing under various operating conditions.


Figure 2-20 Parallel Printer Control Block Diagram

Table 2-6 Parallel Printer Connectors Pin Assignments

| SIGNAL | PIN NUMBER AT A | PIN NUMBER AT B | PIN NUMBER AT C | REMARKS |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { DATA STB }}$ | 1 | 3 | 2 |  |
| DATA 1 |  | 6 | 16 |  |
| DATA 2 | 3 | 7 | 4 |  |
| DATA 3 | 4 | 8 | 17 |  |
| DATA 4 | 5 | 9 | 5 |  |
| DATA 5 | 6 | 10 | 18 |  |
| DATA 6 | 7 | 11 | 6 |  |
| DATA 7 | 8 | 12 | 19 |  |
| DATA 8 | 9 | 13 | 7 |  |
| $\overline{\text { ACK }}$ | 10 | 2 | 14 |  |
| Input Busy | 11 | 22 | 9 |  |
| PE | 12 | 29 | 25 |  |
| SELECT | 13 |  | 15 |  |
| Signal Ground | 14 | NC | NC |  |
| NC | 15 | NC | NC |  |
| Signal Ground | 16 | NC | NC |  |
| Chassis Ground | 17 | NC | NC |  |
| $+5 \mathrm{Vdc}$ | 18 | 27 | NC 24 |  |
| Twisted Pair - |  |  |  |  |
| Ground (Pin 1) | 19 | NC | NC |  |
| Ground (Pin 2) | 20 | 20 | 8 |  |
| Ground (Pin 3) | 21 | 21 | 21 |  |
| Ground (Pin 4) | 22 | 5 | 3 |  |
| Ground (Pin 5) | 23 | 24 | 10 |  |
| Ground (Pin 6) | 24 | 26 | 11 |  |
| Ground (Pin 7) | 25 | 28 | 12 |  |
| Ground (Pin 8) | 26 | 30 | 13 |  |
| Ground (Pin 9) | 27 | 31 | 26 |  |
| Ground (Pin 10) | 28 | NC |  |  |
| Ground (Pin 11) | 29 | NC |  |  |
| Ground (Pin 31) | 30 | NC |  |  |
| Input Prime | 31 | 23 | 22 |  |
| Fault | 32 | 25 | 23 |  |
| Signal Ground | 33 | NC | NC |  |
| NC | 34 | NC | NC |  |
| NC | 35 | 18 |  |  |
| Input Busy | 36 | NC | NC |  |
|  |  | 19 | 20 | No signal |
|  |  | 1 | 1 | No signal |



NOTE: SEE TABLE 2-6 FOR PIN NUMBERS AT LOCATIONS A, B, AND C.
Figure 2-21 Parallel Printer Cable Connect

Table 2-7 Parallel Printer Interface Signals

| SIGNAL | SOURCE | DESCRIPTION |
| :---: | :---: | :---: |
| RMS | APC | Receive Machine Set. <br> This signal is used with the ODA printer interface only. |
| BUSY | Printer | Goes high to indicate that the printer cannot receive data: <br> 1. During data entry <br> 2. During printing operation <br> 3. In offline state <br> 4. During printer error status. |
| $\overline{\text { STROBE }}$ | APC | Strobe pulse to read data in. The signal level is normally High. Read-in of data is performed at the Low level of this signal. |
| SG |  | Twisted-pair return signal ground level. |
| SELECT | Printer | Goes high to indicate that the printer is in selected state. |
| $\overline{\text { ACKNLG }}$ | Printer | Acknowledge goes Low to indicate that data has been received and that the printer is ready to accept other data. |

Table 2-7 Parallel Printer Interface Signals (cont'd)

| SIGNAL | SOURCE | DESCRIPTION |
| :---: | :---: | :---: |
| $\overline{\text { INPUT PRIME }}$ | APC | Goes Low to initialize the printer. |
| DATA 1 | APC | Data lines from 8255A, PB0 through PB7. High is logic 1; Low is logic 0 . |
| DATA 2 | APC |  |
| DATA 3 | APC |  |
| DATA 4 | APC |  |
| DATA 5 | APC |  |
| DATA 6 | APC |  |
| DATA 7 | APC |  |
| DATA 8 | APC |  |
| $\overline{\text { FAULT }}$ | Printer | Goes Low when the printer is in <br> 1. Paper End state <br> 2. Offline state <br> 3. Error state. |
| +5 V | Printer | Device Control (DCN) |
| PE | Printer | Goes high to indicate that printer is out of paper. |

Table 2-8 Parallel Printer Controller Instruction

| INSTRUCTION | READ/ <br> WRITE | I/O ADDRESS | DATA BUS |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 10 |
| Write Signal 0 | W | 6E | 1 | 0 | 0 | 1 | 0 | 1 | $0 \quad 0$ |
| Write Signal 1 | W | 6 E | 0 | 0 | 0 | 0 | 0 | 1 |  |
| Write Signal 2 | W | 6 E | 0 | 0 | 0 | 0 | 0 | 1 |  |
| Write Signal 3 | W | 6 E | 0 | 0 | 0 | 0 | 1 | 0 | $\begin{array}{ll} & \\ 0 & \mathrm{M} \\ \mathrm{A} \\ & \mathrm{S} \\ & \mathrm{K}\end{array}$ |
| Write Signal 4 | W | 6E | 0 | 0 | 0 | 0 | 1 | 1 | $\begin{array}{lc} \\ 1 & \mathrm{I} \\ \mathrm{R} \\ & \\ \\ \mathrm{T}\end{array}$ |
| Write Signal 5 | W | 6C | P | X | X | $\begin{gathered} \mathrm{M} \\ \mathrm{~A} \\ \mathrm{~S} \\ \mathrm{~K} \end{gathered}$ | X | X | X X |
| Read Signal | R | 68 | 5 | 0 | 0 | - F A U L T | S E L E C T | 0 | $\begin{array}{lr} \mathrm{R} & \\ \mathrm{D} & \mathrm{P} \\ \mathrm{R} & \mathrm{E} \\ \mathrm{Q} & \end{array}$ |
| Write Data | W | 6A |  | D A T A 7 | D A T A 6 | D A T A 5 | D A T A 4 | D A T A 3 | $\begin{array}{cc}\text { D } & \text { D } \\ \text { A } & \text { A } \\ \text { T } & \text { T } \\ \text { A } & \text { A } \\ 2 & 1\end{array}$ |

Table 2-9 Parallel Printer Controller Instruction Sequence

| INSTRUCTION | DESCRIPTION |  |
| :---: | :---: | :---: |
| Write Signal 0 | Set the 8255 Mode |  |
| Write Signal 1 | Interrupt Enable Flag (INTE) | 1: Flag On <br> 0 : Flag Off |
| Write Signal 2 (Not used for Centronics I/F) | Receive Machine Set (RMS) | $\begin{aligned} & \text { 1: RMS On } \\ & 0: \text { RMS Off } \end{aligned}$ |
| Write Signal 3 | $\begin{array}{ll} \text { Mask Set or Reset } & \text { 1: Reset } \\ & 0: \text { Set } \end{array}$ |  |
| Write Signal 4 | Input Prime (IP) Set or Reset | $\begin{aligned} & \text { 1: Reset } \\ & \text { 0: Set } \end{aligned}$ |
| Write Signal 5 | IP and Mask Set or Reset |  |
| Read Signal | Read the status of the printer |  |
| Write Data | Write data to be printed |  |

RECEIVE DATA


Figure 2-22 Parallel Printer Controller Interface Timing

DATA BUFFER FULL


Figure 2-22 Parallel Printer Controller Interface Timing (cont'd)

NO DATA IS IN THE DATA BUFFER


STORED DATA IS IN THE DATA BUFFER


Figure 2-23 Parallel Printer Controller Interface at Paper Out Status

### 2.8 KEYBOARD

The Keyboard employs capacitance technology and an 8048, 8-bit microprocessor that performs keyboard scanning and coding functions. It contains 109 keys in three major groupings. The central area is a standard typewriter layout. Above the central area are 22 user-definable function keys in a single row. To the right of the central area are 25 keys that consist of a numeric entry pad and a set of cursor/ control keys.

As shown in Figure 2-24, the Keyboard is arranged as a matrix ( $8 \times 16$ ), with 128 possible $\mathrm{X} / \mathrm{Y}$ coordinate output combinations (only 109 of which are represented by key positions). The 8048 microprocessor, in combination with an LS74159 decoder chip, produces a scan code output function peculiar to each key position and shift/control status. These scan codes are sent to the Processor PCB on an eight-bit scan data bus designated SD1 through SD8.


Figure 2-24 Keyboard Block Diagram
Pressing a key produces a strobe that latches the corresponding scan code into a key data register or switch (SW) register located on the Processor PCB and generates an interrupt request. Pressing a switch key (such as FNC or SHIFT) is recorded in an SW register on the Processor PCB, the output of which is combined with the key data register to produce the code output.

The CPU I/O address is hexadecimal 48 for the key data register and 4 C for the SW register. The CPU can also read the keyboard status at address 4A.

### 2.8.1 Keyboard Layout and Scan Codes

The Keyboard layout and designated key position numbers are shown in Figure 2-25. The corresponding scan codes are listed in Table 2-10. The scan codes are usually different than the hex codes for the keys. For hex code information, see Appendix D.
(1)

| PNC | PF2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| (2) | (3) | (4) | (5) | (6) | (7) | (8) | (9) | (10) | (11) | (12) | (13) | (14) | (15) | (16) | (17) | (18) | (19) | (20) | (21) | (22) | (23) |


(NUMBERS IN PARENTHESES DESIGNATE KEY POSITION)
$\square$ NONLOCKABLE SWITCH KEYS LOCKABLE SWITCH KEYS

Figure 2-25 Keyboard Layout
Table 2-10 Keyboard Scan Codes

| KEY <br> POSITION | SCAN <br> CODE | KEY <br> POSITION | SCAN <br> CODE | KEY <br> POSITION | SCAN <br> CODE |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $1^{*}$ | - | 38 | 9 C | 75 | 4 D |
| 2 | 80 | 39 | 98 | 76 | 2 C |
| 3 | 81 | 40 | 51 | 77 | 2 E |
| 4 | 82 | 41 | 57 | 78 | 2 F |
| 5 | 83 | 42 | 45 | $79^{*}$ | - |
| 6 | 84 | 43 | 52 | $80^{*}$ | - |
| 7 | 85 | 44 | 54 | $81^{*}$ | - |
| 8 | 86 | 45 | 59 | 82 | 20 |

[^0]Table 2-10 Keyboard Scan Codes (cont'd)

| $\begin{gathered} \text { KEY } \\ \text { POSITION } \end{gathered}$ | $\begin{aligned} & \text { SCAN } \\ & \text { CODE } \end{aligned}$ | $\begin{gathered} \text { KEY } \\ \text { POSITION } \end{gathered}$ | $\begin{aligned} & \text { SCAN } \\ & \text { CODE } \end{aligned}$ | $\begin{gathered} \text { KEY } \\ \text { POSITION } \end{gathered}$ | $\begin{aligned} & \text { SCAN } \\ & \text { CODE } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 9 | 87 | 46 | 55 | 83* | - |
| 10 | 88 | 47 | 49 | 84 | 9 E |
| 11 | 89 | 48 | 4 F | 85 | FB |
| 12 | 8A | 49 | 50 | 86 | 6F |
| 13 | 8B | 50 | 5B | 87 | 9 A |
| 14 | 8 C | 51 | 5D | 88 | FF |
| 15 | 8D | 52 | 5 C | 89 | 96 |
| 16 | 8 E | 53 | 5E | 90 | FC |
| 17 | 8 F | 54* | - | 91 | 6A |
| 18 | 90 | 55* | - | 92 | 77 |
| 19 | 91 | 56 | 41 | 93 | 78 |
| 20 | 92 | 57 | 53 | 94 | 79 |
| 21 | 93 | 58 | 44 | 95 | 6D |
| 22 | 94 | 59 | 46 | 96 | F7 |
| 23 | 95 | 60 | 47 | 97 | 74 |
| 24 | 1 B | 61 | 48 | 98 | 75 |
| 25 | 31 | 62 | 4A | 99 | 76 |
| 26 | 32 | 63 | 4B | 100 | 6B |
| 27 | 33 | 64 | 4 C | 101 | FA |
| 28 | 34 | 65 | 3A | 102 | F9 |
| 29 | 35 | 66 | 3B | 103 | 71 |
| 30 | 36 | 67 | 97 | 104 | 72 |
| 31 | 37 | 68* | - | 105 | 73 |
| 32 | 38 | 69 | 5A | 106 | FD |
| 33 | 39 | 70 | 58 | 107 | F8 |
| 34 | 30 | 71 | 43 | 108 | 70 |
| 35 | 50 | 72 | 56 | 109 | 6 E |
| 36 | 2D | 73 | 42 |  |  |
| 37 | 40 | 74 | 4E |  |  |
| *Positions 1 (FNC), 54 (CTRL), 55 (CAPSLOCK), 68 and 79 (SHIFT), 80 (GRPH 1), 81 (GRPH 2), and 83 (ALT) must be used with another key to generate a scan code. |  |  |  |  |  |

### 2.8.2 Interface

The Keyboard connects with a coiled multiconductor cable to the rear of the Main Unit (see Figure 2-26 and Table 2-11). The cable is a shielded 19 -wire design that includes power $(+5 \mathrm{Vdc})$, grounds, and twelve signal lines. The cable is permanently attached to the Keyboard.


Figure 2-26 Keyboard Interface

Table 2-11 Keyboard Interface Lines

| PIN | SIGNAL |
| :---: | :--- |
| 1 | Not used |
| 2 | Not used |
| 3 | Keyboard Data 1 |
| 4 | Keyboard Data 2 |
| 5 | Keyboard Data 3 |
| 6 | Keyboard Data 4 |
| 7 | Keyboard Data 5 |
| 8 | Keyboard Data 6 |
| 9 | Keyboard Data 7 |
| 10 | Keyboard Data 8 |
| 11 | Signal Ground |
| 12 | Data Strobe |
| 13 | Signal Ground |
| 14 | Not used |
| 15 | Not used |
| 16 | Switch Strobe |
| 17 | Not used |
| 18 | Not used |
| 19 | Debug |
| 20 | Signal Ground |
| 21 | Signal Ground |
| 22 | Signal Ground |
| 23 | +5 Vdc |
| 24 | +5 Vdc |
| 25 | Not used |
| 26 | Not used |

### 2.9 CALENDAR AND CLOCK GENERATOR

The Calendar and Clock Generator is supported by a CMOS Integrated Circuit (IC) (NEC $\mu$ PD1990AC). This IC independently registers the month, day of the month, day of the week, hour, minute, and second, and it can receive or send this information from or to the microprocessor. Because this IC carries out all clock functions, it frees the microprocessor from these duties, increasing the capabilities of the microprocessor in other areas.

### 2.9.1 Circuit Description

As shown in Figure 2-27, the clock generator is driven by a 32.768 kHz crystal oscillator. Should a powèr break occur, system battery power prevents calendar-and-clock data loss. A 14-pin IC encloses all functions.


Figure 2-27 Clock/Calendar Block Diagram

### 2.9.2 Programming Considerations

Input and output of clock/calendar data is a vailable on command as a 40-bit serial word having the following format.
MSB

| 4 bits | 4 bits | 8 bits | 8 bits | 8 bits | 8 bits |
| :---: | :---: | :---: | :---: | :---: | :---: |
| month | day of wk. | date | hour | minute | second |

The write/read instruction format is shown in Table 2-12 and Figure 2-28.

Table 2-12 Clock/Calendar Instruction Format


## COMMAND SUMMARY

(1) SET REGISTER

(2) READ DATA

$0=$ NORMAL (ELECTRO-CHEM $>3.0 \mathrm{~V}$, SANYO $>2.3 \mathrm{~V}$ )
$1=$ LOW (ELECTRO-CHEM $\leqq 3.0 \mathrm{~V}$, SANYO $\leqq 2.3 \mathrm{~V}$ )

Figure 2-28 Clock/Calendar Format

### 2.10 JUMPER SETTINGS

The Processor PCB has four jumpers (TM1, TM2, TM3, and TM4). TM1 is not related to system functions, but to battery replacement. To prevent harm to the diode when replacing the battery, TM1 must be removed.

To adapt the APC interface for a Centronics-type or ODA printer, set TM2, TM3, and TM4 as instructed in Figure 2-29.


Figure 2-29 Processor PCB Jumper Settings

## Chapter 3

## Controller PCB



The Controller PCB (G9PFCU) is the same size and has the same general physical arrangement as the Processor PCB. Like the Processor PCB, it fits into the Mother Board with a 100 -pin card-edge socket. It is normally located in the first slot position (closest to the CRT).

Installed on the Controller PCB are five cable connectors: a communications interface connector, a CRT interface connector, an FDD interface connector, a speaker interface connector, and a volume interface connector (see Figure 3-1).

Figure 3-2 shows the functional relationships between the five principal components that occupy the Controller PCB.

- CRT Display control for the 12 -inch monochrome or color display -designed around the $\mu$ PD7220 graphic display controller
- An 8-inch FDD control, that can read from and drive double-sided doubledensity flexible disks or single-sided single-density disks
- Serial I/O device control, supported by the NEC 8251A controller, converts serial data to parallel data and parallel data to serial data -- it can do so synchronously or asynchronously, using half- or full-duplex at various baud rates
- Sound control is supported by Large-Scale Integration (LSI) NEC $\mu$ PD1771-006 and generates signal beeps and programmed melodies
- Arithmetic processing unit, an optional device, that provides high performance fixed-and-floating-point arithmetic operations and floating-point trigonometric operations.


### 3.1 MOTHER BOARD/CARD CAGE INTERFACE

For a description of this interface, see Section 2.1.


Figure 3-1 Controller PCB


Figure 3-2 Controller PCB Block Diagram

### 3.2 CRT DISPLAY CONTROL

This adapter connects the microprocessor with a 12 -inch monochrome or color display. At the heart of this computer-graphics system is the $\mu$ PD7220 Graphic Display Controller (GDC), an intelligent LSI microprocessor that carries out the high-speed and repetitive duties required to generate the raster display and manage the display memory. The GDC duties include

- Generating the basic video raster timing (including sync and blanking signals)
- Video-display-memory modification and data moves
- Calculating display-memory addresses.

Some characteristics of the CRT-control design are

- Display buffer is independent of system memory
- An 80 -character by 25 -line screen ( 2000 characters)
- A 26th line reserved for system status information
- Direct drive output
- An 8-dot by 19 -dot character box
- A 7-dot by 11-dot character
- 8 -dot by 16 -dot special programmable characters.

A character generator supplies the video process logic with the information necessary for displaying the characters. Additionally, a special-character generator contains the fonts for user-programmable characters; these are 8 by 16 characters in 8 by 19 character boxes.

In the display-control adapter is a character-code buffer memory that stores character codes or special-character codes (each character has 1 of 256 codes in RAM or 250 codes in ROM, of which 6 in ROM are not assigned) and an attribute-code buffer memory that stores character attributes (each character is associated with one or more of eight attributes). Figure 3-3 shows the functional relationships between the principal components of CRT control.


Figure 3-3 CRT Display Control Block Diagram

### 3.2.1 Display Buffer Memory

There are 2000 positions on the display screen, and each position is associated with 3 bytes ( 24 bits) of display buffer memory. Two of the three bytes of data indicate the character code or special-character code for an individual display position. $\mathrm{A}^{\prime} 1^{\prime}$ in the character-set bit (Bit 7) indicates that the character comes from the special (or user programmed) character set (see Figure 3-4).


Figure 3-4 Character-Code Representation in the Character Code Buffer Memory

The character code (or special-character code) indicates to the character generator which of the 256 possible characters to display in a given display position. Also associated with each display position is an attribute code, which requires the third byte of data. The attribute code specifies the absence or presence of eight possible character supplements, which are shown in Table 3-1 and Figure 3-5.

Table 3-1 Attribute Description for Character Attribute Code

| ATTRIBUTE | FUNCTION | COMMENT |
| :--- | :--- | :--- |
| GR | Green | $\begin{array}{l}\text { Must always equal '1' with } \\ \text { monochrome display. }\end{array}$ |
| R/H | Blue | $\begin{array}{l}\text { Red/ } \\ \text { highlight } \\ \text { RVacter is blue. }\end{array}$ |
| Bed color (color display)/high- |  |  |
| Reverse |  |  |
| lighted character (monochrome). |  |  |
| video |  |  |\(\left.\quad \begin{array}{l}Character and Field Video <br>


transposed.\end{array}\right\}\)| Blinking |
| :--- |$\quad$| Vertical bar |
| :--- |
| UB |


| BIT NUMBER | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ATTRIBUTE CODE | GR | BU | R/H | RV | BL | VB | OB | UB |

Figure 3-5 Bit Map for Character Attribute Code

Therefore, associated with each display position are a character code (or specialcharacter code) and an attribute code. Both codes are stored in different physical areas of the display buffer memory, which is separate from main memory and accessible to only the GDC. This buffer has four $2 \mathrm{~K} \times 8$-bit CMOS static RAMs for the character-code memory and two $2 \mathrm{~K} \times 8$-bit CMOS static RAMs for the attribute-code memory.

The logical arrangement of this buffer is seen as a single $4 \mathrm{~K} \times 24$-bit storage area, with associated character codes and attribute codes logically concatenated into single 24-bit words. Specifically, for any given display unit, the bit address of its character code is identical to that of its attribute code except for Bit 12. Bit 12 is ' 0 ' for the character-code address and ' 1 ' for the attribute-code address. For example, character-code address ' 0000 ' is associated with attribute-code address ' $1000^{\prime}$ because their addresses are identical except for Bit 12. Figure 3-6 is a memory map that shows the organization of the display buffer memory. Notice that Bit 12 determines whether an address accesses a character code (Bit $12=0$ ) or a character attribute code (Bit $12=1$ ).


Figure 3-6 Display Buffer Memory Map

Controller PCB


Figure 3-7 Relationship Between Character Code, Character-Attribute Code, Display Position, and Video Screen

### 3.2.2 Programming Considerations

The GDC has four registers, all of which can be accessed directly or indirectly by the 8086 processor: status register, First-In First-Out (FIFO), command register, and data register. The I/O addresses, functions, and bit maps are summarized in Table 3-2.

The status register is an 8 -bit read-only register. Its I/O address is 80 (HEX). Using the $8086 \mathrm{I} / \mathrm{O}$ In command, the status register can be read at any time.

Figure 3-8 is a bit map of the GDC status register. Table 3-3 describes the contents of the status register.

Table 3-2 GDC I/O-Address and Bit Map


BIT


Figure 3-8 GDC Status Register Bit Map

Table 3-3 Contents of the GDC Status Register

| BIT | DESCRIPTION |
| :---: | :---: |
| 0 | When this flag is a ${ }^{\prime} 1^{\prime}$, it indicates that a byte is available to be read by the system microprocessor. This bit must be tested before each read operation. It drops to a ' 0 ' while the data is transferred from the FIFO into the microprocessor interface data register. |
| 1 | $\mathrm{A}^{\prime} 1^{\prime}$ at this flag indicates a full FIFO in the GDC. A $0^{\prime}$ ' ensures that there is room for at least one byte. This flag needs to be checked before each write into the GDC. |
| 2 | This bit and the FIFO-Full flag coordinate system microprocessor accesses with the GDC FIFO. When the bit is' 1 ', the Empty flag ensures that the commands and parameters previously sent to the GDC have been processed. |
| 3 | While the GDC is drawing a graphics figure, this status bit is a ${ }^{\prime} 1$ '. |
| 4 | This bit is a ' 1 ' during DMA data transfers. |
| 5 | Vertical retrace sync occurs while this flag is a ' 1 '. The vertical sync flag coordinates display format modifying commands to the blanked interval surrounding vertical sync. This eliminates display disturbances. |
| 6 | A ' 1 ' value for this flag signifies that horizontal retrace blanking is currently underway. |
| 7 | Not used. |

The FIFO is an internal buffer of the GDC that stores microprocessor commands. Access to the FIFO is coordinated through flags in the status register. The command processor fetches command bytes from the FIFO and interprets them. The command bytes are decoded and succeeding parameters are distributed to their proper destinations within the GDC. The command processor yields to the bus interface when both access the FIFO simultaneously.

The Parameter RAM stores parameters that are used repetitively during the display and drawing processes.

Table 3-4 defines the GDC abbreviations and symbols. Table 3-5 lists and describes the GDC commands. Table 3-6 lists the command constants. The APC uses the GDC in Character Mode only.

Table 3-4 GDC Symbols

| SYMBOL | NAME | DESCRIPTION |
| :---: | :---: | :---: |
| A0 TO A15 | Address 0 to <br> Address 15 | Controls display position of cursor. |
| BLD | Blinking Disable | Cursor blinks $(B L D=0)$ or does not blink ( $\mathrm{BLD}=1$ ). |
| BL | Blinking Rate | Controls frequency of blinking. |
| CF1 | Cursor Finish | Controls at which line the cursor finishes. |
| CHR | Character Mode | Character Mode (CHR) and Graphic Mode (G) define the display modes as follows: |
|  |  | $\frac{\text { CHR }}{0}$  $\frac{\mathrm{G}}{0}$  <br> 1   Mode <br> 0   Character Mode 0 <br> 0 1  Not Used Mode 1 |
| CIR | Circle | Indicates that a circle is being drawn if $\mathrm{CIR}=1$. |
| CSR | Display Cursor | Controls presence $(\operatorname{CSR}=1)$ or absence $(\mathrm{CSR}=0)$ of the cursor. |
| CST | Cursor Start | Controls at which line the cursor starts. |
| C/R | Character Per Row | Defines horizontal display period. |

Table 3-4 GDC Symbols (cont'd)

| SYMBOL | NAME | DESCRIPTION |
| :---: | :---: | :---: |
| DE | Display Enable | Controls display start ( $\mathrm{DE}=1$ ) or display stop ( $\mathrm{DE}=0$ ). |
| DIR | Direction | Controls drawing direction. |
| D | Dynamic RAM | $\mathrm{D}=1$ implies display buffer consists of dynamic RAM; otherwise ( $\mathrm{D}=0$ ) consists of static RAM. |
| F | Flashless Mode | Controls for flashless drawing ( $\mathrm{F}=1$ ) or flashing drawing ( $\mathrm{F}=0$ ). |
| G | Graphic Mode | Not used; see CHR. |
| HBP | Horizontal <br> Back Porch | Defines the amount of left horizontal blanking time. |
| HFP | Horizontal Front Porch | Defines the amount of right horizontal blanking time. |
| HOS | Horizontal Sync | Horizontal sync occurs when HOS $=1$. |
| I | Interlace | Display is interlaced $(\mathrm{I}=1)$ or not interlaced ( $\mathrm{I}=0$ ). |
| LIN | Line | $\operatorname{LIN}=1$ indicates that line is being drawn. |
| L/F | Lines Per Frame | Defines the number of lines in the vertical display period. |
| L/R | Lines Per Row | $\mathrm{L} / \mathrm{R}$ defines the number of lines in each row. |
| M | Master | $\mathrm{M}=0$ indicates GDC is in multi (slave)mode; $\mathbf{M}=1$ indicates single (master)mode. The APC only uses master mode. |

Table 3-4 GDC Symbols (cont'd)

| SYMBOL | NAME | DESCRIPTION |
| :---: | :---: | :---: |
| MOD | Modify | Controls data that is accessed by CODEW command or CODER command. |
| RAD | RAM Address | RAD defines the RAM address that stores the scroll address. |
| REC | Rectangle | $\mathrm{REC}=1$ indicates that a rectangle is being drawn. |
| S | Shrink | Affects line center ( $\mathrm{S}=1$ ). |
| SL0 to SL9 | Scroll Line | Controls scroll-line count. |
| SLA | Slant | Controls slant of text or drawing. |
| VBP | Vertical <br> Back Porch | Defines the amount of upper vertical blanking time. |
| VES | Vertical Sync | Vertical sync occurs when VES $=1$. |
| VFP | Vertical <br> Front Porch | Defines the amount of lower vertical blanking time. |

Table 3-5 GDC Commands


Table 3-5 GDC Commands (cont'd)


Table 3-5 GDC Commands (cont'd)


Table 3-5 GDC Commands (cont'd)


Table 3-6 GDC Command Constants

| COMMAND/ <br> PARAMETER | SETTING VALUE <br> (HEX) | REMARKS |
| :---: | :---: | :---: |
| C | SYNCSET | Character display mode ' 0 ': no |
| P1 | 10 | interlace, flashless drawing, static |
| P2 | 4 E | RAM, 80 characters per row |
| P3 | 52 |  |
| P4 | 0E |  |
| P5 | 06 |  |
| P6 | 13 |  |
| P7 | EE |  |
| P8 | 45 |  |
| C | Master/slave | Master versus slave video synchronization |
| $\begin{aligned} & \text { C } \\ & \text { P1 } \end{aligned}$ | $\begin{gathered} \text { ZOOM W } \\ 00 \end{gathered}$ | Zooming disabled |
| C | CSR DISP | Blinking block cursor |
| P1 | 12 Cl |  |
| P3 | 8B |  |
| $\begin{aligned} & \mathrm{C} \\ & \mathrm{P} 1 \end{aligned}$ | $\begin{gathered} \text { PITCH W } \\ 50 \end{gathered}$ | 80 characters per row |
| C | MASK W |  |
| P1 | FF |  |
| P2 | FF |  |

### 3.3 CRT DISPLAY UNIT

The CRT Display unit consists of a chassis-mounted circuit, a 12-inch monochrome or color CRT Display, Controller PCB, and internal power unit.

The monochrome or color display units connect to the Controller PCB (see Figures 3-9 and 3-10).


Figure 3-9 Monochrome-CRT Display Interface


PIN ASSIGNMENT


Figure 3-10 Color-CRT Display Interface

Another internal cable, the power supply cable, carries 115 Vac power from the system power supply to the internal power supply of the CRT Display. This internal power unit provides the CRT Display with +12 Vdc .

The following items are the principal operating characteristics of the monochrome CRT Display.

- Display control. A brightness control knob is available to the operator on the front of the unit.
- Monochrome Display screen. The Monochrome CRT Display employs a yellow-green, long-persistence phosphor (P39) and has a reduced-glare surface. The display format is 80 characters wide by 25 lines high plus one status line. Each standard character consists of a 7 (width)-by-11 (height) dot matrix. Special characters can be as large as 8 -by- 16 dots. The screen is composed of 475 lines of vertical resolution.
- Color Display screen. The Color Display has an 8-color, high-resolution, reduced-glare screen.
- Horizontal drive. This positive level, TTL compatible frequency is 22.727 kHz . The minimum pulse width is $3 \mu \mathrm{~s}$.
- Vertical drive. This frequency is 41.5 Hz and is negative level/TTL compatible.
- Video signal. The video signal is positive level with a 50 -ns minimum pulse width.
- CRT Display interface.


### 3.4 FLEXIBLE DISK DRIVE CONTROLLER

The APC has space and power for two 8-inch FDDs. The drives are soft-sectored and two-sided, with 77 cylinders ( 0 to 76 ). They use Modified Frequency Modulation (MFM) coded in 256 byte sectors (except index track), giving an unformatted capacity of about 1.2 MB per drive. They have a track access time of 5 ms .

The 8 -inch Flexible Disk Drive Controller (FDC) on the Controller PCB attaches to the FDD with an internal flat cable, which is daisy-chained if there are two FDDs.

The FDC is designed for double-density MFM-coded drives, uses write precompensation, and employs the NEC $\mu$ PD765. The FDC uses DMA for record-data transfers. An interrupt level indicates completed operation or a status condition that requires processor attention.

Figure $3-11$ is a functional block diagram of the FDC. This controller contains two registers that can be accessed by the main processor: a status register and a data register. The 8 -bit main status register contains the status information of the FDC and can be accessed at any time. This register facilitates the transfer of data between the processor and FDC. It can be read only. Table 3-7 summarizes the bit functions of the main status register.

The 8-bit data register (which actually consists of several registers in a stack with only one register presented to the data bus at a time) stores data, commands, parameters, and FDD status information. Data bytes are written into the data register to program the FDC and are read out of it to obtain results after a command.

The FDC can perform 15 different commands. Each command is initiated by a multibyte transfer from the processor, and the result after execution of the command can also be a multibyte transfer back to the processor. Because of this multibyte interchange of information between the FDC and the processor, each command can be considered in three phases.

- Command Phase - The FDC receives all information required to perform a particular operation from the processor.
- Execution Phase - The FDC performs the operation.
- Result Phase - Status and other housekeeping information are made available to the processor.


Figure 3-11 FDC Block Diagram

Table 3-7 Bit Description of the FDC Main Status Register

| $\begin{gathered} \text { BIT } \\ \text { NUMBER } \end{gathered}$ | NAME | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| DB0 | FDD A Busy | DAB | FDD A is in the Seek Mode. |
| DB1 | FDD B Busy | DBB | FDD B is in the Seek Mode. |
| DB2 | FDD C Busy | DCB | Not used. |
| DB3 | FDD D Busy | DDB | Not used. |
| DB4 | FDC Busy | CB | A read or write command is in process. |
| DB5 | Non-DMA <br> Mode | NDM | The FDC is in the Non-DMA Mode. |
| DB6 | Data Input/ Output | DIO | Indicates direction of data transfer between the FDC and the processor. DIO = ' 1 ' indicates transfer is from FDC data register to the processor; DIO = '0' indicates transfer is from processor to FDC data register. |
| DB7 | Request for Master | RQM | Indicates Data Register is ready to send or receive data to or from the processor. Both bits DIO and RQM should be used to perform the handshaking functions of "ready" and "direction" to the processor. |

Figure 3-12 is a timing diagram that defines the timing of this three-phase command process.


Figure 3-12 FDC Timing Diagram

### 3.4.1 Programming Considerations

Table 3-8 defines the symbols used in the FDC command summary given in Table 3-9. Tables 3-10, 3-11, 3-12 and 3-13 define the bit functions of the command status registers. Table 3-14 lists the I/O addresses and functions of the FDC registers.

Table 3-8 FDC Symbols

| SYMBOL | NAME | DESCRIPTION |
| :--- | :--- | :--- |
| A0 | Address Line 0 | Controls the selection of the Main Status <br> Register (A0=0) or Data Register <br> $(\mathrm{A} 0=1)$. |
| D | Cylinder Number | Specifies the selected cylinder number. <br> Specifies the data pattern that is going to <br> be written into a sector. |
| D7 to D0 | Data Bus | 8-bit Data Bus, where D7 is the most <br> significant bit, and D0 is the least <br> significant bit. |
| DTL | Data Length | When N is defined as 00, DTL is the <br> data length that users are going to read <br> out or write into the sector. |
| EOT | End of Track | Indicates the final sector number on a <br> cylinder. |

Table 3-8 FDC Symbols (cont'd)

| SYMBOL | NAME | DESCRIPTION |
| :---: | :---: | :---: |
| GPL | Gap Length | Specifies length of Gap 3 (spacing between sectors excluding VCO Sync. Field). |
| H | Head Address | Specifies the head number 0 or 1 , as specified in the ID field. |
| HD | Head | Specifies the selected head number 0 or 1. ( $\mathrm{H}=\mathrm{HD}$ in all command words.) |
| HLT | Head Load Time | Indicates the head load time in the FDD ( 2 to 256 ms in $2-\mathrm{ms}$ increments). |
| HUT | Head Unload Time | Indicates the head unload time after a read or write operation has occurred (0 to 240 ms in $16-\mathrm{ms}$ increments). |
| MF | FM or MFM Mode | If MF is Low, FM Mode is selected; if High, MFM Mode is selected only if MFM is implemented. |
| MT | Multi-Track | If MT is High, a multitrack operation is to be performed. (A cylinder under both HD0 and HD1 is read or written.) |
| N | Number | Specifies the number of data bytes written in a sector. |
| NCN | New Cylinder Number | New cylinder number, which is going to be reached as a result of the Seek operation. Desired position of head. |
| ND | Non-DMA Mode | Signals that operation is Non-DMA Mode. |
| PCN | Present Cylinder <br> Number | Designates cylinder number at the completion of Sense Interrupt Status Command, indicating the position of the head at present time. |

Table 3-8 FDC Symbols (cont'd)

| SYMBOL | NAME | DESCRIPTION |
| :---: | :---: | :---: |
| R | Record | Specifies the sector number, which is read or written. |
| R/W | Read/Write | Specifies the Read (R) or Write (W) signal. |
| SC | Sector | Indicates the number of sectors per cylinder. |
| SK | Skip | Specifies the Skip Deleted Data Address Mark. |
| SRT | Step Rate Time | Specifies the Stepping Rate for the FDD ( 1 to 16 ms in $1-\mathrm{ms}$ increments). |
| ST 0 | Status 0 | Specifies which of four registers will |
| ST 1 | Status 1 | store the status information after a |
| ST 2 | Status 2 | command has been executed. This |
| ST 3 | Status 3 | information is available during the result phase after command execution. These registers should not be confused with the main status register (selected by A0 0 ). ST 0 to 3 can be read only after a command has been executed. They contain information relevant to that particular command. |
| STP | Scan Test | During a Scan operation, if STP $=1$, the data in contiguous sectors is compared byte by byte with data sent from the processor (or DMA). If STP $=2$, then alternate sectors are read and compared. |
| $\begin{aligned} & \text { US0, } \\ & \text { US1 } \end{aligned}$ | Unit Select | Specifies the selected drive number. |

Table 3-9 FDC Commands


Table 3-9 FDC Commands (cont'd)


Table 3-9 FDC Commands (cont'd)


Table 3-9 FDC Commands (cont'd)


Table 3-9 FDC Commands (cont'd)


Table 3-9 FDC Commands (cont'd)


Table 3-10 FDC Status Register 0

| NUMBER | BIT <br> NAME | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: | :--- |$|$| D7terrupt |
| :--- |
| D6 |
| Code |

Table 3-11 FDC Status Register 1

| NUMBER | BIT <br> NAME | SYMBOL | DESCRIPTION |
| :---: | :--- | :---: | :--- | D6 | End of |
| :---: |
| Cylinder |
| D5 |

Table 3-12 FDC Status Register 2

| NUMBER | BIT <br> NAME | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| D7 | - | - | Not Used. This bit is always 0 (Low). |
| D6 | Control Mark | CM | During execution of the Read Data or Scan command, if the FDC encounters a sector that contains a Deleted Data Address Mark, this flag is set. |
| D5 | Data Error in Data Field | DD | If the FDC detects a CRC error in the data, then this flag is set. |
| D4 | Wrong Cylinder | WC | This bit is related with the ND bit, and when the contents of C on the medium are different from that stored in the ID Register, this flag is set. |
| D3 | Scan Equal Hit | SH | During execution of the Scan command, if the condition of "equal" is satisfied, this flag is set. |
| D2 | Scan Not Satisfied | SN | During execution of the Scan command, if the FDC cannot find a sector on the cylinder that meets the condition, then this flag is set. |
| D1 | Bad Cylinder | BC | This bit is related with the ND bit, and when the contents of $C$ on the medium are different from that stored in the ID Register and the content of C is FF , then this flag is set. |
| D0 | Missing Address Mark in Data Field | MD | When data is read from the medium, if the FDC cannot find a Data Address Mark or Deleted Data Address Mark, then this flag is set. |

Table 3-13 FDC Status Register 3

| NUMBER | BIT <br> NAME | SYMBOL | DESCRIPTION |
| :---: | :--- | :---: | :--- |
| D7 | Fault | FT | Indicates the status of the Fault <br> signal from the FDD. |
| D5 | Ready | WP | Indicates the status of the Write <br> Protected signal from the FDD. |
| D4 | Track 0 | T0 | Indicates the status of the <br> Ready signal from the FDD. <br> Indicates the status of the Track <br> 0 signal from the FDD. <br> D3 |
| Two Side | TS | Indicates the status of the Two <br> Side signal from the FDD. |  |
| D1 | Unit Select 1 | US 1 | Indicates the status of Side <br> Select signal to the FDD. <br> Indicates the status of the Unit <br> Select 1 signal to the FDD. |
| D0 | Unit Select 0 | US 0 | Indicates the status of the Unit <br> Select 0 signal to the FDD. |

Table 3-14 FDC Register I/O Addresses and Functions

| I/O <br> ADDRESS | READ/ <br> WRITE | FUNCTION |
| :---: | :--- | :---: |
| 50 | Read | Read-Status Register |
| 52 | Read | Read-Data Register |
| 52 | Write | Write-Data Register |

### 3.4.2 Drive A and B Interface

All signals are TTL compatible, and all outputs are driven by open-collector gates. The drives provide termination networks; each input is terminated with a 150 -ohm resistor. The output signals are described in Table 3-15, the input signals are described in Table 3-16.

Table 3-15 Output Signals

| SIGNAL | DRIVER | DESCRIPTION |
| :---: | :---: | :---: |
| Drive Select A and B | 7445 | When the line associated with a drive is not active, these two lines are used by Drives A and B to degate all drivers to the adapter and all receivers from the attachment. |
| Step | 7406 | The selected drive moves the read/write head one cylinder in or out (according to the direction-line signal) for each pulse present on this line. |
| Direction | 7406 | For each recognized pulse of the step line, the read/write head moves one cylinder toward the spindle if this line is active, and away from the spindle if this line is inactive. |
| Write Data | 7406 | For each inactive-to-active transition of this line (while Write Enable is active), the selected drive causes a flux change to be stored on the disk. |
| Write Gate | 7406 | Unless this line is active, the drive disables the write current for the head. |
| Head Load | 7406 | While this line is active, the drive loads the read/ write head. |
| Side Select | 7406 | The read/write head selects which side of the flexible disk to read/write. $\begin{aligned} & 0=\text { head } 0 \\ & 1=\text { head } 1 \end{aligned}$ |
| M/FM | 7406 | This signal selects the Code-Reading Mode, FM or MFM. <br> $0=$ FM Mode <br> $1=$ MFM Mode |

Table 3-15 Output Signals (cont'd)

| SIGNAL | DRIVER | DESCRIPTION |
| :---: | :---: | :--- |
| VFO Sync | 7406 | This signal enables or disables the VFO Circuit <br> Mode. <br> $0=$ enable <br> $1=$ disable |
| Low Current | 7406 | This line relays head-position information to the <br> drive. |
| File-Unsafe Reset | 7406 | This line resets a drive if it is in fault status. |

Table 3-16 Input Signals

| SIGNAL | DESCRIPTION |
| :--- | :--- |
| Index | The selected drive supplies one pulse per disk revolution <br> on this line. |
| Track 0 Protect | The selected drive activates this line when a write pro- <br> tected diskette is mounted in the drive. |
| Read DataThe selected drive activates this line when the read/write <br> head is over Track 0. |  |
| ReadyThe selected drive supplies a pulse on this line for each <br> flux change encountered on the disk; it relays data from <br> the flexible disk. |  |
| File Unsafe | This line becomes active when the selected drive is ready. <br> When a dual-sided disk is mounted on the drive, this line <br> becomes active. |
| Data Window the drive is in a fault state, the selected drive activates |  |
| this line. |  | | The selected drive combines read data with clock data, |
| :--- |
| which allows the FDC to discriminate data from read |
| data. |

### 3.5 FDD UNIT

The 8 -inch FDD is a two-sided, double-density unit that can read from and write to one-sided and single-density flexible disks as well. The FDD can read and record digital data using either FM or MFM. Signal transfer is in the VFO Mode.

The FDD unit attaches to the FDC with the signal cable and the flexible disk interface connector, which is located on the Controller PCB (see Figure 3-1). A power cable connects each FDD unit to the APC power supply.

To enable disk reading, insert a disk, and close the front latch; this causes the drive hub to clamp the disk and turn it at 360 rpm . When an index sensor detects the index hole, it activates a signal. The stepper motor positions the read/write heads over the desired tracks for reading.

### 3.5.1 Specifications

The FDD specifications are listed in Table 3-17.

## Table 3-17 FDD Specifications

| CHARACTERISTIC | SPECIFICATION |
| :--- | :--- |
| Transfer Rate |  |
| FM | $31.25 \mathrm{~KB} / \mathrm{sec}$ |
| MFM | $62.5 \mathrm{~KB} / \mathrm{sec}$ |
| Disk Speed | 360 rpm |
| Seek Time | 5 ms track to track |
| Seek Settling Time | 15 ms |
| Head-Load Time | 50 ms |
| Tracks Per Inch | 48 |
| Maximum Bits Per Inch |  |
| FM | 3.408 |
| MFM | 6.816 |
| Recording Mode | FM or MFM |

Table 3-17 FDD Specifications (cont'd)

| CHARACTERISTIC | SPECIFICATION |
| :---: | :---: |
| Dimensions |  |
| Height | $8.55 \mathrm{in} .(217.2 \mathrm{~mm})$ |
| Width | 2.28 in. ( 58.0 mm ) |
| Depth | $12.73 \mathrm{in} .(323.0 \mathrm{~mm})$ |
| Weight | $7.7 \mathrm{lb}(3.5 \mathrm{lb})$ |
| Operating Temperature Range | 50 to $113^{\circ} \mathrm{F}$ ( 10 to $45^{\circ} \mathrm{C}$ ) |
| Relative Humidity Tolerance Range | 20 to $80 \%$ |
| Power | $+24 \mathrm{Vdc} \pm 10 \% \quad \begin{aligned} 0.75 \mathrm{~A} \text { (starting) } \\ 0.90 \mathrm{~A} \text { (average) }\end{aligned}$ |
|  | $+5 \mathrm{Vdc} \pm 5 \% 0.8 \mathrm{~A}$ |
|  | $-5 \mathrm{Vdc} \pm 5 \% 0.07 \mathrm{~A}$ |
| Power Consumption | 28 W (maximum) |
| Error Rate |  |
| Recoverable | 1 per $10{ }^{9}$ |
| Non-Recoverable | 1 per $10^{12}$ |
| Seeks | 1 per $10^{6}$ |

### 3.5.2 Interface

Figure 3-13 shows the signal connector interface and pin assignments; Figure 3-14 illustrates the power connector interface and pin assignments.

### 3.5.3 Terminations and Jumper Settings

The location and installation of the termination resistor modules are shown in Figure 3-15, and the jumper location and jumper setting are shown in Figure 3-16.


AT STANDARD TTL LEVELS

| 8 in. FDD | 49 | LOW CURRENT | $\begin{aligned} & \text { FDD } \\ & \text { CONTROL } \end{aligned}$ |
| :---: | :---: | :---: | :---: |
|  | 47 | FILE UNSAFE RESET |  |
|  | 45 | FILE UNSAFE |  |
|  | 41 | TWO SIDED |  |
|  | 37 | SIDE SELECT |  |
|  | 33 | HEAD LOAD |  |
|  | 31 | INDEX |  |
|  | 29 | READY |  |
|  | 27 | VFO SYNC |  |
|  | 25 | DRIVE SELECT A |  |
|  | 23 | DRIVE SELECT B |  |
|  | 21 | DRIVE SELECT C |  |
|  | 19 | DRIVE SELECT D |  |
|  | 17 | DIRECTION SELECT |  |
|  | 15 | STEP |  |
|  | 13 | WRITE DATA |  |
|  | 11 | WRITE GATE |  |
| - | 9 | TRACK 00 |  |
|  | 7 | WRITE PROTECT |  |
|  | 5 | READ DATA |  |
|  | 3 | MFM |  |
|  | 1 | WINDOW |  |
|  | 2-50(EVEN) GROUND |  |  |
|  |  |  |  |

Figure 3-13 FDD Signal Connector Interface and Pin Assignments


Figure 3-14 FDD Power Connector Interface and Pin Assignments


Figure 3-15 FDD Termination Resistor Modules, Location and Installation


DRIVE B


DRIVE A


Figure 3-16 FDD Jumper, Location and Proper Setting

### 3.6 SERIAL I/O COMMUNICATIONS CONTROLLER

Supported by the 8251A USART controller, this communications interface circuit is programmed by the CPU to operate using synchronous, asynchronous, or business-machine serial-data-transmission techniques. Basically, the serial I/O device converts parallel data of the microprocessor into serial data and vice versa and generates appropriate supervisory lines to interface with a modem or other external peripheral devices.

### 3.6.1 Specifications

Table 3-18 lists the specifications for the Serial I/O Communications Controller.

### 3.6.2 Circuit Description

A functional block diagram of the serial I/O device is shown in Figure 3-17. Table 3-19 lists the serial I/O commands.

### 3.6.3 Interface

The serial I/O connects to the APC rear panel with a 26 -pin cable connector, designated CN3 on the Controller PCB. The other end of the 26 -pin cable connects to a 36-pin D-type connector similar to the printer connector. Table 3-20 lists and Figure 3-18 shows the pin assignments of all the cables. Table 3-21 explains the interface signals.

### 3.6.4 Programming Considerations

Operation of the 8251A processor is programmed by two 8 -bit control words:

- A mode instruction word, which is the first word written into the 8251 A after reset
- A command instruction word, which defines the operation to be performed.

Table 3-18 Serial I/O Communications Controller Specifications

| Characteristics | Specifications |
| :--- | :--- |
| Processor | NEC 8251A |
| Channel | 1 |
| Transmission Mode | Half-Duplex or Full-Duplex |
| Synchronization | Synchronous or Asynchronous |
| Interface | EIA RS-232C |
| Line Speed |  |
| Asynchronous Mode | 50 to 19.2K Baud |
| Synchronous Mode | 50 to 19.2K Baud |
| Business Machine | 1200 Baud |



Figure 3-17 Serial I/O Communications Controller Block Diagram

Table 3-19 Serial I/O Commands

\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{COMMAND} \& \multirow[t]{2}{*}{I/O ADDRESS} \& \multirow[t]{2}{*}{READ/ WRITE} \& \multicolumn{6}{|c|}{DATA BUS} <br>
\hline \& \& \& 7 \& 6 \& 54 \& 3 \& 2 \& 10 <br>
\hline Read Data \& 30 \& R \& \& R
D
6 \& $\begin{array}{ll}R & R \\ D & D \\ 5 & 4\end{array}$ \& R
D
3 \& $\begin{array}{ll}\text { R } & \\ \mathrm{D} & \mathrm{D} \\ 2 & \end{array}$ \& $\begin{array}{cc}R & R \\ D & D \\ 1 & 0\end{array}$ <br>
\hline Write Data \& 30 \& W \& \& S
D
6 \& $\begin{array}{cc}\text { S } & \text { S } \\ \text { D } & \text { D } \\ 5 & 4\end{array}$ \& S
D
3 \& S
D

2 \& $\begin{array}{cc}\text { S } & \text { S } \\ \text { D } & \text { D } \\ 1 & 0\end{array}$ <br>
\hline Read Status \& 32 \& R \& \& S
Y
N \& $\begin{array}{ll}\text { F } & O \\ \text { E } & \mathrm{E}\end{array}$ \& E \& T \& $\begin{array}{cc}R & T \\ R & R \\ D & D \\ \text { Y } & \text { Y }\end{array}$ <br>
\hline Write Mode (A) \& 32 \& W \& $\mathrm{S}_{2}$ \& S \& $\begin{array}{ll}\text { E } & \text { P } \\ \text { P } & \mathrm{E} \\ & \mathrm{N}\end{array}$ \& $L_{2}$ \& $L_{1}$ \& $\mathrm{B}_{2} \mathrm{~B}_{1}$ <br>
\hline Write Mode (S) \& 32 \& W \& S
C
S \& E
S
D \& $\begin{array}{ll} & \\ & \text { P } \\ \text { E } & \mathrm{E} \\ \text { P } & \mathrm{N}\end{array}$ \& $L_{2}$ \& $L_{1}$ \& $0 \quad 0$ <br>
\hline Write Command \& 32 \& W \& \& I \& $\begin{array}{ll}R & R \\ S & S \\ & T\end{array}$ \& R \& $R$
E
E
N \& $\begin{array}{ll}E & T \\ R & E \\ & \mathrm{~N}\end{array}$ <br>
\hline Write Mask \& 34 \& W \& \& \& \& \& \& $\begin{array}{ccc}R_{x} & T_{x} \\ R & R\end{array}$ <br>
\hline Read Signal \& 34 \& R \& \& \& \& \& C \& $\begin{array}{ll}\text { C } & \mathrm{C} \\ \mathrm{I} & \mathrm{D}\end{array}$ <br>
\hline Write Signal \& 36 \& W \& \& \& \& \& \& T <br>
\hline
\end{tabular}

Table 3-20 Serial I/O Connectors Pin Assignments

| SIGNAL | PIN NUMBER <br> AT A | PIN NUMBER <br> AT B | PIN NUMBER <br> AT C | REMARKS |
| :---: | :---: | :---: | :---: | :--- |
| Frame Ground | 1 | 1 | 1 |  |
| SD | 2 | 2 | 3 |  |
| RD | 3 | 3 | 5 |  |
| RS | 4 | 4 | 7 |  |
| CS | 5 | 5 | 9 |  |
| DR | 6 | 6 | 11 |  |
| Signal Ground | 7 | 7 | 13 |  |
| CD | 8 | 8 | 15 |  |
|  | 9 | 9 | 17 | No signal |
|  | 10 | 10 | 19 |  |
|  | 11 | 11 | 21 |  |
|  | 12 | 12 | 23 |  |
| ST2 | 13 | 13 | 25 |  |
|  | 14 | 19 | 2 |  |
|  | 16 | 20 | 4 |  |
| RT | 17 | 21 | 6 | No signal |
|  | 18 | 22 | 8 |  |
|  | 19 | 23 | 10 |  |
| ER | 20 | 24 | 12 | No signal |
|  | 21 | 25 | 14 |  |
|  | 22 | 26 | 16 |  |
|  | 23 | 27 | 18 | No signal |
|  | 24 | 29 | 22 |  |
|  | 25 | 30 | 24 | No signal |

Table 3-21 Serial I/O Device Interface Connector Pin Descriptions

| SIGNAL | SOURCE | DESCRIPTION |
| :--- | :--- | :--- |
| SG |  | Signal ground |
| SD | Controller | Send data |
| RD | Modem | Receive data |
| RS | Controller | Request to send |
| CS | Modem | Clear to send |
| DR | Modem | Data set ready |
| SG |  | Transmit Clock |
| ST2(TxC) | Modem | Receive Clock |
| RT | Modem | Data Terminal Ready |
| ER | Controller | Transmit Clock |
| ST1(RxC) | Controller |  |

The processor can also read a status word from the 8251 A , or write sync characters (in the Synchronous Mode), or specify that the data bus is to be read from or written to and transmitted to or received from (respectively) the modem. Instruction to the 8251A is determined by the levels on IC Pins 10, 11, 12, 13 and 21 (see Table 3-22).


Figure 3-18 Communications Controller Cable Connections

Table 3-22 8251A Instructions

| SYMBOL | NAME | DESCRIPTION |
| :---: | :---: | :---: |
| $\overline{W R}$ | $\overline{\text { WRITE }}$ | A Low on this line indicates that data on the bus is to be written into the 8251 A (APC IOW line). |
| $\overline{\mathrm{CS}}$ | $\overline{\overline{\text { CHIP }}}$ | A Low on this line selects the 8251 A , enabling read or write operations. This line must be Low for the 8251A to respond to or affect the data bus (APC S10 line). |
| $\mathrm{C} / \overline{\mathrm{D}}$ | $\frac{\text { CONTROL/ }}{\text { DATA }}$ | A High on this line specifies that a control word is being written in or that a status word read out. A Low means that data is being written in or read out (APC AB line). |
| $\overline{\mathrm{RD}}$ | $\overline{\text { READ }}$ | A Low on this line indicates that the data or a status word is being read from the 8251 A (APC IOR line). |
| RST | RESET | A High on this line places the 8251A in an idle mode, waiting for a new set of control words (APC RST line). |

### 3.6.4.1 ASYNCHRONOUS OPERATING MODE

The mode instruction word for asynchronous operation is shown in Figure 3-19. The format of the command instructions word is shown in Figure 3-20. Figure 3-21 shows the setup of jumper settings and the resulting circuit. Table 3-23 shows how the Baud rate is set.


Figure 3-19 Asynchronous Mode Instruction Word


Figure 3-20 Command Instruction Word Format

Controller PCB


Figure 3-21 Communications Controller, Circuit for Asynchronous Operation

Table 3-23 Communications Controller, Baud Rate Coding
During Asynchronous Operation

|  |  |  | $\mathrm{COU}$ | $\begin{array}{r} \text { UNT } \\ \mathrm{H} \end{array}$ | $\begin{aligned} & \text { [ RE } \\ & \mathrm{HIG} \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { EGISTI } \\ & \text { GH } \end{aligned}$ |  |  |  | OUN | $\begin{array}{r} \text { NT } \\ \text { L } \end{array}$ | $\begin{aligned} & \text { RE } \\ & \mathrm{COW} \end{aligned}$ | EGIS <br> W | ISTE |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BAUD RATE | RATE* |  | 141 | 131 | 12 | 1110 | 9 | 8 |  | 76 | 5 | 43 | 32 | 1 |  |
| 19.2K | 8 |  | 0 | 0 | 0 | 00 | 0 |  |  | 0 | 0 | 01 | 10 | 00 |  |
| 9600 | 16 |  | 0 | 0 | 0 | $0 \quad 0$ | 0 |  |  | 0 | 0 | 10 | 00 | 00 |  |
| 4800 | 32 |  | 0 | 0 | 0 | $0 \quad 0$ | 0 |  |  | 0 | 1 | 00 | 00 | 00 |  |
| 2400 | 64 |  | 0 | 0 | 0 | 00 | 0 |  |  | 1 | 0 | 00 | 00 | 00 |  |
| 1200 | 128 |  | 0 | 0 | 0 | 00 | 0 | 0 |  | 10 | 0 | 00 | 00 | 00 |  |
| 600 | 256 |  | 0 | 0 | 0 | $0 \quad 0$ | 0 |  |  | 0 | 0 | 00 | 00 | 00 |  |
| 300 | 512 |  | 0 | 0 | 0 | $0 \quad 0$ | 1 |  |  | 0 | 0 | 00 | 00 | 00 |  |
| 200 | 768 |  | 0 | 0 | 0 | 00 | 1 |  |  | 0 | 0 | 00 | 00 | 00 |  |
| 135 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 100 | 1536 |  | 0 | 0 | 0 | $0 \quad 1$ | 1 | 0 |  | 0 | 0 | 00 | 00 | 00 |  |
| 75 | 2048 |  | 0 | 0 | 0 | 10 | 0 | 0 |  | 0 | 0 | 00 | 00 | 00 | 0 |
| 50 | 3072 |  | 0 | 0 | 0 | 11 | 0 | 0 |  | 0 | 0 | 00 | 00 | 00 | 0 |
| *Count Rate $=2457600 /(\mathrm{RxC}$ or TxC) $\times 16(\mathrm{~Hz})$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### 3.6.4.2 SYNCHRONOUS OPERATING MODE

The mode instruction word for synchronous operation is shown by Figure 3-22. Figures 3-23 and 3-24 show the circuits for synchronous operation using external (Modem) and interval clocks, respectively. Table 3-24 lists the Baud rate setting codes in synchronous operation.

Controller PCB


Figure 3-22 Synchronous Mode Instruction Word


Figure 3-23 Communications Controller, Circuit for Synchronous Operation Using External Clock


Figure 3-24 Communications Controller, Circuit for Synchronous Operation Using Internal Clock

Table 3-24 Communications Controller, Baud Rate Coding During Synchronous Operation


### 3.6.4.3 BUSINESS MACHINE OPERATING MODE

Figure 3-25 shows the circuit and Table 3-25 lists the Baud rate setting codes when operation with business-machine timing.


Figure 3-25 Communications Controller, Circuit for Business Machine Clock

Table 3-25 Communications Controller, Baud Rate Coding During Operations with Business Machine Clocking

| BAUD RATE | RATE | COUNT REGISTER HIGH |  |  |  |  |  |  |  |  | COUNT REGISTER LOW |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1 | 413 | 12 | 11 | 11 | 10 | 9 | 8 |  | 76 | 65 | 43 | 32 | 21 | 0 |
| 19.2K | 8 | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 0 | 0 |  | 00 | 0 | 01 | 10 | 0 |  |
| 9600 | 16 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 00 | 0 | 10 | 00 | 0 |  |
| 4800 | 32 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 00 | 1 | 00 | 00 | 0 |  |
| 2400 | 64 | 0 | 0 | 0 0 | 0 | 0 | ) | 0 | 0 | 0 |  | 01 | 10 | 00 | 00 | 0 |  |
| 1200 | 128 | 0 | 0 | 0 0 | 0 |  | 0 | 0 | 0 | 0 |  | 10 | 0 | 00 | 00 | 0 |  |
| 600 | 256 | 0 | 0 | 00 | 0 | 0 | 0 | 0 | 0 | 1 |  | 00 | 0 | 00 | 00 | 0 | 0 |
| 300 | 512 |  | 0 | 0 0 | 0 | 0 | 0 | 0 | 1 | 0 |  | 00 | 0 | 00 | 00 | 0 |  |
| 200 | 768 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 | 1 | 1 |  | 00 | 0 | 00 | 00 | 0 | 0 |
| 135 | 1138 |  | 0 | 00 | 0 | 0 | 0 | 1 | 0 | 0 |  | 01 | 1 | 10 | 00 | 1 |  |
| 100 | 1536 | 0 | 0 | 00 | 0 | 0 | 0 | 1 | 1 | 0 |  | 00 | 0 | 00 | 00 | 0 | 0 |
| 75 | 2048 |  | 0 | 00 | 0 | 1 | 1 | 0 | 0 | 0 |  | 00 | 0 | 00 | 00 | 0 |  |
| 50 | 3072 | 0 | 0 | 0 0 | 0 | 1 | 1 | 1 | 0 | 0 |  | 00 | 0 | 00 | 00 | 0 | 0 |

### 3.6.5 Status Word Format

The status word format is shown by Figure 3-26.


Figure 3-26 Communications Controller, Status Word Format

### 3.7 SOUND CONTROL

The sound control system is supported by the NEC $\mu$ PD1771C-006, which drives a loudspeaker through a $1 / 4$-Watt audio amplifier. This LSI generates audio signals and programmable music. Through music programming, the sound control system can generate tones ranging over two octaves in frequency, at specified note lengths, intensities, and tempos.

A functional block diagram of the sound control system is shown in Figure 3-27. The sound system speaker is mounted near the front of the main unit. An operator's volume control is also provided.


Figure 3-27 Sound Control Block Diagram

### 3.7.1 Interface

Figure 3-28 shows the sound control interface with the Controller PCB, and Table 3-26 describes the pin assignments.


Figure 3-28 Location of Sound Interface Connectors
Table 3-26 Sound Interface Pin Assignments

| CONNECTOR | PIN | SIGNAL |
| :--- | :---: | :--- |
| CN6 <br> (Volume <br> Interface) | 1 | Volume In |
|  | 2 | Volume Out |
|  | 3 | Ground |
| CN7 <br> (Speaker <br> Interface) | 4 | Ground |

### 3.7.2 Programming Considerations

Tables 3-27, 3-28 and 3-29 give format and command information for soundprogramming users.

Table 3-27 Sound Programming Read/Write Format

| INSTRUCTION | READ/ WRITE | I/O <br> ADDRESS | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Write Command | W | 60 |  | FS | C5 | C4 | C3 | C2 | C1 | C 0 |
| Read Status | R | 60 | S7 | S6 | S5 | S4 | S3 |  | S1 | S0 |
| Legend: |  |  |  |  |  |  |  |  |  |  |
| FS $\quad=$ First (0) or Second (1) command identification |  |  |  |  |  |  |  |  |  |  |
| C0 to C5 = Sound Control and Scale commands |  |  |  |  |  |  |  |  |  |  |
| S0 to S7 = Status information: if HEX value is 80, all the write commands are accepted; if HEX value is 00 , only the Beep command is accepted. |  |  |  |  |  |  |  |  |  |  |

Table 3-28 Sound Control Commands

| FIRST COMMAND |  | SECOND COMMAND |  |
| :---: | :---: | :---: | :---: |
| COMMAND | DATA BUS |  | DATA BUS |
|  | $\begin{array}{llllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$ | MUSIC EXPRESSION | $\begin{array}{llllllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$ |
| Music Notes | $\begin{array}{lllllllll}0 & 0 & 1 & 1 & 0 & 0 & 0 & 1\end{array}$ | Volume Illegal | $\begin{array}{llllllll}0 & 1 & 0 & 0 & 0 & 0 & 0 & 0\end{array}$ |
| Beep Notes |  | Piano | $\begin{array}{llllllll}0 & 1 & 0 & 0 & 0 & 0 & 0 & 1\end{array}$ |
| 20 ms | $\begin{array}{lllllllll}0 & 0 & 1 & 1 & 1 & 0 & \text { X X }\end{array}$ | Medium | $\begin{array}{llllllll}0 & 1 & 0 & 0 & 0 & 0 & 1 & 0\end{array}$ |
| 6 minutes | $\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & 1 & \mathrm{X} & \mathrm{X}\end{array}$ | Forte | $\begin{array}{llllllll}0 & 1 & 0 & 0 & 0 & 0 & 1 & 1\end{array}$ |
| 710 Hz | $\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & X & 0 & 0\end{array}$ |  |  |
| 1202 Hz | $\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & X & 0 & 1\end{array}$ | Tempo Slow (1.0 sec) | $\begin{array}{lllllllll}0 & 1 & 0 & 1 & 0 & 0 & 0 & 0\end{array}$ |
| 2038 Hz | $\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & X & 1 & 0\end{array}$ | Moderately Slow ( 0.87 sec ) | $\begin{array}{lllllllll}0 & 1 & 0 & 1 & 0 & 0 & 0 & 1\end{array}$ |

Table 3-28 Sound Control Commands (cont'd)


Table 3-29 Sound Scale Commands


Table 3-29 Sound Scale Commands (cont'd)

| FIRST COMMAND (NOTE TONE) |  | SECOND COMMAND (NOTE DURATION) |  |
| :---: | :---: | :---: | :---: |
| COMMAND | DATA BUS |  | DATA BUS |
|  | $\begin{array}{llllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$ | COMMAND | $\begin{array}{llllllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$ |
| A | $\begin{array}{llllllll}0 & 0 & 0 & 0 & 1 & 0 & 1 & 0\end{array}$ |  |  |
| A\# | $\begin{array}{llllllll}0 & 0 & 0 & 0 & 1 & 0 & 1 & 1\end{array}$ | teenth note ( ${ }^{*}$ ) | $\begin{array}{llllllll}0 & 1 & 0 & \text { X X 1 }\end{array}$ |
| B | $\begin{array}{llllllll}0 & 0 & 0 & 0 & 1 & 1 & 0 & 0\end{array}$ | Thirty-second note ( $\bullet$ ) | $\begin{array}{llllllll}0 & 1 & 0 & \text { X X l } & 0 & 1\end{array}$ |
| C | $\begin{array}{llllllll}0 & 0 & 0 & 0 & 1 & 1 & 0 & 1\end{array}$ | Illegal | $\begin{array}{lllllllll}0 & 1 & 0 & X & X & 1 & 1 & 0\end{array}$ |
| C\# | $\begin{array}{llllllll}0 & 0 & 0 & 0 & 1 & 1 & 1 & 0\end{array}$ | Illegal | $\begin{array}{llllllll}0 & 1 & 0 & X & X & 1 & 1 & 1\end{array}$ |
| D | $\begin{array}{llllllll}0 & 0 & 0 & 0 & 1 & 1 & 1 & 1\end{array}$ |  |  |
| D\# | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 0 & 0 & 0 & 0\end{array}$ |  |  |
| E | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 0 & 0 & 0 & 1\end{array}$ |  |  |
| F | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 0 & 0 & 1 & 0\end{array}$ |  |  |
| F\# | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 0 & 0 & 1 & 1\end{array}$ |  |  |
| G | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 0 & 1 & 0 & 0\end{array}$ |  |  |
| G\# | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 0 & 1 & 0 & 1\end{array}$ |  |  |
| A | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 0 & 1 & 1 & 0\end{array}$ |  |  |
| A\# | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 0 & 1 & 1 & 1\end{array}$ |  |  |
| B | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 1 & 0 & 0 & 0\end{array}$ |  |  |
| C | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 1 & 0 & 0 & 1\end{array}$ |  |  |
| C\# | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 1 & 0 & 1 & 0\end{array}$ |  |  |
| D | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 1 & 0 & 1 & 1\end{array}$ |  |  |
| D\# | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 1 & 1 & 0 & 0\end{array}$ |  |  |
| E | $\begin{array}{llllllll}0 & 0 & 0 & 1 & 1 & 1 & 0 & 1\end{array}$ |  |  |
|  | $\begin{array}{lllllllll}0 & 0 & 0 & 1 & 1 & 1 & 1 & 0\end{array}$ |  |  |
| Illegal | Through |  |  |
|  | $\begin{array}{lllllllll}0 & 0 & 1 & 0 & 1 & 1 & 1 & 1\end{array}$ |  |  |
| Rest | $\begin{array}{lllllllll}0 & 0 & 1 & 1 & 0 & 0 & 0 & 0\end{array}$ |  |  |
|  | $\begin{array}{lllllllll}0 & 0 & 1 & 1 & 0 & 0 & 0 & 1\end{array}$ |  |  |
| Illegal | Through |  |  |

### 3.8 JUMPER SETTINGS

Figure 3-29 shows the Controller PCB jumper settings, which adapt the system to various communications situations and to either monochrome or color display.



ASYNCHRONOUS (TM1-3, TM2-1, TM4-2)


BUSINESS MACHINE CLOCK (TM1-2, TM2-1, TM4-1)


MONOCHROME DISPLAY (TM3-2, TM5 SHORTED, TM6-1)


COLOR DISPLAY (TM3-1, TM5 OPEN, TM6-2)

Figure 3-29 Controller PCB Jumper Settings

## Chapter 4

## Power Supply



The dc power supply is a $100 \mathrm{~W}, 5$-voltage level, switching regulator providing the following dc outputs. The power supply also provides a noise-filtered switched 115 $\mathrm{V}, 60 \mathrm{~Hz}$ output at 1.2 A , and a single-pole, single-throw power control switch output for external power On/Off control.

- $+5 \mathrm{Vdc} \pm 5 \%$ @ 9 A
- $-5 \mathrm{Vdc} \pm 5 \%$ @ 0.3 A
- +12 Vdc $\pm 5 \%$ @ 0.3 A
- $-12 \mathrm{Vdc} \pm 5 \%$ @ 0.25 A
- +24 Vdc $\pm 10 \%$ @ 1.8 A

The power supply furnishes all required power to APC components in the Keyboard and terminal cabinet and is located in a removable chassis module under the CRT Display. The power On/Off Switch is an integral part of the power supply.

All dc outputs are regulated and have overcurrent and overvoltage protection. Ripple voltage does not exceed 50 mV at any dc output except the 24 V output, where the ripple voltage does not exceed 100 mV . Spike noise voltage is less than 250 mV on any output. If an overload or overvoltage condition exists on any of the dc outputs, the unit automatically shuts down until the condition is corrected and the power is recycled off and on. The power supply is designed for continuous operation at 100 W of dc output and 130 W of ac output. The ac output is 2.5 A maximum at 104 to $132 \mathrm{~V}, 60 \pm 0.5 \mathrm{~Hz}$ and is fused for 5.0 A .

The APC power supply incorporates a POF circuit that enables remote On/Off switching of both ac and dc outputs. The POF character is 5B and its address is AD08.

A functional block diagram of the power supply is shown by Figure 4-1, which also shows additional specifications of the POF feature.

The input and output cable connections to and from the power supply are shown in Figure 4-2 and listed in Table 4-1.


Figure 4-1 System Power Supply Block Diagram


Figure 4-2 Power Supply Interconnection Diagram

Table 4-1 Power Supply Pin Command Assignments

| CN2 <br> PIN <br> NUMBER | DESCRIPTION | CN2 <br> PIN <br> NUMBER | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 1 | 115 Vac | 9 | 115 Vac |
| 2 | Ground | 10 | Ground |
| 3 | +12 Vdc | 11 | -12 Vdc |
| 4 | -5 Vdc | 12 | -5 Vdc |
| 5 | P0F | 13 | +24 Vdc |
| 6 | +5 Vdc | 14 | Ground |
| 7 | +5 Vdc | 15 | +5 Vdc |
| 8 | Ground | 16 | Ground |

## Appendix A

## Integrated Circuit Data Sheets

## 16-BIT MICROPROCESSOR *

DESCRIPTION The $\mu$ PD8086 is a 16 -bit microprocessor that has both 8 -bit and 16 -bit attributes. It has a 16 -bit wide physical path to memory for high performance. Its architecture allows higher throughput than the $5 \mathrm{MHz} \mu$ PD8085A-2.<br>FEATURES - Can Directly Address 1 Megabyte of Memory<br>- Fourteen 16-Bit Registers with Symmetrical Operations<br>- Bit, Byte, Word, and Block Operations<br>- 8- and 16-Bit Signed and Unsigned Arithmetic Operations in Binary or Decimal<br>- Multiply and Divide Instructions<br>- 24 Operand Addressing Modes<br>- Assembly Language Compatible with the $\mu$ PD8080/8085<br>- Complete Family of Components for Design Flexibility

PIN CONFIGURATION

| GND | 1 |  | 40 | $\square \mathrm{V}_{C C}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| AD14 | 2 |  | 39 | AD15 |  |
| AD13 | 3 |  | 38 | P A16/S3 |  |
| AD12 | 4 |  | 37 | ] $\mathrm{A} 17 / \mathrm{S} 4$ |  |
| AD11 | 5 |  | 36 | A18/S5 |  |
| AD10 | 6 |  | 35 | A $19 / 56$ |  |
| AD9 | 7 |  | 34 | - $\overline{\mathrm{BHE} / \mathrm{S} 7}$ |  |
| AD8 8 | 8 |  | 33 | $\square \mathrm{MN} / \overline{\mathrm{MX}}$ |  |
| AD7 | 9 |  | 32 | - $\overline{\mathrm{RD}}$ |  |
| AD6 8 | 10 | $\mu$ PD8086 | 31 | HOLD | ( $\overline{\mathrm{RO}} / \mathrm{GTO}$ ) |
| AD5 8 | 11 | CPU | 30 | 2 HLDA | ( $\overline{\mathrm{RQ} / \mathrm{GT1}}$ ) |
| AD4 5 | 12 |  | 29 | ] WR | ( $\overline{\text { LOCK }}$ ) |
| AD3 5 | 13 |  | 28 | м $\overline{10}$ | (52) |
| $A D 2$ | 14 |  | 27 | ¢ $\mathrm{D} /$ /R | (S1) |
| AD1 | 15 |  | 26 | $2 \overline{D E N}$ | ( $\overline{\text { SOP }}$ ) |
| ADO | 16 |  | 25 | ALE | (aso) |
| NMI | 17 |  | 24 | $\underline{\text { INTA }}$ | (QS1) |
| INTR | 18 |  | 23 | ] TEST |  |
| CLK | 19 |  | 22 | READY |  |
| GND | 20 |  | 21 | RESET |  |

*Preliminary
Reprinted through courtesy of NEC Electronics, U.S.A., Inc.
NOTE: These manufacturer's specifications are provided for reference. The APC may not use some of the functions described here.

PIN IDENTIFICATION

| No. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 2-16, 39 | AD0-AD15 | Address/Data Bus | Multiplexed address ( $T_{1}$ ) and data $\left(T_{2}, T_{3}, T_{W}, T_{4}\right)$ bus. 8 -bit peripherals tied to the lower 8 bits, use $\mathbf{A O}$ to condition chip select functions. These lines are tri-state during interrupt acknowledge and hold states. |
| 17 | NMI | Non-Maskable Interrupt | This is an edge triggered input causing a type 2 interrupt. A look-up table is used by the processor for vectoring information. |
| 18 | INTR | Interrupt Request | A level triggered input sampled on the last clock cycle of each instruction. Vectoring is via an interrupt look-up table. INTR can mask in software by resetting the interrupt enable bit. |
| 19 | CLK | Clock | The clock input is a $1 / 3$ duty cycle input basic timing for the processor and bus controller. |
| 21 | RESET | Reset | This active high signal must be high for 4 clock cycles. When it returns low, the processor restarts execution. |
| 22 | READY | Ready | An acknowledgement from memory or I/O that data will be transferred. Synchronization is done by the $\mu$ PD8284 clock generator. |
| 23 | TEST | Test | This input is examined by the "WAIT" instruction, and if low, execution continues. Otherwise the processor waits in an "Idie" state. Synchronized by the processor on the leading edge of CLK. |
| 24 | INTA | Interrupt Acknowledge | This is a read strobe for reading vectoring information. During $\mathrm{T}_{2}, \mathrm{~T}_{3}$, and $\mathrm{T}_{\mathrm{w}}$ of each interrupt acknowledge cycle it is low. |
| 25 | ALE | Address Latch Enable | This is used in conjunction with the $\mu$ PD8282/8283 latches to latch the address, during $\mathrm{T}_{1}$ of any bus cycle. |
| 26 | $\overline{\text { DEN }}$ | Data Enable | This is the output enable for the $\mu$ PD8282/8287 transceivers. It is active low during each memory and I/O access and INTA cycles. |
| 27 | DT/R | Data Transmit/Receive | Used to control the direction of data flow through the transceivers. |
| 28 | M/10 | Memory/IO Status | This is used to separate memory access from 1/O access. |
| 29 | $\overline{W R}$ | Write | Depending on the state of the $\mathrm{M} / \overline{\mathrm{TO}}$ line, the processor is either writing to $1 / O$ or memory. |
| 30 | HLDA | Hold Acknowledge | A response to the HOLD input, causing the processor to tri-state the local bus. The bus return active one cycle after HOLD goes back low. |
| 31 | HOLD | Hold | When another device requests the local bus, driving HOLD high, will cause the $\mu$ PD8086 to issue a HLDA. |
| 32 | $\overline{\text { RD }}$ | Read | Depending on the state of the $M / \overline{\mathbf{1 0}}$ line, the processor is reading from either memory or 1/O. |
| 33 | MN/ $\overline{M X}$ | Minimum/Maximum | This input is to tell the processor which mode it is to be used in. This effects some of the pin descriptions. |
| 34 | $\overline{\mathrm{BHE}} / \mathrm{S}_{7}$ | Bus/High Enable | This is used in conjunction with the most significant half of the data bus. Peripheral devices on this half of the bus use BHE to condition chip select functions. |
| 35-38 | A16-A19 | Most Significant Address Bits | The four most significant address bits for memory operations. Low during I/O operations. |
| $\begin{gathered} 26,27,28 \\ 34-38 \end{gathered}$ | $\mathrm{SO}_{0} \mathrm{~S}_{7}$ | Status Outputs | These are the status outputs from the processor. They are used by the $\mu$ PD8288 to generate bus control signals. |
| 24, 25 | $\mathrm{OS}_{1}, \mathrm{OS}_{0}$ | Que Status | Used to track the internal $\mu$ PD8086 instrurstion que. |
| 29 | LOCK | Lock | This output is set by the "LOCK" instruction to prevent other system bus masters from gaining control. |
| 30, 31 | $\begin{aligned} & \overline{\mathrm{RO} / \overline{G T_{O}}} \\ & \overline{\mathrm{RQ}} / \overline{\mathrm{GT}} \mathbf{1} \end{aligned}$ | Request/Grant | Other local bus masters can force the processor to rebase the local bus at the end of the current bus cycle. |

## BLOCK DIAGRAM



| Operating Temperature | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | ABSOLUTE MAXIMUM |
| :---: | :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |  |
| Voltage on Any Pin with | -1.0 to +7 V |  |
| Power Dissipation | . . . . . . 2.5W |  |

$\mathrm{T}_{\mathrm{a}}=25^{\circ} \mathrm{C}$
"COMMENT: Stress above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
$T_{a}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{VCC}=5 \mathrm{~V} \pm 10 \%$

| PARAMETER | SYMBOL | LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| Input Low Voltage | $V_{\text {IL }}$ | -0.5 | +0.8 | V |  |
| Input High Voltage | VIH | 2.0 | $\mathrm{V}_{\mathrm{Cc}}+0.5$ | $v$ |  |
| Output Low Voltage | $\mathrm{VOL}^{\text {O }}$ |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA}$ |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| Power Supply Current $\mu$ PD8086/ $\mu$ PD8086-2 | ICC |  | $\begin{aligned} & 340 \\ & 350 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\mathrm{T}_{\mathrm{a}}=25^{\circ} \mathrm{C}$ |
| Input Leakage Current | ILI |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV}<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {CC }}$ |
| Output Leakage Current | 'LO |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| Clock Input Low Voltage | $\mathrm{V}_{\mathrm{CL}}$ | -0.5 | +0.6 | $\checkmark$ |  |
| Clock Input High Voltage | $\mathrm{V}_{\mathrm{CH}}$. | 3.9 | Vcc +1.0 | V |  |
| Capacitance of Input Buffer (All input except $\left.A D_{0}-A D_{15}, \overline{R Q} / \overline{G T}\right)$ | CIN |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| Capacitance of I/O Buffer $\left(A D_{0}-A D_{15}, \overline{R Q} / \overline{G T}\right)$ | $\mathrm{ClO}_{10}$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

## AC CHARACTERISTICS

$\mu P D 8086: T_{a}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| MINIMUM COMPLEXITY | timing requiremments |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PARAMETER | SYMBOL | $\mu \mathrm{PD8086}$ |  | ${ }_{\mu}{ }^{\text {PDP80B6-2 }}$ (Proliminary) |  | UNITS | TEST CONDITIONS |
|  |  |  | MIN | max | MIN | MAX |  |  |
| SYSTEM | CLK Cycle Period - $\mu$ PD8086 | TCLCL | 200 | 500 | 125 | 500 | ns |  |
|  | CLK Low Time | TCLCH | (2/3 TCLCL) -15 |  | (2/3 TCLCL) -15 |  | ns |  |
|  | CLK High Time | TCHCL | (1/3 TCLCL) +2 |  | (1/3 TCLCL) +2 |  | ns |  |
|  | CLK Rise Time | TCH1CH2 |  | 10 |  | 10 | ns | From 1.0 V to 3.5 V |
|  | CLK Fall Time | TCL2CL1 |  | 10 |  | 10 | ns | From 3.5 V to 1.0V |
|  | Data in Setup Time | TDVCL | 30 |  | 20 |  | ns |  |
|  | Data in Hold Time | TCLDX | 10 |  | 10 |  | ns |  |
|  | RDY Setup Time into $\mu$ PD8284 <br> (1) (2) | TRIVCL | 35 |  | 35 |  | ns |  |
|  | RDY Hold Time into $\mu$ PD8284 <br> .(1) (2) | TCLR1X | 0 |  | 0 |  | ns |  |
|  | READY Setup Time into $\mu$ PDB086 | TRYHCH | (2/3 TCLCL) -15 |  | (2/3 TCLCL) - 15 |  | ns |  |
|  | READY Hold Time into $\mu$ PDB086 | TCHRYX | 30 |  | 20 |  | ns |  |
|  | READY Inactive to CLK <br> (3) | TRYLCL | -8 |  | -8 |  | ns |  |
|  | HOLD Setup Time | THVCH | 35 |  | 20 |  | ns |  |
|  | INTR, NMI, TEST Setup Time (2) | TINVCH | 30 |  | 15 |  | ns |  |
|  | Input Rise Time | tilin |  | 20 |  |  | ns | From 0.8 V to 2.0 V |
|  | Input Fall Time | TIHIL |  | 12 |  |  | ns | From 2.0 V to 0.8 V |


| TIMING RESPONSES | TIMING RESPONSES |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PARAMETER | SYmbol | $\mu \mathrm{PDBOB6}$ |  | $\mu$ PD8086-2 Proliminary) |  | UNITS | TEST CONDITIONS |
|  |  |  | MIN | MAX | MIN | MAX |  |  |
|  | Address Valid Delay | tclav | 10 | 110 | 10 | 60 |  | $C_{L}=20-100 \mathrm{pF}$ for all $\mu$ PD8086 Outputs (In addition to $\mu$ PD8086 self-load) |
|  | Address Hold Time | tclax | 10 |  | 10 |  | ns |  |
|  | Addrests Float Delay | tclaz | TCLAX | 80 | TCLAX | 50 | ns |  |
|  | ALE Width | TLHLL | TCLCH-20 |  | TCLCH-10 |  | ns |  |
|  | ALE Active Delay | TCLLH |  | 80 |  | 50 | ns |  |
|  | ALE Inactive Delay | TCHLL |  | 85 |  | 55 | ns |  |
|  | Address Hold Time to ALE Inactive | tLLAX | TCHCL-10 |  | TCHCL-10 |  | ns |  |
|  | Data Valid Delay | tclov | 10 | 110 | 10 | 60 | ns |  |
|  | Data Hold Time | TCHDX | 10 |  | 10 |  | ns |  |
|  | Data Hold Time After WR | TWHDX | TCLCH-30 |  | TCLCH-30 |  | ns |  |
|  | Conrol Active Delay 1 | TCVCTV | 10 | 110 | 10 | 70 | ns |  |
|  | Control Active Delay 2 | TCHCTV | 10 | 110 | 10 | 60 | ns |  |
|  | Control Active Dolay | tCvCTX | 10 | 110 | 10 | 70 | ns |  |
|  | Addross Float to READ Active. | TAZRL | 0 |  | 0 |  | ns |  |
|  | $\overline{R D}$ Active Deloy | TCLRL | 10 | 165 | 10 | 100 | ns |  |
|  | $\overline{\text { AD Insctive Doiay }}$ | TCLRH | 10 | 150 | 10 | 80 | ns |  |
|  | $\overline{\mathrm{AD}}$ Inective to Next Address Active | trhav | TCLCL-45 |  | TCLCL-40 |  | ns |  |
|  | HLDA Valld Doilay | tclhav | 10 | 160 | 10 | 100 | ns |  |
|  | RD Width | TRLRH | 2TCLCL-75 |  | 2TCLCL-50 |  | ns |  |
|  | WR Width | TWLWH | 2TCLCL-60 |  | 2TCLCL-40 |  | ns |  |
|  | Address Valld to ALE Low | TAVAL | TCLCH-60 |  | TCLCH-40 |  | ns |  |
|  | Output Rise Time | toloh |  | 20 |  |  | $n 8$ | From 0.8 V to 2.0 V |
|  | Output fall Time | TOHOL |  | 12 |  |  | $n$ | From 2.0 V to 0.8 V |

NOTES: (1) SIgnal at $\mu$ PDE284 shown for reference oniy
(2) Setup requirement for asynchronous signal only to guarantee recognition at next CLK
(3) Appiles only to T 2 state. (8 ns into T 3 )

TIMING WAVEFORMS


## Minimum Complexity <br> Systems (Con't.)



NOTES: (1) All signals switch between $\mathrm{V}_{\mathrm{OH}}$ ana $\mathrm{V}_{\mathrm{OL}}$ unless otherwise specified.
(2) RDY is sampled near the end of $T_{2}, T_{3}, T_{W}$ to determine if $T_{W}$ machines states are to be inserted.
(3) Two INTA cycles run back-to-back. The $\mu$ PD8086 local ADDR/Data Bus is floating during both INTA cycles. Control signals shown for second INTA cycle.
(4) Signals at $\mu$ PD8284 are shown for reference only.
(5) All timing measurements are made at 1.5 V unless otherwise noted.

TIMING WITH $\mu$ PB8288 BUS CONTROLLER

| PARAMETER | SYMBOL | [PD8086 |  | - PDobo86-2 (Pretiminary) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | max | MIN | MAX |  |  |
| CLK Cycle Period - $\mu$ PD8086 | TCLCL | 200 | 500 | 125 | 500 | ns |  |
| CLK Low Time | TCLCH | (2/3 TCLCL) -15 |  | (2/3 TCLCL) - 15 |  | ns |  |
| CLK High Time | TCHCL | (1/3 TCLCL) +2 |  | (1/3 TCLCL) +2 |  | ns |  |
| CLK Rise Time | TCH1CH2 |  | 10 |  | 10 | ns | From 1.0V to 3.5V |
| CLN Fall Time | TCL2CL1 |  | 10 |  | 10 | ns | From 3.5 V to 1.0 V |
| Data in Setup Time | toval | 30 |  | 20 |  | ns |  |
| Data in Hold Time | TCLDX | 10 |  | 10 |  | ns |  |
| RDY Setup Time into $\mu$ PD8284 <br> (1) (2) | TRIVCL | 35 |  | 35 |  | ns |  |
| RDY Hold Time into $\mu$ PD8284 <br> (1). (2) | TCLR1X | 0 |  | 0 |  | ns |  |
| READY Setup Time into $\mu$ PD8086 | TRYHCH | (2/3 TCLCL) - 15 |  | (2/3 TCLCL) - 15 |  | ns |  |
| READY Hold Time into $\mu$ PD8086 | TCHRYX | 30 |  | 20 |  | ns |  |
| READY inactive to CLK (4) | trylcl | -8 |  | -8 |  | ns |  |
| Setup Time for Recognition (INTR, NMI, TEST) (2) | TINVCH | 30 |  | 15 |  | ns |  |
| $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Setup Time | TGVCH | 30 |  | 15 |  | ns |  |
| $\overline{\mathrm{RQ}}$ Hold Time into $\mu$ POBO86 | tehgx | 40 |  | 30 |  | ns |  |
| Input Rise Time | TILIH |  | 20 |  |  | ns | From 0.8 V to 2.0 V |
| Input Fall Time | TIHIL |  | 12 |  |  | ns | From 2.0 V to 0.8 V |

timing hesponses

| PARAMETER | SYMBOL | HPD8086 |  | [PD8086.2 (Praliminary) |  | Units | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | max |  |  |
| Command Active Delay (See Note 1) | TCLML | 10 | 35 | 10 | 35 | ns | $C_{L}=20.100 \mathrm{pF}$ for all $\mu$ PD8086 Outputs (In addition to «PD8086 selftood) |
| Command Inactive Delay (See Note 1) | tclmh | 10 | 35 | 10 | 35 | ns |  |
| READY Active to Status Passive (See Note 3) | TRYHSH |  | 110 |  | 65 | ns |  |
| Status Active Delay | TCHSV | 10 | 110 | 10 | 60 | ns |  |
| Status Inactive Delay | TCLSH | 10 | 130 | 10 | 70 | ns |  |
| Address Valid Delay | tclav | 10 | 110 | 10 | 60 | ns |  |
| Address Hold Time | tclax | 10 |  | 10 |  | ns |  |
| Address Float Delay | TCLAZ | TCLAX | 80 | TCLAX | 50 | ns |  |
| Status Valid to ALE High (See Note 1) | TSVLH |  | 15 |  | 15 | ns |  |
| Status Valid to MCE High (See Note 1! | TSVMCH |  | 15 |  | 15 | nı |  |
| CLK Low to ALE Valid (See Note 1) | tclen |  | 15 |  | 15 | ns |  |
| CLK Low to MCE High (See Note 1) | TCLMCH |  | 15 |  | 15 | ns |  |
| ALE Inactive Delay (See Note 1) | TCHLL |  | 15 |  | 15 | ns |  |
| MCE Inactive Delay (See Note 1) | TCLMCL |  | 15 |  | 15 | ns |  |
| Data Valid Delay | tclov | 10 | 110 | 10 | 60 | ns |  |
| Data Hold Time | TCHDX | 10 |  | 10 |  | ns |  |
| Control Active Delay (See Note 1) | TCVNV | 5 | 45 | 5 | 45 | $n s$ |  |
| Control Inactive Delay (See Note 1) | tcvnx | 10 | 45 | 10 | 45 | ns |  |
| Address Float to Read Active | tazRL | 0 |  | 0 |  | ns |  |
| RD Active Delay | TCLRL | 10 | 165 | 10 | 100 | ns |  |
| RD Inactive Delay | TCLRH | 10 | 150 | 10 | 80 | ns |  |
| RO Inactive to Next Address Active | trhav | TCLCL-45 |  | TCLCL-40 |  | ns |  |
| Direction Control Active Delay (See Note 1) | tchotl |  | 50 |  | 50 | $n$ |  |
| Direction Control Inactive Delay (See Note 1) | тChDTH |  | 30 |  | 30 | $n s$ |  |
| GT Active Delay | TCLGL | 0 | 85 | 0 | 50 | $n 3$ |  |
| GT Insctive Dolay | TCLGH | 0 | 85 | 0 | 50 | $n s$ |  |
| $\overline{\text { AD Width }}$ | TRLRH | 2TCLCL 50 |  | 2TCLCL. 50 |  | ns |  |
| Output Rise Time | TOLOH |  | 20 |  |  | ns | From 0.8 V to 2.0 V |
| Output Fall Time | тоноL |  | 12 |  |  | $n$ | From 2.0V 100.8 V |

A1-8

MAXIMUM MODE SYSTEM
With $\mu$ PB8288
Bus Controller
Applies oniv to T 3 and weit states.

Applies only to $T 2$ state ( 8 ns into T ).

TIMING WAVEFORMS
Maximum Mode System Using $\mu$ PB8288 Controller (7)


TIMING WAVEFORMS
Maximum Mode
System Using $\mu$ PB8288 Controller
(Con't.) (7)


ASYNCHRONOUS SIGNAL
RECOGNITION

## BUS LOCK SIGNAL TIMING



REQUEST/GRANT SEQUENCE TIMING*

*for Maximum Mode only

HOLD/HOLD ACKNOWLEDGE TIMING*


| Cerdip |  |  |
| :--- | :---: | :---: |
| ITEM MILLIMETERS INCHES <br> A 51.5 MAX 2.03 MAX <br> B 1.62 MAX 0.06 MAX <br> C $2.54 \pm 0.1$ $0.1 \pm 0.004$ <br> D $0.5 \pm 0.1$ $0.02 \pm 0.004$ <br> E $48.26 \pm 0.1$ $1.9 \pm 0.004$ <br> F 1.02 MIN 0.04 MIN <br> G 3.2 MIN 0.13 MIN <br> H 1.0 MIN 0.04 MIN <br> I 3.5 MAX 0.14 MAX <br> J 4.5 MAX 0.18 MAX <br> K 15.24 TYP 0.6 TYP <br> L 14.93 TYP 0.59 TYP <br> M $0.25 \pm 0.05$ $0.01 \pm 0.0019$ |  |  |

## PROGRAMMABLE COMMUNICATION INTERFACES



PIN NAMES
PIN CONFIGURATION

| $\mathrm{D}_{2} \square_{1}$ | $\bigcirc$ | 28 | $\square \mathrm{D}_{1}$ |
| :---: | :---: | :---: | :---: |
| $\mathrm{D}_{3} \mathrm{Cl}_{2}$ |  | 27 | ] $\mathrm{D}_{0}$ |
| $8 \times 0{ }^{3}$ |  | 26 | $\mathrm{v}_{\mathrm{cc}}$ |
| GNO 4 |  | 25 | 万 $\mathrm{R} \mathrm{\times C}$ |
| $\mathrm{D}_{4} \mathrm{O}_{5}$ |  | 24 | $\square$ DTR |
| $\mathrm{D}_{5} \square^{6}$ | $\mu \mathrm{PD}$ | 23 | 日 $\overline{\text { RTS }}$ |
| $\mathrm{D}_{6} \mathrm{C}$ - | 8251/ | 22 | DSE |
| $\mathrm{D}_{7} \mathrm{Cl}_{8}$ | 8251A | 21 | -reset |
| $\overline{\mathrm{T} \times \mathrm{C}}{ }^{\text {c }}$ |  | 20 | ] clk |
| WR ${ }_{10}$ |  | 19 | $\square \mathrm{T} \times \mathrm{D}$ |
| Cs ${ }^{\text {- }}$ |  | 18 | $\mathrm{T}^{\text {TXE }}$ |
| C60 ${ }^{2}$ |  | 17 | $\square$ CTS |
| $\overline{\text { RO }} 13$ |  | 16 | SYNDET ( $\mu$ PD8251) SYNDET/BD ( $\mu$ PD8251A) |
| RxROY ${ }_{14}$ |  | 15 | $] \mathrm{T} \times \mathrm{RDY}$ |


| $\mathrm{O}_{7} \cdot \mathrm{D}_{0}$ | Dats Bus (8 bits) |
| :---: | :---: |
| C/ $\overline{0}$ | Control or Data is to be Written or Reed |
| $\overline{\text { ab }}$ | Read Date Commend |
| WR | Write Data or Control Command |
| $\overline{\text { cs }}$ | Chip Ensble |
| CLK | Clock Pulse (TTL) |
| RESET | Repat |
| T $\times$ C | Transmitter Clock (TTL) |
| TxD | Transmitter Dite |
| $\overline{\mathrm{A} \times \mathrm{C}}$ | Receiver Clock (TTL) |
| R×D | Receiver Data |
| RxRDY | Receiver Ready (has cheracter for 8000 ) |
| TxROY | Transmitter Resoty (resoy for cher from 8080 ) |
| $\overline{\text { DSF }}$ | Date Set Reedy |
| DTA | Data Terminat Resay |
| SYNDET | Sync Detact |
| SYNDET/BD | Sync Detect/Broak Detect |
| ATS | Request to Send Date |
| CTS | Cleer to Send Doun |
| TxE | Trenumitter Emply |
| Vcc | 45 Vott Supply |
| GND | Ground |

TM: Z80 is a registered trademark of Zilog, Inc. Reprinted through courtesy of NEC Electronics, U.S.A., Inc.
NOTE: These manufacturer's specifications are provided for reference. The APC
may not use some of the functions described here.

The $\mu$ PD8251 and $\mu$ PD8251A Universal Synchronous/Asynchronous Receiver/
Transmitters are designed specifically for 8080 microcomputer systems but work with most 8 -bit processors. Operation of the $\mu$ PD8251 and $\mu$ PD8251A, like other I/O devices in the 8080 family, are programmed by system software for maximum flexibility.

In the receive mode, the $\mu$ PD8251 or $\mu$ PD8251A converts incoming serial format data into parallel data and makes certain format checks. In the transmit mode, it formats parallel data into serial form. The device also supplies or removes characters or bits that are unique to the communication format in use. By performing conversion and formatting services automatically, the USART appears to the processor as a simple or "transparent" input or output of byte-oriented parallel data.

The $\mu$ PD 8251 A is an advanced design of the industry standard 8251 USART. It operates with a wide range of microprocessors, including the 8080,8085 , and $\mu$ PD 780 (Z80 ${ }^{\text {TM }}$ ). The additional features and enhancements of the $\mu$ PD8251A over the $\mu$ PD8251 are listed below.

1. The data paths are double-buffered with separate $I / O$ registers for control, status, Data In and Data Out. This feature simplifies control programming and min. imizes processor overhead.
2. The Receiver detects and handles "break" automatically in asynchronous operations, which relieves the processor of this task.
3. The Receiver is prevented from starting when in "break" state by a refined Rx initialization. This also prevents a disconnected USART from causing unwanted interrupts.
4. When a transmission is concluded the $T \times D$ line will always return to the marking state unless SBRK is programmed.
5. The Tx Disable command is prevented from halting tra!ismission by the $T_{x}$ Enable Logic enhancement, until all data previously written has been trans mitted. The same logic also prevents the transmitter from turning off in the mid dle of a word.
6. Internal Sync Detect is disabled when External Sync Detect is programmed. An External Sync Detect Status is provided through a flip.flop which clears itself upon a status read.
7. The possibility of a false sync detect is minimized by:

- ensuring that if a double sync character is programmed, the characters be contiguously detected.
- clearing the Rx register to all Logic 1s $(\mathrm{VOH})$ whenever the Enter Hunt com. mand is issued in Sync mode.

8. The $\overline{R D}$ and $\overline{W R}$ do not affect the internal operation of the device as long as the $\mu$ PD8251A is not selected.
9. The $\mu$ PD8251A Status can be read at any time, however, the status update will be inhibited during status read.
10. The $\mu$ PD8251A has enhanced $A C$ and $D C$ characteristics and is free from extraneous glitches, providing higher speed and improved operating margins.
11. Baud rate from $D C$ to $64 K$.

FUNCTIONAL
DESCRIPTION
$\mu$ PD8251A FEATURES AND ENHANCEMENTS

A2-2

## BASIC OPERATION

| $\mathbf{C} / \overline{\mathbf{D}}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ | $\overline{\mathbf{C S}}$ |  |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 1 | 0 | $\mu$ PD8251 $/ \mu$ PD8851A $\rightarrow$ Data Bus |
| 0 | 1 | 0 | 0 | Data Bus $\rightarrow \mu$ PD8251 $/ \mu$ PD8251A |
| 1 | 0 | 1 | 0 | Status $\rightarrow$ Data Bus |
| 1 | 1 | 0 | 0 | Data Bus $\rightarrow$ Control |
| $X$ | $X$ | $X$ | 1 | Data Bus $\rightarrow$ 3.State |
| $X$ | 1 | 1 | 0 |  |

TM: Z80 is a registered trademark of Zilog, Inc.

## BLOCK DIAGRAM



[^1]$T_{a}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ for 8251 A and $\pm 5 \%$ for $8251 ; \mathrm{GND}=0 \mathrm{~V}$.

| PARAMETER | SYMBOL | LIMITS |  |  |  |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mu \mathrm{PD8251}$ |  |  | [PPD8251A |  |  |  |
|  |  | MIN | TYp | MAX | MIN | MAX |  |  |
| Input Low Vol tage | $V_{\text {IL }}$ | -0.5 |  | 0.8 | 0.5 | 0.8 | $\checkmark$ |  |
| Input High Voltage | $v_{\text {IH }}$ | 2.0 |  | $\mathrm{V}_{\mathrm{Cc}}$ | 2.2 | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| Output Low Voltage | VOL |  |  | 0.45 |  | 0.45 | v | $\mu$ PD8251: $10 \mathrm{~L}=1.7 \mathrm{~mA}$ <br> $\mu \mathrm{PD} 8251 \mathrm{~A}: 1 \mathrm{OL}=2.2 \mathrm{~mA}$ |
| Output High Voltage | ${ }^{\mathrm{VOH}}$ | 2.4 |  |  | 2.4 |  | v | $\mu$ PD8251: $\quad 1 \mathrm{OH}=-106 \mu \mathrm{~A}$ <br> $\mu$ PD8251A: $1 \mathrm{OH}=-400 \mu \mathrm{~A}$ |
| Data Bus Leakage |  |  |  | -50 |  | -10 | $\mu$ | VOUT $=0.45 \mathrm{~V}$ |
|  |  |  |  | 10 |  | 10 |  | $V_{\text {OUT }}=V_{\text {CC }}$ |
| Input Load Current | IIL |  |  | 10 |  | 10 | $\mu \mathrm{A}$ | At 5.5 V |
| Power Supply Current | 'cc |  | 45 | 80 |  | 100 | mA | $\mu$ PD8251A: All Outputs $=$ Logic 1 |

$T_{a}=25^{\circ} \mathrm{C}: V_{C C}=G N D=O V$

| PARAMETER | SYMBOL | LIMITS |  |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP | Max |  |  |
| Input Capacitance | $\mathrm{CIN}^{\text {I }}$ |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| 1/O Capacitance | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  |  | 20 | pF | Unmeasured pins returned 10 GND |

DC CHARACTERISTICS

CAPACITANCE
$T_{a}=0^{\circ} \mathrm{C} 1070^{\circ} \mathrm{C}, ~ V_{C C}=5.0 \mathrm{~V}=10 \%$ for $8251 \mathrm{~A}, \mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=50 \mathrm{~V}: 5 \%$ tor 8251

| PARAMETER | SYMBOL | LIMITS |  |  |  | UNIT | test CONOITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | -PD8251 |  | $\mu$ POB215A |  |  |  |
|  |  | MIN | MAX | MIN | MAX |  |  |
| READ |  |  |  |  |  |  |  |
| Address Stable betore $\overline{\text { DEAD }}$ ( (CS , C/O) | 'AR | 50 |  | 50 |  | ns |  |
| Address Hold Time tor READ. IC'S. CD) | tra | 5 |  | 50 |  | ns |  |
| वEAD Pulse Width | tra | 430 |  | 250 |  | ns |  |
| Data Detar from $\overline{\text { READ }}$ | 'RD |  | 350 |  | 250 | ns | $\begin{array}{\|ll} \hline \text { POD } 251 C_{L} & 100 \mathrm{\mu F} \\ \mu \text { POB251A } C_{L} & 150 \mathrm{pF} \\ \hline \end{array}$ |
| $\overline{\text { READ }}$ : Data Floaring | ${ }^{\text {' }} \mathrm{D}$ | 25 | 200 | 10 | 100 | ns | $\begin{aligned} & { }^{4} \mathrm{COB251} \\ & \mathrm{C}_{L}=100 \mathrm{pF} \\ & \mathrm{C}_{L}=15 \mathrm{pF} \\ & \hline \end{aligned}$ |
| WRITE |  |  |  |  |  |  |  |
| Address Stabie before WRITE | taw | 20 |  | 50 |  | ns |  |
| Address Hold Time tor WRITE | iWA | 20 |  | 50 |  | ns |  |
| Write Pulse Wiath | iww | 400 |  | 250 |  | ns |  |
| Data Sel Uo T.me tor WRITE | ${ }^{\text {tow }}$ | 200 |  | 150 |  | ns |  |
| Data Hold T.me to What ${ }^{\text {de }}$ | 'wo | 40 |  | 30 |  | ns |  |
| Recoverr Time Between WRITES (2) | 'Rv | 6 |  | 6 |  | $\mathrm{Cr}^{\text {cr }}$ |  |
| OTHER TIMING |  |  |  |  |  |  |  |
| Coock Period (3) | ${ }^{\text {c }} \mathrm{Cr}$ | 0420 | 135 | 032 | 135 | \#s |  |
| Clock Puise Widin High | 'ow | 220 | 07 Cr | 140 | ${ }^{1} \mathrm{Cr} 90$ | ns |  |
| Cock Puise Wath Lon | tow |  |  | 90 |  | ns |  |
|  | 18. ${ }^{\text {f }}$ | 0 | 50 | 5 | 20 | ns |  |
| T*O Detar trom Faling Eage of TxC | ${ }^{1015}$ |  | 1 |  | 1 | as | -P08251 CL $=100 \mathrm{DF}$ |
| Ra Dara Set Ud Time io Samoling Puise | ${ }_{\text {'SA }}{ }^{\text {d }}$ | 2 |  | 2 |  | 4 |  |
| Rx Data mold T me to Samo ng Puise | IHRX | 2 |  | 2 |  | us |  |
| Transmitter indut Clock Frequency ix Baud Rate | 'Tx | OC | 56 |  | 64 | $\mathrm{aH:}_{4}$ |  |
| 16x Baug Rote $64 \times$ Baud Rate |  | DC | 520 |  | 310 | ${ }_{k+2}$ |  |
| $64 \times$ Baud Rate |  | OC | 520 |  | 615 | $\times{ }^{+}$ |  |
|  | 'TPW | 12 |  | 12 |  | $\frac{\mathrm{Cr}}{\mathrm{Cr}}$ |  |
| $\begin{aligned} & \text { Tansm i:e ingut C ock Puse Ceiar } \\ & 1 \times \text { Baud Rate } \\ & 16 \times \text { and } 64 \times \text { Baud Rale } \end{aligned}$ | ${ }^{1 T P D}$ | $\frac{15}{3}$ |  | $\frac{15}{3}$ |  | $\frac{1 \mathrm{Cr}}{\mathrm{i} \mathrm{Cr}}$ |  |
| $\begin{aligned} & \text { Rece ive Indul Clock Fieauency } \\ & 1 \times \text { Baud Rate } \\ & 16 \times \text { Baud Rate } \end{aligned}$ | ${ }^{\text {R } x}$ | $\frac{D C}{\text { DC }}$ | 56 |  | 64 310 | ${ }_{\mathrm{kH}}^{\mathrm{kHz}}$ |  |
| $64 \times$ Baut Rate |  | OC | 520 |  | 615 | ${ }_{\mathrm{kHz}}$ |  |
| Receiver Inpul C'ock Puse W.din $1 \times$ Baud Rale <br> 16 X and $64 \times$ Baud Rate | 'RPW | 12 |  | 12 |  | $\frac{\mathrm{Cr}}{\mathrm{Cr}}$ |  |
| Receiver inpul Clock Pulse Deiar 1x Baua Hate <br> 16 x and $64 \times$ Baud Rate | 'RPD | ${ }^{15}$ |  | $\frac{15}{3}$ |  | $\frac{1 \mathrm{Cr}}{\frac{1}{\mathrm{Cr}}}$ |  |
| Traor Delar tiom Center ot Data B.1 | ${ }^{19} \times$ |  | 16 |  | 8 | Cry | ${ }^{4} \mathrm{PO} 8251 \mathrm{C}_{L} 50 \mathrm{~m}$ |
| RaRor Delay trom Center ol Databi, internal sYNOET Delar 'rom Center ot Da'a B.t | $\begin{aligned} & \text { 'Rx } \\ & \text { I/S } \end{aligned}$ |  | $\begin{aligned} & 20 \\ & 25 \end{aligned}$ |  | $\begin{aligned} & 24 \\ & 24 \end{aligned}$ | $\begin{aligned} & \mathrm{Cr} \\ & \mathrm{CH} \end{aligned}$ |  |
| External SYNDET Sel UD Time belore Failing Edge of $\overline{A_{x} C}$ | 'Es | 16 |  | 10 |  | ${ }^{1} \mathrm{C} Y$ |  |
| TxEMPTY Delay trom Center of Data Bit | T $7 \times \varepsilon$ |  | 16 |  | 20 | $\mathrm{Cr}_{\mathrm{Cr}}$ |  |
| Conio: Delar trom Rising Edge of WRITE (TXE OTR ATS) | 'wc |  | 16 |  | 8 | ${ }^{\text {cr }}$ |  |
| Contio' io READ Sel Ud Time ĪSR $\overline{\text { CTS }}$ | ${ }^{\text {'CR }}$ | 16 |  | 20 |  | ${ }^{1} \mathrm{Cr}$ |  |



Figure 1.
test load circuit


TIMING WAVEFORMS




WRITE DATA CYCLE (PROCESSOR $\rightarrow$ USART)


TIMING WAVEFORMS (CONT.)


WRITE CONTROL OR OUTPUT PORT CYCLE
(PROCESSOR $\rightarrow$ USART)


READ CONTROL OR INPUT PORT CYCLE
(PROCESSOR $\leftarrow$ USART)
notes
Twe includer the imponse iming ot a contiol br"
(2) TCR include the oftect of CTS on the TxENBL cricutior


TRANSMITTER CONTROL AND FLAG TIMING (ASYNC MODE)


TIMING WAVEFORMS (CONT.)

RECEIVER CONTROL AND FLAG TIMING (ASYNC MODE)


EXAMPLE FORMAT - 5 bit Character with parity and 2 Sync characters
TRANSMITTER CONTROL AND FLAG TIMING (SYNC MODE)


Notes: (1) Internal sync, 2 sync characters, 5 bits, with parity. (2) External sync, 5 bits, with parity.

| PIN |  |  | FUNCTION |
| :---: | :---: | :---: | :---: |
| NO. | SYMBOL | NAME |  |
| $\begin{gathered} 1.2 \\ 27.28 \\ 5-8 \end{gathered}$ | $\mathrm{D}_{7}-\mathrm{D}_{0}$ | Data Bus Buffer | An 8-bit, 3-state bi-directional buffer used to interface the USART to the processor data bus. Data is transmitted or received by the buffer in response to input/output or Read/ Write instructions from the processor. The Data Bus Buffer also transfers Control words, Command words, and Status. |
| 26 | $\vee^{\text {CC }}$ | $\vee_{\text {CC }}$ Supply Voltage | + 5 volt supply |
| 4 | GND | Ground | Ground |
| Read'Write Control Logic |  |  | This logic blocl. accepis inputs fiom the pio cessor Control Bus and generates control signals for overall USART operation The Mode Instruction and Command Instruction registers that store the control formats for device func thonal definition are located in the Read Write Control Logic |
| 21 | RESET | Reset | A "one" on this input forces the USART into the "Idie" mode where it will remain untul reinitial ized with a new set of control words. Minimum RESET pulse width is $6^{\circ} \mathrm{CY}$ |
| 20 | CLK | Clock Pulse | The CLK input provides for internal device tim ing and is usually connected to the Phase 2 (TTL) output of the $\mu$ PB8224 Clock Generator. External inputs and outputs ale not referenced to CLK, but the CLK frequency must be at least 30 times the Receive' or Tiansmitier clocks in the synchronous mode and 4.5 times for the asynchronous mode |
| 10 | $\overline{\mathrm{WR}}$ | Write Data | A "zero" on this input instructs the USART to accept the data or control word which the processor is writing out on the data bus |
| 13 | $\overline{R D}$ | Read Data | A "zero" on this input instructs the USART to place the data or status information onto the Data Bus for the processor to read |
| 12 | C: $\bar{O}$ | Control Data | The Control Data input, in confunction with the $\overline{W R}$ and $\overline{R D}$ inputs, informs the USART 10 accept or provide either a data character. control word or status information via the Data Bus. 0 - Data. 1 Controt |
| 11 | $\overline{\overline{C S}}$ | Chip Select | A "zero" on this input enables the USART to read from or write to the processor. |
| Modem Control |  |  | The $\mu$ PD8251 and $\mu$ PD8251A have a set of control inputs and outputs which may be used to simplify the interface to a Modem. |
| 22 | $\overline{\text { DSR }}$ | Data Set Ready | The Data Set Ready input can be tested by the processor via Status information. The $\overline{\mathrm{SR}}$ input is normally used to test Modem Data Set Ready condition. |
| 24 | $\overline{\text { DTR }}$ | Data Terminal Ready | The Data Terminal Ready outpul can be con. trolled via the Command word The DTR output is normally used to drive Modem Data Terminal Ready or Rate Select lines |
| 23 | $\stackrel{\rightharpoonup}{\text { RTS }}$ | Request to Send | The Request to Send output can be controlled via the Command word The RTS output is normally used to drive the Modem Request to Send line. |
| 17 | CTS | Clear to Send | A "zero" on the Clear to Send input enables the USART to transmit serial data if the TxEN bit in the Command Instruction register is enabled (one) |

The Transmit Buffer receives parallel data from the Data Bus Buffer via the internal data bus, converts parallel to serial data, inserts the necessary characters or bits needed for the programmed communication format and outputs composite serial data on the $T \times D$ pin.

| PIN |  |  | FUNCTION |
| :---: | :---: | :---: | :---: |
| NO. | SYMBOL | NAME |  |
| Transmit Control Logic |  |  | The Transmit Control Logic accepts and outputs all external and internal signals necessary for serial data transmission. |
| 15 | TXRDY | Transmitter Ready | Transmitter Ready signals the processor that the transmitter is ready to accept a data character. TxRDY can be used as an interrupt or may be tested through the Status information for polled operation. Loading a character from the processor automatically resets T×RDY, on the leading edge. |
| 18 | T×E | Transmitter Empty | The Transmitter Empty output signals the processor that the USART has no further characters to transmit. TXE is automatically reset upon receiving a data character from the processor. In half-duplex, $T \times E$ can be used to signal end of a transmission and request the processor to "turn the line around." The TXEn bit in the command instruction does not effect $T \times E$. <br> In the Synchronous mode, a "one" on this output indicates that a Sync character or characters are about to be automatically transmitted as "fillers" because the next data character has not been loaded. |
| 9 | $\overline{\mathrm{T} \times \mathrm{C}}$ | Transmitter Clock | The Transmitter Clock controls the serial charac ter transmission rate. In the Asynchronous mode, the $\overline{T \times C}$ frequency is a multiple of the actual Baud Rate. Two bits of the Mode Instruction select the multiple to be $1 \mathrm{x}, 16 \mathrm{x}$, or 64 x the Baud Rate. In the Synchronous mode, the $\bar{T} \times \mathrm{C}$ frequency is automatically selected to equal the actual Baud Rate. <br> Note that for both Synchronous and Asynchro. nous modes, serial data is shifted out of the USART by the falling edge of $\overline{T \times C}$. |
| 19 | T×0 | Transmitter Data | The Transmit Control Logic outputs the composite serial data stream on this pin. |



TRANSMIT BUFFER

PIN IDENTIFICATION (CONT.)
$\mu$ PD8251 AND $\mu$ PD8251A INTERFACE TO 8080 STANDARD SYSTEM BUS

RECEIVE BUFFER
The Receive Buffer accepts serial data input at the $\overline{\mathrm{RxD}}$ pin and converts the data from serial to parallel format. Bits or characters required for the specific communication technique in use are checked and then an eight-bit "assembled" character is readied for the processor. For communication techniques which require less than eight bits, the $\mu$ PD8251 and $\mu$ PD8251A set the extra bits to "zero."
PIN IDENTIFICATION (CONT.)

| PIN |  |  | FUNCTION |
| :---: | :---: | :---: | :---: |
| No. | SYMBOL | NAME |  |
| Receiver Contiol Logic |  |  | This block manages all activities related to incoming datd. |
| 14 | R×RDY | Recerver Ready | The Receiver Ready output indicates that the Receive, Buffer is ready with an "assembled" characte, for input to the processor For Polled opetation, the processol can check R×RDY using a Status Read or R×ROY can be con nected to the processor interiupt stiucture Note that readina the character to the pro cessol ،utomatically ese is RxRDY |
| 25 | $\overline{\mathrm{R} \times \mathrm{C}}$ | Receiver Clock | The Receiver Clock determines the rate at which the incoming character is received in the Asynchionous inodr. the $\mathrm{R} \times \mathrm{C}$ frequency may be 116 or 64 temes the actual Baud Rate but in the Syn chronous mode the $\overline{R_{x C} C}$ fiequency must rifual the Baud Rate Tivo bits in the mode nstuction stliect Asvichronous at $1 x$. $16 x$ ot $64 x$ or Syll chronous oferation at 1 x the Baud Rate <br> Unline $\overline{T \times C}$. (1,th, is sampled thy the $P$ PO825 and aPD8251A on the ising edge of $\overline{\mathrm{R} \times \mathrm{C}}$ (1) |
| 3 | R.D | Receren Dinn | A composite setal datd stifam is recerved by the Recenter Cuntror Logic on this pin |
| 16 | SYNDET <br> 1нPD8251। | Sync Detect | The SYNC Detect Den is only used in the Synchonous mode The $\mu$ PD8251 mar be pu giommed through the Mode Instruction io odetate in either the internal or external Sync mode and SYNDET then functions as an output or input espectively in the internal Sync mode. the SYNDET Output sill go to a "one" when the $\mu$ PD8251 has lucated the SYNC chatacter In the Recerve mode 1 (dout) SYNC Chatacter (the synct opetation has been do o grammed. SYNDET will go to "one" in the middie of the last bit of the second SYNC character SYNDE T is autumatically eset to zero" upon a Status Read or RESET In the externat SYNC mode. a"rero" to "one" thans lion un the SYNDET input will cause the $\mu$ PD8251 to start assembling data characte on the next falling edge of $\overline{R_{x} C}$ The length of the SYNDET input should be at least one $\overline{\mathrm{R} \times \mathrm{C}}$ period. but mav be removed once the ${ }_{\mu}$ PD8251 is in SYNC |
| 16 | SYNDET BD ( $\mu$ PD8251A) | Sync Detect Break Detect | The SYNDET/BD pin is used in both Synchronous and Asynchronous modes. When in SYNC mode the features for the SYNDET pin described above apply. When in Asynchronous mode, the Break Detect output will go high which all zero word of the programmed length is received. This word consists of: start bit, data bit, parity bit and one stop bit. Reset only occurs when Rx data returns to a logic one state or upon chip reset. The state of Break Detect can be read as a status bit. |

Note: (1) Since the $\mu$ PD8251 and $\mu$ PD8251A will frequently be handing both the reception and transmission for a given link. the Receive and Transmit Baud Rates will be same. $\overline{\mathrm{AxC}^{\prime}}$ and $\overline{T \times C}$ then require the same frequency and may be thed together and connected to a single clock source or Baud Rate Generator.
Examples

If the Baud Rate equals 110 (Async)
$\overline{R_{x} C}$ or $\overline{T_{x} C}$ equals $110 \mathrm{~Hz}(1 x)$
$\overline{R \times C}$ or $\overline{T \times C}$ equals $1.76 \mathrm{KHz}^{1 / 6 x)}$
R×C or $\overline{T \times C}$ equals $7.04 \mathrm{KHz}^{(64 \times 1}$

A set of control words must be sent to the $\mu$ PD8251 and $\mu$ PD8251A to define the desired mode and communications format. The control words will specify the BAUD rate factor ( $1 \mathrm{x}, 16 \mathrm{x}, 64 \mathrm{x}$ ), character length ( 5 to 8 ), number of STOP bits ( $1,1-1 / 2$, 2) Asynchronous or Synchronous mode, SYNDET (IN or OUT), parity, etc.

After receiving the control words, the $\mu$ PD8251 and $\mu$ PD8251A are ready to communicate. TxRDY is raised to signal the processor that the USART is ready to receive a character for transmission. When the processor writes a character to the USART, TxRDY is automatically reset.

Concurrently, the $\mu$ PD8251 and $\mu$ PD8251A may receive serial data; and after receiving an entire character, the RxRDY output is raised to indicate a completed character is ready for the processor. The processor fetch will automatically reset R×RDY.

Note: The $\mu$ PD8251 and $\mu$ PD8251A may provide faulty RxRDY for the first read after power-on or for the first read after receive is re-enabled by a command instruction ( $R \times E$ ). A dummy read is recommended to clear faulty $R \times R D Y$. But this is not the case for the first read after hardware or software reset after the device operation has once been established.

The $\mu$ PD8251 and $\mu$ PD8251A cannot transmit until the TxEN (Transmitter Enable) bit has been set by a Command Instruction and until the $\overline{\mathrm{CTS}}$ (Clear to Send) input is a "zero". TxD is held in the "marking" state after Reset awaiting new control words.

The USART must be loaded with a group of two to four control words provided by the processor before data reception and transmission can begin. A RESET (internal or external) must immediately proceed the control words which are used to program the complete operational description of the communications interface. If an external RESET is not available, three successive 00 Hex or two successive 80 Hex command instructions ( $C / \bar{D}=1$ ) followed by a software reset command instruction ( 40 Hex ) can be used to initialize the $\mu$ PD8251 and $\mu$ PD8251A.

There are two control word formats:

1. Mode Instruction
2. Command Instruction

This control word specifies the general characteristics of the interface regarding the Synchronous or Asynchronous mode, BAUD rate factor, character length, parity, and number of stop bits. Once the Mode Instruction has been received, SYNC characters or Command Instructions may be inserted depending on the Mode Instruction content.

## OPERATIONAL DESCRIPTION

USART PROGRAMMING

COMMAND INSTRUCTION

TYPICAL DATA BLOCK

MODE INSTRUCTION
DEFINITION

ASYNCHRONOUS TRANSMISSION

This control word will be interpreted as a SYNC character definition if immediately preceded by a Mode Instruction which specified a Synchronous format. After the SYNC character(s) are specified or after an Asynchronous Mode Instruction, all subsequent control words will be interpreted as an update to the Command Instruction. Command Instruction updates may occur at any time during the data block. To modify the Mode Instruction, a bit may be set in the Command Instruction which causes an internal Reset which allows a new Mode Instruction to be accepted.


NOTE (1)The second SYNC character is skipped if MODE instruction has progiammed the $\mu$ PD8251 and $\mu$ PD8251A to single character Internal SYNC Mode Both SYNC characters are skipped if MODE instiuction has programmed the $\mu$ PD8251 and $\mu$ PD8251A to ASYNC mode.

The $\mu$ PD8251 and $\mu$ PD8251A can operate in either Asynchronous or Synchronous communication modes. Understanding how the Mode Instruction controls the functional operation of the USART is easiest when the device is considered to be two separate components (one asynchronous and the other synchronous) which share the same support circuits and package. Although the format definition can be changed at will or "on the fly," the two modes will be explained separately for clarity.

When a data character is written into the $\mu$ PD8251 and $\mu$ PD8251A, the USART automatically adds a START bit (low level or "space") and the number of STOP bits (high level or "mark") specified by the Mode Instruction. If Parity has been enabled. an odd or even Parity bit is inserted just before the STOP bit(s), as specified by the Mode Instruction. Then, depending on $\overline{\mathrm{CTS}}$ and TXEN , the character may be trans mitted as a serial data stream at the $T \times D$ output. Data is shifted out by the falling edge of $T \times C$ at $T \times C, T \times C / 16$ or $T \times \bar{C} / 64$, as defined by the Mode Instruction.

If no data characters have been loaded into the $\mu$ PD8251 and $\mu$ PD8251A, or if all available characters have been transmitted, the T×D output remains "high" (marking) in preparation for sending the START bit of the next character provided by the processor. TxD may be forced to send a BREAK (continuously low) by setting the correct bit in the Command Instruction.

The $R \times D$ input line is normally held "high" (marking) by the transmitting device. A falling edge at $R \times D$ signals the possible beginning of a START bit and a new character. The START bit is checked by testing for a "low" at its nominal center as specified by the BAUD RATE. If a "low" is detected again, it is considered valid, and the bit assembling counter starts counting. The bit counter locates the approximate center of the data, parity (if specified), and STOP bits. The parity error flag (PE) is set, if a parity error occurs. Input bits are sampled at the $R \times D$ pin with the rising edge of $\overline{R \times C}$. If a high is not detected for the STOP bit, which normally signals the end of an input character, a framing error (FE) will be set. After a valid STOP bit, the input character is loaded into the parallel Data Bus Buffer of the $\mu$ PD8251 and $\mu$ PD8251A and the RxRDY signal is raised to indicate to the processor that a character is ready to be fetched. If the processor has failed to fetch the previous character, the new character replaces the old and the overrun flag (OE) is set. All the error flags can be reset by setting a bit in the Command Instruction. Error flag conditions will not stop subsequent USART operation.



TRANSMISSION FORMAT


PROCESSOR BYTE (5-8 8ITS/CHAR) (3)
DATA CHARACTER


## RECEIVE FORMAT

Notes
(i) Generated by $\mu P D 8251 / 82: 51 A$
(2) Does not appear on the Data Bus
(3) If character length is defined as 5, 6, or 7 bits, the unused bits are set to "zero."

SYNCHRONOUS

SYNCHRONOUS RECEIVE

As in Asynchronous transmission, the TxD output remains "high" (marking) until the $\mu$ PD8251 and $\mu$ PD8251A receive the first character (usually a SYNC character) from the processor. After a Command Instruction has set TXEN and after Clear to Send ( $\overline{\mathrm{CTS}}$ ) goes low, the first character is serially transmitted. Data is shifted out on the falling edge of $\overline{T \times C}$ and the same rate as $\overline{T \times C}$.

Once transmission has started, Synchronous Mode format requires that the serial data stream at TxD continue at the $\mathrm{T} \times \mathrm{C}$ rate or SYNC will be lost. If a data character is not provided by the processor before the $\mu$ PD8251 and $\mu$ PD8251A Transmit Buffer becomes empty, the SYNC character(s) loaded directly following the Mode Instruction will be automatically inserted in the TxD data stream. The SYNC character(s) are inserted to fill the line and maintain synchronization until new data characters are available for transmission. If the $\mu$ PD8251 and $\mu$ PD8251A become empty, and must send the SYNC character(s), the TXEMPTY output is raised to signal the processor that the Transmitter Buffer is empty and SYNC characters are being transmitted. TxEMPTY is automatically reset by the next character from the processor.

In Synchronous Receive, character synchronization can be either external or internal. If the internal SYNC mode has been selected, and the Enter HUNT (EH) bit has been set by a Command Instruction, the receiver goes into the HUNT mode.

Incoming data on the R×D input is sampled on the rising edge of $\overline{R \times C}$. and the Receive Buffer is compared with the first SYNC character after each bit has been loaded until a match is found. If two SYNC characters have been programmed, the next received character is also compared. When the SYNC character(s) programmed have been detected, the $\mu$ PD8251 and $\mu$ PD8251A leave the HUNT mode and are in character synchronization. At this time, the SYNDET (output) is set high. SYNDET is automatically reset by a STATUS READ.

If external SYNC has been specified in the Mode Instruction, a "one" applied to the SYNDET (input) for at least one $\overline{R \times C}$ cycle will synchronize the USART

Parity and Overrun Errors are treated the same in the Synchronous as in the Asynchronous Mode. If not in HUNT, parity will continue to be checked even if the receiver is not enabled. Framing errors do not apply in the Synchronous format.

The processor may command the receiver to enter the HUNT mode with a Command Instruction which sets Enter HUNT (EH) if synchronization is lost.


Note (1) It chatacter lengith is defined as 5.60, 7 bits, then unusuch bitsurestet to "zero.
$\mathrm{A}^{\prime}$ 2-16

COMMAND INSTRUCTION
FORMAT
After the functional definition of the $\mu$ PD8251 and $\mu$ PD8251A has been specified by the Mode Instruction and the SYNC character(s) have been entered (if in SYNC mode), the USART is ready to receive Command Instructions and begin communication. A Command Instruction is used to control the specific operation of the format selected by the Mode Instruction. Enable Transmit, Enable Receive, Error Reset and Modem Controls are controlled by the Command Instruction.
After the Mode Instruction and the SYNC character(s) (as needed) are loaded, all subsequent "control writes" ( $C / \bar{D}=1$ ) will load or overwrite the Command Instruction register. A Reset operation (internal via CMD IR or external via the RESET input) will cause the $\mu$ PD8251 and $\mu$ PD8251A to interpret the next "control write", which must immediately follow the reset, as a Mode Instruction.

STATUS READ FORMAT It is frequently necessary for the processor to examine the status of an active interface device to determine if errors have occurred or if there are other conditions which require a response from the processor. The $\mu$ PD8251 and $\mu$ PD8251A have features which allow the processor to read the device status at any time. A data fetch is issued by the processor while holding the C/D input "high" to obtain device Status Information. Many of the bits in the status register are copies of external pins. This dual status arrangement allows the $\mu$ PD8251 and $\mu$ PD8251A to be used in both Polled and interrupt driven environments. Status update can have a maximum delay of 16 clock periods in the $\mu$ PD8251 and 28 clock periods in the $\mu$ PD8251A.

PARITY ERROR When a parity error is detected, the PE flag is set. It is cleared by setting the ER bit in a subsequent Command Instruction. PE being set does not inhibit USART operation.

OVERRUN ERROR If the processor fails to read a data character before the one following is available, the OE flag is set. It is cleared by setting the ER bit in a subsequent Command Instruction. Although OE being set does not inhibit USART operation, the previously received character is overwritten and lost.
FRAMING ERROR (1) (1)

If a valid STOP bit is not detected at the end of a character, the FE flag is set. It is cleared by setting the ER bit in a subsequent Command Instruction. FE being set does not inhibit USART operation.

Note:
(1) ASYNC mode on! $y$

FORMAT


APPLICATION OF THE $\mu$ PD8251
AND $\mu$ PD8251A


ASYNCHRONOUS SERIAL INTERFACE TO CRT TERMINAL, DC to 9600 BAUD


ASYNCHRONOUS INTERFACE TO TELEPHONE LINES


SYNCHRONOUS INTERFACE TO TERMINAL OR PERIPHERAL DEVICE


SYNCHRONOUS INTERFACE TO TELEPHONE LINES


PACKAGE OUTLINES $\mu$ PD8251C
$\mu$ PD8251AC

$\mu$ PD8251D
$\mu$ PD8251AD

## Ceramic

| ITEM | MILLIMETERS | INCHES |
| :---: | :---: | :---: |
| A | 36.2 MAX. | 1.43 MAX |
| 8 | 1.59 MAX. | 0.06 MAX. |
| C | $2.54: 0.1$ | $0.1: 0.004$ |
| D | $0.46 \pm 0.01$ | 0.02:0.004 |
| E | $33.02 \leq 0.1$ | 1.3:0.004 |
| F | 1.02 MIN . | 0.04 MIN . |
| G | 3.2 MIN . | 0.13 MIN . |
| H | 1.0 MIN . | 0.04 MIN . |
| 1 | 3.5 MAX. | 0.14 MAX. |
| $J$ | 4.5 MAX. | 0.18 MAX. |
| K | 15.24 TYP. | 0.6 TYP. |
| L | 14.93 TYP. | 0.59 TYP. |
| M | $0.25: 0.05$ | 0.01: 0.002 |

## SINGLEIDOUBLE DENSITY FLOPPY DISK CONTROLLER



Reprinted through courtesy of NEC Electronics, U.S.A., Inc.
NOTE: These manufacturer's specifications are provided for reference. The APC may not use some of the functions described here.


## BLOCK DIAGRAM

## ABSOLUTE MAXIMUM <br> RATINGS*

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

DC CHARACTERISTICS
$\mathrm{T}_{\mathrm{a}}=-10^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$ unless otherwise specified.

| PARAMETER | SYMBOL | LIMITS |  |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP(1) | MAX |  |  |
| Input Low Voltage | $V_{\text {IL }}$ | -0.5 |  | 0.8 | V |  |
| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | 2.0 |  | $\mathrm{V}_{\text {CC }}+0.5$ | V |  |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | $\mathrm{V}_{\text {cc }}$ | V | $\mathrm{I}^{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| Input Low Voltage (CLK + WR Clock) | $V_{\text {IL }}(\Phi)$ | -0.5 |  | 0.65 | V |  |
| Input High Voltage (CLK + WR Clock) | $V_{1 H}(\Phi)$ | 2.4 |  | $V_{C C}+0.5$ | V |  |
| VCC Supply Current | ${ }^{1} \mathrm{CC}$ |  |  | 150 | mA |  |
| Input Load Current | ILI |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ |
| (All Input Pins) |  |  |  | -10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ |
| High Level Output Leakage Current | ${ }^{1} \mathrm{LOH}$ |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {OUT }}=V_{\text {CC }}$ |
| Low Level Output Leakage Current | ILOL |  |  | -10 | $\mu \mathrm{A}$ | $V_{\text {OUT }}=+0.45 \mathrm{~V}$ |

Note: (1) Typical values for $\mathrm{T}_{\mathrm{a}}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
$-10^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

Power Dissipation
1 Watt

PIN IDENTIFICATION

| PIN |  |  | INPUT/ OUTPUT | $\begin{gathered} \text { CONNECTION } \\ \text { TO } \end{gathered}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| No. | SYMSOL | NAME |  |  |  |
| 1 | RST | Resot | Input | Procsmor | Plecen FDC in letio statio. Reoets output lines to FDD to " 0 " (low). Doew not effect SRT, HUT or HLT in Specity commend. If RDY pin is held high during Reset, FDC will generate interrupt 1.25 ms leser. To clear this interrupt use Sense Inturrupt Stetus commend. |
| 2 | मD | Read | Input(1) | Processor | Control algnel for tremafor of deta from FDC to Dots Bur, when "0" (low). |
| 3 | $\bar{W}$ | Write | Inpur(1) | Processor | Control signal for tranefor of dete to FDC vis Deta Bus, when "0" (low). |
| 4 | $\overline{\text { cs }}$ | Chip Select | Input | Proceseor | IC selected when "O" (low), allowing $\overline{\text { RD }}$ and WR to be onabled. |
| 5 | $A_{0}$ | Data/Stetus Fog Solect | Input(1) | Procemor | Selects Date Reg ( $A_{0}=1$ ) or Status Reg ( $A_{0}=0$ ) contents of the FDC to be sent to Deta Bus. |
| 6-13 | $\mathrm{DB}_{6-\mathrm{DB}}^{7}$ | Dote Bus | Input(1) Output | Procomer | 8i-Directionel 8-8it Data Bus. |
| 14 | DRO | Date DMA Requent | Output | DMA | DMA Request is being made by FDC when DRO-"1". |
| 15 | $\overline{\text { DACK }}$ | DMA Acknowledge | Input | DMA | DMA cycle is active when " 0 "' (low) and Controller is performing DMA transfer. |
| 16 | TC | Terminal Count | Input | DMA | Indicates the termination of a DMA transfor when "1" (high). It terminates data transfor during Reed/Write/Scan command in DMA or interrupt mode. |
| 17 | IDX | Index | Input | FDD | Indicates the beginning of a disk track. |
| 18 | INT | Interrupt | Output | Procemer | Interrupt Request Generated by FDC. |
| 19 | CLK | Clock | Input |  | Single Phase 8 MHz Squarewave Clock. |
| 20 | GND | Ground |  |  | D.C. Power Return. |
| 21 | WCK | Write Clock | Input |  | Write dete rate to FDD. FM $\mathbf{- 5 0 0} \mathrm{kHz}$, MFM - 1 MHz, with a pulso width of 250 ns for both FM and MFM. |
| 22 | RDW | Read Date Window | Input | Phem Lock Loop. | Generated by PLL. and used to semplo deta from FDD: |
| 23 | RDD | Read Date | Input | FDD | Reed deta from FDD, contelning clock and deta blta. |
| 24 | vco | vco Sync | Output | Phem Lock Loop | Inhibits VCO in PLL when " 0 " (low). onables VCO when "1." |
| 25 | WE | Write Enable | Output | FDD | Encblee write derto into FDD. |
| 28 | MFM | MFM Mode | Output | Pheeo Lock Loop | MFM mode when "1," FM mode when "0." |
| 27 | HD | Hoed Seloct | Output | FDD | $\begin{aligned} & \text { Heed } 1 \text { selected when " " } 1 \text { " (high). } \\ & \text { Heed } 0 \text { solected when "0" (low). } \end{aligned}$ |
| 28,29 | $\mathrm{US}_{1}, \mathrm{US} 0$ | Unit Solect | Output | FDD | FDD Unit Selected. |
| 30 | WDA | Write Dots | Outpur | FDO | Seried clock and deta bius to FDD. |
| 31,32 | $\mathrm{PS}_{1}, \mathrm{PS} \mathbf{0}$ | $\begin{aligned} & \begin{array}{l} \text { Procompensation } \\ \text { (pro-thift) } \end{array} \\ & \hline \end{aligned}$ | Output | FDD | Write procompensetion stetus during MiFM mode. Determines eerly, lete, and normid times. |
| 33 | FLT/TR 0 | Foult/Track 0 | Input | FDD | Soneve FDD fault condition, in Risd/ Write mode; and Treck 0 condition in sook mode. |
| 34 | WP/TS | Write Protect/ Two-Side | Input | FDD | Senses Write Protect status in Reed/Write mode; and Two Side Mudio in Seok mode. |
| 36 | ROY | Rosdy | Input | FDD | indiceter FDD 4 a reedy to and or recolve deta. |
| 36 | HDL | Head Loed | Output | FDD | Commiend which ceusee reed/writs heed In FDD to contect diaketis. |
| 37 | FR/STP | FIt Reoutstep | Output | FDD | Reves fault F.F. In FDD in Roed/Witio mode, contains step pulese to move heid to enother cyilinder in seok mode. |
| 38 | LCT/DIA | Low Current/ Direction | Output | FDD | Lowors Write current on inner trecke in Read/Write mode, determinee direction. heed will step in seok mode. A foule rever pulso in laved of the beoinning of eech Aoed or Write commend prior to the occurrence of the Heed Loed alenel. |
| 30 | Riniseek | Reed Wriw/sEEK | Output | FDD |  |
| 40 | Vcc | + 6 V |  |  | DC Powor. |
| (1) Diveled when C8 - 1 . |  |  |  |  |  |

$T_{a}=-10^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{C}}=+5 \mathrm{~V} \pm 5 \%$ unless otherwise specified.

| PARAMETER | SYMBOL | LIMITS |  |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP(1) | MAX |  |  |
| Clock Period | $\Phi_{\text {ch }}$ | 120 | 125 | 500 | ns |  |
| Clock Active (High, Low) | $\Phi_{0}$ | 40 |  |  | ns |  |
| Clock Rise Time | $\Phi_{r}$ |  |  | 20 | ns |  |
| Clock Fall Time | $\Phi_{\text {f }}$ |  |  | 20 | ns |  |
| $A_{0}, \overline{C S}, \overline{\text { DACK }}$ Set Up Time to $\overline{R D} \downarrow$ | $T_{\text {AR }}$ | 0 |  |  | ns |  |
| $A_{0}, \overline{C S}, \overline{\text { DACK }}$ Hold Time from $\overline{\text { RD }} \uparrow$ | TRA | 0 |  |  | ns |  |
| $\overline{\text { RD Width }}$ | TRR | 250 |  |  | ns |  |
| Data Access Time from $\overrightarrow{R D} \downarrow$ | TRD |  |  | 200 | ns | $C_{L}=100 \mathrm{pf}$ |
| DB to Float Delay Time from RD $\uparrow$ | $T^{T}$ DF | 20 |  | 100 | ns | $C_{L}=100 \mathrm{pF}$ |
| $A_{0}$. CS, $\overline{\text { DACK }}$ Set Up Time to $\overline{W R} \downarrow$ | TAW | 0 |  |  | ns |  |
| A $0, \overline{C S}, \overline{\text { DACK }}$ Hold Time to WR $\dagger$ | TWA | 0 |  |  | ns |  |
| $\overline{\text { WR Width }}$ | ${ }^{T}$ WW | 250 |  |  | ns |  |
| Data Set Up Time to $\overline{\text { WR }} \uparrow$ | T DW | 150 |  |  | ns |  |
| Data Hold Time from $\overline{W R} \uparrow$ | TWD | 5 |  |  | ns |  |
| INT Delay Time from $\overline{\mathrm{RD}} \uparrow$ | TRI |  |  | 500 | ns |  |
| INT Delay Time from $\overline{W R} \uparrow$ | ${ }^{\text {TWI }}$ |  |  | 500 | ns |  |
| DRQ Cycle Time | $T_{\text {MCY }}$ | 13 |  |  | $\mu \mathrm{s}$ |  |
| DRQ Delay Time from DACK $\downarrow$ | ${ }^{T}$ AM |  |  | 200 | ns |  |
| TC Width | ${ }^{\text {TTC }}$ | 1 |  |  | ФCY |  |
| Reset Width | TRST | 14 |  |  | ${ }^{\text {¢ }} \mathrm{CY}$ |  |
| WCK Cycle Time | TCY |  | $\begin{array}{\|l\|} \hline 2 \text { or } 4 \text { (2) } \\ 1 \text { or } 2 \\ \hline \end{array}$ |  | $\mu \mathrm{s}$ | $\begin{aligned} & \text { MFM }=0 \\ & \text { MFM }=1 \end{aligned}$ |
| WCK Active Time (High) | $\mathrm{T}_{0}$ | 80 | 250 | 350 | ns |  |
| WCK Rise Time | Tr |  |  | 20 | ns |  |
| WCK Fall Time | $\mathrm{T}_{\mathrm{f}}$ |  |  | 20 | ns |  |
| Pre-Shift Delay Time from WCK $\uparrow$ | ${ }^{T}$ TP | 20 |  | 100 | ns |  |
| WDA Delay Time from WCK $\dagger$ | ${ }^{T}$ CD | 20 |  | 100 | ns |  |
| RDD Active Time (High) | TrDD | 40 |  |  | ns |  |
| Window Cycle Time | TWCY |  | $\begin{aligned} & 2.0 \\ & 1.0 \end{aligned}$ |  | $\mu s$ | $\begin{aligned} & \text { MFM }=0 \\ & \text { MFM }=1 \end{aligned}$ |
| Window Hold Time to/from RDD | TRDW TWRD | 15 |  |  | ns |  |
| US 0,1 Hold Time to RW/SEEK $\uparrow$ | TUS | 12 |  |  | $\mu \mathrm{s}$ |  |
| SEEK/RW Hold Time to LOW CURRENT/ DIRECTION $\dagger$ | ${ }^{\text {T }}$ SD | 7 |  |  | $\mu s$ |  |
| LOW CURRENT/DIRECTION Hold Time to FAULT RESET/STEP $\uparrow$ | TDST | 1.0 |  |  | $\mu s$ |  |
| US 0,1 Hold Time from FAULT RESET/STEP $\uparrow$ | Tstu | 5.0 |  |  | $\mu \mathrm{s}$ | 8 MHz Clock Period |
| STEP Active Time (High) | $T_{\text {STP }}$ | 6.0 | 7.0 |  | $\mu \mathrm{s}$ |  |
| STEP Cycle Time | TSC | 33 | (3) | (3) | $\mu s$ |  |
| FAULT RESET Active Time (High) | TFR | 8.0 |  | 10 | $\mu 5$ |  |
| Write Data Width | TWDD | T0-50 |  |  | ns |  |
| US $\mathbf{0 , 1}^{1}$ Hold Time After SEEK | TSU | 15 |  |  | $\mu \mathrm{s}$ |  |
| Seek Hold Time from DIR | TDS | 30 |  |  | $\mu \mathrm{s}$ | 8 MHz Clock |
| DIR Hold Time after STEP | TSTD | 24 |  |  | $\mu s$ |  |
| Index Pulse Width | TIDX | 10 |  |  | ${ }_{\underline{\text { ¢ }}} \mathrm{CY}$ |  |
| $\overline{R D}+$ Delay from DRQ | TMR | 800 |  |  | ns |  |
| $\overline{\text { WR }}+$ Delay from DRQ | TMW | 250 |  |  | ns | 8 MHz Clock Period |
| $\overline{\text { WE }}$ or $\overline{\text { RD }}$ Response Time from DRO $\dagger$ | TMRW |  |  | 12 | $\mu \mathrm{s}$ |  |

Notes: (1) Typical values for $\mathrm{T}_{\mathrm{a}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$ and nominal supply voltage.
(2) The former value of $\mathbf{2}$ and 1 are applied to Standard Floppy, and the latter value of $\mathbf{4}$ and $\mathbf{2}$ are applied to Mini-floppy.
(3) Under Software Control. The range is from 1 ms to 16 ms at 8 MHz Clock Period, and 2 to 32 ms at 4 MHz Clock Period
(4) For mini-floppy applications, $\Phi_{C Y}$ must be 4 mHz .

$$
\mathrm{T}_{\mathrm{a}}=25^{\circ} \mathrm{C} ; \mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz} ; \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}
$$

| PARAMETER | SYMBOL | LIMITS |  |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP | max |  |  |
| Clock Input Capacitance | $\mathrm{C}_{\text {IN( }}$ ( $)$ |  |  | 20 | pF | All Pins Except Pin Under Test Tied to AC Ground |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ |  |  | 10 | pF |  |
| Output Capacitance | COUT |  |  | 20 | pF |  |

## AC TEST CONDITION

## INPUT/OUTPUT

clock



AC TESTING

Inputs 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 ."
Clocks are driven at 3.0 V for a logic " 1 " and 0.3 V for a logic " 0. ." Timing measure ments are made at 2.4 V for a logic " 1 " and 0.65 V for a logic " 0 ."

TIMING WAVEFORMS





INTERNAL REGISTERS The $\mu$ PD765 contains two registers which may be accessed by the main system processor; a Status Register and a Data Register. The 8-bit Main Status Register contains the status information of the FDC, and may be accessed at any time. The 8-bit Data Register (actually consists of several registers in a stack with only one register presented to the data bus at a time), which stores data, commands, parameters, and FDD status information. Data bytes are read out of, or written into, the Data Register in order to program or obtain the results after a particular command. The Status
Register may only be read and is used to facilitate the transfer of data between the processor and $\mu$ PD765.
The relationship between the Status/Data registers and the signals $\overline{\mathrm{RD}}, \overline{W R}$, and $A_{0}$ is shown below.

| $A_{0}$ | $\overline{R D}$ | $\overline{W R}$ | FUNCTION |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 1 | Read Main Status Register |
| 0 | 1 | 0 | Illegal |
| 0 | 0 | 0 | Illegal |
| 1 | 0 | 0 | Illegal |
| 1 | 0 | 1 | Read from Data Register |
| 1 | 1 | 0 | Write into Data Register |

INTERNAL REGISTERS (CONT.)

The bits in the Main Status Register are defined as follows:

| BIT NUMBER | NAME | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{DB}_{0}$ | FDD 0 Busy | $\mathrm{D}_{0} \mathrm{~B}^{8}$ | FDD number O is in the Seek mode. If any of the bits is set FDC will not accept read or write command. |
| $\mathrm{DB}_{1}$ | FDD 1 Busy | $\mathrm{D}_{1} \mathrm{~B}^{8}$ | FDD number 1 is in the Seek mode. If any of the bits is set FDC will not accept read or write command. |
| $\mathrm{DB}_{2}$ | FDD 2 Busy | $\mathrm{D}_{2} \mathrm{~B}$ | FDD number 2 is in the Seek mode. If any of the bits is set FDC will not accept read or write command. |
| $\mathrm{DB}_{3}$ | FDD 3 Busy | $\mathrm{D}_{3}{ }^{8}$ | FDD number 3 is in the Seek mode. If any of the bits is set FDC will not accept read or write command. |
| $\mathrm{DB}_{4}$ | FDC Busy | CB | A read or write command is in process. FDC will not accept any other command. |
| $\mathrm{DB}_{5}$ | Execution Mode | EXM | This bit is set only during execution phase in non-DMA mode. When DB5 goes low, execution phase has ended, and result phase was started. It operates only during NON-DMA mode of operation. |
| ${ }^{\text {D8 }} 6$ | Data Input/Output | DIO | Indicates direction of data transfer between FDC and Data Register. If DIO $=$ " 1 " then transfer is from Data Register to the Processor. If DIO = " 0 ", then transfer is from the Processor to Data Register. |
| D87 | Request for Master | RQM | Indicates Data Register is ready to send or receive data to or from the Processor. Both bits DIO and RQM should be used to perform the hand-shaking functions of "ready" and "direction" to the processor. |

The DIO and ROM bits in the Status Register indicate when Data is ready and in which direction data will be transferred on the Data Bus. The max time between the last $\overline{R D}$ or $\overline{W R}$ during command or result phase and $D I O$ and RQM getting set or reset is $12 \mu \mathrm{~s}$. For the result phase to when $\mathrm{DB}_{4}$ (FDC Busy) goes low is $12 \mu \mathrm{~s}$.
Data in, Out
(DIO)
Request tor Master
ROMM)

The $\mu$ PD 765 is capable of performing 15 different commands. Each command is initiated by a multi-byte transfer from the processor, and the result after execution of the command may also be a multi-byte transfer back to the processor. Because of this multi-byte interchange of information between the $\mu$ PD765 and the processor, it is convenient to consider each command as consisting of three phases:

| Command Phase: | The FDC receives all information required to perform a particular <br> operation from the processor. |
| :--- | :--- |
| Execution Phase: | The FDC performs the operation it was instructed to do. |
| Result Phase: | After completion of the operation, status and other housekeeping <br> information are made available to the processor. |

INSTRUCTION SET


INSTRUCTION SET (1) (2) (CONT.)


[^2]| SYMBOL | NAME | DESCRIPTION |
| :---: | :---: | :---: |
| A0 | Address Line 0 | $A_{0}$ controls selection of Main Status Register ( $A_{0}=0$ ) or Data Register ( $A_{0}=1$ ) |
| c | Cylinder Number | C stands for the current/selected Cylinder (track) number 0 through 76 of the medium. |
| D | Data | D stands for the data pattern which is going to be written into a Sector. |
| $D_{7} \cdot D_{0}$ | Data Bus | 8-bit Data Bus, where $D_{7}$ stands for a most significant bit, and $D_{0}$ stands for a least significant bit. |
| DTL | Data Length | When $N$ is defined as 00 , DTL stands for the data length which users are going to read out or write into the Sector. |
| EOT | End of Track | EOT stands for the final Sector number on a Cylinder. During Read or Write operation FDC will stop date transfer after a sector \# equal to EOT. |
| GPL | Gap Length | GPL stands for the length of Gap 3. During Read/Write commands this value determines the number of bytes that VCOs will stay low after two CRC bytes. During Format command it determines the size of Gap 3. |
| H | Head Address | H stands for head number 0 or 1 , as specified in ID field. |
| HD | Head | HD stands for a selected head number 0 or 1 and controls the polarity of pin 27 . $(H=H D$ in all command words.) |
| HLT | Head Load Time | HLT stands for the head load time in the FDD (2 to $\mathbf{2 5 4} \mathbf{~ m s}$ in 2 ms increments). |
| HUT | Head Unload Time | HUT stands for the head unload time after a read or write operation has occurred ( $\mathbf{1 6}$ to $\mathbf{2 4 0} \mathbf{~ m s}$ in 16 ms increments). |
| MF | FM or MFM Mode | If MF is low, FM mode is selected, and if it is high, MFM mode is selected. |
| MT | Multi-Track | If MT is high, a multi-track operation is to be performed. If MT $=1$ after finishing Read/Write operation on side 0 FDC will automatically start searching for sector 1 on side 1 . |

COMMAND SYMBOL DESCRIPTION


| SYMBOL | NAME | DESCRIPTION |
| :--- | :--- | :--- |
| N | Number | $\begin{array}{l}\text { N stands for the number of data bytes } \\ \text { written in a Sector. }\end{array}$ |
| NCN | New Cylinder Number | $\begin{array}{l}\text { NCN stands for a new Cylinder number, } \\ \text { which is going to be reached as a result of the } \\ \text { Seek operation. Desired position of Head. }\end{array}$ |
| ND | Non-DMA Mode | ND stands for operation in the Non-DMA Mode. |
| PCN | $\begin{array}{l}\text { Present Cylinder } \\ \text { Number }\end{array}$ | $\begin{array}{l}\text { PCN stands for the Cylinder number at the com- } \\ \text { pletion of SENSE INTERRUPT STATUS } \\ \text { Command. Position of Head at present time. }\end{array}$ |
| R | Record | $\begin{array}{l}\text { R stands for the Sector number, which will } \\ \text { be read or written. }\end{array}$ |
| SC | Read/Write | $\begin{array}{l}\text { R/W stands for either Read (R) or Write (W) } \\ \text { signal. }\end{array}$ |
| SK | Skip | $\begin{array}{l}\text { SC indicates the number of Sectors per } \\ \text { Cylinder. }\end{array}$ |
| SRT | Step Rate Time | $\begin{array}{l}\text { SK stands for Skip Deleted Data Address Mark. }\end{array}$ |
| SRT stands for the Stepping Rate for the FDD. |  |  |
| (1 to 16 ms in 1 ms increments.) Stepping Rate |  |  |
| applies to all drives, (F = 1 ms, E = 2 ms, etc.). |  |  |$\}$

PROCESSOR INTERFACE During Command or Result Phases the Main Status Register (described earlier) must be read by the processor before each byte of information is written into or read from the Data Register. After each byte of data read or written to Data Register, CPU should wait tor $12 \mu$ s before reading MSR. Bits D6 and D7 in the Main Status Register must be in a 0 and 1 state, respectively, before each byte of the command word may be written into the $\mu$ PD 765 . Many of the commands require multiple bytes, and as a result the Main Status Register must be read prior to each byte transfer to the $\mu$ PD765. On the other hand, during the Result Phase, D6 and D7 in the Main Status Register must both be 1's ( $D 6=1$ and $D 7=1$ ) before reading each byte from the Data Register. Note, this reading of the Main Status Register before each byte transfer to the $\mu$ PD 765 is required in only the Command and Result Phases, and NOT during the Execution Phase.

During the Execution Phase, the Main Status Register need not be read. If the $\mu$ PD765 is in the NON-DMA Mode, then the receipt of each data byte (if $\mu$ PDi 65 is reading data from FDD) is indicated by an Interrupt signal on pin 18 (INT $=1$ ). The generation of a Read signal ( $\overline{\mathrm{RD}}=0$ ) or Write signal $(\overline{\mathrm{WR}}=0)$ will reset the Interrupt as well as output tne Data onto the Data Bus. If the processor cannot handle Interrupts fast enough (every $13 \mu \mathrm{~s}$ ) for MFM and $27 \mu \mathrm{~s}$ for FM mode, then it may poll the Main Status Register and then bit D7 (RQM) functions just like the Interrupt signal. If a Write Command is in process then the WR signal performs the reset to the Interrupt signal.

If the $\mu$ PD765 is in the DMA Mode, no Interrupts are generated during the Execution Phase. The $\mu$ PD 765 generates DRQ's (DMA Requests) when each byte of data is available. The DMA Controller responds to this request with both a $\overline{\mathrm{DACK}}=0$ (DMA Acknowledge) and a $\overline{R D}=0$ (Read signal). When the DMA Acknowledge signal goes low ( $\overline{\mathrm{DACK}}=0$ ) then the DMA Request is reset ( $\mathrm{DRQ}=0$ ). If a Write Command has been programmed then a $\overline{W R}$ signal will appear instead of $\overline{R D}$. After the Execution Phase has been completed (Terminal Count has occurred) or EOT sector was read/ written, then an Interrupt will occur (INT = 1). This signifies the beginning of the Result Phase. When the first byte of data is read during the Result Phase, the Interrupt is automatically reset (INT $=0$ ).
It is important to note that during the Result Phase all bytes shown in the Command Table must pe read. The Read Data Command, for example has seven bytes of data in the Result Phase. All seven bytes must be read in order to successfully complete the Read Data Command. The $\mu$ PD765 will not accept a new command until all seven bytes have been read. Other commands may require fewer bytes to be read during the Result Phase.
The $\mu$ PD765 contains five Status Registers. The Main Status Register mentioned above may be read by the processor at any time. The other four Status Registers (ST0, ST1, ST2, and ST3) are only available during the Result Phase, and may be read only after completing a command. The particular command which has been executed determines how many of the Status Registers will be read.
The bytes of data which are sent to the $\mu$ PD 765 to form the Command Phase, and are read out of the $\mu$ PD765 in the Result Phase, must occur in the order shown in the Command Table. That is, the Command Code must be sent first and the other bytes sent in the prescribed sequence. No foreshortening of the Command or Result Phases are allowed. After the last byte of data in the Command Phase is sent to the $\mu$ PD765, the Execution Phase automatically starts. In a similar fashion, when the last byte of data is read out in the Result Phase, the command is automatically ended and the $\mu$ PD765 is ready for a new command.
After the Specify command has been sent to the $\mu$ PD765, the Unit Select line USO and US1 will automatically go into a polling mode. In between commands (and between step pulses in the SEEK command) the $\mu$ PD765 polls all four FDD's looking for a change in the Ready line from any of the drives. If the Ready line changes state (usually due to a door opening or closing) then the $\mu$ PD765 will generate an interrupt. When Status Register 0 (STO) is read (after Sense interrupt Status is issued), Not Ready (NR) will be indicated. The polling of the Ready line by the $\mu$ PD765 occurs continuously between commands, thus notifying the processor which drives are on or off line. Each drive is polled every 1.024 ms except during the Read/Write commands.

## READ DATA

A set of nine (9) byte words are required to place the FDC into the Read Data Mode. After the Read Data command has been issued the FDC loads the head (if it is in the unloaded state), waits the specified head settling time (defined in the Specify Command), and begins reading ID Address Marks and ID fields. When the current sector number (" $\mathrm{R}^{\prime \prime}$ ) stored in the ID Register (IDR) compares with the sector number read off the diskette, then the FDC outputs data (from the data field) byte-to-byte to the main system via the data bus.
After completion of the read operation from the current sector, the Sector Number is incremented by one, and the data from the next sector is read and output on the data bus. This continuous read function is called a "Multi-Sector Read Operation." The Read Data Command may be terminated by the receipt of a Terminal Count signal. TC should be issued at the same time that the $\overline{\text { DACK }}$ for the last byte of data is sent. Upon receipt of this signal, the FDC stops outputting data to the processor, but will continue to read data from the current sector, check CRC (Cyclic Redundancy Count) bytes, and then at the end of the sector terminate the Read Data Command.
The amount of data which can be handled with a single command to the FDC depends upon MT (multitrack), MF (MFM/FM), and N (Number of Bytes/Sector). Table 1 below shows the Transfer Capacity.

| Multi-Track MT | MFM/FM MF | Bytes/Sector N | Maximum Transfer Capacity (Bytes/Sector) (Number of Sectors) | Final Sector Read from Diskette |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 00 | $(128)(26)=3,328$ | 26 at Side 0 |
| 0 | 1 | 01 | $(256)(26)=6,656$ | or 26 at Side 1 |
| 1 | 0 | 00 | $(128)(52)=6,656$ | 26 at Side 1 |
| 1 | 1 | 01 | $(256)(52)=13,312$ |  |
| 0 | 0 | 01 | $(256)(15)=3,840$ | 15 at Side 0 |
| 0 | 1 | 02 | $(512)(15)=7,680$ | or 15 at Side 1 |
| 1 | 0 | 01 | $(256)(30)=7,680$ | 15 at Side 1 |
| 1 | 1 | 02 | $(512)(30)=15,360$ |  |
| 0 | 0 | 02 | $(512)(8)=4,096$ | 8 at Side 0 |
| 0 | 1 | 03 | $(1024)(8)=8,192$ | or 8 at Side 1 |
| 1 | 0 | 02 | $(512)(16)=8,192$ | 8 at Side 1 |
| 1 | 1 | 03 | $(1024)(16)=16,384$ |  |

Table 1. Transfer Capacity
The "multi-track" function (MT) allows the FDC to read data from both sides of the diskette. For a particular cylinder, data will be transferred starting at Sector 1 , Side 0 and completing at Sector L, Side (Sector $L=$ last sector on the side). Note, this function pertains to only one cylinder (the same track) on each side of the diskette.
When $N=0$, then DTL defines the data length which the FDC must treat as a sector. If DTL is smaller than the actual data length in a Sector, the data beyond DTL in the Sector, is not sent to the Data Bus. The FDC reads (internally) the complete Sector performing the CRC check, and depending upon the manner of command termination, may perform a Multi-Sector Read Operation. When $N$ is non-zero, then DTL has no meaning and should be set to FF Hexidecimal.

At the completion of the Read Data Command, the head is not unloaded until after Head Unload Time Interval (specified in the Specify Command) has elapsed. If the processor issues another command before the head unloads then the head settling time may be saved between subsequent reads. This time out is particularly valuable when a diskette is copied from one drive to another.
If the FDC detects the Index Hole twice without finding the right sector, (indicated in "R"), then the FDC sets the ND (No Data) flag in Status Register 1 to a 1 (high), and terminates the Read Data Command. (Status Register 0 also has bits 7 and $\mathbf{6}$ set to 0 and 1 respectively.)

After reading the ID and Data Fields in each sector, the FDC checks the CRC bytes. If a read error is detected (incorrect CRC in ID field), the FDC sets the DE (Data Error) flag in Status Register 1 to a 1 (high), and if a CRC error occurs in the Data Field the FDC also sets the DD (Data Error in Data Field) flag in Status Register 2 to a 1 (high), and terminates the Read Data Command. (Status Register 0 also has bits 7 and 0 set to 0 and 1 respectively.)

If the FDC reads a Deleted Data Address Mark off the diskette, and the SK bit (bit D5 in the first Command Word) is not set ( $S K=0$ ), then the FDC sets the CM (Control Mark) flag in Status Register 2 to a 1 (high), and terminates the Read Data Command, after reading all the data in the Sector. If SK $=1$, the FDC skips the sector with the Deleted Data Address Mark and reads the next sector. The CRC bits in the deleted data field are not checked when $S K=1$.

During disk data transfers between the FDC and the processor, via the data bus, the FDC must be serviced by the processor every $27 \mu \mathrm{~s}$ in the FM Mode, and every $13 \mu \mathrm{~s}$ in the MFM Mode, or the FDC sets the OR (Over Run) flag in Status Register 1 to a 1 (high), and terminates the Read Data Command.

If the processor terminates a read (or write) operation in the FDC, then the ID Information in the Result Phase is dependent upon the state of the MT bit and EOT byte. Table 2 shows the values for $C, H, R$, and N , when the processor terminates the Command.

| MT | HD | Final Sector Transferred to Processor | ID Information at Result Phase |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | C | H | R | N |
| 0 | 0 | Less than EOT | NC | NC | $R+1$ | NC |
|  | 0 | Equal to EOT | C + 1 | NC | $R=01$ | NC |
|  | 1 | Less than EOT | NC | NC | $R+1$ | NC |
|  | 1 | Equal to EOT | C + 1 | NC | $R=01$ | NC |
| 1 | 0 | Less than EOT | NC | NC | R + 1 | NC |
|  | 0 | Equal to EOT | NC | LSB | $R=01$ | NC |
|  | 1 | Less than EOT | NC | NC | $R+1$ | NC |
|  | 1 | Equal to EOT | C + 1 | LSB | $R=01$ | NC |

Notes: 1 NC (No Change): The same value as the one at the beginning of command execution.
2 LSB (Least Significant Bit): The least significant bit of H is complemented.

## WRITE DATA

A set of nine (9) bytes are required to set the FDC into the Write Data mode. After the Write Data command has been issued the FDC loads the head (if it is in the unloaded state), waits the specified Head Settling Time (defined in the Specify Command), and begins reading ID Fields. When all four bytes loaded during the command (C, H, R, N) match the four bytes of the ID field from the diskette, the FDC takes data from the processor byte-by-byte via the data bus, and outputs it to the FDD.

After writing data into the current sector, the Sector Number stored in " $R$ " is incremented by one, and the next data field is written into. The FDC continues this "Multi-Sector Write Operation" until the issuance of a Terminal Count signal. If a Terminal Count signal is sent to the FDC it continues writing into the current sector to complete the data field. If the Terminal Count signal is received while a data field is being written then the remainder of the data field is filled with 00 (zeros).

The FDC reads the ID field of each sector and checks the CRC bytes. If the FDC detects a read error (incorrect CRC) in one of the ID Fields, it sets the DE (Data Error) riag of Status Register 1 to a 1 (high), and terminates the Write Data Command. (Status Register 0 also has bits $7^{\prime}$ and 6 set to 0 and 1 respectively.) The Write Command operates in much the same manner as the Read Command. The following items are the same, and one should refer to the Read Data Command for details:

- Transfer Capacity
- Head Unload Time Interval
- EN (End of Cylinder) Flag
- ID Information when the processor terminates command (see Table 2)
- ND (No Data) Flag
- Definition of DTL when $N=0$ and when $N \neq 0$

In the Write Data mode, data transfers between the processor and FDC, via the Data Bus, must occur every $27 \mu$ s in the FM mode, and every $13 \mu \mathrm{~s}$ in the MFM mode. If the time interval between data transfers is longer than this then the FDC sets the OR (Over Run) flag in Status Register 1 to a 1 (high), and terminates the Write Data Command. (Status Register 0 also has bit 7 and $\mathbf{6}$ set to 0 and 1 respectively.)

## WRITE DELETED DATA

This command is the same as the Write Data Command except a Deleted Data Address Mark is written at the beginning of the Data Field instead of the normal Data Address Mark.

## READ DELETED DATA

This command is the same as the Read Data Command except that when the FDC detects a Data Address Mark at the beginning of a Data Field (and SK $=0$ (low), it will read all the data in the sector and set the CM flag in Status Register 2 to a 1 (high), and then terminate the command. If SK = 1, then the FDC skips the sector with the Data Address Mark and reads the next sector.

## READ A TRACK

This command is similar to READ DATA Command except that this is a continuous READ operation where the entire data field from each of the sectors are read. Immediately after encountering the INDEX HOLE, the FDC starts reading all data fields on the track, as continuous blocks of data. If the FDC finds an error in the ID or DATA CRC check bytes, it continues to read data from the track. The FDC compares the ID information read from each sector with the value stored in the IDR, and sets the iND flag of Status Register 1 to a 1 (high) if there is no comparison. Multi-track or skip operations are not allowed with this command.

## FUNCTIONAL DESCRIPTION OF COMMANDS (CONT.)

This command terminates when number of sectors read is equal to'EOT. If the FDC does not find an ID Address Mark on the diskette after it encounters the INDEX HOLE for the second time, then it sets the MA (missing address mark) flag in Status Register 1 to a 1 (high), and terminates the command. (Status Register 0 has bits 7 and 6 set to 0 and 1 respectively.)

## READ ID

The READ ID Command is used to give the present position of the recording head. The FDC stores the values from the first ID field it is able to read. If no proper ID Address Mark is found on the diskette, before the INDEX HOLE is encountered for the second time then the MA (Missing Address Mark) flag in Status Register 1 is set to a 1 (high), and if no data is found then the ND (No Data) flag is also set in Status Register 1 to a 1 (high). The command is then terminated with Bits 7 and 6 in Status Register 0 set to 0 and 1 respectively. During this command there is no data transfer between FDC and the CPU except during the result phase.

## FORMAT A TRACK

The Format Command allows an entire track to be formatted. After the INDEX HOLE is detected, Data is written on the Diskette; Gaps, Address Marks, ID Fields and Data Fields, all per the IBM System 34 (Double Density) or System 3740 (Single Density) Format are recorded. The particular format which will be written is controlled by the values programmed into $N$ (number of bytes/sector), SC (sectors/cylinder), GPL (Gap Length), and D (Data Pattern) which are supplied by the processor during the Command Phase. The Data Field is filled with the Byte of data stored in D. The ID Field for each sector is supplied by the processor that is, four data requests per sector are made by the FDC for C (Cylinder Number), H (Head Number), $R$ (Sector Number) and $N$ (Number of Bytes/Sector). This allows the diskette to be formatted with nonsequential sector numbers, if desired.

The processor must send new values for $\mathrm{C}, \mathrm{H}, \mathrm{R}$, and N to the $\mu \mathrm{PD} 765$ for each sector on the track. If FDC is set for DMA mode, it will issue 4 DMA requests per sector. If it is set for interrupt mode, it will issue four interrupts per sector and the processor must supply $\mathrm{C}, \mathrm{H}, \mathrm{R}$ and N load for each sector. The contents of the $R$ register is incremented by one after each sector is formatted, thus, the $R$ register contains a value of $R$ when it is read during the Result Phase. This incrementing and formating continues for the whole track until the FDC encounters the INDEX HOLE for the second time; whereupon it terminates the command
If a FAULT signal is received from the FDD at the end of a write operation, then the FDC sets the EC flag of Status Register 0 to a 1 (high), and terminates the command after setting bits 7 and 6 of Status Register 0 to 0 and 1 respectively. Also the loss of a READY signal at the beginning of a command execution phase causes bits 7 and 6 of Status Register 0 to be set to 0 and 1 respectively.
Table 3 shows the relationship between N, SC, and GPL for various sector sizes
51⁄" MINI FLOPPY

| FORMAT | SECTOR SIZE | N | SC | GPL (1) | GPL (2) | SECTOR SIZE | N | SC | GPL (1) | GPL (2) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FM Mode | 128 bytes/Sector | 00 | 1 A | 07 | 1 B | 128 bytes/Sector | 00 | 12 | 07 | 09 |
|  | 256 | 01 | OF | OE | 2A | 128 | 00 | 10 | 10 | 19 |
|  | 512 | 02 | 08 | 1 B | 3A | 256 | 01 | 08 | 18 | 30 |
|  | 1024 bytes/Sector | 03 | 04 | 47 | 8A | 512 | 02 | 04 | 46 | 87 |
|  | 2048 | 04 | 02 | C8 | FF | 1024 | 03 | 02 | C8 | FF |
|  | 4096 | 05 | 01 | C8 | FF | 2048 | 04 | 01 | C8 | FF |
| MFM Mode | 256 | 01 | 1 A | OE | 36 | 256 | 01 | 12 | 0 A | OC |
|  | 512 | 02 | OF | 1 B | 54 | 256 | 01 | 10 | 20 | 32 |
|  | 1024 | 03 | 08 | 35 | 74 | 512 | 02 | 08 | 2 A | 50 |
|  | 2048 | 04 | 04 | 99 | FF | 1024 | 03 | 04 | 80 | FO |
|  | 4096 | 05 | 02 | C8 | FF | 2048 | 04 | 02 | C8 | FF |
|  | 8192 | 06 | 01 | C8 | FF | 4096 | 05 | 01 | C8 | FF |

Table 3
Note: (1) Suggested values of GPL in Read or Write Commands to avoid splice point between data field and ID field of contiguous sections.
(2) Suggested values of GPL in for mat command.
(3) In MFM mode FDC can not perform a read/write/format operation with 128 bytes/sector. ( $N=00$ )
(4) All the values are hexidecimal.

## SCAN COMMANDS

The SCAN Commands allow data which is being read from the diskette to be compared against data which s being supplied from the main system. The FDC compares the data on a byte-by-byte basis, and looks for sector of data which meets the conditions of $D_{F D D}=D_{\text {Processor }}, D_{F D D} \leqslant D_{\text {Processor }}$, or $D_{F D D} \geqslant$ Dprocessor. The hexidicemial byte of FF either from memory or from FDD can be used as a mask byte because it always meet the condition of the compare. Ones complement arithmetic is used for comparison FF = largest number, $00=$ smallest number). After a whole sector of data is compared, if the conditions are not met, the sector number is incremental ( $R+S T P \rightarrow R$ ), and the scan operation is continued. The scan operation continues until one of the following conditions occur; the conditions for scan are met (equal ow, or high), the last sector on the track is reached (EOT), or the terminal count signal is received.

If the conditions for scan are met then the FDC sets the SH (Scan Hit) flag of Status Register 2 to a 1 (high), and terminates the Scan Command. If the conditions for scan are not met between the starting sector (as specified by R) and the last sector on the cylinder (EOT), then the FDC sets the SN (Scan Not Satisfied) flag of Status Register 2 to a 1 (high), and terminates the Scan Command. The receipt of a TERMINAL COUNT signal from the Processor or DMA Controller during the scan operation will cause the FDC to complete the comparison of the particular byte which is in process, and then to terminate the com mand. Table 4 shows the status of bits SH and SN under various conditions of SCAN.

| COMMAND | STATUS REGISTER 2 |  | COMMENTS |
| :--- | :---: | :---: | :---: |
|  | BIT 2 $=$ SN | BIT 3 $=$ SH |  |
| Scan Equal | 0 | 1 | DFDD $=$ DProcessor |
|  | 1 | 0 |  |
|  | 0 | 1 | DFDD $=$ DProcessor |
|  | 0 | 0 | DFDD $<$ DProcessor |
|  | 1 | 0 | DFDD $>$ Dprocessor |
| Scan Higi or Equal | 0 | 1 | DFDD $=$ DProcessor |
|  | 0 | 0 | DFDD $>$ Dprocessor |
|  | 1 | 0 | DFDD $<$ DProcessor |

Table 4

If the FDC encounters a Deleted Data Address Mark on one of the sectors (and SK $=0$ ), then it regarus the sector as the last sector on the cylinder, sets CM (Control Mark) flag of Status Register 2 to a 1 (high) and terminates the command. If SK = 1, the FDC skips the sector with the Deleted Address Mark, and reads the next sector. In the second case (SK = 1), the FDC sets the CM (Control Mark) flag of Status Register 2 to a 1 (high) in order to show that a Deleted Sector had been encountered.
When either the STP (contiguous sectors $=01$, or alternate sectors $=02$ sectors are read) or the MT (Multi Track) are programmed, it is necessary to remember that the last sector on the track must be read. For example, if $\mathrm{STP}=02, \mathrm{MT}=0$, the sectors are numbered sequentially 1 through 26 , and we start the Scan Command at sector 21 ; the following will happen. Sectors 21,23 , and 25 will be read, then the next sectol (26) will be skipped and the Index Hole will be encountered before the EOT value of 26 can be read. This will result in an abnormal termination of the command. If the EOT had been set at 25 or the scanning started at sector 20, then the Scan Command would be completed in a normal manner.
During the Scan Command data is supplied by either the processor or DMA Controller for comparison against the data read from the diskette. In order to avoid having the OR (Over Run) flag set in Status Register 1 , it is necessary to have the data available in less than $27 \mu \mathrm{~s}$ (FM Mode) or $13 \mu \mathrm{~s}$ (MFM Mode). If an Overrun occurs the FDC ends the command with bits 7 and 6 of Status Fiegister 0 set to 0 and 1, respectively.

SEEK
The read/write head within the FDD is moved from cylinder to cylinder under control of the Seek Command. FDC has four independent Present Cylinder Registers for each drive. They are clear only after Recalibrate command. The FDC compares the PCN (Present Cylinder Number) which is the current head

## FUNCTIONAL DESCRIPTION OF COMMANDS (CONT.)

## FUNCTIONAL DESCRIPTION OF COMMANDS (CONT.)

position with the NCN (New Cylinder Number), and if there is a difference performs the following operation:

PCN < NCN: Direction signal to FDD set to a 1 (high), and Step Pulses are issued. (Step In.)
PCN > NCN: Direction signal to FDD set to a 0 (low), and Step Pulses are issued. (Step Out.)
The rate at which Step Pulses are issued is controlled by SRT (Stepping Rate Time) in the SPECIFY Command. After each Step Pulse is issued NCN is compared against PCN, and when NCN $=$ PCN, then the SE (Seek End) flag is set in Status Register 0 to a 1 (high), and the command is terminated. At this point FDC interrupt goes high. Bits $\mathrm{DB}_{0}-\mathrm{DB}_{3}$ in Main Status Register are set during seek operation and are cleared by Sense Interrupt Status command.
During the Command Phase of the Seek operation the FDC is in the FDC BUSY state, but during the Execution Phase it is in the NON BUSY state. While the FDC is in the NON BUSY state, another Seek Command may be issued, and in this manner parallel seek operations may be done on up to 4 Drives at once. No other command could be issued for as long as FDC is in process of sending Step Pulses to any drive.
If an FDD is in a NOT READY state at the beginning of the command execution phase or during the seek operation, then the NR (NOT READY) flag is set in Status Register 0 to a 1 (high), and the command is terminated after bits 7 and 6 of Status Register 0 are set to 0 and 1 respectively.
If the time to write 3 bytes of seek command exceeds $150 \mu \mathrm{~s}$, the timing between first two Step Pulses may be shorter than set in the Specify command by as much as 1 ms

## RECALIBRATE

The function of this command is to retract the read/write head within the FDD to the Track 0 position. The FDC clears the contents of the PCN counter, and checks the status of the Track 0 signal from the FDD. As long as the Track 0 signal is low, the Direction signal remains $\mathbf{O}$ (low) and Step Pulses are issued. When the Track 0 signal goes high, the SE (SEEK END) flag in Status Register 0 is set to a 1 (high) and the command is terminated. If the Track 0 signal is still low after 77 Step Pulse have been issued, the FDC sets the SE (SEEK END) and EC (EQUIPMENT CHECK) flags of Status Register 0 to both is (highs), and terminates the command after bits 7 and 6 of Status Register 0 is set to 0 and 1 respectively.
The ability to do overlap RECALIBRATE Commands to multiple FDD 5 and the loss of the READY signal as described in the SEEK Command, also applies to the RECALIBRATE Command.

## SENSE INTERRUPT STATUS

An Interrupt signal is generated by the FDC for one of the following reasons:

## 1. Upon entering the Result Phase of:

a. Read Data Command
e. Write Data Command
b. Read a Track Command
f. Format a Cylinder Command
c. Read ID Command
g. Write Deleted Data Command
d. Read Deleted Data Command
h. Scan Commands
2. Ready Line of FDD changes state
3. End of Seek or Recalibrate Command
4. During Execution Phase in the NON-DMA Mode

Interrupts caused by reasons 1 and 4 above occur during normal command operations and are easily dis cernible by the processor. During an execution phase in NON-DMA Mode, DB5 in Main Status Register is high. Upon entering Result Phase this bit gets clear. Reason 1 and 4 does not require Sense Interrupt Status command. The interrupt is cleared by reading/writing data to FDC. Interrupts caused by reasons 2 and 3 above may be uniquely identified with the aid of the Sense Interrupt Status Command. This command when issued resets the interrupt signal and via bits 5, 6, and 7 of Status Register 0 identifies he cause of the interrupt.

| SEEK END <br> BIT 5 | INTERRUPT CODE |  | CAUSE |
| :---: | :---: | :---: | :---: |
|  | BIT 6 | BIT 7 |  |
| 0 | 1 | 1 | Ready Line changed state, either polarity |
| 1 | 0 | 0 |  |
| 1 | 1 | 0 | Abnormal Termination of Seek or Recalibrate Command |

Table 5
Neither the Seek or Recalibrate Command have a Result Phase. Therefore, it is mandatory to use the Sense interrupt Status Command after these commands to effectively terminate them and to provide verification o where the head is positioned (PCN).
Issuing Sense Interrupt Status Command without interrupt pending is treated as an invalid command

## SPECIFY

The Specify Command sets the initial values for each of the three internal timers. The HUT (Head Unload Time) defines the time from the end of the Execution Phase of one of the Read/Write Commands to the head unload state. This timer is programmable from 16 to 240 ms in increments of $16 \mathrm{~ms} 101=16 \mathrm{~ms}, 02=32 \mathrm{~ms}$.... OF $=$ 240 ms ). The SRT (Step Rate Time) defines the time interval between adjacent step pulses. This timer is programmable from 1 to 16 ms in increments of 1 ms ( $F=1 \mathrm{~ms}, E=2 \mathrm{~ms}, \mathrm{D}=3 \mathrm{~ms}$, etc.). The HLT (Head Load Time) defines the time between when the Head Load signal goes high and when the Read/Write operation starts. This timer is programmable from 2 to 254 ms in increments of $2 \mathrm{~ms} 101=2 \mathrm{~ms}, 02=\mathbf{4 m s}, 03=6 \mathrm{~ms}$... 7F $=$ 254 ms ).
The time intervals mentioned above are a direct function of the clock (CLK on pin 19). Times indicated above are for an $\mathbf{8} \mathbf{~ M H z}$ clock, if the clock was reduced to $\mathbf{4} \mathbf{M H z}$ (mini-floppy application) then all time intervals are increased by a factor of 2 .
The choice of DMA or NON-DMA operation is made by the ND (NON-DMA) bit. When this bit is high (ND $=1$ the NON-DMA mode is selected, and when ND $=0$ the DMA mode is selected.

## SENSE DRIVE STATUS

This command may be used by the processor whenever it wishes to obtain the status of the FDDs. Status Register 3 contains the Drive Status information stored internally in FDC registers.

## INVALID

If an invalid command is sent to the FDC (a command not defined above), then the FDC will terminate the command after bits 7 and 6 of Status Register 0 are set to 1 and 0 respectively. No interrupt is generated by the $\mu$ PD765 during this condition. Bit 6 and bit 7 (DIO and RQM) in the Main Status Register are both high (" 1 ") indicating to the processor that the $\mu$ PD765 is in the Result Phase and the contents of Status Register 0 (STO) must be read. When the processor reads Status Register $\mathbf{0}$ it will find a $\mathbf{8 0}$ hex indicating an invalid command was received.
A Sense Interrupt Status Command must be sent after a Seek or Recalibrate Interrupt, otherwise the FDC will consider the next command to be an Invalid Command.
In some applications the user may wish to use this command as a No-Op command, to place the FDC in a standby or no operation state.

STATUS REGISTER IDENTIFICATION

| BIT |  |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NO. | NAME | SYMBOL |  |
| STATUS REGISTER 0 |  |  |  |
| $\mathrm{D}_{6}$ | Interrupt Code | IC | $D_{7}=0 \text { and } D_{6}=0$ <br> Normal Termination of Command, (NT). Command was completed and properly executed. |
|  |  |  | $D_{7}=0 \text { and } D_{6}=1$ <br> Abnormal Termination of Command, (AT). <br> Execution of Command was started, but was not successfully completed. |
|  |  |  | $\mathrm{D}_{7}=1 \text { and } \mathrm{D}_{6}=0$ <br> Invalid Command issue, (IC). Command which was issued was never started. |
|  |  |  | $\mathrm{D}_{7}=1$ and $\mathrm{D}_{6}=1$ <br> Abnormal Termination because during command execution the ready signal from FDD changed state. |
| $\mathrm{D}_{5}$ | Seek End | SE | When the FDC completes the SEEK Command, this flag is set to 1 (high). |
| D4 | Equipment Check | EC | If a fault Signal is received from the FDD, or if the Track 0 Signal fails to occur after 77 Step Pulses (Recalibrate Command) then this flag is set. |
| $\mathrm{D}_{3}$ | Not Ready | NR | When the FDD is in the not-ready state and a read or write command is issued, th is flag is set. If a read or write command is issued to Side 1 of a single sided drive, then this flag is set. |
| $\mathrm{D}_{2}$ | Head Address | HD | This flag is used to indicate the state of the head at Interrupt. |
| $\mathrm{D}_{1}$ | Unit Select 1 | US 1 | These flags are used to indicate a Drive Unit. |
| $\mathrm{D}_{0}$ | Unit Select 0 | US 0 | Number at Interrupt. |
| STATUS REGISTER 1 |  |  |  |
| $\mathrm{D}_{7}$ | End of Cylinder | EN | When the FDC tries to access a Sector beyond the final Sector of a Cylinder, this flag is set. |
| $\mathrm{D}_{6}$ |  |  | Not used. This bit is always 0 (low). |
| D5 | Data Error | DE | When the FDC detects a CRC error in either the ID field or the data field, this flag is set. |
| $\mathrm{D}_{4}$ | Over Run | OR | If the FDC is not serviced by the main-systems during data transfers, with in a certain time interval, this flag is set. |
| D3 |  |  | Not used. This bit always 0 (low). |
| $\mathrm{D}_{2}$ | No Data | ND | During execution of READ DATA, WRITE DELETED DATA or SCAN Command, if the FDC cannot find the Sector specified in the IDR Register, this flag is set. |
|  |  |  | During executing the READ ID Command, if the FDC cannot read the ID field without an error, then this flag is set. |
|  |  |  | During the execution of the READ A Cylinder. Command, if the starting sector cannot be found, then this flag is set. |


| BIT |  |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NO. | NAME | SYMBOL |  |
| STATUS REGISTER 1 (CONT.) |  |  |  |
| D1 | Not Writable | NW | During execution of WRITE DATA, WRITE DELETED DATA or Format A Cylinder Command, if the FDC detects a write protect signal from the FDD, then this flag is set. |
| $\mathrm{D}_{0}$ | Missing Address Mark | MA | If the FDC cannot detect the ID Address Mark after encountering the index hole twice, then this flag is set. |
|  |  |  | If the FDC cannot detect the Data Address Mark or Deleted Data Address Mark, this flag is set. Also at the same time, the MD (Missing Address Mark in Data Field) of Status Register 2 is set. |
| STATUS REGISTER 2 |  |  |  |
| D7 |  |  | Not used. This bit is always 0 (low). |
| $\mathrm{D}_{6}$ | Control Mark | CM | During executing the READ DATA or SCAN Command, if the FDC encounters a Sector which contains a Deleted Data Address Mark, th is flag is set. |
| D5 | Data Error in Data Field | DD | If the FDC detects a CRC error in the data field then this flag is set. |
| $\mathrm{D}_{4}$ | Wrong Cylinder | WC | This bit is related with the ND bit, and when the contents of C on the medium is different from that stored in the IDR, this flag is set. |
| $\mathrm{D}_{3}$ | Scan Equal Hit | SH | During execution, the SCAN Command, if the condition of "equal" is satisfied, th is flag is set. |
| $\mathrm{D}_{2}$ | Scan Not Satisfied | SN | During executing the SCAN Command, if the FDC cannot find a Sector on the cylinder which meets the condition, then this flag is set. |
| D1 | Bad Cylinder | BC | This bit is related with the ND bit, and when the content of $C$ on the medium is different from that stored in the IDR and the content of $C$ is FF, then this flag is set. |
| $\mathrm{D}_{0}$ | Missing <br> Address Mark <br> in Data Field | MD | When data is read from the medium, if the FDC cannot find a Data Address Mark or Deleted Data Address Mark, then this flag is set. |
| STATUS REGISTER 3 |  |  |  |
| D7 | Fault | FT | This bit is used to indicate the status of the Fault signal from the FDD. |
| $\mathrm{D}_{6}$ | Write <br> Protected | WP | This bit is used to indicate the status of the Write Protected signal from the FDD. |
| D5 | Ready | RY | This bit is used to indicate the status of the Ready signal from the FDD. |
| D4 | Track 0 | т0 | This bit is used to indicate the status of the Track 0 signal from the FDD. |
| D3 | Two Side | TS | This bit is used to indicate the status of the Two Side signal from the FDD. |
| $\mathrm{D}_{2}$ | Head Address | HD | This bit is used to indicate the status of Side Select signal to the FDD. |
| D1 | Unit Select 1 | US 1 | This bit is used to indicate the status of the Unit Select 1 signal to the FDD. |
| Do | Unit Select 0 | US 0 | This bit is used to indicate the status of the Unit Select 0 signal to the FDD. |

It is suggested that you utilize the following applications notes:
(1) \#8 - for an example of an actual interface, as well as a "theoretical" data separator.
(2) \#10 - for a well documented example of a working phase lock loop.

## PACKAGE OUTLINE $\mu$ PD765AD



## PACKAGE OUTLINE $\mu$ PD765AC



| Plastic |  |  |
| :---: | :---: | :--- |
| ITEM | MILLIMETERS | INCHES |
| A | 51.5 MAX | 2.028 MAX |
| B | 1.62 | 0.064 |
| C | $2.54 \cdot 0.1$ | $0.10 \pm 0.004$ |
| D | $0.5 \pm 0.1$ | $0.019 \pm 0.004$ |
| E | 48.26 | 1.9 |
| F | 1.2 MIN | 0.047 MIN |
| G | 2.54 MIN | 0.10 MIN |
| H | 0.5 MIN | 0.019 MIN |
| I | 5.22 MAX | 0.206 MAX |
| J | 5.72 MAX | 0.225 MAX |
| K | 15.24 | 0.600 |
| L | 13.2 | 0.520 |
| M | $0.25+0.1$ | $0.010+0.004$ |
|  | 0.05 |  |

# PRELIMINARY <br> GRAPHICS DISPLAY CONTROLLER 

## Description

The $\mu$ PD7220 Graphics Display Controller (GDC) is an intelligent microprocessor peripheral designed to be the heart of a high-performance raster-scan computer graphics and character display system. Positioned between the video display memory and the microprocessor bus, the GDC performs the tasks needed to generate the raster display and manage the display memory. Processor software overhead is minimized by the GDC's sophisticated instruction set, graphics figure drawing, and DMA transfer capabilities. The display memory supported by the GDC can be configured in any number of formats and sizes up to 256 K 16 -bit words. The display can be zoomed and panned, while partitioned screen areas can be independently scrolled. With its light pen input and multiple controller capability, the GDC is ideal for advanced computer graphics applications.

## Features

$\square$ Microprocessor Interface
DMA transfers with 8257- or 8237-type controllers
FIFO Command Buffering
$\square$ Display Memory Interface
Up to 256 K words of 16 bits
Read-Modify-Write (RMW) Display Memory cycles in under 800ns
Dynamic RAM reresh cycles for nonaccessed memory

## $\square$ Light Pen Input

$\square$ External video synchronization mode
$\square$ Graphics Mode
Four megabit, bit-mapped display memory
$\square$ Character Mode:
8 K character code and attributes display memory
$\square$ Mixed Graphics and Characters Mode
64 K if all characters
1 megapixel if all graphics
$\square$ Graphics Capabilities
Figure drawing of lines, arc/circles, rectangles, and graphics character in 800 ns per pixel
Display 1024-by-1024 pixels with 4 planes of color or grayscale.
Two independently scrollable areas
$\square$ Character Capabilities:
Auto cursor advance
Four independently scrollable areas
Programmable cursor height
Characters per row: up to 256
Character rows per screen: up to 100
$\square$ Video Display Format
Zoom magnification factors of 1 to 16
Panning
Command-settable video raster parameters
$\square$ Technology
Single +5 volt, NMOS, 40 -pin DIP
$\square$ DMA Capability:
Bytes or word transfers
4 clock periods per byte transferred

## System Considerations

The GDC is designed to work with a general purpose microprocessor to implement a high-performance computer graphics system. Through the division of labor established by the GDC's design, each of the system components is used to the maximum extent through sixlevel hierarchy of simultaneous tasks. At the lowest level, the GDC generates the basic video raster timing, including sync and blanking signals. Partitioned areas on the screen and zooming are also accomplished at this level. At the next level, video display memory is modified during the figure drawing operations and data moves. Third, display memory addresses are calculated pixel by pixel as drawing progresses. Outside the GDC at the next level, preliminary calculations are done to prepare drawing parameters. At the fifth level, the picture must be represented as a list of graphics figures drawable by the GDC. Finally, this representation must be manipulated, stored, and communicated. By handling the first three levels, the GDC takes care of the high-speed and repetitive tasks required to implement a graphics system.

## GDC Components

The GDC block diagram illustrates how these tasks are accomplished.


## Microprocessor Bus Interface

Control of the GDC by the system microprocessor is
achieved through an 8 -bit bidirectional interface. The status register is readable at any time. Access to the FIFO buffer is coordinated through flags in the status register and operates independently of the various internal GDC operations, due to the separate data bus connecting the interface and the FIFO buffer.

## Command Processor

The contents of the FIFO are interpreted by the command processor. The command bytes are decoded, and the succeeding parameters are distributed to their proper destina-

Reprinted through courtesy of NEC Electronics, U.S.A., Inc.
NOTE: These manufacturer's specifications are provided for reference. The APC
may not use some of the functions described here.
tions within the GDC. The command processor yields to the bus interface when both access the FIFO simultaneously.

## DMA Control

The DMA control circuitry in the GDC coordinates transfers over the microprocessor interface when using an external DMA controller. The DMA Request and Acknowledge handshake lines directly interface with a $\mu$ PD8257 or $\mu$ PD8237 DMA controller, so that display data can be moved between the microprocessor memory and the display memory.

## Parameter RAM

The 16-byte RAM stores parameters that are used repetitively during the display and drawing processes. In character mode, this RAM holds four sets of partitioned display area parameters: in graphics mode, the drawing pattern and graphics character take the place of two of the sets of parameters.

## Video Sync Generator

Based on the clock input, the sync logic generates the raster timing signals for almost any interlaced, non-interlaced, or "repeat field" interlaced video format. The generator is programmed during the idle period following a reset. In video sync slave mode, it coordinates timing between multiple GDCs.

## Memory Timing Generator

The memory timing circuitry provides two memory cycle types: a two-clock period refresh cycle and the read-modify-write (RMW) cycle which takes four clock periods. The memory control signals needed to drive the display memory devices are easily generated from the GDC's ALE and DBIN outputs.

## Zoom \& Pan Controller

Based on the programmable zoom display factor and the display area entries in the parameter RAM, the zoom and pan controller determines when to advance to the next memory address for display refresh and when to go on to the next display area. A horizontal zoom is produced by slowing down the display refresh rate while maintaining the video sync rates. Vertical zoom is accomplished by repeatedly accessing each line a number of times equal to the horizontal repeat. Once the line count for a display area is exhausted, the controller accesses the starting address and line count of the next display area from the parameter RAM. The system microprocessor, by modifying a display area starting address, can pan in any direction, independent of the other display areas.

## Drawing Processor

The drawing processor contains the logic necessary to calculate the addresses and positions of the pixels of the various graphics figures. Given a starting point and the appropriate drawing parameters, the drawing processor needs no further assistance to complete the figure drawing

## Display Memory Controller

The display memory controller's tasks are numerous. Its primary purpose is to multiplex the address and data information in and out of the display memory. It also contains the 16 -bit logic unit used to modify the display memory contents during RMW cycles, the character mode line counter, and the refresh counter for dynamic RAMs. The memory controller apportions the video field time between the various types of cycles.

## Light Pen Deglitcher

Only if two rising edges on the light pen input occur at the same point during successive video fields are the pulses
accepted as a valid light pen detection. A status bit indicates to the system microprocessor that the light pen register contains a valid address.

## Programmer's View of GDC

The GDC occupies two addresses on the system microprocessor bus through which the GDC's status register and FIFO are accessed. Commands and parameters are written into the GDC's FIFO and are differentiated based on address bit A0. The status register or the FIFO can be read as selected by the address line.


GDC Microprocessor Bus Interface Registers
Commands to the GDC take the form of a command byte followed by a series of parameter bytes as needed for specifying the details of the command. The command processor decodes the commands, unpacts the parameters. loads them into the appropriate registers within the GDC and initiates the required operations.
The commands available in the GDC can be organized into five categories as described in the following section

## GDC Command Summary

## Video Control Commands

1. RESET: Resets the GDC to its idle state.
2. SYNC: Specifies the video display format.
3. VSYNC: Selects master or slave video synchronization mode.
4. CCHAR: Specifies the cursor and character row heights.
Display Control Commands
5. START: Ends Idle mode and unblanks the display.
6. BCTRL: Controls the blanking and unblanking of the display.
7. ZOOM: Specifies zoom factors for the display and graphics characters writing.
8. CURS: Sets the position of the cursor in display memory.
9. PRAM: Defines starting addresses and lengths of the display areas and specifies the eight bytes for the graphics character.
10. PITCH: Specifies the width of the $X$ dimension of display memory.
Drawing Control Commands
11. WDAT: Writes data words or bytes into display memory.
12. MASK: Sets the mask register contents.
13. FIGS: Specifies the parameters for the drawing processor.
14. FIGD: Draws the figure as specified above.
15. GCHRD: Draws the graphics character into display memory.

## Data Read Commands

1. RDAT: Reads data words or bytes from display memory.
2. CURD: Reads the cursor position.
3. LPRD: Reads the light pen address.

DMA Control Commands

1. DMAR: Requests a DMA read transfer.
2. DMAW: Requests a DMA write transfer


## Status Register (SR)

## Status Register Flags

## SR-7: Light Pen Detect

When this bit is set to 1 , the light pen address (LAD) register contains a deglitched value that the system microprocessor may read. This flag is reset after the 3-byte LAD is moved into the FIFO in response to the light pen read command.

## SR-6: Horizontal Blanking Active

A 1 value for this flag signifies that horizontal retrace blanking is currently underway.

## SR-5: Vertical Sync

Vertical retrace sync occurs while this flag is a 1 . The vertical sync flag coordinates display format modifying commands to the blanked interval surrounding vertical sync. This eliminates display disturbances

## SR-4: DMA Execute

This bit is a 1 during DMA data transfers.

## SR-3: Drawing in Progress

While the GDC is drawing a graphics figure, this status bit is a 1 .

## SR-2: FIFO Empty

This bit and the FIFO Full flag coordinate system microprocessor accesses with the GDC FIFO. When it is 1 , the Empty flag ensures that all the commands and parameters previously sent to the GDC have been processed.

## SR-1: FIFO Full

A 1 at this flag indicates a full FIFO in the GDC. A 0 ensures that there is room for at least one byte. This flag needs to be checked before each write into the GDC.

## SR-0: Data Ready

When this flag is a 1 , it indicates that a byte is available to be read by the system microprocessor. This bit must be tested before each read operation. It drops to a 0 while the data is transferred from the FIFO into the microprocessor interface data register.

## FIFO Operation \& Command Protocol

The first-in, first-out buffer (FIFO) in the GDC handles the command dialogue with the system microprocessor. This flow of information uses a half-duplex technique, in which the single 16 -location FIFO is used for both directions of data movement, one direction at a time. The FIFO's direction is controlled by the system microprocessor through the GDC's command set. The microprocessor coordinates these transfers by checking the appropriate status register bits
The command protocol used by the GDC requires the differentiation of the first byte of a command sequence from the succeeding bytes. This first byte contains the operation code and the remaining bytes carry parameters. Writing
into the GDC causes the FIFO to store a flag value alongside the data byte to signify whether the byte was written into the command or the parameter address. The command processor in the GDC tests this bit as it interprets the entries in the FIFO.
The receipt of a command byte by the command processor marks the end of any previous operation. The number of parameter bytes supplied with a command is cut short by the receipt of the next command byte. A read operation from the GDC to the microprocessor can be terminated at any time by the next command.

The FIFO changes direction under the control of the system microprocessor. Commands written into the GDC always put the FIFO into write mode if it wasn't in it already. If it was in read mode, any read data in the FIFO at the time of the turnaround is lost. Commands which require a GDC response, such as RDAT, CURD and LPRD, put the FIFO into read mode after the command is interpreted by the GDC's command processor. Any commands and parameters behind the read-evoking command are discarded when the FIFO direction is reversed

## Read-Modify-Write Cycle

Data transfers between the GDC and the display memory are accomplished using a read-modify-write (RMW) memory cycle. The four clock period timing of the RMW cycle is used to: 1) output the address, 2) read data from the memory, 3) modify the data, and 4) write the modified data back into the initially selected memory address. This type of memory cycle is used for all interactions with display memory including DMA transfers, except for the two clock period display and RAM refresh cycles.
The operations performed during the modify portion of the RMW cycle merit additional explanation. The circuitry in the GDC uses three main elements: the Pattern register, the Mask register, and the 16 -bit Logic Unit. The Pattern register holds the data pattern to be moved into memory. It is loaded by the WDAT command or, during drawing, from the parameter RAM. The Mask register contents determine which bits of the read data will be modified. Based on the contents of these registers, the Logic Unit performs the selected operations of REPLACE, COMPLEMENT, SET, or CLEAR on the data read from display memory.
The Pattern register contents are ANDed with the Mask register contents to enable the actual modification of the memory read data, on a bit-by-bit basis. For graphics drawing, one bit at a time from the Pattern register is combined with the Mask. When ANDed with the bit set to a 1 in the Mask register, the proper single pixel is modified by the Logic Unit. For the next pixel in the figure, the next bit in the Pattern register is selected and the Mask register bit is moved to identify the pixel's location within the word. The Execution word address pointer register, EAD, is also adjusted as required to address the word containing the next pixel.
In character mode, all of the bits in the Pattern register are used in parallel to form the respective bits of the modify data word. Since the bits of the character code word are used in parallel, unlike the one-bit-at-a-time graphics drawing process, this facility allows any or all of the bits in a memory word to be modified in one RMW memory cycle. The Mask register must be loaded with 1 s in the positions where modification is to be permitted.

The Mask register can be loaded in either of two ways. In graphics mode, the CURS command contains a four-bit dAD field to specify the dot address. The command processor converts this parameter into the one-of-16 format used in the Mask register for figure drawing. A full 16 bits can be loaded into the Mask register using the MASK command In addition to the character mode use mentioned above, the 16 -bit MASK load is convenient in graphics mode when all of the pixels of a word are to be set to the same value. The Logic Unit combines the data read from display memory, the Pattern Register, and the Mask register to generate the data to be written back into display memory. Any one of four operations can be selected: REPLACE, COMPLEMENT, CLEAR or SET. In each case, if the respective Mask bit is 0 , that particular bit of the read data is returned to memory unmodified. If the Mask bit is 1 , the modification is enabled. With the REPLACE operation, the modify data simply takes the place of the read data for modification enabled bits. For the other three operations, a 0 in the mod ify data allows the read data bit to be returned to memory. A 1 value causes the specified operation to be performed in the bit positions with set Mask bits.

## Figure Drawing

The GDC draws graphics figures at the rate of one pixel per read-modify-write (RMW) display memory cycle. These cycles take four clock periods to complete. At a clock frequency of 5 MHz , this is equal to 800 ns . During the RMW cycle the GDC simultaneously calculates the address and position of the next pixel to be drawn.
The graphics figure drawing process depends on the display memory addressing structure. Groups of 16 horizon tally adjacent pixels form the 16 -bit words which are handled by the GDC. Display memory is organized as a linearly addressed space of these words. Addressing of individual pixels is handled by the GDC s internal RMW logic
During the drawing process, the GDC finds the next pixel of the figure which is one of the eight nearest neighbors of the last pixel drawn. The GDC assigns each of these eight directions a number from 0 to 7 , starting with straight down and proceeding counterclockwise


Drawing Directions
Figure drawing requires the proper manipulation of the address and the pixel bit position according to the drawing direction to determine the next pixel of the figure. To move to the word above or below the current one, it is necessary to subtract or add the number of words per line in display memory. This parameter is called the pitch. To move to the word to either side, the Execute word address cursor, EAD must be incremented or decremented as the dot address pointer bit reaches the LSB or the MSB of the Mask register. To move to a pixel within the same word, it is necessary to rotate the dot address pointer register to the right or left.

The table below summarizes these operations for each direction.
Whole word drawing is useful for filling areas in memory with a single value. By setting the Mask register to all 1s with the MASK command, both the LSB and MSB of the

| DIR | OPERATIONS TO ADDRESS THE NEXT PIXEL |  |
| :---: | :---: | :---: |
| 000 | $E A D \cdot P \rightarrow E A D$ |  |
| 001 | $E A D \cdot P \rightarrow E A D$ |  |
|  | $\triangle A D(M S B) \quad 1$ EAD $\cdot 1 \rightarrow E A D$ | $a A D \rightarrow L R$ |
| 010 | OAD (MSB) 1 EAD $\cdot 1 \rightarrow E A D$ | $d A D \rightarrow L R$ |
| 011 | $E A D \quad P \rightarrow E A D$ |  |
|  | dAD (MSB) 1 EAD $\cdot \rightarrow$ EAD | $\Delta A D \rightarrow L R$ |
| 100 | EAD $P \rightarrow E A D$ |  |
| 101 | EAD P $\rightarrow$ EAD |  |
|  | dAD (LSB) 1 EAD $1 \rightarrow$ EAD | ${ }_{\text {d }} \mathrm{AD} \rightarrow \mathrm{RR}$ |
| 110 | dAD $/ 2$ SB 1 EAD $1 \rightarrow$ EAD | $d A D \rightarrow R R$ |
| $1{ }^{1}$ | $E A D \cdot P \rightarrow E A D$ |  |
|  | OAD 12 SB , 1 EAD $\cdot \rightarrow$ EAD | $d A D \rightarrow R R$ |

dAD will always be 1 heq s...
dAD will always be 1 , so that the EAD value will be incremented or decremented for each cycle regardless of direction. One RMW cycle will be able to effect all 16 bits of the word for any drawing type. One bit in the Pattern register is used per RMW cycle to write all the bits of the word to the same value. The next Pattern bit is used for the word, etc For the various figures, the effect of the initial direction upon the resulting drawing is shown below:


Note that during line drawing, the angle of the line may be anywhere within the shaded octant defined by the DIR value. Arc drawing starts in the direction initially specified by the DIR value and veers into an arc as drawing proceeds. An arc may be up to 45 degrees in length. DMA transfers are done on word boundaries only, and follow the arrows indicated in the table to find successive word addresses. The slanted paths for DMA transfers indicate the GDC changing both the $X$ and $Y$ components of the word address when moving to the next word. It does not follow a 45 degree diagonal path by pixels.

## Drawing Parameters

In preparation for graphics figure drawing, the GDC's Drawing Processor needs the figure type, direction and drawing parameters, the starting pixel address, and the pattern from the microprocessor. Once these are in place within the GDC, the Figure Draw command, FIGD, initiates the drawing operation. From that point on, the system microprocessor is not involved in the drawing process. The GDC Drawing Processor coordinates the RMW circuitry and address registers to draw the specified figure pixel by pixel.
The algorithms used by the processor for figure drawing are designed to optimize its drawing speed. To this end, the specific details about the figure to be drawn are reduced by the microprocessor to a form conducive to high-speed address calculations within the GDC. In this way the repetitive, pixel-by-pixel calculations can be done quickly, thereby minimizing the overall figure drawing time. The table below summarizes the parameters.

| DRAWING TYPE | DC | D | D2 | D1 | DM |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Itial V |  |  | 8 |  |  |
| Line | \|l| | $\|\Delta \mathrm{D}\|-\mid \mathrm{ta}$ | - | 2\| $\mid$ D ${ }^{\text {\| }}$ |  |
| Arc* | $\boldsymbol{s i n} 0+$ | r-1 | 2(r-1) | -1 | rsin |
| Rectangle |  | A-1 | B-1 |  |  |
| Area fill | B-1 |  |  |  |  |
| raphic Ch | B-1 | A | A |  |  |
| ad \& | W-1 |  |  |  |  |
| dmaw | D-1 | C-1 |  |  |  |
| DMAR | D-1 | C-1 | C-1)/2 |  |  |
| - initial values for the various parameters are loaded during the handling of the FIGS op code byte. <br> - Circles are drawn with 8 arce, each of which span $45^{\circ}$, so that $\sin 0=1 / \sqrt{2}$ and $\sin \theta=\mathbf{0}$. <br> ... Graphic characters are a special case of bit-map area filling in which $B$ and $A \leqslant 8$. <br> If $\mathrm{A}=\mathbf{8}$ there is no need to load D and D2. <br> Where: <br> $-1=$ all ONES value. <br> All numbers are shown in base 10 for convenience. The GDC accepts base 2 numbers ( 2 s complement notation where appropriate). <br> - = No parameter bytes sent to GDC for this parameter. <br> $\Delta l=$ The larger at $\Delta x$ or $\Delta y$. <br> $\Delta D=$ The smaller at $\Delta x$ or $\Delta y$. <br> $\mathbf{r}=$ Radius at curvature, in pixels. <br> $\phi=$ Angle from major axis to end at the arc. $\phi \leqslant 45^{\circ}$. <br> $\theta=$ Angle from major axis to start at the arc. $\theta \leqslant 45^{\circ}$. <br> $t=$ Round up to the next higher integer. <br> t = Round down to the next lower integer. <br> $A=$ Number of pixels in the initially specifled direction. <br> $B=$ Number of pixeis in the direction at right angles to the initially specified direction. <br> $\mathbf{w}=$ Number of words to be accessed. <br> C = Number of bytes to be transferred in the initially specified direction. (Two bytes per word if word transfer mode is selected). <br> D = Number of words to be accessed in the direction at right angles to the initially apecified direction. <br> DC = Drawing count parameter which is one less than the number of RMW cycles to be executed. <br> DM = Dots masked from drawing during arc drawing. <br> * = Needed only for word reads. |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |

## Oraphics Character Drawing

Graphics characters can be drawn into display memory pixel-by-pixel. The up to 8 -by-8 character is loaded into the GDC's parameter RAM by the system microprocessor. Consequently, there are no limitations on the character set used. By varying the drawing parameters and drawing direction, numerous drawing options are available. In area fill applications, a character can be written into display memory as many times as desired without reloading the parameter RAM.
Once the parameter RAM has been loaded with up to eight graphics character bytes by the appropriate PRAM command, the GCHRD command can be used
to draw the bytes into display memory starting at the cursor. The zoom magnification factor for writing, set by the zoom command, controls the size of the character written into the display memory in integer multiples of 1 through 16. The bit values in the PRAM are repeated horizontally and vertically the number of times specified by the zoom factor.
The movement of these PRAM bytes to the display mem ory is controlled by the parameters of the FIGS command. Based on the specified height and width of the area to be drawn, the parameter RAM is scanned to fill the required area.
For an 8-by-8 graphics character, the first pixel drawn uses the LSB of RA-15, the second pixel uses bit 1 of RA-15, and so on, until the MSB of RA-15 is reached.
The GDC jumps to the corresponding bit in RA-14 to continue the drawing. The progression then advances toward the LSB of RA-14. This snaking sequence is continued for the other 6 PRAM bytes. This progression matches the sequence of display memory addresses calculated by the drawing processor as shown above. If the area is narrower than 8 pixels wide, the snaking will advance to the next PRAM byte before the MSB is reached. If the area is less than 8 lines high, fewer bytes in the parameter RAM will be scanned. If the area is larger than 8 by 8 , the GDC will repeat the contents of the parameter RAM in two dimensions, as required to fill the area with the 8 -by- 8 mozaic. (Fractions of the 8 -by-8 pattern will be used to fill areas which are not multiples of 8 by 8 .)

## Parameter RAM Contents: RAM Address RA

## 0 to 15

The parameters stored in the parameter RAM, PRAM, are available for the GDC to refer to repeatedly during figure drawing and raster-scanning. In each mode of operation the values in the PRAM are interpreted by the GDC in a predetermined fashion. The host microprocessor must load the appropriate parameters into the proper PRAM locations. PRAM loading command allows the host to write into any location of the PRAM and transfer as many bytes as desired. In this way any stored parameter byte or bytes may be changed without influencing the other bytes.
The PRAM stores two types of information. For specifying the details of the display area partitions, blocks of four bytes are used. The four parameters stored in each block include the starting address in display memory of each display area, and its length. In addition, there are two mode bits for each area which specify whether the area is a bit-mapped graphics area or a coded character area, and whether a 16 -bit or a 32 -bit wide display cycle is to be used for that area.
The other use for the PRAM contents is to supply the pattern for figure drawing when in a bit-mapped graphics area or mode. In these situations, PRAM bytes 8 through 16 are reserved for this patterning information. For line, arc, and rectangle drawing (linear figures) locations 8 and 9 are loaded into the Pattern Register to allow the GDC to draw dotted, dashed, etc. lines. For area filling and graphics bit-mapped character drawing locations 8 through 15 are referenced for the pattern or character to be drawn
Details of the bit assignments are shown on the following pages for the various modes of operation.
Character Mode



Diepiay Parnition 2
stanting oddrose and
tengin


Graphics and Mixed Graphics and Character Modes


Command Bytes Summary


## Video Control Commands

Reset


Modes of Operation Bits

| C | G | Display Mode |
| :--- | :--- | :--- |
| 0 | 0 | Mixed Graphics \& Character |
| 0 | 1 | Graphics Mode |
| 1 | 0 | Character Mode |
| 1 | 1 | Invalid |


| 1 | $S$ | Video Framing |
| :--- | :--- | :--- |
| 0 | 0 | Noninterlaced |
| 0 | 1 | Invalid |
| 1 | 0 | Interlaced Repeat Fleld for Character Dlsplays |
| 1 | 1 | Interlaced |

Repeat Field Framing: 2 Field Sequence with $1 / 2$ line offset between otherwise identical fields.
Interlaced Framing: 2 Field Sequence with $1 / 2$ line offset. Each field displays alternate lines.
Noninterlaced Framing: 1 field brings all of the information to the screen.

Total scanned lines in interlace mode is odd. The sum of VFP + VS + VBP + AL should equal one less than the desired odd number of lines.

| D | Dynamic RAM Refresh Cycles Enable |
| :---: | :---: |
| 0 | No Refresh - STATIC RAM |
| 1 | Refresh - Dynamic RAM |

Dynamic RAM refresh is important when high display zoom factors or DMA are used in such a way that not all of the rows in the RAMs are regularly accessed during display raster generation and for otherwise inactive display memory.

| $F$ | Drawing Time Window |
| :---: | :--- |
| 0 | Drawing during active display time and retrace blanking |
| 1 | Drawing only during retrace blanking |

Access to display memory can be limited to retrace blanking intervals only, so that no disruptions of the image are seen on the screen.

## SYNC Format Specify

SYNC:



This command also loads parameters into the sync generator. The various parameter fields and bits are identical to those at the RESET command. The GDC is not reset nor does it enter idle mode.

## Vertical Sync Mode



When using two or more GDCs to contribute to one image one GDC is defined as the master sync generator, and the others operate as its slaves. The VSYNC pins of all GDCs are connected together.

## Slave Mode Operation

A few considerations should be observed when synchronizing two or more GDCs to generate overlayed video via the VSYNC INPUT/OUTPUT pin. As mentioned above, the Horizontal Front Porch (HFP) must be 4 or more display cycles wide. This is equivalent to eight or more clock cycles. This gives the slave GDCs time to initialize their internal video sync generators to the proper point in the video field to match the incoming vertical sync pulse (VSYNC). This resetting of the generator occurs just after the end of the incoming VSYNC pulse, during the HFP interval. Enough time during HFP is required to allow the slave GDC to complete the operation before the start of the HSYNC interval.
Once the GDCs are initialized and set up as Master and Slaves, they must be given time to synchronize. It is a good idea to watch the VSYNC status bit of the Master GDC and wait until after one or more VSYNC pulses have been generated before the display process is started. The START command will begin the active display of data and will end the video synchronization process, so be sure there has been at least one VSYNC pulse generated for the Slaves to synchronize to.


In graphics mode, LR should be set to 0 .
The blink rate parameter controls both the cursor and attribute blink rates. The cursor blink-on time = blink-off time $=2 \times \mathrm{BR}$ (video frames). The attribute blink rate is always $1 / 2$ the cursor rate but with a $3 / 4$ on- $1 / 4$ off duty cycle.

## Display Control Commands

Start Display \& End Idle Mode

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

## Display Blanking Control



$$
\begin{aligned}
& \text { The dilapoley } 13 \text { enabied } \\
& \text { oy } 1 \text { I. end blemened by }
\end{aligned}
$$



Zoom magnification factors of 1 through 16 are available using codes 0 through 15 , respectively.


In character mode, the third parameter byte is not needed. The cursor is displayed for the word time in which the display scan address (DAD) equals the cursor address. In graphics mode, the cursor word address specifies the word containing the starting pixel of the drawing; the dot address value specifies the pixel within that word.

## Parameter RAM Load



From the starting address, SA, any number of bytes may be loaded into the parameter RAM at incrementing addresses, up to location 15. The sequence of parameter bytes is terminated by the next command byte entered into the FIFO. The parameter RAM stores 16 bytes of information in predefined locations which differ for graphics and character modes. See the parameter RAM discussion for bit assignments.

## Pitch Specification



This value is used during drawing by the drawing processor to find the word directly above or below the current word, and during display to find the start of the next line.

The Pitch parameter (width of display memory) is set by two different commands. In addition to the PITCH command, the RESET (or SYNC) command also sets the pitch value. The "active words per line" parameter, which specifies the width of the raster-scan display, also sets the Pitch of the display memory. In situations in which these two values are equal there is no need to execute a PITCH command.

## Drawing Control Commands

Write Data into Display Memory


Upon receiving a set of parameters (two bytes for a word transfer, one for a byte transfer), one RMW cycle into Video Memory is done at the address pointed to by the cursor EAD. The EAD pointer is advanced to the next word, according to the previously specified direction. More parameters can then be accepted.

For byte writes, the unspecified byte is treated as all zeros during the RMW memory cycle.

In graphics bit-map situations, only the LSB of the WDAT parameter bytes is used as the pattern in the RMW operations. Therefore it is possible to have only an all ones or all zeros pattern. In coded character applications all the bits of the WDAT parameters are used to establish the drawing pattern.
The WDAT command operates differently from the other commands which initiate RMW cycle activity. It requires parameters to set up the Pattern register while the other commands use the stored values in the parameter RAM. Like all of these commands, the WDAT command must be preceeded by a FIGS command and its parameters. Only the first three parameters need be given following the FIGS opcode, to set up the type of drawing, the DIR direction, and the DC value. The DC parameter +1 will be the number of RMW cycles done by the GDC with the first set of WDAT parameters. Additional sets of WDAT parameters will see a DC value of 0 which will cause only one RMW cycle to be executed.

Mask Register Load


This command sets the value of the 16 -bit Mask register of the figure drawing processor. The Mask register controls which bits can be modified in the display memory during a read-modify-write cycle.

The Mask register is loaded both by the MASK command and the third parameter byte of the CURS command. The MASK command accepts two parameter bytes to load a 16 -bit value into the Mask register. All 16 bits can be individually one or zero, under program control. The CURS command on the other hand, puts a " 1 of 16 " pattern into the Mask register based on the value of the Dot Address value, dAD. If normal single-pixel-at-a-time graphics figure drawing is desired, there is no need to do a MASK command at all since the CURS command will set up the proper pattern to address the proper pixels as drawing progresses. For coded character DMA, and screen setting and clearing opertions using the WDAT command, the MASK command should be used after the CURS command if its third parameter byte has been output.

Figure Drawing Parameters Specify







| Valid Figure Type Select Combinations |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SL | R | A | GC | $\underline{L}$ | Operation |
| 0 | 0 | 0 | 0 | 0 | Character Display Mode Drawing, Individual Dot Drawing, DMA, WDAT, and RDAT |
| 0 | 0 | 0 | 0 | 1 | Straight Line Drawing |
| 0 | 0 | 0 | 1 | 0 | Graphics Character Drawing and Area filling with graphics character pattern |
| 0 | 0 | 1 | 0 | 0 | Arc and Circle Drawing |
| 0 | 1 | 0 | 0 | 0 | Rectangle Drawing |
| 1 | 0 | 0 | 1 | 0 | Slanted graphics character drawing and slanted area filling |

Only these bit combinations assure correct drawing operation.

## Figure Draw Start

FIGD: | 0 | 1 | 1 | 0 | 1 | ${ }^{1}$ | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  |  |  |  |  |  |

On execution of this instruction, the GDC loads the parameters from the parameter RAM into the drawing processor and starts the drawing process at the pixel pointed to by the cursor, EAD, and the dot address, dAD.

## Graphics Character Draw and Area Filling Start

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

Based on parameters loaded with the FIGS command, this command initiates the drawing of the graphics character or area filling pattern stored in Parameter RAM. Drawing begins at the address in display memory pointed to by the EAD and dAD values.

## Data Read Commands

## Read Data from Display Memory



Using the DIR and DC parameters of the FIGS command to establish direction and transfer count, multiple RMW cycles can be executed without specification of the cursor address after the initial load (DC number of words or bytes)
As this instruction begins to execute, the FIFO buffer direction is reversed so that the data read from display memory can pass to the microprocessor. Any commands or parameters in the FIFO at this time will be lost. A command byte sent to the GDC will immediately reverse the buffer direction back to write mode, and all RDAT information not yet read from the FIFO will be lost. MOD should be set to 00 if no modification to video buffer is desired

## Cursor Address Read

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



The Execute Address, EAD, points to the display memory word containing the pixel to be addressed.
The Dot Address, dAD, within the word is represented as a 1-of-16 code for graphics drawing operations

## Light Pen Address Read

LPRD:


The light pen address, LAD, corresponds to the display word address, DAD, at which the light pen input signal is detected and deglitched.

The light pen may be used in graphics, character, or mixed modes but only indicates the word address of light pen position.


DMA Write Request


## Absolute Maximum Ratings* (Tentative)

| 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 V to +7 V |
| Power Dissipation | 1.5 Watt |

*COMMENT: Exposing the device to stresses above those listed in Absolute Maximum Ratings could cause permanent damage. The device is not meant to be operated under conditions outside the limits described in the operational sections of this specification. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## DC Characteristics

$t_{a}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% ; G N D=0 \mathrm{~V}$

| Parameter | Symbol | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| Input Low Voltage | $v_{\text {IL }}$ | -0.5 | 0.8 | v |  |
| Input High Voitage | $\mathrm{V}_{\text {IH }}$ | 2.0 | $\mathrm{v}_{\mathrm{Cc}}+0.5$ | $v$ |  |
| Output Low Voitage | $\mathrm{V}_{\text {OL }}$ |  | 0.45 | $v$ | ${ }^{1} \mathrm{OL}=2.2 \mathrm{~mA}$ |
| Output High Voltage | $\mathrm{V}_{\text {OH }}$ | 2.4 |  | $v$ | ${ }^{1} \mathrm{OH}=-400 \mu \mathrm{~A}$ |
| Input Low Leak Current | ILL |  | - 10 | $\mu \mathrm{A}$ | $v_{1}=0 v$ |
| Input High Leak Current | IIH |  | +10 | $\mu \mathrm{A}$ | $v_{1}=v_{c c}$ |
| Output Low Leak Current | ${ }^{102}$ |  | - 10 | $\mu \mathrm{A}$ | $v_{0}=0 V^{\text {c }}$ |
| Output High Leak Current | ${ }^{\prime} \mathrm{OH}$ |  | +10 | $\mu \mathrm{A}$ | $\mathrm{v}_{\mathrm{o}}=\mathrm{v}_{\mathrm{cc}}$ |
| Clock Input Low Voltage | $\mathrm{V}_{\mathrm{CL}}$ | -0.5 | 0.6 | $v$ |  |
| Clock input High Voltage | $\mathrm{V}_{\mathrm{CH}}$ | 3.9 | $\mathrm{V}_{\mathrm{Cc}}+1.0$ | $v$ |  |
| $V_{\text {cC }}$ Supply Current | ${ }^{\text {c }} \mathrm{C}$ |  | 270 |  |  |

## Capacitance

| Parameter | Symbol | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| Input Capacitance I/O Capacitance | $\begin{aligned} & \mathrm{c}_{\mathrm{N}} \\ & \mathrm{c}_{\mathrm{NO}} \end{aligned}$ |  | $\begin{aligned} & 10 \\ & 20 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $=1 \mathrm{mHz}$ |
| Output Capacitance Clock Input Capacitance | $\begin{aligned} & \mathrm{C}_{\text {OUT }} \\ & \mathrm{C}_{\phi} \end{aligned}$ |  | $\begin{aligned} & 20 \\ & 20 \end{aligned}$ | $\begin{aligned} & \mathbf{p F} \\ & \mathbf{p F} \end{aligned}$ | (unmeasured) $=0 \mathrm{~V}$ |

AC Characteristics
$t_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V} \pm 10 \%$; $G N D=0 \mathrm{~V}$

| Read Cycle |  | $(\mathrm{GDC} \rightarrow \mathrm{CPU})$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Limits |  | Unit | $\begin{gathered} \text { Test } \\ \text { Conditions } \end{gathered}$ |
|  |  | Min | Max |  |  |
| ${ }^{\text {t }}$ AR | Address Setup to $\overline{\mathrm{RD}}$. | 0 |  | ns |  |
| $t_{\text {tha }}$ | Address Hold from $\overline{\text { RD }}$ | 0 |  | ns |  |
| $t_{\text {RR1 }}$ | $\overline{\text { PD Pulse Width }}$ | $t_{\text {RD1 }}+20$ | 80 | ns |  |
| ${ }^{\text {tr }}$ ( ${ }^{\text {d }}$ | Data Delay from $\overline{\mathrm{R}}$. |  | 80 | ns | $C_{L}=50 \mathrm{pF}$ |
| ${ }^{\text {t }} \mathrm{DF}$ | Data Floating from $\overline{\mathrm{RD}}$ + | 0 | 100 | ns |  |
| ${ }^{\text {traCy }}$ | $\overline{\text { RO Pulse Cycle }}$ | 4 ICLK |  | ns |  |


| Write Cycle |  | $(\mathrm{GDC} \rightarrow \mathrm{CPU})$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Limits |  | Unit | Test Conditions |
|  |  | Min | Max |  |  |
| ${ }^{\text {taw }}$ | Address Setup to $\overline{\mathrm{WR}}$. | 0 |  | ns |  |
| ${ }^{\text {t }}$ WA | Address Hold from WR. | 0 |  | ns |  |
| ${ }^{\text {tww }}$ | $\overline{\text { WR Pulse Width }}$ | 100 |  | ns |  |
| tow | Data Setup to $\overline{\mathrm{WR}}$, | 80 |  | ns |  |
| ${ }^{\text {two }}$ | Data Hold from $\overline{\text { Wr }}$, | 0 |  | ns |  |
| ${ }^{\text {twor }}$ | $\overline{\text { WR Puise Cycle }}$ | 4 tclk |  | ns |  |


| DMA Read Cycle |  | $(\mathrm{GDC} \leftrightarrow \mathrm{CPU})$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Limits |  | Unit | TestConditions |
|  |  | Min | Max |  |  |
| ${ }_{\text {t }}^{\text {KR }}$ | $\overline{\text { DACK }}$ Setup to $\overline{\text { RD }}$ : | 0 |  | ns |  |
| $t_{\text {PK }}$ | $\overline{\text { DACK }}$ Hold from $\overline{\mathrm{RD}}$ t | 0 |  | ns |  |
| $t_{\text {PR2 }}$ | $\overline{\text { RD Pulse Width }}$ | $\mathrm{t}_{\text {RD2 }}+20$ |  | ns |  |
| $t_{\text {thD2 }}$ | Data Delay from $\overline{\mathrm{AD}}$. |  | 1.5 t CLK +80 | ns | $C_{L}=50 \mathrm{pF}$ |
| $t_{\text {fea }}$ | DREQ Delay from $2 \times$ CCLK $\dagger$ |  | 120 | ns | $C_{L}=50 \mathrm{pF}$ |
| tak | DREQ Setup to DACK | 0 |  | ns |  |
| ${ }^{\text {tok }}$ | DACK High Level Width | tclk |  | ns |  |
| ${ }^{\text {t }}$ E | $\overline{\text { DACK Pulse Cycle }}$ | 4 tclk |  | ns |  |
| ${ }^{t_{K Q}(\mathrm{R})}$ | DREQ + Delay from $\overline{\text { DACK }}$ |  | 2 tCLK +120 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |



| R/M/W Cycle |  | (GDC $\leftrightarrow$ Display Memory) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Limits |  |  |  |
| Symbol | Parameter | Min | Max | Unit | Conditions |
| ${ }^{\text {A }}{ }^{\text {D }}$ | Address/Data Delay from 2XCCLK $\dagger$ |  | 130 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| toff | Address/Data Floating from 2xCCLK $\dagger$ | 10 | 130 | ns | $C_{L}=50 \mathrm{pF}$ |
| ${ }^{\text {tods }}$ | Input Data Setup to 2XCCLK | 40 |  | ns |  |
| ${ }^{\text {din }}$ | Input Data Hold from 2XCCLK | 0 |  | ns |  |
| ${ }^{\text {tobl }}$ | DBIN Delay from 2XCCLK |  | 90 | ns | $C_{L}=50 \mathrm{pF}$ |
| $t_{\text {tR }}$ | ALE个 Delay from 2XCCLK $\uparrow$ | 30 | 110 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $\mathrm{t}_{\text {RF }}$ | ALE + Delay from 2XCCLK | 20 | 90 | ns | $\mathrm{C}_{\mathrm{L}}=\mathbf{5 0} \mathrm{pF}$ |
| $t_{\text {RW }}$ | ALE Width | $1 / 3$ CCLK |  | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |


| Display Cycle |  | (GDC $\rightarrow$ Display Memory) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Limits. |  | Unit | Test Conditions |
|  |  | MIn | Max |  |  |
| tvo | Video Signal Delay from 2XCCLK $\dagger$ |  | 120 | ns | $\mathrm{c}_{\mathrm{L}}=50 \mathrm{pF}$ |
| Input Cycle |  | (GDC $\rightarrow$ Display Memory) |  |  |  |
|  |  | Lumits |  |  | Tost |
| Symbol | Parameter | Min | Max | Unit | Conditions |
| ${ }^{\text {tps }}$ | Input Signal Setup to 2XCCLK ${ }^{\dagger}$ | 20 |  | ns |  |
| tpw | Input Signal Width | tclk |  | ns |  |
| Clock |  |  |  |  |  |
| Symbol | Parameter | $\overline{\text { min }}$ | Max | Unit | Test Conditions |
| ${ }^{\text {t }}$ 'R | Clock Rise Time |  | 10 | ns |  |
| ${ }^{\text {i }}$ CF | Clock Fall Time |  | 10 | ns |  |
| ${ }^{\text {' }} \mathrm{CH}$ | Clock High Pulse Width | 95 |  | ns |  |
| ${ }^{\text {che }}$ | Clock Low Puise Width | 95 |  | ns |  |
| tclk | Clock Cycle | 200 | 2000 | ns |  |

## Timing Waveforms

## Display Memory RMW Timing



Microprocessor Interface Write Timing


## Timing Wavoforms (Cont.)

Microprocessor Interface Roed Timing


## Microprocessor Interface DMA Write Timing



M: iroprocessor Interface DMA Read Timing


## Timing Waveforms (Cont.)

Display Memory Display Cycle Timing


Light Pen and External Sync Input Timing


Clock Timing


Test Level (for AC Tests)



## Timing Waveforms (Cont.)

Interlaced Video TIming


Video Sync Generator Parameters


## Timing Waveforms (Cont.)

## Display and RMW Cycles (1x Zoom)



## Display and RMW Cycles ( $2 \times$ Zoom)



## Zoomed Display Operation with RMW Cycle (3x Zoom)



Video Field Timing


A4-18


## Pin Identification

| Pln |  | Direction | Function |
| :---: | :---: | :---: | :---: |
| No. | Symbol |  |  |
| 1 | 2xwCLK | IN | Clock Input |
| 2 | DEIN | OUT | Display Memory Read Input Flag |
| 3 | HSYNC | OUT | Horizontal Video Sync Output |
| 4 | V/EXT SYNC | IN/OUT | Vortical Vidoo Sync Output or External VSYNC Input |
| 5 | BLANK | OUT | CRT Blanking Output |
| 6 | ALE ( $\overline{\text { AAS }}$ ) | OUT | Address Latch Enable Output |
| 7 | DRQ | OUT | DMA Roquest Output |
| 8 | $\overline{\text { DACK }}$ | IN | DMA Acknowledge input |
| 9 | $\overline{\text { AD }}$ | in | Read Strobe Input for Microprocessor interface |
| 10 | $\overline{\text { wi }}$ | in | Write Strobe input for Microprocessor intertace |
| 11 | AO | IN | Address Select Input for Microprocescor interface |
| 12-19 | DBO to 7 | IN/OUT | Bldirectional Data Bus to Host Microproceseor |
| 20 | GND | - | Ground |
| 21 | LPEN | IN | Light Pon Detect Input |
| 22-34 | ADO to 12 | IN/OUT | Address and Data Lines to Display Memory |
| 35-37 | AD13 to 15 | IN/OUT | Utilization Varies with Mode of Operation |
| 38 | A16 | OUT | Utilization Varies with Mode of Operation |
| 39 | A17 | OUT | Utilization Varies with Mode of Operation |
| 40 | $\mathrm{v}_{\text {cc }}$ | - | + $5 \mathrm{~V} \pm 10 \%$ |

## Character Mode Pin Utilization

| Pin |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| No. | Name | Direction | Function |  |
| 35-37 | AD13 to | 15 | OUT | Line Counter Bits 0 to 2 Outputs |
| 38 | A16 | OUT | Line Counter Bit 3 Output |  |
| 39 | A17 | OUT | Cureor Output |  |

## Mixed Mode Pin Utilization

| Mn |  | Drection | Function |
| :---: | :---: | :---: | :---: |
| No. | Name |  |  |
| 35-37 | AD13 to 15 | in/OUT | Addrese and Data Bits 13 to 15 |
| 38 | A16 | OUT | Atrributo Blink and Cloar Line Counter' Output |
| 39 | A17 | OUT | Cursor and Bit-Map Area* Fiag Output |

* = Output during the HSYNC interval. Use the trailing edge at HSYNC to clock this value into a flop for reference during the rest of the video line.


## Graphics Mode Pin Utilization

| Mn |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Mo. | Meme | Direction | Function |  |
| $35-37$ | AD13 to 15 | IN/OUT | Addrose and Data Bits 13 to 15 |  |
| 38 | A16 | OUT | Addrese Bit 16 Output |  |
| 39 | A17 | OUT | Addrose Bit 17 Output |  |

## Pin Configuration



Block Diagram of a Craphics Terminal


Package Outlines
MPD7220D
${ }^{\text {PPD7220C }}$


| Plastic |  |  |
| :--- | :---: | :--- |
| ITEM | MILLIMETERS | INCHES |
| A | 515 MAX | 2.028 MAX |
| B | 162 | 0.064 |
| C | $254 \cdot 01$ | $0.10 \cdot 0.004$ |
| D | $0.5 \cdot 01$ | $0019 \cdot 0.004$ |
| E | 48.26 | 19 |
| F | 12 MIN | 0.047 MIN |
| G | 2.54 MIN | 0.10 MIN |
| H | 0.5 MIN | 0.019 MIN |
| I | 5.22 MAX | 0.206 MAX |
| J | 5.72 MAX | 0.225 MAX |
| K | 15.24 | 0.600 |
| L | 13.2 | 0.520 |
| M | $0.25+0.1$ | $0.010+0.004$ |
|  | 0.05 | 0.002 |

Appendix B
Logic and Schematic Diagrams
The APC logic and schematic diagrams are arranged in drawing number sequence.





136-100430-500-A
G9PFBU PCB Circuit Diagram Sheet 2 of 11
















136-100430-501-A


Pin assignment of CRT display unit connector



## G9PFCU PCB Circuit Diagram

 Sheet 7 of 11




## Appendix C

## Programmable Array Logic Decoding Specifications

There are four Programmable Array Logic (PAL) devices in the APC, two on the Processor PCB and two on the Controller PCB. These devices are identified and listed in Table C-1. Tables C-2 to C-5 describes each PAL device in terms of its inputs and outputs.

Table C-1 Identification and Location of PAL Devices

| STAMPED <br> IDENTIFICATION | MANUFACTURER DATA | PCB LOCATION |
| :---: | :---: | :---: |
| PFB01C | MMI PAL 16L8 <br> or <br> Signetics N 82 S153F | G9PFBU (Processor PCB) <br> Location 7N |
| PFB02 | MMI PAL 10L8 | G9PFBU (Processor PCB) <br> Location 1N |
| PFC01 | MMI PAL 14L4 or Signetics N 82S153F | G9PFCU (Controller PCB) <br> Location 2H |
| NMS02 | MMI PAL 14L4 | G9PFCU (Controller PCB) <br> Location 2N |

Table C-2 PFB01C Inputs/Outputs

| INPUT |  | OUTPUT |  |
| :---: | :---: | :---: | :---: |
| PIN NUMBER | SIGNAL NAME | PIN NUMBER | SIGNAL NAME |
| $\begin{array}{r} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 11 \\ \hline \end{array}$ | A7 <br> A6 <br> A5 <br> A4 <br> A3 <br> A2 <br> A1 <br> A0 <br> BHE0 <br> AE371 | $\begin{aligned} & 19 \\ & 18 \\ & 17 \\ & 16 \\ & 15 \\ & 14 \\ & 13 \\ & 12 \end{aligned}$ | B0 <br> B1 <br> B2 <br> KB <br> C0 <br> WAT <br> CDMA0 <br> MBC |
| $\overline{\overline{\mathrm{B} 0}} \quad=$ | $\begin{aligned} &=(\overline{\mathrm{A} 7} \cdot \overline{\mathrm{~A} 6} \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{BHE} 0} \cdot \overline{\mathrm{AE} 371})+(\overline{\mathrm{A} 7} \cdot \overline{\mathrm{~A} 6} \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 2} \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371})+ \\ &(\overline{\mathrm{A} 7} \cdot \mathrm{~A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \mathrm{~A} 1 \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371}) \end{aligned}$ |  |  |
| $\overline{\mathrm{B} 1} \quad=$ | $\begin{aligned} = & (\overline{\mathrm{A} 7} \cdot \overline{\mathrm{~A} 6} \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{BHE}} \cdot \overline{\mathrm{AE} 371})+(\overline{\mathrm{A} 7} \cdot \overline{\mathrm{~A} 6} \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \mathrm{~A} 3 \cdot \overline{\mathrm{BHE} 0} \cdot \overline{\mathrm{AE} 371})+ \\ & (\overline{\mathrm{A} 7} \cdot \mathrm{~A} \cdot \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \mathrm{~A} 3 \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371})+ \\ & (\overline{\mathrm{A} 7} \cdot \mathrm{~A} \cdot \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \mathrm{~A} 1 \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371}) \end{aligned}$ |  |  |
| $\overline{\mathrm{B} 2} \quad=$ | $\begin{aligned} = & (\overline{\overline{\mathrm{A} 7} \cdot} \cdot \overline{\mathrm{~A} 6} \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371})+ \\ & (\overline{\mathrm{A} 7} \cdot \overline{\mathrm{~A} 6} \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A}} 3 \cdot \overline{\mathrm{~B} H E} \cdot \overline{\mathrm{AE} 37} 1)+(\overline{\mathrm{A} 7} \cdot \overline{\mathrm{~A} 6} \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \mathrm{~A} 3 \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371}) \\ & +(\overline{\mathrm{A} 7} \cdot \mathrm{~A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \mathrm{~A} 1 \cdot \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371}) \end{aligned}$ |  |  |
| $\overline{\mathrm{KB}} \quad=(\bar{A}$ | $=(\overline{\mathrm{A} 7} \cdot \mathrm{~A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{~A} 4} \cdot \mathrm{~A} 3 \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371})$ |  |  |
| $\overline{\mathrm{C} 0} \quad=$ | $=\left(\frac{(\overline{\mathrm{A} 7} \cdot \mathrm{~A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \mathrm{~A} 4 \cdot \mathrm{~A} 3 \cdot \overline{\mathrm{~A} 2} \cdot \overline{\mathrm{~A} 1} \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371})}{(\overline{\mathrm{A} 7} \cdot \mathrm{~A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \mathrm{~A} 4 \cdot \mathrm{~A} 3 \cdot \overline{\mathrm{~A} 2} \cdot \overline{\mathrm{BHE} 0} \cdot \overline{\mathrm{AE} 371})}+\right.$ |  |  |
| $\overline{\mathrm{WAT}}=(\overline{\mathrm{A}}$ | $=(\overline{\mathrm{A} 7} \cdot \mathrm{~A} 6 \cdot \overline{\mathrm{A5}} \cdot \mathrm{~A} 4 \cdot \mathrm{~A} 3 \cdot \overline{\mathrm{~A} 2} \cdot \overline{\mathrm{~A} 1} \cdot \overline{\mathrm{A0}} \cdot \overline{\mathrm{AE} 371})$ |  |  |
| $\overline{\mathrm{MBC}}=$ | $\begin{aligned} = & (\overline{\mathrm{A} 7} \cdot \overline{\mathrm{~A} 6} \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{BHE}} \cdot \overline{\mathrm{AE} 371})+(\overline{\mathrm{A} 7} \cdot \overline{\mathrm{~A} 6} \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371})+ \\ & (\overline{\mathrm{A} 7} \cdot \overline{\mathrm{~A} 6} \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \mathrm{~A} \cdot \overline{\mathrm{BH}} \overline{\mathrm{AE} 0} \cdot \overline{\mathrm{AE} 371})+(\overline{\mathrm{A} 7} \cdot \mathrm{~A} \cdot \cdot \overline{\mathrm{~A} 4} \cdot \mathrm{~A} 3 \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371})+ \\ & (\overline{\mathrm{A} 7} \cdot \overline{\mathrm{~A} 6} \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \mathrm{~A} 3 \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371})+(\overline{\mathrm{A} 7} \cdot \mathrm{~A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \mathrm{~A} 4 \cdot \mathrm{~A} 3 \cdot \overline{\mathrm{~A} 2} \cdot \overline{\mathrm{~B}}- \\ & \overline{\mathrm{HE}} \cdot \overline{\mathrm{AE} 371})+ \\ & (\overline{\mathrm{A} 7} \cdot \mathrm{~A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \mathrm{~A} 4 \cdot \mathrm{~A} 3 \cdot \overline{\mathrm{~A} 2} \cdot \overline{\mathrm{~A} 1} \cdot \overline{\mathrm{~A} 0} \cdot \overline{\mathrm{AE} 371}) \end{aligned}$ |  |  |
| $\overline{\overline{\text { CDMA0 }}}=$ | $=(\overline{\mathrm{A} 7} \cdot \overline{\mathrm{~A} 6} \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{BHEO}} \cdot \overline{\mathrm{AE} 371})$ |  |  |

Table C-3 PFB02 Inputs/Outputs

| INPUT |  | OUTPUT |  |
| :---: | :---: | :---: | :---: |
| PIN NUMBER | SIGNAL NAME | PIN NUMBER | SIGNAL NAME |
| $\begin{array}{r} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 11 \end{array}$ | MBCS <br> DMC <br> AB19 <br> AB18 <br> AB17 <br> MRD <br> IOR <br> MRQ <br> AB0 <br> IMM | $\begin{aligned} & 19 \\ & 18 \\ & 17 \\ & 16 \\ & 15 \\ & 14 \\ & 13 \\ & 12 \end{aligned}$ | ROMS <br> RAMS <br> BMMS <br> BEXC <br> MRBS <br> DMA <br> MPR <br> ITMM |
| $\overline{\text { ROMS }}=(\mathrm{A}$ $\overline{\mathrm{RAMS}}=(\overline{\mathrm{A}}$ $\overline{\mathrm{BMMS}}=(\mathrm{A}$ $\overline{\mathrm{BEXC}}=(\overline{\mathrm{D}}$ $\overline{\mathrm{MRBS}}=(\overline{\mathrm{A}}$ $\overline{\mathrm{DMA}}=(\overline{\mathrm{D}}$ $\overline{\mathrm{MPR}}=(\mathrm{D}$ $\overline{\mathrm{ITMM}}=(\overline{\mathrm{A}}$ | $\begin{aligned} & \cdot \overline{\mathrm{AB} 18} \cdot \mathrm{AB} 17 \cdot \overline{\mathrm{MRD}} \\ & \cdot \overline{\mathrm{AB} 18} \cdot \overline{\mathrm{AB} 17}) \\ & \cdot \mathrm{MR1} \cdot \mathrm{AB} 17 \cdot \mathrm{MRQ} \\ & \cdot \overline{\mathrm{AB} 18} \cdot \overline{\mathrm{AB} 17} \cdot \overline{\mathrm{MRD}} \\ & \cdot \overline{\mathrm{IOR}})+(\overline{\mathrm{DMC}} \cdot \overline{\mathrm{MF}} \\ & \cdot \mathrm{MBCS} \cdot \overline{\mathrm{IOR}})+(\mathrm{D} \\ & \cdot \overline{\mathrm{AB} 18} \cdot \overline{\mathrm{AB} 17})+(\mathrm{A} \end{aligned}$ | $\overline{\mathrm{B} 0} \cdot \mathrm{IMM})$ <br> $\overline{\text { MRD }} \cdot I M M)$ <br> AB17) |  |

Table C-4 PFC01 Inputs/Outputs

| INPUT |  | OUTPUT |  |
| :---: | :---: | :---: | :---: |
| PIN NUMBER | SIGNAL NAME | PIN NUMBER | SIGNAL NAME |
| $\begin{array}{r} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 11 \\ 13 \end{array}$ | A0 A1 A2 A3 A4 A5 A6 DT/R BHE IOR IOW | 19 18 17 16 15 14 12 | LSI B0 B1 B2 IO CS0 CS1 |
| $\begin{aligned} \overline{\mathrm{LSI}}= & (\overline{\mathrm{A} 6} \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{~A} 0)+(\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{~A} 0)+ \\ & (\overline{\mathrm{A} 6} \cdot \overline{\mathrm{~A} 5} \cdot \mathrm{~A} 4 \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{~A} 0)+(\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \mathrm{~A} 4 \cdot \mathrm{~A} 3 \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0)+ \\ & (\overline{\mathrm{A} \cdot} \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{BHE})+(\mathrm{A} 6 \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \cdot \overline{\mathrm{~A} 2} \cdot \overline{\mathrm{~A} 1} \cdot \mathrm{~A} 0)+ \\ & (\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{BHE}) \end{aligned}$ |  |  |  |
| $\begin{aligned} \overline{\mathrm{B} 0}= & (\overline{\mathrm{A} 6} \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{~A} 0)+(\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \mathrm{~A} 4 \cdot \mathrm{~A} 3 \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0)+ \\ & \left.(\overline{\mathrm{A} 6} \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0)+\left(\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \frac{\mathrm{~A} 2}{\mathrm{~A}} \cdot \mathrm{BHE}\right)+\overline{\mathrm{A}} \overline{\mathrm{~A}} \cdot \mathrm{~A} 0 \cdot \overline{\mathrm{~A} T / \mathrm{R}}\right)+ \\ & (\mathrm{A} 6 \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} \cdot \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0 \cdot \overline{\mathrm{DT} / \mathrm{R}})+(\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \mathrm{~A} \cdot \mathrm{~A} 0 \cdot \overline{\mathrm{~A}}) \\ & (\mathrm{A} 6 \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0) \end{aligned}$ |  |  |  |
| $\begin{aligned} \overline{\mathrm{B} 1}= & (\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{~A} 0)+(\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \mathrm{~A} 4 \cdot \mathrm{~A} 3 \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0)+ \\ & (\overline{\mathrm{A} 6} \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \cdot \overline{\mathrm{BHE}})+(\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \mathrm{~A} 4 \cdot \cdot \mathrm{~A} 3 \cdot \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{BHE})+ \\ & (\mathrm{A} 6 \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0 \cdot \mathrm{DT} / \mathrm{R})+(\mathrm{A} 6 \cdot \cdot \mathrm{~A} 5 \cdot \cdot \mathrm{~A} 4 \cdot \mathrm{~A} 3 \cdot \mathrm{~A} 2 \cdot \overline{\mathrm{~A} 1} \cdot \mathrm{~A} 0 \cdot \overline{\mathrm{DT} / \mathrm{R}})+ \\ & (\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0 \cdot \overline{\mathrm{DT} / \mathrm{R}}) \end{aligned}$ |  |  |  |
| $\begin{aligned} \overline{\mathrm{B} 2}= & (\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \mathrm{~A} 4 \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{~A} 0)+(\overline{\mathrm{A} 6} \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \overline{\mathrm{A3}} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{BHE})+ \\ & (\overline{\mathrm{A} 6} \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \overline{\mathrm{~A} 1} \cdot \mathrm{~A} 0)+(\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{BHE})+ \\ & (\overline{\mathrm{A} 6} \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0 \cdot \overline{\mathrm{DT} / \mathrm{R}})+(\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0 \cdot \overline{\mathrm{DT} / \mathrm{R}})+ \\ & (\mathrm{A} 6 \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0) \end{aligned}$ |  |  |  |
| $\begin{aligned} \overline{\mathrm{IO}}= & (\overline{\mathrm{A} 6} \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \overline{\mathrm{~A} 1} \cdot \mathrm{~A} 0 \cdot \mathrm{IOW})+(\overline{\mathrm{A} 6} \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \overline{\mathrm{A3}} \cdot \mathrm{~A} 2 \cdot \overline{\mathrm{~A} 1} \cdot \mathrm{~A} 0 \cdot \mathrm{IOR})+ \\ & (\overline{\mathrm{A} 6} \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4 \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0 \cdot \mathrm{IOW})+(\mathrm{A} 6 \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \overline{\mathrm{~A} 1} \cdot \mathrm{~A} 0 \cdot \mathrm{IOW})+ \\ & (\mathrm{A} 6 \cdot \cdot \overline{\mathrm{~A} 5} \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \mathrm{~A} 2 \cdot \mathrm{~A} \cdot \mathrm{~A} 0 \cdot \mathrm{IOW})+(\mathrm{A} 6 \cdot \mathrm{~A} 5 \cdot \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0 \cdot \mathrm{IOW})+ \\ & (\mathrm{A} \cdot \cdot \mathrm{~A} 5 \cdot \overline{\mathrm{~A} 4} \cdot \overline{\mathrm{~A} 3} \cdot \overline{\mathrm{~A} 2} \cdot \mathrm{~A} 1 \cdot \mathrm{~A} 0 \cdot \mathrm{IOR}) \end{aligned}$ |  |  |  |
| $\overline{\mathrm{CS} 0}=(\mathrm{A} 6 \cdot \mathrm{~A} 5 \cdot \mathrm{~A} 4)$ |  |  |  |
| $\overline{\mathrm{CS} 1}=(\overline{\mathrm{A} 6} \cdot \overline{\mathrm{~A} 5} \cdot \mathrm{~A} 4)$ |  |  |  |

Table C-5 NMS02 Inputs/Outputs

| INPUT |  | OUTPUT |  |
| :---: | :---: | :---: | :---: |
| PIN NUMBER | SIGNAL NAME | PIN NUMBER | SIGNAL NAME |
| $\begin{array}{r} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 11 \\ 12 \\ 13 \\ 18 \\ 19 \end{array}$ | $\begin{aligned} & \text { CC7 } \\ & \text { CC6 } \\ & \text { CC5 } \\ & \text { CC4 } \\ & \text { CC3 } \\ & \text { CC2 } \\ & \text { CC1 } \\ & \text { CC0 } \\ & \text { M8960 } \\ & \text { MRQ0 } \\ & \text { MW0 } \\ & \text { XNU } \\ & \text { XNU } \\ & \text { XNU } \end{aligned}$ | $\begin{aligned} & 17 \\ & 16 \\ & 15 \\ & 14 \end{aligned}$ | ANK0 <br> FULL1 <br> BE0 <br> BS0 |
|  |  |  |  |
| $\begin{array}{ll} \overline{\mathrm{BE} 0} & =(\overline{\mathrm{M}} \\ \mathrm{BS} 0 & =(\overline{\mathrm{M}} \end{array}$ | $\begin{aligned} & \overline{50} \cdot \overline{\mathrm{MRQ} 0}) \\ & \overline{50} \cdot \overline{\mathrm{MRQ} 0} \cdot \overline{\mathrm{MW} 0}) \end{aligned}$ |  |  |

## Appendix D

## Character Code and Keyboard Information

This appendix gives important character code and keyboard information for the APC. The characters that can be generated and their associated codes are shown in Table D-1. The meanings of the ASCII special characters are given in Table D-2. Table D-3 lists the APC special characters that differ in representation from the ASCII standard, but the generated code is the same. A quick reference quide for easy association of the ASCII special characters and APC special characters is provided in Table D-4. The APC GRPH1 characters are shown in Figure D-1, the GRPH2 characters in Figure D-2.

Table D-1 Code Table

| $\begin{aligned} & \text { SECOND } \\ & \text { HEX } \\ & \text { DIGIT } \end{aligned}$ | FIRST HEX DIGIT |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| 0 | $\begin{gathered} \text { NUL } \\ 00 \end{gathered}$ | $\underset{16}{ }$ | $\underset{32}{\text { SP }}$ | $\begin{gathered} 0 \\ 48 \end{gathered}$ | $\begin{aligned} & @ \\ & 64 \end{aligned}$ | $\begin{aligned} & \mathbf{P} \\ & 80 \end{aligned}$ | 96 | $\underset{112}{\mathrm{p}}$ | 128 | 144 | 160 | ${ }_{176}$ | ${ }_{192}{ }^{\text {a }}$ | $\underset{208}{\$}$ | 224 |  |
| 1 | $\underset{01}{\mathrm{SOH}}$ | $\underset{17}{\mathrm{DC1}}$ | $\begin{gathered} ! \\ 33 \end{gathered}$ | $\begin{gathered} 1 \\ 49 \end{gathered}$ | $\begin{aligned} & \text { A } \\ & 65 \end{aligned}$ | $\underset{81}{\mathrm{Q}}$ | $\begin{aligned} & \text { a } \\ & 97 \end{aligned}$ | $\underset{113}{\mathrm{q}}$ | 129 | 145 | $\underset{161}{ }$ | 3 177 | ${ }_{193}{ }^{\nu}$ | ${ }_{209}^{\omega}$ | 225 | 241 |
| 2 | $\underset{02}{\text { STX }}$ | $\begin{gathered} \mathrm{DC} 2 \\ 18 \end{gathered}$ | $34$ | $\begin{gathered} 2 \\ 50 \end{gathered}$ | $\underset{66}{\mathrm{~B}}$ | $\begin{aligned} & \mathrm{R} \\ & 82 \end{aligned}$ | $\begin{aligned} & \mathrm{b} \\ & 98 \end{aligned}$ | $\underset{114}{\mathrm{r}}$ |  | 146 | ${ }_{162}{ }^{\circ}$ | ${ }_{178} \boldsymbol{\tau}$ | ${ }_{194}{ }^{\text {d }}$ | $\underset{210}{\sim}$ | 226 | $2421$ |
| 3 | $\underset{03}{\mathrm{ETX}}$ | $\underset{19}{\mathrm{DC} 3}$ | $\begin{gathered} \# \\ 35 \end{gathered}$ | $\begin{gathered} 3 \\ 51 \end{gathered}$ | $\underset{67}{\mathrm{C}}$ | $\underset{83}{\mathbf{S}}$ | $\begin{gathered} \mathrm{c} \\ 99 \end{gathered}$ | $\begin{gathered} \mathbf{s} \\ 115 \end{gathered}$ | 131 | 147 |  | $\begin{array}{\|c} \hline 4 \\ 179 \\ \hline \end{array}$ | ${ }_{195} \beta$ | $\begin{array}{\|c} \sqrt{2} \\ 211 \end{array}$ | $227$ | $243$ |
| 4 | $\underset{04}{\mathrm{EOT}}$ | $\begin{array}{\|c} \mathrm{DC4} \\ 20 \end{array}$ | $\begin{aligned} & \$ \\ & 36 \end{aligned}$ | $\begin{gathered} 4 \\ 52 \end{gathered}$ | $\begin{gathered} \mathrm{D} \\ 68 \end{gathered}$ | $\begin{aligned} & \mathrm{T} \\ & 84 \end{aligned}$ | $\underset{100}{\mathrm{~d}}$ | $\begin{gathered} \mathrm{t} \\ 116 \end{gathered}$ | 132 | 148 | $\underset{164}{ } \leq$ | 5 <br> 180 | ${ }_{196} \boldsymbol{\xi}$ | 7 212 |  | 244 |
| 5 | $\begin{gathered} \text { ENQ } \\ 05 \end{gathered}$ | $\underset{21}{\text { NAK }^{2}}$ | $\begin{gathered} \% \\ 37 \end{gathered}$ | $\begin{gathered} 5 \\ 53 \end{gathered}$ | $\begin{gathered} \mathrm{E} \\ 69 \end{gathered}$ | $\begin{aligned} & \mathrm{U} \\ & 85 \end{aligned}$ | $\begin{gathered} \mathrm{e} \\ 101 \end{gathered}$ | $\begin{gathered} \text { u } \\ 117 \end{gathered}$ |  | 149 |  | 6 181 | ${ }_{197} \eta$ | 8 213 |  |  |
| 6 | $\underset{06}{\mathrm{ACK}}$ | $\mathrm{SYN}_{22}$ | $\begin{aligned} & \& \\ & 38 \end{aligned}$ | $\begin{gathered} 6 \\ 54 \end{gathered}$ | $\underset{70}{F}$ | $\begin{aligned} & \mathbf{V} \\ & 86 \end{aligned}$ | $\begin{gathered} \text { f } \\ 102 \end{gathered}$ | $\underset{118}{\mathbf{v}}$ | 134 | 150 | $\begin{array}{\|c} \bullet \\ \hline 166 \\ \hline \end{array}$ | ${ }_{182}{ }^{\epsilon}$ | ${ }_{198} \theta$ | $\begin{array}{r} 9 \\ 214 \\ \hline \end{array}$ |  | 246 |
| 7 | $\underset{07}{\mathrm{BEL}}$ | $\underset{23}{\text { ETB }}$ | 39 | $\begin{gathered} 7 \\ 55 \end{gathered}$ | $\begin{aligned} & \mathrm{G} \\ & 71 \end{aligned}$ | $\begin{aligned} & \text { W } \\ & 87 \end{aligned}$ | $\underset{103}{\underset{10}{g}}$ | $\underset{111}{\mathbf{w}}$ | 135 | 151 |  | ${ }_{183} \rho$ | ${ }_{199} 1$ | $\begin{array}{\|c} l \\ \hline 215 \\ \hline \end{array}$ |  |  |
| 8 | $\begin{gathered} \text { BS } \\ 08 \end{gathered}$ | ${ }_{24}^{\mathrm{CAN}}$ | $\underset{40}{( }$ | $\begin{gathered} 8 \\ 56 \end{gathered}$ | $\begin{aligned} & \mathrm{H} \\ & 72 \end{aligned}$ | $\begin{aligned} & \mathbf{X} \\ & 88 \end{aligned}$ | $\begin{gathered} \mathrm{h} \\ 104 \end{gathered}$ | $\begin{gathered} \mathrm{x} \\ 120 \end{gathered}$ | 136 | 152 | $\frac{1}{2}$ | ${ }_{184} \sigma$ | + |  |  | 248 ¢ |
| 9 | $\underset{09}{\mathrm{HT}}$ | $\underset{25}{\text { EM }}$ | $\underset{41}{( }$ | $\begin{gathered} 9 \\ 57 \end{gathered}$ | $\underset{73}{\mathrm{I}}$ | $\begin{aligned} & \mathrm{Y} \\ & 89 \end{aligned}$ | $\begin{gathered} \mathrm{i} \\ 105 \end{gathered}$ | $\underset{121}{y}$ | 137 | 153 | $169$ | ${ }_{185} \psi$ | $\underset{201}{v}$ | $\underset{217}{\neq}$ | $233$ | $J_{249}$ |
| A | $\underset{10}{\mathrm{LF}}$ | $\underset{26}{\text { SUB }}$ | $42$ | $58$ | $\underset{74}{\mathrm{~J}}$ | $\begin{aligned} & \mathrm{Z} \\ & 90 \end{aligned}$ | $\underset{106}{\mathrm{j}}$ | $\begin{gathered} \mathrm{z} \\ 122 \end{gathered}$ | 138 | 154 | $170$ | $\Omega$ | $\begin{array}{r} \pi \\ 202 \\ \hline \end{array}$ | $\underset{218}{ }$ | $234$ | ${ }_{2} 5$ |
| B | $\begin{aligned} & \text { VT } \\ & 11 \end{aligned}$ | $\underset{27}{\text { ESC }}$ | $\begin{aligned} & + \\ & 43 \end{aligned}$ | ; | $\underset{75}{\mathbf{K}}$ | $[$ | $\begin{gathered} \mathrm{k} \\ 107 \end{gathered}$ | $\underset{123}{\{ }$ | 139 | 155 | 171 | ${ }_{187} \Gamma$ | $\bigwedge_{203}$ | ( 0 | $8$ | 251 |
| C | $\begin{gathered} \mathrm{FF} \\ 12 \end{gathered}$ | $\underset{28}{\text { FS }}$ | 44 | $<$ | $\stackrel{\mathrm{L}}{76}$ | $92$ | $\begin{gathered} 1 \\ 108 \end{gathered}$ | $\begin{gathered} 1 \\ 124 \end{gathered}$ |  | 156 | ${ }_{172}+$ | 0 188 | 2 204 | $\begin{array}{r} 0 \\ 220 \\ \hline \end{array}$ | ${ }_{236}$ | 252 |
| D | $\underset{13}{\text { CR }}$ | $\begin{gathered} \text { GS } \end{gathered}$ | $\overline{45}$ | $\begin{aligned} & = \\ & 61 \end{aligned}$ | $\underset{77}{\mathbf{M}}$ | ${ }_{93}$ | $\begin{gathered} \mathrm{m} \\ 109 \end{gathered}$ | $\underset{125}{\}}$ | 141 |  | $173$ | $\begin{array}{r} \delta \\ 189 \\ \hline \end{array}$ |  | ${ }_{221}{ }^{5}$ | ${ }_{237}$ | 253 |
| E | $\underset{14}{\mathrm{SO}}$ | $\begin{gathered} \text { RS } \\ 30 \end{gathered}$ | 46 | $\underset{62}{>}$ | $\underset{78}{\mathbf{N}}$ | $\widehat{94}$ | $\begin{gathered} \mathrm{n} \\ 110 \end{gathered}$ | $\widetilde{126}$ |  |  | $174$ | ${ }_{190}{ }^{K}$ | $206$ | ${ }_{222} \lambda$ |  | ${ }_{254}$ |
| F | $\underset{15}{\text { SI }}$ | $\begin{gathered} \text { US } \\ 31 \end{gathered}$ | $\stackrel{1}{47}$ | $\begin{gathered} ? \\ 63 \end{gathered}$ | $\begin{aligned} & \mathrm{O} \\ & 79 \end{aligned}$ | 95 | $\begin{gathered} \mathrm{o} \\ 111 \end{gathered}$ | $\underset{127}{\text { DEL }}$ |  |  | ${ }_{175}^{1} 4$ | $\sum_{191}$ | $\begin{array}{r} T \\ \hline 207 \\ \hline \end{array}$ | ${ }_{223} \mu$ |  | $2$ |

ASCII Charact :r
Graphics Character


Decimal Code

Table D-2 ASCII Special Characters

| CODE | MEANING |
| :--- | :--- |
| NUL | Null |
| SOH | Start of Heading |
| STX | Start Text |
| ETX | End Text |
| EOT | End of Transmission |
| ENQ | Enquiry |
| ACK | Acknowledge |
| BEL | Bell |
| BS | Backspace |
| HT | Horizontal Tab |
| LF | Line Feed |
| VT | Vertical Tab |
| FF | Form Feed |
| CR | Carriage Return |
| SO | Shift Out |
| SI | Shift In |
| DLE | Data Link Escape |
| DC1 | Device Control 1 |
| DC2 | Device Control 2 |
| DC3 | Device Control 3 |
| DC4 | Device Control 4 |
| NAK | Negative Acknowledge |
| SYN | Synchronous Idle |
| ETB | End Transmission Block |
| CAN | Cancel |
| EM | End of Medium |
| SUB | Substitute |
| ESC | Escape |
| FS | Form Separator |
| GS | Group Separator |
| RS | Record Separator |
| US | Unit Separator |
| SP | Space |
| DEL | Delete |
| These codes are not displayed on the APC as shown. Some of these codes |  |
| are not used by the APC, but the unused codes can still be transmitted for |  |
| use by other devices. |  |
|  |  |

Table D-3 APC Special Characters

| $\begin{array}{\|c\|} \hline \text { SECOND } \\ \text { HEX } \\ \text { DIGIT } \end{array}$ | FIRST HEX DIGIT |  |
| :---: | :---: | :---: |
|  | 0 | 1 |
| 0 | 00 | $\underset{16}{\square}$ |
| 1 | $D_{01}$ | 17 |
| 2 |  | 18 |
| 3 | $\infty_{03}^{\infty}$ | 19 |
| 4 | $\overbrace{04}$ | $\stackrel{-}{20}$ |
| 5 | $\begin{aligned} & ? \\ & 0 \\ & 0 \end{aligned}$ | $\underset{21}{ }$ |
| 6 | $\begin{aligned} & \overline{\mathrm{OK}} \\ & 06 \end{aligned}$ | $0$ |
| 7 | $\xrightarrow{0}$ | ${ }_{23}$ |
| 8 | + | ${ }_{24}$ |
| 9 | $\xrightarrow[09]{ }$ | ${ }_{25}$ |
| A | $\stackrel{\bigcirc}{10}$ | 26 |
| B | $\dagger$ | $\underset{\sim}{\square}$ |
| C | $\underset{12}{\sim}$ | ${ }_{28}^{9}$ |
| D | 4 | [ ${ }^{1}$ |
| E |  | $\square$ |
| F | $\frac{\text { 关 }}{15}$ | $\square_{31}$ |



NOTE: Only characters that are not associated with a specific APC function are displayed on the screen.

Table D-4 Quick Reference Guide for ASCII Special Character/APC Special Character Association

| ASCII SPECIAL CHARACTER | APC SPECIAL CHARACTER |
| :---: | :---: |
| NUL |  |
| SOH | $\checkmark$ |
| STX | $\checkmark$ |
| ETX | $\infty$ |
| EOT | z |
| ENQ | $\square$ |
| ACK | OK |
| BEL | 0 |
| BS | + |
| HT | $\Rightarrow$ |
| LF | $\diamond$ |
| VT | $\downarrow$ |
| FF | $\checkmark$ |
| CR | $\leftarrow$ |
| SO | 옻 |
| SI | 因 |
| DLE | $\square$ |
| DC1 |  |
| DC2 | - |
| DC3 | - |
| DC4 | $\div$ |
| NAK | $\times$ |
| SYN | 0 |
| ETB | $\square$ |
| CAN | $\square$ |
| EM | ■ |
| SUB |  |
| ESC | $\square$ |
| FS | 日 |
| GS | [9] |
| RS | $\square$ |
| US | $\square$ |
| ${ }_{\text {DPL }}$ |  |

NOTE: Characters associated with a specific APC function are not displayed.


NOTE: Characters associated with a specific APC function are not displayed.
A. UNSHIFTED (SHIFT KEY UP)


Graphics
Character

B. SHIFTED (SHIFT KEY DOWN)

NOTES: 1 GRPHI CHARACTERS ARE PRODUCED WHEN THE GRPH1 KEY IS PRESSED.

2 GRAPHICS SYMBOLS ASSOCIATED WITH A SPECIFIC APC FUNCTION ARE NOT DISPLAYED ON THE SCREEN. INSTEAD, THE FUNCTION IS PERFORMED.

3 THE ALPHANUMERIC SYMBOLS ASSOCIATED WITH THE GRAPHIC SYMBOLS ARE THE HEXADECIMAL (HEX) CODES GENERATED BY PRESSING THE KEYS.

Figure D-1 APC GRPH1 Characters

A. UNSHIFTED (SHIFT KEY UP)


NOTE: GRPH2 CHARACTERS ARE PRODUCED WHEN THE GRPH2 KEY IS PRESSED

Figure D-2 APC GRPH2 Characters



| $\begin{aligned} & \text { INS } \\ & \text { (IC) } \end{aligned}$ | (2F) | $\begin{array}{\|c} \left\lvert\, \begin{array}{c} \text { CLEAR } \\ \text { HOME } \\ (1 \mathrm{E}) \end{array}\right. \end{array}$ | $\begin{array}{r} \text { PRINT } \\ \text { (ID) } \end{array}$ | BREAK$\mathrm{STOP}_{(13)}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DEL <br> (18) | $(2 \mathrm{~A})$ | (37) | (38) | $\begin{gathered} 9 \\ (39) \end{gathered}$ | (2D) |
|  | (0B) | $4$ (34) | $\begin{gathered} 5 \\ (35) \end{gathered}$ | $\begin{gathered} 6 \\ (36) \end{gathered}$ | (2B) |
| $\stackrel{\leftarrow}{(\mathrm{ID})}$ | $\overrightarrow{(0 \mathrm{C})}$ | (31) | $\begin{gathered} \hline 2 \\ (32) \end{gathered}$ | $\begin{gathered} \hline 3 \\ (33) \end{gathered}$ | $\begin{aligned} & \mathrm{E} \\ & \mathrm{~N} \\ & \mathrm{~T} \end{aligned}$ |
|  | (0A) | 0 | (30) | (2E) | $\begin{aligned} & \mathrm{E} \\ & \mathrm{E} \\ & \mathrm{R} \end{aligned}$ |


$\square$ LOCKABLE SWITCH KEYS

NOTES: 1. HEX NUMBERS IN PARENTHESES DESIGNATE HEX CODES
2. FOR HEX CODES OF STANDARD ALPHANUMERIC CHARACTERS, SEE TABLE D-1.
3. KEYS WITH $\left(^{*}\right)$ MUST BE USED WITH ANOTHER KEY TO GENERATE A CODE
4. "SHIFT" OR "CTRL" PLUS "BREAK STOP" GENERATES HEX CODE 03.
5. KEYS WITH (**) (PFI7 TO PF22) GENERATE THE SPECIAL CODES SHOWN BELOW.

|  | PF17 | ESCOO |
| :--- | :--- | :--- |
|  | PF18 | ESCOP |
|  | PF19 | ESCOQ |
|  | PF20 | ESCOR |
|  | PF21 | ESCOS |
|  | PF22 | ESCOT |
| FNC | PF17 | ESCOU |
| FNC | PF18 | ESC O'V |
| FNC | PF19 | ESC OW |
| FNC | PF20 | ESC O'X |
| FNC | PF21 | ESC O'Y |
| FNC | PF22 | ESC OZ |

Figure D-3 Keyboard Layout Showing Hex Codes For Special Keys

## Appendix E

## I/O Port Addresses and Instructions

The I/O port addresses and instructions for all devices are listed in Tables E-1 to E-21.

Data bus bit descriptions are listed left to right as Bits 7 through 0 for low order bytes and Bits 15 through 8 for high order bytes.

Table E-1 I/O Port Address and Instructions for the DMA Controller

| INSTRUCTION | READ/ WRITE | I/O <br> ADDRESS | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CH0 Address Read | R | 01 | $\begin{aligned} & \text { A7 } \\ & \text { A15 } \end{aligned}$ | $\begin{aligned} & \text { A6 } \\ & \text { A14 } \end{aligned}$ | $\begin{aligned} & \text { A5 } \\ & \text { A13 } \end{aligned}$ | $\begin{aligned} & \text { A4 } \\ & \text { A12 } \end{aligned}$ | $\begin{aligned} & \text { A3 } \\ & \text { A11 } \end{aligned}$ | $\begin{aligned} & \text { A2 } \\ & \text { A10 } \end{aligned}$ | $\begin{aligned} & \text { A1 } \\ & \text { A9 } \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { A8 } \end{aligned}$ |
| CH0 Address Write | w | 01 | $\begin{aligned} & \text { A7 } \\ & \text { A15 } \end{aligned}$ | $\begin{aligned} & \text { A6 } \\ & \text { A14 } \end{aligned}$ | $\begin{aligned} & \text { A5 } \\ & \text { A13 } \end{aligned}$ | $\begin{aligned} & \text { A4 } \\ & \text { A12 } \end{aligned}$ | $\begin{aligned} & \text { A3 } \\ & \text { A11 } \end{aligned}$ | $\begin{aligned} & \text { A2 } \\ & \text { A10 } \end{aligned}$ | $\begin{aligned} & \text { A1 } \\ & \text { A9 } \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { A8 } \end{aligned}$ |
| CH0 Word Count R. | R | 11 | $\begin{aligned} & \text { W7 } \\ & \text { W15 } \end{aligned}$ | W6 W14 | W5 W13 | W4 W12 | $\begin{aligned} & \text { W3 } \\ & \text { W11 } \end{aligned}$ | $\begin{aligned} & \text { W2 } \\ & \text { W10 } \end{aligned}$ | $\begin{aligned} & \text { W1 } \\ & \text { w9 } \end{aligned}$ | $\begin{aligned} & \text { w0 } \\ & \text { w8 } \end{aligned}$ |
| CH0 Word Count W. | w | 11 | $\begin{aligned} & \text { W7 } \\ & \text { W15 } \end{aligned}$ | W6 <br> W14 | $\begin{aligned} & \text { W5 } \\ & \text { W13 } \end{aligned}$ | $\begin{aligned} & \text { W4 } \\ & \text { W12 } \end{aligned}$ | $\begin{aligned} & \text { W3 } \\ & \text { W11 } \end{aligned}$ | $\begin{aligned} & \text { W2 } \\ & \text { W10 } \end{aligned}$ | $\begin{aligned} & \text { W1 } \\ & \text { w9 } \end{aligned}$ | $\begin{aligned} & \text { w0 } \\ & \text { w8 } \end{aligned}$ |
| CH1 Address Read | R | 03 | $\begin{aligned} & \text { A7 } \\ & \text { A15 } \end{aligned}$ | $\begin{aligned} & \text { A6 } \\ & \text { A14 } \end{aligned}$ | $\begin{aligned} & \text { A5 } \\ & \text { A13 } \end{aligned}$ | $\begin{aligned} & \text { A4 } \\ & \text { A12 } \end{aligned}$ | $\begin{aligned} & \text { A3 } \\ & \text { A11 } \end{aligned}$ | $\begin{aligned} & \text { A2 } \\ & \text { A10 } \end{aligned}$ | $\begin{aligned} & \text { A1 } \\ & \text { A9 } \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { A8 } \end{aligned}$ |
| CH1 Address Write | w | 03 | $\begin{aligned} & \text { A7 } \\ & \text { A15 } \end{aligned}$ | $\begin{aligned} & \text { A6 } \\ & \text { A14 } \end{aligned}$ | $\begin{aligned} & \text { A5 } \\ & \text { A13 } \end{aligned}$ | $\begin{aligned} & \mathrm{A} 4 \\ & \mathrm{~A} 12 \end{aligned}$ | $\begin{aligned} & \text { A3 } \\ & \text { A11 } \end{aligned}$ | $\begin{aligned} & \text { A2 } \\ & \text { A10 } \end{aligned}$ | $\begin{aligned} & \text { A1 } \\ & \text { A9 } \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { A8 } \end{aligned}$ |
| CH1 Word Count R. | R | 13 | W7 <br> W15 | W6 <br> W14 | W5 W13 | W4 W12 | $\begin{aligned} & \text { W3 } \\ & \text { W11 } \end{aligned}$ | $\begin{aligned} & \text { W2 } \\ & \text { W10 } \end{aligned}$ | $\begin{aligned} & \text { W1 } \\ & \text { W9 } \end{aligned}$ | $\begin{aligned} & \text { w0 } \\ & \text { w8 } \end{aligned}$ |
| CH1 Word Count W. | w | 13 | W7 <br> W15 | W6 <br> W14 | W5 <br> W13 | $\begin{aligned} & \text { W4 } \\ & \text { W12 } \end{aligned}$ | $\begin{aligned} & \text { W3 } \\ & \text { W11 } \end{aligned}$ | $\begin{aligned} & \text { W2 } \\ & \text { W10 } \end{aligned}$ | $\begin{aligned} & \text { W1 } \\ & \text { W9 } \end{aligned}$ | $\begin{aligned} & \text { w0 } \\ & \text { w8 } \end{aligned}$ |
| CH2 Address Read | R | 05 | $\begin{aligned} & \text { A7 } \\ & \text { A15 } \end{aligned}$ | $\begin{aligned} & \text { A6 } \\ & \text { A14 } \end{aligned}$ | $\begin{aligned} & \text { A5 } \\ & \text { A13 } \end{aligned}$ | $\begin{aligned} & \text { A4 } \\ & \text { A12 } \end{aligned}$ | $\begin{aligned} & \text { A3 } \\ & \text { A11 } \end{aligned}$ | $\begin{aligned} & \text { A2 } \\ & \text { A10 } \end{aligned}$ | $\begin{aligned} & \text { A1 } \\ & \text { A9 } \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { A8 } \end{aligned}$ |
| CH2 Address Write | w | 05 | $\begin{aligned} & \text { A7 } \\ & \text { A15 } \end{aligned}$ | $\begin{aligned} & \text { A6 } \\ & \text { A14 } \end{aligned}$ | $\begin{aligned} & \text { A5 } \\ & \text { A13 } \end{aligned}$ | $\begin{aligned} & \text { A4 } \\ & \text { A12 } \end{aligned}$ | $\begin{aligned} & \text { A3 } \\ & \text { A11 } \end{aligned}$ | $\begin{aligned} & \text { A2 } \\ & \text { A10 } \end{aligned}$ | $\begin{aligned} & \text { A1 } \\ & \text { A9 } \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { A8 } \end{aligned}$ |
| CH2 Word Count R. | R | 15 | W7 <br> W15 | W6 <br> W14 | $\begin{aligned} & \text { W5 } \\ & \text { W13 } \end{aligned}$ | $\begin{aligned} & \text { W4 } \\ & \text { W12 } \end{aligned}$ | $\begin{aligned} & \text { W3 } \\ & \text { W11 } \end{aligned}$ | $\begin{aligned} & \text { W2 } \\ & \text { W10 } \end{aligned}$ | $\begin{aligned} & \text { W1 } \\ & \text { W9 } \end{aligned}$ | $\begin{aligned} & \text { w0 } \\ & \text { w8 } \end{aligned}$ |
| CH2 Word Count W. | w | 15 | $\begin{aligned} & \text { W7 } \\ & \text { W15 } \end{aligned}$ | $\begin{aligned} & \text { W6 } \\ & \text { W14 } \end{aligned}$ | $\begin{aligned} & \text { W5 } \\ & \text { W13 } \end{aligned}$ | $\begin{aligned} & \text { W4 } \\ & \text { W12 } \end{aligned}$ | $\begin{aligned} & \text { W3 } \\ & \text { W11 } \end{aligned}$ | $\begin{aligned} & \text { W2 } \\ & \text { W10 } \end{aligned}$ | $\begin{aligned} & \text { W1 } \\ & \text { W9 } \end{aligned}$ | $\begin{aligned} & \text { w0 } \\ & \text { w8 } \end{aligned}$ |
| CH3 Address Read | R | 07 | $\begin{aligned} & \text { A7 } \\ & \text { A15 } \end{aligned}$ | $\begin{aligned} & \text { A6 } \\ & \text { A14 } \end{aligned}$ | $\begin{aligned} & \text { A5 } \\ & \text { A13 } \end{aligned}$ | $\begin{aligned} & \text { A4 } \\ & \text { A12 } \end{aligned}$ | $\begin{aligned} & \text { A3 } \\ & \text { A11 } \end{aligned}$ | $\begin{aligned} & \text { A2 } \\ & \text { A10 } \end{aligned}$ | $\begin{aligned} & \text { A1 } \\ & \text { A9 } \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { A8 } \end{aligned}$ |
| CH3 Address Write | w | 07 | $\begin{aligned} & \text { A7 } \\ & \text { A15 } \end{aligned}$ | $\begin{aligned} & \text { A6 } \\ & \text { A14 } \end{aligned}$ | $\begin{aligned} & \text { A5 } \\ & \text { A13 } \end{aligned}$ | $\begin{aligned} & \text { A4 } \\ & \text { A12 } \end{aligned}$ | $\begin{aligned} & \text { A3 } \\ & \text { A11 } \end{aligned}$ | $\begin{aligned} & \text { A2 } \\ & \text { A10 } \end{aligned}$ | $\begin{aligned} & \text { A1 } \\ & \text { A9 } \end{aligned}$ | $\begin{aligned} & \text { A0 } \\ & \text { A8 } \end{aligned}$ |

Table E-1 I/O Port Address and Instructions for the DMA Controller (cont'd)

| INSTRUCTION | READ/ <br> WRITE | $\mathrm{I} / \mathrm{O}$ <br> ADDRESS | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CH3 Word Count | R | 17 | W7 <br> W15 | W6 <br> W14 | W5 <br> W13 | W4 <br> W12 | W3 <br> W11 | W2 <br> W10 | $\begin{aligned} & \text { W1 } \\ & \text { W9 } \end{aligned}$ | $\begin{aligned} & \text { W0 } \\ & \text { W8 } \end{aligned}$ |
| CH3 Word Count | W | 17 | W7 <br> W15 | W6 <br> W14 | W5 <br> W13 | W4 <br> W12 | W3 <br> W11 | W2 <br> W10 | W1 W9 | $\begin{aligned} & \text { W0 } \\ & \text { W8 } \end{aligned}$ |
| DMA Status Read | R | 09 | RQ3 | RQ2 | RQ1 | RQ0 | TC3 | TC2 | TC1 | TC0 |
| DMA Command Write | W | 09 | KS | DS | WS | PR | TM | CE | AH | MM |
| Illegal | R | 19 | - | - | - | - | - | - | - | - |
| Write Request Register | W | 19 | - | - | - | - | - | RB | CS1 | CS0 |
| Illegal | R | 0B | - | - | - | - | - | - | - | - |
| Write Single Mask | W | 0B | - | - | - | - | - | MK | CS1 | CS0 |
| Illegal | R | 1B | - | - | - | - | - | - | - | - |
| Write Mode | W | 1B | MS1 | MS0 | ID | AT | TR1 | TR0 | CS1 | CS0 |
| Illegal | R | 0D | - | - | - | - | - | - | - | - |
| Clear F/F | W | 0D | - | - | - | - | - | - | - | - |
| Read Temporary Register | R | 1D | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| Master Clear | W | 1D | - | - | - | - | - | - | - | - |
| Illegal | R | 0F | - | - | - | - | - | - | - | - |
| Illegal | W | 0F | - | - | - | - | - | - | - | - |
| Illegal | R | 1F | - | - | - | - | - | - | - | - |
| Write All Mask | W | 1F | - | - | - | - | MB3 | MB2 | MB1 | MB0 |

Table E-2 I/O Port Addresses and Instructions for the Interrupt Controller

| INSTRUCTION | READ/ <br> WRITE | I/O <br> ADDRESS |  |  |  |  |  | DATA BUS |
| :--- | :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Table E-3 I/O Port Addresses and Instructions for the Interval Timer

| INSTRUCTION | READ WRITE | $\begin{gathered} \mathrm{I} / \mathrm{O} \\ \text { ADDRESS } \end{gathered}$ | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Counter 0 | R | 29 | $\begin{aligned} & \mathrm{C} 7 \\ & \mathrm{C} 15 \end{aligned}$ | $\begin{aligned} & \text { C6 } \\ & \text { C14 } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 5 \\ & \mathrm{C} 13 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 4 \\ & \mathrm{C} 12 \end{aligned}$ | $\begin{aligned} & \text { C3 } \\ & \text { C11 } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 2 \\ & \mathrm{C} 10 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{C} 9 \end{aligned}$ | $\begin{aligned} & \text { C0 } \\ & \text { C8 } \end{aligned}$ |
| Load Counter 0 | W | 29 | $\begin{aligned} & \text { C7 } \\ & \text { C15 } \end{aligned}$ | $\begin{aligned} & \text { C6 } \\ & \text { C14 } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 5 \\ & \mathrm{C} 13 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 4 \\ & \mathrm{C} 12 \end{aligned}$ | $\begin{aligned} & \text { C3 } \\ & \text { C11 } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 2 \\ & \mathrm{C} 10 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{C} 9 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 0 \\ & \mathrm{C} 8 \end{aligned}$ |
| Read Counter 1 | R | 2B | $\begin{aligned} & \mathrm{C} 7 \\ & \mathrm{C} 15 \end{aligned}$ | $\begin{aligned} & \text { C6 } \\ & \text { C14 } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 5 \\ & \mathrm{C} 13 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 4 \\ & \mathrm{C} 12 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 3 \\ & \mathrm{C} 11 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 2 \\ & \mathrm{C} 10 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{C} 9 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 0 \\ & \mathrm{C} 8 \end{aligned}$ |
| Load Counter 1 | W | 2B | $\begin{aligned} & \mathrm{C} 7 \\ & \mathrm{C} 15 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 6 \\ & \mathrm{C} 14 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 5 \\ & \mathrm{C} 13 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 4 \\ & \mathrm{C} 12 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 3 \\ & \mathrm{C} 11 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 2 \\ & \mathrm{C} 10 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{C} 9 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 0 \\ & \mathrm{C} 8 \end{aligned}$ |
| Read Counter 2 | R | 2D | $\begin{aligned} & \mathrm{C} 7 \\ & \mathrm{C} 15 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 6 \\ & \mathrm{C} 14 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 5 \\ & \mathrm{C} 13 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 4 \\ & \mathrm{C} 12 \end{aligned}$ | $\begin{aligned} & \text { C3 } \\ & \text { C11 } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 2 \\ & \mathrm{C} 10 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{C} 9 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 0 \\ & \mathrm{C} 8 \end{aligned}$ |
| Load Counter 2 | W | 2D | $\begin{aligned} & \mathrm{C} 7 \\ & \mathrm{C} 15 \end{aligned}$ | $\begin{aligned} & \text { C6 } \\ & \text { C14 } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 5 \\ & \mathrm{C} 13 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 4 \\ & \mathrm{C} 12 \end{aligned}$ | $\begin{aligned} & \text { C3 } \\ & \text { C11 } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 2 \\ & \mathrm{C} 10 \end{aligned}$ | $\begin{aligned} & \mathrm{C} 1 \\ & \text { C9 } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 0 \\ & \mathrm{C} 8 \end{aligned}$ |
| No Operation | R | 2 F | - | - | - | - | - | - | - | - |
| Write Mode | W | 2F | SC1 | SC0 | RL1 | RL0 | M2 | M1 | M0 | BCD |

Table E-4 I/O Port Addresses and Instructions for the Serial I/O Communications Controller Number 1

| INSTRUCTION | READ/ WRITE | I/O <br> ADDRESS | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Data | R | 30 | RD | RD6 | RD5 | RD4 | RD3 | RD2 | RD1 | RD0 |
| Write Data | W | 30 | SD | SD6 | SD5 | SD4 | SD3 | SD2 | SD1 | SD0 |
| Read Status | R | 32 | DR | SYN | FE | OE | PE | TE | RR | TR |
| Write Mode (A) | W | 32 | S2 | S1 | EP | PEN | L2 | L1 | B2 | B1 |
| Write Mode (S) | w | 32 | SCS | ESD | EP | PEN | L2 | L1 | 0 | 0 |
| Write Command | W | 32 | EH | IR | RS | RST | SBR | REN | ER | TEN |
| Write Mask | W | 34 | 0 | 0 | 0 | 0 | 0 | TXE | RXR | TXR |
| Read Signal | R | 34 | - | - | - | - |  |  | CI | CD |
| Write Signal | W | 36 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TDC |
|  | R | 36 |  |  |  |  |  |  |  |  |

Table E-5 I/O Port Addresses and Instructions for the Serial I/O Communications Controller Number 2

| INSTRUCTION | READ/ WRITE | I/O ADDRESS | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Data | R | 31 | RD8 | RD7 | RD6 | RD5 | RD4 | RD3 | RD2 | RD1 |
| Write Data | W | 31 | SD8 | SD7 | SD6 | SD5 | SD4 | SD3 | SD2 | SD1 |
| Read Status | R | 33 | DR | SYN | FE | OE | PE | TE | RRDY | TRDY |
| Write Mode (A) | W | 33 | S2 | S1 | EP | PEN | L2 | L1 | B2 | B1 |
| Write Mode (S) | W | 33 | SCS | ESD | EP | PEN | L2 | L1 | B2 | B1 |
| Write Command | W | 33 | EH | IR | RS | RST | SBR | REN | ER | TEN |
| Write Mask | w | 35 | 0 | 0 | 0 | 0 | 0 | TXE | RXR | TXR |
| Read Signal | R | 35 | - | - | - | - | SCA | CS | CI | CD |
| Write Signal | W | 37 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TDC |

Table E-6 I/O Port Addresses and Instructions for the DMA Address Registers

| INSTRUCTION | READ/ WRITE | I/O <br> ADDRESS | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CH0 Read Address R. | R | 38 |  |  |  |  |  |  |  |  |
| CH0 Write Address R. | W | 38 | 0 | 0 | 0 | 0 | A19 | A18 | A17 | A16 |
| CH1 Read Address | R | 3A |  |  |  |  |  |  |  |  |
| CH1 Write Address R. | W | 3A | 0 | 0 | 0 | 0 | A19 | A18 | A17 | A16 |
| CH2 Read Address | R | 3 C |  |  |  |  |  |  |  |  |
| CH2 Write Address R. | W | 3 C | 0 | 0 | 0 | 0 | A19 | A18 | A17 | A16 |
| CH3 Read Address | R | 3 E |  |  |  |  |  |  |  |  |
| CH3 Write Address R. | W | 3E | 0 | 0 | 0 | 0 | A19 | A18 | A17 | A16 |

Table E-7 I/O Port Addresses and Instructions for the CRT Controller

| INSTRUCTION | READ/ <br> WRITE | I/O <br> ADDRESS | DATA BUS |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Status | R | 40 | LP | HP | VS | DMA DW | FE | FF | DR |  |
| Write Parameter | W | 40 | P7 | P6 | P5 | P4 | P3 | P2 | P1 | P0 |
| Read Data | R | 42 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| Write Command | W | 42 | C7 | C6 | C5 | C4 | C3 | C2 | C1 | C0 |
| Reset Intr. | W | 46 |  |  |  |  | GDC TM | APU | CRT |  |

Table E-8 I/O Port Addresses and Instructions for the Graphics Display Controller

| INSTRUCTION | READ/ <br> WRITE | I/O <br> ADDRESS |  |  |  | DATA BUS |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Status | R | 70 | LP | HB | VS | DMA DW | FE | FF | DR |  |
| Write Parameter | W | 70 | P 7 | P6 | P5 | P4 | P3 | P2 | P1 | P0 |
| Read Data | R | 72 | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 |
| Write Command | W | 72 | C 7 | C 6 | C 5 | C 4 | C 3 | C 2 | C 1 | C 0 |
| Graph Enable | W | 76 | - | - | - | - | - | - | - | $1 / 0$ |

NOTE: For Graph Enable, $1=$ Release From Blanking Status; $0=$ Blanking Always. At power on, Blanking Always is selected.

Table E-9 I/O Port Addresses and Instructions for the Keyboard Controller

| INSTRUCTION | READ/ <br> WRITE | I/O <br> ADDRESS | DATA BUS |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Data | R | 48 | SD8 | SD7 | SD6 | SD5 | SD4 | SD3 | SD2 | SD1 |
| Buzzer Set | W | 48 | - | - | - | - | - | - | - | - |
| Read Status | R | 4 A |  |  |  |  | TP2 | TP1 | TP0 | ALM |
| Buzzer Reset | W | 4A | - | - | - | - | - | - | - | - |
| Read Signal | R | 4C | SW8 | SW7 | SW6 | SW5 | SW4 | SW3 | SW2 | SW1 |
| Read Book/Page | R | 4E | B4 | B3 | B2 | B1 | P4 | P3 | P2 | P1 |
| Read Shift | R | $4 E$ | 0 | 0 | 0 | 0 | SF4 | SF3 | SF2 | SF1 |

Table E-10 I/O Port Addresses and Instructions for the FDD Controller

| INSTRUCTION | $\begin{aligned} & \text { READ/ } \\ & \text { WRITE } \end{aligned}$ | I/O <br> ADDRESS | DATA BUS |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Status | R | 50 | RQM DIO | NDM | FCB | F3B | F2B | F1B | F0B |
| Read Data | R | 52 | D7 D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| Write Command | W | 52 | C7 C6 | C5 | C4 | C3 | C2 | C1 | C0 |

Table E-11 I/O Port Addresses and Instructions for the Clock and Calendar

| INSTRUCTION | READ/ <br> WRITE | I/O <br> ADDRESS | DATA BUS |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Data | R | 58 | - | - | - | - | - | - | BATTDO |
| Set Register | W | 58 | 0 | 0 | DI | CLK | STB | C2 | C1 |
|  |  | C0 |  |  |  |  |  |  |  |

Table E-12 I/O Port Address and Instruction for the BBM Enable

| INSTRUCTION | READ <br> WRITE | I/O <br> ADDRESS | DATA BUS |  |
| :--- | :---: | :---: | :---: | :---: |
| BBM Enable | W | 59 |  | ENB |

Table E-13 I/O Port Addresses and Instructions for the APU

| INSTRUCTION | READ WRITE | $\begin{gathered} \mathrm{I} / \mathrm{O} \\ \text { ADDRESS } \end{gathered}$ | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Data | R | 5A | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| Write Data | W | 5A | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| Read Status | R | 5E | B | S | Z | E3 | E2 | E1 | E0 | CRY |
| Write Command | W | 5E | C7 | C6 | C5 | C4 | C3 | C2 | C1 | C0 |

Table E-14 I/O Port Address and Instruction for the Power Off Control

| INSTRUCTION | READ <br> WRITE | I/O <br> ADDRESS | DATA BUS |  |
| :---: | :---: | :---: | :---: | :---: |
| Power Off | W | $5 B$ |  | OFF |

Table E-15 I/O Port Addresses and Instructions for the Sound Control

| INSTRUCTION | READ/ WRITE | I/O <br> ADDRESS | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write Command | w | 60 | 0 | FS | C5 | C4 | C3 | C2 | C1 | C0 |
| Read Status | R | 60 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 |

Table E-16 I/O Port Addresses and Instructions for the Timer


Table E-17 I/O Port Addresses and Instructions for the ODA Controller Number 1

| INSTRUCTION | READ/ <br> WRITE | I/O <br> ADDRESS | DATA BUS |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

Table E-18 I/O Port Addresses and Instructions for the IDA Controller

| INSTRUCTION | READ/ WRITE | $\begin{gathered} \text { I/O } \\ \text { ADDRESS } \end{gathered}$ | DATA BUS |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read Signal | R | 71 | $\overline{\mathrm{DCN}}$ IP3 | IP2 | PSM | $\overline{\text { SMR }}$ | IP1 | SDRQ | STT |
| Read Data | R | 73 | SD8 SD7 | SD6 | SD5 | SD4 | SD3 | SD2 | SD1 |
| Write Signal 2 | W | 75 | IRT SDR | SMS | MASK |  |  |  |  |
| Write Signal 0 | w | 77 | 10 | 0 | 1 | 0 | 1 | 1 | 0 |
| Write Signal 1 | w | 77 | 00 | 0 | 0 | 0 | 1 | 0 | INTE |
| Write Signal 1 | w | 77 | 00 | 0 | 0 | 1 | 0 | 0 | MASK |
| Write Signal 1 | W | 77 | 00 | 0 | 0 | 1 | 0 | 1 | SMS |
| Write Signal 1 | w | 77 | 00 | 0 | 0 | 1 | 1 | 0 | SDR |
| Write Signal 1 | W | 77 | 00 | 0 | 0 | 1 | 1 | 1 | IRT |
| Write Signal 3 | W | 79 |  |  |  |  |  |  | SDA |

Table E-19 I/O Port Addresses and Instructions for the Communications Adapter

| INSTRUCTION | READ/ <br> WRITE | I/O <br> ADDRESS |  |  |  | DATA BUS |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write BUF1 | W | 80 | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 |
| Read BUF4 | R | 80 | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 |
| Write BUF2 | W | 82 | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 |
| Read BUF5 | R | 82 | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 |
| Write BUF3 | W | 84 | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 |
| Read BUF6 | R | 84 | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 |
| Start DMA | W | 86 | - | - | - | - | - | - | - | - |
| Set INT1 | W | 88 | - | - | - | - | - | - | - | - |
| Reset INT2 | W | 8 A | - | - | - | - | - | - | - | - |
| Reset SDMA INT | W | 8 C | - | - | - | - | - | - | - | - |
| Reset RDMA INT | W | 8 E | - | - | - | - | - | - | - | - |
| Read INT | R | 90 | - | - | - | - | INT1 INT2 | MSDE | MRDE |  |

Table E-20 I/O Port Addresses and Instructions for the ASOP Controller

| INSTRUCTION | READ/ <br> WRITE | I/O <br> ADDRESS | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Low Address Set | W | F0 | SA7 | SA6 | SA5 | SA4 | SA3 | SA2 | SA1 | SA0 |
| Mid Address Set | W | F2 | SA1 | SA14 | SA13 | SA12 | SA11 | SA10 | SA9 | SA8 |
| High Address Set | W | F4 |  |  |  |  | SA19 | SA18 | SA17 | SA16 |
| Mask Set | W | F6 |  |  |  |  |  |  |  | MASK |
| Read Signal | h | F6 |  |  |  |  |  |  | R/W | INT |

## Appendix F

## Hardware Specifications

FEATURE
CPU*
Word Length
Clock Rate
ROM*
RAM
Standard Size*
Maximum Size
Memory with Battery Backup*

SPECIFICATION
NEC $\mu$ PD 8086
16 bits
5 MHz
8 K (bootstrap and self-test)
64K chips, 200 ns Access Time
128 KB
256 KB
4 K (CMOS)
Two-year life
Can be protected against accidental writing

Parallel
Asynchronous and Synchronous at speeds up to $19,200 \mathrm{bps}$
Software Emulators for all important IBM Workstations and Communications subsystems
Second RS-232C Port

Other Standard Features*
Music

Pitch Range: $2+$ Octaves
Number of Tempos: 4
Note Duration: thirty-second to whole Dynamics: piano, medium, forte accent
*Standard Feature, included with Basic Unit

## FEATURE

SPECIFICATION

| Other Standard Features* (cont.) | Pitch: 4 selectable frequencies <br> Alarm <br> Length: 20 ms or continuous |
| :--- | :--- |
| Loudness: 3 levels |  |
| Clock/Calendar <br> Automatic Power Off <br> Lithium Battery | Hardware (with battery backup) <br> Can be initiated locally or remotely |
|  | Backs up CMOS RAM and <br> Clock/Calendar |
|  | Two-year life |

FEATURE
Display Screen* (cont.)
Character Graphics*
Line Drawing
Keyboard*
Number of Keys
(excluded in Programmable
Function Keys)
Number of Programmable
Function Keys
Numeric Pad
Standard Printer
Type
Speed
Controller*
Dimensions
Main Enclosure $\quad 19.7$ in. $(50 \mathrm{~cm})$ wide x $13.8 \mathrm{in} .(35 \mathrm{~cm})$

Keyboard

86 high x
monochrome: 18.1 in . $(46 \mathrm{~cm}$ ) deep
color: 19.9 in . ( 50.5 cm ) deep.

## SPECIFICATION

Overline, underline, vertical line, highlight, inverse video, blinking, secret
Line segment, rectangle, arc, circle

22, Dual Mode (effectively, 44)
Standard

Dot Matrix
100 Characters per second Standard
9.7 in . $(50 \mathrm{~cm}$ ) wide $\times 2.4 \mathrm{in}$. $(6 \mathrm{~cm})$ high x 9.1 in. $(23 \mathrm{~cm})$ deep
*Standard Feature, included with Basic Unit

## Glossary

## A Abbreviation for Ampere.

AD0 to AD15 Address and Data lines 0 to 15; bus interface channels. See Chapter 2 for information.

Address Bus A set of parallel conductors that carry address codes from the microprocessor to memory and I/O devices.

## ALE Address Latch Enable.

AND A logic operator having the property that if P is a statement, Q is a statement, R is a statement..., then the AND of $\mathrm{P}, \mathrm{Q}, \mathrm{R} . .$. is true if and only if all statements are true, false if any statement is false.

ANSI American National Standards Institute; an organization that develops and publishes industry standards, including terminology and standard codes.

## APC Advanced Personal Computer.

ASCII American Standard Code for Information Interchange; this standard defines character set codes that are used for data interchange between equipment of different manufacturers. This code defines 96 displayed characters ( 64 without lowercase) and 32 non-displayed controls in terms of 7 bits (plus an eighth bit for parity check).

Assembler A computer program that prepares a machine-language program from a symbolic language program.

Asynchronous Without relation to a regular time period.

Asynchronous Communications A method of transmitting data in which the timing of character placement on connecting transmitting lines is not critical. The transmitted characters are preceded by a start bit and followed by one or more stop bits; this designates individual characters and allows the interval between characters to vary.

Attribute, Character In the APC, one of eight supplements that can accompany a character on the display screen.

A16 to A19 Address bits 16 to 19; bus interface channels.
BASIC Beginner's All-purpose Symbolic Instruction Code; a common, highlevel, numerical-application-oriented, computer program language that is easily learned.

Baud (1) A unit of signaling speed equal to the number of discrete conditions or signal events per second. For example, one baud equals one-half dot cycle per second in Morse code, one bit per second in a train of binary signals, and one 3-bit value per second in a train of signals each of which can assume one of eight different states. (2) In asynchronous transmission, the baud is a unit of modulation rate that equals the unit intervals.

BBM Battery-Backed Memory.
BHE Bus High Enable; a bus-interface channel. See Chapter 2.
Binary (1) A condition that can have exactly two values; for example, ON and OFF, 1 and 0.(2) A numbering system that includes the digits zero and one and uses two as its base; that is, the base-2 numbering system.

Binary-Coded Decimal (BCD) Positional notation in which the individual decimal digits are represented by a set of four binary numerals; for example, the number twenty-three is represented by 00100011 in binary-coded decimal notation, and by 10111 in binary notation.

Bootstrap A technique or device designed to bring itself into a desired state by means of its own action; for example, a machine routine whose first few instructions are sufficient to bring the rest of itself into the computer from an input device.

Buffer A temporary storage area between devices used to compensate for differences in data flow rates or in the occurrence of events; a storage area that temporarily holds input or output data.

Bus A number of parallel conductors (usually 8 or 16 , sometimes 20 ) used for transmitting data signals or power; for example, address bus, data bus.

Byte A sequence of adjacent binary digits (eight digits in most machines including the APC) operated upon as a unit and usually shorter than a computer word (a word is composed of two bytes in the APC).

C/ $\overline{\mathbf{D}}$ (CONTROL/ $\overline{\mathbf{D A T A}})$ An input signal of the NEC 8251 A Communications Controller. See Chapter 3.

Central Processing Unit (CPU) (1) A unit of a computer that includes the circuits controlling the interpretation and execution of instructions. (2) In the APC, the NEC $\mu$ PD8086 microprocessor.

Chip A tiny piece of semiconductor material on which microscopic electronic components are photoetched to form one or more circuits. After connector leads and a case are added, it is called an integrated circuit.

CLKO Communications Clock; a bus-interface channel. See Chapter 2.
COBOL Common Business Oriented Language; a business data processing language.

Clock (1) The basic source of synchronizing signals in the microcomputer; PHIO in the APC. (2) In data communications, the clock - CLK0 in the APC - that controls the timing of signal sending and receiving.

CMOS Complementary Metal Oxide Semiconductor
Code (1) A system for representing data according to unambiguous rules; e.g. a binary decimal code. (2) Within a given machine or storage location, a system of binary digits given certain arbitrary meanings, used for transmitting information; for example, in the APC, character code, character-attribute code, command code. (3) To change the symbolic representation of data or commands in order to make them conform to such a system.

Communications Refers to communication between computers or between computers and terminals. Information is transmitted with synchronous or asynchronous timing, and in serial-data or parallel-data form.

Computer A data processor capable of high-speed mathematical or logical calculations, able to assemble, store, and otherwise process information derived from coded data in accordance with a predetermined program.

CP/M Control Program For Microprocessors; a registered trademark of Digital Research, an operating system that comprises four subsystems: basic inputoutput system (BIOS), basic disk-operating system (BDOS), console command processor (CCP), and transient program area (TPA). Programs that are created, edited, debugged, assembled, and executed on one CP/M-based configuration run on all $\mathrm{CP} / \mathrm{M}$-based configurations. $\mathrm{CP} / \mathrm{M}$ is thus a standard interface between user programs and system hardware. Among the high-level languages that currently run with CP/M are BASIC, COBOL, FORTRAN, Pascal, APL, and PL/1.

CRT Cathode Ray Tube; a vacuum tube in which electrons are accelerated to and focused upon a fluorescent screen.

CRT Display Unit In the APC, the equipment that receives data and transforms it into visible images on the CRT display screen. Specifically, the unit includes a cathode ray tube, display control, display screen, horizontal driver, and vertical driver.

## CS Code Segment

$\overline{C S}$ (Chip Select) An input signal of the Intel 8251A Communications Controller. See Chapter 3.

DACK0 to DACK3 DMA-request Acknowledgement 0 through 3; bus-interface channels. See Chapter 2.

Data (1) A representation of facts, concepts, or instructions in a formalized manner suitable for communication, interpretation, or processing by humans or automatic means. (2) Any representations such as characters or analog quantities to which meaning is or might be assigned.

DIP Dual In-Line Package; a popular IC packaging container that has two parallel rows (hence dual) of leads, which connect the unit to a circuit board. They are available in a variety of configurations, from 14 -pin to 40 -pin assemblies.

Disk, Flexible A type of magnetic disk, so named because it is soft and bends easily; also called floppy disk.

Disk, Hard Conventional magnetic disk that is stiffer than a flexible disk, contains more concentrated data, and can be read faster.

Disk, Magnetic A flat circular plate with a magnetic surface on which data can be stored by selective magnetization of portions of the flat surface.

Display Position A unit on the video display screen capable of containing one character; that is, each display unit holds one character box. The APC video display has 25 lines of 80 display positions; and each display position is composed of an $8 \times 19$ dot matrix.

DMA Direct Memory Access; high-speed data transfer operation in which an I/O channel transfers information directly to or from the memory. Transfers take place with no microprocessor intervention using a "cycle-stealing" method. Also called "data break."

DMC DMA Cycle; a bus-interface channel. See Chapter 2.
Double Density Refers to a type of magnetic disk storage organization in which 256 characters of information are stored on each sector of a track. Compare with single density.

DRQ0 to DRQ3 DMA Request 0 to 3, bus interface channels. See Chapter 2.

## DS Data Segment

DT/R Data Transmit or Receive; a bus-interface channel. See Chapter 2.
EIA Electronics Industries Association; an electronics trade association that formulates and establishes industry standards.

EPROM Erasable Programmable Read-Only Memory. Like a PROM, it is a programmable read-only memory, but unlike an ordinary PROM its contents can be erased and rewritten more than once. Like any ROM device, an EPROM retains its contents indefinitely.

FDC Flexible Disk Controller.
FDD Flexible Disk Drive.
FIFO First-In First-Out.
Firmware Refers to microprocessors and other software that have been permanently written into ROM chips; for example, the bootstrap loader is a firmware program.

Fixed-Point Arithmetic Computer calculations in which the computer does not consider the radix point. Compare floating-point arithmetic.

Flag An indicator used to specify the status of a designated condition. A flag is usually one or two bits and can be hardware- or software-implemented.

Floating-Point Arithmetic Arithmetic procedures in which the computer keeps track of the radix point. Compare fixed-point arithmetic.

FM Frequency Modulation.
Full Duplex In communications, pertains to simultaneous two-way independent transmission in both directions; also called duplex. Compare with half duplex.

GDC Graphic Display Controller.
Half Duplex In communications, pertains to an alternate, one-way-at-a-time independent transmission. Compare with full duplex.

Hexadecimal (HEX) Refers to the number system with 16 as its base. The hexadecimal system uses 16 symbols: 0 to 9 , and A to F for the base- 10 numbers 10 to 15 . One hexadecimal digit can be represented by four bits.

Hertz (Hz) A unit of frequency equal to one cycle per second.

Highlighting A method used to distinguish or emphasize data on a CRT Display. There are a number of methods: reversing the field, blinking, underlining, changing color, changing light intensity, or some combination of these. The APC features all of these highlighting methods.

High-Order Position In this manual (and in general), the left-most position in a string of digits, characters, or bytes. A high-order position is more significant than a low-order position.

ICW Initialization Command Word.
Impact Printer A printer that forms characters by physically striking the paper through a ribbon; for example, conventional typewriters print this way.

Input/Output (I/O) Pertaining to a hardware device that can transmit data into or receive data from a computer.

Integrated Circuit (IC) A microunit consisting of interconnected elements, inseparably associated and formed on or within a single substrate to function as an electronic circuit.

Intel A large semiconductor designer, manufacturer, and distributor.
Interlace To assign successive storage location numbers to physically separate storage locations; this reduces access time.

Interrupt (1) A suspension of the normal flow of a process in such a way that the flow can be resumed. (2) A special control signal from an I/O device that diverts the attention of the CPU from the program to a specific address.

IOR I/O Read; a bus-interface channel. See Chapter 2.
IOW I/O Write; a bus-interface channel. See Chapter 2.
IP Instruction Pointer.
IR0 to IR14 Interrupt Request 0 to 14 ; bus-interface channels. See Chapter 2.
IRR Read Interrupt Register.
IRST Initial Reset; a bus-interface channel. See Chapter 2.

K Abbreviation for kilo. (1) Prefix meaning 1000. (2) With regard to memory space and addressing, kilo means 1024 (2 to the 10th power); for example 2 K equals 2048.

KB Abbreviation for kilobyte; 1024 bytes.
$\mathbf{k H z}$ Abbreviation for kilohertz; a unit of frequency equal to 1000 hertz.
LAD Light Pen Address.
Low-Order Position The left-most position in a string of digits, characters, or bytes. A low-order position is less significant than a high-order position.

## LSB Least Significant Bit.

LSI Large Scale Integration; (1) Refers to a component density of 100 or more per chip. (2) A chip with more than 100 components.

M Abbreviation for mega. (1) Prefix meaning $1,000,000$. (2) With regard to memory space and addressing, mega means $1,048,576$ ( 2 to the 20th power); for example, one MB equals one megabyte, $1,048,576$ bytes.

Machine Language Binary-coded language; the only type of language that can be directly used by the machine.

Main Unit In the APC, the Main Unit houses all the microcomputer devices except the Keyboard and Printer. In addition, all interfaces are in or on this unit.

Matrix Printer A printer that forms characters by printing a pattern of dots.
MB Megabyte; $1,048,576$ bytes. The addressing power of the APC.
Memory Address (1) The unique location of a word in memory. (2) In the APC, a 20 -bit value that identifies a specific portion of memory.

Memory Map A symbolic representation of memory locations that defines the boundaries of various memory segments.

MFM Modified Frequency Modulation; a magnetic-disk coding system that uses double-density encoding of information.

MHz Megahertz; a unit of frequency equal to one million hertz.
Microprocessor (1) The principal component of a microcomputer, it is a semiconductor central processing unit. Usually contained on a single chip, which is mounted on a DIP, it includes an arithmetic logic unit, control logic, and control-memory unit. (2) In the APC, the microprocessor is the NEC $\mu$ PD8086, which is mounted on a 40 -pin DIP.

Mnemonic An abbreviation of two or three letters (abbreviated in a way to aid human memory) that is used instead of terminology.

Mode Refers to various methods of operation; for example, the synchronous versus the asynchronous mode.

Modem MOdulator-DEModulator; a device that modulates signals transmitted over communication facilities. This device enables computers and terminals to communicate over telephone circuits.

Monitor (1) A device that observes and verifies the operation of a data processing system and indicates any significant departure from the norm. (2) Software or hardware that observes, supervises, controls, or verifies the operation of a system. (3) A video display.

MOS Metal Oxide Semiconductor.
Mother Board A circuit board into which various printed circuit boards (PCB) are plugged. In the APC, the Mother Board is inside the card cage and has five PCB slots.

MR Memory Read; a bus-interface channel. See Chapter 2.
MRQ Memory ReQuest, a bus-interface channel. See Chapter 2.
ms millisecond; one-thousandth of one second, 0.001 second.
MSB Most Significant Bit.
Multiplexer A device capable of combining several low-speed inputs into one high-speed data stream transmitted on a single channel. A demultiplexer subsequently reconverts the single data stream into low-speed inputs for the host computer. Two kinds of multiplexers are time-division multiplexers in which the channel is divided into time slots and frequency-division multiplexers in which the channel is divided into frequency bands.

MW Memory Write; a bus-interface channel. See Chapter 2.
NAND A logical operator that is the negation of AND.
NEC Nippon Electric Company; a large manufacturer of electronics equipment, including semiconductors and microcomputers.

NOR A logical operator that is the negation of OR.
ns nanosecond; one billionth of a second, 0.000000001 second.
NT Normal Termination.
OCW Operational Command Word.
ODA Output Device Adapter.
OR A logic operator having the property that if P is a statement, Q is a statement, $R$ is a statement..., then the $O R$ of $P, Q, R . .$. is true if at least one statement is true, false only if all statements are false. Often represented by + , as in $\mathrm{P}+\mathrm{Q}$.

Output Pertaining to a device, process, or channel involved in an output process, or to the data or states involved in an output process.

Overflow That portion of the result of an operation that exceeds the capacity of the intended unit of storage.

Parallel Data Method for representing data in which characters are transmitted and received over separate lines, usually simultaneously. Compare serial data.

Parameter In general, a quantity used to specify I/O devices or to designate desired routines.

PCB Printed Circuit Board.
Personal Computer A relatively low-cost computer that is based on tiny microcomputer chips and is therefore portable and personally controllable. Personal computers are often classified as home, hobbyist, professional, business, small business, appliance, and others.

PHIO System Clock; a bus-interface channel. See Chapter 2.

POF Power-Off Control; (1) A bus-interface channel. See Chapter 2. (2) In the APC, a control circuit that shuts off the system power supply by a microprocessor command.

Printed Circuit Board Also called pc board, plate, card, chassis, and - in this manual - PCB; an insulating board with metallic wiring paths for point-topoint connections, but it can also include metallized connecting surfaces and heat sinks or heat radiators. Printed circuit boards are single-sided, double-sided, or multilayer; all pc boards in the APC are multilayer.

Program A series of instructions or statements, in a form acceptable to a computer, prepared in order to achieve a certain result.

Programmable Array Logic (PAL) TTL Schottky bipolar devices designed to replace standard TTL logic. They are fully programmable to provide a high degree of design flexibility and efficiency. The basic logic implementation is the AND-OR array, where the AND is programmable and the OR fixed. PALs are used to make logic modification quicker and easier than with standard devices.

PROM Programmable Read Only Memory; unprogrammed upon manufacture, can be programmed once and only once. After programming, like ROMs, they retain their contents indefinitely.

Protocol In data communications, a specific set of rules defining the format and content of messages between communicating devices.

P39 Phosphor Used in both the monochrome and color displays of the APC, it is a yellow-green, long-persistence phosphor that provides good luminescence, small dot size, and good focus.

RAM Random Access Memory. See Read/Write Memory.
Raster Scan A technique of graphics CRT displays; it operates by varying the intensity of a beam that periodically scans left-to-right and top-to-bottom. This CRT graphics method is the type used in the APC and conventional home TV; it is the only method that makes full color display possible.
$\overline{\mathbf{R D}} \overline{\text { READ }}$; an input signal of the NEC 8251A Communications Controller. See Chapter 3.

RDY Ready; a bus-interface channel. See Chapter 2.

Read/Write Memory Also called random access memory or RAM. A type of memory in which each cell can be both sensed at appropriate output terminals and changed in response to electrical input signals.

Refreshing A process of periodically reactivating or restoring information that decays when left idle; for example, the phosphor on a CRT must be refreshed in order to maintain the image, and dynamic memory cells need constant refreshing to maintain their contents.

RFSH Refresh; a bus-interface channel. See Chapter 2.
Register A device capable of storing a specified a mount of data such as one word.
rpm Revolutions Per Minute.
ROM Read-Only Memory; memory that can be read but not altered.
RS-232C Interface An interface between a modem and the associated data terminal equipment that is standardized by EIA Standard 232C.

RST RESET; an input signal of the NEC 8251A Communications Controller. See Chapter 3.

Serial Data Method for representing data in which the data stream is transmitted and received as a single signal by 2 single transmission path. Compare parallel data.

Single Density Refers to a magnetic disk storage technique in which 128 characters of information are stored on each sector of a track. Compare double density.

Software A set of programs, procedures, and possibly associated documentation concerned with the operation of a data processing system.

Sound Generator In general, a computer device that includes a tone-generator and speaker for outputting tones. In the APC, the sound generator is fully programmable and capable of generating user-programmed melodies and various beep signals.

Special Character In the APC, a character that the user can create through the ACGGEN utility program; the programmed character is stored in display RAM (and on disk if desired) and is accesible on command. There is storage allocation for 256 special characters, though an indefinite number can be stored on disk.

Status Register A register that provides storage for arithmetic and control status flags.

SW Switch.
Synchronous Having a constant time interval between successive bits, characters, or events.

Synchronous Communications A method of transmitting information in which the timing of character placement signifies the division between characters. A data stream of an indefinite number of characters is preceded by one or two sync bits, which indicate where the data stream begins.

TC Terminal Count; a bus-interface channel. See Chapter 2.
TTL Transistor/Transistor Logic.
USART Universal Synchronous/Asynchronous Receiver/Transmitter
V Abbreviation for Volt.
VFO Variable Frequency Oscillator.
W Abbreviation for Watt.
Word A group of characters that occupy one storage location and are treated as a single entity, instruction, or quantity. In the APC, two bytes ( 16 bits) make up a word.
$\overline{\text { WR }}(\overline{\text { WRITE }})$ An input signal of the NEC 8251A Communications Controller. See Chapter 3.


Seal or tape all edges for mailing-do not use staples.


FOLD HERE
Seal or tape all edges for mailing-do not use staples.


[^0]:    *Positions 1 (FNC), 54 (CTRL), 55 (CAPS LOCK), 68 and 79 (SHIFT), 80 (GRPH 1), 81
    (GRPH 2), and 83 (ALT) must be used with another key to generate a scan code.

[^1]:    ABSOLUTE MAXIMUM Operating Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ RATINGS*

    | Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
    | :---: | :---: |
    | Ali Output Voltages | -0.5 to +7 V olts |
    | All Input Voltages | -0.5 to +7 Volts |
    | Supply Voltages | -0.5 to +7 Volts |

    $\mathrm{T}_{\mathrm{a}}=25^{\circ} \mathrm{C}$
    *COMMENT: Stress above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

[^2]:    Note: (1) Symbols uned in this troble ere dencribed at the end of mis section
    (2) Ao enould equal binery 1 for all operations.
    (3) $x=$ Don't care. usuatily made to equal binery 0

