# - Tandy 1000 <br> Technical <br> Reference Manual 



TANDY

## TERMS AND CONDITIONS OF SALE AND LICENSE OF TANDY COMPUTER EQUIPMENT AND

SOFTWARE PURCHASED FROM RADIO SHACK COMPANY-OWNED COMPUTER CENTERS, RETAIL
STORES AND RADIO SHACK FRANCHISEES OR DEALERS AT THEIR AUTHORIZED LOCATIONS

## LIMITED WARRANTY

## I. CUSTOMER OBLIGATIONS

A. CUSTOMER assumes full responsibility that this computer hardware purchased (the "Equipment"), and any copies of software included with the Equipment or licensed separately (the "Software') meets the specifications, capacity, capabilities, versatility, and other requirements of CUSTOMER.
B. CUSTOMER assumes full responsibility for the condition and effectiveness of the operating environment in which the Equipment and Software are to function, and for its installation

## II. LImited warranties and conditions of sale

A. For a period of ninety (90) calendar days from the date of the Radio Shack sales document received upon purchase of the Equipment. RADIO SHACK warrants to the original CUSTOMER that the Equipment and the medium upon which the Software is stored is free from manufacturing defects. This warranty is only applicable to purchases of Tandy Equipment by the original customer from Radio Shack company-owned computer centers, retail stores, and Radio Shack franchisees and deaters at their authorized locations. The warranty is void if the Equipment's case or cabinet has been opened, or if the Equipment or Software has been subjected to improper or abnormal use. If a manufacturing defect is discovered during the stated warranty period, the defective Equipment must be returned to a Radio Shack Computer Center, a Radio Shack retail store, a participating Radio Shack franchisee or a participating Radio Shack dealer for repair, along with a copy of the sales document or lease agreement. The original CUSTOMER'S sole and exclusive remedy in the event of a defect is limited to the correction of the defect by repair, replacement, or refund of the purchase price, at RADIO SHACK'S election and sole expense. RADIO SHACK has no obligation to replace or repair expendable items.
B. RADIO SHACK makes no warranty as to the design, capability, capacity, or suitability for use of the Software, except as provided in this paragraph. Software is licensed on an "AS IS" basis, without warranty. The original CUSTOMER'S exclusive remedy, in the event of a Software manufacturing defect, is its repair or replacement within thirty (30) calendar days of the date of the Radio Shack sales document received upon license of the Software. The defective Software shall be returned to a Radio Shack Computer Center, a Radio Shack retail store, a participating Radio Shack franchisee or Radio Shack dealer along with the sales document.
C. Except as provided herein no employee, agent, franchisee, dealer or other person is authorized to give any warranties of any nature on behalf of RADIO SHACK.
D. EXCEPT AS PROVIDED HEREIN, RADIO SHACK MAKES NO EXPRESS WARRANTIES, AND ANY IMPLIED WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE IS LIMITED IN ITS DURATION TO THE DURATION OF THE WRITTEN LIMITED WARRANTIES SET FORTH HEREIN.
E. Some states do not allow limitations on how long an implied warranty lasts, so the above limitation(s) may not apply to CUSTOMER.
III. LIMITATION OF LIABILITY
A. EXCEPT AS PROVIDED HEREIN, RADIO SHACK SHALL HAVE NO LIABILITY OR RESPONSIBILITY TO CUSTOMER OR ANY OTHER PERSON OR ENTITY WITH RESPECT TD ANY LIABILITY, LOSS OR DAMAGE CAUSED OR ALLEGED TO BE CAUSED DIRECTLY OR INDIRECTLY BY "EQUIPMENT" OR "SOFTWARE" SOLD, LEASED LICENSED OR FURNISHED BY RADIO SHACK, INCLUDING, BUT NOT LIMITED TO, ANY INTERRUPTION OF SERVICE, LOSS OF BUSINESS OR ANTICIPATORY PROFITS OR CONSEQUENTIAL DAMAGES RESULTING FROM THE USE OR OPERATION OF THE "EQUIPMENT" OR "SOFTWARE." IN NO EVENT SHALL RADIO SHACK BE LIABLE FOR LOSS OF PROFITS, OR ANY INDIRECT, SPECIAL, OR CONSEQUENTIAL DAMAGES ARISING OUT OF ANY BREACH OF THIS WARRANTY OR IN ANY MANNER ARISING OUT OF OR CONNECTED WITH THE SALE, LEASE, LICENSE, USE OR ANTICIPATED USE OF THE "EQUIPMENT" OR "SOFTWARE." NOTWITHSTANDING THE ABDVE LIMITATIONS AND WARRANTIES, RADIO SHACK'S LIABILITY HEREUNDER FOR DAMAGES INCURRED BY CUSTOMER OR OTHERS SHALL NOT EXCEED THE AMOUNT PAID BY CUSTOMER FOR THE PARTICULAR "EQUIPMENT" OR "SOFTWARE" INVOLVED.
B. RADIO SHACK shall not be liable for any damages caused by delay in delivering or furnishing Equipment and/or Software.
C. No action arising out of any claimed breach of this Warranty or transactions under this Warranty may be brough more than two (2) years after the cause of action has accrued or more than four (4) years after the date of the Radio Shack sales document for the Equipment or Software, whichever first occurs.
D. Some states do not allow the limitation or exclusion of incidental or consequential damages, so the above limitation(s) or exclusion(s) may not apply to CUSTOMER.
IV. SOFTWARE LICENSE

RADIO SHACK grants to CUSTOMER a non-exclusive, paid-up license to use the TANDY Software on one computer subject to the following provisions:
A. Except as otherwise provided in this Software License, applicable copyright laws shall apply to the Software.
B. Title to the medium on which the Software is recorded (cassette and/or diskette) or stored (ROM) is transferred to CUSTOMER, but not title to the Software.
C. CUSTOMER may use Software on one host computer and access that Software through one or more terminals if the Software permits this function.
D. CUSTOMER shall not use, make, manufacture, or reproduce copies of Software except for use on one computer and as is specifically provided in this Software License. Customer is expressly prohibited from disassembling the Software
E. CUSTOMER is permitted to make additional copies of the Software only for backup or archival purposes or if additional copies are required in the operation of one computer with the Software, but only to the extent the Software allows a backup copy to be made. However, for TRSDOS Software, CUSTOMER is permitted to make a limited number of additional copies for CUSTOMER'S own use
F. CUSTOMER may resell or distribute unmodified copies of the Software provided CUSTOMER has purchased one copy of the Software for each one sold or distributed. The provisions of this Software License shall also be applicable to third parties receiving copies of the Software from CUSTOMER
G. All copyright notices shall be retained on all copies of the Software.
V. APPLICABILITY OF WARRANTY
A. The terms and conditions of this Warranty are applicable as between RADIO SHACK and CUSTOMER to either a sale of the Equipment and/or Software License to CUSTOMER or to a transaction whereby Radio Shack sells or conveys such Equipment to a third party for lease to CUSTOMER.
B. The limitations of liability and Warranty provisions herein shall inure to the benefit of RADIO SHACK, the author, owner and or licensor of the Software and any manufacturer of the Equipment sold by Radio Shack.
VI. STATE LAW RIGHTS

The warranties granted herein give the original CUSTOMER specific legal rights, and the original CUSTOMER may have other rights which vary from state to state

## Tandy 1000 Computer 25-1504

Tandy 1000 BIOS<br>© 1984 Tandy Corporation and Phoenix Compatibility Corporation All Rights Reserved.

Some of the system software in the Tandy 1000 is retained in read-only memory (ROM) format. All portions of this system software, whether in the ROM format or other source code format, and the ROM circuitry, are copyrighted and are the proprietary and trade secret information of Tandy Corporation. Use, reproduction, or publication of any portion of this material without the prior written authorization by Tandy Corporation is strictly prohibited.

Tandy ${ }^{\circledR} 1000$ Technical Reference Manual<br>© 1985 Tandy Corporation<br>All Rights Reserved.

Reproduction or use without the express written permission from Tandy Corporation, of any portion of this manual is prohibited. While reasonable efforts have been taken to assure its accuracy, Tandy Corporation assumes no liability resulting from any errors or omissions in this manual, or from the use of the information contained herein.

## The FCC wants you to know...

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 has been found to comply with the limits for Class A computing devices pursuant to Subpart J of Part 15 of FCC Rules, which are designed to provide reasonable protection against such interference when operated in a commercial environment. Operation of this equipment in a residential area is likely to cause interference in which case the user at his own expense will be required to take whatever measures may be required to correct the interference.

Tandy is a registered trademark of Tandy Corporation.

> IBM and PCjr are is a registered trademarks of International Business Machines Corporation.

## Table of Contents

Introduction ..... 1
Specifications
Electrical ..... 3
Mechanical ..... 6
Connector Pin Assignments ..... 7
1000 and IBM I/O Bus Cross Reference Chart ..... 10
Bus Interface Specifications ..... 13
Theory of Operation ..... 17
Main Logic Board ..... 17
IFL Equations ..... 21
Introduction to the Video System Logic ..... 38
Video System Modes ..... 45
Display Modes ..... 45
Operating Modes ..... 46
Graphics Mode ..... 47
System Logic Registers ..... 50
Video Array Register ..... 50
Palette Mask Register ..... 50
Border Color Register ..... 51
Mode Control Register ..... 51
Palette Register ..... 52
Video Memory Map Register ..... 53
Mode Register ..... 55
Color Select Register ..... 55
Status Reqister ..... 56
CRT/Processor Page Register ..... 57
General Memory Information ..... 58
Mode Selection Summary ..... 58
I/O Map ..... 58
System Confiquration Port ..... 59
ROM ..... 59
RAM ..... 59
Detailed Memory Map ..... 60
256K Memory Expansion Board ..... 73
Jumper Options ..... 73
Theory of Operation ..... 74
BS-232 Board ..... 77
Introduction ..... 77
Theory of Operation ..... 78
300 Baud Modem ..... 85
Introduction ..... 85
Theory of Operation ..... 86
Mouse Clock/Calendar Board ..... 97
Introduction ..... 91
Theory of Operation Hardware ..... 91
Theory of Operation Software ..... 92
Keyboard Assembly ..... 101
Keyboard Specifications ..... 101
Key Code Chart ..... 102
Keyboard Timing ..... 104
Keyboard Layout ..... 105
Appendices
A/ Comparative Tables for IBM PC and PCjr Computers
B/ Printer Specifications
C/ Intel Corporation Specifications:

8088-2
8237A-5
8253-5
8255A-5
8259A-8
8272A
8284A-1
D/ Texas Instruments Specifications: 76496

E/ Motorola Semiconductors Specifications: MC6845

F/ Teac Disk Drive Manual
G/ Connectors and Pin Designations
H/ Schematics

## INTRODUCTION TO THE TANDY 1000 COMPUTER

The Tandy 1000 Computer is modular in design to allow maximum flexibility in system configuration. The computer consists of a Main Unit, a detachable keyboard with coiled cable, and a monitor. The Main Unit is supplied with one internal floppy disk drive. (A second floppy disk drive is optional.) The standard types of monitors used with the Tandy 1000 are the monochrome composite and the color RGB monitor. Since these units are modular, they may be placed on top of the Main Unit or at any convenient location.

Internal storage is expanded by adding a second $51 / 4^{\prime \prime}$ floppy disk drive. Each disk drive has a capacity of 360 K bytes formatted.

The Tandy 1000 has a standard 128 K of system RAM. An optional DMA/RAM board allows the Tandy 1000 to be expanded in increments of 128 K of RAM. This board will fit into one of the expansion slots. With two fully populated RAM boards installed, the Tandy 1000 will have 640K bytes of maximum RAM allowed by the system memory map.

Other features include a parallel printer port, two built-in joystick interfaces, a speaker for audio feedback, and a light pen interface.

The Main Unit is the heart of the Tandy 1000. It houses the Main Logic Assembly, system power supply, and floppy disk drives.

The Main Logic Assembly is a large board mounted to the bottom of the Main Unit and interconnected to the keyboard, power supply, and disk drives by a series of cables. The illustration in Figure 1 shows the major components of a Tandy 1000 system.

The Power Supply is a 54 W switching regulator type, designed to provide adequate power capacity for a fully configured system using all the option slots.

The Floppy Disk Drive uses 5¼" double-sided, double-density diskettes to read, write, or store data. These are soft sector diskettes. The Disk Drive assembly is installed in the standard unit. The floppy disk stores approximately 360K bytes (formatted) of data. All system programs, with the exception of the system startup sequence, are stored on disk.

Either a monochrome or a color display may be used with the Tandy 1000. The monochrome monitor is a high-resolution green phosphor display which provides excellent visual quality. It features a 12 " screen with an anti-glare surface. Each display is capable of 25 lines of 80 characters. The character matrix is 8 wide $\times 9$ high.


Tandy 1000 System
Figure 1

## SPECIFICATIONS

Processor: Intel 8088

## Dimensions:

$6 \times 17 \times 13 \mathrm{3} / 8$ inches (HWD)

## Weight:

17 lbs. 4 oz. with 1 Disk Drive

## Power Requirements:

120 VAC, $60 \mathrm{~Hz}, 1$ Amp maximum
With 2 Floppy Disk Drives, 2 Memory Cards, and RS-232:
AC Current: 0.7 - 0.8 Amps with Floppy doing R/W tests.
Leakage Current: 0.5 mA
Disk Drive:

| Idle +5 VDC | 0.23 Amps | +12 VDC 0.106 Amps |
| :--- | :---: | ---: |
| R/W | 0.286 Amps | 0.295 Amps |
| R/W | 0.2 Minimum | 0.550 Max |
| Main Logic Board: +5 VDC | 4.07 Amps | +12 VDC |
| Main Logic Board Option Cards: | -12 VDC | 0.032 Amps |
| Maps |  |  |

## Environment:

Air Temperature
System ON: 60 to 90 degrees $F$ ( 15.6 to 32.2 degrees $C$ )
System OFF: 50 to 110 degrees $F$ ( 10 to 43 degrees C)
Humidity
System ON-OFF: $8 \%$ to $80 \%$

## Disk Drive Specifications

## Power:

Supply
Voltage +5 VDC Input +12 VDC Input
Ripple
0 to 50 kHz
100 mV
100 mV
Tolerance
Including Ripple
$+1-5 \% \quad+/-5 \%$
Standby Current

Nominal
Worst Case
600 mA
700 mA
400 mA 500 mA
Operating Current
Nominal
Worst Case
600 mA
900 mA
700 mA 2400 mA

## Environment:

Temperature

Operating Nonoperating
Relative Humidity
Operating Nonoperating

50 to 122 degrees $F$ (10 to 44 C )
-40 to 140 degrees $F(-40$ to $60 C)$
20\% to 80\% (noncondensing)
$5 \%$ to $95 \%$ (noncondensing)

The following pages reflect the mechanics for the Tandy 1000 option PCB's and option board panel.




## Connector Pin Assignments

J2 - Speaker Interface
(2-Pin Vertical Header)
1 - Sound

J3 - Right Joystick
(6-Pin Rt. Angle Circular Din)
1 - Y Axis
3 - Ground
$2-\quad X$ Axis
$5-\quad+5 \mathrm{VDC}$
4 - Switch 1
6 - Switch 2

J4 - Left Joystick
(6-Pin Rt. Angle Circular Din)
1 - Y Axis
3 - Ground
$5-\quad+5 \mathrm{VDC}$
$2-X$ Axis
4 - Switch 1
6 - Switch 2

J5 - Keyboard Interface
(8-Pin Rt. Angle Circular Din)

| 1 | - | 2 | - |
| :--- | :--- | :--- | :--- |
| 3 | KBDDDATA | 4 | - KBDCLK |
| 3 | - Ground | 6 | - KBDRST |
| 5 | -5 VDC | 8 | - |
| 7 | - MULTIDATA |  |  |

J6 - Floppy Disk Interface
(Dual 17-Pin Vertical Header)

| 1 | - Ground |
| :--- | :--- |
| $3-$ Ground | 2 |
| $5-$ Ground | 4 |
| $5-$ NC |  |
| 7 | - Ground |

J7 - DC POWER
(9-PIN VERTICAL HEADER)
$\left.\begin{array}{lll}1 & -+5 \text { VDC } & 2\end{array}\right)+5$ VDC

J8,J9,J10 - Expansion Interface Connectors (Dual 31-Pin Card Edge)

| A01 - NMI | B01 - Ground |
| :---: | :---: |
| A02 - D7 | B02 - RESET |
| A03 - D6 | B03 - + 5 VDC |
| A04 - D5 | B04 - IR2 |
| A05 - D4 | B05 - (-5 VDC) |
| A06 - D3 | B06 - FDCDMARQ |
| A07 - D2 | B07 - 12 VDC |
| A08 - D1 | B08 - AUDIOIN |
| A09 - D1 | B09 - + 12 VDC |
| A10 - READY | B10 - Ground |
| A11 - AEN | B11 - MEMW* |
| A12 - A19 | B12 - MEMR* |
| A13 - A18 | B13 - IOW* |
| A14 - A17 | B14 - IOR* |
| A15 - A16 | B15 - (DACK3*) |
| A16 - A15 | B16 - (DRQ3*) |
| A17 - A14 | B17 - (DACK1*) |
| A18 - A13 | B18 - (DRQ1*) |
| A19 - A12 | B19 - REFRESH* |
| A20 - A11 | B20 - CLK |
| A21 - A10 | B21 - RFSHRQ |
| A22 - A09 | B22 - BREQ* |
| A23 - A08 | B23 - IR5 |
| A24 - A07 | B24 - IR4 |
| A25 - A06 | B25 - IR3 |
| A26 - A05 | B26 - FDCDACK* |
| A27 - A04 | B27 - DMATC |
| A28 - A03 | B28 - ALE |
| A29 - A02 | B29 - +5 VDC |
| A30 - A01 | B30 - OSC |
| A31-A00 | B31 - Ground |

Note: Signals in parentheses on J8, J9, and J 10 are shown for PC Compatible Reference only and are not used on the main logic board of the Tandy 1000.
$\begin{aligned} \mathrm{J} 11 \text { - } & \text { Parallel Interface } \\ & \text { (34-Pin Card Edge) }\end{aligned}$
1 - PPSTROBE* 2 - Ground

3 - PPDATAO
4 - Ground
5 - PPDATA1
6 - Ground
7 - PPDATA2
8 - Ground
9 - PPDATA3
10 - Ground
11 - PPDATA4
12 - Ground
13 - PPDATA5
14 - NC
15 - PPDATA6
16 - Ground
17 - PPDATA7 18 - Ground
19 - PPACK* 20 - Ground
21 - PPBUSY 22 - Ground
23 - PPPAEM 24 - Ground
25 - PPBUSY* 26 - NC

27 - Ground 28 - PPFAULT
29 - NC 30 - PPINIT*.
31 - Ground 32 - PPAUTOFEED*
33 - Ground 34 - NC
J12 - Light Pen
(9-Pin Connector Male Rt. Angle D-Subminiature)
$1-\quad+5 \mathrm{VDC}$
2 - Ground
$3-$ LPIN
4 - LPSW*
$5-N C$
6 - NC
7 - NC
$8-N C$
$9-N C$

J13 - RGBI Video
(9-Pin Socket Rt. Angle D-Subminiature)
1 - Ground
2 - Ground
3 - Red
4 - Green
5 - Blue
6 - Intensity
7 - +12 VDC 8 - HSYNC
$9-$ VSYNC
J14 - Composite Output
(Dual Rt. Angle RCA-Type Phone Jack)
A - Video
B - Audio

| Pin No. | Signal Name | Description |
| :---: | :---: | :---: |
| B18 | DRQ1* | IBM - This signal is always available on the IBM PC. |
|  |  | TANDY 1000 - DMA request 1 is available only on the I/O bus when the Memory/DMA board is installed. |
| B17 | DACK1 * | IBM - This signal is always available on the IBM PC. |
|  |  | TANDY 1000 - DMA grant 1 is only available on the I/O bus when the Memory/DMA board is installed. |
| B16 | DRQ3* | IBM - This signal is always available on the IBM PC. |
|  |  | TANDY 1000 - DMA request 3 i only available on the I/O bus when the Memory/DMA board is installed. |
| B15 | DACK3* | IBM - This signal is always available on the IBM PC. |
|  |  | TANDY 1000 - DMA grant 3 is only available on the I/O bus when the Memory/DMA board is installed. |
| B05 | -5VDC | IBM - -5 VDC is always available. |
|  |  | TANDY 1000--5VDC is not installed on the I/O bus, but a modification is available through an authorized repair center. |
| B21 | RFSHRQ* | IBM - This signal functions as a refresh request on the I/O bus, but is labeled Interrupt Request 7. |
|  |  | TANDY 1000-Same function as on the IBM PC, but different pin designation. |
| B22 | BREQ* | IBM - This signal functions as a bus request on the I/O bus, but is labeled Interrupt Request 6. |
|  |  | TANDY 1000-Same function as on the IBM PC, but different pin designation. |
| B08 | AUDIOIN | IBM - Reserved |
|  |  | TANDY 1000 - Audio input is supplied from an optional board on the I/O bus to a multiplexer on the main logic board for an output to the external speaker. |

## 1000 and IBM I/O Bus Cross Reference Chart (Continued)

| Pin No. | Signal Name | Description |
| :---: | :---: | :---: |
| B06 | FDCDMARQ* | These signals are functionally the same as |
| B26 | FDCDACK* | those on the IBM PC, however, the Tandy |
| B27 | DMATC | 1000 was designed with an FDC Controller |
|  |  | on the main logic board and the DMA Con- |
|  |  | troller on the optional memory board. The |
|  |  | IBM PC has the DMA Controller on the |
|  |  | main logic board and the optional FDC Controller on the I/O bus. |

Note: All other pins are identical to the IBM PC. See Section 3 for the connector pin assignments.

## BUS INTERFACE SPECIFICATIONS

This specification is for the primary bus on the Tandy 1000 main logic board, which also is available to the option board connectors. The specification describes the signals in the following manner. See Figures 5 and 5.1.

- The following signal nomenclature is used in the schematic and literature. Signals designated with the suffix ""*" are logically "true low" (normal inactive state is high); if they are not so designated, the signal is logically "true high.'
- Direction-- input or output-is referenced to the CPU.
- Brief functional description of the signal.
- Description of the "drive" or "load" characteristics of the signal. This includes the specific source by IC type and reference designator, drive capability for "output" signals, and actual load for "input" signals. The drive/load is defined in "unit loads" and specified as "high/low." This specification is for the main logic board only. Some signals have an alternate source, an external bus master such as the DMA.
- 1 Unit Load (UL) is defined as: Ioh =.04mA @ 2.4 V

$$
\mathrm{lo}=1.6 \mathrm{~mA} @ 0.5 \mathrm{~V}
$$

## Signal Listing

| A00 - A19 | $\bigcirc$ | ADDRESS | SOURCE: U41, U42, U61 <br> Drive - 65/15 UL <br> Latch Strobe - ALE <br> Output Enable - AEN <br> Alternate external source |
| :---: | :---: | :---: | :---: |
| D0-D7 | $1 / 0$ | DATA | SOURCE: U62 <br> Drive - 37/15 UL <br> Direction Control -RD* <br> (CPU read signal) <br> Enable - DEN* |
| ALE | O | ADDRESS LATCH STROBE | SOURCE: U46 |
| IOW* | 0 | I/O WRITE STROBE | Drive - 50/7.5 UL |
| IOR* | 0 | I/O READ STROBE | Output Enable - AEN |
| MEMW* | 0 | MEMORY WRITE STROBE | Pull-Up - 4.7K ohms |
| MEMR* | 0 | MEMORY READ STROBE | Alternate external source |
| CLK | O | CPU CLOCK | $4.77 \mathrm{MHz}, 33 \%$ duty cycle SOURCE: U82 <br> Drive - 75/7.5 UL |
| OSC | 0 | OSCILLATOR | 14.32MHz, $50 \%$ duty cycle SOURCE: U82 <br> Drive - 75/7.5 UL |
| NMI | 1 | NON-MASKABLE INTERRUPT | To System NMI Load: 1/1 UL U117 |


| READY | SYSTEM WAIT | SOURCE: OPEN-COLLECTOR OR 3-STATE BUFFERS <br> Load: 1 UL and 1.0 K ohm pull-up. 10/0.9 UL <br> Set LOW by Peripherals (//O or Memory) to extend READ or WRITE cycles. |
| :---: | :---: | :---: |
| RESET | O SYSTEM RESET | Power On or Manual SOURCE: U82 Drive: 75/7.5 UL |
| BREQ* | BUS REQUEST | From external masters Load: 1 UL and 10 K ohm pull-up. 10/0.9 UL |
| AEN | O BUS GRANT | To external masters SOURCE: U82 <br> Drive - 75/7.5 UL |
| $\begin{aligned} & \text { IR2 } \\ & \text { IR3 } \end{aligned}$ | I INTERRUPT REQUEST\#2 I INTERRUPT REQUEST\#3 | To system interrupt controller Load: 1 UL and 2.2K pull-down |
| IR4 | INTERRUPT REQUEST\#4 |  |
| AUDIO IN | 1 | From External Sound Source Load: 10k ohms. |
| AUDIO OUT |  | To External Source Drive: 1.25 Volts P.P into 10 K |
| The following are not sourced by the CPU but are to be SOURCED (O) Output or LOADED (I) input by an external DMA source: |  |  |
| RFSHRQ | I REQUEST DMA CHANNEL\#O | Dedicated input requests to DMA |
| DRQ1 | I REQUEST DMA CHANNEL\#1 | Load: 8237A-5/9517A |
| FDCDMARQ | I REQUEST DMA CHANNEL\#2 | 1 MOS load 40/160 UL |
| DRQ3 | I REQUEST DMA CHANNEL\#3 |  |
| REFRESH* | O ACKNOWLEDGE DRQO* | Dedicated output |
| DACK1* | O ACKNOWLEDGE DRQ1* | acknowledges from DMA. |
| FDCDACK* | O ACKNOWLEDGE DRQ2* | Drive: 8237A-5/9517A |
| DACK3* | O ACKNOWLEDGE DRQ3* | $2 / 2$ UL |
| DMATC | O TERMINAL COUNT | Used by DMA Controller to indicate Terminal Count reached. Drive: $2 / 2$ UL |
| $\begin{aligned} & +5 V D C \\ & +12 V D C \\ & -12 V D C \\ & \text { GROUND } \end{aligned}$ | $+5 \mathrm{VDC} \pm 4 \%$ 3.0 Amps available on the bus. <br> $+12 \mathrm{VDC} \pm 5 \% 0.5 \mathrm{Amps}$ available on the bus. <br> $-12 \mathrm{VDC}+8.3 \%-25 \% 0.06$ Amps available on the bus. <br> Power Return for $+5+12,-12$ VDC. |  |



Figure 2
CPU/BUS Timing Signal


Figure 2.1
CPU/BUS Timing Signal

## THEORY OF OPERATION

## Main Logic Board

The Block Diagram of the main logic board (Figure 3) shows the basic functional divisions.

## CPU Function

The CPU function consists of the CPU (Intel 8088), the address, data interface, the CPU control signal generator, the bus control signal generator and the interrupt controller (Intel 8259A). It is located in the upper right hand corner of the board above the external bus connectors.

## Non-CPU Function, Main Logic Board

The non-CPU functions can be divided into two main parts: memory and I/O. Memory consists of RAM and ROM. RAM or Video/System Memory serves as storage for both the video data and program data. ROM memory contains the BIOS and diagnostics. I/O consists of all the peripheral functions; keyboard, floppy disk controller, printer, joystick, light pen and sound.

## Processor Address/Data Interface

The 8088 has three groups of Address/Data lines; AD0 - AD7, A8 - A15 and A16 - A19. AD0 - AD7 are multiplexed address and data lines. To separate and save the address that comes out first, the signals are applied to U61 (74LS373) and latched by ALE. Additionally, the signals are applied to data transceiver U62 (74LS245). U62 is enabled only during the data portion of the CPU cycle. (The exception is during an Interrupt Acknowledge cycle.) Direction of transmission is controlled by the RD* (READ) signal from the CPU. Address lines A8 - A15 are present during the entire CPU cycle and need only to be buffered. Address lines A16 - A19 are multiplexed with status signals S4-S7 and need to be latched. The results are: A8-A11, A16-A19 are latched into U41 (74LS373) by ALE and A12 - A15 are buffered by half of U43 (74LS244). The outputs from these latches/buffers/transceivers are the BUS Signals A00 - A19, D0 - D7.

## CPU Control Signal Generation

The 8088 CPU uses a 4.77 MHz clock with a special duty cycle (33\% high, $67 \%$ low.) This clock is produced by the 8284 clock generator/driver U45. The 8284 receives a 14 MHz input clock and divides it by 3 to produce CPUCLK (4.77 MHz) and by 6 to produce D2CLK ( 2.385 MHz ). In addition to being used by the control signal logic the clocks are buffered by U82 (74LS244) for
the bus signals OSC ( 14 MHz ), ( 4.77 MHz ) and main logic signal D2CLK (2.385 MHz ). (See the Bus Interface Specification)

The RESET signals (CPURESET, SYSRST*, RST*) originate at U45 (8284) which synchronizes the input RES*. RES* originates from C26 which is shorted to 0 volts by either the manual reset switch or by diode CR6 when the power is off.

The READY circuit synchronizes the system "ready" signals with the CPU clock and generates the CPU input CPUREADY. If a function needs one or more "wait" states added to its access, it must set the READY line low. From the main logic board, READY is set low by the sound IC for 32 extra "wait states" and the video/system memory sets READY low for typically one or two "wait" cycles. The READY circuit of the 8284 (U45) is operated in the nonasynchronous mode; i.e. two sequential edges of clock (a rising edge first) are required to set the CPUREADY signal true. Of the four inputs provided, two are used, RDY2 and AEN2. Inputs to RDY2 must be high and the input to AEN2 must be low to set CPUREADY high. Only one input is applied to AEN2: IOWAIT which is a positive pulse generating one "wait" state for every I/O cycle. The signal READY applied to the RDY2 input comes directly from the BUS and is the wired-or (logical OR) of any/all READY's from the subsystems which need "wait state(s)" inserted. READY is pulled-up by R34.

## Oscillator Timing and Dynamic RAM Control

The main system timing starts with the 28.63636 MHz oscillator. This oscillator is a single package which produces a TTL output. From the oscillator, U39 divides the master frequency into 4 multiples. The timing diagram (Figure 4) shows this division. 14.31818 MHz is used to clock the video array chip, and also is used by the Intel 8284 to generate the CPU clock signal.

The first three outputs from the counter (U39) are used to derive 8 time states, (U38) and the last output is used to effectively double the number to 16. These 16 time states are shown at the bottom of Figure 6.1. These time states are then used as J-K inputs for F109 flip-flops, which generate the system timing signals RAS*, CAS* and MUX.

The timing diagram shows RAS* and CAS* as constantly occuring pulses which cycle every 279 ns. Only the RAS* and CAS* pulses for the video cycles are constant. During the CPU cycle, RAS* and CAS* pulse will occur only if the CPU is accessing memory. This function is controlled by U116 and $1 / 2$ of U94. A CPU request for accesses is first latched by the first half of U116. As soon as the next CPU cycle time starts, the second half of U116 is clocked and the CPU access cycle starts. The CPU cycle lasts until the rising edge of RAS* in the video cycle.

The other signals generated by the system timing are STIS, DYMU, and CPULT. ST15 is a syncronization signal for the Video Array chip, and references time state 0 from U39. DYMUX occurs on the rising edge of MUX in the CPU cycle and latches the video data. The final signal, CPULT occurs only during a CPU access and is used to latch read data for the CPU.


Figure 3
Main Logic Block Diagram


Figure 4
Master Oscillator Timing (All Times in Nanoseconds)

## IFL Equations

## U53 Memory Address Decode

Code: 53G
Checksum: 50C9

## Equations:

```
VSACC* = RFSH*
    + }\overline{19}\cdot\overline{18}\cdot17\cdot\overline{\textrm{MC3}}\cdot\overline{\textrm{MC2}}\cdot\textrm{MC1
    + }\overline{19}\cdot18\cdot\overline{17}\cdot\overline{\textrm{MC3}}\cdot\textrm{MC2}\cdot\overline{\textrm{MC1}
    + }\overline{19}\cdot18\cdot17\cdot\overline{MC3}\cdot\textrm{MC2}\cdot\textrm{MC1
    + RFSH*}\cdot\overline{\mp@subsup{M}{MEMR}{}
    + \overline{RFSH*}}\cdot\overline{MEMW}*\cdot\overline{19}\cdot\overline{18}\cdot\overline{17}\cdot\overline{\textrm{MC3}}\cdot\overline{\textrm{MC2}}\cdot\overline{\textrm{MC1}
        19}\cdot\overline{18}\cdot17\cdot\overline{\textrm{MC3}}\cdot\overline{\textrm{MC}2}\cdot\textrm{MC}
        19}\cdot18\cdot\overline{17}\cdot\overline{\textrm{MC3}}\cdot\textrm{MC}2\cdot\overline{\textrm{MC}
    + RFSH*}\cdot\overline{MEMW}*\cdot19\cdot\overline{18}\cdot\overline{17}\cdotMC3\cdot\overline{MC2}\cdot\overline{MC1
    + HGMEMAC
HGMEMAC* = RFSH*}\cdot\mp@subsup{\overline{MEMR}}{}{*}\cdot19\cdot\overline{18}\cdot17\cdot16\cdot1
    + RFSH**MEMW**19\cdot18\cdot17\cdot16.15
ROMSCO* = RFSH*}\mp@subsup{}{}{*}\cdot\mp@subsup{\overline{MEMR}}{}{*}\cdot19\cdot18\cdot17\cdot16\cdot15\cdot14\cdot1
ROMSC1* = RFSH*}*\mp@subsup{\overline{MEMR}}{}{*}\cdot19\cdot18\cdot17\cdot16\cdot15\cdot14\cdot1
MEMSEL* = VSACC* + HGMEMAC* + ROMCSO* + ROMCS1*
```


## U80 Main I/O Address Code

Code: 80B
Checksum: 58F9

Inputs:

## Addresses

15•14 $\mathbf{1 3 \cdot 1 2 \cdot 1 1 \cdot 1 0 \cdot 9 \cdot 8 \cdot 7}$
IOOSEL* $=0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 0$ IO1SEL* $=0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 1$
IO4SEL* $=0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 1 \cdot 0 \cdot 0$
IO6SEL* $=0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 1 \cdot 1 \cdot 0$
IO7SEL* $=0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 0 \cdot 1 \cdot 1 \cdot 1$

## Outputs:

$$
\begin{aligned}
& \text { INTCS* } \quad=\operatorname{IOOSEL} * \cdot \overline{6} \cdot 5 \cdot \overline{4} \cdot \overline{3} \\
& \text { TMRCS* } \quad=\text { IOOSEL }{ }^{*} \cdot 6 \cdot \overline{5} \cdot \overline{4} \cdot \overline{3} \\
& \text { PIOCS* } \quad=1 O 0 S E L * \cdot 6 \cdot 5 \cdot \overline{4} \cdot \overline{3} \\
& \text { NMICS* } \quad=101 \text { SEL }^{*} \cdot \overline{6} \cdot 5 \cdot \overline{4} \cdot \overline{3} \\
& \text { SNDCS* } \quad=101 \mathrm{SEL}^{*} \cdot 6 \cdot \overline{5} \cdot \overline{4} \cdot \overline{3} \\
& \text { JOYSTKCS* }=1 \text { O4SEL* } \cdot \overline{6} \cdot \overline{5} \cdot \overline{4} \cdot \overline{3} \\
& \text { PRINTCS* }=\text { IO6SEL* } \cdot 6 \cdot 5 \cdot 4 \cdot 3 \\
& \text { FDCCS* } \quad=\text { IO7SEL* } 6 \cdot 5 \cdot 4 \cdot \overline{3} \\
& \text { IOSEL* }=\text { TMRCS* }+ \text { PIOCS* }+ \text { NMICS* }^{*}+\text { SNDCS } \\
& \text { + PRINTCS* + FDCCS* + IO7SEL* } 6 \cdot 5 \cdot 4
\end{aligned}
$$

## U46 System Timing Synthesizer

Code: 46DC

## Checksum: 3E69

## Equations:



## U103 Video Address Decode

Code: 103C
Checksum: 44B0
GACS* $=\cdot \overline{\text { IOW }} \cdot \overline{\text { IOTSEL* }} \cdot 6 \cdot \overline{5} \cdot 4 \cdot 3 \cdot \overline{2} \cdot \overline{1} \cdot \overline{0} \cdot$ MODE $^{*}$
$+\overline{\text { IOW }} \cdot \overline{\text { OTSEL*}} \cdot 6 \cdot \overline{5} \cdot 4 \cdot 3 \cdot \overline{2} \cdot \overline{1} \cdot 0$
$+\cdot \overline{\text { IOW }} \cdot \overline{\text { OTSEL* }} \cdot 6 \cdot \overline{5} \cdot 4 \cdot 3 \cdot \overline{2} \cdot 1 \cdot \overline{0} \cdot$ STATUS* $^{*}$
$+\overline{\text { IOW }} \cdot \overline{\text { OTSEL* }} \cdot 6 \cdot \overline{5} \cdot 4 \cdot 3 \cdot 2 \cdot 1 \cdot 0$
STATUS $^{*}=$ IOTSEL* $^{*} \cdot 6 \cdot \overline{5} \cdot 4 \cdot 3 \cdot \overline{2} \cdot \overline{1} \cdot 0$
MODE* $=$ •IOW $\cdot$ IO7SEL* $\cdot 6 \cdot \overline{5} \cdot 4 \cdot 3 \cdot \overline{2} \cdot \overline{1} \cdot \overline{0}$
LPCLR* $=\overline{\text { IO7SEL*}} \cdot 6 \cdot \overline{5} \cdot 4 \cdot 3 \cdot \overline{2} \cdot 1 \cdot 0 \cdot \overline{\text { IOW }}$
LPSET $^{*}=\overline{\text { OTSEL }}$ * $\cdot 6 \cdot \overline{5} \cdot 4 \cdot 3 \cdot 2 \cdot \overline{1} \cdot \overline{0} \cdot \overline{\text { IOW }}$
PGCLK ${ }^{*}=\overline{\text { IOTSEL*}} \cdot 6 \cdot \overline{5} \cdot 4 \cdot 3 \cdot 2 \cdot 1 \cdot 0 \cdot \overline{\text { IOW }}$
6845 CS $^{*}=\overline{\text { OTSEL*}} \cdot 6 \cdot \overline{5} \cdot 4 \cdot \overline{3}$.

## System Control Signal Generation

The System Control Signal Generator provides the timing strobes required by the system. These include IOW*, IOR*, MEMW*, MEMR*, ALE, $D E N^{*}$ and $1 O / M^{*}$. These signals are synthesized by $U 46$ ( IFL ) from timing signals A,B,C,D, 8088 status signals SSO*, DT/R*, IO/M* plus HLDA and INTCS* (8259 chip select). Timing signals A, B, C, D come from flip-flops U23 and U47. The timing clock is CPUCLOCK. A CPU cycle is divided into five periods: T1, T2, T3, TWAIT, and T4. Each cycle has a clock rising edge and a clock falling edge. Thus T1 + denotes rising, and $T 1$ - denotes falling. Signal " $A$ " is started by ALE true ( $T 1+$ ) and stopped by " C ", ( $\mathrm{T} 2+$ ). Signal " B " is started by " A " and ( $\mathrm{T} 1-$ ) and stopped by CPUREADY, and " D ". Signal " C " is started by " B ", (T2 +) and stopped by "BNOT", (T3 + ). Signal "D" is started by "C'", (T2-) and stopped by "CNOT", (T3-). Characteristically, "A" is always one clock long while " $B$ ", " $C$ " and " $D$ " are variable in length depending on the number of inserted "wait" states. Thus any half-clock period between $T 1+$ and $T 3$ - can be logically combined to create the output timing signals. See Figure 5 .

All external devices, except the 8259A Interrupt Controller, are buffered by an LS244 that is controlled by the DEN* signal. Since the 8259A is not buffered, the DEN* signal must remain inactive during accesses to the 8259A.

## Bus Specification

Specifications for the bus will include the expansion connector pin/signal assignments and the signal characteristics. Refer to the Expansion I/F Connector diagram. See Figure 6.


TIMING DIAGRAM

Figure 5
(All Times in Nanoseconds)

## EXPANSION I/F CONNECTOR



Figure 6

## Interrupt Function

The 8088 supports two types of interrupts: maskable (by the CPU, INT) and non-maskable (NMI). See Figure 7. The 8259A Interrupt Controller is the source of the INT for the 8088. The 8259A has eight interrupt inputs controlled through software commands. It can mask (disable) and prioritize (arrange priority) to generate INT. These eight interrupts are:
\#0 Timer Channel 0 Software Timer
\#1 Keyboard
\#2 Hard Disk Controller
\#3 Modem
\#4 RS-232
\#5 Vertical Sync
\#6 Disk Controller, Floppy
\#7 Printer

Keyboard Code Received
Optional Function, Interrupt on Bus
Optional Function, Interrupt on Bus
Optional Function, Interrupt on Bus
Software Timer for Video
Ready to Receive/Transmit Data
Data Transmission Complete

The NMI interrupt is not maskable by the CPU but it can be enabled/disabled by hardware. The enable is at Port 00A0 Bit 7. The enable is cleared by RESET. There is no specific function assigned to NMI and it is available on the bus.

## INTERRUPT STRUCTURE



8259A INTERRUPT CONTROLLER

| INTERRUPT | FUNCTION |
| :---: | :--- |
| NMI | AVAILABLE ON BUS |
| $\emptyset$ | 8253 TIMER CH $\emptyset$ |
| 1 | KEYBOARD |
| 2 | HARD DISK |
| 3 | SECONDARY COMM. |
| 4 | PRIMARY COMM. |
| 5 | VERTICAL SYNC. |
| 6 | FLOPPY DISK CONTROLLER |
| 7 | PARALLEL PORT |

Figure 7

## Bus Interface

The interface to the main bus is divided into three parts: address/control strobes, memory data and I/O data. The address/control strobe part (BAO - BA19, BMEMR*, BMEMW*, BIOR*, BIOW*) is shared by both the I/O and the memory sections. Input buffers are U59, U60 and U42. One function of the address bus is the select logic for each of the functions. U80 decodes all the I/O chip selects except those for the Video/System Memory I/O ports which are decoded by U103. The memory selects are decoded by U53. The I/O data transceiver is $\cup 97$ with its output enable decoded by U80. The memory transceiver is U 14 and its output enable is decoded by U53. The direction control for both data transceivers are the "read"' strobes; IOR* for U97 and MEMRFOR U14.

## Keyboard / Timer / Sound Circuits

The focal point for this circuit is the 8255 Programmable Peripheral Interface (PPI). It has three 8 bit parallel ports, $\mathrm{A}, \mathrm{B}$ and C . Port A is configured as an input port and is used for keyboard data. Port B is configured as an output port and is used for control signals for the sound, keyboard and timer functions. Port C is split into 4 inputs, including the timer channel and \#2 monitor and 4 outputs including the keyboard/multifunction interface signals. See Figure 8.

## Keyboard Data

The computer receives data from the keyboard in an asynchronous serial format with one 8 bit word for each keystroke. This serial data is converted by the shift register, U91. This byte is then read by the CPU through the 8255 Port A. On receipt of a character an interrupt is set and the keyboard "BUSY" signal disables further transfers from the keyboard ( $1 / 2$ of U104). To enable the keyboard again, the "keyboard clear" signal from 8255 Port B must be toggled. This signal when high clears the interrupt, the shift register and holds "BUSY"" active (U78 pin 11.) Holding "BUSY'" active prevents another character from being sent until the clear routine is complete. The serial data from the keyboard consists of a clock signal and a data signal. The clock consists of 8 consecutive positive pulses (signal normal state is logic low). The rising edge of each pulse is centered in the middle of each data period. The data signal consists of 8 data periods and a "end-of-character" bit. Normal state of the data signal is logic high which represents a logic 1 . Thus the data signal will change only if the data bit is a 0 . The ninth and last data bit is always a 0 . In the absence of a ninth clock it will strobe a 1 into $\cup 104$ and set the interrupt and busy signals. See the Keyboard Timing Chart in the Keyboard Chapter.

## PROGRAMMABLE PERIPHERAL I/F 8255A-5

 (PPI)
## PORT ASSIGNMENTS



Figure 8

## Timer Function

The Timer is an 8253 Timer/Counter consisting of three independent counters. The clock for all three counters is 1.1925 MHz . The gate for counter \#0, \#1 is permanently "on'". The gate for counter \#2 is controlled by a bit of the 8255 Port B. The output of counter \#0 is dedicated to system interrupt \#0 (8259 IRO) for software timing functions. The output of counter \#1 is dedicated to the REFRESH function. When the optional DMA/Memory board is installed, DMA channel \#0 is used for refreshing the RAM memory. Counter \#1 sets RFSHRQ* (DRQ0) every 15 microseconds to initiate a single "dummy" memory read. The output of counter \#2 is routed to the sound circuit and into the 8255 Port C for monitoring by the CPU. See Figure 9.

## Sound Function

The sound function consists of an internal and an external sound circuit. The internal sound circuit is directly connected to the speaker via U118. The source of the sound frequencies is U96 Complex Sound Generator. Internally, U96 has four programmable sound generators. The frequency and output level of each is controlled by software. The four internal generators are summed with an external input into a single output. The external source is from the 8253 counter \#2 (programmable frequency and fixed amplitude). In addition to being the only source for the unit speaker, it is one of three selectable sources for the external audio out signal. This signal is intended as an input into a external amplifier such as a stereo. The three sound frequency sources are:

1. Complex sound generator U96.
2. The 8253 counter at channel 2 .
3. Any external source applied to bus interface pin B08, Audio In.

These are selected by an analog multiplexer U105. Selection signals are SNDCNTLO, SNDCNTL1 from the 8255. The output driver for Audio Out is U119 which is designed to drive a load impedance of 1000 ohms. See Figure 10.

## SYSTEM TIMER 8253-5



CHANNEL $\emptyset:$ MODE $\emptyset$, INTERRUPT ON T/C
1: MODE $\emptyset$, NEGATIVE PULSE ON T/C
2: MODE 3, SQUARE WAVE OUTPUT

Figure 9


Figure 10

## Joystick Interface

The joystick interface converts positional information from hand-held joysticks (1 or 2) into CPU data. Each joystick provides 1 or 2 push-buttons and X, Y position for a total of 4 bits each. You can use 2 joysticks. The joystick handle is connected to two potentiometers mounted perpendicular to each other; one for $X$ position, one for $Y$ position. Through the cable, the main logic board applies +5 VDC to one side and ground to the other of the pots. The pot wiper is the position signal: a voltage between 0 and +5 VDC . This signal is applied to one input of a comparator U119. The other comparator input is the reference signal (a ramp between 0.0 to +5.0 volts.) When the position signal is equal or less than the reference signal, the comparator output goes true. This comparator output is the $X$ or $Y$ position data bit. The ramp is reset to 0.0 VDC whenever a "write"' is made at Port 200/201 Hex. The IOW* signal turns on Q2, which drains C6 to 0.0 volts. When Q2 is turned off, Q1, R3, R4, R9, and CR1 create a constant-current source that linearly charges C 6 to +5.0 VDC in 1.12 milliseconds. The joystick information is "read" by the CPU at Port 200/201 Hex through U18. See Figure 11.

## Printer Interface

The printer interface is totally contained in a custom Gate Array U108 and is shown in Figure 12. Functionally, the printer interface consists of an output data latch (write @ 378) and accompanying input data buffer. The latch and buffer reads back the output data (read @ 37A) with an accompanying input buffer for read-back (read @ 37A). The input buffer is for reading printer input signals (read @ 379), I/O address decoding, data transceiver, and interrupt logic. The interrupt is (logically) ACKNOWLEDGE* if interrupts are enabled (37A Bit 4).

## JOYSTICK I/F



PROGRAMMING CONSIDERATIONS


IOR's

@ REGULAR INTERVALS

ONCE TRIGGERED BY SOFTWARE THE INTERGRATOR CIRCUIT PRODUCES A PULSE THE DURATION OF WHICH IS DEPENDENT ON JOYSK POSITION.

Figure 11


PRINTER SCHEMATIC

Figure 12

## Floppy Disk Controller Interface

The Floppy Disk Controller interface consists of the 765 controller and support circuitry. The oscillator formed by U29, Y1 generates an 8.00 MHz clock that is divided down to 4.00 MHz and 2.00 MHz by U 30 . The 4.00 MHz signal is applied to the FDC for its internal processor clock (CLK pin 19) and to counter circuit U31 to generate the FDC write clock (WCK pin 21). U31 produces a pulse at count 15 that loads the next count of 8 . Therefore, WCK is a 250 nanosecond pulse every 2.0 microseconds. The CPU interface consists of the chip select decode U98, U51 address A0, A1, function decode FDCCS*, and IOR*, IOW*. The function decode FDCDS* is separated into the lower four address range for the "DOR" register and into the upper four address range for the FDC; both are inhibited by AEN. The "DOR" latch U71 is for configuration control, drive select, reset, interrupt/DMA request enable, drive motor control, and software transfer terminal count. Latch U106 is used to delay the FDC DMA request (DRQ) as specified by the 765 specification. Counter U50 is used to add pre-compensation to the MFM coded write data ( 250 nanosecond pulse every 2.0 microseconds maximum). The 765 FDC signals "early" and "late" determine the number of 8 MHz clock periods ( 125 nanoseconds) the write data is delayed thru U69-normal $=6$, early $=4$, late $=7$. Data separator U69 converts "raw data" from the drive into read data (RDD) and read clock (RDW).

## Introduction to the Video System Logic

The Video System Logic is composed of three functional sections: Video Address Generation, Video Memory, and Video Data Processing.

The Video Address Generation logic is composed of the MC6845, one control register U99, and six multiplexers. The MC6845 generates the video addresses and video timing signals for all modes of operation. The control register is used for paging the 128 K system memory. The MC6845 has a maximum address range of 32 K . Since the Video/System RAM size is 128 K , the RAM is divided into 4 pages of 32 K each. Selection of the page is determined by the Page Register U99, by the Page Multiplexer U89, U90, and by associated gates. The CPU has the option of addressing the RAM at two different locations, one as 32 K window starting at B 8000 or as System RAM at an assigned 128 K page between 00000 and A0000. The top two bits of the control register U99 are used to select different addressing modes for high resolution graphics. For programming ease, any of the graphics modes requiring only 16 K of memory will be automatically selected by the addressing logic. Multiplexers U72 through U75 are used to select either the CPU or the video address and to switch between row and column addresses for the dynamic RAM chips.

The Video Memory is composed of two 8 bit rows of 64 K dynamic RAMs ( 64 K $\times 8 \times 2$ ) that is shared by the video and the CPU (8088). The video system sees the memory organized as $64 \mathrm{~K} \times 16$ bits wide to allow a high video bit rate. See the RAM Timing Chart (page 41) for the RAM specifications. The CPU sees the memory as only 8 bits wide. During any read operation (either CPU or video), both banks of memory are accessed at the same time. The data is latched into U35 and U56 for the video or into U36 and U57 for the CPU. The video uses all 16 bits of memory; however, the CPU expects only 8 bits, and the extra bits are ignored. The CPU selects the $64 \mathrm{~K} \times 8$ bank using address 00000; so the memory is organized as $128 \mathrm{~K} \times 8$ to the CPU.

The RAM is located at an address determined by the memory configuration control port. In a 128 K system that address is normally 00000 - 1FFFF. In addition this memory may be accessed at the 32 K byte address from B8000 - BFFFF. A page register selects which of the 4 pages are available to the CPU. The CPU access is synchronized to the video so that no adverse effects are observed at any time.

The processor can address any location in memory while the video is using only a 16 K or 32 K page. This allows one video page to be displayed while another is being changed by the CPU. Therefore, the displayed page can be switched during vertical retrace. A video system memory map is shown on the next page.


VIDEO SYSTEM MEMORY MAP

The third section of the video (Video Data Processing) is composed of only one 40-pin IC. However, a large amount of logic has been compressed into that single HCMOS custom IC. Figure 13 shows a block diagram of the logic. The multiplexed data input from the RAM is divided back into 16 bits of information. For the alphanumeric mode this is character byte and attribute byte data. In alphanumeric mode, the character data is used to address the character ROM. The character ROM output is loaded into a shift register controls the on/off selection of each video dot. The attribute byte defines foreground and background color. In graphics mode, the data bits are first rearranged depending on the mode, and then loaded into the shift register. The mode selection multiplexer selects alpha, 2 color, 4 color medium resolution, 4 color high resolution, or 16 color modes. The output of the mode selection multiplexer clocks the RGBI data before it goes to the palette RAM and then clocks it again after the palette. From this last register, the RGBI data passes through the border color mux and then through the output buffers as RGBI data. The RGB outputs are also used to generate the composite color signal.

The remaining logic of the Video Array consists of the timing logic, the control register logic and the timing delay logic. The timing logic provides the clocks and shift load signals for the latches and the shift registers. The control registers are loaded by the system software and provide the mode selection and color control bits. The timing delay logic synchronizes all the logic. See Figure 14 for the Video Array Block Diagram.

Main System Board Ram Timing Specification
AC Operating Conditions and Characteristics

| Parameter | Symbol | Min. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: |
| Random Read or Write Cycle Time | tRC | 279 | - | ns |
| Read Write Cycle Time | tRWC | 279 | - | ns |
| Access Time from Row Address Strobe | tRAC | - | 200 | ns |
| Access Time from Column Address | tCAC | - | 100 | ns |
| Output Buffer and Turn-Off Delay | tOFF | 0 | 30 | ns |
| Row Address Strobe Precharge Time | tRP | 100 | - | ns |
| Row Address Strobe Pulse Width | tRAS1 | 170 | - | ns |
| Column Address Strobe Pulse Width | tCAS | 130 | - | ns |
| Row Address Setup Time | tASR | 0 | - | ns |
| Row Address Hold Time | tRAH | 20 | - | ns |
| Column Address Setup Time | tASC | 0 | - | ns |
| Column Address Hold Time | tCAH | 35 | - | ns |
| Transition Time (Rise and Fall) | tT | - | 50 | ns |
| Read Command Setup Time | tRCS | 0 | - | ns |
| Read Command Hold Time | tRCH | 0 | - | ns |
| Read Command Hold Time Referenced to RAS | tRRH | 0 | -- | ns |
| Write Command Hold Time | tWCH | 35 | - | ns |
| Write Command Hold Time Referenced to RAS | tWCR | 95 | - | ns |
| Write Command Pulse Width | tWP | 35 | - | ns |
| Write Command to Row Strobe Lead Time | tRWL | 45 | - | ns |
| Write Command to Column Strobe Lead Time | tCWL | 45 | - | ns |
| Data in Setup Time | tDS | 0 |  | ns |
| Data in Hold Time | tDH | 35 | - | ns |
| Data in Hold Time Referenced to RAS | tDHR | 95 | - | ns |
| Column to Row Strobe Precharge Time | tCRP | 0 | - | ns |
| RAS Hold Time | tRSH | 85 | - | ns |
| Refresh Period | tRFSH | - | 2.0 | ns |
| WRITE Command Setup Time | tWCS | 0 | - | ns |
| CAS to WRITE Delay | tCWD | 45 | - | ns |
| RAS to WRITE Delay | tRWD | 120 | - | ns |
| CAS Hold Time | tCSH | 200 | - | ns |



VIDEO SYSTEM BLOCK DIAGRAM

Figure 13


VIDEO ARRAY BLOCK dIAGRAM

Figure 14

## Memory Map

See Port 00AO

MEMCONFIG, 3
MEMCONFIG, 2
MEMCONFIG, 1


## Video System Modes

## Display Modes

The video circuitry is designed to operate with three types of display devices: a standard TV using an optional RF modulator, a composite monitor and an RGBI color monitor. To support these different display types, both a composite video output and a 9 -pin RGBI connector are provided.

The video display system is very flexible and can be programmed for a number of video modes. These modes use varying numbers of colors (2, 4, or 16). These 16 colors are defined by combinations of the RGBI as shown in the color chart below and can be used for foreground, background, and character blinking. If you are using a black and white monitor. (These colors will appear as shades of gray for use as reverse video, highlighting, and blinking.) In addition any 1 of the 16 colors or shades of gray can be used for the screen border.

| Color | I | R | G | B |
| :--- | :--- | :--- | :--- | :--- |
| Black | 0 | 0 | 0 | 0 |
| Blue | 0 | 0 | 0 | 1 |
| Green | 0 | 0 | 1 | 0 |
| Cyan | 0 | 0 | 1 | 1 |
| Red | 0 | 1 | 0 | 0 |
| Magenta | 0 | 1 | 0 | 1 |
| Brown | 0 | 1 | 1 | 0 |
| Light Gray | 0 | 1 | 1 | 1 |
| Dark Gray | 1 | 0 | 0 | 0 |
| Light Blue | 1 | 0 | 0 | 1 |
| Light Green | 1 | 0 | 1 | 0 |
| Light Cyan | 1 | 0 | 1 | 1 |
| Pink | 1 | 1 | 0 | 0 |
| Light Magenta | 1 | 1 | 0 | 1 |
| Yellow | 1 | 1 | 1 | 0 |
| White | 1 | 1 | 1 | 1 |

## Available Colors Table

## Operating Modes

The operating modes supported by the system software may be grouped into two categories: alphanumeric, and graphic.

The alphanumeric mode has two basic types of operation: 80 character by 25 rows and 40 character by 25 rows. In both modes the characters are generated by a 256 character ROM. The character ROM is divided into the following groups:

96 Standard ASCII characters
48 Block Graphics characters
64 Foreign Language/Greek characters
16 Special Graphics characters
32 Word Processing/Scientific-Notation characters
In both modes all characters are 7 dots wide by 7 dots high and are placed in an 8 dot wide by 8 or 9 dot high matrix.
In both the $40 \times 25$ mode and the $80 \times 25$ mode, two bytes of data are used to define each character on the screen. The even address ( $0,2,4$ etc.) is the character code and is used in addressing the character generator ROM. The odd address ( $1,3,5$ etc.) is the attribute byte, that defines the foreground and background color of the character. The following chart shows how the attribute byte functions to control colors.

| ATTRIBUTE BYTE |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BIT | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| $\begin{gathered} 3 D 9 \text { Bit } 5 \\ =0 \end{gathered}$ | \| | $R$ | unc | B | I | $\begin{gathered} \text { Fore } \\ \text { R } \end{gathered}$ | $\begin{gathered} \text { und } \\ G \end{gathered}$ | B |
| $\begin{gathered} 3 D 9 \text { Bit } 5 \\ =1 \end{gathered}$ | Blink | R | G | B | I | R | G | B |
| Blink $=$ A 1 in bit 7 enables blinking of the foreground. |  |  |  |  |  |  |  |  |

## Graphics Mode

The Video Color/Graphics System can be programmed for a wide variety of modes. The Tandy 1000 and its system ROM BIOS supports the following Graphics Modes:

| Mode | IMB PCjr | IBM PC |
| :---: | :---: | :---: |
| 4-Color Medium-Resolution | x | x |
| 16-Color Medium-Resolution | x |  |
| 16-Color Low-Resolution | x |  |
| 2-Color High-Resolution | x | x |
| 4-Color High Resolution | x |  |

Low and medium resolution modes work on all types of display devices. The high-resolution mode may require a monitor for correct operation.

## Graphics Memory Usage

Graphics memory uses either two or four banks of 8000 bytes. In either case pixel information for the display's upper-left corner is found at address 0000. The 4-color high-resolution and 16 -color medium-resolution graphics use four banks of 8000 bytes.

The following is a table of the graphics storage organization for four banks of 8000 bytes:


## Graphics Storage Organization

The 2-color high-resolution graphics, the 4-color medium-resolution graphics, and the 16 -color low-resolution graphics use only two banks of 8000 bytes.

The following is a table of the graphics storage organization for two banks of 8000 bytes:


## Graphics Storage Organization

## High-resolution 2-Color Graphics

The high-resolution 2-color mode may require a high-resolution monitor for correct operation. This mode can display 2 of 16 possible colors. It contains 200 rows of 640 pixels, requires 16K bytes of read/write memory, and formats 8 pixels per byte. This mode is available in the IBM PC and IBM PCjr.

$$
\begin{aligned}
& \text { Byte } 0=\text { eighth pixel } \\
& \text { Byte } 1=\text { seventh pixel } \\
& \text { Byte } 2=\text { sixth pixel } \\
& \text { Byte } 3=\text { fifth pixel } \\
& \text { Byte } 4=\text { fourth pixel } \\
& \text { Byte } 5=\text { third pixel } \\
& \text { Byte } 6=\text { second pixel } \\
& \text { Byte } 7=\text { first pixel }
\end{aligned}
$$

## High-Resolution 4-Color Graphics

The high-resolution 4-color mode may require a high-resolution monitor for correct operation. This mode can display 4 out of 16 colors. (Each pixel selects 1 of 4 colors.) It contains 200 rows of 640 pixels, requires 32 K bytes of read/write memory and formats 8 pixels per two bytes ( 1 even-byte and 1 odd-byte). This mode is only supported on the IBM PCjr.

|  | Even Bytes | Odd Bytes |
| :--- | :---: | :---: |
| First Display Pixel | PAO (7) | PA1 (7) |
| Second Display Pixel | PAO (6) | PA1 (6) |
| Third Display Pixel | PAO (5) | PA1 (5) |
| Fourth Display Pixel | PAO (4) | PA1 (4) |
| Fifth Display Pixel | PAO (4) | PA1 (3) |
| Sixth Display Pixel | PAO (3) | PA1 (2) |
| Seventh Display Pixel | PAO (1) | PA1 (2) |
| Eighth Display Pixel | PAO (0) | PA1 (0) |

## Medium-Resolution 16-Color Graphics

The medium-resolution 16-color graphics mode works with all types of display devices. This mode specifies 1 of 16 colors for each pixel. It requires 32 K bytes of read/write memory, contains 320 rows of 200 pixels, and formats each byte in the same manner as the low-resolution mode. This mode is available in the IBM PCjr only.

Second Pixel

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PA0 | PA - | PA2 | PA3 | PA0 | PA1 | PA2 | PA3 |

## Low-Resolution 16-Color Graphics

The low-resolution mode works with all types of display devices. This mode contains 200 rows of 160 pixels, requires 16 K bytes of read/write memory, specifies 16 colors for each pixel by the RGBI bits, and formats 2 pixels per byte. This mode is available in the IBM PCjr only.

Second Pixel
First Pixel

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PA0 | PA1 | PA2 | PA3 | PA0 | PA1 | PA2 | PA3 |

## Medium-Resolution 4-Color Graphics

The medium-resolution mode works with all types of display devices. This mode supports 4 of 16 possible colors. It requires 16 K bytes of read/write memory, contains 320 rows of 200 pixels, selects 1 of 4 colors for each pixel, and formats 4 pixels per byte. This mode is available in the IBM PC and IBM PCjr.

Fourth Pixel Third Pixel Second Pixel First Pixel

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PA0 | PA1 | PA0 | PA1 | PA0 | PA1 | PA0 | PA1 |

## System Logic Registers

## Video Array Registers

The Video Array is addressed at I/O addresses 3D8, 3D9, 3DA, and 3DE. Address 3D8 and 3D9 are PC compatible control registers. Address 3DA is an address register for port selection inside the Video Array. Address 3DE is the data port. You can program all Video Array registers, except 3D8 and 3D9. Registers are programmed by first writing an address to 3DA and the data to 3DE. The following chart shows the address at each of these Video Array registers.

| Register | Address Hex |
| :--- | :---: |
| Palette Mask | 01 |
| Border Color | 02 |
| Mode Control | 03 |
| Palette Registers | $10-1 F$ |

## Palette Mask Register

This 4-bit (write-only) register has a video array address of 01 H . The following table lists each bit.

| Bit | Palette Mask |
| :---: | :---: |
| 0 | 0 |
| 1 | 1 |
| 2 | 2 |
| 3 | 3 |

This register allows any of the address lines into the palette where they are then forced to 0 .

## Border Color Register

This 4-bit (write-only) register can be addressed in the video array at 02H. The following table gives the register's bit functions.

Bit

1
2
3
$0 \quad B$ (Blue) Border Color Select

## Description

G (Green) Border Color Select
R (Red) Border Color Select
I (Intensity) Border Color Select

## Border Color Register

The screen-border color is defined by bits $0-3$, that selects one of 16 colors. See the Colors Definition Table listed in this section.

## Mode Control Register

This 5-bit (write-only) register is accessed at the video array address 03H. The following table gives the register's bit functions.

## Bit Description

$0 \quad$ Not used

1 Not used
2
3
4
Border Enable
4 Color High Res. 16 Color Mode

## Mode Control Register

Bit 0 Not Used
Bit 1 Not Used
Bit 2 This bit enables the border color register. For PC compatibility this bit should be 0 . For PCjr compatibility this bit should be 1 .

Bit 3 For the 4 color $640 \times 200$ graphics mode, this bit should be set to 1 and for all other modes set to 0 .

Bit 4 Set this bit to 1 for 16 color modes and to 0 for all other modes.

## Palette Registers

The palette is a $16 \times 4$ high speed RAM that lets you redefine any color. To load the palette, write the hex address to the video array address register at 3DA. (The 16 palette registers are located at addresses 10-1F.) Then the new palette color is written to 3DE. Only the 4 least significant bits are used as shown by the following table:
Bit Description

| 0 | Blue |
| :---: | :---: |
| 1 | Green |
| 2 | Red |
| 3 | Intensity |

## Palette Register Format

Bit 4 of the video array address register is used to select the palette. Once the palette is selected, hashing or noise will be observed on the display. To avoid this effect, the palette should be accessed during vertical or horizontal blanking, and the address register should be changed to less than 10 prior to returning to normal operation.

During the normal display operation, the RGBI information is used to address the palette as shown in the chart below. If a graphics mode (which uses fewer than 16 colors) is selected, the palette is addressed by the extra bits defined by the control registers at 3D8 and 3D9. Optionally, the extra bits may be masked off (PA3 and PA2 are set to 0 or PA3, PA2 and PA1 are set to 0 ) by using the palette mask register. When you use the mask register, only palette registers 0 and 1 will be used for 2 color modes. Only registers $0,1,2$ and 3 will be used for 4 color modes.

| Palette Address Bits | Palette Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| PAO (B) | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 1 |
| PA1 (G) | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| PA1 (R) | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| PA3 (I) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

## Video Memory Map and Registers

## Video Memory Map

Address Description
3D0 Not used
3D1 Not used
3D2 Not used
3D3 Not used
3D4 6845 Address Register
3D5 6845 Data Register
3D6 Not used
3D7 Not used
3D8 Mode Select Register
3D9 Color Select Register
3DA Video Array Address \& Status
3DB Clear Light Pen Latch
3DC Set Light Pen Latch
3DD Not used
3DE Gate Array Data
3DF CRT Processor Page Register
Operation of the video subsystem and mode selection is controlled by the registers listed in the above table. The video array registers at 3DA were explained earlier. The remaining control registers operate as follows:

## 6845 Address Register (3D4)

This 5-bit write-only register addresses 1 of the 18 internal data registers of the 6845 CRT controller. The selected register is then read or written through the 6845 data register.

## 6845 Data Register (3D5)

This port is used to access the internal data register previously selected through the 6845 address register.
PROGRAMMING TABLE FOR THE 6845 All Values in Hex (Decimal)

|  | Register Address | $\begin{gathered} 40 \times 25 \\ \text { Alpha } \end{gathered}$ | $\begin{gathered} 80 \times 25 \\ \text { Alpha } \\ \hline \end{gathered}$ | Low Res. Graphics | High Res. Graphics | $\begin{gathered} 40 \times 25 \\ \text { Alpha } \end{gathered}$ | $\begin{gathered} 80 \times 25 \\ \text { Alpha } \\ \hline \end{gathered}$ | Low Res. Graphics | High Res. Graphics |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | Horizontal Total | 38 (56) | 71 (113) | 38 (56) | 71 (113) | 38 (56) | 71 (113) | 38 (56) | 71 (113) |
| 01 | Horizontal Displayed | 28 (40) | 50 (80) | 28 (40) | 50 (80) | 28 (40) | 50 (80) | 28 (40) | 50 (80) |
| 02 | Horizontal Sync Position | 2D (45) | 5A (90) | 2D (45) | 5A (90) | 2C (44) | 58 (88) | 2C (44) | 58 (88) |
| 03 | Horizontal Sync Width | OA (10) | OA (10) | OA (10) | OA (10) | 08 (8) | 10 (16) | 08 (8) | 10 (16) |
| 04 | Vertical Total | 1C (28) | 1C (28) | 7F (127) | 3F (63) | 1F (31) | 1F (31) | 7F (127) | 3F (63) |
| 05 | Vertical Total Adjust | 01 (1) | 01 (1) | 06 (6) | 06 (6) | 06 (6) | 06 (6) | 06 (6) | 06 (6) |
| 06 | Vertical Displayed | 19 (25) | 19 (25) | 64 (100) | 32 (50) | 19 (25) | 19 (25) | 64 (100) | 32 (50) |
| 07 | Vertical Sync Position | 1A (26) | 1A (26) | 70 (112) | 38 (56) | 1 C (28) | 1 C (28) | 70 (112) | 38 (56) |
| 08 | Interlace Mode | 02 (2) | 02 (2) | 02 (2) | 02 (2) | 02 (2) | 02 (2) | 02 (2) | 02 (2) |
| 09 | Max Scan Line Address | 08 (8) | 08 (8) | 01 (1) | 03 (3) | 07 (7) | 07 (7) | 01 (1) | 03 (3) |
| 10 | Cursor Start | 06 (6) | 06 (6) | 06 (6) | 06 (6) | 06 (6) | 06 (6) | 06 (6) | 06 (6) |
| 11 | Cursor End | 07 (7) | 07 (7) | 07 (7) | 07 (7) | 07 (7) | 07 (7) | 07 (7) | 07 (7) |
| 12 | Start <br> Address (High) | 00 (0) | 00 (0) | 00 (0) | 00 (0) | 00 (0) | 00 (0) | 00 (0) | 00 (0) |
| 13 | Start <br> Address (Low) | 00 (0) | 00 (0) | 00 (0) | 00 (0) | 00 (0) | 00 (0) | 00 (0) | 00 (0) |
| Monitor Mode |  |  |  |  |  |  |  |  |  |

## Mode Register (3D8)

This mode register controls the basic operating characteristics of the video. It consists of a 6 -bit write-only register, and each bit controls one aspect of the operation of the video subsystem.

## Bit Description

0 High Resolution Dot Clock. This bit controls the operating speed of the video system. A " 0 " selects the lower speed for 40 character text or low resolution graphics modes. A " 1 " selects high speed for 80 character text or high resolution graphics modes.
1 Graphics Select. This bit selects alpha or graphics modes. A " 0 " selects the alpha mode. A " 1 " selects the graphics mode.

2 Black and White Select. This bit selects black and white or color mode for TV or composite monitors. A " 1 " will disable the color signal and give a black and white image. In RGB monitors, a different color palette is selected by this bit in $320 \times 2004$ color graphics mode. This bit will have no other effect on RGB operation.
3 Video Enable. This bit enables or disables the video display. A "1" enables the video display.
4640 Dot Graphics. This bit is used to select either of the two $640 \times 200$ graphics modes. A " 1 " selects $640 \times 200$.
5 Blink Enable. This control bit is used in the alpha mode only. A " 1 " selects blinking if the attribute bit is set (bit 7). A " 0 " selects 16 background colors. (With blinking selected only 8 background colors are available.)

## Color Select Register (3D9)

This register is used to control several color features in the alpha modes and the $320 \times 2004$ color mode.

## Bit Description

0-3 Alpha Border. In either alpha mode, these bits are used to select the screen color. In the $320 \times 2004$ color mode, these bits determine the background color if PA0 and PA1 are both 0 . In the $640 \times 2002$ color mode, they select the foreground color.

0 Blue
1 Green
2 Red
3 Intensity
4 Alpha Background/320 Graphics Foreground Intensity. When blink is enabled in the alpha mode, this bit is used to select the intensity. In the $320 \times 2004$ color mode, the bit selects the intensity of the foreground.
$5320 \times 2004$ Color Blue Control. This bit is used to control the blue output in $320 \times 200$ color graphics.

## Status Register

The 4-bit "read only" register provides video and light pen status. It is addressed by a read operation at 3DA. (The video array address register is not used to select this port.) The following table gives the register's bit functions:

Bit Status
0 Display Inactive
1 Light Pen Trigger Set
2 Light Pen Switch Made*
3 Vertical Retrace

## Status Register

Bit 0 When bit 0 is (0), the display is active. When (1), this indicates video is not displayed.

Bit 1 When bit 1 is "high," this indicates that the light pen input has a positive-going edge, and has set the light pen trigger. When this trigger is "low," during a system power-on, it may be cleared by performing an I/O command to address 3DB. No specific data is required due to address-activated action.

Bit 2 Bit 2 is the status of the light pen switch. When bit 2 is "low," the light pen switch is on. The switch is not latched or debounced.

Bit 3 When bit 3 is "high," this indicates that the vertical retrace is active.

## Light Pen Latch

Set 3DC
Reset 3DB
Any output to the port sets or resets the light pen latch (data byte has no effect). Before the 6845 can read the light pen again, the latch (3DB) must be cleared.

## CRT/Processor Page Register

This 8-bit (write-only) register is addressed at 3DF. The descriptions below are of the register functions:

## Bit Description

$0 \quad$ CRT Page 0
1 CRT Page 1
2 CRT Page 2
3 Processor Page 0
4 Processor Page 1
$5 \quad$ Processor Page 2
$6 \quad$ Video Address Mode 0
$7 \quad$ Video Address Mode 1

## CRT / Processor Page Register

## CRT Page 0-2

Bits $0-2$ select the 16 K page used by the video. In 32 K modes, bit 0 is ignored.

## Processor Page 0-2

These processor page bits are combined with the CPU address to select the 32 K segment of memory accessed at B8000. If an odd page number is selected ( $1,3,5$, etc.) the window is reduced to 16 K .

## Video Address Mode 0-1

These bits are used in conjunction with the graphics control bit (bit 1 at 3D8) to select the video address supplied to the RAM. The following chart lists the values to be used for each video mode.

| Video Address Mode |  |  |
| :--- | :---: | :---: |
| Mode Description | $\mathbf{1}$ (Bit 7) | $\mathbf{0}$ (Bit 6) |
| All Alpha Modes | 0 | 0 |
| Low-Resolution-Graphics Modes | 0 | 1 |
| High-Resolution-Graphics Modes | 1 | 1 |
| Unused, Reserved | 1 | 0 |

CRT / Processor Page Register

General Memory Information
Mode Selection Summary

|  | $40 \times 25$ <br> Alpha <br> B/W | $40 \times 25$ <br> Alpha <br> Color | $80 \times 25$ <br> Alpha <br> Color | $160 \times 200$ <br> 16 <br> Graphics | $320 \times 200$ <br> 4 <br> Graphor <br> Graph | $320 \times 200$ <br> 4 Shades <br> Of B/W | $320 \times 200$ <br> 16 Color <br> Graphics | $640 \times 200$ <br> 2 Color <br> Graphics | $640 \times 200$ <br> 4 Cralor <br> Graphics |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 3D8 <br> Bit 0 <br> HRESCK | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 |
| 3D8 <br> Bit 1 <br> GRPH | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 |
| 3K8 <br> Bit 2 <br> BW | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 3D8 <br> Bit 4 <br> HRESAD | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 |
| 3DA <br> REG 03 <br> Bit 3 <br> 4 Color | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| 3DA <br> Reg 03 <br> Bit 4 <br> 16 Color | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 |

## I/O Map

Address Block

| 0000-001F | $0000-000 F$ |
| :---: | :---: |
| 0020-003F | 0020-0021 |
| 0040-005F | 0040-0043 |
| 0060 - 007F | 0060-0063 |
| 0080-009F | 0080-0083 |
| 00A0 - 00BF | 00A0 |
| 00C0 - OODF | 00C0-00C1 |
| 00E0 - 01FF |  |
| 0200 - 020F | 0200-0201 |
| 0210-031F |  |
| 0320-032F |  |
| 0330 - 036F |  |
| 0370 - 037F | 0378-037B |
| 0380 - 03CE |  |
| 03D0- 03DF | All |
| 03E0 - 03EF |  |
| 03F0 - 03FF | 03F2, F4, F5 |
| 0400 - FFFF |  |

## Function

DMA Function
Interrupt Controller
Timer
PIO
DMA Page Register
NMI Mask Register
Sound Generator
Reserved
Joystick I/F
Reserved
Reserved Hard Disk
Not Assigned
Printer
Not used
System Video
Reserved
Floppy Disk Controller Not Usable

## System Configuration Port I/O Address: 00AO

| Data <br> Bit | Function |  |
| :---: | :--- | :--- |
|  |  | Selects 1 Of $8-128 \mathrm{~K}$ |
| D1 | MEMCONFIG 1 | Memory Pages Where |
| D2 | MEMCONFIG 2 | Video/System Ram Memory |
| D3 | MEMCONFIG 3 | To Be Located. See |
|  |  | Memory Map For Details. |
|  |  | Register Located Main Logic. |
| D4 |  | Reserved |
| D5 |  | Reserved |
| D6 |  | Reserved |
| D7 | NMIEN | Enables NMI Input To To |
|  |  | CPU 0 = Mask 1 = Enable |
|  |  | Register Located Main Logic. |

## ROM

System ROM
Size: $\quad 16 K \times 8$ (128K)
$32 \mathrm{~K} \times 8$ (256K) optional
Quantity: 1 or 2 , socketed
Address Range - ROM: F0000 To FFFFF
Two 32 K address segments are decoded in hardware.
There will always be one system ROM located at the boot segment F8000 - FFFFF. The second system ROM will be limited to the second address segment F0000 - F7FFF.

No error detection capability.

## RAM

RAM address range: 00000 to B8000
RAM memory used by the CPU must be continuous beginning at 00000 .
Address selection granularity -64 K .
Video memory access at B8000/C0000.
Presence (quantity) of RAM in addition to video/system RAM determined by initialization routing.

Video system RAM memory address select defined by "MEMCONFIG" register at 00A0. On power-up or reset, address defaults to B8000.

No memory error detection capability.

## Detailed Memory Map

## Address ${ }^{1}$ <br> 0000 <br> 0001 <br> 0002 <br> 0003 0004 0005 0006 0007 0008 <br> $$
0009
$$ <br> 000A <br> 000B <br> 000C <br> 000D <br> 000E 000F

## Address ${ }^{2}$

0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
002A
002B
002C
002D
002E
002F

## Description

8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller
8237A-5 DMA Controller

## Description

8259A Interrupt Controller
8259A Interrupt Controller
8259A Interrupt Controller
8259A Interrupt Controller
8259A Interrupt Controller
8259A Interrupt Controller
8259A Interrupt Controller
8259A Interrupt Controller
Not used
Not used
Not used
Not used
Not used
Not used
Not used
Not used

1. A4 - A15 are used to generate the chip select for the 8237A-5. A0, A1, A2, A3 are connected directly to the 8237A-5. The assigned addresses are $0000-000 \mathrm{~F}$. The DMA is optional.
2. $A 3-A 15(B)$ are used to generate the chip select for the 8259A. A0 is decoded directly by the 8259A. The assigned addresses are 0020-0021(B).

| Address ${ }^{3}$ | Description |
| :---: | :---: |
| 0040 | 8253-5 Timer |
| 0041 | 8253-5 Timer |
| 0042 | 8253-5 Timer |
| 0043 | 8253-5 Timer |
| 0044 | 8253-5 Timer |
| 0045 | 8253-5 Timer |
| 0046 | 8253-5 Timer |
| 0047 | 8253-5 Timer |
| 0048 | Not used |
| 0049 | Not used |
| 004A | Not used |
| 004B | Not used |
| 004C | Not used |
| 004D | Not used |
| 004E | Not used |
| 004F | Not used |
| Address ${ }^{4}$ | Description |
| 0060 | 8255A-5 PPI |
| 0061 | 8255A-5 PPI |
| 0062 | 8255A-5 PPI |
| 0063 | 8255A-5 PPI |
| 0064 | 8255A-5 PPI |
| 0065 | 8255A-5 PPI |
| 0066 | 8255A-5 PPI |
| 0067 | 8255A-5 PPI |
| 0068 | Not used |
| 0069 | Not used |
| 006A | Not used |
| 006B | Not used |
| 006C | Not used |
| 006D | Not used |
| 006E | Not used |
| 006F | Not used |

3. A3-A15 are used to generate the chip select for the 8253-A. A0 is decoded directly by the 8253-A. The assigned addresses are 0040-0043.
4. A3 - A15 are used to generate the chip select for the 8255A-5. A1 and A0 are decoded directly by the $8255 \mathrm{~A}-5$. The assigned addresses are 0060-0063.

## Detailed Memory Map——Continued

| 0060 - PORT A |  |
| :---: | :---: |
| Bit | Description |
| 0 | Keyboard Bit 0 - LSB |
| 1 | Keyboard Bit 1 - |
| 2 | Keyboard Bit 2 - |
| 3 | Keyboard Bit 3 - |
| 4 | Keyboard Bit 4 - |
| 5 | Keyboard Bit 5 - |
| 6 | Keyboard Bit 6 - |
| 7 | Keyboard Bit 7 - MSB |
| See Keyboard Specifications |  |
| 0061 - PORT B - READ OR WRITE |  |
| Bit | Description |
| 0 | 1 = 8253 Gate \#2 Enabled |
| 1 | Speaker Data Out |
| 2 | Not used |
| 3 | Not used |
| 4 | Not Used |
| 5 | Sound Control 0 |
| 6 | Sount Control 1 |
| 7 | 1 = Keyboard Clear |
| 0062 - PORT C - READ/WRITE5 |  |
| Bit | Description |
| 0 | (Out) Not Used |
| 1 | (Out) Multi-Data |
| 2 | (Out) Multi-Clock |
| 3 | (Out) Not Used |
| 4 | (In) Not Used |
| 5 | 8253 Cut \# |
| 6 | (In) Not Used |
| 7 | (In) Not Used |

[^0] output at PCO - PC3.

## Detailed Memory Map-—Continued

Address ${ }^{6}$ Description
$0080 \quad$ DMA Page Reg. (Not Used)
0081 DMA Page Reg. (Ch 2)
0082 DMA Page Reg. (Ch 3)
0083 DMA Page Reg. (Ch 0, 1)
0084 Not used
0085 Not used
0086 Not used
0087 Not used
0088 Not used
$0089 \quad$ Not used
008A Not used
008B Not used
008C Not used
008D Not used
008E Not used
008F Not used

## 0081 - WRITE ONLY

## Address

Description
Bit $0 \quad$ DMA Ch 2 Address A16
Bit 1 DMA Ch 2 Address A17
Bit 2 DMA Ch 2 Address A18
Bit 3 DMA Ch 2 Address A19
Bit 4
Bit 5
Not used
Not used
Bit 6
Bit 7
Not used
Not used

## 0082 - WRITE ONLY

## Address

Bit 0
Bit 1
Bit 2
Bit 3
Bit 4
Bit 5
Bit 6
Bit 7

## Description

DMA Ch 3 Address A16
DMA Ch 3 Address A17
DMA Ch 3 Address A18
DMA Ch 3 Address A19
Not used
Not used
Not used
Not used

## 0083 - WRITE ONLY

Address

Bit 1
Bit 2
Bit 3
Bit 4
Bit 5
Bit 6
Bit 7

Address ${ }^{7}$
00AO
00A1
00A2
00A3
00A4
00A5
00A6
00A7
00A8
00A9
00AA
00AB
00AC
00AD
OOAE
00AF

Bit $0 \quad$ DMA CH $0-1$ Address A16
DMA CH 0-1 Address A17
DMA CH 0-1 Address A18

## Description

DMA CH 0 - 1 Address A19
Not used
Not used
Not used
Not used

## Description

NMI Mask Register
NMI Mask Register
NMI Mask Register
NMI Mask Register
NMI Mask Register
NMI Mask Register
NMI Mask Register
NMI Mask Register
Not used
Not used
Not used
Not used
Not used
Not used
Not used
Not used
7. $A 0, A 1, A 2=X$.
$X=$ don't care
Detailed Memory Map-_Continued

## Address ${ }^{8}$ <br> 00C0 <br> 00C1 <br> 00C2 <br> 00C3 <br> 00C4 <br> 00C5 <br> 00C6 <br> 00C7 <br> 00C8 <br> 00C9 <br> 00CA <br> 00CB <br> OOCC <br> 00CD <br> OOCE <br> OOCF

## OOAO, OOA1 ${ }^{9}$

## Bit <br> 0 <br> 1 <br> 2 <br> 3 <br> 4 <br> 5 <br> 6 <br> 7

## Description

Sound SN76496
Sound SN76496
Sound SN76496
Sound SN76496
Sound SN76496
Sound SN76496
Sound SN76496
Sound SN76496
Not used
Not used
Not used
Not used
Not used
Not used
Not used
Not used

## Description

Not Used
MEMCONFIG 1
MEMCONFIG 2
MEMCONFIG 3
X
X
X
1 = Enable NMI
8. The chip select is decoded for Write Only, and approximately 42 wait states are inserted.
9. $X=$ don't care.

## Detailed Memory Map_-Continued

| Address ${ }^{10}$ | Description |
| :---: | :---: |
| 0200 | Joystick |
| 0201 | Joystick |
| 0202 | Joystick |
| 0203 | Joystick |
| 0204 | Joystick |
| 0205 | Joystick |
| 0206 | Joystick |
| 0207 | Joystick |
| 0208 | Not used |
| 0209 | Not used |
| 020A | Not used |
| 020B | Not used |
| 020C | Not used |
| 020D | Not used |
| 020E | Not used |
| 000F | Not used |
| 0201 - READ ${ }^{11}$ |  |
| Bit | Description |
| 0 | $R-X$ Position |
| 1 | $R-Y$ Position |
| 2 | $L-X$ Position |
| 3 | L - Y Position |
| 4 | R Button \#1 |
| 5 | R Button \#2 |
| 6 | L Button \#1 |
| 7 | L Button \#2 |

10. The assigned addresses are $0020-0021$. $A 0, A 1$, and $A 2=X$.
11. A Write to 0200 restarts the integrator. Therefore, Write to 0201 before the port for joystick valves.

## Detailed Memory Map——Continued

0378
Bit Description

0
1
2
3
4
5
6
7
Data Bit 0 - LSB
Data Bit 1 -
Data Bit 2 -
Data Bit 3 -
Data Bit 4 -
Data Bit 5 -
Data Bit 6 -
Data Bit 7 - MSB

0379
Bit
0
1
2
3
4
5
6
7

## Address ${ }^{12}$

0370
0371
0372
0373
0374
0375
0376
0377
0378
0379
037A
037B
037C
037D
037E
037F

## Description

Not used
Not used
Not used
$0=$ Error
$1=$ Printer Selected
$0=$ End Of Form
$0=$ Acknowledge
$0=$ Busy

## Description

Not used
Not used
Not used
Not used
Not used
Not used
Not used
Not used
Printer - Data Latch
Printer - Read Status
Printer - Control Latch
Printer - Not used
Printer - Data Latch
Printer - Read Status
Printer - Control Latch
Printer - Not used
12. $A 0$ and $A 1$ are decoded by printer logic. The assigned addresses are $0378-0378 . A 2=X$, and $X=$ don't care.

| 037A (037E) | Description |
| :---: | :--- |
| Bit |  |
| 0 | $0=$ Strobe |
| 1 | $0=$ Auto FD XT |
| 2 | $0=$ Initialize |
| 3 | $1=$ Select Printer |
| 4 | $0=$ Enable Interrupt |
| 5 | Not used |
| 6 | Not used |
| 7 |  |
|  |  |
| Address | Not used |
| 3D0 | Not used |
| 3D1 | Not used |
| 3D2 | Not used |
| 3D3 | 6845 Address Register |
| 3D4 | 6845 Data Register |
| 3D5 | Not used |
| 3D6 | Not used |
| 3D7 | Mode Select Register |
| 3D8 | Color Select Register |
| 3D9 | Write Video Array Address |
| 3DA | \& Read Status |
|  | Clear Light Pen Latch |
| 3DB | Preset Light Pen Latch |
| 3DC | Not used |
| 3DD | Write Video Array Data |
| 3DE | CRT Processor Page Register |
| 3DF |  |

## Memory Map <br> Video Array 3DA \& 3DE

## Video Array ${ }^{13}$

00 Bit 0
00 Bit 1
00 Bit 2
00 Bit 3
00 Bit 4

01 Bit 0
01 Bit 1
01 Bit 2
01 Bit 3

02 Bit 0
02 Bit 1
02 Bit 2
02 Bit 3
03 Bit 0
03 Bit 1
03 Bit 2
03 Bit 3
03 Bit 4
$10-1 F$ Bit 0
$10-1$ F Bit 1
$10-1 F$ Bit 2
$10-1$ F Bit 3

Read (3DA) Write (3DE)
Display Inactive
Light Pen Set
Light Switch Status
Vertical Retrace
Not Used
Not Used
Not Used
Not Used
Not Used
Not Used
Palette Mask 0
Palette Mask 1
Palette Mask 2
Palette Mask 3
Border Blue
Border Green
Border Red
Border Intensity
Not Used
Not Used
Border Enable
4 Color High Resolution
16 Color Mode
Palette Blue
Palette Green
Palette Red
Palette Intensity
MEMORY MAP

## Address

3D8 Bit 0
3D8 Bit 1
3D8 Bit 2
3D8 Bit 3
3D8 Bit 4
3D8 Bit 5
3D9 Bit 0
3D9 Bit 1
3D9 Bit 2
3D9 Bit 3
3D9 Bit 4
3D9 Bit 5

Description
High Resolution Clock
Graphics Select
Black And White
Video Enable
640 Dot Graphics
Blink Enable
Background Blue
Background Green
Background Red
Background Intensity
Foreground Intensity
Color Select

## MEMORY MAP (3DF)

Bit
0
1
2
3
4
5
6
7

## Description

CRT Page 0
CRT Page 1
CRT Page 2
Processor Page 1
Processor Page 2
Processor Page 3
Video Address Mode 0
Video Address Mode 1

## Address

03F0
03F0
03F1
03F2
03F3
03F4
03F5
03F6
03F7
03F8
03F9
03FA
03FB
03FC
03FD
03FE
03FF

## Description

DOR Register
DOR Register
DOR Register
DOR Register
DOR Register (Write Only)
FDC - Status (Read Only)
FDC - Data (R/W)
FDC - Status (Read)
FDC - Data (R/W)
Not used
Not used
Not used
Not used
Not used
Not used
Not used
Not used

$$
A 1=X
$$

DOR A2 $=0$
FDC A2 $=1$

## 3F2 (WRITE ONLY)

Bit<br>Description<br>0<br>1<br>2<br>Drive Select $A^{*}$<br>Drive Select $B^{*}$<br>$0=$ FDC Reset<br>1 = Enable DMA Req/Interrupt<br>1 = Drive A Motor On<br>1 = Drive B Motor On<br>$1=$ FDC Terminal Count<br>Not Used<br>*To Select Drive A: Bit 0* • Bit 1*<br>To Select Drive B: Bit 0 - Bit $1^{*}$

## 256K MEMORY EXPANSION JUMPER OPTIONS AND CONFIGURATIONS

## Memory Jumper Options

Listed below are the jumper options necessary for the correct operation of the Tandy 1000:

1. With E1-E2 jumper installed, memory on board will be 256 K in size, without a jumper at this location, memory will be 128K.
2. With E3-E4 jumpered, no DMA is present and the memory starting address is 40000 hex. Without a jumper at this location, DMA is present and the memory starting address is 00000 hex.

If jumper E3-E4 is present, U13 (DMA) MUST NOT BE INSTALLED.
The first memory board MUST have DMA (U113) installed regardless whether 128 K or 256 K of memory is present.
With two boards installed, the first memory board must be 256K. See the chart below:

|  | E1-E2 | E3-E4 |
| :---: | :---: | :---: |
| Jumper in |  | NO DMA |
| Jumper out | 256 K | MEM BASE ADDRESS 40000 |
|  |  | DMA PRESENT |
|  | 128 K | MEM BASE ADDRESS 00000 |
|  |  |  |

## 256K MEMORY EXPANSION THEORY OF OPERATION

## Memory I/O

The 256K Memory Expansion board is a byte wide (8 bits at a time) memory array that will provide up to 256 K bytes of RAM. With two fully populated RAM boards installed the maximum RAM of 640 K allowed by the system memory map will be available. ( 128 K on the main logic board and 512 K on the two expansion RAM boards.) Memory Timing comes from the 14.31818 MHz signal on the bus. This signal is located at B30 on the expansion bus and is three times the CPU's operating frequency. This is also the operating frequency for the clocked delay line.

A Memory Read or Memory Write command starts the memory cycle as indicated by one of the RAS* (Row Address Strobe) 0,1,2, or 3 going active low. Memory options E1-E2 and E3-E4 in conjunction with address lines A16-A19 determines which one of the four RAS* signals goes active. The memory command starts a clocked delay line at 30ns starting AMUX (Address Multiplex) and WR* (Write/Read) and a full clock at 70ns for CAS* (Column Address Strobe) due to the alignment of the memory command to OSC (Oscillator).

The REFRESH signal identifies the MR* (Memory Read) signal that follows as a REFRESH cycle. REFRESH cycles have all four RAS* signals active simultaneously. No AMUX* or CAS* signals go active during a REFRESH cycle.

The Dynamic Memory lines between A0-A7 and A8-A15 are multiplexed by U6 and U10 with the normal state buffering AO-A7 to the dynamic memory array.

## Direct Memory Access Controller

The DMA Controller U13 is a four channel device. Each channel is dedicated to a specific I/O function via a REQUEST/ACKNOWLEDGE handshake. The Controller transfers data between the particular 1/O function and memory by emulation. The CPU read and write strobes the transfer from source to destination which takes place on the same cycle thus increasing through put.

A block diagram of the DMA function is shown in Figure 15. During DMA operation the DMA Controller is bus master and generates the bus address (A0-A19 and the required memory at I/O read/write strobe pairs. (MEMORY READ I/O WRITE or I/O READ - MEMORY WRITE). The DMA Controller is also an I/O function. It is through this port that the DMA transfer parameters are programmed (start address, transfer count, etc.).
The controller occupies sixteen contiguous addresses (AO thru AF). Because the controller can only output sixteen address bits, a four bit address extension register is required to allow DMA addressing capability to the entire one megabyte memory address space. The address extension register resides at a separate peripheral address of 080-083 hex.

For programming purposes, what is written on data lines D0-D3 to the address extension register will come out on address lines A16-A19 respectively during the appropriate DMA cycles. The following is a list of DMA Channels:

| Register 80 | Not Used |
| :--- | :--- |
| Register 81 | Channel 2 |
| Register 82 | DMA Channel 3 |
| Register 83 | DMA Channels 0 and 1 |

The DMA Controller (Channel 0 ) is dedicated to memory refresh. The Channel 0 request line is tied to a flip-flop (U115 on the main logic board) that is pulsed at $15 \mu$ s intervals. The DMA acknowledge line for Channel 0 (REFRESH) clears the flip-flop and instructs the system that the memory cycle in progress is a refresh cycle. The DMA Controller is programmed to step sequentially through memory addresses so that all 256 rows will be refreshed. DMA Channel 2 is assigned to the Floppy Disk Controller. DMA Channels 1 and 3 are uncommitted and are available on the bus.

The DMA Controller multiplexes data bits D0-D7 with address bits A8-A15. The presence of address information on these lines is indicated by a ADSTB (Address Strobe) being high. The falling edge of ADSTB latches address data into a 74LS373 (U14) latch. U14 is then enabled for output by a DMAAEN* (DMA Address Enable), output by the DMA Controller during DMA cycles. DMAAEN* also enables U16 (74LS125), buffering A4-A7, U18 (74LS670), A16,A19,U15 (74LS245), A0-A3, memory read, memory write, I/O read and I/O write.

DMAAEN* is used by U9 (82S153 IFL) to enable the data buffer U17 (74LS245) during DMA as well as during memory and I/O accesses to the board by the CPU.

U12 (74LS74) and U51 (74LSO0) perform two functions. First the DMA Controller synchronizes READY to its input clock. Secondly, in order to mimic the CPU during DMA cycles, one wait state is inserted during either IOR* or IOW*.


Figure 15

## INTRODUCTION TO RS-232 ASYNCHRONOUS COMMUNICATION BOARD

The RS-232 board is a single-channel asynchronous serial communications board. The heart of the board is the WD8250 Asynchronous Communications Element (ACE), that functions as a serial data input/output interface. It performs serial-to-parallel conversion on data characters received from a peripheral device or a modem, and parallel-to-serial conversion on data characters received from the CPU. Status information reported includes the type and condition of the transfer operations performed by the ACE as well as any error conditions. The WD8250 includes a programmable baud rate generator that allows operation from 50 to 9600 baud. The WD8250 can be software tailored to the user's requirements. It will add and remove start bits, stop bits, and parity bits. It supports $5-, 6-, 7$-, or 8 - bit characters with $1,11 / 2$, or 2 stop bits. Diagnostic capabilities provide loopback functions of transmit/receive and input/output signals. Other features include:

- Full double buffering which eliminates the need for precise synchronization.
- Independent receiver clock input.
- False start bit detection.
- Line break generation and detection.
- Modem control functions: Clear To Send (CTS), Request To Send (RTS), Data Set Ready (DRS), Data Terminal Ready (DTR), Ring Indicator (RI), and Carrier Detect (CD).


## Theory of Operation for RS-232

The RS-232 asynchronous communications board has various modes of operation that can be selected by programming the WD8250 ACE. The WD8250 is programmed by selecting the I/O address (3F8 to 3FE primary, and 2FB to 2FE secondary), and writing data out to the board. Address bits A0, A1, and A2 are used to define the modes of operation by selecting the different registers. The selection of certain registers is done by using the divisor latch access bit (Bit 7) of the line control register.

One interrupt is provided to the system for IRQ4 for primary operation, and IRQ3 for secondary operation. This interrupt is active high. Bit 3 of the modem control register must be set high in order to send interrupts to the system. When this bit is high, any interrupts allowed by the interrupt enable register will cause an interrupt.

Refer to Figure 16 for the Functional Pin Definitions, and Figures 17 and 18 for Timing Diagrams of the WD8250.
Figure 19 shows the Block Diagram for the RS-232 Adapter.
Figure 20 shows the Functional Pin Definitions for the 82S153 IFL.

| $\begin{aligned} & \text { PIN } \\ & \text { NUMBER } \end{aligned}$ | PIN NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 1.8 | DATA BUS | D0-D7 | 3-state input/output lines. Bi-directional communication lines between WD8250 and Data Bus. All assembled data TX and RX, control words, and status information are transferred via the DO-D7 data bus. |
| 9 | RECEIVE CLK. | RCLK | This input is the 16 X baud rate clock for the receiver section of the chip (may te tied to BAUDOUT pin 15). |
| 10 | SERIALINPUT | SIN | Received Serial Data In from the cammúnications link (Peripheral device, modem or data set). |
| 11 | SERIAL OUTPUT | SOUT | Transmitted Serial Data Out to the communication link. The SOUT signal is set to a (logic 1) marking condition upon a MASTER RESET. |
| 12 | CHIP SELECT | CSO | When CS0 and CS1 are high, and $\overline{\mathrm{CS} 2}$ is low, chip |
| 13 | CHIP SELECT | CS1 | is selected. Selection is complete when the ad. |
| 14 | CHIP SELECT | CS2 | dress strobe $\overline{A D S}$ latches the chip select signais. |
| 15 | BAUDOUT | BAUDOUT | 16X clock signal for the transmitter section of the WD8250. The clock rate is equal to the oscillator frequency divided by the divisor loaded into the divisor latches. The BAUDOUT signal may be used to clock the receiver by tying to (pin 9) RCLK. |
| $\begin{aligned} & 16 \\ & 17 \end{aligned}$ | EXTERNAL CLOCK IN EXTERNAL CLOCK OUT | XTAL 1 <br> XTAL 2 | These pins connect the crystal or signal clock to the WD8250 baud rate divisor circuit. |
| $\begin{aligned} & 18 \\ & 19 \end{aligned}$ | DATA OUT STROBE data out strobe | $\begin{aligned} & \overline{\text { DOSTR }} \\ & \text { DOSTR } \end{aligned}$ | When the chip has been selected, a low $\overline{\text { OOSTR }}$ or high DOSTR will latch data into the selected WD8250 register (a CPU write). Only one of these lines need be used. Tie unused tine to its inactive state. DOSTR - high or DOSTR - low. |
| 20 | GROUND | VSS | System signal ground. |
| $\begin{aligned} & 21 \\ & 22 \end{aligned}$ | DATA IN STROBE DATA IN STROBE | DISTR DISTR | When chip has been selected, a low DISTR or high OISTR will allow a read of the selected WDB250 register (a CPU read). Only one of these lines need be used. Tie unused line to its inactive state. DISTR - high or DISTR - low. |
| 23 | DRIVER DISABLE | DDIS | Output goes low whenever data is being read from the WD8250. Can be used to reverse data direction of external transceiver. |
| 24 | CHIP SELECT OUT | CSOUT | Output goes high when chip is selected. No data transfer can be initiated until CSOUT is high. |
| 25 | ADDRESS STROBE | $\overline{\text { ADS }}$ | When low, provides latching for register. Select (A0, A1, A2) and chip select (CS0, CS1, CS2) |
|  |  |  | NOTE: An active $\overline{A D S}$ signal is required when the Register Sefect (A0, A1, A2) signals are not stable for the duration of a read or write operation. If not required, the $\overline{A D S}$ input can be tied permanently low. |
| 26 | REGISTER SELECT A2 | A2 | These three inputs are used to select a WD8250 |
| 27 28 | REGISTER SELECT A1 REGISTER SELECT AO | A1 | internal register during a data read or write. |
| 29 | NO CONNECT | NC | No Connect |
| 30 | INTERRUPT | INTRPT | Output goes high whenever an enabled interrupt is pending. |
| 31 | OUTPUT 2 | $\overline{\text { OUT2 }}$ | User-designated output that can be programmed by Bit 3 of the modem control register $=1$. causes OUT2 to go low. |
| 32 | REQUEST TO SEND | $\overline{\mathrm{RTS}}$ | Output when low informs the modem or data set that the WD8250 is ready to transmit data. |
| 33 | DATA TERMINAL READY | $\overline{\text { DTA }}$ | Output when low informs the modem or data set that the WD8250 is ready to communicate. |
| 34 | OUTPUT 1 | OUT1 | 1 causes OUT1 to go low. |
| 35 | MASTER RESET | MR | When high clears the registers to states |
| 36 | Clearto send | $\overline{\text { CTS }}$ | Input from DCE indicating remote device is ready to transmit. |
| 37 | DATA SET READY | $\overline{\text { DSA }}$ | Input from DCE used to indicate the status of the local data set. |
| 38 | RECEIVED LINE SIGNAL DETECT | $\overline{\text { RSLD }}$ | Input from DCE indicating that it is receiving a signal which meets its signal quality conditions. |
| 39 | RING INDICATOR | $\overline{\text { AI }}$ | Input, when low, indicates that a ringing signal is being received by the modem or data set. |
| 40 | $+5 \mathrm{~V}$ | $V_{C C}$ | + 5 Volt Supply. |

Figure 16


READ CYCLE TIMING

transmitter timing


MODEM CONTROLS TIMING
Figure 17

## WD8250


eandout timing


Receiver timing
Figure 18


Figure 19
RS-232 Asynchronous Communications Adapter Block Diagram

82 S 153 IFL Pin Descriptions

| PIN NUMBER | PIN NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 1 | ADDRESS ENABLE | AEN | Indicates DMA cycle when high, CPU cycle when low. |
| 2-8 | ADDRESS <br> LINES | A3-A9 | These address lines are used for decoding the address space 2F8-2FF (secondary) or 3F8-3FF (primary). |
| 9 | SECONDARY INTERRUPT REQUEST | IORQ3 <br> address space. | Sends interrupts to the CPU while operating in the secondary |
| 10 | GROUND |  |  |
| 11 | PRIMARY INTERRUPT REQUEST | IORQ4 | Sends interrupts to the CPU while operating in the primary address space. |
| 12 | PRIMARY OR SECONDARY UARTS | P or S | An input that determines which address space will be used. Primary (3F8-3FF) when high or secondary (2F8-2FF) when low. |
| 13 | UART INTERRUPT | INT | Receives interrupt signal from the 8250. |
| 14 | UART CHIP SELECT | UCS | Enables the 8250 ACE when low. |
| 15 | NOT USED |  |  |
| 16 | NOT USED |  |  |
| 17 | DATA CHIP SELECT | DCS | Enables the data bus buffers when low. |
| 18 | NOT USED |  |  |
| 19 | NOT USED |  |  |
| 20 | VCC |  |  |

Figure 20

## INTRODUCTION TO THE 300 BAUD MODEM

The 300 baud modem is a plug-in option for the Tandy 1000. This modem is an auto answer-auto originate device with tone and pulse-type dialer circuitry. See Figure 21. It is controlled by a 6805 single-chip microprocessor (U7), and simple ASCII commands control the operation of the modem.

These ASCII commands are supplied through the on-board UART. The UART converts parallel commands to serial data for the modem. The microprocessor converts the serial data into parallel data and controls the modem using the input/output ports.

The modem circuitry is divided into six major subsections:

- Modem filter
- Carrier detect section
- UART
- Microprocessor section
- Tone dialer section
- Telephone interface section


## Theory of Operation for the 300 Baud Modem

## Modem Filter

The modem filter section consists of U3, parts of U9 and U6, and the modem chip U1. U3 is an MC145440 filter chip. It contains two switched capacitor filters and an operational amplifier. Depending on the mode of operation, one filter processes the receive carrier, while the other filter processes the transmit carrier. The operational amplifier is used as a duplexer. This device allows transmit carrier to be amplified to the telephone interface transformer but not to the receive side of the filter.

The filter chip is powered by +5.0 volts from the computer's main power supply. Internal circuitry generates a false ground at Pin 5, which is one-half the Vcc power of the chip. All signals within the filter chip swing around this level. The false ground is shown as a chassis ground symbol on the schematic, and the true ground ( 0.0 VDC ) is shown with a signal ground symbol (a triangle).

U3 uses a $4.00 \mathrm{MHz}(\mathrm{Y} 1)$ crystal to generate an internal clock. The frequency is also divided by 4 to generate a 1.00 MHz clock for the modem chip. This clock reference is supplied at Pin 11 of U3.

## Transmit Section

Serial data from the UART is supplied at Pin 11 of U8. The modem chip, U1, frequency modulates the high and low state of the input at Pin 11 and generates transmit carrier. Transmit carrier is supplied to the filter from Pin 9 of U1. A digitally-generated sine wave is produced at this pin and is DC decoupled by C2. R1, a 10K pot, adjusts the level of transmitter carrier to the filter chip at Pin 2. The signal is passed through summing amplifier U2 and applied to the duplexer input. R3 passes most of the signal energy to C 1 and on to the secondary of T1.

## Receive Section

The receive carrier passes through T1 and is applied to pin 17. Transmit carrier is sensed at pin 15 of U 3 and is subtracted from the smaller received carrier by the duplexer op-amp in U3. The duplexer's output is at Pin 16, and the receive filter input is tied to this pin. Once the receive carrier is processed by the receive filter, the output at Pin 14 is decoupled away from false ground by C13 and allowed to swing arouna system ground. R16, R21, and part of U6 give about 10 dB of gain, and the received carrier is filtered by R29 and C23. C22 decouples the signal back to the false ground reference, and the signal is applied to the limiter, U9. After being squared by the limiter, the modem chip U1 detects any FSK activity and generates a serial output for the UART at pin 7 .

## Carrier Detect

The carrier signal from the receive side of the modem filter is measured to determine whether there is sufficient strength to allow error-free communications. Once the receive carrier is amplified by U6, C21 decouples the signal, and it is applied to a half-wave amplifier rectifier U6. Using a gain of almost 4, this op-amp circuit passes through the positive half of the carrier signal to a filter capacitor. CR6 passes the positive half of the carrier, while CR5 "shorts out" the negative half.

C2D filters resulting positive DC signal, and the resulting voltage is compared to a reference voltage at Pin 7 of U9. R19 and R20 hold this voltage to about 0.8 Volts. At Pin 6 of U9, Pin 1 changes from a high voltage to a low voltage. R32 and Pin 8 of U9 make up another voltage comparator, but notice that this time, the positive input to the comparator is referenced at false ground ( 2.5 volts). When the voltage at R32 falls below 2.5 volts, the output at Pin 14 of U9 goes from a low to a high. This output is designed to "short out" the output of the limiter at Pin 2. When Pin 14 goes high, it actually forces a transistor to turn off and allow limited carrier to be applied to Pin 1 of U1. Of course, if there are fewer than 0.8 volts at Pin 6 of U9, Pin 14 keeps the limited output shorted, and there is no received FSK for U1 to demodulate.

Unlike other modems, the carrier detect level at Pin 1 of U9 is not directed to a voltage translator for use at Pin 8 of the RS-232 connector. Instead, the 300 baud modem signals the microprocessor with the carrier detect signal, applying the output of U9 to Pin 26 of U7. The microprocessor makes the decision and controls Pin 38 of the UART at the proper time.

## UART Section

The UART section consists of U8 (the UART), its crystal Y2, a transmission buffer U12, and a gate array U11. In operation, the 1000 port is connected to these 3 devices. Depending on the selection of jumper plug E1-3, the primary or secondary serial channel addresses are decoded by U11. Bus data is switched by U12. The UART controls its direction at Pin 1, and the gate array U11 controls the master enable. U8 operates just like any UART in that it converts parallel data from the port into serial data for the modem's microprocessor. Notice that DTR is not used for this modem.

## Microprocessor Section

The 6805 microprocessor has 1024 bytes of ROM and 64 bytes of RAM. It communicates with the user by using the serial inputs and outputs supplied by the RS-232 connector. It also controls all protocol timing and telephone signaling.

U7 receives a 4.00 MHz clock reference from the filter crystal. The crystal is tapped at Pin 8 of $\cup 3$ and is not buffered. When power is applied to the modem and capacitor C26 charges high, the microprocessor starts its internal control program.

Serial input from the UART interface is applied to the microprocessor's interrupt input at Pin 2. When the microprocessor is echoing commands or listing user options, it signals Pin 12 in a serial manner. Because two inputs must share one line of the UART, R15 is used as a resistive multiplexer. The output of U1 Pin 7 cannot be made to "turn off." Hence, it might have a low voltage at this pin. R15 isolates the microprocessor's output from the modem chip's output. If U1 Pin 7 is low, a high at Pin 12 of U7 supplies current to R15 and to the UART. Even though the low at Pin 7 of U1 somewhat loads the output at Pin 28 of U 7 , there is still sufficient voltage to supply U 8 with the proper high level signal.

When the modem is in an ON-LINE condition, Pin 12 of U7 is configured as an input pin. At this time, the microprocessor is monitoring any data being received by the modem. Since R15 is not driven high by pin 12 any more, the normal transitions on Pin 7 of U1 control the translation of signals at Pin 38 of U8.

The microprocessor is at the same time controlling the relays in the telephone interface. K2 determines whether or not the modem is connected to the telephone line. It is controlled by the microprocessor through relay drive U4, Pins 12 and 13. K1 is used during pulse dialing. It is controlled by relay driver U4, Pins 1 and 14. The diodes across the two relay coils prevent counter-EMF chatter and protect the driver from any high voltage spikes.

## Tone Dialer Section

The tone dialer chip U10 controls the telephone interface circuitry using tone signaling. This chip has its own crystal ( Y 3 , a 3.579545 MHz device). A binary coded decimal number is applied to the BCD input of this chip by U7. When Pins 10, 11, 12, and 13 have a digit applied to them, the microprocessor supplies a timed high signal to Pin 15 . This high enables the tone generator, and Pin 17 outputs a digitally-generated sine wave of the proper frequency.

The tone output is DC decoupled by C24, forcing it to swing around system ground. U2, along with R17 and R4, amplifies the tone signal by a factor of 4 and applies it to the same duplexer used by the modem transmit carrier. (There is no carrier at this time.) Once it passes through the transformer, it is applied to the telephone line.

## Telephone Interface Section

The telephone interface section consists of a coupling transformer, two sets of relay contacts, transient suppressors, and a ring detector.

The coupling transformer isolates modem ground and passes tone signals through in both directions. It also protects the telephone line from high voltage due to its breakdown characteristics.

As mentioned before, K 2 is the hook relay, and K 1 is the pulse dial relay. When the modem is ON-LINE, K2 is on, shorting out Pins 1 and 8 . (Also notice that it shorts out 9 and 15.) Assuming that you are not pulse dialing at this time, K 1 is not active, and a connection occurs between the contacts of K 2 and the primary of T 1 .

When the modem puise dials, K1 switches on and off, breaking and making the T1 connection to TIP and RING. The Central Office detects these makes and breaks, and the number is pulse-dialed. R9 and C36 form a stubbing network for protection of K1's contacts. CR2 prevents harmful voltage transients from being passed to the telephone line.

Bridge rectifier CR8 accomplishes ring detection. When ring voltage is applied to TIP and RING, CR8 full-wave rectifies the sine wave and applies DC to filter C12. This voltage is allowed to turn on transistor Q1 which, in turn, lights the LED within opto-isolator U5. The transistor inside U5 follows the pulsating ring voltage and outputs a 5.0 volt square wave to Pin 19 of the microprocessor. The microprocessor makes the decision whether or not to activate K2 and answer the call.


Figure 21

## TANDY 1000 MOUSE/CLOCK/CALENDAR

## Introduction

The Mouse Clock/Calendar Board interfaces the DIGI-Mouse pointing device (Cat. No. 26-1197) to the Tandy 1000. The application programs that require the DIGI-Mouse pointing device can be used on the Tandy 1000. Also the battery backed clock/calendar allows the user to run the software provided on the diskette that comes with the owner's manual.

## Specifications

Dimensions: Standard half size board (5 $\times 4.2$ inches).
Battery: $\quad 3.0$-Volt Lithium coin cell, type 2320 (Cat. No. 23-163). The battery life is one year.

Processor: 80428 -bit single chip processor.
Clock Speed: 7.16 MHz
Ambient Temperature Range:
$55^{\circ}$ to $95^{\circ} \mathrm{F}\left(12^{\circ}\right.$ to $\left.35^{\circ} \mathrm{C}\right)$
Storage Temperature Range:
$-40^{\circ}$ to $+160^{\circ} \mathrm{F}\left(-40^{\circ}\right.$ to $\left.71^{\circ} \mathrm{C}\right)$

## Theory of Operation (Hardware)

Look at the block diagram (Figure 22) while reading the information below.

## Bus I/F

Data, address, and control signals of the 1000 interface bus are buffered by U9 (an octal bus transceiver) and U7 (an octal buffer/line driver with 3-state outputs).

## Chip Select and Reset Logic

The address lines are decoded by U2, U5, and U6. When the 1000 writes or reads to Ports 2FC or 2FE, a chip select signal is generated at Pin 6 of U2. The cip select controls U9 (the data buffer) and U3 (the 8042 processor).
During DMA cycles, the AEN signal from the 1000 bus, disables the chip select signal at Pin 1 of U7. An active AEN signal disables the $1 Y$ outputs of $U 7$, causing the A08 signal from Pin 12 of U7 to float and to be pulled high by R20. U5 then inverts the A08 signal, ensuring that the chip select is disabled during DMA.

One half of U1 (a dual D-type flip-flop) is used in a "divide by 2 " configuration. The 14.32 MHz oscillator signal from the 1000 interface bus is divided in half for a clock speed of 7.14 MHz , to be used by the 8042 processor. The 7.14 MHz clock is at Pin 5 of U 1 .

The other half of U1 is used as a reset latch. A reset signal is provided for the 8042 processor by ORing together the System Reset signal from the computer interface bus and the signal from the reset latch at Pin 11 of U2. The 8042 processor can be reset by a system reset or a write to I/O port 2FF. A write to I/O port 2FD clears the reset signal.

## 8042 Processor

In the heart of the option board is the 8042 processor (U3). This processor acts as an input port for serial information from the DIGI-Mouse and the Clock/Calendar chip (U8). It then translates this information to a parallel format and controls its transfer to the computer interface bus. The Clock/ Calendar option board uses interrupt request IR3 to inform the 1000 when it is ready to transfer data.

## DIGI-Mouse Buffers and Filters

A 9-Pin DB jack at J2 connects the DIGI-Mouse to the clock/calendar board. RC filtering is used to reduce noise in the inputs. U4 (a CMOS hex schmitt trigger) provides further buffering and waveshaping of the DIGI-Mouse inputs, which are interfaced to the processor chip through its peripheral port bits P10 to P16.

## Clock Chip

The Phillips-Signetics Clock/Calendar Chip (U8) interfaces directly to U3 at its peripheral port bits P17, P20-P23, and P27. The time base for the clock ship is a 32.768 KHz crystal, which is similar to that found in watches. The battery MUST be installed for the clock function to work. When a power failure occurs, the chip indicates this by sending a low-battery signal (POWF) to the 8042 processor.

## Theory of Operation (Software)

User specifications:

- The motion sensor is oriented with the connecting cable and buttons pointing away from the user, the positive $x$ axis extends to the right and the positive $y$ axis extends toward the user.
- Maximum motion allowed before it is detected is $1 / 80$ of an inch along either axis. This distance is called a mickey.
- The minimum unit of time for the Clock/Calendar chip is 1 minute. Maximum accuracy is $\pm 1 / 2$ minute. The units of time accepted by the chip are minutes, (24) hours, day of month, and month.


Figure 22
DIGI-Mouse/Clock Controller Board Block Diagram I/F

- There are 3 modes for the mouse's motion data and button data that can be transfered to the host: the internal timed data poll mode, the event data poll mode, and the host request data poll mode.
- To communicate with the clock/calendar chip, the user employs the set time command and a read time command.

I/O Ports used by the Clock/Calendar Board:
8042 Data Port 2FC

8042 Command/Status Port 2FE
8042 Set RESET 8042 Port 2FF
8042 Clear RESET 8042 Port 2FD

Layout of the 8042's status port (2FE):
Read by the 8088 :
Bit \#0 = Output register full flag 1 = full
Bit \#1 = Input register full flag $1=$ full
Bit \#2 = F0 flag - not used
Bit \#3 = F1 flag - command flag $1=$ button up
Bit \#4 = Primary button status 1 = button up
Bit \#5 = Secondary button status $1=$ button up
Bit \#6 = Tertiary button status $1=$ button up
Bit \#7 = Calendar power status $1=$ power has failed

Written to by the 8088 :
This is the same as for the data written to Data Port 2FC, except the F1 (command) flag in 8042's status port is set.

Output:
When sending data or commands from the 8088 to the 8042 , the following procedure must be used:

1. Check the status port (2FE) of the 8042 to see if the input port full flag is set (Bit 1).
2. If the flag is set, wait until the 8042 clears it. If it is not cleared within 1 millisecond, reset the 8042 chip because it is locked up.
3. If the flag is clear, proceed.
4. Check the length of the command. If it is equal to 1 , then send the data to $2 F E$, and stop here.
5. If the length equals 2 or more, then send the data to $2 F C$, and proceed.
6. Wait until the input port full flag is cleared by the 8042 before sending the next byte of data.
7. When the length equals 1 , send it to $2 F E$, and stop here.

Formats of Commands to the 8042 :

| Command | Header | Data |
| :---: | :---: | :---: |
| Set Time | 01 | All data must be in BCD format. <br> 1 st byte $=$ minutes . <br> 2nd byte = hurs ( 24 hour clock). <br> 3rd byte = day of the montth. <br> 4th byte $=$ month. |
| Read Time | 02 | None <br> Returns data packet "R' |
| Set Mouse Motion Interrupt | 08 | Output is 2 bytes. <br> $0=$ disable function. <br> $1-255=$ net number of "mickeys" <br> to be moved before interrupt is |
| and |  | triggered. <br> Returns data packet " M ". |
| Button Interrupt |  | $0=$ disable function. $1-255=$ enable function Returns data packet " $B$ ". |
| Set Timer Interrupt | 20 | Outputs 1 byte of data $0=$ disable function. $1-255=$ enable function Returns data packet " A ". |

(Timer is set to interrupt approximately 40 times per second if the data is available to send.)

## What is happening:

The 8042 is interrupted every time data is written to the input port 2FC (or 2FE, which set the command flag). The 8042 moves the data from the input register into the input buffer and increments a counter. It then returns to the point in the mouse data sampling and processing cycle at the point of interruption.

During each cycle, the 8042 checks the command flag to see if a command has been received. If the command flag is set, the 8042 checks the header byte to determine which command is in its input buffer. It then compares the counter to the number of bytes in that command. If any of these tests fails, the 8042 resets the pointer to the input buffer, clears the counter and the command flag, and continues with its normal cycle. If all the ttests succeed, the 8042 jumps to the routine that handles that command. Each command has the requirement to reset the buffer pointer, the counter, the command flag and then return control to the normal process.

## Input:

Data transfer between the 8042 and the main processor (8088) uses the interrupt mode, the poll mode, or both. the 8042 interrupts the 8088 by toggling Port 2, Bit 4, which is connected through a buffer to the 8259A interrupt controller chip. The clock/calendar board uses IR3 as an interrupt. Internally, the 8042 knows if the 8088 has read/written a byte from/to it by checking the status of the OBF/IBF flags. Three procedures are available to transfer the data from the 8042 to the 8088 . They are discussed below.

Mode 1: Full interrupt mode
This mode uses the interrupt line to signal each byte to e transmitted. As each byte is transmitted, the common procedure below is executed except Mode 3 must have the latched interrupt cleared after each byte is processed. This mode may be the fastest mode when only the clock interrupt is actively being triggered.
Mode 2: Initial interrupt and poll mode
This mode uses the interrupt line to signal the start of a data packet, and polls the rest of the packet. It clears the latched interrupt only after all the data packet is transmitted. it uses the common procedure outlined below.

## Mode 3: Poll only mode

This mode does not use the interrupt signal at all. It uses only the output register full flag in the 8042's status register (Port 2FE).

## Common procedure:

The 8088 must have the following initialized before any interrupt mode is used:

- A hardware interrupt vector at 002C.
- An interrupt controller at port 21 (ANDed with a F7).

The 8042 has a data packet set up in its output buffer and begins transmitting by placing the "header" into the output register (Port 2FC). Placing the header byte into the output register sets the output register full flag in the status register (Port 2FE, Bit 0) and sends a signal on the interrupt line to the 8088 (via the 8259). The 8042 begins its normal processing cycle, testing the output register full flag on each cycle.

If the flag is set, the 8042 sends another signal on the interrupt line. If the flag is cleared and the packet still continues to send, the 8042 places the next data byte into the output register and sends a signal on the interrupt line to the 8088. If the flag is cleared and the data packet is empty, the 8042 does NOT send an interrupt signal, but continues with its normal processing.

On the 8088 side, the "mouse" interrupt has a priority behind the 8253 timer, keyboard, and hard disk. This means that when the interrupt enters its routine, the higher-level interrupts are enabled. The interrupt handler routine should do all the following:

- Ensure that the 8042 is generating the interrupt by placing a data byte in its output register.
- Identify the type of data packet by its "header" byte and switch to the appropriate routine when the entire data packet is received.
- After the data packet is processed, clear or reset the buffer pointers, counters and the latched interrupt.

Format of Data Packets from the 8042:

| Data Packet | Header | Data |
| :--- | :--- | :--- |
| Mouse data |  | 4 bytes of data |
| All data | "A" | 1st byte $=$ MSB of Delta $x$ <br> Motion data only |
|  |  | 2nd byte $=$ LSB of Delta $x$ |
| 3rd byte $=$ MSB of Delta $y$ |  |  |
| 4th byte $=$ LSB of Delta $y$ |  |  |

(The button data is found in the status register (Port 2FE.)

| Mouse data |  |  |
| :--- | :--- | :--- |
| Button data only | "B" | none <br> data found in status register (Port <br> 2FE bits \# 4, 5, 6) |
| Read time data | "R", | 4 bytes of data in BCD format <br> 1st byte $=$ minutes |
| 2nd byte $=$ hours (24-hour clock) |  |  |

Initialization Procedures of 8088:
The following hardware and software interrupts should be initialized:

## Description

Hardware interrupt vector (INT OB)
Application interrupt vector (INT 33)
Hardware interrupt controller (IR3)
Video display interrupt (INT 10)

## Address Type

002C Doubleword Pointer 00CC Doubleword Pointer Port 21 (reset Bit 3) 0040 Doubleword Pointer

## Operation of the Clock/Calendar:

When the 8042 receives either the Set Time or Read Time command, it shuts off all other operations until it is finished with the command. All the resources of the 8042 are required to communicate with the clock/calendar chip.
In the Set Time command, the 8042 breaks up the 4 bytes of time data into 4 packets and sends them serially a bit at a time. Upon completion, the 8042 resumes normal operation.

In the Read Time command, the 8042 sets up bit serial communications with the clock/calendar chip and builds 4 time data packets. The 4 packets are converted to bytes and placed in the output buffer behind the " $R$ " header byte. The 8042 sets up a Read Time data packet to be sent to the 8088 and returns to normal operation.

If the power fails, bit data is set in the status register (Port 2FE Bit 7). First, check to see if the power failure is temporary. (Perhaps the battery lost contact with the clock circuit because of a bump or jarring of the equipment.) To check for temporary failure, issue a Set Time command. If the power failure bit is set to zero everything is normal. If the power fialure bit is not reset, then the battery either is dead or is dislodged from its holder clip. After replacing or resetting the battery, issue the Set Time command to ensure proper operation.

## Operation of the 8042:

Upon power up/RESET, the 8042 initializes the system by zeroing all RAM and clearing all flags, ports, and registers. It then sets up the default conditions and enters the normal mouse data procesing cycle, which follows:

1. The 8042 takes a copy of the Mouse/Clock/Calendar data port (P1) and saves copy.
2. It then checks to see if there is any change in the status of the buttons. If there is, the 8042 sends a copy to the status register.
3. Next, the 8042 determines the Delta $x$ changes or Delta $y$ changes. Both Deltas use the same process.
4. The 8042 retrieves the copy of Port P1 and compares the bit pattern of $x A$ and $x B$ to the old copy to see if any changes have occured. If a change has occured then, the 8042 determines whether the change is $+1,-1$, or null. (Null occurs when the 8042 misses 2 state changes of $x A$ and $x B$.)
5. The Delta $\times$ (or $y$ ) working accumulator $\pm 32735$ units) is then either incremented or decremented respectively. A null result does not affect the accumulators.
6. At this point, the 8042 checks the event-triggered data polls for motion and button data. If either occurred, then the 8042 transfers the values in the working accumulators to the output buffer behind the appropriate header byte and clears the working accumulators to zero. If not, then the 8042 checks to see if any input from the 8088 has been received by checking the F1 command flag. If there is input in the input buffer, the 8042 tests the header to see which bit is "on" and jumps to the routine that handles that command.
7. After checking for input, the 8042 then checks the internal timer to see if anything has timed out. Two items are connected to the timer flag, the 8042 and the timed data transfer interrupt. All outputs to the 8088 are tied to the timer. Each time the timer times out, the 8042 checks the output register full flag to see if it is set.

If the flag is set, the 8042 sends off a signal on the interrupt line to the 8088 , resets the timer, and returns to normal operation. The 8042 checks to see if it needs to send any more data. If it does, it moves the next data byte to the output register, sends a signal on the interrupt line, and returns to normal operations. If the output buffer is empty, the 8042 simply returns to normal operation. Connected to the timer is the timed data transfer interrupt. When the timer interrupt is enabled, the 8042 also checks to see if the timer has timed out. If it has, then the 8042 transfers the mouse data from the working accumulators to the output buffer behind the header byte and ships it to the 8088. It then clears the working accumulators and returns to the start of the cycle.

## KEYBOARD ASSEMBLY

The Tandy 1000 has a 90-key keyboard that includes 12 function keys, a numeric keypad, and special purpose keys for paging. The keyboard is connected to the Main Unit by a coiled cable and operated at a maximum distance of 4 feet from the main unit. Figure 23 shows the interconnecting cable connector to the keyboard assembly. The cable assembly can be disconnected from the keyboard assembly during repair.


Figure 23

## Keyboard Specifications

The keyboard is fully encoded with microprocessor control, and requires +5 VDC supplied from the Main Unit.

1. Key Type - all keys generate "make" and "break" codes. See the Key Code Chart. Break codes are formed by adding 80H to the make code. Keys 49 and 71 have alternate action that "makes' on one actuation of the key and "breaks" on succeeding actuation. No code is generated for these two keys when the key is released.
2. Number of Keys - 90
3. Repeat Strobe - there is a repeat strobe of 66 to 111 mSec when any key is depressed for more than 1 second, with the exception of SHIFT, CTRL, CAPS, ENTER, and NUMBER LOCK.

## Key Code Chart

## Key Number

1
2
3
4
5
6
7
8
9
10
11
12
13
14
Legend
F1
Scan Code
3B
F2 3C
F3 3D
F4 3E
F5 3F
F6 40
F7 41
F8 42
F9 43
F10 44
F11 59
F12 5A
INSERT + 55
DELETE - 53
15
BREAK 54
16
17
ESC 01
$1!02$
18 2 @ 03
19
3 \# 04
$20 \quad 4 \$$
$21 \quad 5 \% \quad 06$

22
$6^{\wedge} \quad 07$
23
24
7 \& 08
25
8 * 09
26
9 (OA
0) OB
27 - — OC
$=+$
OD
BACKSPACE OE
ALT 38
31
PRINT 37
32
7 (backslash) 47
33
34
8 (Tilde) 48
9 PG UP 49
35 TAB OF
36
Q 10
37 W $\quad 11$
$38 \quad \mathrm{E} \quad 12$
$39 \quad R \quad 13$
40 T 14
$41 \quad$ Y 15
$42 \cup 16$
43 I $\quad 17$
$45 \quad P \quad 19$

| Key Number | Legend | Scan Code |
| :---: | :---: | :---: |
| 46 | \{ [ | 1 A |
| 47 | \} ] | 1 B |
| 48 | HOLD | 46 |
| 49 | NUM LOCK | 45 |
| 50 | 4 | 4B |
| 51 | 5 | 4 C |
| 52 | 6 | 4D |
| 53 | CTRL | 1D |
| 54 | A | 1E |
| 55 | S | 1 F |
| 56 | D | 20 |
| 57 | F | 21 |
| 58 | G | 22 |
| 59 | H | 23 |
| 60 | J | 24 |
| 61 | K | 25 |
| 62 | L | 26 |
| 63 | ; | 27 |
| 64 | , ${ }^{\prime}$ | 28 |
| 65 | ENTER | 1 C |
| 66 |  | 29 |
| 67 | HOME | 58 |
| 68 | 1 END | 4 F |
| 69 | 2 (Grave) | 50 |
| 70 | 3 PG DN | 51 |
| 71 | CAPS | 3A |
| 72 | SHIFT | 2 A |
| 73 | Z | 2 C |
| 74 | X | 2 D |
| 75 | C | 2 E |
| 76 | V | 2 F |
| 77 | B | 30 |
| 78 | N | 31 |
| 79 | M | 32 |
| 80 | , < | 33 |
| 81 | $\ddagger$ | 34 |
| 82 | $1 ?$ | 35 |
| 83 | SHIFT | 36 |
| 84 |  | 2B |
| 85 |  | 4A |
| 86 |  | 4E |
| 87 | 0 | 52 |
| 88 |  | 56 |
| 89 | ENTER | 57 |
| 90 (Space Key) |  |  |

## Keyboard Timing

Figure 24 is the timing chart for the Tandy 1000 Keyboard Assembly.


Keyboard Assembly Timing chart

Figure 24

## Keyboard Layout

Shown below is the keyboard layout and number designation of the keys on the Tandy 1000 keyboard. They should be used with the Key Code Chart for determining data value transmitted by the keyboard.


Figure 25. Keyboard Identification

| 1 | 2 | 3 |  |  |  |  | 5 | 61 | 7 |  | $B$ |  |  |  |  | 10 | 41 | 12 |  |  |  | 14 | 45 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 16 | 17 | 18 | 19 |  | 20 |  | 21 | 22 | 23 |  | 24. | 25 |  | 26 | 27 |  | 28 | 29 | 30 | 31 | 32 | 33 | 34 |
| 35 |  | 36 | 37 | 38 |  | 39 | 40 | 41 |  | 42 | 43 |  | 44 | 45 |  | 46 | 47 | 65 | 48 | 49 | 50 | 51 | 52 |
|  |  | 54 |  |  | 56 | 57 | 5 |  |  | 60 |  | 1 | 6 |  | 3 | 64 |  |  | 66 | 67 | 68 | 69 | 70 |
| 71 | 72 | 73 |  | 7 | 475 |  | 76 | 77 | 78 |  | 79 | 80 |  | 81 | 82 |  | 83 | 84 | 85 | 86 | 87 | 88 | 89 |
|  | 91 | 92 |  | 90 |  |  |  |  |  |  |  |  |  |  |  | 3 | 94 | 95 |  |  |  |  |  |

NOTE: KEYS 91 THRU 95 NOT USED ON U.S. VERSION, USED ON INTERNATIONAL VERSION ONLY

Figure 26. Key Number Identification


Figure 27
Tandy 1000 Keyboard

## APPENDICES

The following sections contain reprints of manufacturer's documentation of components used in the Tandy 1000.

Tandy Corporation gratefully acknowledges permission by the following to reprint their copyrighted material in this manual

Teac Corporation<br>3-7-3 Naka-Cho<br>Musashimo, Tokyo, Japan<br>IBM PC ${ }^{\circledR}$ and IBM PCjr ${ }^{\text {™ }}$<br>P.O. Box 1328-W<br>Boac Raton, Florida 33432<br>Motorola Semiconductors<br>5005 E. McDowell Road<br>Phoenix, Arizona 85008<br>Intel Corporation<br>3065 Bowers Avenue<br>Santa Clara, California 95051<br>Texas Instruments<br>P.O. Box 1087<br>Richardson, Texas 75080

## Comparative Tables for IBM PC and PCjr. Computers

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


|  | IBM PC | IBM PCjr | TANDY $1 \emptyset \emptyset \emptyset$ |
| :---: | :---: | :---: | :---: |
| 0020 | 8259A INTERRUPT CONTROLLER | 8259A INTERRUPT CONTROLLER | 8259A INTERRUPT CONTROLLER |
| 0021 |  |  |  |
| 0022 |  |  |  |
| 0023 |  |  |  |
| 0024 |  |  |  |
| 0025 |  |  |  |
| 0026 |  | , | 1 |
| 0027 |  | 8259A INTERRUPT CONTROLLER | 8259A INTERRUPT CONTROLLER |
| 0028 |  |  |  |
| 0029 |  |  |  |
| 002A |  |  |  |
| 002B | SAME AS $\emptyset \emptyset 2 \emptyset$ - $\emptyset \emptyset 27$ |  |  |
| 002C |  |  |  |
| 002 D |  |  |  |
| 002 E | 1 |  |  |
| 002 F | 8259A INTERRUPT CONTROLLER |  |  |
|  | A19-A15 NOT DECODED (X) CHIP SELECT FROM A9 - A5 $A \emptyset \longrightarrow I . C .$ <br> $\mathrm{A} 4, \mathrm{~A} 3, \mathrm{~A} 2, \mathrm{~A} 1=\mathrm{X}$ <br> ADDRESS RANGE $=\emptyset 20-\emptyset 3 \mathrm{~F}$ ASSIGNED ADDRESS $=\emptyset 2 \emptyset, \emptyset 21$. | $\begin{gathered} \text { A1 } \emptyset-\mathrm{A} 15 \text { NOT DECODED (X) } \\ \text { A1, A2 }=\mathrm{X} \\ \text { A } \emptyset \rightarrow 1 . \mathrm{C} . \\ \text { ADDRESS RANGE }=\emptyset 2 \emptyset-\emptyset 27 \\ \text { ASSIGNED ADDRESS }=\emptyset 2 \emptyset, \emptyset 21 . \end{gathered}$ | DECODE A3 - A15 (B) $A \emptyset \longrightarrow I . C$. <br> ASSIGNED ADDRESS: $0 \emptyset 20-0021 \text { (B). }$ |


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


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


| DATA | $\begin{gathered} \text { IBM PC } \\ 0 \emptyset 60-\text { PORT A } \end{gathered}$ | IBM PCjr 0060 - PORT A | TANDY $1 \emptyset \emptyset \emptyset$ 0060 - PORT A |
| :---: | :---: | :---: | :---: |
| BIT $\emptyset$ | KEYBOARD SCAN CODE / CONFIG SW1 | RESERVED | KEYBOARD BIT $\emptyset$ - LSB |
| BIT 1 | 2 |  | 1 |
| BIT 2 | 3 |  | 2 |
| BIT 3 | 4 |  | 3 |
| BIT 4 | 5 |  | 4 |
| BIT 5 | 6 |  | 5 |
| BIT 6 | . 7 | $\downarrow$ | $1{ }^{6}$ |
| BIT 7 | KEYBOARD SCAN CODE / CONFIG SW8 | RESERVED | KEYbOARD BIT 7 -MSB |
|  | SEE IBM TECH REFERENCE |  | SEE 1000 KEYBOARD |
|  | MANUAL 2.02 FOR DETAILS |  | SPECIFICATION FOR DETAILS |
|  |  |  |  |


| DATA | IBM PC <br> 0061 - PORT B - READ OR WRITE | IBM PCjr <br> 0061 - PORT B - READ OR WRITE | TANDY $10 \emptyset 0$ 0061 - PORT B - READ OR WRITE |
| :---: | :---: | :---: | :---: |
| BIT $\emptyset$ | $1=8253$ GATE \# 2 ENABLED | SAME | SAME |
| BIT 1 | SPEAKER DATA OUT | SAME | SAME |
| BIT 2 | 1 = ENABLE READING | 1 = ALPHA (GRAPHICS) | NO FUNCTION |
|  | CONFIG SW 13 THRU 16 |  |  |
|  | (I/O CHAN. ROM SIZE) OR |  |  |
|  | $\theta=$ ENABLE READING |  |  |
| $\dagger$ | CONFIG SW 12 (@PCØ-PC3) |  |  |
| BIT 3 | 1 = CASSETTE MOTOR OFF | SAME | NO FUNCTION |
| BIT 4 | $\theta=$ ENABLE RAM PARITY | 1 = DISABLE CASSETTE MTR RELAY, INTERNAL BEEPER | NOT USED |
| BIT 5 | $\emptyset$ = ENABLE I/O CH PARITY | SPKR SW $\emptyset$ | SOUND CONTROL 0 |
| BIT 6 | $\theta$ = HOLD KEYBOARD CLK LOW | SPKR SW 1 | SOUND CONTROL 1 |
| BIT 7 | $\theta$ = ENABLE KEYBOARD | 1 = KEYBOARD CLEAR | 1 = KEYBOARD CLEAR |
|  | 1 = CLEAR KEYBOARD AND |  |  |
| 1 | ENABLE CONFIG SW 1-8 |  |  |
|  |  |  |  |


| DATA | IBM PC <br> 9062 - PORT C - READ ONLY | IBM PCjr <br> ض 062 - PORT C - READ ONLY | TANDY 1000 <br> 0062 - PORT C - READ/WRITE |
| :---: | :---: | :---: | :---: |
| BIT 0 | CONFIG SW16 OR | 1 = KEYBOARD LATCHED | (OUT) NOT USED |
|  | CONFIG SW12 |  |  |
|  | SEE PORT 061 , BIT 2 |  |  |
| BIT 1 | CONFIG SW15 | $\theta=$ INTERNAL MODEM INSTALLED | (OUT) MULTI-DATA |
| BIT 2 | CONFIG SW14 | $\emptyset$ = DISKETTE DRIVE INSTALLED | (OUT) MULTI-CLOCK |
| BIT 3 | CONFIG SW13 | $\emptyset=64 \mathrm{~K}$ RAM EXPANSION | (OUT) NOT USED |
|  |  | INSTALLED |  |
| BIT 4 | CASSETTE DATA IN | SAME | (IN) NOT USED |
| BIT 5 | 8253 CUT \#2 | SAME | (IN) SAME |
| BIT 6 | 1 = I/O CH CK (PARITY ERROR) | KEYBOARD DATA | (IN) NOT USED |
| BIT 7 | 1 = RAM PARITY ERROR | KEYBOARD CABLE INSTALLED | (IN) NOT USED |
|  | HARDWARE LOGIC ATTACHED IS FOR INPUT ONLY. |  | IN TANDY 1000 THE HARDWARE LOGIC IS CONFIGURED SO THAT PORT C IS SPLIT WITH <br> INPUT: PC4 - PC7 <br> OUTPUT: $\mathrm{PC}(-\mathrm{PC} 3$ |


|  | IBM PC | IBM PCjr | TANDY 1 $\emptyset \emptyset \emptyset$ |
| :---: | :---: | :---: | :---: |
| 0080 | DMA PAGE REG. (NOT USED) |  | DMA PAGE REG. (NOT USED) |
| 1 | $(\mathrm{CH} 2)$ |  | ( CH 2$)$ |
| 2 | ( CH 3 ) |  | - (CH 3) |
| 3 | $\dagger$ ( $\mathrm{CH} \emptyset, 1$ ) |  | DMA PAGE REG. (CH0, 1) |
| 4 | REPEATED THRU $\emptyset \emptyset 9 \mathrm{~F}$ |  |  |
| 5 |  |  |  |
| 6 |  |  |  |
| 7 |  |  |  |
| 8 |  |  |  |
| 9 |  |  |  |
| A |  |  |  |
| B |  |  |  |
| C |  |  |  |
| D |  |  |  |
| , E | $\downarrow$ |  |  |
| ¢ 08 F | DMA PAGE REG. |  |  |
|  | A10 - A15 NOT DECODED CHIP SELECT FROM A5 - A9 <br> A0. A1 TO 1C <br> A2, A3, A4 $=\mathrm{X}$ <br> ADDRESS RANGE: 0980 - $\emptyset 99$ ASSIGNED ADDRESS: $\varnothing 080$ - 0083 . | NO DMA FUNCTION. | CHIP SELECT FROM A3 -- A15 <br> A 0, , 1 TO 1C. <br> DMA OPTIONAL ON TANDY 1000. |


|  | IBM PC | IBM PCjr | TANDY $1 \emptyset \emptyset \emptyset$ |
| :---: | :---: | :---: | :---: |
| 0 - A 0 | NMI MASK REGISTER | PORT AD | NMI MASK REGISTER |
| 1 |  |  |  |
| 2 |  |  |  |
| 3 |  |  |  |
| 4 |  |  |  |
| 5 |  |  |  |
| 6 |  | + | 1 |
| 7 |  | PORT A 0 | NMI MASK REGISTER |
| 8 |  |  |  |
| 9 |  |  |  |
| A |  |  |  |
| B |  |  |  |
| C |  |  |  |
| D |  |  |  |
| E | $\downarrow$ |  |  |
| $\emptyset \emptyset \mathrm{A}$ F | NMI MASK REGISTER |  |  |
|  | A10-A15 NOT DECODED (X) CHIP SELECT FROM A9 - A5, 10 W $\mathrm{A} \emptyset-\mathrm{A} 4=\mathrm{X}$ <br> ADDRESS RANGE: $\emptyset \mathrm{A} \emptyset-\emptyset \mathrm{BF}$ ASSIGNED ADDRESS: $\emptyset A \emptyset$. | A10 - A15 NOT DECODED <br> CHIP SELECT FROM A9 - A3 $A \emptyset-A 2=X$ <br> ADDRESS RANGE: $\emptyset \mathrm{A} \emptyset-\emptyset \mathrm{A} 7$ ASSIGNED ADDRESS: $\emptyset$ A $\emptyset$. | $\mathrm{A}, \mathrm{A} 1, \mathrm{~A} 2=\mathrm{X}$. |


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


|  | IBM PC | IBM PCjr | TANDY $10 \emptyset \emptyset$ |
| :---: | :---: | :---: | :---: |
| 0200 | GAME CONTROL ADAPTER | JOYSTICK | JOYSTICK |
| 201 |  |  |  |
| 2 |  |  |  |
| 3 |  |  |  |
| 4 |  |  |  |
| 5 |  |  |  |
| 6 |  | $\downarrow$ | $\downarrow$ |
| 7 |  | Joystick | JOYSTICK |
| 8 |  |  |  |
| 9 |  |  |  |
| A |  |  |  |
| B |  |  |  |
| C |  |  |  |
| D | $\downarrow$ |  |  |
| 1 E | GAME CONTROL ADAPTER |  |  |
| $\emptyset \emptyset \emptyset \mathrm{F}$ |  |  |  |
|  | A10 - A15 NOT DECODED (X) CHIP SELECT FROM A9 - A 9 ADAPTER \& DATA BUS DRIVER MUST BE INACTIVE WHEN AEN IS ACTIVE LOW FILES POSITION ONESHOTS. | A10 - A15 NOT DECODED (X) CHIP SELECT FROM A9 - A $\emptyset$ ADAPTER \& DATA BUS DRIVER MUST BE INACTIVE WHEN AEN IS ACTIVE LOW FILES POSITION ONESHOTS. | $\mathrm{A} 0, \mathrm{~A} 1, \mathrm{~A} 2=\mathrm{X}$ ASSIGNED ADDRESS: 0020 - 0021 . |


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


|  | PC MEMORY MAP | PCjr MEMORY MAP | TANDY $1 \emptyset \emptyset \emptyset$ MEMORY MAP |
| :---: | :---: | :---: | :---: |
| 93D0 |  |  |  |
| 93D1 |  |  |  |
| 03D2 |  |  |  |
| 93D3 |  |  |  |
| 93D4 | 6845 ADDRESS REGISTER | 6845 ADDRESS REGISTER | 6845 ADDRESS REGISTER |
| 93D5 | 6845 DATA REGISTER | 6845 DATA REGISTER | 6845 DATA REGISTER |
| 93D6 |  |  |  |
| 03D7 |  |  |  |
| 63D8 | MODE SELECT REGISTER | NOT AVAILABLE | MODE SELECT REGISTER |
| 03D9 | COLOR SELECT REGISTER | NOT AVAILABLE | COLOR SELECT REGISTER |
| 93DA | READ STATUS REGISTER | WRITE GATE ARRAY ADDRESS, DATA \& READ STATUS | WRITE VIDEO ARRAY ADDRESS \& READ STATUS |
| 93DB | CLEAR LIGHT PEN LATCH | CLEAR LIGHT PEN LATCH | CLEAR LIGHT PEN LATCH |
| 03 DC | PRESET LIGHT PEN LATCH | PRESET LIGHT PEN LATCH | PRESET LIGHT PEN LATCH |
| Ø3DD |  |  |  |
| 03 DE |  |  | WRITE VIDEO ARRAY DATA |
| 03DF |  | CRT PROCESSOR PAGE REGISTER | CRT PROCESSOR PAGE REGISTER |
| SYSTEM <br> TIMING | MEMORY READ $=1$ WAIT I/O READ/WRITE $=1 \mathrm{WAIT}$ | RAM READ/WRITE $\approx 6$ WAITS ROM READ = Ø WAITS <br> I/O READ/WRITE $=0$ WAITS | RAM READ/WRITE $\approx 2$ WAITS ROM READ $=0$ WAITS <br> I/O READ/WRITE = 1 WAITS |


|  | IBM PC | IBM PCjr | TANDY $10 \emptyset \emptyset$ |
| :---: | :---: | :---: | :---: |
| 03 F 0 | FDC, DOR REGISTER (WRITE ONLY) |  | DOR REGISTER |
| 1 |  |  |  |
| 2 |  |  | $\downarrow$ |
| 3 | DOR REGISTER (WRITE ONLY) |  | DOR REGISTER (WRITE ONLY) |
| 4 | - STATUS (READ ONLY) |  | FDC - STATUS (READ ONLY) |
| 5 | FDC - DATA (R/W) |  | - DATA (R/W) |
| 6 |  |  | - - STATUS (READ) |
| 7 |  |  | FDC - DATA (R/W) |
| 8 |  |  |  |
| 9 |  |  |  |
| A |  |  |  |
| B |  |  |  |
| C |  |  |  |
| D |  |  |  |
| - E |  |  |  |
| O 3 F F |  |  |  |
|  | FDC FUNCTION SELECT IS FROM $\mathrm{A} 3-\mathrm{A} 9 . \mathrm{FDC} \mathrm{A} \emptyset=\mathrm{A} \emptyset, \mathrm{FDC} \mathrm{CSV}=\mathrm{A} 1$ SELECT FOR 'DOR' IS FDC FUNCTIONAL SELECT • A2 IBM SPECIFIES $\text { FDC - STATUS }-3 F 4$ $\text { FDC - DATA }-3 \text { F5 }$ $\text { DOR - } \quad 3 \mathrm{~F} 2$ | IBM PCjr FDC @ 90 FX | $\begin{gathered} \mathrm{A} 1=\mathrm{X} \\ \text { DOR A2 }=\emptyset \\ \text { FDC A2 }=1 \end{gathered}$ |


| VIDEO ARRAY ADDRESS (3DA) | $\begin{aligned} & \text { PC MEMORY MAP } \\ & \text { 3DA } \end{aligned}$ |  | PCjr MEMORY MAP GATE ARRAY 3DA |  | TANDY $10 \emptyset 0$ MEMORY MAP VIDEO ARRAY 3DA \& 3DE |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | READ | WRITE | READ | WRITE | READ (3DA) | WRITE (3DE) |
| 90 BIT 0 | DISPLAY INACTIVE | NOT USED | DISPLAY ENABLE | HIBW/LOBW | DISPLAY INACTIVE | NOT USED |
| 90 BIT 1 | LIGHT PEN SET | NOT USED | LIGHT PEN SET | GRAPHICS | LIGHT PEN SET | NOT USED |
| 09 BIT 2 | LIGHT SWITCH STATUS | NOT USED | LIGHT SWITCH STATUS | B/W | LIGHT SWITCH STATUS | NOT USED |
| 90 BIT 3 | VERTICAL RETRACE | NOT USED | VERTICAL RETRACE | VIDEO ENABLE | VERTICAL RETRACE | NOT USED |
| 09 BIT 4 | NOT USED | NOT USED | VIDEO DOTS | I6 COLOR GRAPHICS | NOT USED | NOT USED |
|  |  |  |  |  |  |  |
| 91 BIT 0 |  | NOT USED |  | PALETTE MASK 9 |  | PALETTE MASK 9 |
| 01 BIT I |  | NOT USED |  | PALETTE MASK I |  | PALETTE MASK 1 |
| 01 BIT 2 |  | NOT USED |  | PALETTE MASK 2 |  | PALETTE MASK 2 |
| 01 BIT 3 |  | NOT USED |  | PALETTE MASK 3 |  | PALETTE MASK 3 |
|  |  |  |  |  |  |  |
| 02 BIT 0 |  | NOT USED |  | BORDER BLUE |  | BORDER BLUE |
| 02 BIT I |  | NOT USED |  | BORDER GREEN |  | BORDER GREEN |
| 02 BIT 2 |  | NOT USED |  | BORDER RED |  | BORDER RED |
| 92 BIT 3 |  | NOT USED |  | BORDER INTENSITY |  | BORDER INTENSITY |
|  |  |  |  |  |  |  |
| 03 BIT 9 |  | NOT USED |  | RESERVED $=0$ |  | NOT USED |
| 03 BIT 1 |  | NOT USED |  | ENABLE BLINK |  | NOT USED |
| 03 BIT 2 |  | NOT USED |  | RESERVED = ¢ |  | BORDER ENABLE |
| 03 BIT 3 |  | NOT USED |  | 2 COLOR GRAPHICS |  | 4 COLOR HIGH RES. |
| 03 BIT 4 |  | NOT USED |  | NOT USED |  | 16 COLOR MODE |
|  |  |  |  |  |  |  |
| 04 BIT 9 |  | NOT USED |  | ASYNCHRON. RESET |  | NOT USED |
| 04 BIT 1 |  | NOT USED |  | SYNCHRONOUS RESET |  | NOT USED |
|  |  |  |  |  |  |  |
| $19-1 \mathrm{~F}$ BIT 0 |  | NOT USED |  | PALETTE BLUE |  | PALETTE BLUE |
| I0-1F BIT 1 |  | NOT USED |  | PALETTE GREEN |  | PALETTE GREEN |
| $10-1$ F BIT 2 |  | NOT USED |  | PALETTE RED |  | PALETTE RED |
| $10-1 F$ BIT 3 |  | NOT USED |  | PALETTE INTENSITY |  | PALETTE INTENSITY |
|  | $\begin{aligned} & \text { READS STATUS } \\ & \text { AT 3DA } \end{aligned}$ |  | READS STATUS <br> AT 3DA AND <br> SET ADDRESS/DATA <br> FLIP-FLOP TO ADDRESS | WRITE ADDRESS <br> AT 3DA <br> WRITE DATA <br> AT 3DA | $\begin{aligned} & \text { READS STATUS } \\ & \text { AT 3DA } \end{aligned}$ | WRITE ADDRESS <br> AT 3DA <br> Write data <br> AT 3DE |


| DATA | IBM PC <br> 0081 - WRITE ONLY | IBM PCjr | TANDY $1 \emptyset \emptyset \emptyset$ |
| :---: | :---: | :---: | :---: |
| BIT $\emptyset$ | DMA CH2 ADDRESS A16 |  |  |
| 1 | A17 |  |  |
| 2 | 1 A18 | SAME | SAME |
| 3 | DMA CH2 ADDRESS A19 |  |  |
| 4 | NO USE |  |  |
| 5 |  |  |  |
| 16 | 1 |  |  |
| BIT 7 | NO USE |  |  |
|  |  | DMA OPTIONAL ON PCjr | DMA OPTIONAL ON TANDY 1000. |




|  | PC MEMORY MAP | PCjr MEMORY MAP | TANDY 1000 MEMORY MAP |
| :---: | :---: | :---: | :---: |
| 3DF BIT $\dagger$ | NOT USED | CRT PAGE $\emptyset$ | CRT PAGE $\emptyset$ |
| 3DF BIT 1 | NOT USED | CRT PAGE 1 | CRT PAGE 1 |
| 3DF BIT 2 | NOT USED | CRT PAGE 2 | CRT PAGE 2 |
| 3DF BIT 3 | NOT USED | PROCESSOR PAGE 1 | PROCESSOR PAGE 1 |
| 3DF BIT 4 | NOT USED | PROCESSOR PAGE 2 | PROCESSOR PAGE 2 |
| 3DF BIT 5 | NOT USED | PROCESSOR PAGE 3 | PROCESSOR PAGE 3 |
| 3DF BIT 6 | NOT USED | VIDEO ADDRESS MODE $\emptyset$ | VIDEO ADDRESS MODE $\emptyset$ |
| 3DF BIT 7 | NOT USED | VIDEO ADDRESS MODE 1 | VIDEO ADDRESS MODE 1 |
| 3DF BIT 7 | NOT USED | VIDEO ADDRESS MODE 1 | VIDEO ADDRESS MODE 1 |


| DATA | $\begin{gathered} \text { IBM PC } \\ 3 F 2 \text { (WRITE ONLY) } \end{gathered}$ | IBM PCjr SAME | TANDY $10 \emptyset 0$ SAME |
| :---: | :---: | :---: | :---: |
| BIT $\emptyset$ | DRIVE SELECT $\emptyset^{*}$ | DRIVE ENABLE | DRIVE SELECT $\emptyset^{*}$ |
| BIT 1 | DRIVE SELECT ${ }^{*}$ | NOT USED | DRIVE SELECT 1* |
| BIT 2 | $\theta=$ FDC RESET | NOT USED | $\emptyset=$ FDC RESET |
| BIT 3 | 1 = ENABLE INTERRUPT, DMA | NOT USED | 1 = ENABLE DMA REQ/INTERRUPT |
| BIT 4 | 1 - DRIVE MOTOR \# 1 ON | NOT USED | 1 = DRIVE $\emptyset$ MOTOR ON |
| BIT 5 | \#2 | WATCH DOG TIMER ENABLE | 1 = DRIVE 1 MOTOR ON |
| BIT 6 | \# | WATCH DOG TIMER TRIGGER | 1 - FDC TERMINAL COUNT |
| BIT 7 | 1 = DRIVE MOTOR \#4 ON | FDC RESET | NOT USED |
|  |  |  | * TO SELECT DRIVE $\emptyset:$ BIT $\emptyset^{*} \cdot$ BIT 1* TO SELECT DRIVE $1:$ BIT $\emptyset \cdot$ BIT $1^{*}$ |


|  | PC MEMORY MAP | PCjr MEMORY MAP | TANDY $10 \emptyset \emptyset$ MEMORY MAP |
| :---: | :---: | :---: | :---: |
| 3D8 BIT $\emptyset$ | HIGH RESOLUTION CLOCK | NOT USED | HIGH RESOLUTION CLOCK |
| 3D8 BIT 1 | GRAPHICS SELECT | NOT USED | GRAPHICS SELECT |
| 3 D 8 BIT 2 | BLACK AND WHITE | NOT USED | BLACK AND WHITE |
| 3D8 BIT 3 | VIDEO ENABLE | NOT USED | VIDEO ENABLE |
| 3D8 BIT 4 | 640 DOT GRAPHICS | NOT USED | 640 DOT GRAPHICS |
| 3D8 BIT 5 | BLINK ENABLE | NOT USED | BLINK ENABLE |
| $3 \mathrm{D} 9 \mathrm{BIT} \emptyset$ | BACKGROUND BLUE | NOT USED | BACKGROUND BLUE |
| 3D9 BIT 1 | BACKGROUND GREEN | NOT USED | BACKGROUND GREEN |
| 3 D 9 BIT 2 | BACKGROUND RED | NOT USED | BACKGROUND RED |
| 3 D 9 BIT 3 | BACKGROUND INTENSITY | NOT USED | BACKGROUND INTENSITY |
| 3 D 9 BIT 4 | FOREGROUND INTENSITY | NOT USED | FOREGROUND INTENSITY |
| 3 D 9 BIT 5 | COLOR SELECT | NOT USED | COLOR SELECT |
|  |  |  |  |


| DATA | $\begin{gathered} \text { IBM PC } \\ \text { 037A (037E) } \end{gathered}$ | $\begin{gathered} \text { IBM PCjr } \\ \text { 037A (037E) } \end{gathered}$ | TANDY $1 \emptyset \emptyset \emptyset$ 037A (037E) |
| :---: | :---: | :---: | :---: |
| BIT $\emptyset$ | $\theta=$ STROBE | $\theta=$ STROBE | $\emptyset=$ STROBE |
| BIT 1 | $\theta$ = AUTO FD XT | $\theta=$ AUTO FD XT | $\emptyset=$ AUTO FD XT |
| BIT 2 | $\phi=$ INITIALIZE | $\theta=$ INITIALIZE | $\theta=$ INITIALIZE |
| BIT 3 | $\emptyset$ = SELECT PRINTER | $\theta$ = SELECT PRINTER | $\emptyset=$ SELECT PRINTER |
| BIT 4 | 1 = ENABLE INTERRUPT | 1 = ENABLE INTERRUPT | 1 = ENABLE INTERRUPT |
| BIT 5 | UNUSED | UNUSED | $\theta=$ ENABLE OUTPUT DATA |
| BIT 6 | UNUSED | UNUSED | UNUSED |
| BIT 7 | UNUSED | UNUSED | UNUSED |
|  |  |  |  |


| DATA | $\begin{gathered} \text { IBM PC } \\ 0378(037 \mathrm{C}) \mathrm{RW} \end{gathered}$ | $\begin{gathered} \text { IBM PCjr } \\ 0378(037 \mathrm{C}) \end{gathered}$ | TANDY $1 \emptyset 0 \emptyset$ 0378 |
| :---: | :---: | :---: | :---: |
| BIT 0 | DATA BIT $\emptyset$ - LSB | DATA BIT $\emptyset$ - LSB | DATA BIT $\emptyset$ - LSB |
| BIT 1 | DATA BIT 1 - | DATA BIT 1 - | DATA BIT 1 - |
| BIT 2 | DATA BIT $2-$ | DATA BIT $2-$ | DATA BIT $2-$ |
| BIT 3 | DATA BIT 3 - | DATA BIT 3 - | DATA BIT 3 - |
| BIT 4 | DATA BIT 4 - | DATA BIT 4 - | DATA BIT 4 - |
| BIT 5 | DATA BIT 5 - | DATA BIT 5 - | DATA BIT 5 - |
| BIT 6 | DATA BIT 6 - | DATA BIT 6 - | DATA BIT 6 - |
| BIT 7 | DATA BIT 7 - MSB | DATA BIT 7 - MSB | DATA BIT 7 - MSB |
|  | 0379 (037D) READ ONLY | 0379 (037D) READ ONLY | 0379 |
| BIT $\emptyset$ | UNUSED | UNUSED | UNUSED |
| BIT 1 | UNUSED | UNUSED | UNUSED |
| BIT 2 | UNUSED | UNUSED | UNUSED |
| BIT 3 | $\theta=$ ERROR CONDITION | $\emptyset=E R R O R$ | $\theta=E R R O R$ |
| BIT 4 | 1 = PRINTER SELECTED | 1 = PRINTER SELECTED | 1 = PRINTER SELECTED |
| BIT 5 | $\theta=$ END OF FORM | $\theta$ = END OF FORM | $\emptyset=$ END OF FORM |
| BIT 6 | $\emptyset=$ ACKNOWLEDGE | $\theta=$ ACKNOWLEDGE | $\emptyset=$ ACKNOWLEDGE |
| BIT 7 | $\emptyset=$ BUSY | $\emptyset=$ BUSY | $\emptyset=$ BUSY |
|  |  |  |  |


| DATA | $\begin{gathered} \text { IBM PC } \\ 0201 \text { - READ } \end{gathered}$ | $\begin{gathered} \text { IBM PCjr } \\ 0201 \text { - READ } \end{gathered}$ | TANDY $1 \emptyset \emptyset \emptyset$ $0201 \text { - READ }$ |
| :---: | :---: | :---: | :---: |
| BIT $\emptyset$ | A - X POSITION | A - X POSITION | L-X POSITION |
| BIT 1 | A - Y | A - Y | $L-Y$ |
| BIT 2 | B - $\mathbf{X}$ | B - X | $\mathbf{R}-\mathrm{X}$ |
| BIT 3 | $\mathrm{B}-\mathrm{Y}$ | $\mathrm{B}-\mathrm{Y}$ | $\mathbf{R}-\mathbf{Y}$ |
| BIT 4 | A BUTTON \# 1 | A BUTTON \#1 | L BUTTION \# 1 |
| BIT 5 | A BUTTON \#2 | A BUTTON \#2 | L BUTTON \#2 |
| BIT 6 | B BUTTON \# 1 | B BUTTON \# 1 | R BUTTON \# 1 |
| BIT 7 | B BUTTON \#2 | B BUTTON \#2 | R BUTTON \#2 |
|  | WRITE TO PORT STARTS TIMING PERIOD. <br> (ENABLES ONE SHOT MODE OF QUAD 555.) <br> THEREFORE WRITE TO PORT 201 BEFORE INTEGRATING PORT ON JOYSTICK VALUES. |  | WRITE TO 0200 RESTARTS INTEGRATOR. THEREFORE WRITE TO 201 BEFORE INTEGRATING PORT IN JOYSTIÇK VALUES. |


| DATA | $\begin{gathered} \text { IBM PC } \\ \text { وФA }- \text { WRITE } \end{gathered}$ | $\begin{gathered} \text { IBM PCjr } \\ \emptyset \emptyset A \emptyset-A 7 \end{gathered}$ | $\begin{gathered} \text { TANDY } 1 \emptyset \emptyset \emptyset \\ \emptyset 0 \mathrm{~A} \emptyset, 00 \mathrm{~A} 1 \end{gathered}$ |
| :---: | :---: | :---: | :---: |
| BIT $\emptyset$ | X | X | MEMCONFIG $\emptyset$ |
| BIT 1 |  |  | MEMCONFIG 1 |
| BIT 2 |  | $\downarrow$ | MEMCONFIG 2 |
| BIT 3 |  | X | MEMCONFIG 3 |
| BIT 4 |  | 1 = DISABLE - HRQ (BUS HOLD REQ) | X |
| BIT 5 | $\pm$ | $\begin{aligned} & \text { 1: TIMER CLK \#2 }=1.1925 \mathrm{MHZ} \\ & \emptyset: \text { TIMER CLK \#2 }=\text { CLK } \# 1 \text { OUT } \end{aligned}$ | X |
| BIT 6 | X | 1 = 1R TEST | X |
| BIT 7 | 1 = ENABLE NMI | 1 = ENABLE NMI | 1 = ENABLE NMI |
|  | READ FROM $\emptyset \emptyset A \emptyset$ - NO FUNCTION. | READ FROM ØӨA - $9 \emptyset$ A 7 CLEARS NMI ENABLE NO DATA INVOLVED. | READ FROM 0ØA $0,00 \mathrm{~A} 1$ HAS NO FUNCTION. DEFINES ONE OF FIVE 128 K MEMORY. <br> SEE MEMORY PAGE MAP. |

## Printer Specifications

$\begin{aligned} & X=\text { follows standard } \\ & *_{n}=\text { special }(\text { see notes } n)\end{aligned} \quad A=$ alternate ( $\quad \quad E G=$ enable graphics $\quad D G=$ disable graphics

| Types | $\left\|\begin{array}{l} -\mathrm{CGP} \\ 22 \emptyset \\ 1192 \end{array}\right\|$ | -LP (Dot Matrix)- |  |  | ------DMP (Dot Matrix)- |  |  |  |  | ---- | ------ | DWP | (Daisy Wheel) Tandy <br> 210 410$\|$Spec |  |  | IBM <br> Spec |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Model |  | V | VI | VIII | 110 | 120 | 200 | 409 | 429 | 500 | 2109 |  |  |  |  |  |
| 26 |  | 1165 | I166 | 1168 | 1271 | 1255 | 1254 | 1251 | 1267 | 1252 | 1256 | 1158 | 1257 | 1250 |  |  |
| Code |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21 ! | $!$ | ! | ! | ! | $!$ | $!$ | $!$ | $!$ | ! | $!$ | ! | $!$ | $!$ | $!$ | $!$ | ! |
| 22 " | " | " | " | " | " | " | " | " | " | " | " | " | " | " | " | " |
| 23 \# | \# | \# | \# | \# | \# | \# | \# | \# | \# | \# | \# | \# | \# | \# | \# | \# |
| 24 \$ | S | \$ | \$ | \$ | S | \$ | S | \$ | S | \$ | \$ | \$ | \$ | \$ | \$ | \$ |
| $25 \%$ | \% | \% | \% | \% | \% | \% | \% | \% | \% | \% | \% | \% | \% | \% | \% | \% |
| 26 \& | \& | \& | \& | \& | \& | \& | \& | \& | \& | \& | \& | \& | \& | \& | \& |  |
| 27 , | , | , | , | , | , | , | , | , | , | , | , | , | , | , | , | , |
| 28 ( | ( | $($ | $($ | $($ | ( | ( | ( | $($ | ( | ( | ( | $($ | ( | ( | ( | ( |
| 29 ) | ) | ) | ) | ) | ) | ) | ) | ) | ) | ) | ) | ) | ) | ) | ) | ) |
| 2A* | * | * | * | * | * | * | * | * | * | * | * | * | * | * | * | * |
| $2 \mathrm{~B}+$ | + | + | + | + | + | + | + | + | + | + | + | + | + | + | + | + |
| 2 C , | , | , | , | , | , | , | , | , | , | , | , | , | , | , | , | , |
| 2D - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - |
| 2E. | - |  | . |  |  | . | . | . |  | . |  |  |  |  |  |  |
| 2F/ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | / |
| 300 | $\emptyset$ | $\emptyset$ | $\emptyset$ | 0 | $\emptyset$ | 0 | 0 | 0 | $\emptyset$ | 0 | $\emptyset$ | 0 | 0 | $\emptyset$ | $\emptyset$ | 0 |
| 311 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 322 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 |
| 333 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 |
| 344 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 |
| 355 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 |
| 366 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 |
| 377 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 |
| 388 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 |
| 399 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 | 9 |
| 3A : | : | : | : | : | : | : | : | : | : | : | : | : | : | : | : | : |
| 3B ; | ; | ; | ; | ; | , | ; | ; | ; | ; | , | ; | , | ; | , | ; | , |
| 3 C | < | < | < | < | < | < | < | < | < | < | < | $<$ | < | < | < | < |
| $3 \mathrm{D}=$ | $=$ | $=$ | $=$ | $=$ | $=$ | $=$ | $=$ | $=$ | $=$ | $=$ | $=$ | $=$ | $=$ | $=$ | $=$ | = |
| 3E > | ) | ) | ) | ) | ) | ) | ) | ) | ) | ) | > | ) | $)$ | ) | ) | ) |
| 3F ? | ? | ? | ? | ? | ? | ? | ? | ? | ? | ? | ? | ? | ? | ? | ? | ? |
| 40 @ | (a) | (a) | (a) | (a) | (a) | (a) | (a) | (a) | (a) | (a) | @ | @ | @ | @ | @ | (a) |
| 41 A | A | A | A | A | A | A | A | A | A | A | A | A | A | A | A | A |
| 42 B | B | B | B | B | B | B | B | B | B | B | B | B | B | B | B | B |
| 43 C | C | C | C | C | C | C | C | C | C | C | C | C | C | C | C | C |
| 44 D | D | D | D | D | D | D | D | D | D | D | D | D | D | D | D | D |
| 45 E | E | E | E | E | E | E | E | E | E | E | E | E | E | E | E | E |
| 46 F | F | F | F | F | F | F | F | F | F | F | F | F | F | F | F | F |
| 47 G | G | G | G | G | G | G | G | G | G | G | G | G | G | G | G | G |
| 48 H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H | H |
| 49 I | I | I | I | I | I | I | I | I | 1 | I | I | I | I | 1 | I | I |
| 4A J | J | J | J | J | J | J | J | J | J | J | J | J | J | J | J | J |
| 4B K | K | K | K | K | K | K | K | K | K | K | K | K | K | K | K | K |
| 4C L | L | L | L | L | L | L | L | L | L | L | L | L | L | L | L | L |
| 4D M | M | M | M | M | M | M | M | M | M | M | M | M | M | M | M | M |
| 4E N | N | N | N | N | N | N | N | N | N | N | N | N | N | N | N | N |
| 4F O | 0 | 0 | 0 | 0 | 0 | 0 | 0 | O | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

$\begin{aligned} & \mathrm{X}=\text { follows standard } \\ & \boldsymbol{*}_{\mathbf{n}}=\text { special (see notes } \mathrm{n} \text { ) }\end{aligned} \quad \mathrm{A}=$ alternate ( ) $\quad \mathrm{EG}=$ enable graphics $\quad \mathrm{DG}=$ disable graphics

| Types | $\begin{aligned} & -\mathrm{CGP} \\ & 220 \\ & 1192 \end{aligned}$ | -LP (Dot Matrix)- |  |  | ---D | DMP | Dot Ma | trix) | - | --- | ------ | DWP (Daisy Wheel) Tandy |  |  |  | $\begin{gathered} \text { IBM } \\ \text { Spec } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Model |  | V | VI | VIII | 116 | 120 | 200 | 409 | 420 | 500 | 2100 | II | 210 | 1410 | Spec |  |
| 26 |  | 1165 | 1166 | 1168 | 1271 | 1255 | 1254 | 1251 | 1267 | 1252 | 1256 | 1158 | 1257 | 1250 |  |  |
| Code |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 50 P | P | P | P | P | P | P | P | P | P | P | P | $\mathbf{P}$ | P | P | P | P |
| 51 Q | Q | Q | Q | Q | Q | Q | Q | Q | Q | Q | Q | Q | Q | Q | Q | Q |
| 52 R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R | R |
| 53 S | S | S | S | S | S | S | S | S | S | S | S | S | S | S | S | S |
| 54 T | T | T | T | T | T | T | T | T | T | T | T | T | T | T | T | T |
| 55 U | U | U | U | U | U | U | U | U | U | U | U | U | U | U | U | U |
| 56 V | V | V | V | V | V | V | V | V | V | V | V | V | V | V | V | V |
| 57 W | W | W | W | W | W | W | W | W | W | W | W | W | W | W | W | W |
| 58 X | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X |
| 59 Y | Y | Y | Y | Y | Y | Y | Y | Y | Y | Y | Y | Y | Y | Y | Y | Y |
| 5A Z | Z | Z | Z | Z | Z | Z | Z | Z | Z | Z | Z | Z | Z | Z | Z | Z |
| 5B [ | X | X | X | X | X | X | X | $\mathbf{X}(\uparrow)$ | X ( $\uparrow$ ) | X | X ( $\uparrow$ ) | X | $\mathbf{X}(\uparrow)$ | X | X ( $\uparrow$ ) | X |
| 5 C 1 | X | X | X | X | X | X | X | X ( $\downarrow$ ) | $\mathbf{X}(\downarrow)$ | X | $\mathbf{X}(\downarrow)$ | X | $\mathbf{X}(\downarrow)$ | X | $\mathbf{X}(\downarrow)$ | X |
| 5D ] | X | X | X | X | X | X | X | $\mathbf{X}(\leftarrow)$ | $\mathbf{X}(\leftarrow)$ | X | $\mathbf{X}(\leftarrow)$ | X | $\mathbf{X}(\stackrel{)}{ }$ | X | $\mathbf{X}(\leftarrow)$ | X |
| $5 \mathrm{E}^{\wedge}$ | X | A (t) | A (1) | X | X | X | X | $\mathbf{X}(\rightarrow)$ | $\mathbf{X}(\rightarrow)$ | X | $\mathbf{X}(\rightarrow)$ | X | $\mathbf{X}(\rightarrow)$ | X | $\mathbf{X}(\rightarrow)$ | X |
| 5 F | X | A $(\leftarrow)$ | $\mathbf{A}(\leftarrow)$ | X | X | X | X | X | X | X | X | X | X | X | X | X |
| $60^{\prime}$ | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X |
| 61 a | a | a | a | a | a | a | a | a | a | a | a | a | a | a | a | a |
| 62 b | b | b | b | b | b | b | b | b | b | b | b | b | b | b | b | b |
| 63 c | c | c | c | c | c | c | c | c | c | c | c | c | c | c | c | c |
| 64 d | d | d | d | d | d | d | d | d | d | d | d | d | d | d | d | d |
| 65 e | e | e | e | e | e | e | e | e | e | e | e | e | e | e | e | e |
| 66 f | f | f | f | f | f | f | f | f | f | f | f | f | f | f | f | f |
| 67 g | g | g | g | $g$ | g | g | $g$ | g | g | g | g | g | $g$ | g | $g$ | g |
| 68 h | h | h | h | h | h | h | h | h | h | h | h | h | h | h | h | h |
| 69 i | i | 1 | i | 1 | i | i | i | i | i | i | I | i | I | i | i | - |
| 6 Aj | j | j | j | j | j | j | J | j | J | j | j | j | j | j | j | j |
| 6 Bk | k | k | k | k | k | k | k | k | k | k | k | k | k | k | k | k |
| 6 Cl | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 6D m | m | m | m | m | m | m | m | m | m | m | m | m | m | m | m | m |
| 6E n | n | n | n | $n$ | n | $n$ | n | n | $n$ | n | n | n | n | n | n | n |
| 6F o | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 79 p | p | p | p | p | p | p | p | p | p | p | p | p | p | p | p | p |
| 71 q | q | q | q | q | q | q | 4 | q | q | q | q | q | q | q | q | q |
| 72 r | r | r | r | r | r | r | r | r | r | r | r | r | r | r | , | r |
| 73 s | s | s | s | s | $s$ | $s$ | s | s | s | s | s | s | $s$ | s | s | s |
| 74 t | t | t | t | t | t | t | t | t | t | t | t | t | t | t | t | t |
| 75 u | u | u | u | u | u | u | u | u | u | u | u | u | u | u | u | u |
| 76 v | $v$ | v | $v$ | $v$ | v | $v$ | v | v | v | v | $v$ | v | v | $v$ | v | v |
| 77 w | w | w | w | w | w | w | w | w | w | w | w | w | w | w | w | w |
| 78 x | x | $\mathbf{x}$ | $\mathbf{x}$ | $\mathbf{x}$ | $\mathbf{x}$ | x | $\mathbf{x}$ | $\mathbf{x}$ | x | $\mathbf{x}$ | $\mathbf{x}$ | $\mathbf{x}$ | $\mathbf{x}$ | $\mathbf{x}$ | $\mathbf{x}$ | $\mathbf{x}$ |
| 79 y | y | y | y | y | y | y | y | y | y | y | y | y | y | y | y | y |
|  | z | z | z | z | z | z | z | z | z | $z$ | z | $\underline{z}$ | z | z | z | z |
| 7 B \{ | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X |
| 7 C | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X |
| 7D \} | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X |
| 7E - | X | X | X | X | $\mathbf{X}$ | X | X | X | X | X | X | X | X | X | X | X |
| $7 \mathbf{F}$ | X | X | X | $\mathbf{X}$ | X | X | X | X | X | X | X | X | X | X | X | X |

$\underset{\sim n=\text { follows standard }}{X} \quad \mathbf{A}=$ alternate ( $\quad \quad \mathrm{EG}=$ enable graphics $\quad \mathrm{DG}=$ disable graphics * $_{\mathrm{n}}=$ special (see notes $\mathbf{n}$ )

\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline Types Model 26 \& \[
\begin{gathered}
\text { DMP } \\
2100 \mathrm{P} \\
1274
\end{gathered}
\] \& \[
\begin{gathered}
\text { DMP } \\
430 \\
1277
\end{gathered}
\] \& \[
\begin{gathered}
\text { DMP } \\
105 \\
1276
\end{gathered}
\] \& \[
\begin{gathered}
\text { DMP } \\
130 \\
1280
\end{gathered}
\] \& \[
\begin{gathered}
\text { DWP } \\
220 \\
1278
\end{gathered}
\] \& \[
\begin{gathered}
\text { TRP } \\
100 \\
1275
\end{gathered}
\] \& \[
\begin{gathered}
\text { LMP } \\
2150 \\
1272
\end{gathered}
\] \& TANDY \& IBM \\
\hline Code \& \& \& \& \& \& \& \& \& \\
\hline \begin{tabular}{l}
80 \\
81 \\
82 \\
83 \\
84 \\
85 \\
86 \\
87 \\
88 \\
89 \\
8A \\
8B \\
8C \\
8D \\
8E \\
8F
\end{tabular} \& \& \& \& \& \& \& \& \& \[
\begin{aligned}
\& \text { C } \\
\& \text { ü } \\
\& \text { é } \\
\& \hat{a} \\
\& \text { à } \\
\& \ddot{a} \\
\& \text { à } \\
\& \circ \\
\& \text { à } \\
\& \text { c (BEL) } \\
\& \hat{e} \text { (BS) } \\
\& \ddot{e} \text { (HT) } \\
\& \text { e (LF) } \\
\& \hat{i} \text { (VT) } \\
\& \ddot{i} \text { (FF) } \\
\& \text { i (CR) } \\
\& \text { ï (SO) } \\
\& \AA \text { (SI) }
\end{aligned}
\] \\
\hline \begin{tabular}{l}
99 \\
91 \\
92 \\
93 \\
94 \\
95 \\
96 \\
97 \\
98 \\
99 \\
9A \\
9B \\
9C \\
9D \\
9E \\
9F
\end{tabular} \& \& \& \& \& \& \& \& \& \begin{tabular}{l}
É \\
\(\boldsymbol{x}\) \\
A (10) \\
\(\stackrel{\circ}{\circ}\) \\
ö (EE) \\
ò \\
\(\hat{\mathbf{u}}\) \\
ù \\
ü (CAN) \\
Ö \\
Ü \\
¢ \\
£ \\
Y \\
Pt \\
\(f\)
\end{tabular} \\
\hline  \& \[
\begin{aligned}
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X}
\end{aligned}
\] \& \(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\)
\(\mathbf{X}\) \& \[
\begin{aligned}
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \hline
\end{aligned}
\] \& \[
\begin{aligned}
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X} \\
\& \mathbf{X}
\end{aligned}
\] \& X

X \& $\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$

$\mathbf{X}$ \& $$
\begin{aligned}
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X} \\
& \mathbf{X}
\end{aligned}
$$ \& $\mathbf{X}$

$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$
$\mathbf{X}$ \&  <br>
\hline
\end{tabular}

| $\begin{aligned} & X=\text { follows standard } \\ & { }_{*_{n}}=\text { special }(\text { see notes } n \text { ) } \end{aligned}$ |  |  | A = alternate ( | ) | EG = enable graphics |  | DG $=$ disable graphics |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Types Model 26 | $\begin{gathered} \text { DMP } \\ 2100 \mathrm{P} \\ 1274 \end{gathered}$ | $\begin{gathered} \text { DMP } \\ 430 \\ 1277 \end{gathered}$ | $\begin{gathered} \text { DMP } \\ 105 \\ 1276 \end{gathered}$ | $\begin{gathered} \text { DMP } \\ 130 \\ 1280 \end{gathered}$ | $\begin{gathered} \text { DWP } \\ 220 \\ 1278 \end{gathered}$ | $\begin{gathered} \text { TRP } \\ 100 \\ 1275 \end{gathered}$ | $\begin{aligned} & \text { LMP } \\ & 2150 \\ & 1272 \end{aligned}$ | TANDY | IBM |
| Code |  |  |  |  |  |  |  |  |  |
| B9 $\quad ¥$ | X | X | X | X |  | X | X | X |  |
| B1 $\ddot{\text { A }}$ | X | X | X | X |  | X | X | X |  |
| B2 0 | X | X | X | X |  | X | X | X |  |
| B3 Ü | X | X | X | X |  | X | X | X | I |
| B4 ${ }^{\text {¢ }}$ | X | X | X | X |  | X | X | X | $\pm$ |
| B5 ~ | X | X | X | X |  | X | X | X | $\ddagger$ |
| B6 ä | X | X | X | X |  | X | X | X | -1 |
| B7 $\quad$ ö | X | X | X | X |  | X | X | X | $\pi$ |
| B8 ii | X | X | X | X |  | X | X | X | 7 |
| B9 ${ }^{\text {B }}$ | X | X | X | X |  | X | X | X | 4 |
| BA Tm | X | $\mathbf{X}$ | X | $\mathbf{X}$ |  | X | X | X | 11 |
| BB è | X | X | X | X |  | X | X | X | 7 |
| BC ù | X | X | X | X |  | X | X | X | 』 |
| BD è | X | X | X | X |  | X | X | X | $\stackrel{ }{4}$ |
| BE " | X | X | X | X |  | X | X | X | $\pm$ |
| BF $f$ | X | X | X | X |  | X | X | X | 7 |
| C 0 â | X | X |  | X |  | X |  | X | L |
| C1 ${ }_{\text {ê }}$ | X | X |  | X |  | X |  | X | $\perp$ |
| C2 i | X | X |  | $\mathbf{X}$ |  | X |  | X | T |
| C3 ${ }^{\text {of }}$ | X | X |  | X |  | X |  | X | + |
| C4 $\hat{\mathbf{u}}$ | X | X |  | X |  | X |  | X | - |
| C5 ^ | X | X |  | X |  | X |  | X | $+$ |
| C6 ë | X | X |  | X |  | X |  | X | F |
| C7 | X | X |  | X |  | X |  | X | Ir |
| CB á | X | X |  | X |  | X |  | X | $\stackrel{1}{5}$ |
| C9 | X | X |  | X |  | X |  | X | $\stackrel{T}{1}$ |
| CA ${ }_{\text {ó }}$ | X | X |  | X |  | X |  | X | $\xrightarrow{\text { ㄴ }}$ |
| C8 ${ }^{\text {u }}$ | X | X |  | X |  | X |  | X | T |
| CC i | X |  |  | X |  | X |  | X | 1 F |
| CD ${ }^{\text {n }}$ | X | X |  | X |  | X |  | X | = |
| CE à | X | X |  | X |  | X |  | X | 4 |
| CF ${ }^{\text {or }}$ | X | X |  | X |  | X |  | X | $\pm$ |
| D9 A | X | X |  | X |  | X |  | X | $\stackrel{1}{ }$ |
| D1 $x$ | X | X |  | X |  | X |  | X | ㄱ |
| D2 ${ }^{\AA}$ | X | X |  | X |  | X |  | X | $\pi$ |
| D3 ${ }^{\text {a }}$ | X | X |  | X |  | X |  | X | - |
| D4 ${ }^{\text {d }}$ | X | X |  | X |  | X |  | X | 튼 |
| D5 ${ }^{\text {¢ }}$ | X | X |  | X |  | X |  | X | $F$ |
| D6 N | X | X |  | X |  | X |  | X | r |
| D7 E, | X | X |  | X |  | X |  | X | \# |
| D8 ${ }^{\text {A }}$ | X | X |  | X |  | X |  | X | $\neq$ |
| D9 $\mathrm{I}^{\prime}$, | X | X |  | X |  | X |  | X | 」 |
| DA ${ }^{\text {ó }}$ | $\mathbf{X}$ | X |  | X |  | X |  | X | $\Gamma$ |
| DB U' | X | X |  | X |  | X |  | X | - |
| DC i | X | X |  | X |  | X |  | X | - |
| DD U | X | X |  | X |  | X |  | X | $\cdots$ |
| DE E | X | X |  | X |  | $\mathbf{X}$ |  | X | - |
| DF A | X | X |  | X |  | X |  | X | - |



| $\begin{aligned} & X=f o l l \\ & *_{n}=s p \end{aligned}$ | ws stan cial (see | tes n ) | A = alter | ( ) |  | enable g | hics | DG = dis | ble grap |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Types | DMP | DMP | DMP | DMP | DWP | TRP | LMP | TANDY | IBM |
| Model | 2100P | 430 | 105 | 130 | 220 | 100 | 2150 |  |  |
| 26 | 1274 | 1277 | 1276 | 1280 | 1278 | 1275 | 1272 |  |  |
| Code |  |  |  |  |  |  |  |  |  |
| 00 |  |  |  |  |  |  |  |  |  |
| 01 | NUL | NUL | NUL | NUL | NUL | NUL | NUL | NUL | NUL |
| 02 |  |  |  |  |  |  |  |  |  |
| 93 |  |  |  |  |  |  |  |  |  |
| 94 |  |  |  |  |  |  |  |  |  |
| 95 |  |  |  |  |  |  |  |  |  |
| 96 |  |  |  |  |  |  |  |  |  |
| 97 |  |  |  | BEL |  |  |  | BEL | BEL |
| 98 | BM |  |  | BM | BM |  | BS | BM | BS |
| 99 |  |  |  |  |  | HT |  | LF | HT |
| 9A | LF | LF | LF | LF | LF | LF | LF | LF | LF |
| ¢B |  |  |  |  |  |  |  |  | VT |
| 9 C | FF | FF |  | FF |  | FF | FF | FF | FF |
| 9D | TR | CR | CR | CR | TR | CR | CR | TR | CR |
| 9E | EU | EU | EU | EU | EU | EU | EU | EU | SE |
| 9 F | SU | SU | SU | SU | SU | SU | SU | SU | CM |
| 10 |  |  |  |  |  |  |  |  |  |
| 11 |  |  |  |  |  |  |  |  |  |
| 12 | EG | EG | EG | EG |  | EG | EG | EG | 10 |
| 13 | ED |  |  | ED |  |  | ED | ED | DS |
| 14 | EW | EW |  | EW |  |  | EW | EW | EE |
| 15 |  |  |  |  |  |  |  |  |  |
| 16 |  |  |  |  |  |  |  |  |  |
| 17 |  |  |  |  |  |  |  |  |  |
| 18 |  |  |  |  |  |  |  |  | CAN |
| 19 |  | ED |  |  |  |  |  |  |  |
| 1 A |  |  |  |  |  |  |  |  |  |
| 1B | AP | AP |  |  |  |  |  |  |  |
| 1 C | RC | RC | RC | RC |  | RC | RC |  |  |
| 1D |  |  | BU |  |  |  |  |  |  |
| 1E | DG | DG | DG |  |  | DG | DG |  |  |
| 1 F |  |  | BI |  |  |  |  |  |  |




|  | Symbol $=$ description | \# of bytes in control code |
| :---: | :---: | :---: |
| 05 | $=$ select $\emptyset 5$ CPI monospaced characters | 1 |
| 75 | $=$ select 07.5 CPI monospaced characters | 2 |
| 10 | $=$ select $1 \emptyset$ CPI monospaced characters | 2 |
| 12 | $=$ select 12 CPI monospaced characters | 2 |
| 16 | $=$ select ( $15,16,16.7) \mathrm{CPI}$ monospaced characters (condensed) | 2 |
| 6LF | $=$ full line feed ( 6 lines/inch or $1 / 6$ inch line feed) | 2 |
| 7LF | $=4 / 5$ line feed ( 7.5 lines/inch or $8 / 60$ inch line feed) | 2 |
| BLF | $=3 / 4$ line feed ( 8 lines/inch or $1 / 8$ inch line feed) | 2 |
| 9L | $=2 / 3$ line feed ( $1 / 9 \mathrm{inch}$ forward line feed) | 2 |
| 10L | $=3 / 5$ line feed ( 10 lines/inch or $1 / 10$ inch line feed) | 2 |
| 12L | $=1 / 2$ line feed ( 12 lines/inch or $1 / 12$ inch line feed) | 2 |
| 36L | $=1 / 6$ line feed ( 36 lines/inch or $1 / 36$ inch line feed) | 2 |
| 48L | $=1 / 8$ line feed (48 lines/inch or $1 / 48$ inch line feed) | 2 |
| 72L | $=1 / 12$ line feed ( 72 lines/inch or $1 / 72$ inch line feed) | 2 |
| 72 I | $=7 / 12$ line feed ( $7 / 72$ inch line feed) | 2 |
| 129 | $=1 / 2 \emptyset$ line feed ( 120 lines/inch or $1 / 12 \emptyset$ inch line feed) | 2 |
| 144 | $=1 / 24$ line feed (144 lines/inch or $1 / 144$ inch line feed) | 2 |
| 188 | $=1 / 31$ line feed ( 188 lines/inch or $1 / 188$ inch line feed) | 2 |
| $14 n$ | $=\mathrm{n} / 24$ line feed (144/n lines/inch or $n / 144$ inch line feed) | 3 |
| 18n | $=n / 31$ line feed ( $188 / \mathrm{n}$ lines/inch or $\mathrm{n} / 188$ inch line feed) | 3 |
| 216 | $=1 / 36$ line feed ( 216 lines/inch or $1 / 216$ inch line feed) | 2 |
| 21 n | $=\mathrm{n} / 36$ line feed (216/n lines/inch or $n / 216$ inch line feed) | 3 |
| 72n | $=n / 72$ line feed (executes $n / 72$ inch line feed) | 3 |
| 72 S | $=n / 72$ line feed (sets $n / 72$ inch line feed, no motion) | 3 |
| 6B | $=$ select $6 \emptyset$ dots/inch bit image | $4+n 1 \mathrm{n} 2$ |
| 12B | $=$ select 120 dots $/$ inch bit image | $4+n \ln 2$ |
| 12G | $=$ select 129 dots/inch graphics | $4+n 1 \mathrm{n} 2$ |
| 24G | $=$ select 240 dots/inch graphics | $4+n 1 \mathrm{n} 2$ |
| A $\emptyset$ | $=$ font assignment for correspondence 10 CPI | 3 |
| A1 | = font assignment for correspondence 12 CPI | 3 |
| AP | = font assignment for proportional | 3 |
| ALF | $=$ line feed is set to ESC A $(1 \mathrm{~B}+41)$ | 2 |
| BEL | = ring bell | 1 |
| BI | $=$ select bidirectional printing | 1 |
| BM | = back space in microspaces | 2 |
| BS | $=$ back space 1 character width relative to current pitch | 1 |
| BU | $=$ bidirectional $(\mathrm{n}=\emptyset)$ - unidirectional ( $\mathrm{n}=1$ ) carriage movement | 3 |
| CAN | = clear print buffer and see manual for special conditions | 1 |
|  | $=$ print control characters in $\emptyset-2 \emptyset \mathrm{H}$ range | 2 |
| CE | $=$ select correspondence 12 CPI character | 2 |
| CIP | = cancel ignore paper end | 2 |
| CM | $=$ select compressed mode ( $1 / 2$ current pitch selection) | 1 |
| CN | $=$ select correspondence 10 CPI character | 2 |
| CP | $=$ select compressed proportional character | 2 |
| CR | = carriage return $\mathrm{w} / \mathrm{o}$ line feed | 1 |
| CS | = color-scan mode | 2 |
| CS1 | = select character set \# 1 | 2 |
| CS2 | = select character set \#2 | 2 |
| CT | = cancel tabs to default settings | 2 |


|  | Symbol $=$ description | \# of bytes in control code |
| :---: | :---: | :---: |
| D11 | $=$ define dot interval ratio (1:1) | 2 |
| D43 | $=$ define dot interval ratio (4:3) | 2 |
| DCS | = download character set | 3 |
| DG | = disable graphics | 1 |
| DH | = double height | 2 |
| DR | = advance paper one dot row | 2 |
| DS | $=$ de select printer (serial $=\mathrm{X}$ off) | 1 |
| EA | $=$ end superscript, subscript or double height | 2 |
| EB | $=$ end bold print | 2 |
| ED | = enable data processing mode | 1 |
| EE | $=$ end of chracter elongation | 2 |
| EF | $=$ select standard elite 12 CPI characters | 2 |
| EG | = enable graphics | 1 |
| EM | = end emphasized (horizontal double strike) | 2 |
| ES | = end skip perforation | 2 |
| ET | = end 16 CPl (condensed) character mode | 2 |
| EU | $=$ end underline | 1 |
| EW | $=$ enable word processing mode | 1 |
| EX | = exit external program mode | 2 |
| FE | = forward linefeed execute | 2 |
| FF | = form feed | 1 |
| FL | = set form feed length | 3 |
| FR | = full reverse line feed | 2 |
| FS | $=$ font select $\mathrm{n}=1$ high speed $\mathrm{n}=2$ middle font $\mathrm{n}=3$ letter qual. | 3 |
|  | = half line-feed forward (no motion) | 2 |
| HG | $=$ transfers high-res graphic data | 4+1(N1N2) |
| HP | $=$ moves the print head to a position specified | 4 |
| HR | $=$ half line feed reverse | 2 |
| HT | = horizontal tab | 1 |
| IB | = select IBM character set | 2 |
| IC | = italic cursive character | 2 |
| IM | = increment microspaces (proportional spacing) | 2 |
| 100 | = italic on/off | 3 |
| IP | = ignore paper end | 2 |
| ISO | $=$ selects ISO character sets n=country | 3 |
| LF | = full forward line feed | 1 |
| LM | $=$ left margin set | 3 |
| MF | = micro font | 2 |
| Mn | = set horizontal margin | 4 |
| MD | $=$ toggles between Tandy and IBM modes | 2 |
| NLQ | = near letter quality - proportional font | 2 |
| NQE | = near letter quality - elite font | 2 |
| NQP | $=$ near letter quality - pica font | 2 |
| NUL | $=$ terminator | 1 |
| P1 | = insert new paper in hopper \#1 | 2 |
| P2 | = insert new paper in hopper \#2 | 2 |
| PF | $=$ select standard pica 10 CPI characters | 2 |
| PN | = proportional spacing on/off | 3 |
| PS | $=$ set perforations skip | 3 |

[^1]|  | Symbol $=$ description | \# of bytes in control code |
| :---: | :---: | :---: |
| RC | = repetitions of character | 3 |
| RES | $=$ reserved | 0 |
| RLF | $=$ reverse line feed | 2 |
| RM | $=$ right margin set | 3 |
| RS | $=$ Tandy character set | 2 |
| SB | = start bold | 2 |
| SC | = select color | 2 |
| SCR | $=$ select $\mathrm{CR}=\mathrm{CR}$ only | 2 |
| SE | = start of character elongation | 2 |
| SEU | = $\mathbf{n}=1$ start underline $\mathrm{n}=\emptyset$ end underline | 3 |
| SF | $=$ set forward linefeed | 2 |
| SHT | = set horizontal tab | 2+list ( terminal= $\dagger$ ) |
| SM | $=$ select emphasized (horizontal double strike) | 2 |
| SNL | $=$ select $\mathrm{CR}=\mathrm{CR}+\mathrm{LF}$ | 2 |
| SP | $=$ select proportional characters | 2 |
| SPF | $=$ select proportional font | 3 |
| SPL | = sets page length | 3 |
| SRF | $=$ set reverse line feed | 2 |
| SS | $=$ superscript ( $\mathrm{n}=\emptyset$ ) - subscript ( $\mathrm{n}=1$ ) character | 3 |
| SSS | $=$ selects superscript under the condition specified in the owners manual | 2 |
| SU | = start underline | 1 |
| SVT | $=$ set vertical tab | $2+$ list ( terminal $=\emptyset$ ) |
| TCR | $=\mathrm{n}=\emptyset \mathrm{CR}$ only $\mathrm{n}=1 \mathrm{CR}+\mathrm{LF}$ | 3 |
| TER | $=$ terminator of tab list | 1 |
| TF | = top of form | 2 |
| TR | $=$ Tandy carriage return ( $\mathrm{CR}+\mathrm{LF}$ ) | 2 |
| VT | = vertical tab | 1 |
| XP | = enter external program mode | 2 |

## intel

# iAPX 88/10 <br> 8-BIT HMOS MICROPROCESSOR 8088/8088-2 

\author{

- 8-Bit Data Bus Interface <br> - 16-Bit Internal Architecture <br> - Direct Addressing Capability to 1 Mbyte of Memory <br> - Direct Software Compatibility with iAPX 86/10 (8086 CPU) <br> - 14-Word by 16-Bit Register Set with Symmetrical Operations <br> - 24 Operand Addressing Modes
}

The Intel ${ }^{*}$ iAPX 88/10 is a new generation, high performance microprocessor implemented in $N$-channel, depletion load, silicon gate technology (HMOS), and packaged in a 40-pin CerDIP package. The processor has attributes of both 8 - and 16 -bit microprocessors. It is directly compatible with iAPX 86/10 software and 8080/8085 hardware and peripherals.


Figure 1. iAPX 88/10 CPU Functional Block Diagram
Figure 2. IAPX 88/10 Pin Configuration
iAPX 88/10

## ABSOLUTE MAXIMUM RATINGS*

| Storage Temperature. $-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}$ <br> Voltage on Any Pin with <br> Respect to Ground . . . . . . . . . . . . . . . . . - 1.0 to +7 V |
| :---: |
|  |  |
|  |  |
|  |  |
|  |  |

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

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

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 | $\mathrm{v}_{\mathrm{CC}}+0.5$ | $\checkmark$ |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| ${ }^{1} \mathrm{CC}$ | $\text { Power Supply Current: } \begin{aligned} & 8088 \\ & 8088-2 \end{aligned}$ |  | $\begin{aligned} & 340 \\ & 350 \end{aligned}$ | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant V_{C C}$ |
| ILO | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{OUT}} \leqslant \\ & V_{\mathrm{CC}} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{CL}}$ | Clock Input Low Voltage | -0.5 | +0.6 | $V$ |  |
| $\mathrm{V}_{\mathrm{CH}}$ | Clock Input High Voltage | 3.9 | $\mathrm{v}_{\mathrm{CC}}+1.0$ | V |  |
| $\mathrm{C}_{\text {IN }}$ | Capacitance if Input Buffer (All input except $A D_{0}-A D_{7}, R Q / G T$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{10}$ | Capacitance of I/O Buffer $\left(A D_{0}-A D_{7}, R Q / G T\right.$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

## A.C. CHARACTERISTICS (8088: $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C \mathrm{C}}=5 \mathrm{~V} \pm 10 \%$ ) ( $8088-2: \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, V_{C C}=5 \mathrm{~V} \pm 5 \%$ )

MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS

|  |  | 8088 |  | 8088-2 |  |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Min. | Max. | Min. | Max. | Units |  |
| TCLCL | CLK Cycle Period | 200 | 500 | 125 | 500 | ns |  |
| TCLCH | CLK Low Time | ( $2 / 3$ TCLCL) -15 |  | (2/3 TCLCL)-15 |  | ns |  |
| TCHCL | CLK High Time | $(1 / 3$ TCLCL) +2 |  | $(1 / 3$ TCLCL) +2 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 |  | 10 | ns | $\begin{aligned} & \text { From } 1.0 \mathrm{~V} \\ & \text { to } 3.5 \mathrm{~V} \end{aligned}$ |
| TCL2CL1 | CLK Fall Time |  | 10 |  | 10 | ns | From 3.5V to 1.0 V |
| TDVCL | Data in Setup Time | 30 |  | 20 |  | ns |  |
| TCLDX | Data in Hold Time | 10 |  | 10 |  | ns |  |
| TRIVCL | RDY Setup Time into 8284 (See Notes 1, 2) | 35 |  | 35 |  | ns |  |
| TCLR1X | RDY Hold Time into 8284 (See Notes 1, 2) | 0 |  | 0 |  | ns |  |
| TRYHCH | READY Setup Time into 8088 | (2/3TCLCL)-15 |  | (2/3 TCLCL)-15 |  | ns |  |
| TCHRYX | READY Hold Time into 8088 | 30 |  | 20 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 3) | -8 |  | -8 |  | ns |  |
| THVCH | HOLD Setup Time | 35 |  | 20 |  | ns |  |
| TINVCH | INTR, NMI, TEST Setup Time (See Note 2) | 30 |  | 15 |  | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 |  | 20 | ns | $\begin{aligned} & \text { From } 0.8 \mathrm{~V} \\ & \text { to } 2.0 \mathrm{~V} \end{aligned}$ |
| TIHIL | Input Fall Time (Except CLK) |  | 12 |  | 12 | ns | $\begin{aligned} & \text { From } 2.0 \mathrm{~V} \\ & \text { to } 0.8 \mathrm{~V} \end{aligned}$ |

iAPX 88/10
PRELODMONARY

## A.C. CHARACTERISTICS (Continued)

 timing responses|  |  | 8088 |  | 8088-2 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Min. | Max. | Min. | Max. | Units | Test Conditions |
| TCLAV | Address Valid Delay | 10 | 110 | 10 | 60 | ns | $C_{L}=20-100 \mathrm{pF} \text { for }$ <br> all 8088 Outputs <br> in addition to internal loads |
| TCLAX | Address Hold Time | 10 |  | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 80 | TCLAX | 50 | ns |  |
| TLHLL | ALE Width | TCLCH-20 |  | TCLCH-10 |  | ns |  |
| TCLLH | ALE Active Delay |  | 80 |  | 50 | ns |  |
| TCHLL | ALE Inactive Delay |  | 85 |  | 55 | ns |  |
| TLLAX | Address Hold Time to ALE Inactive | TCHCL-10 |  | TCHCL-10 |  | ns |  |
| TCLDV | Data Valid Delay | 10 | 110 | 10 | 60 | ns |  |
| TCHDX | Data Hold Time | 10 |  | 10 |  | ns |  |
| TWHDX | Data Hold Time After $\overline{W R}$ | TCLCH-30 |  | TCLCH-30 |  | ns |  |
| TCVCTV | Control Active Delay 1 | 10 | 110 | 10 | 70 | ns |  |
| TCHCTV | Control Active Delay 2 | 10 | 110 | 10 | 60 | ns |  |
| TCVCTX | Control Inactive Delay | 10 | 110 | 10 | 70 | ns |  |
| TAZRL | Address Float to READ Active | 0 |  | 0 |  | ns |  |
| TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 10 | 165 | 10 | 100 | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 150 | 10 | 80 | ns |  |
| TRHAV | $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TCLCL-45 |  | TCLCL-40 |  | ns |  |
| TCLHAV | HLDA Valid Delay | 10 | 160 | 10 | 100 | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Width | 2TCLCL-75 |  | 2TCLCL-50 |  | ns |  |
| TWLWH | WR Width | 2TCLCL-60 |  | 2TCLCL-40 |  | ns |  |
| TAVAL | Address Valid to ALE Low | TCLCH-60 |  | TCLCH-40 |  | ns |  |
| TOLOH | Output Rise Time |  | 20 |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | 12 |  | 12 | ns | From 2.0 V to 0.8 V |

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


WAVEFORMS


## WAVEFORMS (Continued)



## A.C. CHARACTERISTICS

MAX MODE SYSTEM (USING 8288 BUS CONTROLLER)

## TIMING REQUIREMENTS

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

## NOTES:

1. Signal at 8284 or 8288 shown for reference only.
2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK
3. Applies only to $T 2$ state ( 8 ns into $T 3$ state).
4. Applies only to T 2 state ( 8 ns into T 3 state).
iAPX 88/10
PRELINONARY

## A.C. CHARACTERISTICS

## TIMING RESPONSES

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

iAPX 88/10

WAVEFORMS


WAVEFORMS (Continued)


WAVEFORMS (Continued)


## inte

INTEL CORPORATION, 3065 Bowers Avenue, Santa Clara, California 95051

## intل ${ }^{\circ}$

## 8253/8253-5 PROGRAMMABLE INTERVAL TIMER

- MCS-85 ${ }^{\text {TM }}$ Compatible 8253.5
- 3 Independent 16-Bit Counters
- DC to 2 MHz
- Programmable Counter Modes
- Count Binary or BCD
- Single +5 V Supply
- Available in EXPRESS
-Standard Temperature Range
-Extended Temperature Range

The Intel 8253 is a programmable counter/timer chip designed for use as anl Intel microcomputer peripheral. It uses nMOS technology with a single +5 V supply and is packaged in a 24 -pin plastic DIP.
It is organized as 3 independent 16 -bit counters, each with a count rate of up to 2 MHz . All modes of operation are software programmable.


Figure 1. Block Diagram
Figure 2. Pin Configuration

## FUNCTIONAL DESCRIPTION

## General

The 8253 is a programmable interval timer/counter specifically designed for use with the Intel'u Microcomputer systems. Its function is that of a general purpose, multi-timing element that can be treated as an array of 1/O ports in the system software.
The 8253 solves one of the most common problems in any microcomputer system, the generation of accurate time delays under software control. Instead of setting up timing loops in systems software, the programmer configures the 8253 to match his requirements, initializes one of the counters of the 8253 with the desired quantity. then upon command the 8253 will count out the delay and interrupt the CPU when it has completed its tasks. It is easy to see that the software overhead is minimal and that multiple delays can easily be maintained by assignment of priority levels.

Other counter/timer functions that are non-delay in nature but alsn common to most microcomputers can be implemented with the 8253.

- Programmable Rate Generator
- Event Counter
- Binary Rate Multiplier
- Real Time Clock
- Digital One-Shot
- Complex Motor Controlter


## Data Bus Buffer

This 3-state, bi-directional, 8-bit buffer is used to interface the 8253 to the system data bus. Data is transmitted or received by the buffer upon execution of INput or OUTput CPU instructions. The Data Bus Buffer has three basic functions.

1. Programming the MODES of the 8253 .
2. Loading the count registers.
3. Reading the count values

## Read/Write Logic

The Read/Write Logic accepts inputs from the system bus and in turn generates control signals for overall device operation. It is enabled or disabled by CS so that no operation can occur to change the function untess the device has been selected by the system logic.

## $\overline{R D}$ (Read)

A "Iow" on this input informs the 8253 that the CPU is inputting data in the form of a counters value.

## $\overline{W R}$ (Write)

A "low" on this input informs the 8253 that the CPU is outputting data in the form of mode information or loading counters.

## A0, A1

These inputs are normally connected to the address bus. Their function is to select one of the three counters to be operated on and to address the control word register for mode selection.

## $\overline{\mathrm{CS}}$ (Chip Select)

A "low" on this input enables the 8253. No reading or writing will occur unless the device is selected. The $\overline{\mathrm{CS}}$ input has no effect upon the actual operation of the counters


Figure 3. Block Dlagram Showing Data Bus Bufter and Read/Write Logic Functions

| $\overline{\mathrm{CS}}$ | $\overline{\mathrm{BD}}$ | $\overline{\mathrm{WR}}$ | $\mathbf{A}_{\mathbf{1}}$ | $\mathbf{A}_{\mathbf{0}}$ |  |
| :--- | :---: | :---: | :---: | :---: | :--- |
| 0 | 1 | 0 | 0 | 0 | Load Counter No. 0 |
| 0 | 1 | 0 | 0 | 1 | Load Counter No. 1 |
| 0 | 1 | 0 | 1 | 0 | Load Counter No. 2 |
| 0 | 1 | 0 | 1 | 1 | Write Mode Word |
| 0 | 0 | 1 | 0 | 0 | Read Counter No. 0 |
| 0 | 0 | 1 | 0 | 1 | Read Counter No. 1 |
| 0 | 0 | 1 | 1 | 0 | Read Counter No. 2 |
| 0 | 0 | 1 | 1 | 1 | No-Operation 3-State |
| 1 | X | X | X | X | Disable 3-State |
| 0 | $\mathbf{1}$ | 1 | X | X | No-Operation 3-State |

## Control Word Register

The Control Word Register is selected when AO, A1 are 11 It then accepts information from the data bus buffer and stores it in a register. The information stored in this register controls the operational MODE of each counter selection of binary or BCD counting and the loading of each count register.

The Control Word Register can only be written into, no read operation of its contents is available

## Counter \#0, Counter \#1, Counter \#2

These three functional blocks are identical in operation so only a single Counter will be described Each Counter consists of a single, 16-bit, pre-settable, DOWN counter The counter can operate in either binary or $B C D$ and its input, gate and output are configured by the selection of MODES stored in the Control Word Register

The counters are fully independent and each can have separate Mode configuration and counting operation binary or BCD. Also there are special features in the control word that handle the loading of the count value so that software overhead can be minimized for these functions.
The reading of the contents of each counter is available to the programmer with simple READ operations for event counting applications and special commands and logic are included in the 8253 so that the contents of each counter can be read "on the fly" without having to inhitit the clock input.

## 8253 SYSTEM INTERFACE

The 8253 is a component of the Intel ${ }^{\text {m }}$ Microcomputer Systems and interfaces in the same manner as all other peripherals of the family. It is treated by the systems software as an array of peripheral 1/O ports; three are counters and the fourth is a control register for MODE programming
Basically, the select inputs AO. A1 connect to the AO. A1 address bus signals of the CPU The $\overline{\mathrm{CS}}$ can be derived directly trom the address bus using a linear select method Or it can be connected to the output of a decoder. such as an Intel. 8205 for larger systems


Figure 4. Block Diagram Showing Control Word Register and Counter Functions


Figure 5. 8253 System Interface

## OPERATIONAL DESCRIPTION

## General

The complete functional definition of the 8253 is programmed by the systems software. A set of control words must be sent out by the CPU to initialize each counter of the 8253 with the desired MODE and quantity information. Prior to initialization, the MODE, count, and output of all counters is undefined. These control words program the MODE, Loading sequence and selection of binary or $B C D$ counting.
Once programmed, the 8253 is ready to perform whatever timing tasks it is assigned to accomplish.
The actual counting operation of each counter is completely independent and additional logic is provided on-chip so that the usual problems associated with efficient monitoring and management of external. asynchronous events or rates to the microcomputer system have been eliminated

## Programming the $\mathbf{8 2 5 3}$

All of the MODES for each counter are programmed by the systems software by simple 1/O operations.
Each counter of the 8253 is individually programmed by writing a control word into the Control Word Register

## ( $A 0, A 1=11$ )

## Control Word Format

| $\mathrm{D}_{\mathbf{7}}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{\mathbf{5}}$ | $\mathrm{D}_{\mathbf{4}}$ | $\mathrm{D}_{\mathbf{3}}$ | $\mathrm{D}_{\mathbf{2}}$ | $\mathrm{D}_{\mathbf{1}}$ | $\mathrm{D}_{\mathbf{0}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC 1 | $\mathrm{SC0}$ | RL 1 | RLO | M 2 | M 1 | M 0 | BCD |

## Definition of Control

SC - Select Counter.

| SC1 | SC0 |  |
| :---: | :---: | :--- |
| 0 | 0 | Select Counter 0 |
| 0 | 1 | Select Counter 1 |
| 1 | 0 | Select Counter 2 |
| 1 | 1 | Illegal |

## RL - Read/Load:

RL1
RL0

| 0 | 0 | Counter Latching operation (see <br> READ/WRITE Procedure Section) |
| :---: | :---: | :--- |
| 1 | 0 | Read/Load most significant byte only. |
| 0 | 1 | Read/Load least significant byte only. |
| 1 | 1 | Read/Load least significant byte first. <br> then most significant byte. |

## M - MODE:

| M2 |
| :--- |
| M1 |
| 0 0 0 Mode 0 <br> 0 0 1 Mode 1 <br> $X$ 1 0 Mode 2 <br> $X$ 1 1 Mode 3 <br> 1 0 0 Mode 4 <br> 1 0 1 Mode 5 |

BCD:

| 0 | Binary Counter 16-bits |
| :---: | :--- |
| 1 | Binary Coded Decimal (BCD) Counter <br> (4 Decades) |

## Counter Loading

The count register is not loaded until the count value is written (one or two bytes, depending on the mode selected by the RL bits), followed by a rising edge and a falling edge of the clock. Any read of the counter prior to that falling clock edge may yield invalid data.

## MODE Definition

MODE 0: Interrupt on Terminal Count. The output will be initially low after the mode set operation. After the count is loaded into the selected count register. the output will remain low and the counter will count. When terminal count is reached the output will go high and remain high until the selected count register is reloaded with the mode or a new count is loaded. The counter continues to decrement after terminal count has been reached.
Rewriting a counter register during counting results in the following:
(1) Write 1 st byte stops the current counting.
(2) Write 2 nd byle starts the new count.

MODE 1: Programmable One.Shot. The output will go low on the count following the rising edge of tr.a gate in. put.
The output will go high on the terminal count. If a new count value is loaded while the output is low it will not affect the duration of the one-shot pulse until the succeeding trigger. The current count can be read at any time without affecting the one-shot pulse.
The one-shot is retriggerable, hence the output will remain low for the full count after any rising edge of the gate input.

## 8253/8253-5

MODE 2: Rate Generator. Divide by $N$ counter. The output will be low for one period of the input clock. The period from one output pulse to the next equals the number of input counts in the count register. If the count register is reloaded between output pulses the present period will not be affected, but the subsequent period will reflect the new value.
The gate input, when low, will force the output high. When the gate input goes high, the counter will start from the initial count. Thus, the gate input can be used to synchronize the counter.
When this mode is set, the output will remain high until after the count register is loaded. The output then can also be synchronized by software.

MODE 3: Square Wave Rate Generator. Similar to MODE 2 except that the output will remain high until one half the count has been completed (for even numbers) and go low for the other half of the count. This is accomplished by decrementing the counter by two on the falling edge of each clock pulse. When the counter reaches terminal count, the state of the output is changed and the counter is reloaded with the full count and the whale process is repeated.
If the count is odd and the output is high, the first clock pulse (after the count is loaded) decrements the count by 1 . Subsequent clock pulses decrement the clock by 2. After timeout, the output goes low and the full count is reloaded. The first clock puise (following the reload) decrements the counter by 3 . Subsequent clock pulses decrement the count by 2 until timeout. Then the whole process is repeated. In this way, if the count is odd, the output will be high for $(N+1) / 2$ counts and low for ( $\mathrm{N}-1$ )/2 counts.

MODE 4: Software Tinggered Strobe. After the mode is set, the output will be high. When the count is loaded, the counter will begin counting. On terminal count, the
output will go low for one input clock period, then will go high again.

If the count register is reloaded during counting, the new count will be loaded on the next CLK puise. The count will be inhibited while the GATE input is low.

MODE 5: Hardware Tiggered Strobe. The counter will start counting after the rising edge of the trigger input and will go low for one clock period when the terminal count is reached. The counter is retriggerable. The output will not go low until the full count after the rising edge of any trigger.

|  | $\begin{aligned} & \text { Low } \\ & \text { Or Going } \\ & \text { Low } \\ & \hline \end{aligned}$ | Rising | High |
| :---: | :---: | :---: | :---: |
| 0 | Disables counting | -- | Enables counting |
| 1 | $\cdots$ | 1) Initiates counting <br> 2) Fesets Onfput atter next clock | -- |
| 2 | 1) Disables counting <br> 2) Sets outpur immediately high | 1) Reloads counter <br> 2) Inltiates counting | Enables counting |
| 3 | 1) Disables counting <br> 2) Sets output immediately nigh | initlates counting | Enables counting |
| 4 | Disables counting | -- | Enables counting |
| 5 | -- | initiates counting | -- |

Figure 6. Gate PIn Operations Summery


Figure 7. 8253 Timing Diagrams

## 8253 READ/WRITE PROCEDURE

## Write Operations

The systems software must program each counter of the 8253 with the mode and quantity desired. The programmer must write out to the 8253 a MODE control word and the programmed number of count register bytes (1 or 2 ) prior to actually using the selected counter.
The actual order of the programming is quite flexible Writing out of the MODE control word can be in any sequence of counter selection, e.g., counter \#0 does not have to be first or counter \#2 last. Each counter's MODE control word register has a separate address so that its loading is completely sequence independent (SC0. SC1)

The loading of the Count Register with the actual count value, however, must be done in exactly the sequence programmed in the MOOE control word (RLO. RL1). This loading of the counter's count register is still sequence independent like the MODE control word loading, but when a selected count register is to be loaded it must be loaded with the number of bytes programmed in the MODE control word (RLO, RL1). The one or two bytes to be loaded in the count register do not have to follow the associated MOOE control word. They can be programmed at any time following the MODE control word loading as long as the correct number of bytes is loaded in order.

All counters are down counters. Thus, the value loaded into the count register will actually be decremented Loading all zeroes into a count register will result in the maximum count ( $2^{16}$ for Binary or $10^{4}$ for $B C D$ ). In MODE 0 the new count will not restart until the load has been completed. It will accept one of two bytes depending on how the MODE control words (RLO. RL.1) are programmed. Then proceed with the restart operation


Note: Format shown is a simple example of loading the 8253 and does not imply that it is the only format that can be used.

Figure 8. Programming Format


Note: The exclusive addresses of each counter's count register make the task of programming the 8253 a very simple matter, and maximum effective use of the device will result if this fenture is fully utilized.

Figure 9. Alternate Programming Formats

8253/8253-5

## Read Operations

In most counter applications it becomes necessary to read the value of the count in progress and make a computational decision based on this quantity. Event counters are probably the most common application that uses this function. The 8253 contains logic that will allow the programmer to easily read the contents of any of the three counters without disturbing the actual count in progress.
There are two methods that the programmer can use to read the value of the counters. The first method involves the use of simple 1/O read operations of the selected counter. By controlling the A0. A 1 inputs to the 8253 the programmer can select the counter to be read (remember that no read operation of the mode register is allowed A0. A1-11) The only requirement with this method is that in order to assure a stable count reading the actual operation of the selected counter must be inhibited either by controlling the Gate input or by external logic that inhibits the clock input The contents of the counter selected will be avallable as follows
first l/O Read contains the least significant byte (LSB)
second l/O Read contains the most significant byte (MSB).
Oue to the internal logic of the 8253 it is absolutely necessary to complete the entire reading procedure If two bytes are programmed to be read then two bytes must be read before any loading WR command can be sent to the same counter.

## Read Operation Chart

| A1 | AO | RD |  |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Read Counter No. 0 |
| 0 | 1 | 0 | Read Counter No. 1 |
| 1 | 0 | 0 | Read Counter No. 2 |
| 1 | 1 | 0 | Illegal |

## Reading While Counting

In order for the programmer to read the contents of any counter without effecting or disturbing the counting operation the 8253 has special internal logic that can be accessed using simple WR commands to the MODE register Basically, when the programmer wishes to read the contents of a selected counter "on the fiy" he toads the MODE register with a special code which latches the present count value into a storage register so that its contents contain an accurate, stable quantity. The programmer then issues a normal read command to the selected counter and the contents of the latched register is avallable

## MODE Register for Latching Count

$A 0, A 1=11$

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC1 | SC0 | 0 | 0 | $\times$ | $\times$ | $\times$ | $\times$ |

SC1.SC0 - specify counter to be latched
D5.D4 - 00 designates counter latching operation.
$\times$
The same limitation applies to this mode of reading the counter as the previous method. That is, it is mandatory to complete the entire read operation as programmed. This command has no effect on the counter's mode.


Figure 10. MCS-85 ${ }^{\text {™ }}$ Clock Interface*

## 8253/8253-5

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias
Storage Temperature
Voltage On Any Pin
With Respect to Ground
Power Dissipation
$0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
$0.5 \mathrm{Vto}+7 \mathrm{~V}$
1 Watt
*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not impliec. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $\quad\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%\right)$.

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | $\checkmark$ |  |
| $V_{\text {IH }}$ | Input High Voltage | 2.2 | $\mathrm{V}_{\mathrm{CC}}+.5 \mathrm{~V}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | Note 1 |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | $\checkmark$ | Note 2 |
| IIL | Input Load Current |  | +10 | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{\text {CC }}$ to $0 V$ |
| $\mathrm{I}_{\text {OFL }}$ | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $V_{\text {OUT }}=V_{\text {CC }}$ to 45 V |
| ${ }^{\text {c CC }}$ | $\mathrm{V}_{C C}$ Supply Current |  | 140 | mA |  |

CAPACITANCE $\left(T_{A}=25{ }^{-}, V_{C C}=G N D=0 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Typ. | Max | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{t/O}}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to $\mathrm{V}_{\mathrm{SS}}$ |

A.C. CHARACTERISTICS $\quad\left(T_{A}=0 . C\right.$ to $70 \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}=10 \%$, $\left.\mathrm{GND}-\mathrm{OV}\right) \cdot$

Bus Parameters (Note 3)
READ CYCLE

| Symbol | Parameter | 8253 |  | 8253-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $t^{\text {AR }}$ | Address Stable Before $\overline{R E A D}$ | 50 |  | 30 |  | ns |
| ${ }^{\text {tra }}$ | Address Hold Time for $\overline{\text { READ }}$ | 5 |  | 5 |  | ns |
| $t_{\text {RR }}$ | $\overline{\text { READ Pulse Width }}$ | 400 |  | 300 |  | ns |
| tro | Data Delay From $\overline{\text { PEAD }}{ }^{\text {4 }}$ |  | 300 |  | 200 | ns |
| $t_{\text {DF }}$ | $\overline{\text { READ }}$ to Data Floating | 25 | 125 | 25 | 100 | ns |
| $t_{\text {try }}$ | Recovery Time Between READ and Any Other Control Signal | 1 |  | 1 |  | $\mu \mathrm{s}$ |

## inted

## 8253/8253-5

## A.C. CHARACTERISTICS (Continued)

## write cycle

| Symbol | Parameter | 8253 |  | 8253-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {a }}$ AW | Address Stable Before WRITE | 50 |  | 30 |  | ns |
| twa | Address Hold Time for WRITE | 30 |  | 30 |  | ns |
| ${ }^{\text {tww }}$ | WRITE Putse Width | 400 |  | 300 |  | ns |
| $t_{\text {ow }}$ | Data Set Up Time for WRITE | 300 |  | 250 |  | ns |
| two | Data Hold Time for $\overline{\text { WRITE }}$ | 40 |  | 30 |  | ns |
| trv | Recovery Time Between WRITE and Any Other Control Signal | 1 |  | 1 |  | $\mu \mathrm{s}$ |

## CLOCK AND GATE TIMING

| Symbol | Parameter | 8253 |  | 8253 -5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {t CLK }}$ | Clock Period | 380 | dc | 380 | dc | ns |
| $t_{\text {PWW }}$ | High Pulse Width | 230 |  | 230 |  | ns |
| $t_{\text {PWWL }}$ | Low Pulse Width | 150 |  | 150 |  | ns |
| $\mathrm{t}_{\mathrm{GW}}$ | Gate Width High | 150 |  | 150 |  | ns |
| ${ }^{\text {t GL }}$ | Gate Width Low | 100 |  | 100 |  | ns |
| ${ }^{\text {tGS }}$ | Gate Set Up Time to CLK $\dagger$ | 100 |  | 100 |  | ns |
| ${ }^{t} \mathrm{GH}_{\mathrm{H}}$ | Gate Hold Time After CLK $\dagger$ | 50 |  | 50 |  | ns |
| tod | Output Delay From CLK $\downarrow$ [4] |  | 400 |  | 400 | ns |
| todg | Output Delay From Gate $\downarrow$ [4] |  | 300 |  | 300 | ns |
| ${ }^{\text {twc }}$ | Write to CLK Set Up | 450 |  | 350 |  |  |

NOTES:

1. $\mathrm{lOL}=2.2 \mathrm{~mA}$.
2. $\mathrm{IOH}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
3. AC timings measured at $\mathrm{V}_{\mathrm{OH}} 2.2, \mathrm{~V}_{\mathrm{OL}}=0.8$
4. $C_{L}=150 \mathrm{pF}$.

- For Extended Temperature EXPRESS, use M8253 electrical parameters.


## A.C. TESTING INPUT, OUTPUT WAVEFORM

(

## A.C. TESTING LOAD CIRCUI:-



8253/8253-5

## WAVEFORMS



## CLOCK AND GATE TIMING



[^2]
## intel

## 8259A/8259A-2 /8259A-8 PROGRAMMABLE INTERRUPT CONTROLLER

- iAPX 86, iAPX 88 Compatible
- MCS-80 ${ }^{\text {® }}$, MCS-85 ${ }^{\text {a }}$ Compatible
- Eight-Level Priority Controller
- Expandable to 64 Levels
- Programmable Interrupt Modes
- Individual Request Mask Capability
- Single + 5V Supply (No Clocks)
- 28-Pin Dual-In-Line Package
- Available in EXPRESS
- Standard Temperature Range
- Extended Temperature Range

The intel ${ }^{\text {* }}$ 8259A Programmabie Interrupt Controller handies up to eight vectored priority interrupts tor the CPU. It is cascadable for up to 64 vectored priority interrupts without additional circuitry. It is packaged in a 28 -pin DIP, uses NMOS technology and requires a single +5 V supply. Circuitry is static, requiring no clock input.
The 8259A is designed to minimize the software and real time overhead in handing multi-level priority interrupts it has several modes, permitting optimization for a variety of system requirements.

The 8259A is fully upward compatible with the Intel* 8259 . Software originally written tor the 8259 will operate the 8259A in all 8259 equivalent modes (MCS 80/85. Non-Buffered. Edge Trigqered)


Figure 1. Block Diagram


Figure 2. Pin Configuration

8259A/8259A-2/8259A-8

Table 1. Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 28 | 1 | Supply: +5V Supply. |
| GND | 14 | 1 | Ground. |
| $\overline{\mathrm{CS}}$ | 1 | 1 | Chip Select: A low on this pin enables $\overline{R O}$ and $\overline{W R}$ commurication between the CPU and the 8259A. INTA functions are independent of CS. |
| WR | 2 | $\bigcirc$ | Write: A low on this pin when CS is low enables the 8259A to accept command words from the CPU. |
| $\stackrel{\overline{\mathrm{RD}}}{ }$ | 3 | 1 | Read: A low on this pin when CS is low enables the 8259A to release status onto the data bus for the CPU. |
| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | 4-11 | $1 / 0$ | Bldirectional Data Bua: Control, status and interrupt-vector information is transferred via this bus. |
| $\mathrm{CAS}_{0}-\mathrm{CAS}_{2}$ | 12, 13, 15 | $1 / 0$ | Cascade Lines: The CAS lines form a private 8259A bus to control a multiple 8259A structure. These pins are outputs for a master 8259A and inputs for a slave 8259A. |
| $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ | 16 | 1/0 | Slave Program/Enable Buffer: This is a dual function pin. When in the Buffered Mode it can be used as an output to control buffer transceivers (EN). When not in the buffered mode it is used as an input to designate a master ( $\mathrm{SP}=1$ ) or slave $(\mathrm{SP}=0)$. |
| INT | 17 | $\bigcirc$ | Interrupt: This pin goes high whenever a valid interrupt request is asserted It is used to interrupt the CPU, thus it is connected to the CPU's interrupt pin. |
| $\underline{I R}-\mathrm{IR}_{7}$ | 18-25 | 1 | Interrupt Requests: Asynchronous inputs. An interrupt request is executed by raising an IR input (low to high), and holding it high until it is acknowledged (Edge Triggered Mode), or just by a high level on an (A input (Level Triggered Mode). |
| $\overline{\text { INTA }}$ | 26 | 1 | Interrupt Acknowledge: This pin is used to enable 8259A interrupt-vector data onto the data bus by a sequence of interrupt acknowledge pulses issued by the CPU |
| $A_{0}$ | 27 | 1 | AO Address Line: This pin acts in conjunction with the $\overline{\mathrm{CS}}, \overline{\mathrm{WR}}$, and $\overline{\mathrm{RD}}$ pins It is used by the 8259A to decipher various Command Words the CPU writes and status the CPU wishes to read. It is typically connected to the CPU AO address line (At for iAPX B6, 88). |

## FUNCTIONAL DESCRIPTION

## Interrupts in Microcomputer Systems

Microcomputer system design requires that I/O devices such as keyboards, displays, sensors and other components receive servicing in an efficient manner so that large amounts of the total system tasks can be assumed by the microcomputer with little or no effect on throughput.
The most common method of servicing such devices is the Polled approach. This is where the processor must test each device in sequence and in effect "ask" each one if it needs servicing. It is easy to see that a large portion of the main program is looping through this continuous polling cycle and that such a method would have a serious, detrimental effect on system throughput, thus limiting the tasks that could be assumed by the microcomputer and reducing the cost effectiveness of using such devices.
A more desirable method would be one that would allow the microprocessor to be executing its main program and only stop to service peripheral devices when it is told to do so by the device itself. In effect, the method would provide an external asynchronous input that would inform the processor that it should complete whatever instruction that is currently being executed and tetch a new routine that will service the requesting device. Once this servicing is complete, however, the processor would resume exactly where it left off.
This method is called Interrupt. It is easy to see that system throughput would drastically increase, and thus more tasks could be assumed by the microcomputer to further enhance its cost effectiveness.
The Programmable Interrupt Controller (PIC) functions as an overall manager in an Interrupt-Driven system environment. It accepts requests from the peripheral equipment, determines which of the incoming requests is of the highest importance (priority), ascertains whether the incoming request has a higher priority value than the level currently being serviced, and issues an interrupt to the CPU based on this determination.
Each peripheral device or structure usually has a special program or "routine" that is associated with its specific functional or operational requirements; this is referred to as a "service routine". The PIC, after issuing an Interrupt to the CPU, must somehow input information into the CPU that can "point" the Program Counter to the service routine associated with the requesting device. This "pointer" is an address in a vectoring table and will often be referred to, in this document, as vectoring data.

## The 8259A

The 8259A is a device specifically designed for use in real time, interrupt driven microcomputer systems. It manages eight levels or requests and has built-in features for expandability to other 8259A's (up to 64 levels). It is programmed by the system's software as an I/O peripheral. A selection of priority modes is avallable to the programmer so that the manner in which the requests are proceased by the 8259A can be configured to
match his system requirements. The priority modes can be changed or reconfigured dynamically at any time during the main program. This means that the complete interrupt structure can be defined as required, based on the total system environment.


Figure 3a. Polled Method


Figure 3b. Interrupt Method

## INTERRUPT REQUEST REGISTER (IRR) AND IN-SERVICE REGISTER (ISR)

The interrupts at the IR Input lines are handled by two registers in cascade, the Interrupt Request Register (IRR) and the In-Service Register (ISR). The IRR is used to store all the interrupt levels which are requesting service; and the ISR is used to store all the interrupt levels which are being serviced.

## PRIORITY RESOLVER

This logic block determines the priorities of the bits set in the IRR. The highest priority is selected and strobed into the corresponding bit of the ISR during INTA pulse.

## INTERRUPT MASK REGISTER (IMR)

The IMR stores the bits which mask the interrupt lines to be masked. The IMR operates on the IRR. Masking of a higher priority input will not affect the interrupt request lines of lower priority.

## INT (INTERRUPT)

This output goes directly to the CPU interrupt input. The $\mathrm{V}_{\mathrm{OH}}$ level on this line is designed to be fully compatible with the 8080A, 8085A and 8086 input levels.

## $\overline{\text { INTA }}$ (INTERRUPT ACKNOWLEDGE)

$\overline{\text { INTA }}$ pulses will cause the 8259A to release vectoring information onto the data bus. The format of this data depends on the system mode ( $\mu \mathrm{PM}$ ) of the 8259A.

## DATA BUS BUFFER

This 3-state, bidirectional 8 -bit buffer is used to interface the 8259A to the system Data Bus. Control words and status information are transferred through the Data Bus Buffer.

## READNWRITE CONTROL LOGIC

The function of this block is to accept OUTput commands from the CPU. It contains the Initialization Command Word (ICW) registers and Operation Command Word (OCW) registers which store the various control formats for device operation. This function block also allows the status of the 8259A to be transterred onto the Data Bus.

## $\overline{\text { Cs }}$ (CHIP SELECT)

A LOW on this input enables the 8259A. No reading or writing of the chip will occur unless the device is selected.

## WR (WRITE)

A LOW on this input enables the CPU to write control words (ICWs and OCWs) to the 8259A.

## $\overline{\text { RD }}$ (READ)

A LOW on this input enables the 8259A to send the status of the Interrupt Request Register (IRR), In Service Register (ISR), the Interrupt Mask Register (IMR), or the Interrupt level onto the Data Bus.


Figure 4a. 8259A Block Diagram


Figure 4b. 8259A Block Diagram

## $A_{0}$

This input signal is used in conjunction with $\overline{W R}$ and $\overline{R D}$ signals to write commands into the various command registers, as well as reading the various status registers of the chip. This line can be tied directly to one of the address lines.

## THE CASCADE BUFFER/COMPARATOR

This function block stores and compares the IDs of all 8259A's used in the system. The associated three I/O pins (CASO-2) are outputs when the 8259A is used as a master and are inputs when the 8259A is used as a slave. As a master, the 8259A sends the ID of the interrupting slave device onto the CASO-2 lines. The slave thus selected will send its preprogrammed subroutine address onto the Data Bus during the next one or two consecutive INTA pulses. (See section "Cascading the 8259A")

## INTERRUPT SEQUENCE

The powerful features of the 8259A in a microcomputer system are its programmability and the interrupt routine addressing capability. The latter allows direct or indirect jumping to the specific interrupt routine requested without any polling of the interrupting devices. The normal sequence of events during an interrupt depends on the type of CPU being used.
The events occur as follows in an MCS-80/85 system:

1. One or more of the INTERRUPT REQUEST lines (1R7-0) are raised high, setting the corresponding IRR bit(s).
2. The 8259A evaluates these requests, and sends an INT to the CPU, if appropriate
3. The CPU acknowledges the INT and responds with an INTA pulse
4. Upon receiving an INTA from the CPU group, the highest priority ISR bit is set, and the corresponding IRR bIt is reset. The 8259A will also release a CALL in struction code (11001101) onto the 8-bit Data Bus through its D7-0 pins.
5. This CALL instruction will initiate two more $\overline{\operatorname{INTA}}$ pulses to be sent to the 8259A from the CPU group.
6. These iwo INTAA pulses allow the 8259A to release its preprogrammed subroutine address onto the Data Bus. The lower 8-bit address is released at the first INTA pulse and and the higher 8 -bit address is released at the second $\overline{\mathrm{NTA}}$ pulse
7. This completes the 3-byte CALL instruction released by the 8259A. In the AEOI mode the ISR bit is reset at the end of the third INTA pulse. Otherwise, the ISR bit remains set until an appropriate EOI command is issued at the end of the interrupt sequence.
The events occurring in an IAPX 86 system are the same unt!l step 4
8. Upon receiving an INTA trom the CPU group, the highest priority ISR DIt is set and the corresponding IRR Dit is reset The 8259A does not drive the Data Bus during this cycle.
9. The iAPX 86.10 will initiate a second ITNTA pulse During this pulse. the 8259A releases an 8-bit pointer onto the Data Bus where it is read by the CPU

6 This completes the interrupt cycle. In the AEOI mode the ISR bit is reset at the end of the second INTA pulse Otherwise. the ISR bit remains set until an appropriate EOI command is issued at the end of the interrupt subroutine.

If no interrupt request is present at step 4 of either sequence (i.e., the request was too short in duration) the 8259A will issue an interrupt level 7. Both the vectoring bytes and the CAS lines will look like an interrupt level 7 was requested.


Figure 4c. 8259A Block Diagram


Figure 5. 8259A Interface to Standard System Bus

## INTERRUPT SEQUENCE OUTPUTS MCS-80, MCS-85*

This sequence is timed by three IINTĀ pulses. During the first INTA pulse the CALL opcode is enabled onto the data bus.

## Content of First Interrupt <br> Vector Byte

|  | D7 | D8 | D5 | D4 | 03 | D2 | 01 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| call cooe | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 |

During the second $\overline{\operatorname{NT}} \mathbf{A}$ pulse the lower address of the appropriate service routine is enabled onto the data bus. When Interval $=4$ bits $A_{5}-A_{7}$ are programmed, while $A_{0^{-}}$ $A_{4}$ are automatically inserted by the 8259A. When Inter$\mathrm{val}=8$ only $A_{6}$ and $A_{7}$ are programmed, while $A_{0}-A_{5}$ are automatically inserted.

Content of Second Interrupt
Vector Byte

| 1R | Interval $=4$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | 01 | DO |
| 7 | A7 | A6 | A5 | 1 | 1 | 1 | 0 | 0 |
| 6 | A7 | A6 | A5 | 1 | 1 | 0 | 0 | 0 |
| 5 | A7 | A6 | A5 | 1 | 0 | 1 | 0 | 0 |
| 4 | A7 | A6 | A5 | 1 | 0 | 0 | 0 | 0 |
| 3 | A7 | A6 | A5 | 0 | 1 | 1 | 0 | 0 |
| 2 | A7 | A6 | A5 | 0 | 1 | 0 | 0 | 0 |
| 1 | A7 | A6 | A5 | 0 | 0 | 1 | 0 | 0 |
| 0 | A7 | A6 | A5 | 0 | 0 | 0 | 0 | 0 |


| IR | interval $=8$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | 01 | D0 |
| 7 | A7 | A6 | 1 | 1 | 1 | 0 | 0 | 0 |
| 6 | A7 | A6 | 1 | 1 | 0 | 0 | 0 | 0 |
| 5 | A7 | A6 | 1 | 0 | 1 | 0 | 0 | 0 |
| 4 | A) | A6 | 1 | 0 | 0 | 0 | 0 | 0 |
| 3 | A7 | A6 | 0 | 1 | 1 | 0 | 0 | 0 |
| 2 | A7 | A6 | 0 | 1 | 0 | 0 | 0 | 0 |
| 1 | A 7 | A6 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | A) | A6 | 0 | 0 | 0 | 0 | 0 | 0 |

During the third INTA pulse the higher address of the appropriate service routine, which was programmed as byte 2 of the initialization sequence $\left(A_{8}-A_{15}\right)$, is enabled onto the bus.

Content of Third Interrupt
Vector Byte

| D7 | D8 | D5 | D4 | D3 | D2 | D1 | D |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A 15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 |

## IAPX 86, IAPX 88

iAPX 86 mode is similar to MCS-80 mode except that only two Interrupt Acknowledge cycles are issued by the processor and no CALL opcode is sent to the processor. The first interrupt acknowledge cycle is similar to that of MCS-80, 85 systems in that the 8259A uses it to internally freeze the state of the interrupts for priority resolution and as a master it issues the interrupt code on the cascade lines at the end of the INTA pulse. On this first cycle it does
not issue any data to the processor and leaves its data bus bufters disabled. On the second interrupt acknowledge cycle in IAPX 86 mode the master (or slave if so programmed) will send a byte of data to the processor with the acknowledged interrupt code composed as follows (note the state of the ADI mode control is ignored and $A_{5}-A_{11}$ are unused in iAPX 86 mode):

Content of Interrupt Vector Byte for iApX $\mathbf{8 6}$ System Mode

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IR 7 | 17 | T6 | T5 | T4 | T3 | 1 | 1 | 1 |
| IR6 | T7 | T6 | T5 | T4 | T3 | 1 | 1 | 0 |
| IR5 | 17 | T6 | T5 | T4 | T3 | 1 | 0 | 1 |
| IR4 | T7 | T6 | T5 | T4 | 13 | 1 | 0 | 0 |
| IR3 | T7 | T6 | T5 | T4 | T3 | 0 | 1 | 1 |
| IR2 | T7 | T6 | T5 | T4 | T3 | 0 | 1 | 0 |
| IR 1 | 17 | T6 | T5 | T4 | T3 | 0 | 0 | 1 |
| IRO | 17 | T6 | T5 | T4 | T3 | 0 | 0 | 0 |

## PROGRAMMING THE 8259A

The 8259A accepts two types of command words generated by the CPU:

1. Initialization Command Words (ICWs,: Before normal operation can begin, each 8259A in the systern must be brought to a starting point - by a sequence of 2 to 4 bytes timed by $\overline{W R}$ pulses.
2. Operation Command Words (OCWs): These are the command words which command the 8259A 10 oper. ate in various interrupt modes. These modes are
a. Fully nested mode
b. Rotating priority mode
c. Special mask mode
d. Polled mode

The OCWs can be written into the 8259A anytime after initialization.

## INITIALIZATION COMMAND WORDS (ICWS) <br> GENERAL

Whenever a command is issued with $\mathrm{A} 0=0$ and $\mathrm{D} 4=1$, this is interpreted as Initialization Command Word 1 (ICW1). ICW1 starts the initialization sequence during which the following automatically occur.
a. The edge sense circuit is reset, which means that following initialization, an interrupt request (IR) input must make a low-to-high transition to generate an interrupt.
b. The Interrupt Mask Register is cleared
c. IR7 input is assigned priority 7.
d. The slave mode address is set to 7 .
e. Special Mask Mode is cleared and Status Read is set to IRR.
f. If IC4 $=0$, then all functions selected in ICW4 are set to zero. (Non-Buffered mode*, no Auto-EOI, MCS-80, 85 system).
-Nole: MasteriSlave in ICW4 is only used in the buffered mode

## INITIALIZATION COMMAND WORDS 1 AND 2 (ICW1, ICW2)

$\mathrm{A}_{5}-\mathrm{A}_{15}$ : Page starting address of service routines. In an MCS 80/85 system, the 8 request levels will generate CALLs to 8 tocations equally spaced in memory. These can be programmed to be spaced at intervals of 4 or 8 memory locations, thus the 8 routines will occupy a page of 32 or 64 bytes, respectively.
The address format is 2 bytes long $\left(A_{0}-A_{15}\right)$. When the routine interval is $4, A_{0}-A_{4}$ are automatically inserted by the 8259A, while $A_{5}-A_{15}$ are programmed externally. When the routine interval is $8, A_{0}-A_{5}$ are automatically inserted by the 8259A, while $A_{6}-A_{15}$ are programmed externally.
The 8-byte interval will maintain compatibility with current software, while the 4 -byte interval is best for a compact jump table

In an iAPX 86 system $A_{15}-A_{1 t}$ are inserted in the five most significant bits of the vectoring byte and the 8259A sets the three least significant bits according to the interrupt level. $\mathrm{A}_{10}-\mathrm{A}_{5}$ are ignored and ADI (Address interval) has no effect

LTIM: If LTIM $=1$, then the 8259A will operate in the level interrupt mode. Edge detect logic on the interrupt inputs will be disabled.
$A D I: \quad C A L L$ address interval. $A D I=1$ then interval $=4$; $A D I=0$ then interval $=8$

SNGL: Single. Means that this is the only 8259A in the system. If SNGL = 1 no ICW3 will be issued.

IC4: If this bit is set - ICW4 has to be read. If ICW4 is not needed, set IC4 $=0$.

## INITIALIZATION COMMAND WORD 3 (ICW3)

This word is read only when there is more than one 8259A in the system and cascading is used, in which case $\mathrm{SNGL}=0$. It will load the 8 -bit slave register. The functions of this register are:
a. In the master mode (either when $S P=1$, or in buffered mode when M/S = 1 in ICW4) a " 1 " is set for each slave in the system. The master then will release byte 1 of the call sequence (for MCS-80/85 system) and will enable the corresponding slave to release bytes 2 and 3 (for iAPX 86 only byte 2) through the cascade lines
b. In the slave mode (either when $\overline{\mathbf{S P}}=0$, or if $\mathrm{BUF}=1$ and $M / S=0$ in ICW4) bits $2-0$ identify the slave. The slave compares its cascade input with these bits and if they are equal, bytes 2 and 3 of the call sequence (or just byte 2 for iAPX 86 are released by it on the Data Bus.

## INITIALIZATION COMMAND WORD 4 (ICW4)

SFNM: If SFNM = 1 the special fully nested mode is programmed.
BUF: If $B U F=1$ the buffered mode is programmed. In buffered mode $\overline{\text { SP/ }} / \overline{\mathrm{EN}}$ becomes an enable outpút and the master/slave determination is by M/S.
M/S: If buffered mode is selected: M/S = 1 means the 8259A is programmed to be a master, M/S = 0 means the 8259A is programmed to be a slave. If $B U F=0$. M/S has no function.
AEOI: If $\mathrm{AEOI}=1$ the automatic end of interrupt mode is programmed.
$\mu \mathrm{PM}: ~ M i c r o p r o c e s s o r ~ m o d e: ~ \mu \mathrm{PM}=0$ sets the 8259A for MCS 80,85 system operation. $\mu$ PM $=1$ sets the 8259A for iAPX 86 system operation.


Figure 6. Initialization Sequence


Figure 7. Initialization Command Word Format

## OPERATION COMMAND WORDS (OCWs)

After the inhtialization Command Words (ICWs) are programmed into the 8259A, the chip is ready to accept Interrupt requests at its input lines. However, during the 8259A operation, a selection of algorithms can command the 8259A to operate in various modes through the Operation Command Words (OCWs).

## OPERATION CONTROL WORDS (OCWs)

$\square$
OCW1

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| M7 | M6 | M5 | M4 | M3 | M2 | M1 | M0 |

0


0

OPERATION CONTROL WORD 1 (OCW1)
OCW1 sets and clears the mask bits in the interrupt Mask Register (IMR). $M_{7}-M_{0}$ represent the eight mask bits. $M=1$ indicates the channel is masked (inhibited), $M=0$ indicates the channel is enabled.

## OPERATION CONTROL WORD 2 (OCW2)

R, SL, EOI - These three bits control the Rotate and End of Interrupt modes and combinations of the two. A chart of these combinations can be found on the Operation Command Word Format.
$L_{2}, L_{T}, L_{0}$-These bits determine the interrupt level acted upon when the SL bit is active.

## OPERATION CONTROL WORD 3 (OCW3)

ESMM - Enable Special Mask Mode. When this bit is set to 1 it enables the SMM bit to set or reset the Special Mask Mode. When ESMM $=0$ the SMM bit becomes a "don't care".
SMM - Special Mask Mode. If ESMM $=1$ and $S M M=1$ the 8259A will enter Special Mask Mode. If ESMM $=1$ and $S M M=0$ the 8259A will revert to normal mask mode. When $E S M M=0 . S M M$ has no effect.


Figure 8. Operation Command Word Format

## FULLY NESTED MODE

This mode is entered after initialization unless another mode is programmed. The interrupt requests are ordered in priority form 0 through $7(0$ highest). When an interrupt is acknowtedged the highest priority request is determined and its vector placed on the bus. Additionally, a bit of the Interrupt Service register (ISO-7) is set. This bit remains set until the microprocessor issues an End of Interrupt (EOI) command immediately before returning from the service routine, or if AEOI (Automatic End of Interrupt) bit is set. until the trailing edge of the last INTA. While the IS bit is set, all further interrupts of the same or lower priority are inhibited. while higher levels will generate an interrupt (which will be acknowledged only if the microprocessor internal Interrupt enable flip.flop has been re-enabled through software)
After the Initialization sequence, IRO has the hignest priority and IR7 the lowest. Priorities can be changed, as will be explained, in the rotating priority mode

## END OF INTERRUPT (EOI)

The In Service (IS) bit can be reset either automatically following the traiting edge of the last in sequence INTA pulse (when AEOI bit in ICW1 is set) or by a command word that must be issued to the 8259A before returning from a service routine (EOI command). An EOI command must be issued twice if in the Cascade mode. once for the master and once for the corresponding slave
There are two forms of EOI command: Specific and NonSpecific. When the 8259A is operated in modes which preserve the fully nested structure, it can determine which IS bit to reset on EOI When a Non-Specific EOI command is issued the 8259A will automatically reset the highest is bit of those that are set, since in the fully nested mode the highest IS level was necessarily the last level acknowledged and serviced. A non-specific EOI can be issued with OCW2 $(E O I=1 . S L=0, R=0)$.
When a mode is used which may disturb the fully nested structure the 8259A may no longer be able to determine the last level acknowledged. In this case a Specific End of Interrupt must be issued which includes as part of the command the IS level to be reset. A specific EOI can be issued with OCW2 ( $E O$ I $=1, S L=1, R=0$. and LO-L2 is the binary level of the IS bit to be reset).

It should be noted that an is bit that is masked by an IMR bit will not be cleared by a non-specific EOI it the 8259A is in the Special Mask Mode.

## AUTOMATIC END OF INTERRUPT (AEOI) MODE

If $A E O I=1$ in ICW4, then the 8259A will operate in AEOI mode continuously until reprogrammed by ICW4. In this mode the 8259A will automatically perform a nonspecific EOI operation at the traiting edge of the last interrupt acknowledge pulse (third pulse in MCS-80/85, second in IAPX 86) Note that from a system standpoint, this mode should be used only when a nested multilevel interrupt structure is not required within a single 8259A
The AEOI mode can only be used in a master 8259A and not a slave.

## AUTOMATIC ROTATION <br> (Equal Priority Devices)

In some applications there are a number of interrupting devices of equal priority. In this mode a device, after being serviced, receives the lowest priority, so a device requesting an interrupt will have to wait, in the worst case until each of 7 other devices are serviced at inost once. For example, if the priority and "in service" status is:

Before Rotate (IR4 the highest priority requiring service)

IS' Status
157 ISE IS5 ISA IS3 IS2 is 1 ISO


After Rotate (IR4 was serviced, all other priorities rotated correspondingly)
"IS" Status
IS7 ise is5 ise is3 is2 ist iso


There are two ways to accomplish Automatic Rotation using OCW2, the Rotation on Non-Specific EOI Command ( $\mathrm{R}=1 . \mathrm{SL}=0 . \mathrm{EOI}=-1$ ) and the Rotate in Automatic EOI Mode which is set by ( $R=1 . S L=0, E O I=0$ ) and cleared by $(R=0, S L=0, E O I=0)$

## SPECIFIC ROTATION

## (Specific Priority)

The programmer can change priorities by programming the bottom priority and thus fixing all other priorities; i.e., if IR5 is programmed as the bottom priority device, then IR6 wilt have the highest one.
The Set Priority command is issued in OCW2 where: $R=1 . S L=1$; LO-L2 is the binary priority level code of the bottom priority device
Observe that in this mode internal status is updated by software control during OCW2. However, it is independent of the End of interrupt (EOI) command (also executed by OCW2). Priority changes can be executed during an EOI command by using the Rotate on Specific EOI command in OCW2 $(R=1, S L=1, E O I=1$ and $L O-L 2=I R$ level to receive bottom priority).

## INTERRUPT MASKS

Each Interrupt Request input can be masked individually by the Interrupt Mask Register (IMR) programmed through OCW1. Each bit in the IMR masks one interrupt channel if it is set (1). Bit 0 masks IR0, Bit 1 masks IR1 and so forth. Masking an IR channel does not affect the other channels operation.

## 8259A/8259A-2/8259A-8

## SPECIAL MASK MODE

Some applications may require an interrupt service routine to dynamically alter the system priority structure during its execution under software control. For example, the routine may wish to inhibit lower priority requests for a portion of its execution but enable some of them for another portion.
The difficulty here is that if an Interrupt Request is acknowledged and an End of Interrupt command did not reset its IS bit (i.e., while executing a service routine), the 8259A would have inhibited all lower priority requests with no easy way for the routine to enable them

That is where the Special Mask Mode comes in. In the special Mask Mode, when a mask bit is set in OCW1, it inhibits further interrupts at that level and enables inter. rupts from all other levels (lower as well as higher) that are not masked.

Thus, any interrupts may be selectively enabled by loading the mask register.
The special Mask Mode is set by OCW3 where: $\operatorname{SSMM}=1, \quad S M M=1$, and cleared where $\operatorname{SSMM}=1$, SMM $=0$.

## POLL COMMAND

In this mode the INT output is not used or the microprocessor internal interrupt Enable flip-flop is reset, disabling its interrupt input. Service to devices is achieved by software using a Poll command.

The Poll command is issued by setting $P=$ " 1 " in OCW3. The 8259A treats the next $\overline{A D}$ pulse to the 8259A (i.e., $\overline{\mathrm{AD}}=0, \overline{C S}=0$ ) as an interrupt acknowledge, sets the appropriate IS bit if there is a request, and reads the priority level. Interrupt is frozen from W'R to $\overline{\mathrm{RD}}$
The word enabled onto the data bus during $\overline{R D}$ is:

$$
\begin{array}{|cccccccc|}
\text { D7 } & \text { D6 } & \text { D5 } & \text { D4 } & \text { D3 } & \text { D2 } & \text { D1 } & \text { D0 } \\
\hline 1 & - & - & - & - & W_{2} & w_{1} & w_{0} \\
\hline
\end{array}
$$

WO-W2: Binary code of the highest priority level requesting service.
I: Equal to a " 1 " if there is an interrupt.
This mode is usetul if there is a routine command common to several levels so that the INTA sequence is not needed (saves ROM space). Another application is to use the poll mode to expand the number of priority levels to more than 64.


Figure 9. Priority Cell-Simplified Logic Diagram

## READING THE 8259A STATUS

The input status of several internal registers can be read to update the user information on the system. The following registers can be read via OCW3 (IRR and ISR or OCW1 [IMR]).
Interrupt Request Register (IRR): 8-bit register which contains the levels requesting an interrupt to be acknowledged. The highest request level is reset from the IRR when an interrupt is acknowledged. (Not affected by IMR.)
in-Service Register (ISR): 8-bit register which contains the priority levels that are being serviced. The ISR is updated when an End of Interrupt Command is issued
Interrupt Mask Register: 8 -bit register which contains the interrupt request lines which are masked
The IRR can be read when, prior to the RD pulse, a Read Register Command is issued with OCW3 (RR $=1$. RIS $=0$.)

The ISR can be read when, prior to the RD pulse. a Read Register Command is issued with OCW3 (RR $=1$. RIS $=1$ ). There is no need to write an OCW3 before every status read operation, as long as the status read corresponds with the previous one: i.e., the 8259A "remembers' whether the IRR or ISR has been previously selected by the OCW3. This is not true when poll is used
After initialization the 8259A is se: to IRR
For reading the IMR, no OCW3 is needed. The output data bus will contain the IMR whenever $\overline{R D}$ is active and AO - 1 (OCW1).
Polling cuerrides status read when $P-1, R R=1$ in $O C W 3$

## EDGE AND LEVEL TRIGGERED MODES

This mode is programmed using bit 3 in ICW1.
If LTIM = ' 0 ', an interrupt request will be recognized by a low to high transition on an IR input. The IR input can remain high without generating another interrupt.

If LTIM $={ }^{\prime} 1$ ', an interrupt request will be recognized by a 'high' level on IR Input. and there is no need for an edge detection. The interrupt request must be removed before the EOI command is issued or the CPU interrupt is enabled to prevent a second interrupt from occurring.

The priority cell diagram shows a conceptual circuit of the level sensitive and edge sensitive input circuitry of the 8259A. Be sure to note that the request latch is a transparent D type latch

In both the edge and level triggered modes the IR inputs must remain high until after the falling edge of the first INTA. If the IR input goes low before this time a DEFAULT IR7 will occur when the CPU acknowledges the interrupt. This can be a usetul safeguard for detecting interrupts caused by spurious noise glitches on the IR inputs. To implement this feature the IR7 routine is used for "clean up" simply executing a return instruction, thus ignoring the interrupt. If IR7 is needed for other purposes a default IR7 can still be detected by reading the ISR A normal IR7 interrupt will set the corresponding ISR bit, a default IR7 won't. If a default IR7 routine occurs during a normal IR7 routine, however the ISR will remain set. In this case it is necessary to keep track of whether or not the IR7 routine was previously entered, If another IR7 occurs it is a default


Figure 10. IR Triggering Timing Requirements

## THE SPECIAL FULLY NESTED MODE

This mode will be used in the case of a big system where cascading is used, and the priority has to be conserved within each slave. In this case the fully nested mode will be programmed to the master (using ICW4). This mode is similar to the normal nested mode with the following exceptions:
a. When an interrupt request from a certain slave is in service this slave is not locked out from the master's priority logic and further interrupt requests from higher priority IR's within the slave will be recognized by the master and will initiate interrupts to the processor. (In the normal nested mode a slave is masked out when its request is in service and no nigher requests from the same slave can be serviced.)
b. When exiting the Interrupt Service routine the software has to check whether the interrupt serviced was the only one from that slave. This is done by sending a non-specific End of Interrupt (EOI) command to the slave and then reading its In-Service register and checking for zero. If it is empty, a non-specific EOI can be sent to the master too. If not, no EOI should be sent.

## BUFFERED MODE

When the 8259A is used in a large system where bus driving buffers are required on the data bus and the cascading mode is used, there exists the problem of enabling buffers.
The buffered mode will structure the 8259A to send an enable signat on $\overline{S P} / \overline{E N}$ to enable the buffers. In this
mode, whenever the 8259A's data bus outputs are enabled, the $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ output becomes active.
This modification forces the use of software programming to determine whether the 8259A is a master or a slave. Bit 3 in ICW4 programs the buffered mode, and bit 2 in ICW4 determines whether it is a master or a slave.

## CASCADE MODE

The 8259A can be easily interconnected in a system of one master with up to eight slaves to handle up to 64 priority levels.

The master controls the slaves through the 3 line cascade bus. The cascade bus acts like chip selects to the slaves during the INTA sequence.

In a cascade configuration, the slave interrupt outputs are connected to the master interrupt request inputs. When a slave request line is activated and afterwards acknowledged, the master will enable the corresponding slave to release the device routine address during bytes 2 and 3 of INTA. (Byte 2 only for $8086 / 8088$ ).

The cascade bus lines are normally low and will contain the slave address code from the trailing edge of the first INTA pulse to the trailing edge of the third pulse Each 8259A in the system must follow a separate initialization sequence and can be programmed to work in a different mode. An EOI command must be issued twice once for the master and once for the corresponding slave. An address decoder is required to activate the Chip Select (CS) input of each 8259A.
The cascade lines of the Master 8259A are activated only for slave inputs, non slave inputs leave the cascade line inactive (low).


Figure 11. Cascading the 8259A

## 8259A/8259A-2/8259A-8

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias .......... $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Storage Temperature..........$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Voltage on Any Pin
with Respect to Ground ............... -0.5 V to +7 V
Power Dissipation . ............................. . . Watt
*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
D.C. CHARACTERISTICS $\quad\left[T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, V_{C C}=5 \mathrm{~V} \pm 5 \%(8259 \mathrm{~A}-8), V_{C C}=5 \mathrm{~V} \pm 10 \%(8259 \mathrm{~A}, 8259 \mathrm{~A}-2)\right]$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $V_{\text {IH }}$ | Input High Voltage | $2.0{ }^{\circ}$ | $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output High Voltage |  | 0.45 | V | $\mathrm{OL}=2.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH}(\text { INT }}$ | Interrupt Output High Voltage | 3.5 |  | V | $\mathrm{I}^{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
|  |  | 2.4 |  | $V$ | $\mathrm{I}^{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $1 / 1$ | Input Load Current | $-10$ | +10 | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| LOL | Ourput Leakage Cürrent | -10 | +10 | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ${ }^{\text {ICC }}$ | $V_{C C}$ Supply Current |  | 85 | mA |  |
| MIR | IR Input Load Current |  | -300 | $\mu \mathrm{A}$ | $V_{1 N}=0$ |
|  |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{C C}$ |

*Note: For Extended Temperature EXPRESS $V_{I H}=2.3 \mathrm{~V}$.
CAPACITANCE ( $T_{A}=25^{\circ} \mathrm{C}: \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=\mathrm{OV}$ )

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{I N}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHZ}$ |
| $\mathrm{C}_{1 / 0}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to $\mathrm{V}_{\mathrm{SS}}$ |

A.C. CHARACTERISTICS $I T_{A}=0^{\circ} \mathrm{C}$ to $\left.70^{\circ} \mathrm{C}, V_{C C}=5 \mathrm{~V} \pm 5 \%(8259 \mathrm{~A}-8), V_{C C}=5 \mathrm{~V} \pm 10 \%(8259 \mathrm{~A}, 8259 \mathrm{~A}-2)\right]$

## TIMING REQUIREMENTS

| Symbol | Parameter | 8259A-8 |  | 8259A |  | 8259A-2 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TAHRL | $\mathrm{AO} / \overline{\mathrm{CS}}$ Setup to $\overline{\mathrm{RD}} / \mathrm{INTA}$. | 50 |  | 0 |  | 0 |  | ns |  |
| TRHAX | AO/ $\overline{C S}$ Hold after $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}}$ : | 5 |  | 0 |  | 0 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Pulse Width | 420 |  | 235 |  | 160 |  | ns |  |
| TAHWL | AO/ $\overline{C S}$ Setup to $\overline{W R} \downarrow$ | 50 |  | 0 |  | 0 |  | ns |  |
| TWHAX | AO/ES Hold after $\overline{W R} \uparrow$ | 20 |  | 0 |  | 0 |  | ns |  |
| TWLWH | $\overline{W R}$ Pulse Width | 400 |  | 290 |  | 190 |  | ns |  |
| TDVWH | Data Setup to $\overline{W R} \uparrow$ | 300 |  | 240 |  | 160 |  | ns |  |
| TWHDX | Data Hold after $\overline{W R} \uparrow$ | 40 |  | 0 |  | 0 |  | ns |  |
| TJLJH | Interrupt Request Width (Low) | 100 |  | 100 |  | 100 |  | ns | See Note 1 |
| TCVIAL | Cascade Setup to Second or Third INTA $\downarrow$ (Slave Only) | 55 |  | 55 |  | 40 |  | ns |  |
| TRHRL | End of $\overline{R D}$ to next $\overline{R D}$ End of INTA to next INTA within an INTA sequence only | 160 |  | 160 |  | 160 |  | ns |  |
| TWHWL | End of $\overline{W R}$ to next $\bar{W} \bar{R}$ | 190 |  | 190 |  | 190 |  | ns |  |

## A.C. CHARACTERISTICS (Continued)

| Symbol | Parameter | 8259A-8 |  | 8259A |  | 8259A-2 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| -TCHCL | End of Command to next Command (Not same command type) | 500 |  | 500 |  | 500 |  | ns |  |
|  | End of INTA sequence to next INTA sequence. |  |  |  |  |  |  |  |  |

Worst case timing for TCHCL in an actual microprocessor system is typically much greater than 500 ns (i.e. $8085 \mathrm{~A}=1.6 \mu \mathrm{~s}$. 8085A-2 $=1 \mu \mathrm{~s}, 8086=1 \mu \mathrm{~s}, 8086-2=625 \mathrm{~ns}$ )
NOTE: This is the low time required to clear the input latch in the edge triggered mode.

TIMING RESPONSES

| Symbol | Parameter | 8259A-8 |  | 8259A |  | 8259A-2 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TRLDV | Data Valid trom R̈D/İTTA. |  | 300 |  | 200 |  | 120 | ns | $\begin{aligned} & \text { Cof Data Bus }= \\ & 100 \mathrm{pF} \end{aligned}$ |
| TRHDZ | Data Float alter $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}}$ ! | 10 | 200 | 10 | 100 | 10 | 85 | ns | C of Data Bus |
| TJHHH | Interrupt Output Delay |  | 400 |  | 350 |  | 300 | ns | Maxtext $C=100 \mathrm{pF}$ <br> Min. test $\mathrm{C}=15 \mathrm{pF}$ |
| TIALCV | Cascade Valid from First $\widetilde{\mid N T A}$ (Master Only) |  | 565 |  | 565 |  | 360 | ns | $C_{C_{N T}}=100 \mathrm{pF}$ |
| TRLEL | Enable Active from $\overline{\mathrm{RD}}$ I or $\left.\overline{\mathbb{N T A}}\right\|^{\text {\| }}$ |  | 160 |  | 125 |  | 100 | ns | $C_{\text {CASCADE }}=100 \mathrm{pF}$ |
| TRHEH | Enable Inactive from $\overline{\mathrm{RO}}$ ' or $\overline{\text { INTA! }}$ |  | 325 |  | 150 |  | 150 | ns |  |
| TAHDV | Data Valid from Stable Address |  | 350 |  | 200 |  | 200 | ns |  |
| TCVDV | Cascade Valid to Valid Data |  | 300 |  | 300 |  | 200 | ns |  |

A.C. TESTING INPUT, OUTPUT WAVEFORM

A.C. TESTING LOAD CIRCUIT


## WAVEFORMS



## inted

## 8259A/8259A-2/8259A-8

WAVEFORMS (Continued)


## OTHER TIMING



8259A/8259A-2/8259A-8

WAVEFORMS (Continued)


NOTES: Interrupt output must remain HIGH at least until leading edge of first INTA.

1. Cycle 1 in IAPX 86, IAPX 88 systems. the Data Bus is not active.

## inted

## 8284A/8284A-1 CLOCK GENERATOR AND DRIVER FOR iAPX 86, 88 PROCESSORS

- Generates the System Clock for the iAPX 86, 88 Processors: $5 \mathrm{MHz}, 8 \mathrm{MHz}$ with 8284A 10 MHz with 8284A-1
- Uses a Crystal or a TTL Signal for Frequency Source
- Provides Local READY and Multibus ${ }^{\text {m }}$ READY Synchronization
- 18-Pin Package
- Single +5 V Power Supply
- Generates System Reset Output from Schmitt Trigger Input
- Capable of Clock Synchronization with Other 8284As
- Available in EXPRESS
- Standard Temperature Range
- Extended Temperature Range


8284A/8284A-1 Pin
8284A/8284A-1 Block Diagram
Configuration

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\overline{\overline{A E N 1}} \overline{\bar{A} E N 2}$ | 1 | Addrese Enable: $\overline{A E N}$ is an active LOW signal. AEN serves to qualify its respective Bus Ready Signal (RDY1 or RDY2). $\overline{A E N ~}{ }^{\dagger}$ validates RDY1 while $\overline{\text { AEN2 }}$ validates RDY2. Two AEN signal inputs are useful in system contigurations which permit the processor to access two Multi-Master System Busses. In non Multi-Master configurations the, $\overline{\mathrm{AEN}}$ signal inputs are tied true (LOW). |
| RDY1, RDY2 | 1 | Bus Ready: (Transfer Complete). RDY is an active HIGH signal which is an indication from a device located on the system data bus that data has been received, or is available. RDY1 is qualified by $\overline{A E N T}$ while RDY2 is qualified by $\bar{A} E N 2$. |
| $\overline{\text { ASYNC }}$ | 1 | Ready Synchronizetion Select: $\overline{\text { ASYNC }}$ is an input which defines the synchronization mode of the READY logic. When ASYNC is low, two stages of READY synchronization are provided. When $\overline{A S Y N C}$ is left open (internal pull-up resistor is provided) or HIGH a single stage of READY synchronization is provided. |
| READY | 0 | Ready: READY is an active HIGH signal which is the synchronized RDY signal input. READY is cleared after the guaranteed hold time to the processor has been met. |
| $\mathrm{x} 1, \mathrm{x} 2$ | 1 | Crystal in: X1 and X2 are the pins to which a crystal is attached. The crystal frequency is 3 times the desired processor clock trequency. |
| F/C | 1 | Frequency/Crystal Select: F/C is a strapping option. When strapped LOW, F/C permits the processor's clock to be generated by the crystal. When $F / \overline{\bar{C}}$ is strapped HIGH. CLK is generated from the EFI input. |
| EFI | 1 | External Frequency: When $F / \overline{\mathrm{C}}$ is strapped HIGH, CLK is generated from the input frequency appearing on this pin. The input signal is a square wave 3 times the frequency of the desired CLK output. |

## FUNCTIONAL DESCRIPTION

## General

The 8284A is a single chip clock generator/driver for the iAPX 86, 88 processors. The chip contains a crystalcontrolled oscillator, a divide-by-three counter, complete MULTIBUS ${ }^{\text {TM }}$ "Ready" synchronization and reset logic. Refer to Figure 1 for Block Diagram and Figure 2 for Pin Configuration.

## Oscillator

The oscillator circuit of the 8284A is designed primarily for use with an external series resonant, fundamental mode, crystal from which the basic operating frequency is derived.

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| CLK | 0 | Proceasor Clock: CLK is the clock output used by the processor and all devices which directly connect to the processor's local bus (i.e., the bipolar support chips and other MOS devices). CLK has an output frequency which is $1 / 3$ of the crystal or EFI input frequency and a $1 / 3$ duty cycle. An output HIGH of 4.5 volts ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ ) is provided on this pin to drive MOS devices. |
| PCLK | 0 | Peripheral Clock: PCLK is a TL level peripheral clock signal whose output frequency is $1 / 2$ that of CLK and has a $50 \%$ duty cycle. |
| OSC | 0 | Oscillator Output: OSC is the TTL level output of the internal oscillator circuitry. Its frequency is equal to that of the crystal. |
| $\overline{\text { RES }}$ | 1 | Reset In: $\overline{\text { RES }}$ is an active LOW signal which is used to generate RESET. The 8284A provides a Schmitt trigger input so that an RC connection can be used to establish the power-up reset of proper duration. |
| RESET | 0 | Reset: RESET is an active HIGH signal which is used to reset the 8086 family processors. Its timing characteristics are determined by $\overline{\text { RES }}$ |
| CSYNC | 1 | Clock Synchronlzation: CSYNC is an active HIGH signal which allows multiple 8284As to be synchronized to provide clocks that are in phase. When CSYNC is HIGH the internal counters are reset. When CSYNC goes LOW the internal counters are allowed to resume counting. CSYNC needs to be externally synchronized to EFI. When using the internal oscillator CSYNC should be hardwired to ground. |
| GND |  | Ground. |
| $\mathrm{V}_{\mathrm{cc}}$ |  | Power: +5 V supply. |

The crystal frequency shouid be selected at three times the required CPU clock. X 1 and $X 2$ are the two crystal input crystal connections. For the most stable operation of the oscillator (OSC) output circuit, two series resistors ( $R_{1}=R_{2}=510 \Omega$ ) as shown in the waveform figures are recommended. The output of the oscillator is buffered and brought out on OSC so that other system timing signals can be derived from this stable, crystal-controlled source.

For systems which have a $V_{C C}$ ramp time $\geqslant 1 \mathrm{~V} / \mathrm{ms}$ and/or have inherent board capacitance between X1 or X2, exceeding 10 pF (not including 8284A pin capacitance), the two 510 r resistors should be used. This circuit provides optimum stability for the oscillator in such extreme conditions. It is advisable to limit stray capacitances to less than 10 pF on X 1 and X 2 to minimize deviation from operating at the fundamental frequency

## Clock Generator

The clock generator consists of a synchronous divide-by-three counter with a special clear input that inhibits the counting. This clear input (CSYNC) allows the output clock to be synchronized with an external event (such as another 8284A clock). It is necessary to synchronize the CSYNC input to the EFI clock external to the 8284A. This is accomplished with two Schottky flipflops. The counter output is a $33 \%$ duty cycle clock at one-third the input frequency.
The F/ $\ddot{C}$ input is a strapping pin that selects either the crystal oscillator or the EFI input as the clock for the +3 counter. If the EFI input is selected as the clock source, the oscillator section can be used independently for another clock source. Output is taken from OSC.

## Clock Outputs

The CLK output is a $33 \%$ duty cycle MOS cloç driver designed to drive the IAPX 86, 88 processors directly. PCLK is a TTL level peripheral clock signal whose output frequency is $1 / 2$ that of CLK. PCLK has a $50 \%$ duty cycle.

## Reset Logic

The reset logic provides a Schmitt trigger input ( $\overline{\mathrm{RES}}$ ) and a synchronizing flip-flop to generate the reset timing. The reset signal is synchronized to the falling edge of CLK. A simple RC network can be used to provide power-on reset by utitizing this function of the 8284A.

## READY Synchronization

Two READY inputs (RDY1, RDY2) are provided to accommodate two Multi-Master system busses. Each input has a qualifier ( $\overline{A E N 1}$ and $\overline{A E N 2}$, respectively). The $\overline{A E N}$ signals validate their respective RDY signals. If a Multi-

Master system is not being used the $\overline{A E N}$ pin should be tied LOW.

Synchronization is required for all asynchronous activegoing edges of either RDY input to guarantee that the RDY setup and hold times are met. Inactive-going edges of RDY in normally ready systems do not require synchronization but must satisfy RDY setup and hold as a matter of proper system design.

The $\overline{A S Y N C}$ input defines two modes of READY synchronization operation.

When $\overline{A S Y N C}$ is LOW, two stages of synchronization are provided for active READY input signals. Positivegoing asynchronous READY inputs will first be synchronized to flip-flop one at the rising edge of CLK and then synchronized to flip-flop two at the next falling edge of CLK, after which time the READY output will go active (HIGH). Negative-going asynchronous READY inputs will be synchronized directly to flip-flop two at the falling edge of CLK, after which time the READY output will go inactive. This mode of operation is intended for use by asynchronous (normaHy not ready) devices in the system which cannot be guaranteed by design to meet the required RDY setup timing, $\mathrm{T}_{\text {R1vCL }}$, on each bus cycle.

When $\overline{A S Y N C}$ is high or left open, the first READY flip. flop is bypassed in the READY synchronization logic. READY inputs are synchronized by flip-llop two on the falling edge of CLK before they are presented to the processor. This mode is available for synchronous devices that can be guaranteed to meet the required RDY setup time.
$\overline{A S Y N C}$ can be changed on every bus cycle to select the appropriate mode of synchronization for each device in the system.


Figure 3. CSYNC Synchronization

## 8284A/8284A-1

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $.0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Output and Supply Voltages -0.5 V to +7 V
All Input Voltages . . . . . . . . . . . . . . . . . . . -1.0 V to +5.5 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . 1 Watt
-NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{F}}$ | Forward Input Current (ASYNC) Other Inputs |  | $\begin{aligned} & -1.3 \\ & -0.5 \end{aligned}$ | $\mathrm{mA}$ | $\begin{aligned} & V_{F}=0.45 \mathrm{~V} \\ & V_{F}=0.45 \mathrm{~V} \end{aligned}$ |
| $I_{R}$ | Reverse Input Current ( $\overline{\text { ASYNC }}$ ) Other Inputs |  | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\mu A$ $\mu A$ | $\begin{aligned} & V_{R}=V_{C C} \\ & V_{R}=5.25 V \end{aligned}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Clamp Voltage |  | -1.0 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| ICC | Power Supply Current |  | 162 | mA |  |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Voltage |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Voltage | 2.0 |  | V |  |
| $V_{\text {IHR }}$ | Reset Input HIGH Voltage | 2.6 |  | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage |  | 0.45 | $\checkmark$ | 5 mA |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage CLK Other Outputs | $\begin{gathered} 4 \\ 2.4 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & -1 \mathrm{~mA} \\ & -1 \mathrm{~mA} \\ & \hline \end{aligned}$ |
| $V_{1 H_{R}}-V_{1 L_{R}}$ | $\overline{\text { RES }}$ Input Hysteresis | 0.25 |  | V |  |

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

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {EHEL }}$ | External Frequency HIGH Time | 13 |  | ns | 90\% -90\% V IN |
| $\mathrm{t}_{\text {ELEH }}$ | External Frequency LOW Time | 13 |  | ns | 10\% - 10\% V $\mathrm{IN}_{\mathrm{IN}}$ |
| $\mathrm{t}_{\text {ELEL }}$ | EFI Period | 33 |  | ns | (Note 1) |
|  | XTAL Frequency | 12 | 25 | MHz |  |
| $t_{\text {RIVCL }}$ | RDY1, RDY2 Active Setup to CLK | 35 |  | ns | $\overline{\text { ASYNC }}=\mathrm{HIGH}$ |
| $\mathrm{t}_{\text {R1VCH }}$ | RDY1, RDY2 Active Setup to CLK | 35 |  | ns | $\overline{\text { ASYNC }}=$ LOW |
| $t_{\text {R1VCL }}$ | RDY1, RDY2 Inactive Setup to CLK | 35 |  | ns |  |
| $t_{\text {CLR1X }}$ | RDY1, RDY2 Hold to CLK | 0 |  | ns |  |
| $t_{\text {AYVCL }}$ | $\overline{\text { ASYNC Setup to CLK }}$ | 50 |  | ns |  |
| ${ }^{\text {t Clay }}$ | ASYNC Hold to CLK | 0 |  | ns |  |
| taivativ | $\overline{\text { AEN1, }}$ AEN2 Setup to RDY1, RDY2 | 15 |  | ns |  |
| ${ }_{\text {clatix }}$ | AEN1, AEN2 Hold to CLK | 0 |  | ns |  |
| $\mathrm{t}_{\text {YHEH }}$ | CSYNC Setup to EFI | 20 |  | ns |  |
| $\mathrm{t}_{\text {EHYL }}$ | CSYNC Hold to EFI | 10 |  | ns |  |
| ${ }_{\text {trHYL }}$ | CSYNC Width | 2.telel |  | ns |  |
| $t_{11 \mathrm{HCL}}$ | RES Setup to CLK | 65 |  | ns | (Note 1) |
| $\mathrm{t}_{\mathrm{CLILH}}$ | RES Hold to CLK | 20 |  | ns | (Note 1) |

## 8284A/8284A-1

A.C. CHARACTERISTICS (ContInued) TIMING RESPONSES

| Symbol | Parameter | Min. 8284 A | Min. 8284A-1 | Max. | Units | Tost Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }_{\text {tacl }}$ | CLK Cycle Period | 125 | 100 |  | ns |  |
| $\mathrm{t}_{\mathrm{CHCL}}$ | CLK HIGH Time | (1/3 $\mathrm{t}_{\text {clal }}$ ) +2 | 39 |  | ns |  |
| ${ }_{\text {telch }}$ | CLK LOW Time | ( 3 ht tcLCL ) 15 | 53 |  | ns |  |
|  ${ }_{\mathrm{Cl} 2 \mathrm{CL}}$ | CLK Rise or fall Time |  |  | 10 | ns | 1.0 V to 3.5 V |
| $\mathrm{t}_{\text {PMPL }}$ | PCLK HIGH Time | $\mathrm{t}_{\text {clat }} \mathbf{- 2 0}$ | $\mathrm{tclac}^{-20}$ |  | ns |  |
| tplph | PCLK LOW Time | $1 \mathrm{Cucs}^{-20}$ | $\mathrm{talcl}^{-20}$ |  | ns |  |
| taylcl | Ready Inactive to CLK (See Note 3) | -8 | -8 |  | ns |  |
| $\mathrm{t}_{\text {PYHCH }}$ | Ready Active to CLK (See Note 2) | ( $\left.23 \mathrm{t}_{\mathrm{CLCL}}\right)^{-15}$ | 53 |  | ns |  |
| $\mathrm{t}_{\mathrm{CLH}}$ | CLK to Reset Delay |  |  | 40 | ns |  |
| $\mathrm{t}_{\text {cle }}$ | CLK to PCLK HIGH DELAY |  |  | 22 | ns |  |
| $\mathrm{t}_{\text {ClPL }}$ | CLK to PCLK LOW Delay |  |  | 22 | ns |  |
| $\mathrm{taich}^{\text {ter }}$ | OSC to CLK HIGH Delay | -5 | -5 | 22 | ns |  |
| tolel | OSC to CLK LOW Delay | 2 | 2 | 35 | ns |  |
| $\mathrm{toloh}^{\text {l }}$ | Output Rise Time (except CLK) |  |  | 20 | ns | From 0.8 V to 2.0 V |
| $\mathrm{t}_{\mathrm{OHO}}$ | Output Fall Time (except CLK) |  |  | 12 | ns | From 2.0 V to 0.8 V |

## NOTES:

1. Setup and hold necessary only to guarantee recognition at next clock.
2. Applies only to T3 and TW states.
3. Applies only to T2 states.

## A.C. TESTING INPUT, OUTPUT WAVEFORM

INPUT/OUTPUT
A.C. testing load circuit


8284A/8284A-1

WAVEFORMS

## CLOCKS AND RESET SIGNALS



NOTE: ALL TIMING MEASUREMENTS ARE MADE AT 1.5 VOLTS, UNLESS OTHERWISE NOTED.

READY SIGNALS (FOR ASYNCHRONOUS DEVICES)


## 8284A/8284A-1

WAVEFORMS (ContInued)
READY SIGNALS (FOR SYNCHRONOUS DEVICES)


Clock High and Low Time (Using X1, X2)


Clock High and Low Time (Using EFI)


Ready to Clock (Using X1, X2)


NOTES:
Ready to Clock (Using EFI)

1. $C_{l}=100 \mathrm{pF}$
2. $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$

## 8237A/8237A-4/8237A-5 HIGH PERFORMANCE PROGRAMMABLE DMA CONTROLLER

- Enable/Disable Control of Individual DMA Requests
- Four Independent DMA Channels
- Independent Autoinitialization of all Channels
- Memory-to-Memory Transfers
- Memory Block Initialization
- Address Increment or Decrement
- High performance: Transfers up to 1.6 M Bytes/Second with 5 MHz 8237A-5
- Directly Expandable to any Number of Channels
- End of Process Input for Terminating Transfers
- Software DMA Requests
- Independent Polarity Control for DREQ and DACK Signals
- Avallable in EXPRESS
- Standard Temperature Range

The 8237A Multimode Direct Memory Access (DMA) Controller is a peripheral interface circuit for microprocessor systems. It is designed to improve system performance by allowing external devices to directly transfer information from the system memory. Memory-to-memory transfer capability is also provided. The 8237A offers a wide variety of programmable control features to enhance data throughput and system optimization and to allow dynamic reconfiguration under program control.
The 8237A is designed to be used in conjunction with an external 8-bit address register such as the 8282. It contains four independent channels and may be expanded to any number of channels by cascading additional controller chips.
The three basic transfer modes allow programmability of the types of DMA service by the user. Each channel can be individually programmed to Autoinitialize to its original condition following an End of Process (EOP).
Each channel has a full 64 K address and word count capability.
The 8237A-4 and 8237A-5 are 4 MHz and 5 MHz selected versions of the standard 3 MHz 8237 A respectively.


Table 1. Pin Description

| Symbol | Type | Name and Function | Symbol | Type | Name end Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ |  | Power: +5 volt supply. |  |  | ory-to-memory operations, data |
| $\mathrm{V}_{\text {SS }}$ |  | Ground: Ground. |  |  | from the memory 8237A on the data |
| CLK | 1 | Clock input: Clock Input controls the internal operations of the 8237A and its rate of data transfers. The input may be driven at up to 3 MHz for the standard 8237A and up to 5 MHz for the 8237A.5. |  |  | read-from-memory transfer. In the write-to-memory transter, the data bus outputs place the data into the new memory location. |
|  |  |  | IOR | 1/0 | UO Read: I/O Read is a bldirecthonal active low three-state line. In the Idie cycle, it is an input control signal used by the CPU to read the control registers. In the Active cycle, it is an output control signal used by the 8237A to access data from a peripheral during a DMA Write transfer. |
| CS | 1 | Chip Select: Chip Select is an active low input used to select the 8237A as an HO device during the Idie cycle. This allows CPU communication on the data bus. |  |  |  |
| RESET | 1 | Reset: Reset is an active high input which clears the Command, |  |  |  |
|  |  | Status, Request and Temporary registers. It also clears the firstlast flip/flop and sets the Mask register. Following a Reset the device is in the Idie cycle. | $\overline{\text { 10W }}$ | $1 / 0$ | UO Write: I/O Write is a bidirectional active low three-state line. In the Idie cycle, it is an input control slgnal used by the CPU to load information Into the 8237A. In the Active cycle, It is an output control signal used by the 8237A to load data to the perlpheral during a DMA Read transfer. |
| READY | 1 | Ready: Ready is an input used to extend the memory read and write pulses from the 8237A to accommodate slow memories or I/O peripheral devices. Ready must not make transitions during its specified setupthold time. |  |  |  |
|  |  |  | $\overline{\text { EOP }}$ | $1 / 0$ | End of Process: End of Process is an active low bidirectional signal. Information concerning the completion of DMA services is available at the bidirectional EOP pin. The 8237A allows an external sig. nal to terminate an active DMA service. This is accomplished by pulling the EOP input low with an external $\overline{E O P}$ signal. The 8237 A also generates a pulse when the terminal count (TC) for any channel is reached. This generates an EOP signal which is output through the $\overline{E O P}$ Line. The reception of EOP, either internal or external, will cause the 8237A to terminate the service, reset the request, and, if Autoinitialize is enabled, to write the base registers to the current registers of that channel. The mask bit and TC bit in the status word will be set tor the currently active channel by $\overline{E O P}$ unless the channel is programmed for Autoinitialize. In that case, the mask bit remains unchanged. During memory-to-memory transfers, EOP will be output when the TC for channel 1 occurs. $\overline{E O P}$ should be tied high with a pull-up resistor if it is not used to prevent erroneous end of process inputs. |
| HLDA | 1 | Hold Acknowledge: The active high Hold Acknowledge from the CPU indicates that it has relinquished control of the system busses. |  |  |  |
| DREQ0-DREQ3 | 1 | DMA Request: The DMA Request lines are individual asynchronous channel request inputs used by peripheral circuits to obtain DMA service. In fixed Priority, DRECO has the highest priority and DREQ3 has the lowest priority. A request is generated by activating the DREQ line of a channel. DACK will acknowledge the recognition of DREQ signal. Polarity of DREQ is programmable. Reset intializes these lines to active high. DREQ must be maintained until the corresponding DACK goes active. |  |  |  |
| DBO-DB7 | $1 / 0$ | Data Bus: The Data Bus lines are bldirectional three-state signals connected to the system data bus. The outputs are enabled in the Program condition during the I/O Read to output the contents of an Address register, a Status register, the Temporary reglster or a Word Count register to the CPU. The outputs are disabled and the inputs are read during an I/O Write cycle when the CPU is programming the 8237A control registers. During DMA cycles the most significant 8 bits of the address are output onto the data bus to be stroded into an external latch by ADSTB. In mem. |  |  |  |
|  |  |  | A0-A3 | $1 / 0$ | Address: The four least significant address lines are bidirectional three-state signals. In the Idle cycle they are inputs and are used by the CPU to address the register to be loaded or read. In the Active cycle they are outputs and provide the lower 4 bits of the output address. |

Table 1. Pin Description (Continued)

| Symbol | Type | Name and Function |
| :--- | :---: | :--- |
| A4-A7 | 0 | Addrese: The four most significant <br> address lines are three-state out- <br> puts and provide 4 bits of address. <br> These lines are enabled only during <br> the DMA service. |
| HRQ | 0 | Hold Request: Thls is the Hold Re- <br> quest to the CPU and is used to re <br> quest control of the system bus. If <br> the corresponding mask bit is <br> clear, the presence of any valid <br> DREQ causes 8237A to issue the <br> HRQ. After HRQ goes active at <br> least one clock cycle (TCY) must <br> occur before HLDA goes active. |
| DACKO-DACK3 | $O$ | DMA Acknowledge: DMA Ac- <br> knowledge is used to notify the in- <br> dividual peripherals when one has <br> been granted a DMA cycle. The <br> sense of these lines is program- <br> mable. Reset initializes them to ac- <br> tive low. |

## FUNCTIONAL DESCRIPTION

The 8237A block diagram includes the major logic blocks and all of the internal registers. The data interconnection paths are also shown. Not shown are the various control signals between the blocks. The 8237A contains 344 bits of internal memory in the form of registers. Figure 3 lists these registers by name and shows the size of each. A detailed description of the registers and their functions can be found under Register Description.

| Name | Slze | Number |
| :--- | :---: | :---: |
| Base Address Registers | 16 bits | 4 |
| Base Word Count Registers | 16 bits | 4 |
| Current Address Registers | 16 bits | 4 |
| Current Word Count Registers | 16 bits | 4 |
| Temporary Address Register | 16 bits | 1 |
| Temporary Word Count Register | 16 bits | 1 |
| Status Register | 8 bits | 1 |
| Command Register | 8 bits | 1 |
| Temporary Register | 8 bits | 1 |
| Mode Registers | 6 bits | 4 |
| Mask Register | 4 bits | 1 |
| Request Register | 4 bits | 1 |

Figure 3. 8237A Internal Registers
The 8237A contains three basic blocks of control logic. The Timing Control block generates internal timing and external control signals for the 8237A. The Program Command Control block decodes the various commands given to the 8237A by the microprocessor prior to servicing a DMA Request. It also decodes the Mode Control word used to select the type of DMA during the servicing. The Priority Encoder block resolves priority contention between DMA channels requesting service simultaneously.

The Timing Control block derives internal timing from the clock input. In 8237A systems this input will usually

| Symbol | Type | Name and Function |
| :--- | :---: | :--- |
| AEN | O | Address Enable: Address Enable <br> enables the 8-bit latch containing <br> the upper 8 address bits onto the <br> system address bus. AEN can also <br> be used to disable other system bus <br> drivers during DMA transfers. AEN <br> is active HIGH. |
| ADSTB | 0 | Address Strobe: The active high, <br> Address Strobe is used to strobe the <br> upper address byte into an external <br> latch. |
| MEMR | $O$ | Memory Read: The Memory Read <br> signal is an active low three-state <br> output used to access data from the <br> selected memory location during a <br> DMA Read or a memory-to-memory <br> transfer. |
| $\overline{\text { MEMW }}$ | O | Memory Write: The Memory Write <br> is an active low three-state output <br> used to write data to the selected <br> memory location during a DMA <br> Write or a memory-to-memory <br> transfer. |

be the $\$ 2$ TTL clock from an 8224 or CLK from an 8085 AH or 8284 A . For $8085 \mathrm{AH}-2$ systems above 3.9 MHz , the 8085 CLK(OUT) does not satisly 8237A. 5 clock LOW and HIGH time requirements. In this case, an external clock should be used to drive the 8237A.5.

## DMA Operation

The 8237A is designed to operate in two major cycles. These are called Idle and Active cycles. Each device cycle is made up of a number of states. The 8237A can assume seven separate states, each composed of one full clock period. State I $(\mathrm{SI})$ is the inactive state. It is entered when the 8237A has no valid DMA requests pending. While in SI, the DMA controller is inactive but may be in the Program Condition, being programmed by the processor. State $\mathrm{SO}(\mathrm{SO})$ is the first state of a DMA service. The 8237A has requested a hold but the processor has not yet returned an acknowledge. The 8237A may still be programmed until it receives HLDA from the CPU. An acknowledge from the CPU will signal that DMA transfers may begin. S1, S2, S3 and S4 are the working states of the DMA service. If more time is needed to complete a transter than is available with normal timing, wait states (SW) can be inserted between S2 or S3 and S4 by the use of the Ready line on the 8237A. Note that the data is transferred directly from the $1 / 0$ device to memory (or vice versa) with $\overline{\mathrm{OR}}$ and MEMW (or $\overline{M E M R}$ and $\overline{\mathrm{IOW}}$ ) being active at the same time. The data is not read into or driven out of the 8237A in I/O-tomemory or memory-to-l/O DMA transfers.
Memory-to-memory transfers require a read-from and a write-to-memory to complete each transfer. The states, which resemble the normal working states, use two digit numbers for identification. Eight states are required for a single transfer. The first four states (S11, $\mathrm{S} 12, \mathrm{~S} 13, \mathrm{~S} 14$ ) are used for the read-from-memory half

## 8237A/8237A-4/8237A-5

and the last four states (S21, S22, S23, S24) for the write-to-memory half of the transfer.

## IDLE CYCLE

When no channel is requesting service, the B237A will enter the Idle cycle and perform "Si" states. In this cycle the 8237A will sample the DREQ lines every clock cycle to determine if any channel is requesting a DMA service. The device will also sample $\overline{\mathrm{CS}}$, looking for an attempt by the microprocessor to write or read the internal registers of the 8237A. When CS is low and HLDA is low, the 8237A enters the Program Condition. The CPU can now establish, change or Inspect the internal definition of the part by reading from or writing to the internal registers. Address lines A0-A3 are inputs to the device and select which registers will be read or written. The $\overline{I O R}$ and $\overline{\mathrm{O} W \bar{W}}$ lines are used to select and time reads or writes. Due to the number and size of the internal registers, an internal flip-flop is used to generate an additlonal bit of address. This bit is used to determine the upper or lower byte of the $\mathbf{1 6}$-bit Address and Word Count registers. The flip-flop is reset by Master Clear or Reset. A separate software command can also reset this filp-flop.

Special software commands can be executed by the 8237A in the Program Condition. These commands are decoded as sets of addresses with the $\overline{\mathrm{CS}}$ and $\overline{\mathrm{IOW}}$. The commands do not make use of the data bus. Instructions include Clear First/Last Flip-FLop and Master Clear.

## ACtive cycle

When the 8237A is in the Idle cycle and a non-masked channel requests a DMA service, the device will output an HRQ to the microprocessor and enter the Active cycle. It is in this cycie that the DMA service will take place, in one of four modes:

Single Transfer Mode - In Single Transfer mode the device is programmed to make one transfer only. The word count will be decremented and the address dec. remented or incremented following each transter. When the word count "rolls over" from zero to FFFFH, a Terminal Count (TC) will cause an Autoinitialize if the channel has been programmed to do so.

DREQ must be held active untII DACK becomes active in order to be recognized. If DREQ is held active throughout the single transfer, HRQ will go inactive and release the bus to the system. It will again go active and, upon recelpt of a new HLDA, another single transfer will be performed, in 8080A, 8085AH, 8088, or 8086 system this will ensure one full machine cycle execution between DMA transfers. Details of timing between the 8237A and other bus control protocols will depend upon the characteristics of the microprocessor involved.

Block Transfer Mode - In Block Transfer mode the device is activated by DREQ to continue making transfers during the service untll a TC, caused by word count going to FFFFH, or an external End of Process (EOP) is encountered. DREQ need only be held active until DACK
becomes active. Again, an Autoinitialization will occur at the end of the service If the channel has been programmed for it.

Demand Transfer Mode - In Demand Transfer mode the device is programmed to continue making transfers unth a TC or external EOP is encountered or until DREQ goes inactive. Thus transfers may continue until the I/O device has exhausted its data capacity. After the I/O device has had a chance to catch up, the DMA service is reestablished by means of a DREQ. During the time between services when the microprocessor is allowed to operate, the intermediate values of address and word count are stored in the 8237A Current Address and Current Word Count registers. Only an EOP can cause an Autoinitialize at the end of the service. $\overline{E O P}$ is generated elther by TC or by an external signal.

Cascade Mode - This mode is used to cascade more than one 8237A together for simple system expansion. The HRQ and HLDA signals from the additional 8237A are connected to the DREQ and DACK signals of a channel of the initial 8237A. This allows the DMA requests of the additional device to propagate through the priority network circuitry of the preceding device. The priority chain is preserved and the new device must wait for its turn to acknowledge requests. Since the cascade channel of the initial 8237A is used only for prioritizing the additional device, it does not output any address or control signals of its own. These could conflict with the outputs of the active channel in the added device. The 8237A will respond to DREQ and DACK but all other outputs except HRQ will be disabled. The ready input is ignored.

Figure 4 shows two additional devices cascaded into an initial device using two of the previous channels. This forms a two level DMA system. More 8237As could be added at the second level by using the remaining channels of the first ievel. Additional devices can aiso be added by cascading into the channels of the second level devices, forming a third level.


Figure 4. Cascaded 8237As

## TRANSFER TYPES

Each of the three active transter modes can perform three different types of transters. These are Read, Write and Verity Write transfers move data from and I/O device to the memory by activating MENWW and TOR. Read transfers move data from memory to an $1 / O$ device by activating MEMR and $\overline{\mathrm{OW}}$. Verify transfers are pseudo transfers. The 8237A operates as in Read or Write transfers generating addresses, and responding to EOP, etc. However, the memory and I/O control lines all remain inactive. The ready input is ignored in verify mode.

Memory-to-Memory-To perform block moves of data from one memory address space to another with a minimum of program effort and time, the 8237A includes a memory-tomemory transfer feature. Programming a bit in the Command register selects channels 0 to 1 to operate as memory-tomemory transfer channels. The transfer is initiated by setting the software DREQ for channel 0 . The 8237A requests a DMA service in the normal manner. After HLDA is true, the device, using four state transfers in Block Transfer mode, reads data from the memory. The channel 0 Current Address register is the source for the address used and is decremented or incremented in the normal manner. The data byte read from the memory is stored in the 8237A internal Temporary register. Channel 1 then performs a four-state transter of the data from the Temporary register to memory using the address in its Current Address register and incrementing or decrementing it in the normal manner. The channel 1 current Word Count is decremented. When the word count of channel 1 goes to FFFFH, a TC is generated causing an EOP output terminating the service.

Channel 0 may be programmed to retain the same address for all transters. This allows a single word to be written to a block of memory.

The 8237A will respond to external EOP signals during memory-to-memory transfers. Data comparators in block search schemes may use this input to terminate the service when a match is found. The timing of memory-to-memory transters is found in Figure 12. Memory-to-memory operations can be detected as an active AEN with no DACK outputs.

Autoinitialize-By programming a bit in the Mode register, a channel may be set up as an Autoinitialize channel. During Autoinitialize initialization, the original values of the Current Address and Current Word Count registers are automatically restored from the Base Address and Base Word count registers of that channel following EOP. The base registers are loaded simultaneously with the current registers by the microprocessor and remain unchanged throughout the DMA service. The mask bit is not altered when the channel is in Autoinitialize. Following Autoinitialize the channel is ready to perform another DMA service, without CPU intervention, as soon as a valid DREQ is detected. In order to Autoninitialize both channels in a memory-to-memory transfer, both word counts should be programmed identically. If interrupted externally, EOP pulses should be applied in both bus cycles.

Priority-The 8237A has two types of priority encoding available as software selectable options. The first is Fixed Priority
which fixes the channels in priority order based upon the descending value of their number. The channel with the lowest priority is 3 followed by 2,1 and the highest priority channel, 0 . After the recognition of any one channel for service, the other channels are prevented from interferring with that service until it is completed.

The second scheme is Rotating Priority. The last channel to get service becomes the lowest priority channel with the others rotating accordingly.


With Rotating Priority in a single chip DMA system, any device requesting service is guaranteed to be recog nized after no more than three higher priority services have occurred. This prevents any one channel from monopolizing the system.

Compressed TIming - In order to achieve even greater throughput where system characteristics permit, the 8237A can compress the transfer time to two clock cycles. From Figure 11 it can be seen that state S3 is used to extend the access time of the read pulse. By removing state S3, the read pulse width is made equal to the write pulse width and a transfer consists only of state S 2 to change the address and state $\mathbf{S} 4$ to perform the read/write. S1 states will still occur when A8-A15 need updating (see Address Generation). Timing for compressed transfers is found in Figure 14.

Address Generation - In order to reduce pin count, the 8237A multiplexes the eight higher order address bits on the data lines. State S 1 is used to output the higher order address bits to an external latch from which they may be placed on the address bus. The falting edge of Address Strobe (ADSTB) is used to load these bits from the data lines to the latch. Address Enable (AEN) is used to enable the bits onto the address bus through a threestate enable. The lower order address blts are output by the 8237A directly. Lines A0-A7 should be connected to the address bus. Figure 11 shows the time relationships between CLK, AEN, ADSTB, DB0-DB7 and A0-A7.

During Block and Demand Transfer mode services, which include multiple transfers, the addresses gener ated will be sequential. For many transters the data held in the external address latch will remain the same. This data need only change when a carry or borrow from A7 to A8 takes place in the normal sequence of addresses. To save time and speed transfers, the 8237A executes S1 states only when updating of A8-A15 in the latch is necessary. This means for long services, S1 states and Address Strobes may occur only once every 256 trans fers, a savings of 255 clock cycies tor each 256 transfers.

## REGISTER DESCRIPTION

Current Address Register - Each channel has a 16-bit Current Address register. This register holds the value of the address used during DMA transfers. The address is automatically incremented or decremented after each transfer and the intermediate values of the address are stored in the Current Address register during the transfer. This register is written or read by the microprocessor in successive 8 -bit bytes. It may also be reinitialized by an Autoinitialize back to its original value. Autoinitialize takes place only after an $\overline{E O P}$.

Current Word Register - Each channel has a 16 -bit Current Word Count register. This register determines the number of transfers to be performed. The actual number of transfers will be one more than the number programmed in the Current Word Count register (i.e., programming a count of 100 will result in 101 transfers). The word count is decremented after each transfer. The intermediate value of the word count is stored in the register during the transfer. When the value in the register goes from zero to FFFFH, a TC will be generated. This register is loaded or read in successive 8 -bit bytes by the microprocessor in the Program Condition. Following the end of a DMA service it may also be reinitialized by an Autoinitialization back to its original value. Autoinitialize can occur only when an $\overline{E O P}$ occurs. It it is not Autoinitialized, this register will have a count of FFFFH after TC.

Base Address and Base Word Count Registers - Each channel has a pair of Base Address and Base Word Count registers. These 16 -bit registers store the original value of their associated current registers. During Autoinitialize these values are used to restore the current registers to their original values. The base registers are written simultaneously with their corresponding current register in 8 -bit bytes in the Program Condition by the microprocessor. These registers cannot be read by the microprocessor.

Command Register - This 8 -bit register controls the operation of the 8237A. It is programmed by the microprocessor in the Program Condition and is cleared by Reset or a Master Clear instruction. The following table lists the function of the command bits. See Figure 6 for address coding.

Mode Register - Each channei has a 6-bit Mode register associated with it. When the register is being written to by the microprocessor in the Program Condition, bits 0 and 1 determine which channel Mode register is to be written.

Request Register - The 8237A can respond to requests for DMA service which are initiated by software as well as by a DREQ. Each channel has a request bit associated with it in the 4 -bit Request register. These are nonmaskable and subject to prioritization by the Priority Encoder network. Each register bit is set or reset sepa-


Mode Register


Request Register

rately under software control or is cleared upon generation of a TC or external $\overline{E O P}$. The entire register is cleared by a Reset. To set or reset a bit, the software loads the proper form of the data word. See Figure 5 for register address coding. In order to make a software request, the channel must be in Block Mode.

Mask Register - Each channel has associated with it a mask bit which can be set to disable the incoming DREQ. Each mask bit is set when its associated channel produces an EOP if the channel is not programmed for Autoinitialize. Each bit of the 4 -bit Mask register may also be set or cleared separately under software control. The entire register is also set by a Reset. This disables all DMA requests until a clear Mask register instruction allows them to occur. The instruction to separately set or clear the mask bits is similar in form to that used with the Request register. See Figure 5 for instruction addressing.


All four bits of the Mask register may also be written with a single command.


| Register | Operation | Signala |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | C̄s | $\overline{10 R}$ | 10w | A3 | $\mathrm{A}_{2}$ | A1 | AO |
| Command | Write | 0 | 1 | 0 | 1 | 0 | 0 | 0 |
| Mode | Write | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
| Request | Write | 0 | 1 | 0 | 1 | 0 | 0 | 1 |
| Mask | Set/Reset | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| Mask | Write | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| Temporary | Read | 0 | 0 | 1 | 1 | 1 | 0 | 1 |
| Status | Read | 0 | 0 | 1 | 1 | 0 | 0 | 0 |

Figure 5. Definition of Register Codes

Status Register - The Status register is available to be read out of the 8237A by the microprocessor. It contains information about the status of the devices at this point. This information includes which channels have reached a terminal count and which channels have pending DMA requests. Bits 0-3 are set every time a TC is reached by that channel or an external $\overline{E O P}$ is applied. These bits are cleared upon Reset and on each Status Read. Bits 4-7 are set whenever their corresponding channel is requesting service.


Temporary Register - The Temporary register is used to hoid data during memory-to-memory transters. Following the completion of the transfers, the last word moved can be read by the microprocessor in the Program Condition. The Temporary register always contains the last byte transferred in the previous memory-to-memory operation, unless cleared by a Reset.

Software Commands-These are additional special software commands which can be executed in the Program Condition. They do not depend on any specific bit pattern on the data bus. The three software commands are:

Clear First/Last Flip-Flop: This command is executed prior to writing or reading new address or word count information to the 8237A. This initializes the flip-tlop to a known state so that subsequent accesses to reg. ister contents by the microprocessor will address upper and lower bytes in the correct sequence.

Master Clear: This software instruction has the same effect as the hardware Reset. The Command. Status, Request, Temporary, and Internal First/Last Flip-Fiop registers are cleared and the Mask register is set. The 8237A will enter the Idle cycle.

Clear Mask Register: This command clears the mask bits of all four channels, enabling them to accept DMA requests.
Figure 6 lists the address codes for the software commands:

| Signala |  |  |  |  |  | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A3 | A2 | A 1 | AO | $\overline{\mathrm{OR}}$ | IOW |  |
| 1 | 0 | 0 | 0 | 0 | 1 | Aead Status Register |
| 1 | 0 | 0 | 0 | 1 | 0 | Write Commena Regisier |
| 1 | 0 | 0 | 1 | 0 | 1 | lllogal |
| 1 | 0 | 0 | 1 | 1 | 0 | Write Request Register |
| 1 | 0 | 1 | 0 | 0 | 1 | Illegat |
| 1 | 0 | 1 | 0 | 1 | 0 | Write Single Mask Regieler Bit |
| 1 | 0 | 1 | 1 | 0 | 1 | Hllegal |
| 1. | 0 | 1 | 1 | 1 | 0 | Write Mode Register |
| 1 | 1 | 0 | 0 | 0 | 1 | Hilagal |
| 1 | 1 | 0 | 0 | 1 | 0 | Cliear Byte Pointer Flip IFlop |
| 1 | 1 | 0 | 1 | 0 | 1 | Hoed Temporary Register |
| 1 | 1 | 0 | 1 | 1 | 0 | Masier Claar |
| 1 | 1 | 1 | 0 | 0 | , | Iliegal |
| 1 | 1 | 1 | 0 | 1 | 0 | Clear Mask Register |
| 1 | 1 | 1 | 1 | 0 | 1 | Hegai |
| 1 | 1 | 1 | 1 | 1 | 0 | Write All Mask Register Bils |

Figure 6. Software Command Codes

| Channet | Reglster | Operation |  |  |  | gnate |  |  |  | Internal Flip-Flop | Data Bus D80-D87 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\overline{\mathbf{C S}}$ | $\overline{\mathbf{O} R}$ | İOW | A3 | 42 | A1 | AO |  |  |
| 0 | Base and Current Address | Write | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | AD-A7 |
|  |  |  | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | $A 8-A 15$ |
|  | Current Address | Read | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | $A 0-A 7$ |
|  |  |  | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | AB-A15 |
|  | Base and Current Word Count | Write | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | W0-W7 |
|  |  |  | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | W8-W 15 |
|  | Current Word Count | Read | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | W0-w7 |
|  |  |  | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | W8-W15 |
| 1 | Bese and Current Address | Write | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | AO-A7 |
|  |  |  | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | A8-A15 |
|  | Current Address | Read | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | AD-A7 |
|  |  |  | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | A8-A15 |
|  | Base and Current Word Count | Write | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | W0-W7 |
|  |  |  | 0 | $\dagger$ | 0 | 0 | 0 | 1 | 1 | 1 | We-W 15 |
|  | Current Word Count | Read | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | wo-w7 |
|  |  |  | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | W8-W15 |
| 2 | Base and Current Address | Write | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | A0-A7 |
|  |  |  | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | AB-A15 |
|  | Curtent Address | Read | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | A0-A7 |
|  |  |  | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | AB-A15 |
|  | Base and Current Word Count | Write | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | wo-w7 |
|  |  |  | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | W8-W 15 |
|  | Current Word Count | Read | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | W0-W7 |
|  |  |  | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | We-W 15 |
| 3 | Base and Curtent Address | Write | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | A0-A7 |
|  |  |  | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | A8-A15 |
|  | Current Address | Read | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | $A D-A 7$ |
|  |  |  | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | A8-A15 |
|  | Base and Current Word Count | Write | 0 | 1 | 0 | 0 | 1 | 1 |  | 0 | W0-W7 |
|  |  |  | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | we-w 15 |
|  | Current Word Count | Read | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | W0-W7 |
|  |  |  | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | W8-W15 |

Figure 7. Word Count and Address Register Command Codes

## PROGRAMMING

The 8237A will accept programming from the host processor any time that HLDA is inactive; this is true even if HRQ is active. The responsibility of the host is to assure that programming and HLDA are mutually exclusive. Note that a problem can occur it a DMA request occurs, on an unmasked channel while the 8237 A is being programmed. For instance, the CPU may be starting to reprogram the two byte Address register of channel 1 when channel 1 receives a DMA request. If the 8237A is enabled (bit 2 in the command register is 0 ) and channel 1 is unmasked, a DMA service will occur after only one byte of the Address register has been reprogrammed. This can be avoided by disabling the controller (setting bit 2 in the command register) or masking the channel before programming any other registers. Once the programming is complete, the controller can be enabled/unmasked.

After power-up it is suggested that all internal locations, especially the Mode registers, be loaded with some valid value. This should be done even if some channels are unused.

## APPLICATION INFORMATION

Figure 8 shows a convenient method for configuring a DMA system with the 8237A controller and an 8080Al 8085AH microprocessor system. The multimode DMA controller issues a HRQ to the processor whenever there is at least one valid DMA request from a peripheral device. When the processor replies with a HLDA signal, the 8237A takes control of the address bus, the data bus and the control bus. The address for the first transfer
operation comes out in two bytes - the least significant 8 bits on the eight address outputs and the most significant 8 bits on the data bus. The contents of the data bus are then latched into the 82828 -bit latch to complete the full 16 bits of the address bus. The 8282 is a high speed, 8 -bit, three-state latch in a 20 -pin package. After the initial transfer takes place, the latch is updated only after a carry or borrow is generated in the least sig. nificant address byte. Four DMA channels are provided when one 8237A is used.


Figure 8. 8237A Systom Interface

## intel

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature under Bias $.0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature .............. $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Voltage on any Pin with
Respect to Ground -0.5 to 7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . 1.5 Watt
"NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}=5 \%, \mathrm{GND}=0 \mathrm{~V}$ )

| Symbol | Parameter | Min. | Typ. ${ }^{11}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{IOH}=-200 \mu \mathrm{~A}$ |
|  |  | 3.3 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ (HRQ Only) |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage |  |  | 45 | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA} \text { (data Bus) } \mathrm{EDP} \\ & \mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA} \text { (other outputs) }(\text { Note } 8) \\ & \left.\mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA} \text { (ADSTB) } \text { (Note } 8\right) \end{aligned}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | 2.2 |  | $\mathrm{V}_{C C}+0.5$ | V |  |
| $V_{\text {IL }}$ | Input LOW Voltage | -0.5 |  | 0.8 | V | $\cdot$ |
| $I_{L}$ | Input Load Current |  |  | $-10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leq \mathrm{V}_{\mathbb{I N}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| 10 | Output Leakage Current |  |  | +10 | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 110 | 130 | mA | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ |
|  |  |  | 130 | 150 | mA | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |
| $\mathrm{C}_{0}$ | Outpul Capacitance |  | 4 | 8 | pF | $\mathrm{fc}=1.0 \mathrm{MHz}$, Inputs $=0 \mathrm{~V}$ |
| $\mathrm{C}_{1}$ | Input Capacitance |  | 8 | 15 | pF |  |
| $\mathrm{C}_{10}$ | I/O Capacitance |  | 10 | 18 | pF |  |

NOTES:

1. Typical values are for ${ }^{\top} A=25^{\circ} \mathrm{C}$, nominal supply voltage and nominal processing parameters.
2. Input timing parameters assume transition times of 20 ns or less. Waveform measurement points for both input and output signals are 2.0 V for HIGH and 0.8 V for LOW, unless ctherwise noted.
3. Output loading is 1 THL gate plus 150 pF capacitance, unless otherwise noted
4. The net $\overline{\mathrm{IOW}}$ or MEMW Pulse width for normal write will be TCY-100 ns and for extended write will be $2 \mathrm{TCY}-100 \mathrm{~ns}$. The net $\overline{\mathrm{CR}} \overline{\mathrm{CR}}$ or $\overline{\mathrm{MEMR}}$ pulse width for normal read will be 2TCY- 50 ns and for compressed read will be TCY-50 ns.
5. TDQ is specified lor two different output HIGH levels. TDQ1 is measured at 2.0 V TDQ2 is measured at 3.3 V . The value for TDQ2 assumes an external 3.3 kg pull-up resistor connecled form HRQ to VCC.
6. DREQ should be held active until DACK is returned.
7. DREQ and DACK signals may be active high or active low. Timing diagrams assume the active high mode.
8. A revision of the 8237A is planned for shipment in Apri! 1984, which will improve the following characleristics. 1. $\mathrm{V}_{\mathrm{IH}}$ from 2.2 V to 2.0 V
9. $\mathrm{V}_{\mathrm{OL}}$ from 0.45 V to 0.4 V on all outputs Test condition $\mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$.

Please contact your local sales oftice at that time for more information.
9. Successive read and/or write operations by the external processor to program or examine the controller must be timed to allow at least 600 ns for the 8237 A . at least 500 ns for the $8237 \mathrm{~A}-4$ and at least 400 ns tor the $9237 \mathrm{~A}-5$. as recovery time between active read or write puises.
10. $\overline{\mathrm{EOP}}$ is an open collector output. This parameter assumes the presence of a 2.2 K pullup to VCC .
11. Pin 5 is an input that should always be at a logic high level An internal pult-up resistor will establish a logic high when the pin is left floating. It is recommended however, that pin 5 be tied to $V_{C C}$.

## A.C. TESTING INPUT, OUTPUT WAVEFORM

SNPUT/OUTPUT

8237A/8237A-4/8237A-5
A.C. CHARACTERISTICS—DMA (MASTER) MODE $\pi_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$, $\mathrm{V}_{\mathrm{cC}}=+5 \mathrm{~V} \pm 5 \%, G \mathrm{GD}=0 \mathrm{~V}$

| Symbol | Parameter | 8237A |  | 8237A-4 |  | 8237A-5 |  | UnIt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | MIn. | Max. |  |
| TAEL | AEN HIGH from CLK LOW (S1) Delay Time |  | 300 |  | 225 |  | 200 | ns. |
| TAET | AEN LOW from CLK HIGH (Si) Delay Time |  | 200 |  | 150 |  | 130 | ns |
| TAFAB | ADR Active to Float Delay from CLK HIGH |  | 150 |  | 120 |  | 90 | ns |
| TAFC | $\overline{\text { READ }}$ or WRITE Float from CLK HIGH |  | 150 |  | 120 |  | 120 | ns |
| TAFDB | DB Active to Float Delay from CLK HIGH |  | 250 |  | 190 |  | 170 | ns |
| TAHR | ADR from READ HIGH Hold Time | TCY-100 |  | TCY-100 |  | TCY-100 |  | ns |
| TAHS | DB from ADSTB LOW Hold Time | 50 |  | 40 |  | 30 |  | ns |
| TAHW | ADR from WRITE HIGH Hold Time | TCY-50 |  | TCY-50 |  | TCY-50 |  | ns |
| TAK | DACK Vatid from CLK LOW Delay Time (Note 7) |  | 250 |  | 220 |  | 170 | ns |
|  | $\overline{\text { EOP }}$ HIGH from CLK HIGH Delay Time (Note 10) |  | 250 |  | 190 |  | 170 | ns |
|  | EOP LOW from CLK HIGH Delay Time |  | 250 |  | 190 |  | 170 | ns |
| TASM | ADR Stable from CLK HIGH |  | 250 |  | 190 |  | 170 | ns |
| TASS | DB to ADSTB LOW Setup Time | 100 |  | 100 |  | 100 |  | ns |
| TCH | Clock High Time (Transitions $\leqslant 10 \mathrm{~ns}$ ) | 120 |  | 100 |  | 80 |  | ns |
| TCL | Clock LOW Time (Transitions $\leqslant 10 \mathrm{~ns}$ ) | 150 |  | 110 |  | 68 |  | ns |
| TCY | CLK Cycle Time | 320 |  | 250 |  | 200 |  | ns |
| TDCL | CLK HIGM to $\overline{\text { READ }}$ or WRITE LOW Delay (Note 4) |  | 270 |  | 200 |  | 190 | ns |
| TDCTR | READ HIGH from CLK HIGH (S4) Delay Time (Note 4) |  | 270 |  | 210 |  | 190 | ns |
| TDCTW | WRITE HIGH from CLK HIGH (S4) Delay Time (Note 4) |  | 200 |  | 150 |  | 130 | ns |
| $\begin{aligned} & \text { TDQ1 } \\ & \text { TDQ2 } \end{aligned}$ | HRQ Valid from CLK HIGH Delay Time (Note 5) |  | 160 |  | 120 |  | 120 | ns |
|  |  |  | 250 |  | 190 |  | 120 | ns |
| TEPS | $\overline{E O P}$ LOW from CLK LOW Setup Time | 60 |  | 45 |  | 40 |  | ns |
| TEPW | $\widehat{\text { EOP Pulse Width }}$ | 300 |  | 225 |  | 220 |  | ns |
| TFAAB | ADR Float to Active Delay from CLK HIGH |  | 250 |  | 190 |  | 170 | ns |
| TFAC | $\overline{\text { READ }}$ or WRITE Active from CLK HIGH |  | 200 |  | 150 |  | 150 | ns |
| TFADB | DB Float to Active Delay from CLK HIGH |  | 300 |  | 225 |  | 200 | ns |
| THS | HLDA Valid to CLK HIGH Setup Time | 100 |  | 75 |  | 75 |  | ns |
| TIDH | Input Data from $\overline{\text { MEMR }}$ HIGH Hold Time | 0 |  | 0 |  | 0 |  | ns |
| TIDS | Input Data to $\overline{\text { MEMR }}$ HIGH Setup Time | 250 |  | 190 |  | 170 |  | ns |
| TODH | Output Data from MEMW HIGH Hotd Time | 20 |  | 20 |  | 10 |  | ns |
| TODV | Output Data Valid to $\overline{\text { MEMW }}$ HIGH | 200 |  | 125 |  | 125 |  | ns |
| TOS | DREQ to CLK LOW (SI, S4) Setup Time (Note 7) | 0 |  | 0 |  | 0 |  | ns |
| TRH | CLK to READY LOW Hold Time | 20 |  | 20 |  | 20 |  | ns |
| TRS | READY to CLK LOW Setup Time | 100 |  | 60 |  | 60 |  | ns |
| TSTL | ADSTB HIGH from CLK HIGH Delay Time |  | 200 |  | 150 |  | 130 | ns |
| TSTT | ADSTB LOW from CLK HIGH Delay Time |  | 140 |  | 110 |  | 90 | ns |

## 8237A/8237A-4/8237A-5

A.C. CHARACTERISTICS—PERIPHERAL (SLAVE) MODE ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$, GND $=0 \mathrm{~V}$ )

| Symbol | Parameter | 8237A |  | 8237A-4 |  | 8237A-5 |  | UnIt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| TAR | ADR Valid or $\overline{\text { CS }}$ LOW to $\overline{\text { READ }}$ LOW | 50 |  | 50 |  | 50 |  | ns |
| TAW | ADA Valid to WRITE HIGH Setup Time | 200 |  | 150 |  | 130 |  | ns |
| TCW | CS LOW to WRITE HIGH Setup Time | 200 |  | 150 |  | 130 |  | ns |
| TDW | Data Valid to WRITE HIGH Setup Time | 200 |  | 150 |  | 130 |  | ns |
| TRA | ADR or CS Hold from $\overline{\text { READ HIGH }}$ | 0 |  | 0 |  | 0 |  | ns |
| TRDE | Data Access from $\overline{\text { READ L LOW (Note 3) }}$ |  | 200 |  | 200 |  | 140 | ns |
| TRDF | DB Float Delay from त्READ HIGH | 20 | 100 | 20 | 100 | 0 | 70 | ns |
| TRSTD | Power Supply HIGH to RESET LOW Setup Time | 500 |  | 500 |  | 500 |  | ns |
| TRSTS | RESET to First $\overline{\text { O }} \bar{W}$ | 2 TCY |  | 2 TCY |  | 2TCY |  | ns |
| TRSTW | RESET Pulse Width | 300 |  | 300 |  | 300 |  | ns |
| TRW | $\overline{\text { READ }}$ Width | 300 |  | 250 |  | 200 |  | ns |
| TWA | ADR from WRITE HIGH Hold Time | 20 |  | 20 |  | 20 |  | ns |
| TWC | CS HIGH from WRITE HIGH Hold Time | 20 |  | 20 |  | 20 |  | ns |
| TWD | Data from WRITE HIGH Hold Time | 30 |  | 30 |  | 30 |  | ns |
| TWWS | Write Width | 200 |  | 200 |  | 160 |  | ns |

WAVEFORMS

## SLAVE MODE WRITE TIMING



Figure 9. Slave Mode Write
SLAVE MODE READ TIMING


## inte

WAVEFORMS (Continued)


WAVEFORMS (Continued)


## READY TIMING



## inter

## 8237A/8237A-4/8237A-5

WAVEFORMS (Continued)


## RESET TIMING



## intel

## 8255A/8255A-5 <br> PROGRAMMABLE PERIPHERAL INTERFACE

- MCS-85 ${ }^{\text {TM }}$ Compatible 8255A. 5
- 24 Programmable I/O Pins
- Completely TTL Compatible
- Fully Compatible with Intel ${ }^{(®)}$ Microprocessor Families
- Improved Timing Characteristics
- Direct Bit Set/Reset Capability Easing Control Application Interface
- Reduces System Package Count
- Improved DC Driving Capability
- Available in EXPRESS
-Standard Temperature Range
-Extended Temperature Range

The Intel* 8255A is a general purpose programmable l/O device designed for use with Intel* microprocessors. It has 24 //O pins which may be individually programmed in 2 groups of 12 and used in 3 major modes of operation. In the first mode (MODE 0 ), each group of $12 / / O$ pins may be programmed in sets of 4 to be input or output. In MODE 1 , the second mode, each group may be programmed to have 8 lines of input or output. Of the remaining 4 pins, 3 are used for hand shaking and interrupt control signals. The third mode of operation (MODE 2) is a bidirectional bus mode which uses 8 lines for a bidirectional bus, and 5 lines, borrowing one from the other group. for handshaking.


Figure 1. 8255A Block Diagram


Figure 2. Pin Configuration

## 8255A FUNCTIONAL DESCRIPTION

## General

The 8255A is a programmable peripheral interface (PPI) device designed for use in Intel ${ }^{\text {t }}$ microcomputer systems. Its function is that of a general purpose I/O component to interface peripheral equipment to the microcomputer system bus. The functional configuration of the 8255A is programmed by the system software so that normally no external logic is necessary to interface peripheral devices or structures.

## Data Bus Buffer

This 3-state bidirectional 8 -bit buffer is used to interface the 8255A to the system data bus. Data is transmitted or received by the buffer upon execution of input or output instructions by the CPU. Control words and status information are also transferred through the data bus buffer.

## Read/Write and Control Logic

The function of this block is to manage alf of the internal and external transters of both Data and Control or Status words. It accepts inputs from the CPU Address and Control busses and in turn, issues commands to both of the Control Groups.

## ( $\overline{\mathrm{CS}}$ )

Chip Select. A "Iow" on this input pin enables the communiction between the 8255A and the CPU.

## (RD)

Read. A "low" on this input pin enables the 8255A to send the data or status information to the CPU on the data bus. In essence, it allows the CPU to "read from" the 8255A.

## ( $\overline{\mathbf{W R}}$ )

Write. A "low" on this input pin enables the CPU to write data or control words into the 8255A.

## ( $A_{0}$ and $A_{1}$ )

Port Select 0 and Port Select 1 . These input signals, in conjunction with the RD and WR inputs, control the selection of one of the three ports or the control word registers. They are normally connected to the least significant bits of the address bus ( $A_{0}$ and $A_{1}$ ).

## 8255A BASIC OPERATION

| $A_{1}$ | $A_{0}$ | $\overline{\text { AD }}$ | $\overline{\text { WR }}$ | $\overline{\mathrm{CS}}$ | INPUT OPERATION (READ) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 1 | 0 | PORT $A=$ DATA BUS |
| 0 | 1 | 0 | 1 | 0 | PORT B $\Rightarrow$ DATA BUS |
| 1 | 0 | 0 | 1 | 0 | PORT C $\Rightarrow$ DATA BUS |
|  |  |  |  |  | OUTPUT OPERATION (WRITE) |
| 0 | 0 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ PORT A |
| 0 | 1 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ PORT B |
| 1 | 0 | 1 | 0 | 0 | DATA BUS - PORT C |
| 1 | 1 | 1 | 0 | 0 | DATA 8US $\Rightarrow$ CONTROL |
|  |  |  |  |  | DISABLE FUNCTION |
| x | X | $x$ | $\times$ | 1 | DATA BUS - 3-STATE |
| 1 | 1 | 0 | 1 | 0 | ILLEGAL CONDITION |
| X | X | 1 | 1 | 0 | DATA BUS $\Rightarrow$ 3-STATE |



Flgure 3. 8255A Block Diagram Showing Data Bus Buffer and Read/Write Control Logic Functions

## (RESET)

Reset. A "high" on this input clears the control register and all ports ( $A, B, C$ ) are set to the input mode.

## Group A and Group 8 Controls

The functional configuration of each port is programmed by the systems software. In essence, the CPU "outputs" a control word to the 8255A. The control word contains information such as "mode", "bit set", "bit reset" etc., that initializes the functional conflguration of the 8255A.
Each of the Control blocks (Group A and Group 8) accepts "comnands" from the Read/Write Control Logic, receives "control words" from the internal data bus and issues the proper commands to its associated ports.

Control Group A - Port A and Port C upper (C7.C4)
Control Group B - Port B and Port C lower (C3.C0)
The Control Word Register can Only be written into. No Read operation of the Control Word Register is allowed.

## Ports A, B, and C

The 8255A contains three 8-bit ports (A, B, and C). All can be configured in a wide varlety of functional characteristics by the system software but each has its own special features or "personality" to further enhance the power and flexibllity of the 8255A.

Port A. One 8-bit data output latch/buffer and one 8-bit data input latch.

Port B. One 8-bit data input/output latch/buffer and one 8 -bit data input buffer.

Port C. One 8 -bit data output latch/bufter and one 8 -bit data input buffer (no latch for input). This port can be divided into two 4.bit ports under the mode control. Each 4-bit port contains a 4-bit latch and it can be used for the control signal outputs and status signal inputs in conjunction with ports A and B .


PIN CONFIGURATION


PIN NAMES


Figure 4. 2225A Block Diagram Showing Group A and Group E Control Function:

## 8255A OPERATIONAL DESCRIPTION

## Mode Selection

There are three basic modes of operation that can be selected by the system soltware:

Mode 0 - Basic Input/Output
Mode 1 - Strobed Input/Output
Mode 2 -- Bi-Directional Bus
When the reset input goes "high" all ports will be set to the input mode (i.e., all 24 lines will be in the high impedance state). After the reset is removed the 8255A can remain in the input mode with no additional initialization required. During the execution of the system program any of the other modes may be selected using a single output instruction. This allows a single 8255A to service a variety of peripheral devices with a simple software maintenance routine.

The modes for Port A and Port B can be separately defined, while Port $C$ is divided into two portions as required by the Port A and Port B definitions. All of the output registers, including the status flip-flops, will be reset whenever the mode is changed. Modes may be combined so that their functional definition can be "tailored" to almost any I/O structure. For instance; Group B can be programmed in Mode 0 to monitor simple switch closings or display computational results, Group A could be programmed in Mode 1 to monitor a keyboard or tape reader on an interrupt-driven basis.


Figure 5. Basic Mode Definitions and Bus Interface


Figure 6. Mode Definition Format

The mode definitions and possible mode combinations may seem confusing at first but after a cursory review of the complete device operation a simple, logical I/O approach will surface. The design of the 8255A has taken into account things such as efficient PC board layout, control signal definition vs PC layout and complete functional flexibility to support almost any peripheral device with no external logic. Such design represents the maximum use of the available pins.

## Single Bit Sgt/Reset Feature

Any of the eight bits of Port $C$ can be Set or Reset using a single OUTput instruction. This feature reduces software requirements in Control-based applications.

8255A/8255A. 5


Figure 7. Bit Set/Reset Format

MODE 0 (Basic Input/Output). This functional configuration provides simple input and output operations for each of the three ports. No "handshaking" is required, data is simply written to or read from a specified port.

When Port C is being used as status/control for Port A or B, these bits can be set or reset by using the Bit Set/Reset operation just as if they were data output ports.

## Interrupt Control Functions

When the 8255A is programmed to operate in mode 1 or mode 2 , control signals are provided that can be used as interrupt request inputs to the CPU. The interrupt request signals, generated from port C , can be inhibited or enabled by setting or resetting the associated INTE flip. flop, using the bit set/reset function of port C.

This function allows the Programmer to disallow or allow a specific I/O device to interrupt the CPU without affecting any other device in the interrupt structure.

INTE flip-flop definition:
(BIT-SET) - INTE is SET - Interrupt enable
(BIT-RESET) - INTE is RESET - Interrupt disable
Note: All Mask flip-flops are automatically reset during mode selection and device Reset.

## Operating Modes



MODE 0 (Basic Input)


MODE 0 (Basic Output)

## inted

## MODE 0 Port Definition

| A |  | $B$ |  | GROUP A |  |  | GROUP B |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D4 | $\mathrm{D}_{3}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | PORT A | PORT C <br> (UPPER) | \# | PORT $B$ | PORT C <br> (LOWER) |
| 0 | 0 | 0 | 0 | OUTPUT | OUTPUT | 0 | OUTPUT | OUTPUT |
| 0 | 0 | 0 | 1 | OUTPUT | OUTPUT | 1 | OUTPUT | INPUT |
| 0 | 0 | 1 | 0 | OUTPUT. | OUTPUT | 2 | INPUT | OUTPUT |
| 0 | 0 | 1 | 1 | OUTPUT | OUTPUT | 3 | INPUT | INPUT |
| 0 | 1 | 0 | 0 | OUTPUT | INPUT | 4 | OUTPUT | OUTPUT |
| 0 | 1 | 0 | 1 | OUTPUT | INPUT | 5 | OUTPUT | InPUT |
| 0 | 1 | 1 | 0 | OUTPUT | INPUT | 6 | INPUT | OUTPUT |
| 0 | 1 | 1 | 1 | OUTPUT | INPUT | 7 | INPUT | INPUT |
| 1 | 0 | 0 | 0 | INPUT | OUTPUT | 8 | OUTPUT | OUTPUT |
| 1 | 0 | 0 | 1 | INPUT | OUTPUT | 9 | OUTPUT | INPUT |
| 1 | 0 | 1 | 0 | INPUT | OUTPUT | 10 | INPUT | OUTPUT |
| 1 | 0 | 1 | 1 | INPUT | OUTPUT | 11 | INPUT | INPUT |
| 1 | 1 | 0 | 0 | INPUT | INPUT | 12 | OUTPUT | OUTPUT |
| 1 | 1 | 0 | 1 | INPUT | INPUT | 13 | OUTPUT | INPUT |
| 1 | 1 | 1 | 0 | INPUT | INPUT | 14 | INPUT | OUTPUT |
| 1 | 1 | 1 | 1 | INPUT | INPUT | 15 | INPUT | INPUT |

## MODE 0 Configurations



CONTROL WORD $=4$

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |



## CONTROL WORD $=5$

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |

$0, \mathrm{O}_{0} \rightarrow \mathrm{PA}_{7} \cdot \mathrm{PA}_{0}$

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 |



CONTROL WORD $=8$

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{O}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |



## CONTROL WORD ${ }^{49}$

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |



CONTROL WORD $=10$

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 |



CONTROL WORD $=11$

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{O}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |



## 8255A/8255A-5

CONTROL WORD $=12$
CONTROL WORD: 14



CONTROL WORD $=13$


CONTROL WORD 75


## Operating Modes

MODE 1 (Strobed Input/Output). This functional con figuration provides a means for transferring I/O data to or from a specified port in conjunction with strobes or "handshaking" signals. In mode 1, port A and Port B use the lines on port C to generate or accept these "hand shaking ${ }^{\text {i }}$ signals

Mode 1 Basic Functional Definitions:

- Two Groups (Group A and Group B)
- Each group contains one 8 -bit data port and one 4 -bit control/data port.
- The 8 -bit data port can be either input or output. Both inputs and outputs are latched.
- Thie 4-bit port is used for control and status of the 8 -bit data port.


## inte

## Input Control Signal Definition

STB (Strobe Input). A "low" on this input loads data into the input latch.

## IBF (Input Buffer Full F/F)

A "high" on this output indicates that the data has been loaded into the input latch; in essence, an acknowledgement IBF is set by STB input being low and is reset by the rising edge of the RD input.

## INTR (Interrupt Request)

A "high" on this output can be used to interrupt the CPU when an input device is requesting service. INTR is set by the $\overline{\text { STB }}$ is a "one", IBF is a "one" and INTE is a "one". It is reset by the falling edge of $\overline{\mathrm{RD}}$. This procedure allows an input device to request service from the CPU by simply strobing its data into the port.

INTE A
Controlled by bit set/reset of $\mathrm{PC}_{4}$. INTE B

Controlled by bit set/reset of $\mathrm{PC}_{2}$.


Figure 8. MODE 1 Input


Figure 9. MODE 1 (Strobed Input)

## Output Control Signal Definition

$\overline{\text { OBF }}$ (Output Buffer Full F/F). The OBF output will go "low" to indicate that the CPU has written data out to the specified port. The OBF FIF will be set by the rising edge of the WR input and reset by ACK Input being low.
$\overline{A C K}$ (Acknowledge Input). A "low" on this input informs the 8255A that the data from port $A$ or port $B$ has been accepted. In essence, a response from the peripheral device indicating that it has received the data output by the CPU.

INTR (Interrupt Request). A "high" on this output can be used to interrupt the CPU when an output device has accepted data transmitted by the CPU. INTR is set when ACK is a "one", OBF is a "one" and INTE is a "one". It is reset by the falling edge of WR.

INTE A
Controlled by bit set/reset of $\mathrm{PC}_{6}$.
INTEB
Controlled by bit set/reset of $\mathrm{PC}_{2}$.


Figure 10. MODE 1 Output


Figure 11. Mode 1 (Strobed Output)

8255A8255A-5

## Combinations of MODE 1

Port A and Port B can be individually defined as input or output in Mode 1 to support a wide variety of strobed I/O applications.


Figure 12. Combinations of MODE 1

## Operating Modes

MODE 2 (Strobed Bidirectional Bus I/O). This functional configuration provides a means for communicating with a peripheral device or structure on a single 8 -bit bus tor both transmitting and receiving data (bidirectional bus I/O). "Handshaking" signals are provided to maintain proper bus flow discipline in a similar manner to MODE 1. Interrupt generation and enable/disable functions are also available.

## MODE 2 Basic Functional Definitions

- Used in Group A only.
- One 8 -bit, bi-directional bus Port (Port A) and a 5 -bit control Port (Port C).
- Both inputs and outputs are latched.
- The 5-bit control port (Port C ) is used for control and status for the 8 -bit, bi-directional bus port (Port A).


## Bidirectionał Bus I/O Control Signal Definition

INTR (Interrupt Request). A high on this output can be used to interrupt the CPU for both input or output operations.

## Output Operations

$\overline{\text { OBF (Output Buffer Ful). The OBF output will go "low" }}$ to indicate that the CPU has written data out to port A.

ACK (Acknowledge). A "low" on this input enables the tri-state output buffer of port $A$ to send out the data. Otherwise, the output buffer will be in the high im. pedance state.

INTE 1 (The INTE Flip.Flop Associated with OBF). Controlled by bit set/reset of $\mathrm{PC}_{6}$

Input Operations
STB (Strobe Input)
STB (Strobe Input). A "low" on this input loads data into the input latch
IBF (Input Buffer Full FIF). A "high" on this output indicates that data has been loaded into the input latch.

INTE 2 (The INTE Flip. Flop Associated with $\ddagger B F$ ). Con. trolled by bit set/reset of $\mathrm{PC}_{4}$.

## 8255A/8255A.5



Figure 13. MODE Control Word


Figure 14. MODE 2


Figure 15. MODE 2 (Bidirectional)

NOTE: Any sequence where $\overline{W \bar{R}}$ occurs before $\overline{A C K}$ and $\overline{S T B}$ occurs before $\overline{R D}$ is permissible. $(I N T R=I B F \cdot \overline{M A S K} \cdot \overline{S T} \bar{B} \cdot \overline{R D}+\overline{O B F} \cdot \overline{M A S K} \cdot \overline{A C K} \cdot \overline{W R})$

8255A/8255A.5
(

Figure 16. MODE $1 / 4$ Combinations

## inted

 8255A/8255A-5
## Mode Definition Summary



## Special Mode Combination Considerations

There are several combinations of modes when not all of the bits in Port C are used for control or status. The remaining bits can be used as follows:

If Programmed as Inputs -
All input lines can be accessed during a normal Port C read.

If Programmed as Outputs -
Bits in C upper ( $\mathrm{PC}, \mathrm{PC}_{4}$ ) must be individually accessed using the bit set/reset function.
Bits in $C$ lower ( $\mathrm{PC}_{3}: \mathrm{PC}_{0}$ ) can be accessed using the bit set/reset function or accessed as a threesome by writing into Port C .

## Source Current Capability on Port B and Port C

Any set of eight output buffers, selected ranoomly from Ports B and C can source 1 mA at 1.5 volts. This feature allows the 8255 to directly drive Darlington type drivers and high-voltage displays that require such source current.

## Reading Port C Status

In Mode 0, Port C transfers data to or from the peripheral device. When the 8255 is programmed to function in Modes 1 or 2, Port C generates or accepts "hand-shaking" signals with the peripheral device. Reading the contents of Port C
allows the programmer to test or verify the "status" of each peripheral device and change the program flow accordingly.

There is no special instruction to read the status information from Port C. A normal read operation of Port C is executed to perform this function.


Figure 17. MODE 1 Status Word Format


Figure 18. MODE 2 Status Word Format

8255A/8255A-5

## APPLICATIONS OF THE 8255A

The 8255A is a very powertul tool for interfacing peripheral equipment to the microcomputer system. It represents the optimum use of available pins and is flexible enough to interface almost any I/O device without the need for additional external logic.
Each peripheral device in a microcomputer system usually has a "service routine" associated with it. The routine manages the software interface between the device and the CPU. The functional definition of the 8255A is programmed by the $1 / O$ service routine and becomes an extension of the system software. By examining the I/O devices interface characteristics for both data transfer and timing, and matching this information to the examples and tables in the detailed operational description, a control word can easily be developed to initialize the 8255A to exactly "fit" the application. Figures 19 through 25 present a few examples of typical applications of the 8255A.


Figure 19. Printer Interface


Figure 20. Keyboard and Display Interface


Figure 21. Keyboard and Terminal Address Interface


Figure 22. Digital to Analog, Analog to Digital


Figure 24. Basic Floppy Disc Interface


Figure 23. Basic CRT Controller Interface


Figure 25. Machine Tool Controller Interface

8255A/8255A. 5

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias.
Storage Temperature
Voltage on Any Pin
With Respect to Ground
Power Dissipation
$0 \mathrm{C}: 10 \mathrm{C}$ 65 C $10+150 C$
0.5 V 10.7 V

1 Watt
*NOTICE: Siresses 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.
D.C. CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=0 \mathrm{C}$ to $70 \mathrm{C} . \mathrm{V}_{\mathrm{CC}}-5 \mathrm{~V} \cdot 10 \%$ GND OV ).

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $V_{\text {OL }}$ (DB) | Output Low Voltage (Data Bus) |  | 0.45 * | V | $\mathrm{I}_{\mathrm{OL}} \quad 2.5 \mathrm{~mA}$ |
| $V_{\text {OL }}$ (PER) | Output Low Voltage (Peripheral Port) |  | $0.45{ }^{\circ}$ | V | $\mathrm{IOL}^{(1)} 1.7 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}(\mathrm{DB})$ | Output High Voltage \{Data Bus) | 2.4 |  | $\checkmark$ | ${ }^{1} \mathrm{OH}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH}}$ (PER) | Output High Voltage (Peripheral Port) | 2.4 |  | $V$ | $\mathrm{IOH}^{\text {OH }}=-200 \mu \mathrm{~A}$ |
| ${ }^{\text {DAAR }}{ }^{111}$ | Darlington Drive Current | -1.0 | $-4.0$ | mA | $R_{\text {EXT }}=750 \Omega 2, V_{\text {EXT }}=1.5 \mathrm{~V}$ |
| ${ }^{\text {I C C }}$ | Power Supply Current |  | 120 | mA |  |
| $1 / 1$ | Input Load Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{\text {CC }}$ to $0 V$ |
| IOFL | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $V_{\text {OUT }}-V_{\text {CC }}$ to 45 V |

## NOTE

1. Available on any 8 pins from Port $B$ and $C$

CAPACITANCE $\left(\mathrm{T}_{\mathrm{A}}=25 \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}\right.$ $0 \mathrm{~V})$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  |  | 10 | pF | ic 1 MHz |
| $\mathrm{Cl}_{1 / \mathrm{O}}$ | 1:O Capactance |  |  | 20 | DF | Unmeasured pins returned to GND |

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

## Bus Parameters

READ

| Symbol | Parameter | 8255A |  | 8255A-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }_{t}$ AR | Address Stable Before READ | 0 |  | 0 |  | ns |
| $t_{\text {RA }}$ | Address Stable After READ | 0 |  | 0 |  | ns |
| tra | READ Pulse Width | 300 |  | 300 |  | ns |
| $t_{\text {RD }}$ | Data Valid From READ ${ }^{11}$ |  | 250 |  | 200 | ns |
| ${ }_{\text {t }} \mathrm{F}$ | Data Float After READ | 10 | 150 | 10 | 100 | ns |
| trv | Time Between READs and/or WRITEs | 850 |  | 850 |  | ns |

8255A/8255A-5
A.C. CHARACTERISTICS (Continued)
wRITE

| Symbol | Parameter | 8255A |  | 8255A-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $t_{\text {AW }}$ | Address Stable Before WRITE | 0 |  | 0 |  | ns |
| twa | Address Stable After WRITE | 20 |  | 20 |  | ns |
| tww | WRITE Pulse Width | 400 |  | 300 |  | ns |
| tow | Data Valid to WRITE (T.E.) | 100 |  | 100 |  | ns |
| two | Data Valid After WRITE | 30 |  | 30 |  | ns |

other timings

| Symbol | Parameter | 8255A |  | 8255A. 5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| tw | WR = 1 to Output ${ }^{11}$ |  | 350 |  | 350 | ns |
| $\mathrm{t}_{1 / \mathrm{R}}$ | Peripheral Data Before RD | 0 |  | 0 |  | ns |
| $t_{\text {HR }}$ | Peripheral Data After RD | 0 |  | 0 |  | ns |
| $t_{\text {AK }}$ | ACK Pulse Width | 300 |  | 300 |  | ns |
| ${ }^{\text {t }}$ ST | STB Pulse Width | 500 |  | 500 |  | ns |
| tPS | Per. Data Before T.E. of STB | 0 |  | 0 |  | ns |
| $\mathrm{tPH}^{\text {P }}$ | Per. Data After T.E. of STB | 180 |  | 180 |  | ns |
| $t_{A D}$ | ACK $=0$ to Output ${ }^{111}$ |  | 300 |  | 300 | ns |
| $\mathrm{t}_{\mathrm{KD}}$ | ACK $=1$ to Output Float | 20 | 250 | 20 | 250 | ns |
| twob | $W R=1$ to $O B F=0^{11 \mid}$ |  | 650 |  | 650 | ns |
| ${ }^{1} \mathrm{AOB}$ | $A C K=0$ to $O B F=1^{\|1\|}$ |  | 350 |  | 350 | ns |
| $\mathrm{t}_{51 \mathrm{~B}}$ | $S T B=0$ to $\mid B F=1^{\|1\|}$ |  | 300 |  | 300 | ns |
| $\mathrm{t}_{\text {RIB }}$ | $R D=1$ to $I B F=0^{111}$ |  | 300 |  | 300 | ns |
| $\mathrm{t}_{\text {RIT }}$ | $R D=0$ to INTR $=0{ }^{11}$ |  | 400 |  | 400 | ns |
| ${ }_{\text {t }}^{\text {SIT }}$ | $S T B=1$ to $\mid$ NTR $=1111$ |  | 300 |  | 300 | ns |
| ${ }_{\text {t }}$ IT | $A C K=1$ to INTR $=1^{\mid 11}$ |  | 350 |  | 350 | ns |
| ${ }_{\text {twit }}$ | $W R=0$ to $\operatorname{INTR}=0^{11,3 \mid}$ |  | 450 |  | 450 | ns |

NOTES:

1. Test Conditions: $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.
2. Period of Reset pulse must be at least $50 \mu \mathrm{~s}$ during or after power on. Subsequent Reset pulse can be 500 ns min.
3. INTR $\uparrow$ may occur as early as $\bar{W} \mathbb{R} \downarrow$.

- For Extended Temperature EXPRESS, use M8255A electrical parameters.


## A.C. TESTING INPUT, OUTPUT WAVEFORM

INPUTIOUTPUT
A.C. TESTING LOAD CIRCUIT


8255A/8255A-5

## WAVEFORMS



WAVEFORMS (Continued)


## irite

## 8255A/8255A-5

WAVEFORMS (Continued)


# 8272A <br> SINGLE/DOUBLE DENSITY FLOPPY DISK CONTROLLER 

- IBM Compatible in Both Single and Double Density Recording Formats
- Programmable Data Record Lengths: 128, 256, 512, or 1024 Bytes/Sector
- Multi-Sector and Multi-Track Transfer Capability
- Drives Up to 4 Floppy or Mini-Floppy Disks
- Data Transfers in DMA or Non-DMA Mode
- Parallel Seek Operations on Up to Four Drives
- Compatible with all Intel and Most Other Microprocessors
- Single-Phase 8 MHz Clock
- Single + 5 Volt Power Supply ( $\pm \mathbf{1 0 \%}$ )

The 8272A is an LSI Floppy Disk Controller (FDC) Chip, which contains the circuitry and control functions for interfacing a processor to 4 Floppy Disk Drives. It is capable of supporting either IBM 3740 single density format (FM), or IBM System 34 Double Density format (MFM) including double sided recording. The 8272A provides control signals which simplify the design of an external phase locked loop and write precompensation circuitry. The FDC simplifies and handies most of the burdens assoclated with implementing a Floppy Disk Drive Interface. The 8272A is a pincompatible upgrade to the 8272 .


Figure 1. 8272A Internal Block Diagram
Figure 2. Pin Configuration

[^3]Table 1. Pin Description

| Symbol | Pln No. | Type | Connecthon To | Name and Function |
| :---: | :---: | :---: | :---: | :---: |
| RESET | 1 | 1 | $\mu \mathrm{P}$ | Reset: Places FDC in idle state. Resets output lines to FDD to " 0 " (low). Does not clear the last specity command. |
| $\overline{\mathrm{RD}}$ | 2 | $\\|^{11}$ | $\mu \mathrm{P}$ | Read: Control signal for transfer of data from FDC to Data Bus, when 0' (low) |
| $\overline{W R}$ | 3 | $1^{14}$ | $\mu \mathrm{P}$ | Write: Control signal for transter of data to FDC via Data Bus, when 0 (low) |
| $\overline{\mathrm{CS}}$ | 4 | 1 | ${ }_{\mu} \mathrm{P}$ | Chip Select: IC selected when 0 (low) allowing $\overline{R D}$ and $\overline{W R}$ to be enabled |
| $\mathrm{A}_{0}$ | 5 | $1^{1 /}$ | $\mu \mathrm{P}$ | Data/Status Register Select: Selects Data $\operatorname{Reg}\left(A_{0}=1\right)$ or Status $\operatorname{Reg}\left(A_{0}=0\right)$ contents to be sent to Data Bus. |
| $\mathrm{DB}_{0} \cdot \mathrm{OB}_{7}$ | 6.13 | $10^{11}$ | $\mu \mathrm{P}$ | Data Bus: Bidirectional 8-Bit Data Bus. |
| DRQ | 14 | 0 | DMA | Data DMA Request: DMA Request is being made by FDC when DRQ 1 |
| $\overline{\text { DACK }}$ | 15 | 1 | DMA | DMA Acknowledge: DMA cycle is aclive when 0 (low) and Controller is performing DMA transter. |
| TC | 16 | 1 | DMA | Terminal Count: Indicates the termination of a DMA transfer when 1 (highi) |
| IDX | 17 | 1 | FDO | Index: Indicates the beginning of a disk track. |
| INT | 18 | 0 | $\mu \mathrm{P}$ | Interrupt: Interrupt Re quest Generated by FDC |
| CLK | 19 | 1 |  | Clock: Single Phase 8 MHz ( 4 MHz for mini floppies) Squarewave Clock |
| GND | 20 |  |  | Ground: D C Power Return |

Note 1 Disabled when $\overline{\mathrm{CS}}$,
Note 2 TC must be activated to terminate ine Execulion Phase ul any cormmand

| Symbol | Pln No. | Type | Connection To | Name and Function |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ | 40 |  |  | D.C. Power: + 5 V |
| $\bar{R} \bar{W}$ SEEK | 39 | $\bigcirc$ | FDD | Read Write/SEEK: When "1" (high) Seek mode selected and when " 0 " (low) Read! Write mode selected |
| LCTSIR | 38 | 0 | FDD | Low Current/Direction: Lowers Write current on inner tracks in Read/Write mode. determines direction head will step in Seek mode. |
| FR STP | 37 | 0 | FDD | Fault Reset/Step: Resets fault FF in FDD in Read Write mode, provides step pulses !o move head to another cylinder in Seek mode. |
| HDL | 36 | 0 | FDD | Head Load: Comntand which causes read/write head in FDD to contact diskette. |
| ROY | 35 | 1 | FDD | Ready: Indicates FDD is ready to send or receive data. Must be tied high (gated by the index pulse) for mini floppies which do not normally have a Ready line. |
| WP TS | 34 | 1 | FDD | Write Protect /TwoSide: Senses Write Protect status in Readi Write mode and Two Side Media in Seek mode |
| FLT TRK0 | 33 | 1 | FDD | Fault/Track 0: Senjes FDD fault condition in Read Write mode and Track 0 condition in Seek mode. |
| PS, $\mathrm{PS}_{0}$ | 31.32 | 0 | FDD | Precompensation (preshift): Write precompensation status duriig MFM mode Determines early late. and nom:al times |
| WR DATA | 30 | 0 | FDD | Write Data: Serial ciock and data bits 10 FDD |
| DS, DS | 28.29 | 0 | FDD | Drive Select: Selects FOD unit |
| HDSEL | 27 | 0 | FDD | Head Select: Head 1 selected when " $\dagger$ (high) Head 0 selected when " 0 " (low). |

Table 1. Pin Description (Continued)

| Symbol | Pin <br> No. | Type | Connec- <br> tion To | Name and Function |
| :--- | :---: | :---: | :---: | :--- |
| MFM | 26 | 0 | PLL. | MFM Mode: MFM mode <br> when "1." FM mode <br> when 0." |
| WE | 25 | 0 | FDD | Write Enable: Enables <br> write data into FDD |
| VCO | 24 | 0 | PLL | VCOSync: Inhibits VCO <br> in PL. when "0" (low) <br> enables VCO when "1. |
| RD DATA | 23 | 1 | FDD | Read Dats: Read data <br> from FDD, containing <br> clock and data bits |


| Symbol | Pin <br> No. | Type | Connec- <br> tion To | Name and Function |
| :---: | :---: | :---: | :---: | :--- |
| DW | 22 | 1 | PLL | Data Window: Gener- <br> ated by PLL. and used <br> to sample data from <br> FDD. |
| WR CLK | 21 | 1 |  | Write Clock: Write data <br> rate to FDD FM $=500$ <br> kHz, MFM -1 MHz. with <br> a pulse width of 250 ns <br> for both FM and MFM. <br> Must be enabled for ail |
| operations. both Read |  |  |  |  |
| and Write. |  |  |  |  |



Figure 3. 8272A System Block Diagram

## DESCRIPTION

Hand-shaking signals are provided in the 8272A which make DMA operation easy to incorporate with the aid of an external DMA Controller chip, such as the 8237A. The FDC will operate in either DMA or Non-DMA mode. In the Non-DMA mode, the FDC generates interrupts to the processor for every transfer of a data byte between the CPU and the 8272A. In the DMA mode, the processor need only load a command into the FDC and all data transfers occur under control of the 8272A and DMA controller.
There are 15 separate commands which the 8272A will execute. Each of these commands require multiple 8 -bit bytes to fully specify the operation which the processor wishes the FDC to perform. The following commands are available.

[^4]Scan High or Equal
Scan Low or Equal Specify

Track 0)
Sense Interrupt Status
Sense Drive Status

For more information see the Intel Application Notes AP-116 and AP-121.

## FEATURES

Address mark detection circuitry is internal to the FDC which simplifies the phase locked loop and read electronics. The track stepping rate, head load time, and head unload time may be programmed by the user. The 8272A offers many additional features such as multiple sector transfers in both read and write modes with a single command, and full IBM compatibility in both single (FM) and double density (MFM) modes.

## 8272A ENHANCEMENTS

On the 8272A, after detecting the Index Pulse, the VCO Sync output stays low for a shorter period of time. See Figure 4A.
On the 8272 there can be a problem reading data when Gap 4A is 00 and there is no IAM. This occurs on some older floppy formats. The 8272A cures this problem by adjusting the VCO Sync timing so that it is not low during the data field. See Figure 4B.


Figure 4. 8272A Enhancements over the 8272

## 8272A REGISTERS - CPU INTERFACE

The 8272A 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), 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 execution of a command. The Status Register may only be read and is used to facilitate the transfer of data between the processor and 8272A.

The relationship between the Status/Data registers and the signals $\overline{R D}, \overline{W R}$, and $A_{0}$ is shown in Table 2.
Table 2. $A_{0}, \overline{R D}, \overline{W R}$ decoding for the selection of Status/Data register functions.

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

Note: Design must guarantes that the 8272A is not subjected to illegal inputs.
The Main Status Register bits are defined in Table 3.

| bit number | name | symbol | description |
| :---: | :---: | :---: | :---: |
| Do | Fodo 0 日usy | $\mathrm{O}_{0} 8$ | FDD number 0 is in the Seek mode. |
| $\mathrm{O}_{1}$ | FDD 1 Busy | 0, 8 | FDD number 1 is in the Seek mode. |
| $\mathrm{D}_{2}$ | FDD 2 Busy | $\mathrm{O}_{2}{ }^{\text {B }}$ | FDD number 2 is in the Seek mode. |
| $\mathrm{D}_{3}$ | FDO 3 Busy | $\mathrm{D}_{3} \mathrm{~B}$ | FDD number 3 is in the Seek mode |
| $\mathrm{D}_{4}$ | FDC Busy | CB | A read or witte command is in process. |
| $\mathrm{D}_{5}$ | Non OMA mode | NOM | The FOC is in the non DMA mode This bit is set only dur. ing the execution phase in non-OMA mode. Transition to "0" state indicates execu:ion phase has ended. |
| $\mathrm{D}_{6}$ | Data Inputioulput | Dio | Indicates direction of dala ranster between FDC and Dta Register it $01 O=" 1 "$ then transter is from Data Register to the Processor If $\mathrm{DHO}=" 0$ ". essor to Data Register. |
| $\mathrm{O}_{7}$ | Request for Master | RQM | Indicates Data Register is ready to send or receive data to or from the Processor. Both bils DIO and ROM should be used to pertorm the handshaking functions of "ready and "direction" to the processor. |

The DIO and RQM bits in the Status Register indicate when Data is ready and in which direction data will be transferred on the Data Bus.
Note: There is a $12 \mu \mathrm{~S}$ or $24 \mu \mathrm{~S}$ RQM flag delay when using an 8 or 4 MHz clock respectively.


Figure 5. Status Register Timing
The 8272 A is capable of executing 15 different commands. Each command is initiated by a multi-byte transfer from the processor, and the resuit 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 8272A 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 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 information are made available to the processor.
During Command or Result Phases the Main Status Register (described in Table 3) must be read by the processor before each byte of information is written into or read from the Data Register. 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 8272A. 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 8272A. On the other hand, during the Result Phase, D6 and D7 in the Main Status Register must both be 1's (D6 = 1 and D7 $=1$ ) before reading each byte from the Data Register. Note, this reading of the Main Status Register before each byte transfer to the 8272A is required in onty 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 8272A is in the non-DMA Mode, then the receipt of each data byte (if 8272 A is reading data from FDD) is indicated by an Interrupt signal on pin 18 (INT = 1). The generation of a Read signal ( $R D=0$ ) will reset the Interrupt as well as output the Data onto
the Data Bus. For example, if the processor cannot handle Interrupts fast enough (every $13 \mu \mathrm{~s}$ for MFM 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.
The 8272A always operates in a multi-sector transfer mode. It continues to transfer data until the TC input is active. In Non-DMA Mode, the system must supply the TC input.
If the 8272A is in the DMA Mode, no Interrupts are generated during the Execution Phase. The 8272A generates DRQ's (DMA Requests) when each byte of data is available. The DMA Controller responds to this request with both a $\overline{D A C K}=0$ (DMA Acknowledge) and a $\overline{R D}=0$ (Read signal). When the DMA Acknowledge signal goes low $(\overline{\mathrm{OACK}}=0)$ then the DMA Request is reset $(\mathrm{DRQ}=0)$. If a Write Command has been programmed then a WR signal will appear instead of $\overline{R D}$. After the Execution Phase has been completed (Terminal Count has occurred) then an Interrupt will occur ( $\operatorname{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 ( $\mathrm{INT}=0$ ).

It is important to note that during the Result Phase all bytes shown in the Command Table must be 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 8272A 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 8272A 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 successfully 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 8272A to form the Command Phase, and are read out of the 8272A in the Result Phase, must occur in the order shown in the Table 4. 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 8272A, the Execution Phase

Table 4. 8272A Command Set


8272A

## Table 4. 8272A Command Set (Continued)



| SYMEOL | NAME | description |
| :---: | :---: | :---: |
| $A_{0}$ | Adoress Line 0 | $\mathrm{A}_{0}$ controis selection of Main Slatus Register ( $A_{0}=0$ ) or Data Repister ( $A_{0}=1$ ). |
| C | Cylinder Number | C stands for the current selected Cylinder track number 0 through 76 of the medium. |
| D | Data | 0 stands for the data pattern which is going to de written into a Sector. |
| $\mathrm{O}_{7}-\mathrm{D}_{0}$ | Data Bus | 8 -bit Data Bus where $D_{7}$ is the most stgniticant bit, and $D_{0}$ is the least signiflcant dit. |
| DSO. DS 1 | Drive Select | DS stends for a selected drive number 0 or 1. |
| DTL | Data Length | When $N$ is defined as $\infty$. DTL stands for the date length which users are going 10 read out or write into the Sector. |
| EOT | End of Track | EOT stends for the final Sector number of a Cyilinder. |
| GPL | Gap Lengin | GPL stands for the length of Gap 3 (spacing between Sectors excluding VCO Sync Flelo). |
| H | Head Address | H stands for head number 0 or 1 , as specitied in 10 fielo. |
| HDS | Head Select | HDS stands for a selected head number 0 of $1(\mathrm{H}=\mathrm{HDS}$ in all command words). |
| HLT | Head Load Time | HLT stands for the head logd time in the FOD ( $\mathbf{2}$ to $\mathbf{2 5 4} \mathrm{ms}$ in $\mathbf{2 m s}$ increments). |
| HUT | Head Unload Time | HUT stands for the head unload time after a read or write operation has occurred (16 10240 ms in 16 ms increments). |
| MFM | FM or MFM Mode | If MF is low. FM mode is selected and if it is high. MFM mode is selected |
| MT | Multi Track | II MT is nigh, a multitrack operation is to be performed (a cyllinder under both HDO and HD1 with be read or written). |
| $N$ | Number | N stands tor the number of dala bytes written in a Sector. |

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 8272A is ready for a new command. A command may be aborted by simply sending a Terminal Count signal to pin 16 (TC = 1). This is a convenient means of ensuring that the processor may always get the 8272A's attention even if the disk system hangs up in an abnormal manner.

## POLLING FEATURE OF THE 8272A

After power-up RESET, the Drive Select Lines DSO and DS1 will automatically go into a polling mode. In between commands (and between step pulses in the SEEK command) the 8272A polls all four FDDs 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 8272A will generate an interrupt. When Status Register 0 (STO) is read (after Sense Interrupt Status is issued), Not Ready (NR) will be indicated. The poliing of the Ready line by the 8272A occurs continuously between instructions, thus notifying the processor which drives are on or off line. Approximate scan timing is shown in Table 6.

Table 6. Scan Timing


## COMMAND DESCRIPTIONS

During the Command Phase, the Main Status Register must be polled by the CPU before each byte is written

| SYMBOL | NAME | DESCRIPTION |
| :---: | :---: | :---: |
| NCN | New Cylinder Number | NCN stands for a new Cylinder number. which is going to be reached as a result of the Seek operation. Desired position of Head. |
| ND | Non DMA Mode | ND stands for operation in the NON-DMA Mode. |
| PCN | Present Cytinder Number | PCN slands tor the Cytinder number at the completion ol SENSE INTERRUPT STATUS Command. Position of head at present time |
| R | Hecord | R slanas tor the Sector number, which will be read or written. |
| R/W | Read/Write | R/W stands for either Read (R) of Write (W) signal |
| SC | Sector | SC indicates the number of Sectors per Cylinder. |
| SK | Skip | SK stands for Skip Deleted Data Address Mark. |
| SRT | Step Rate Time | SAT stands for the Stepping Rate for the FOD it to 16 ms in 1 ms increments: The same Stepping Rate apolies to all drives ( $\mathrm{F}-1 \mathrm{~ms}$. E-2 ms etc) |
| $\begin{aligned} & \text { STO } \\ & \text { ST } 1 \\ & \text { ST } 2 \\ & \text { ST } 3 \end{aligned}$ | Status 0 Stalus 1 Stalus 2 Stalus 3 | ST $0-3$ stand for one of lour registers which store the status information after a command has been executed This information is available dufing the result phase after command execulion. These registers should not be confused with the main status regisier (selected by $\mathrm{A}_{\mathrm{O}}=0$ ). ST 0-3 may be read only after a command has been executed and contain information relevant to that particular command |
| STP |  | During a Scan operation, it STP $=1$, the data in contiguous sectors is compared byte by byte with data sent from the processor (or DMA), and it STP $=2$, then alternate sectors are read and compared |

into the Data Register. The DIO (DB6) and RQM (DB7) bits in the Main Status Register must be in the " 0 " and " 1 " states respectively, before each byte of the command may be written into the 8272A. The beginning of the execution phase for any of these commands will cause DIO and RQM to switch to " 1 " and "0" states respectively.

## 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 ("R") 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-bybyte 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 must be terminated by the receipt of a Terminal Count signal. 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 (multi-track), MFM (MFM/FM), and N (Number of Bytes/Sector). Table 7 on the next page shows the Transfer Capacity.

Table 7. Transfer Capacity

| Multi-Track MT | $\underset{\text { MFM }}{\text { MFM }}$ | $\begin{aligned} & \text { Bytez/Sector } \\ & N \end{aligned}$ | Maximum Tranafor Capacily (Bytew/Section (Number of Sectort) | Final Sactor Read from Diakette |
| :---: | :---: | :---: | :---: | :---: |
| 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$ |  |
| 1 | 1 | 01 | $(256)(52)=13.312$ | 26 al side । |
| 0 | 0 | 01 | $(256)(15)=3.840$ | 15 at side 0 |
| 0 | 1 | 02 | $(512)(15)=7,680$ | or 15 al Side 1 |
| 1 | 0 | 01 | $(256)(30)=7,680$ |  |
| 1 | 1 | 02 | $(512)(30)=15,360$ | 15 at Side ${ }^{\text {a }}$ |
| 0 | 0 | 02 | $(512)(8)=4.096$ | 8 at Side 0 |
| 0 | 1 | 03 | $(1024)(8)=8,192$ | or 8 at Side 9 |
| 1 | 0 | 02 | $(512)(16)=8,192$ | 8 at Side |
| , | 1 | 03 | $(1024)(16)=16.384$ | 8 at Side 1 |

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 1 (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 OFFH.
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 " A "), 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 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 6 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 ( $\mathrm{SK}=0$ ), then the FDC sets the CM (Con. trol 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 $S K=1$, the FDC skips the sector with the Deleted Data Address Mark and reads the next sector.

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$ 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 5 shows the values for $C, H, R$, and $N$, when the processor terminates the Command.

Table 8. ID Information When Processor Terminates Command

| MT | EOT | Final Sector Traneferted to Proceasor |
| :---: | :---: | :---: |
| 0 | $\begin{aligned} & 1 A \\ & \text { OF } \\ & 08 \end{aligned}$ | Sector ; 1025 at Side 0 <br> Sector 1 10 14 at Side 0 <br> Sector 1 to 7 al side 0 |
|  | $\begin{aligned} & 1 \mathrm{~A} \\ & 0 F \\ & 08 \end{aligned}$ | Sector 26 al Side 0 Sector 15 at Side 0 Sector 8 at Side 0 |
|  | $\begin{aligned} & 1 A \\ & 0 F \\ & 0 B \\ & 1 A \\ & \text { OF } \\ & 08 \end{aligned}$ | Sector 1 to 25 at Side 1 <br> Sector 1 to 14 at Side 1 <br> Sector 1 to 7 at Side I <br> Sector 26 at Side 1 <br> Sector 15 at Side : <br> Sector 8 al Side: |
| 1 | $1 A$ $0 F$ 08 | Sector 1 to 25 at Side 0 <br> Scctor 1 to 14 at Side 0 <br> Sector 1 to 7 al Side 0 |
|  | $1 A$ $0 F$ 08 | Sector 26 al Side 0 Sector 15 at Side 0 Sector 8 at Side 0 |
|  | 1A 0 F 08 | Sector 1 to 25 at Side 1 <br> Sector: 10 14 at Side 1 <br> Sector 1 10 7 al Side 1 |
|  | $1 A$ OF O8 | Sector 26 at Side , Sector 15 at Side, Sector 8 at Side ? |


Notes 1 NC (NO Change) The same value as the one at the beginning ol command execution.
2. LSB (Leasi Signiticant Bith 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 the current sector number ("R"). stored in the ID Register (IDR) compares with the sector
number read off the diskette, then 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 'he CRC bytes. If the FDC detects a read error (incorrect CRC) in one of the ID Fields, it sets the DE (Data Error) flag of Status Register 1 to a 1 (high), and terminates the Write Data Command. (Status Register 0 also has bits 7 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, reter to the Read Data Command for details:

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

In the Write Data mode, data transfers between the processor and FDC must occur every $31 \mu \mathrm{~s}$ in the FM mode, ar. every $15 \mu \mathrm{~s}$ in the MFM mode. If the time interval between data transters 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.
For minifloppies, multiple track writes are usually not permitted. This is because of the turr-off time of the erase head coils-the head switches tracks before the erase head lurns off. Therefore the system should typically walt 1.3 mS before attempting to step or cnange sides.

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

Tris 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 $S K=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 the entire data field is read continuously from each of the sectors of a track 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 ND 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.
This command terminates when EOT number of sectors have been read. 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 $I \mathbb{N}$ DEX 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) and the command is terminated.

## 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$ iNumber of Bytes/Sector). This allows the diskette to be formatted with nonsequential sector numbers, if desired.

After formatting each sector, the processor must send new values for $\mathrm{C} . \mathrm{H}, \mathrm{R}$, and N to the 8272A for each sec. tor on the track. The contents of the R Register is incremented by one after each sector is formatted, thus, the $R$ register contains a value of $R+1$ when it is read during the Result Phase. This incrementing and formatting continues for the whole track until the FDC en. counters the INDEX HOLE for the second time where. upon it terminates the command.

If a FAULT signal is received from the FDD at the end of a write oderation. 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 command termination.

Table 9 shows the relationship between N, SC, and GPL for various sector sizes:

Table 9. Sector Size Relationships.
8- STANDARD FLOPPY
51/4 MINI FLOPPY

| FORMAT | SECTOR SIZE | $\cdots$ | Sc | GPL ${ }^{1}$ | GPL ${ }^{2}$ | REMARKS | SECTOR SIZE | N | SC | GPL ${ }^{\prime}$ | GPL ${ }^{2}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FM Mode | 128 DytesiSector | 00 | 1A | 07 | 18 | IBM Diskette 1 | 128 bymesisector | 00 | 12 | 07 | 09 |
|  | 256 | 01 | OF | OE | 2 A | (BM Diskette 2 | 128 | 00 | 10 | 10 | 19 |
|  | 512 | 02 | 08 | 1 B | 3 A |  | 256 | 01 | 08 | 18 | 30 |
|  | 1024 | 03 | 04 | 47 | 8A |  | 512 | 02 | 04 | 46 | 87 |
|  | 2048 | 04 | 02 | C8 | FF |  | 1024 | 03 | 02 | CB | FF |
|  | 4096 | 05 | 01 | C8 | FF |  | 2048 | 04 | 01 | Cs | FF |
| MPM Mode | 256 | 0. | 1 A | OE | 36 | IBM Diskette 20 | 256 | 01 | 12 | 0 A | OC |
|  | 512 | 02 | OF | 1B | 54 |  | 256 | 01 | 10 | 20 | 32 |
|  | 1024 | 03 | 08 | 35 | 74 | IBM Oiskette 20 | 512 | 02 | 08 | 2 A | 50 |
|  | 2048 | 04 | 04 | 99 | FF |  | 1024 | 03 | 04 | 80 | F0 |
|  | 4096 | 05 | 02 | C8 | FF |  | 2048 | 04 | 02 | C8 | FF |
|  | 8192 | 06 | 01 | Ca | FF |  | 4096 | 05 | 01 | c8 | FF |

Note: 1 Suggested values of GPL in Fead or Write Commands to avoid splice point between data field and iD field of contiguous sections
2 Suggested values of GPL in format command

## SCAN COMMANDS

The SCAN Commands allow data which is being read from the diskette to be compared against data which is being supplied from the main system (Processor in NON-DMA mode, and DMA Controller in DMA mode). The FDC compares the data on a byte-by-byte basis, and looks for a sector of data which meets the conditions of $D_{\text {FDD }}=D_{\text {Processor }} \mathrm{D}_{\text {FDD }} \leqslant D_{\text {Processor }}$, or $\mathrm{D}_{\text {FDD }} \geqslant$ DProcessor 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 incremented ( $R+$ STP $\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, low, 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 command. Table 10 shows the status of bits SH and SN under various conditions of SCAN

Table 10. Scan Status Codes

| COMMAND | Status register 2 |  | COMMENTS |
| :---: | :---: | :---: | :---: |
|  | BII $2=5 \mathrm{~N}$ | BIT $3=5 \mathrm{H}$ |  |
| Scan Equal | $0$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{D}_{\text {FDO }}=\text { D Processor } \\ & \mathrm{D}_{\text {FDO }} \neq \text { Dprocesso }^{\prime} \end{aligned}$ |
| Scan Low or Equal | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{D}_{\text {FDO }}=\mathrm{D}_{\text {Processor }} \\ & \mathrm{D}_{\text {FDO }} \mathrm{DP}_{\text {Processor }} \\ & \mathrm{D}_{\text {FOD }} \text { DProcesssor } \end{aligned}$ |
| Scantighor Equal | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ |  |

If the FDC encounters a Deleted Data Address Mark on one of the sectors (and $S K=0$ ), then it regards 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 STP $=01$, or alternate sectors STP $=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 $S T P=02, M T=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 sector (26) will be skipped and the Index Hole will be en. countered 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 terminates the command

## SEEK

The read/write head within the FDD is moved from cylinder to cylinder under control of the Seek Command. The FDC compares the PCN (Present Cylinder Number) which is the current head position with the NCN (New Cylinder Number), and performs the following operation if there is a difference:

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.

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 parallet seek operations may be done on up to 4 Drives at once.

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.

Note that the 8272A Read and Write Commands do not have implird Seeks. Any R/W command should be preceded by: 1) Seek Command; 2) Sense Interrupt Status; and 3) Read ID.

## RECALIBRATE

This command causes the read/write head within the FDD to retract 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 1 (high) 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 Puises have been issued, the FDC sets the SE (SEEK END) and EC (EQUIP. MENT CHECK) flags of Status Register 0 to both 1 s (highs), and terminates the command.
The ability to overlap RECALIBRATE Commands to multiple FDDs, 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
b. Read a Track Command
c. Read ID Command
d. Read Deleted Data Command
e. Write Data Command
f. Format a Cylinder Command
g. Write 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 discernible by the processor. However, 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 the cause of the interrupt.

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 of the head position (PCN).

Table 11. Seek, Interrupt Codes

| SEEK END <br> BIT 5 | INTERRUPT CODE | CAUSE |  |
| :---: | :---: | :---: | :--- |
| 0 | 1 | 1 | Ready Line changed <br> BIT 6 |
| BIT 7 |  |  |  |
| 1 | 0 | 0 | Normal Termination either polarity <br> of Seek or Recalibrate <br> Command |
| 1 | 1 | 0 | Abnormal Termination of <br> Seek or Recalibrate <br> 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}(01=16 \mathrm{~ms}, 02=32 \mathrm{~ms} \ldots$ OF $=$ 240 ms ). The SRT (Step Rate Time) defines the time inierval between adjacent step pulses. This timer is programmable from 1 to 16 ms in increments of $1 \mathrm{~ms}(F=1$ $\mathrm{ms}, \mathrm{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}(01=2 \mathrm{~ms}, 02=4 \mathrm{~ms}, 03=6 \mathrm{~ms} \ldots$ $F E=254 \mathrm{~ms}$ ).

The step rate should be programmed 1 mS ionger than the minimum time required by the drive.

The time intervals mentioned above are a direct function of the clock (CLK on pin 19). Times indicated above are for an 8 MHz clock, if the clock was reduced to 4 MHz (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 $(N D=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.

## INVALID

If an invalid command is sent to the FDC (a command not defined above), then the FDC will terminate the command. No interrupt is generated by the 8272A during this condition. Bit 6 and bit 7 ( OIO and RQM) in the Main Status Register are both high (" 1 ") indicating to the processor that the 8272A is in the Result Phase and the contents of Status Register 0 (STO) must be read. When the processor reads Status Register 0 it will find an 80 H 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.

## Table 12. Status Registers



| BIt |  |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| STATUS REGISTER 1 (CONT.) |  |  |  |
|  |  |  |  |  |
| D 1 | Not Writable | NW | During execution of WRITE DATA, WRITE DELETED DATA or Format A Cylinder Command, it the FDC detects a write protect signal from the FDO, then this flag is set. |
| $\mathrm{D}_{0}$ | Missing <br> Address <br> Mark | MA | If the FDC cannol detect the ID Address Mark after encountering the index hole iwice, then this tlag is set. |
|  |  |  | II the FOC cannot detect the Data Address Mark or Deleted Data Address Mark, this flag is set Also at the same time, the MD iMissing Address Mark in Data Fie!d) of Status Register 2 is set. |
| StATUS REGISTER 2 |  |  |  |
| $\mathrm{D}_{7}$ |  |  | Not used This bit is always 0 (low) |
| $\mathrm{O}_{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, This flag is set |
| $\mathrm{D}_{5}$ | Data Error in Data Field | OD | It the FDC detects a CRC error in the data field then this fiag is set |
| $\mathrm{D}_{4}$ | Wrong Cylinder | WC | This bit is related with the NO 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}$ | $\begin{aligned} & \text { Scan Equal } \\ & \text { Hit } \end{aligned}$ | SH | During execution the SCAN Command it the condition of equal" is satisfied. this "lag is set. |
| $\mathrm{D}_{2}$ | Scan Not Satislied | SN | During executing the SCAN Command, it the FDC cannot find a Sector on the cylinder which meets the condrtion then this llag is set |
| D, | Bad <br> Cylinder | BC | This bit is related with the ND bit. and when the content of C on the medium is different trom that stored in the IDR and the content of $C$ is i FF. then this tlag is set |
| $\mathrm{D}_{0}$ | Missing <br> Address <br> Mark in Data <br> Field | MD | When data is read from the medium. it the FDC cannot lind a Data Address Mark or Deleted Data Address Mark, then this flag is set. |
|  |  | Status | S REGISTER 3 |
| D7 | Fault | FT | This bit is used to indicate the status of the Fault signal from the FDO |
| $\overline{\mathrm{O}}_{6}$ | Write Protected | WP | This bit is used to indicate the I status of the Write Protected signal from the FDD. |
| $\mathrm{D}_{5}$ | Ready | ROY | This bit is used to indicate the status of the Ready signal trom the FDD. |
| 04 | Track 0 | T0 | This bit is used to indicale the slatus of the Track 0 signal from the FDD. |
| $\mathrm{O}_{3}$ | Two Side | TS | This bit is used to indicate the status of the Two Side signa! from the FDD. |
| $\mathrm{D}_{2}$ | Head <br> Address | HD | This bit is used to indicate the status of Side Select signal to the FDD |
| $\mathrm{D}_{1}$ | Unit Select 1 | US 1 | This bil is used to indicate the status of the Unit Select 1 signal to the FDD |
| $\mathrm{D}_{0}$ | Unit Selecto | USO | This bit is used to indicate the status of the Unit Select 0 signal to the FDO. |

## ABSOLUTE MAXIMUM RATINGS*

Operating Temperature
Storage Temperature All Output Voltages All Input Voltages
Supply Voltage $V_{C C}$
Power Dissipation
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
-0.5 to +7 Volts
-0.5 to +7 Volts

| -0.5 to +7 Volts |
| :--- |
| Watt |

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

NOTICE: Stress above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functionaloperation 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
D.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| $V_{16}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $V_{\text {IH }}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | $\mathrm{V}_{\text {CC }}$ | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 120 | mA |  |
| 112 | Input Load Current (All Input Pins) |  | $\begin{gathered} 10 \\ -10 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \\ & V_{I N}=O V \end{aligned}$ |
| $\mathrm{I}_{\mathrm{LOH}}$ | High Level Output Leakage Current |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ |
| 'OFL | Output Float Leakage Current |  | - 10 | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\mathrm{CC}}$ |

## CAPACITANCE $\left(\mathrm{T}_{\mathbf{A}}=25^{\circ} \mathrm{C}, \mathrm{f}_{\mathrm{C}}=1 \mathrm{MHZ}, \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| $\mathrm{C}_{\text {(N(¢) }}$ | Clock Input Capacitance |  | 20 | pF | All Pins Except |
| $\mathrm{ClN}_{\text {IN }}$ | Input Capacitance |  | 10 | pF | Pin Under Test |
| $\mathrm{Cl}_{1 / \mathrm{O}}$ | Input/Output Capacitance |  | 20 | pF | Ground |

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

| Symbol | Parameter | Min. | Max. | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{1} \mathrm{CY}$ | Clock Period | 120 | 500 | ns | Note 5 |
| ${ }^{\text {ICH}}$ | Clock High Period | 40 |  | ns | Note 4, 5 |
| TRST | Resel Width | 14 |  | tcr $Y$ |  |

## AEAD CYCLE


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

| Symbol | Parameter | Typ. ${ }^{1}$ | Min. | Max. | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| :AW | Select Setup to WR. |  | 0 |  | ns |  |
| twa | Select Hold from WF. |  | 0 |  | ns |  |
| IWW | $\overline{\text { WR }}$ Pulse Width |  | 250 |  | ns |  |
| 10w | Data Selup to $\bar{W} \bar{R}$. |  | 150 |  | nis |  |
| Iwo | Data Hold trom WA. |  | 5 |  | ns |  |

## INTERRUPTS



| DMA |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| trocy | DRQ Cycle Period | 13 |  | $\mu \mathrm{S}$ | Note 6 |
| IAKRO | DACK. 10 ORQ. |  | 200 | ns |  |
| 1ROR | DRQ ${ }^{\text {to }} \overline{\mathrm{RD}}$. | 800 |  | ns | Note 6 |
| IROW | ORQ' to WIT. | 250 |  | ms | Note 6 |
| IRORW | DRO ${ }^{\text {to }} \overline{\mathrm{RD}}$. or WF. |  | 12 | $\mu s$ | Note 6 |

FDD INTERFACE

| ${ }^{\text {WhCr }}$ | WCK Cycle Time | $\begin{aligned} & 2014 \\ & 1012 \end{aligned}$ |  |  | $\mu$ | $\begin{aligned} & \text { MFM }=0 \text { Note 2 } \\ & \text { MFM }=1 \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1WCH | wCK High Time | 250 | 80 | 350 | ns |  |
| tCP | Pre Snift Delay from WCK. |  | 20 | 100 | ns |  |
| tCD | WDA Delay trom WCK' |  | 20 | 100 | ns |  |
| IWDD | Write Dala Widin |  | IWCH 50 |  | ns |  |
| twe | WE' to WCK. or WE. to WCK. Delay |  | 20 | 100 | ns |  |
| 'wwey | Window Cucle Time | $\begin{aligned} & 2 \\ & 1 \end{aligned}$ |  |  | 45 | $\begin{aligned} & \text { MFM }=0 \\ & \text { MFM }=1 \end{aligned}$ |
| twRO | Window Selup to RDD* |  | 15 |  | ns |  |
| LRDW | Window Hold rrom RDD. |  | 15 |  | ns |  |
| IRDD | RDD Active Time (HIGH) |  | 40 |  | ns |  |

## FDD SEEKIDIRECTIONISTEP

| IUS | USO, Setup to RWSEEK. |  | 12 |  | $\mu \mathrm{s}$ | Note 6 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| isu | US 01 Hold atler RWISEEK. |  | 15 |  | $\mu \mathrm{S}$ | Note 6 |
| ISD | RWISEEK Selup to LCTIDIR |  | 7 |  | $\mu$ | Note 6 |
| cos | AW/SEEK Hold from LCTIDIA |  | 30 |  | $\mu \mathrm{s}$ | Nole 6 |
| tost | LCT/DIR Setup to FRISTEP* |  | 1 |  | $\mu \mathrm{S}$ | Nole 6 |
| ${ }^{\text {'STD. }}$ | LCT/DIR Hold from FRISTEP. |  | 24 |  | $\mu \mathrm{s}$ | Note 6 |
| tSTU | DS 2 , Hold from FRiStep. |  | 5 |  | $\mu \mathrm{S}$ | Note 6 |
| STP | STEP Active Time (High) | 5 |  |  | $\mu$ | Note 6 |
| 1SC | STEP Cycle Time |  | 33 |  | $\mu s$ | Note 3.6 |
| IFR | FAULT RESET Active Time (Hight |  | 8 | 10 | $\mu \mathrm{S}$ | Note 6 |
| $10 x$ | INDEX Pulse Width | 10 |  |  | tor |  |
| TTC | Terminal Count Width |  | 1 |  | ICY |  |

## NOTES:

1. Typical values for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nonzinal supply voltage
2. The former values are used tor standard floppy and the latter values are used for mini-floppies.
3. ISC $=33 \mu \mathrm{~s} \mathrm{~min}$, is for dilferent drive units In the case of same unit, ISC can be ranged from 1 ms to 16 ms with a MHz ctock period. and 2 ms 1032 ms with 4 MHz clock. under software control.
4. From $2.0 \mathrm{~V} 10+2.0 \mathrm{~V}$
5. At 4 MHz , the clock duty cycle may range from $16 \%$ to $76 \%$. Using an 8 MHz clock the duty cycle can range from $32 \%$ to $52 \%$. Duty cycle is defined as: $D . C=100(t \mathrm{CH}-\mathrm{CY})$ with typical rise and fall times of 5 ns .
6. The specified values listed ate for an 8 MHz clock period. Multiply timings by 2 when using a 4 MHz clock period.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS



## inter

WAVEFORMS (Continued)


## WAVEFORMS (Continued)


fDD WRITE OPERATION


|  | PRESHIFT | PRESHIFT 1 |
| :--- | :---: | :---: |
| NORMAL | 0 | 0 |
| LATE | 0 | 1 |
| EARLY | 1 | 0 |
| INVALID | 1 | 1 |

8272A PRELOMONARY

WAVEFORMS (Continued)

## SEEK OPERATION



WAVEFORMS (Continued)


## CUSTOM LOGIC CIRCUITS

TYPE SN76494, SN76496
PROGRAMMABLE TONE/NOISE GENERATOR
D2801. NOVEMBER 1883

```
- Each Circuit Contains
    3 Programmable Tone Generators
- Programmable White-Noise Generator
- Programmable Attenuation
- Simultaneous Sounds
- TTL-Compatible
- Up to 500 kHz Clock Input for SN76494
    and 4 MHz for SN76496
- External Audio Input for SN76496 May Be Summed with Internally Generated Tones
```


## description

The SN76494 digital complex sound generator is an integrated injection logic ( $\mathbf{I}^{2} L$ ) tone generator designed to provide low-cost tone or noise generation capability in microprocessor systems. The SN76494 is a data-bus-based inputoutput peripheral device that interfaces the microprocessor through eight data lines and three control lines.

The SN76494 is identical to the SN76496 except that the maximum clock input frequency for SN76494 is 500 kHz and for SN76496 it is 4 MHz . A "divide-by-eight" stage is deleted from the SN76496 circuitry so that only 4 clock pulses are required to load the data into the SN76494, compared to 32 pulses for the SN76496.

Either of these devices may also be used as a replacment for the SN76489A in all applications if pin 9 is left open or grounded. The output load must be limited to 10 mA .
When audio input is not desired in the SN76494 or SN76496, the audio input pin should be grounded.

## functional block diagram



Copyright C1983 by Texas Instruments incorporated
Texas
INSTRUMENTS

## TYPE SN76494, SN76496 <br> PROGRAMMABLE TONE/NOISE GENERATOR

## schematics of inputs and outputs


absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage. $\mathrm{V}_{\mathrm{CC}}$ (see Note ${ }^{1)}$ ..... 15 VInput voltage, $\mathrm{V}_{\mathbf{F}}$ :
Audio input ..... 0.9 V
All other inputs. ..... $7 V$
Output current at pin 7 ..... 10 mA
Continuous total power dissipation at (or below) $\mathbf{2 5}^{\circ} \mathrm{C}$ free-air temperature (see Note $\mathbf{2}$ ..... 1150 mW
Operating free-air temperature range ..... $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range ..... $-55^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Lead temperature 1.6 mm ( $1 / 16 \mathrm{inch}$ ) from case for 10 seconds ..... $260^{\circ} \mathrm{C}$
recommended operating conditions

|  |  | SN76494 |  |  | SN76496 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MiN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | $V$ |
| $\mathrm{V}_{\mathrm{H}} \mathrm{H}$ | High-level input voltage | 2 |  |  | 2 |  |  | $V$ |
| $\mathrm{V}_{11}$ | Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
|  | Audio input current | 0 |  | 1.8 | 0 |  | 1.8 | mA |
| VOH | High-level output voltage (pin 4) |  |  | 5.5 |  |  | 5.5 | V |
| OL | Low-level output current (pin 4) |  |  | 2 |  |  | 2 | mA |
| flack | Input clock frequency |  |  | 0.5 |  |  | 4 | MHz |
| (d) WE) | Delay time, CE low to WE Iow | 0 |  |  | 0 |  |  | ns |
| ${ }_{\text {t }}$ u | Setup time, data before WE ! | 0 |  |  | 0 |  |  | ns |
| $t_{\text {h }}$ | Holdtime, data after READY 4 | 0 |  |  | 0 |  |  | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free -air temperature | 0 |  | 70 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

NOTES: I All voltage values are with respect to network ground terminal.
2 For operation above $25^{\circ} \mathrm{C}$ free-air temperature linearly at the rate of $9.2 \mathrm{nW} /{ }^{\circ} \mathrm{C}$

TYPE SN76494, SN76496
PROGRAMMABLE TONE/NOISE GENERATOR
electrical characteristics over recommended ranges of supply voltage and operating free-air temperature range (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | MiN | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 OH | High-level output current (pin 4) |  |  |  |  | 10 | $\mu \mathrm{A}$ |
| OL | Low-level output current (except pin 4) |  |  |  |  | 2 | mA |
| 4 | Input current | CE input | $\mathrm{V}_{1}=0$ to $\mathrm{V}_{\mathrm{Cc}}$ |  | -25 | -175 | $\mu \mathrm{A}$ |
|  |  | All other inputs |  |  | -10 | -70 |  |
| $V_{18}$ | Input bias voltage, audio |  | $R=4.7 \mathrm{k} \Omega$ pin 9 to $V_{C C}$ | 0.5 | 0.7 | 0.9 | $V$ |
| VOH | High-level output voltage (except pin 4) |  |  |  |  | 5.5 | V |
| VOL | Low-level output voltage |  |  |  | 0.25 | 0.4 | $v$ |
| cc | Supply current |  |  |  | 30 | 50 | mA |
|  | Attenuator | 2 dB NOM |  | 1 | 2 | 3 | dB |
|  |  | 4 dB NOM |  | 3 | 4 | 5 |  |
|  |  | 8 dB NOM |  | 7 | 8 | 9 |  |
|  |  | 16 dB NOM |  | 15 | 16 | 17 |  |
| $\mathrm{C}_{\mathrm{i}}$ | Input capacitance |  |  |  |  | 15 | pF |

switching characteristics, $V_{C C}=5 \mathrm{~V} . \mathrm{T}_{A}=25^{\circ} \mathrm{C}$

|  | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 4PHL | Progagation delay time, high-to-low level READY output from $\overline{\mathbf{C E}}$ | $C_{L}=225 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=2 \mathrm{k} \Omega$ to V CC |  | 90 | 150 | ns |

## PARAMETER MEASUREMENT INFORMATION



FIGURE 1 - tPhL TEST CJRCUIT

## TYPE SN76494, SN76496 PROGRAMMABLE TONE/NOISE GENERATOR

## pin assignments and functions

| SIGNATURE | PIN | 1/0 | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\overline{\text { CE }}$ | 6 | IN | Chip Enable - when active (low) data may be transferred from CPU to the SN76494 or SN76496. |
| D0 (MSB) | 3 | in | DO through D7 - Input data bus through which the control data is input. |
| D1 | 2 | in |  |
| D2 | 1 | IN |  |
| D3 | 15 | in |  |
| D4 | 13 | IN |  |
| D5 | 12 | in |  |
| D6 | 11 | in |  |
| D7 (LSB) | 10 | IN |  |
| $\mathrm{v}_{\text {cc }}$ | 16 | in | Supply Voltage ( 5 V nom) |
| GND | 8 | OUT | Ground Reference |
| CLOCK | 14 | IN | Input Clock |
| $\bar{W} E$ | 5 | in | Write Enable - when active (low), $\overline{\text { WE }}$ indicates that data is available from the CPU to the SN76494 or SN76496. |
| READY | 4 | OUT | When active (high). READY indicates that the data has been read. When READY is low, the microprocessor should enter a wait state until READY is high. |
| AUDIO IN | 9 | IN | Audio input from external source |
| AUDIO OUT | 7 | OUT | Audio Drive Out |

PRINCIPLES OF OPERATION

## tone generators

Each tone generator consists of a frequency synthesis section and an attenuation section. The frequency synthesis section requires 10 bits of information (FO-F9) to define haff the period of the desired frequency ( f ). FO is the most significant bit and $\mathbf{F 9}$ is the least significant bit. This information is loaded into a $\mathbf{1 0}$-stage tone counter, which counts down at an $N / 2$ rate where $N$ is the input clock frequency. When the tone counter counts down to zero, a borrow signal is produced. This borrow signal toggles the frequency flip-flop and also reloads the tone counter. Thus, the period of the desired frequency is twice the value of the period register.
The frequency can be calculated by the following:

$$
f=\frac{N}{4 n}
$$

where Na clock in Hz

$$
n=10 \text {-bit binary number }
$$

The output of the frequency flip-flop feeds into a four stage attenuator. The attenuator values, along with their bit position in the data word, are shown in Table 1. Multiple attenuation control bits may be true simultaneousiy. Thus, the maximum attenuation is $\mathbf{2 8 ~ d b}$.

TABLE 1 - ATTENUATION CONTROL

| BIT POSITION |  |  |  | WEIGHT |
| :---: | :---: | :---: | :---: | :---: |
| AO | A1 | A2 | A3 | (in dB) |
| 0 | 0 | 0 | 1 | 2 |
| 0 | 0 | 1 | 0 | 4 |
| 0 | 1 | 0 | 0 | 8 |
| 1 | 0 | 0 | 0 | 16 |
| 1 | 1 | 1 | 1 | OFF |

## TYPE SN76494, SN76496 PROGRAMMABLE TONE/NOISE GENERATOR

## noise generator

The noise generator consists of a noise source and an attenuator. The noise source is a shift register with an exclusive OR-feedback network. The feedback network has provisions to protect the shift register from being locked in the zero state.

TABLE 2 - NOISE FEEDBACK CONTROL

| FEEDBACK | CONFIGURATION |
| :---: | :--- |
| 0 | "Periodic" noise |
| 1 | 'White" noise |

Whenever the noise control register is changed, the shift register is cleared. The shift register will shift at one of four rates as determined by the two NF bits. The fixed shift rates are derived from the input clock.

$$
\text { TABLE } 3 \text { - NOISE GENERATOR FREQUENCY CONTROL }
$$

| BITS | SHIFT RATE |  |
| :---: | :---: | :---: |
| NFO | NF1 |  |
| 0 | 0 | $N / 64$ |
| 0 | 1 | $N / 128$ |
| 1 | 0 | N/256 |
| 1 | 1 | Tone generator $\# 3$ output |

The output of the noise source is connected to a programmable attenuator as shown in Figure 4.

## output buffer/amplifier

The output buffer is a conventional operational amplifier summing circuit. It sums the three tone generator outputs. the noise generator output, and any audio input through pin 9 . The output buffer will generate up to 10 mA .

To prevent oscillations in the output buffer, the output (pin 7 ) should be decoupled. This is done by putting 10 ohms in series with $0.1 \mu \mathrm{~F}$ from pin 7 to ground (see figure 3 ).

## data transfer

The microprocessor selects the SN76494 by taking $\overline{C E}$ low (low voltage). Unless $\overline{C E}$ is low, no data transfer can occur. When $\overline{C E}$ is low, the $\bar{W} \bar{W}$ signal strobes the contents of the data bus to the appropriate control register. The data bus contents must be valid at this time.
The SN76494 requires approximately four clock cycles to load the data into the control register. The SN76496 requires approximately 32 clock cycles. The open-collector READY output is used to synchronize the microprocessor to this transfer and is pulled to the false state (low) immediately following the falling edge of $C E$. It is required to go to the true state (high) when the data transfer is completed. The data transfer timing is shown below.


FIGURE 2 - DATA TRANSFER TIMING

## TYPE SN76494, SN76496 PROGRAMMABLE TONE/NOISE GENERATOR



FIGURE 3 - EXTERNAL AUDIO OUTPUT INTERFACE

NOTE 3: The capacitance values of Cl and C 2 are determined by the frequency response desired and the audio emplifier used.

## TYPE SN76494, SN76496 PROGRAMMABLE TONE/NOISE GENERATOR

TABLE 5 - FUNCTION TABLE

| INPUTS |  | OUTPUT | This table is valid when the device is: |
| :---: | :---: | :---: | :---: |
| $\overline{C E}$ | $\overline{W E}$ | READY |  |
| L | L | L | (1) not being clocked, and |
| L | H | L | (2) is initialized by pulling WE |
| H | L | H | and CE high. |
| H | H | H |  |

## CPU interface to SN76494/SN76496

The microprocessor interfaces with the SN76494 by means of the eight data lines and three control lines ( $\overline{\mathrm{WWE}}, \overline{\mathrm{CE}}$ and READY). Each tone generator requires 10 bits of information to select the frequency and four bits of information to select the attenuation. A frequency update requires a double-byte transfer, while an attenuator update requires a single-byte transfer.

If no other control registers on the chip are accessed, a tone generator may be rapidly updated by initially sending both bytes of frequency and register data, followed by just the second byte of data for succeeding values. The register address is latched on the chip. so the data will continue going into the same register. This allows the six most significant bits to be quickly modified for frequency sweeps.
control registers
The SN76494 and SN76496 have eight internal registers that are used to control the $\mathbf{3}$ tone generators and the noise source. During all data transfers to the SN76494 or SN76496, the first byte contains a three-bit field that determines the destination control register. The register address codes are shown in Table 4.

TABLE 4 - REGISTER ADDRESS FIELD

| RO | R1 | R2 | DESTINATION <br> CONTROL REGISTER |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | Tone 1 Frequency |
| 0 | 0 | 1 | Tone 1 Attenuation |
| 0 | 1 | 0 | Tone 2 Frequency |
| 0 | 1 | 1 | Tone 2 Attenuation |
| 1 | 0 | 0 | Tone 3 Frequency |
| 1 | 0 | 1 | Tone 3 Attenuation |
| 1 | 1 | 0 | Noise Control |
| 1 | 1 | 1 | Noise Attenuation |

data formats
The formats required to transfer data are shown below


|  | REG ADDR |  |  |  | SHIFT |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | RO | R1 | R2 | $\mathbf{x}$ | FB | NFO | NFI |
| BIT 0 |  |  |  |  |  |  |  |

UPDATE ATTENUATOR (SINGLE BYTE TRANSFER)

|  REG ADDR  DATA     <br> 1 RO R1 R2 AO A1 A2 A3 |
| :--- |
| BIT 0 |

## TYPE SN76494, SN76496 <br> PROGRAMMABLE TONE/NOISE GENERATOR

## N package

This dual-in-line package consists of a circuit mounted on a $\mathbf{1 6 - l e a d}$ frame and encapsulated within an electrically nonconductive plastic compound. The compound will withstand soldering temperature with no deformation and circuit performance characteristics remain stable when operated in high-humidity conditions. The package is intended for insertion in mounting-hole rows on 0.300 -inch centers. Once the leads are compressed and inserted. sufficient tension is provided to secure the package in the board during soldering. Leads require no additional cleaning or processing when used in soldered assembly.

MOTOROLA
Semiconductors
3501 ED BLUESTEIN BLVD. AUSTIN TEXAS 78721

## Advance Information

## CRT CONTROLLER (CRTC)

The MC6845 CRT Controller performs the interface to raster scan CRT displays. It is intended for use in processor-based controllers for CRT terminals in stand-alone or cluster configurations.

The CRTC is optimized for hardware/software balance in order to achieve integration of alf key functions and maintain flexibility. For instance, all keyboard functions, R/W, cursor movements, and editing are under processor control; whereas the CRTC provides video timing and Refresh Memory Addressing.

- Applications include "glass-teletype," smart, programmable, intelligent CRT terminals; video games; information display.
- Alphanumeric, semi-graphic, and full graphic capability.
- Fully programmable via processor data bus. Can generate timing for almost any alphanumeric screen density, e.g. $80 \times 24,72 \times 64$, $132 \times 20$, etc.
- Single +5 volt supply. TTL/6800 compatible I/O.
- Hardware scroll (paging or by line or by character)
- Compatible with CPU's and MPU's which provide a means for synchronizing external devices.
- Cursor register and compare circuitry.
- Cursor format and blink are programmable.
- Light pen register.
- Line buffer-less operation. No external DMA required. Refresh Memory is multiplexed between CRTC and MPU.
- Programmable interlace or non-interlace scan.
- 14-bit wide refresh address.


## MOS

(N-Channel, Silicon-Gate)
CRT CONTROLLER (CRTC)


## SYSTEM BLOCK DIAGRAM DESCRIPTION

As shown in Figure 1, the primary function of the CRTC is to generate refresh addresses (MAO-MA13), row selects (RAO-RA4), and video monitor timing (HSYNC, VSYNC) and Display Enable. Other functions include an internal cursor register which generates a Cursor output when its contents compare to the current Refresh Address. A light-pen strobe input signal allows capture of Refresh Address in an internal light pen register.

All timing in the CRTC is derived from the CIk input. In alphanumeric terminals, this signal is the character rate. Character rate is divided down from video rate by external High Speed Timing when the video frequency is greater than 3 MHz . Shift Register, Latch, and MUX Control signals are also provided by external High Speed Timing.

The processor communicates with the CRTC through a buffered 8 -bit Data Bus by reading/writing into the 18-register file of the CRTC.

The Refresh Memory address is multiplexed between the Processor and CRTC. Data appears on a Secondary Bus which is buffered from the processor Primary Bus. A

## MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $V_{C C}^{*}$ | -0.3 to +7.0 | $V_{d c}$ |
| Input Voltage | $\mathrm{V}_{\text {in }}{ }^{*}$ | -0.3 to +7.0 | $V_{\text {dc }}$ |
| Operating Temperature Range | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{\mathrm{stg}}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

${ }^{*}$ With respect to $V_{\text {SS }}(\mathrm{Gnd})$.

RECOMMENDED OPERATING CONDITIONS

| Characteristics | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{\mathrm{CC}}$ | 4.75 | 5.0 | 5.25 | $V_{d c}$ |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | - | 0.8 | $V_{d c}$ |
| Input High Voltage | $\mathrm{V}_{1 \mathrm{H}}$ | 2.0 | - | $\overline{\mathrm{V}}_{\mathrm{CC}}$ | $V_{d c}$ |

number of approaches are possible for solving contentions for the Refresh Memory.

1. Processor always gets priority.
2. Processor gets priority access anytime, but can be synchronized by an interrupt to perform accesses only during horizontal and vertical retrace times.
3. Synchronize processor by memory wait cycles.
4. Synchronize processor to character rate (See Figure 2). The 6800 MPU family lends itself to this configuration because it has constant cycle lengths. This method provides zero burden on the processor because there is never a contention for memory. All accesses are "transparent."
The secondary data bus concept in no way precludes using the Refresh RAM for other purposes. It looks like any other RAM to the Processor. For example, using Approach 4, a 64 K byte RAM Refresh Memory could perform refresh and program storage functions transparently.

FIGURE 2 - TRANSPARENT REFRESH MEMORY CONFIGURATION TIMING USING 6800 MPU FAMILY


## MC6845

ELECTRICAL CHARACTERISTICS $\left(V_{C C}=5.0 \vee \pm 5 \%, V_{S S}=0, T_{A}=0\right.$ to $70^{\circ} \mathrm{C}$ unless otherwise noted)

| Characteristic |  | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage |  | $\mathrm{V}_{\text {IH }}$ | 2.0 | - | $V_{\text {CC }}$ | Vdc |
| Input Low Voltage |  | $V_{\text {IL }}$ | -0.3 | - | 0.8 | $V \mathrm{dc}$ |
| Input Leakage Current |  | 1 in | - | 1.0 | 2.5 | $\mu \mathrm{Adc}$ |
| $\begin{gathered} \text { Three }-S \text { tate }\left(V_{\mathrm{CC}}=5.25 \mathrm{~V}\right) \\ \left(V_{\text {in }}=0.4 \text { to } 2.4 \mathrm{~V}\right) \end{gathered}$ |  | 'TSI | -10 | 2.0 | 10 | $\mu \mathrm{Adc}$ |
| $\begin{array}{r} \hline \text { Output High Voltage } \\ \left(I_{\text {load }}=-205 \mu \mathrm{~A}\right) \\ \left(I_{\text {load }}=-100 \mu \mathrm{~A}\right) \\ \hline \end{array}$ | DO-D7 <br> Other Outputs | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{array}{r} 2.4 \\ -2.4 \\ \hline \end{array}$ | $\begin{aligned} & - \\ & - \end{aligned}$ | - | Vdc |
| Output Low Voltage $\left(1_{\text {load }}=1.6 \mathrm{~mA}\right)$ |  | VOL | - | - | 0.4 | V dc |
| Power Dissipation |  | ${ }^{P} \mathrm{D}$ | - | 600 | - | mW |
| Input Capacitance | DO-D7 <br> All others | $\mathrm{C}_{\text {in }}$ | - |  | $\begin{gathered} 12.5 \\ 10 \\ \hline \end{gathered}$ | pF |
| Output Capacitance | All Outputs | $\mathrm{C}_{\text {out }}$ | - | - | 10 | pF |
| Minimum Clock Pulse Width, Low |  | $P_{\text {WCL }}$ | 160 | $\cdots$ | - | ns |
| Minimum Clock Pulse Width, High |  | $\mathrm{P}_{\text {WCH }}$ | 200 | - | - | ns |
| Clock Frequency |  | ${ }_{f}$ | - | - | 2.5 | MHz |
| Rise and Fall Time for Clock Input |  | $\mathrm{t}_{\mathrm{cr},} \mathrm{t}_{\mathrm{cf}}$ | - | - | 20 | ns |
| Memory Address Delay Time |  | $\mathrm{t}_{\text {MAD }}$ | - | - | 160 | ns |
| Raster Address Delay Time |  | ${ }^{\text {t }}$ /AD | - | - | 160 | ns |
| Display Timing Delay Time |  | ${ }^{\text {t }}$ DTD | - | - | 300 | ns |
| Horizontal Sync Delay Time |  | ${ }_{\text {t HSD }}$ | - | - | 300 | ns |
| Vertical Sync Delay Time |  | tVSD | - | - | 300 | ns |
| Cursor Display Timing Delay Time |  | ${ }^{1} \mathrm{CDD}$ | - | - | 300 | ns. |
| Light Pen Strobe Minimum Pulse Width |  | PW ${ }_{\text {LPH }}$ | 100 | - | - | ns |
| Light Pen Strobe Disable Time |  | 'LPD1 | - | - | 120 | ns |
|  |  | $\mathrm{t}_{\mathrm{LPD}}$ | - | - | 0 | ns |

Note: The light pen strobe must fall to low level before VSYNC pulse rises.
BUS TIMING CHARACTERISTICS

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| READ/WRITE |  |  |  |  |
| Enable Cycle Time | ${ }^{\text {c }} \mathrm{CyCE}$ | 1.0 | - | $\mu \mathrm{s}$ |
| Enable Pulse Width, High | PWEH | 0.45 | 25 | $\mu \mathrm{s}$ |
| Enable Pulse Width, Low | PWEL | 0.43 | - | $\mu \mathrm{s}$ |
| Setup Time, $\overline{\overline{C S}}$ and RS valid to enable positive transition | ${ }^{\text {t }}$ AS | 160 | - | ns |
| Data Delay Time | ${ }^{\text {t D D }}$ | - | 320 | ns |
| Data Hold Time (Read) (write) | ${ }^{\text {H }} \mathrm{H}$ | $\begin{aligned} & 10 \\ & 10 \\ & \hline \end{aligned}$ | - | $n \mathrm{n}$ |
| Address Hold Time | ${ }^{1} \mathrm{AH}$ | 10 | - | ns |
| Rise and Fall Time for Enable Input | ${ }_{\text {ter }}{ }^{\text {t }}$ Eff | - | 25 | ns |
| Data Setup Time | tDSW | 195 | - | ns |
| Data Access Time | ${ }^{\text {t }}$ ACC | - | 480 | ns |

## MC6845



FIGURE 4 - RELATION BETWEEN LPSTB AND REFRESH MEMORY ADDRESS


## MC6845



5b - Bus Write Timing (Write Information Into CRTC)

(4)

MOTOROLA Semiconductor Products Inc.

## MC6845



## MC6845

## PIN DESCRIPTION

## PROCESSOR INTERFACE

The CRTC interfaces to a processor bus on the bidirectional data bus (DO-D7) using CS, RS, E, and R $\bar{W}$ for control signals.

Data Bus (DO-D7) - The bidirectional data lines (DO-D7) allow data transfers between the CRTC internal Register File and the processor. Data bus output drivers are 3 -state buffers which remain in the high impedance state except when the processor performs a CRTC read operation. A high level on a data pin is a logical " 1 ."

Enable ( $E$ ) - The Enable signal is a high impedance TTL/MOS compatible input which enables the data bus input/output buffers and clocks data to and from the CRTC. This signal is usually derived from the processor clock, and the high to low transition is the active edge.
Chip Select ( $\overline{\mathrm{CS}}$ ) - The $\overline{\mathrm{CS}}$ line is a high impedance TTL/MOS compatible input which selects the CRTC when low to read or write the internal Register File. This signal should only be active when there is a valid stable address being decoded from the processor.

Register Select (RS) - The RS line is a high impedance TTL/MOS compatible input which selects either the Address Register ( $R S=$ " 0 ") or one of the Data Registers (RS = " 1 ") of the internal Register File.

Read/Write ( $\mathbf{R} \overline{\mathbf{W}}$ ) - The $\mathbf{R} / \bar{W}$ line is a high impedance TTL/MOS compatible input which determines whether the internal Register File gets written or read. A write is active low ("0").

## CRT CONTROL

The CRTC provides horizontal sync (HS), vertical sync (VS), and Display Enable signals.

Vertical Sync (V SYNC) - This TTL compatible output is an active high signal which drives the monitor directly or is fed to Video Processing Logic for composite generation. This signal determines the vertical position of the displayed text.

Horizontal Sync (H SYNC) - This TTL compatible output is an active high signal which drives the monitor directly or is fed to Video Processing Logic for composite generation. This signal determines the horizontal position of the displayed text.

Display Enable - This TTL compatible output is an active high signal which indicates the CRTC is providing addressing in the active Display Area.

## REFRESH MEMORY/CHARACTER GENERATOR ADDRESSING

The CRTC provides Memory Addresses (MAO-MA13) to scan the Refresh RAM. Also provided are Raster Addresses (RAO-RA4) for the character ROM.

Refresh Memory Addresses (MAO-MA13) - These 14 outputs are used to refresh the CRT screen with pages of data located within a 16 K block of refresh memory. These outputs drive a TTL load and 30 pF . A high level on MAO-MA13 is a logical " 1 ."

Raster Addresses (RA0-RA4) - These 5 outputs from the internal Raster Counter address the Character ROM for the row of a character. These outputs drive a TTL load and 30 pF . A high level (on RAO-RA4) is a logical "1."

## OTHER PINS

Cursor - This TTL compatible output indicates Cursor Display to external Video Processing Logic. Active high signal.

Clock (CLK) - The CLK TTL/MOS compatible input is used to synchronize all CRT control signals. An external dot counter is used to derive this signal which is usually the character rate in an alphanumeric CRT. The active transition is high to low.

Light Pen Strobe (LPSTR) - This high impedance TTL/MOS compatible input latches the current Refresh Addresses in the Register File. Latching is on the low to high edge and is synchronized internally to character clock.
$V_{\text {cc }}$, Gnd
$\overline{\operatorname{RES}}$ - The $\overline{\operatorname{RES}}$ input is used to Reset the CRTC. An input low level on RES forces CRTC into following status:
(A) All the counters in CRTC are cleared and the device stops the display operation.
(B) All the outputs go down to low level.
(C) Control registers in CRTC are not affected and remain unchanged
This signal is different from other M6800 family in the following functions:
(A) RES signal has capability of reset function only when LPSTB is at low level.
(B) After $\overline{\mathrm{RES}}$ has gone down to low level, output signals of MAO-MA13 and RAO-RA4 synchronizing with CLK low level, goes down to low level. (At least 1 cycle CLK signal is necessary for reset.)
(C) The CRTC starts the Display operation immediately after the release of $\overline{\operatorname{RES}}$ signal.

TABLE 1 - CRTC Operating Mode

| TABLE I - CRTC Operating Mode |  |  |
| :---: | :---: | :---: |
| $\overline{\text { RES }}$ | LPSTB | OPERATING MODE |
| 0 | 0 | Reset |
| 0 | 1 | Test Mode |
| 1 | 0 | Normal Mode |
| 1 | 1 | Normal Mode |

## MC6845

## REGISTER FILE DESCRIPTION <br> (See Table 2)

Nineteen registers in the CRTC can be accessed by means of the data bus. Register addressing and lengths are shown in Table 2.

## ADDRESS REGISTER

The Address Register is a 5 bit write-only register used as an "indirect" or "pointer" register. Its contents are the address of one of the other 18 registers in the file. When RS and $\overline{\mathrm{CS}}$ are low, the Address Register itself is addressed. When RS is high, the Register File is accessed.

HORIZONTAL TIMING REGISTERS RO, R1, R2, and R3

Figure 9 shows the visible display area of a typical CRT monitor giving the point of reference for horizontal registers as the left most displayed character position. Horizontal registers are programmed in "character time" units with respect to the reference.

Horizontal Total Register (RO) - This 8 bit write-only register determines the horizontal frequency of HS. It is the total of displayed plus non-displayed character time units minus one.

Horizontal Displayed Register (R1) - This 8 bit write-only register determines the number of displayed characters per horizontal line.

Horizontal Sync Position Register (R2) - This 8 bit write-only register determines the horizontal sync postiion on the horizontal line.

Horizontal Sync Width Register (R3) - This 4 bit
write-only register determines the width of the HS pulse. It may not be apparent why this width needs to be programmed. However, consider that all timing widths must be programmed as multiples of the character clock period which varies. If HS width were fixed as an integral number of character times, it would vary with character rate and be out of tolerance for certain monitors. The rate programmable feature allows compensating HS width.

VERTICAL TIMING REGISTERS R4, R5, R6, R7, R8, and R9

The point of reference for vertical registers is the top character position displayed. Vertical registers are programmed in character row times or scan line times.

Vertical Total Register (R4) and Vertical Total Adjust Register (R5) - The vertical frequency of VS is determined by both R4 and R5. The calculated number of character line times is usually an integer plus a fraction to get exactly a 50 or $\mathbf{6 0 ~ H z}$ vertical refresh rate. The integer number of character line times minus one is programmed in the 7 bit write-only Vertical Total Register; the fraction is programmed in the 5 bit write-only Vertical Scan Adjust Register as a number of scan line times.

Vertical Displayed Register (R6) - This 7 bit write only register determines the number of displayed character rows on the CRT screen, and is programmed in cha: acter row times.

Vertical Sync Position (R7) - This 7 bit write-only register determines the vertical sync position with respect
table 2 - CRTC INTERNAL REGISTER ASSIGNMENT


Note 11): Bit 5 of the Cursor Start Raster Register is used for blink period control, and Bit 6 is used to select blink or non-blink.
to the reference. It is programmed in character row times.
Interlace Mode Register (R8) - This 2 bit write-only register controls the raster scan mode (see Figure 11). When bit 0 and bit 1 are reset, or bit 0 is reset and bit 1 set, the non-interlace raster scan mode is selected. Two interlace modes are available. Both are interlaced 2 fields per frame. When bit 0 is set and bit 1 is reset, the interlace sync raster scan mode is selected. Also when bit 0 and bit 1 are set, the interlace sync and video raster scan mode is selected.

Maximum Scan Line Address Register (R9) - This 5 bit write-only register determines the number of scan lines per character row including spacing. The programmed value is a max address and is one less than the number of scan lines.

## OTHER REGISTERS

Cursor Start Register (R10) - This 7 bit write-only register controls the cursor format (see Figure 10). Bit 5 is the blink timing control. When bit 5 is low, the blink frequency is $1 / 16$ of the vertical field rate, and when bit 5 is high, the blink frequency is $1 / 32$ of the vertical field rate. Bit 6 is used to enable a blink. The cursor start scan line is set by the lower 5 bits.

Cursor End Register (R11) - This 5 bit write-only register sets the cursor end scan line.

Start Address Register (H \& L) (R12, R13) - Start Address Register is a 14 bit write-only register which determines the first address put out as a refresh address after vertical blanking. It consists of an 8 bit lower register, and a 6 bit higher register.

Light Pen Register (H \& L) (R16, R17) - This 14 bit read-only register is used to store the contents of the Address Register ( $\mathrm{H} \& \mathrm{~L}$ ) when the LPSTB input pulses high. This register consists of an 8 bit lower and 6 bit higher register.

Cursor Register (H \& L) (R14, R15) - This 14 bit read/write register stores the cursor location. This register consists of an 8 bit lower and 6 bit higher register.

## CURSOR

The Cursor Start and End Registers allow a cursor of up to 32 scan lines in height to be placed on any scan lines of the character block as shown in Figure 10. Using Bits 5 \& 6 of the Cursor Start Register, the cursor is programmed with blink periods of 16 or 32 times the field period. Optional non-blink and non-display modes can also be selected. When an external 2 X blink on characters is required, it may be necessary to perform cursor blink externally as well so that both blink rates are synchronized. Note that an invert/non-invert cursor is easily implemented by programming the CRTC for blinking cursor and externally inverting the video signal with an exclusive-OR.

The cursor is positioned by changing the contents of registers R14 and R15. The cursor can be placed at any of 16 K character positions, thus facilitating hardware paging and scrolling through memory without loss of the cursor's original position.

## INTERLACE/NON-INTERLACE DISPLAY MODES

An illustration of the $\mathbf{3}$ raster scan modes of operation is shown in Figure 11. Normal sync mode is non-interlace. In this mode, each scan line is refreshed at the vertical field rate (e.g., 50 or 60 Hz ). Frame time is divided into even and odd alternating fields. The horizontal and vertical timing relationship results in the displacement of scan lines in the odd field with respect to the even field. When the same information is painted in both fields, the mode is called "Interlace Sync;" this is a useful mode for enhancing readability by filling in a character. When the even lines of a character are displayed in the even field and the odd lines in the odd field, the mode is called "Interlace Sync and Video." This last mode effectively doubles the character density on a monitor of a given bandwidth. The disadvantage of both interlace modes is an apparent flicker effect, which can be reduced by careful monitor design.

There are restrictions on the programming of CRTC registers for interlace operation:

1) Horizontal total character count, $N_{h t}$ must be odd (i.e., an even number of character times)
2) For Interlace Sync and Video mode only, the max scan line address, $\mathrm{N}_{\mathrm{sl}}$, must be odd (i.e., an even number of scan lines)
3) For Interlace Sync and Video mode only, the Vertical Displayed Total characters must be even. The programmed number, $\mathrm{N}_{\mathrm{vd}}$, must be one-half the actual number required.
4) For Interlace Sync \& Video mode only, the Cursor START and Cursor End Registers must both be even or both odd.

## LIGHT PEN

The contents of the CRTC Address Counter are strobed into R16/R17 Light Pen Registers on the next high to low CLK transition after LPSTB goes high. In most systems, the light pen signal would also cause a processor interrupt routine to read R16/R17. Slow light pen response requires the processor software to modify the captured address read from R16/R17 by a calibration factor.

## PROGRAMMING CONSIDERATIONS

Initialization - Registers RO-R15 must be initialized after power is turned on. The processor normally loads the CRTC registers sequentially from a firmware table. Henceforth, R0-R11 are not changed in most systems. The 6800 program in Table 3 and Figure 12 shows a typical CRTC initialization.

Hardware Scrolling - Registers R12/R13 contents determine which memory location is the first displayed character on the screen. Since the CRTC Linear Address Generator counts from this beginning count, the displayed portion of the screen may be a window on any continuous string of characters within a 16 K block or refresh memory. By centering the R12/R 13 pointer in the middle of the available memory space, scrolling up or down is possible . . . by line, page, or character.


## CRTC DESCRIPTION <br> (Figure 8: CRTC Block Diagram)

The CRTC consists of programmable horizontal and vertical timing generators, programmable linear address register, programmable cursor logic, light pen capture register, and control circuitry for interface to a processor bus.
All CRTC timing is derived from CLK, usually the output of an external dot rate counter. Coincidence (CO) circuits continuously compare counter contents to the contents of the programmable register file, RO-R17. For horizontal timing generation, comparisons result in: 1) Horizontal sync pulse (HS) of a frequency, position, and width determined by the registers, 2) Horizontal Display Signal of a frequency, position, and duration determined by the registers.
The Horizontal counter produces H clock which drives the Scan Line Counter and Vertical Control. The contents of the Raster Counter are continuously compared to the Max Scan Line Address Register. A coincidence resets the Raster Counter and clocks the Vertical Counter.

Comparisons of Vertical Counter contents and Vertical Registers result in: 1) Vertical sync pulse (VS) of a frequency and positon determined by the registers-the width is fixed at 16 raster lines in the vertical control section and is not programmable, 2) Vertical Display of a frequency and position determined by the registers.

The Vertical Control Logic has other functions.

1. Generate row selects, RAO-RA4, from the Raster Count for the corresponding interlace or noninterlace modes.
2. Extend the number of scan lines in the vertical total by the amount programmed in the Vertical Total Adjust Register.
The Linear Address Generator is driven by CLK and locates the relative positions of characters in memory with their positions on the screen. Fourteen lines, MAO-MA13, are available for addressing up to four pages of 4 K characters, 8 pages of 2 K characters, etc. Using the Start Address Register, hardware scrolling through 16 K characters is possible. The Linear Address Generator repeats the same sequence of addresses for each scan line of a character row.

The cursor logic determines the cursor location, size, and blinking rate on the screen. All are programmable.

The light pen strobe going high causes the current contents of the Address Counter to be latched in the Light Pen Register. The contents of the Light Pen Register are subsequently read by the Processor.

Internal CRTC registers are programmed by the processor through the data bus, D0-D7, and the control signals $-\mathrm{R} \overline{\mathcal{W}}, \overline{\mathrm{CS}}, \mathrm{RS}$ and E .


[^5]
## MC6845

## FIGURE 10 - CURSOR CONTROL

Cursor Stayt Register

| B | P |  |
| :---: | :---: | :---: |
| Bit <br> 6 | Bit <br> 5 | Cursor Display Mode |
| 0 | 0 | Non-Blink |
| 0 | 1 | Cursor Non-Display |
| 1 | 0 | Blink, $1 / 16$ Field Rate |
| 1 | 1 | Blink, 1/32 Field Rate |



Example of Cursor Display Mode


Cursor Start Adr. $=9$
Cursor End Adr. $=9$


Cursor Start Adr. $=9$
Cursor End Adr. $=10$


Cursor Start Adr. $=1$ Cursor End Adr. $=5$

FIGURE 11 - INTERFACE CONTROL
Interlace Mode Register

| Bit | Bit | Mode |
| :---: | :---: | :---: |
| 1 | 0 | Normal Sync Mode (Non-Interlace) |
| 0 | 0 |  |
| 1 | 0 |  |
| 0 | 1 | Interlace Sync Mode |
| 1 | $!$ | Interlace Sync \& Video Mode |



Normal Sync



MOTOROLA Semiconductor products inc.

## MC6845

TABLE 3-Typical $80 \times 24$ Screen Format Initialization of CRTC

| Reg. \# | Register File | ProgramUnit | Calculation* | Programmed Value |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Decimal | Hex |
| RO | H Total | $\mathrm{T}_{\mathrm{c}}$ | $102 \times .527=53.76 \mu \mathrm{~s}$ | 102-1 = 101 | $\mathrm{N}_{\mathrm{ht}}=\$ 65$ |
| R1 | H Displayed | $\mathrm{T}_{\mathrm{c}}$ | $80 \times .527=42.16 \mu \mathrm{~s}$ | 80 | $\mathrm{N}_{\text {hd }}=\$ 50$ |
| R2 | H Sync Position | $\mathrm{T}_{\mathrm{c}}$ | $86 \times .527=45.32 \mu \mathrm{~s}$ | 86 | $\mathrm{N}_{\text {hsp }}=\$ 56$ |
| R3 | H Sync Width | $\mathrm{T}_{\mathrm{c}}$ | $9 \times .527=4.74 \mu s$ | 9 | $\mathrm{N}_{\text {hsw }}=\$ 09$ |
| R4 | $\checkmark$ Total | $\mathrm{T}_{\text {cr }}$ | $25 \times 645.12=16.13 \mathrm{~ms}$ | $25=1-24$ | $\mathrm{N}_{\mathrm{vt}}=\$ 18$ |
| R5 | $\checkmark$ Total Adjust | $\mathrm{T}_{\text {sl }}$ | $10 \times 53.76=54 \mathrm{~ms}$ | 10 | $N_{\text {adj }}=\$ 0 \mathrm{~A}$ |
| R6 | $\checkmark$ Displayed | Ter | $24 \times 645.12=15.48 \mathrm{~ms}$ | 24 | $\mathrm{N}_{\mathrm{vd}}=\$ 18$ |
| R7 | $\checkmark$ Sync Position | $\mathrm{T}_{\text {cr }}$ | $24 \times 645.12=15.48 \mathrm{~ms}$ | 24 | $N_{\text {vsp }}=\$ 18$ |
| R8 | Interlace Mode | - |  | - | \$00 |
| R9 | Max Scan Line Address | $\mathrm{T}_{\text {si }}$ |  | 11 | $\mathrm{N}_{\mathbf{s l}}=\$ 0 \mathrm{~B}$ |
| R10 | Cursor Start | $\mathrm{T}_{s l}$ |  | 0 | \$00 |
| R11 | Cursor End | $\mathrm{T}_{\text {si }}$ |  | 11 | \$0B |
| R12 | Start Address (H) | - |  | 128 | \$00 |
| R13 | Start Address (L) | - |  |  | \$80 |
| R14 | Cursor (H) | - |  | 128 | \$00 |
| R15 | Cursor (L) | - |  |  | \$80 |
| Clock Period $\quad=\mathrm{T}_{\mathrm{c}}=.527 \mu \mathrm{~s}$ |  |  |  |  |  |
| Scan Line Period $\quad=\mathrm{T}_{\mathrm{sl}}=\left(\mathrm{N}_{\mathrm{ht}}+1\right) \times \mathrm{T}_{\mathrm{c}}=102 \times .527 \mu \mathrm{~s}=53$. |  |  |  |  |  |
| Character Row Period $=\mathrm{T}_{\mathbf{c r}}=\mathrm{N}_{\mathbf{s l}} \times \mathrm{T}_{\mathbf{s l}}=12 \times 53.76 \mu \mathrm{~s}=645.12 \mu \mathrm{~s}$ |  |  |  |  |  |

FIGURE 12 - INITIALIZATION OF CRTC FOR $80 \times 24$ SCREEN FORMAT IN TABLE 3

| fage | 001 | CRTINT |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00001 |  |  |  | NAM |  | CRTINT |  |
| 00002 | 0900 |  |  | ORG |  | \$9 |  |
| 100003 | 0090 | $5 F$ |  | CLR | $E$ |  | CLEAR COUNTER |
| 00904 | 0091 | CE 9020 |  | LDX |  | \#\$20 |  |
| 00605 | 0604 | F7 9800 | CRTII | STA | $E$ | \$9000 | CRTC ADOR REG |
| 00960 | 00907 | 1680 |  | LDA | A | $0 . X$ |  |
| 0606T | 6009 | E6 9001 |  | STA | A | \$9001 | ACC TO CRTC REG |
| 00008 | 0000 | 88 |  | INX |  |  |  |
| 061099 | 0900 | $5 C$ |  | INC | E |  | INC COUNTER |
| 00010 | aboe | C1 10 |  | CMP | 8 | \# $\ddagger 10$ | LAST CRTC REG? |
| 69611 | 9010 | 26 Fz |  | ENE |  | CRTII |  |
| 00012 | 0812 | $3 F$ |  | SWI |  |  |  |
| -19013 | 0220 |  |  | ORG |  | \$26 |  |
| 009714 | 0020 | 65 | CRTTAE | FCB |  | \$65, \$50 | \$56. $\$ 9$ |
| 00015 | 0024 | 18 |  | FCE |  | \$18.5日月 | \$18.\$18 |
| 00016 | 0028 | 00 |  | FCB |  |  |  |
| Qealt | $002 c$ | 1930 |  | FDE |  | \$ 80.580 |  |
| 00018 |  | 9000 |  | END |  |  |  |
| CRTII | 0004 | 4 CRTTAE | 6020 |  |  |  |  |

(4) MOTOROLA Semiconductor Products Inc.

## OPERATION OF THE CRTC

Timing Chart of the CRT Interface Signals - Timing charts of CRT interface signals are illustrated in this section with the aid of programmed example of the CRTC. When values listed in Table 4 are programmed into CRTC control registers, the device provides the outputs as
shown in the Timing Diagrams (Figures 13 through 15). The screen format of this example is shown in Figure 9. Figure 16 is an illustration of the relation between Refresh Memory Address (MAO-MA13), Raster Address (RAO-RA4) and the position on the screen. In this example, the start address is assumed to be " 0 ".

TABLE 4 - Values Programmed Into CRTC Registers

| Reg. \# | Register Name | Value | Programmed Value |
| :---: | :---: | :---: | :---: |
| RO | H. Total | $\mathrm{N}_{\mathrm{ht}}+1$ | $\mathrm{N}_{\mathrm{ht}}$ |
| R1 | H. Displayed | $\mathrm{N}_{\mathrm{hd}}$ | Nhd |
| R2 | H. Sync Position | $\mathrm{N}_{\text {hsp }}$ | $\mathrm{N}_{\text {hsp }}$ |
| R3 | H. Sync Width | $\mathrm{N}_{\text {hsw }}$ | Nhsw |
| R4 | v. Total | $\mathrm{N}_{\mathrm{vt}}+1$ | $\mathrm{N}_{\mathrm{vt}}$ |
| R5 | V. Scan Line Adjust | $\mathrm{Nadj}^{\text {a }}$ | $\mathrm{N}_{\text {adj }}$ |
| R6 | $\checkmark$. Displayed | $\mathrm{N}_{\text {vd }}$ | $\mathrm{N}_{\mathrm{vd}}$ |
| R7 | V. Sync Position | $N_{\text {VSP }}$ | $\mathrm{N}_{\text {vsp }}$ |
| R8 | Interlace Mode |  |  |
| R9 | Max. Scan Line Address | $\mathrm{N}_{\text {si }}$ | $\mathrm{N}_{\text {si }}$ |
| R10 | Cursor Start |  |  |
| R1 1 | Cursor End |  |  |
| R12 | Start Address (H) | 0 |  |
| R13 | Start Address (L) | 0 |  |
| R14 | Cursor (H) |  |  |
| R15 | Cursor (L) |  |  |
| R16 | Light Pen (H) |  |  |
| R17 | Light Pen (L) |  |  |

## MC6845


(M) MOTOROLA Semiconductor products Inc.

## MC6845




(M) MOTOROLA Semiconductor Products Inc.

TEAC FD-54
MINI FLEXIBLE DISK DRIVE
MAINTENANCE MANUAL

## TABLE OF CONTENTS

> Title Page
SECTION 3 THEORY OF OPERATION .................................................................... 300

3-1 CONSTRUCTION AND FUNCTION ........................................................... 301


3-1-2 Mechanical Section ................................................................ 302
3-2 CIRCUIT DESCRIPTIONS ..................................................................... 307
3-2-1 Read write Circuit .............................................................. 307

3-2-3 Servo Circuit .............................................................................. 320
3-3 FUNCTION OF TEST POINTS AND VARIABLE RESISTORS . . . . . . . . . . . . . . . . . . 321
3-3-1 Function of Test points .............................................................. 322
3-3-2 Function of variable Resistors ............................................... 329

|  |  |
| :---: | :---: |
| SECTION 4 MAINTENANCE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40000 |  |
| 4-1 GENERAL. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4001 |  |
| 4-1-1 Periodic Maintenance .................................................. 4001 |  |
| 4-1-2 Check and Adjustment . ............................................... 4002 |  |
| 4-1-3 Maintenance Parts Replacement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4003 |  |
| 4-1-4 Maintenance Jigs and Tools ......................................... 4007 |  |
| 4-2 PRECAUTIONS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4010 |  |
| 4-2-1 Torque Applied to Screws and Locking Paint ...................... 4010 |  |
| 4-2-2 Handling of Connectors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4011 |  |
| 4-2-3 Head Cable Treatment ............................................... 4016 |  |
| 4-2-4 Initial Setting of SKA . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4018 |  |
| 4-2-4-1 Cable connection and setting of power supply voltage ......... 4018 |  |
| 4-2-4-2 Setting of the maximum track number . . . . . . . . . . . . . . . . . . . . . . . . . 4021 |  |
| 4-2-4-3 setting of step rate and settling time . . . . . . . . . . . . . . . . . . 4022 |  |
| 4-2-4-4 Level disk calibration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4024 |  |
| 4-2-4-5 Alignment disk calibration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4026 |  |
| 4-2-4-6 Humidity setting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4029 |  |
| 4-2-4-7 Setting of SKA gain . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4029 9 |  |
| 4-2-5 Others . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4030 |  |
| 4-3 PREVENTIVE MAINTENANCE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4033 |  |
| 4-3-1 Cleaning of Magnetic Head by Cleaning Disk ............................ 4033 |  |
| 4-3-2 Direct Cleaning (Single sided FDD only) . . . . . . . . . . . . . . . . . . . . . 4035 |  |
| 4-4 CHECK AND ADJUSTMENT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4037 |  |
| 4-4-1 Adjustment of Collet Shaft Plate . . . . . . . . . . . . . . . . . . . . . . . . . . . 4037 |  |
| 4-4-2 Adjustment of Front Lever Position . . . . . . . . . . . . . . . . . . . . . . . . . . 4039 |  |
| 4-4-3 Check and Adjustment of Disk Pad Lever (Bail) . . . . . . . . . . . . . . . . 4041 |  |
| 4-4-4 Check of File Protect Sensor . . . . . . . . . . .................................... . . 4044 |  |
| 4-4-5 Check and Adjustment of Disk Rotation Speed . . . . . . . . . . . . . . . . . . 4047 |  |
| 4-4-6 Check and Adjustment of Head Touch . . . . . . . . . . . . . . . . . . . . . . . . . 4049 |  |
| 4-4-7 Check and Adjustment of Asymmetry . . . . . . . . . . . . . . . . . . . . . . . . . . . 4055 |  |
| 4-4-8 Check of Read Level . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4060 |  |
| 4-4-9 Check of Resolution ............................................... 4063 |  |
| 4-4-10 Check and Adjustment of Track Alignment .......................... . . . 4066 |  |




## SECTION 3

THEORY OF OPERATION

## 3-1. CONSTRUCTION AND FUNCTION

## 3-1-1. General Block Diagram


(Fig. 301) General block diagram

3-1-2. Mechanical Section

Since the disk is a flexible recording media made of mylar film base and data interchangeability between disks and FDDs is required, the mechanical section of the FDD uses precision parts and it is also assembled with high precision. For this reason, only trained technicians can handle the internal mechanism. Never apply excessive impact nor drop the FDD down on the desk.

The mechanical section is constructed with frame (chassis), door mechanism, disk clamp mechanism, disk rotation mechanism, magnetic head and carriage, head seek mechanism, various detection mechanisms, etc.
(1) Frame (chassis)

The main structure for mounting the various mechanisms and printed circuit boards. The frame is made of sheet metal to maintain the stability of the FDD in strength, precision, durability, and expansion coefficient.
(2) Door mechanism and disk clamp mechanism

The door mechanism is constructed with clamp spring (plate spring), front lever, set arm, etc. The end of the clamp spring makes the disk clamp mechanism (collet Ass'y) move up and down.
When a disk is inserted and the front lever is closed, the tip of the collet is inserted in the central window of the disk and the window area is depressed to the spindle so that the center of the disk is clamped in the correct position along the outer circumference of the collet.
(3) Disk rotation mechanism

The disk rotation mechanism comprises DD motor Ass'y which includes spindle.

The DD motor is an outor-rotor type $D C$ brushless motor which has the long life of 20,000 hours or more in continuous rotation. The rotational speed is 300 rpm and maintains stable rotational speed against load variations and environmental changes. This is achieved by a feedback signal from the internal AC tachometer. The precisely combined collet and spindle are attached at the correct angle to maintain the center position correctly without damaging the center hole of the disk and so as to make the head be in contact with disk at the correct angle.
(4) Magnetic head and carriage

(Fig.302) External view of magnetic head core

For single sided FDDs, the external view of the magnetic head is button shaped and it is mounted on the carriage so that it is in contact with the SIDE 0 (the buttom side when the FDD is placed horizontally) head window area of the disk.

For double sided FDDS, both the SIDE 1 head and the SIDE 0 head are special flat type supported with the gimballed mechanisms. The two magnetic heads are mounted accross the disk on one carriage. In both types of head, the surface is designed for minimum disk wear and maximum read output. The head itself is a long life type for
improved head wear.
For the FD-54 drives, either of tunnel erase type head or straddle erase type head is used. The core of the tunnel erase type head is constructed with a read/write gap which is used for data write and data read operations and two erase gaps which are used to erase the edges of the recorded track immediately after the recording (tunnel erase). For the straddle erase type head, the core is constructed with a read/write gap and two erase cores for erasing the edges of the recorded track at the same time with the recording.

Even though the core construction of these two types of head are different, their functions in the FD-54 drives are the same and have complete interchangeability between the data recorded on the disks. The magnetic head and the carriage on which the head is mounted form the most important part of the FDD and is specially assembled with high precision.
(5) Head seek mechanism

The head seek mechanism consists mainly of stepper motor with a capstan (pooly), steel belt (band), guide shafts, and carriage. The carriage is connected to the capstan of the stepping motor through the steel belt and is slided along the guide shafts.
The flat type 4 -phase stepping motor is adopted and it rotates 2 steps ( $3.6^{\circ}$ ) per one track space. The stepper motor is driven in a unique 1-2 phase driving method which brought a success in reducing the heat radiation and to obtain a high speed driving and positioning accuracy. The parrallelism and the distance between the shafts and the center line of the disk, and shaft and disk themselves are precisely machined. Also the thermal expansion of the chassis, steel belt, carriage, etc. are taken into consideration in the process of design so that they are mutually offset with the expansion of the disk.
(6) Detection mechanisms
(a) File protect detection mechanism

This mechanism is constructed with an LED and a photo-transistor to detect the existence of the write enable notch of the disk jacket. When a disk with the notch covered is installed and the light pass for detection is disturbed, no write or erase current will be supplied to the read/write and erase heads and the recorded information on the disk is protected from an erroneous input of a write command. The LED is mounted on the PCBA DD motor servo and the photo-transistor on the front OPT Ass'y.
(b) Track 00 detection mechanism

This mechanism is constructed with a photo-interrupter for detecting the outermost track position (track 00) of the head and the track 00 stopper which is ataached to the rear side of the head carriage. Inside tracks from the track 00 on the disk are used. Even if an erroneous step out command is input from the track 00 position, the command will be ignored by the internal circuit of the FDD. If the head moves out from the track 00 by some reason (such as impact during transportation), the head carriage strikes the track 00 stopper to protect the head from moving out of the returnable range at a next power on.

When step-in commands are input from the innermost track, the head seeks toward inward and stops with an appropriate space left against the head window edge of the disk. In order to recalibrate the track from this position (returning operation to the track 00), it is required to input the step-out commands with several additional steps to the maximum track number.
(c) Index detection mechanism

LED and photo-transistor for the detection of the index hole are
located at the index window area of the disk jacket.
The LED is mounted on the PCBA DD motor servo and the photo-transistor on the front OPT Ass'y. The index hole will be detected along the rotation of the disk.

3-2. CIRCUIT DESCRIPTIONS

The electronics of the FDD is constructed with three sections which are read write circuit, control circuit, and servo circuit. Read write circuit and control circuit are mounted on the PCBA MFD control, and servo circuit is on the PCBA DD motor servo.

3-2-1. Read Write Circuit

The read write circuit is constructed with read circuit, write circuit, and low voltage sensor. They are mostly packed in a read write LSI (bipolar).
Fig. 303 shows the block diagram.

(Fig. 303) Read write circuit block diagram

## (1) Read circuit

The read circuit consists of pre-amplifier, low pass filtex, differentiation amplifier, peak detector, time domain filter and read gate (output driver).
In read operation, the minute voltage induced by the read/write head is amplified about $30 d B$ by the pre-amplifier which is constructed with a video band differential amplifier. Undesirable high frequency noise is eliminated by the low pass filter (L1, L2, C30, etc.) and the read signal is supplied to the differentiation amplifier $(Q 3, Q 4, L 3$, C35, etc.).

The differentiation amplifier phase-shifts the peak position of the reproduced waveform to the zero cross point, and at the same time, further amplifies the signal about 20 dB with the most appropriate equalization. The peak detector which is constructed with a comparator converts the differentiated output into a square wave.

The time domain filter eliminates a virtual pulse caused by the saddle in the low frequency area (1F area, 62.5 KHz , approx.) at outer tracks. The time domain filter is constructed with two edge detectors, $2.4 \mu \mathrm{sec}$, delay single shot (LSI pin 7, RA5, C21), data latch, and lusec data single shot (LSI pins 8 and 9, RA5, C22).

Then the signal is output from the FDD through the read gate, U3 (pins 9, 10, 3-state output driver).

(Fig.304) Read amp. and peak detector waveforms

(Fig. 305) Time domain filter and read gate waveforms
(2) Write circuit

The write circuit consists of write power gate (with side selector), select gate, data latch, write driver, and erase driver.

The write power gate output (COMO or COM1) becomes high voltage when the write gate signal or the erase gate signal is TRUE (HIGH level). These signals are generated by the write/erase gate in the control circuit when all of the following three conditions are satisfied.
(a) The file protect sensor detects the notch of the disk jacket (write enable condition).
(b) The WRITE GATE input signal is TRUE.
(c) MX strap is on or the DRIVE SELECT signal is TRUE (LOW).

The write power gate output is supplied to the common terminal of the head through the diode switch. Table 301 shows the output voltage of the write power gate in various operations.

| Conditions | Write power gate output voltage |  |
| :---: | :---: | :---: |
|  | COM 0 (for Side 0) | COM 1 (for side 1) |
| Side 0 write operation | High | Low |
| Side l write operation | Low | High |
| Side 0 read operation | Middle | Low |
| Side 1 read operation | Low | Middle |

(Table 301) Write power gate output voltage

For the tunnel erase head, the erase gate signal is delayed appropriately against the write gate signal. Since the erase gap is about 0.85 mm behind the read/write gap, it is necessary for the erase driver to delay the write gate signal so that the written data is completely trimmed by the erase head (tunnel erase).

For the straddle erase head, the write gate and the erase gate signals have the same timing. The tunnel erase or the straddle erase produces a guard band between the tracks preventing deterioration of the $S / N$ ratio resulting from a off-track (positioning error). It also ensures disk interchangeability.

The WRITE DATA input pulse is latched by the data latch. And appropriate write current is supplied to the read/write head by turning on and off the two write drivers alternately. When the write driver is active, no read data pulse is generated by the read circuit.

(3) Low voltage sensor

The low voltage sensor is equipped to protect the FDD from erroneous operation due to the internal circuit construction of the FDD during unstable condition of the supplied voltage such as at power on or of The output of this sensor is supplied to almost all the functional blocks of the read write circuit, and control circuit to protect the write driver and erase driver from erroneous operation under the unstable condition of the $D C$ power voltage.


Note: Dotted line shows the LVS input pin 34 of $U 2$, control LSI.
(Fig. 307) Low voltage sensor waveforms

```
3-2-2. Control Circuit
```

The control circuit consists of gates, detectors, and the stepping motor control circuit. The gates are drive select gate to determine the drive select condition, spindle motor gate to determine the rotational condition of the spindle motor, write/erase gate to control the actual write operation, etc. The detectors are index/sector detector, track 00 detector, file protect detector, and ready detector. The former three detectors (photo-transistors) are mounted on the front OPT Ass'y and the transport frame. And the other circuits are mounted on the PCBA MFD control (mostly packed in a control LSI (CMOS)). Fig. 308 shows the block diagram.

Drive select gate classifies the external input signals into several functions and transmits them into the control LSI. The selection of straps (short bars) determines the select condition of the drive, spindle motor operating conditions, and turn-on condition of the front bezel indicator. Refer to items l-ll of the Specification as to the detailed function of each strap.

The write/erase gate judges the FDD whether it can execute write operation or not and issues write gate and erase gate signals for the write circuit. For the FDD with tunnel erase head, a specified delay time is established in the erase gate signal by an internal counter (refer to Fig. 306).

The ready detector consists of speed detector and ready latch. The output of the speed detector which is constructed with a re-triggerable counter becomes always TRUE (HIGH) when the rotational speed of an installed disk (soft sectored) is more than $50 \%$, approx. of the rated speed. The ready latch detects the second index pulse after the speed detector detects the $50 \%$ of the rated speed, then the READY condition is informed to the host system through the output driver, $U 7$ (pin 13 ~ 14).

(Fig. 308) Control circuit block diagram

(Fig. 309) Ready detector waveforms

Stepping motor control circuit is constructed with direction latch, internal step pulse generator, shift register, phase drive selector, overdrive timer, etc.

Direction latch is a circuit to sample and hold the head seek direction designated by the DIRECTION SELECT signal at every input of the STEP pulses.

The internal step pulse generator is constructed with a counter and a pulse generator. The counter is triggered at the trailing edge of the STEP input pulse, and the second internal step pulse is generated with a delay of 3 msec , approx. from each STEP input pulse by the pulse generator. It makes the stepping motor rotate for 2 steps (3.6 ${ }^{\circ}$ ) in response to one STEP input pulse.

```
Outputs of the direction latch and the internal step pulse generator are input to the shift register and phase drive selector, and they are converted to the appropriate timing signals for uni-polar 1-2 phase drive of the 4 -phase stepping motor. These phase drive signals are supplied to the stepping motor driver, 05 (output pins \(12 \sim 15\) ). In order to improve the torque margin in the seek operation, partially 2-phase drive period is provided by the phase drive selector only in the initial stage when the drive phase is changed.
When the head stops on an even track, phase \(A\) is magnetized, while phase \(\bar{A}\) is magnetized when the head stops on an odd track. The phase \(B\) and \(\vec{B}\) are magnetized only during the seek operation.
The output from the internal step pulse generator is also supplied to the over-drive timer constructed with a re-triggerable counter. During the active period of this timer ( 75 msec, approx.), +12 V power is supplied to the stepping motor coils through the over-drive circuit (Q1) to produce enough torque required for the head seek and the settling operations. After the completion of the settling, only \(45 V\) power is supplied to the stepping motor through the diode, CRl, which minimize the power loss by supplying only the required torque for the holding of the stop position. By the above consideration, heat radiation from the motor is depressed to the minimum level and the stepping motor power consumption of 0.33 W , approx. at the stop condition is achieved.
```


(Fig.310) Stepping motor control circuit waveforms

## 3-2-3. Servo Circuit

The servo circuit aims to maintain the rotational speed of the spindle motor at 300 rpm , and the circuit is mounted on the PCBA assembled with the spindle motor.
Start and stop of the spindle motor ( $D D$ motor Ass'y) is controlled by the MOTOR ON signal supplied through the spindle motor gate in the control circuit.

The spindle motor is a long life $D C$ brushless motor having 3 -phase coils. The coils are driven by the exclusive drive IC. Energization and magnetized direction of the coils are controlled by the signal from the hall elements mounted on the PCBA around the rotor so that they are changed corresponding to the designated rotational direction. The rotational speed is maintained stably and precisely. The feedback signal from the AC tacho-meter in the rotor is converted into the drive voltage ( $F-V$ conversion) by servo IC, and supplied to the driver IC through the phase compensation circuit.

## 3-3. FUNCTION OF TEST POINTS AND VARIABLE RESISTORS

Fig. 311 shows the mounting positions of the test points and variable resistors.


PCBA DD motor servo


PCBA MFD control (C)
(Fig.311) Location of test points and variable resistors

## 3-3-1. Function of Test Points

Twelve test points (two for ground) are equipped on the PCBA MFD control for the check and adjustment of the FDD.
(1) TPl (Track 00 sensor)

Test point to observe the output of the track 00 detection phototransistor (shumitt inverter included). As well as TRACK 00 output signal, TPl becomes LOW level when the head is on track 00 or around track 00 position.

TP1
(Track 00 sensor)

(Fig. 312) Typical waveform of TPl

Note: The TRACK 00 output signal goes TRUE (LOW level) only when the phase A coil of the stepper motor is energized and the direction latch is set to the step-out direction (refer to Fig. 310). Therefore, the level change timing of the TRACK 00 signal is not consistent with that of the TPI signal.
(2) TP2 (Erase gate)

Test point to observe the output of the erase gate.
When TP2 is HIGH level, erase current flows through the erase head. This TP is used for the check and adjustment of the required delay time of the erase gate signal against the WRITE GATE input signal when the tunnel erase head is used.

(Fig.313) Typical waveform of TP2 (for tunnel erase head)

| Delay | Straddle erase head | Tunnel erase head |
| :---: | :---: | :---: |
| On-delay | $0 \mu s$ | $200 \sim 320 \mu s$ |
| Off-delay | $0 \mu s$ | $860 \sim 950 \mu s$ |

(Table 302) Erase gate delay
(3) TP3 (Phase B)

Test point to observe the phase $B$ magnetized period of the stepping motor.

The stepping motor rotates for $2-s t e p s$ in response to one STEP input pulse. Therefore, TP3 becomes HIGH level for a specified period when a step-out command from an even track or when a step-in command from an odd track is executed. Refer to Fig. 310.
(4) TP4 (Index)

Test point to observe the output of the index detection photo-transistor (shumitt inverter included).

The signal level at this TP is opposite to that of INDEX output signal. When the index hole or sector hole (hard sectored disk) is detected, HIGH going pulse is observed at TP4. The photo-transistor is mounted on the front OPT Ass'y and the LED is mounted on the back side of the

STEP input pulse

TP3(Phase $B$ magnetized)

(Fig. 314) Typical waveform of TP3

PCBA DD motor servo.
The test point is used for the following purposes.
(a) Confirmation and adjustment of the disk rotational speed. Speed is adjusted by the variable resistor $R 1$ on the PCBA DD motor servo.
(b) Confirmation and adjustment of the index burst timing. Burst timing is adjusted by the index sensor installation screw in the front opT Ass ${ }^{\prime} y$

TP4 (Index)

(Fig. 315) Typical waveform of TP4 (Speed observation)

| Items | Timing |
| :--- | :--- |
| Index interval | $200 \pm 4 \mathrm{~ms}$ |
| Pulse width | $2 \sim 5.5 \mathrm{~ms}$ |
| Burst delay | $200 \pm 200 \mu \mathrm{~s}$ |

(Table 303) Index timing

(Fig. 316) Typical waveform of TP4 (Burst timing observation)
(5) TP5 (Read data)

Test point to observe the read data pulse.
The signal level at this TP is opposite to that of the READ DATA output signal.

(Fig. 317) Typical wave form of TP5

Fig. 317 shows the waveform at TPS in normal data read operation. In the $F M$ method, $2 F$ and $1 F$ intervals are observed, while $2 F, 4 / 3 F$, and $1 F$ intervals are observed in the MFM method.

| Items | Timing |
| :---: | :---: |
| $2 F$ interval | $4 \mu s$, Nom. |
| $4 / 3 F$ interval | $6 \mu s$, Nom. |
| $1 F$ interval | $8 \mu s$, Nom. |
| Pulse width | $1 \pm 0.5 \mu s$ |

(Table 304) Read data pulse timing
(6) TP6 (File protect sensor)

Test point to observe the output of the file protect detection photo-transistor (shumitt inverter included).

As well as the WRITE PROTECT output signal, TP6 becomes LOW level when a disk with the masked write protect notch (write operation cannot be done) is installed.

(Fig. 318) Typical waveform of TP6
(7) TP7, TP8 (Pre-amplifier)

Test point to observe the read pre-amplifier output signals. The pre-amplifier has two outputs of the order of several dozen to several hundred $m V p-p$, and they differ in phase by $180^{\circ}$ (opposite phase). Both outputs are observed at TP7 and TP8 respectively. For an accurate observation of the read waveforms, use two channels of an oscilloscope with one channel set to Invert mode and Add mode of both channels. Use $G(O V)$ test point for the oscilloscope ground.

TP7 and TP8 are used for checking various characteristics of the read/write head and also for the check and adjustment of the head seek mechanism such as track alignment.

TP7,TP8 (Pre-amp.)

(Fig. 319) Typical waveform of TP7 and TP8
(8) TP9, TP10 (Differentiation amplifier)

Test points to observe the differentiation amplifier output signals. Like the pre-amplifier, the differentiation amplifier also has two outputs of the order of several hundred mVp-p to several Vp-p which differ in phase by $180^{\circ}$. Both outputs are observed at TP9 and TP10 respectively.
For an accurate observation of the waveforms, use two channels of the oscilloscope with one channel set to Invert mode and Add mode of both channels.

Use G (OV) test point for the oscilloscope ground.
TP9 and TP1O are used for checking the total operation of the read/write head and the read amplifier and for the check and adjustment of the head seek mechanism such as track alignment.

(Fig. 320) Typical waveform of TP9 and TP10
(9) TP G (OV) -- PCBA MFD control, PCBA read write amp.

TP G is equipped respectively for two test point blocks (TP1 ~ 6 and TP7 ~10). They are used as the ground terminals for measurement equipment. Be sure to use a small size clip to obtain a probe ground of the equipment.

```
3-3-2. Function of Variable Resistors
```

On the PCBA MFD control and the PCBA DD motor servo, maximum two variable resistors are mounted,
The PCBA MFD control of some PCBA versions and some revision numbers has not the variable resistor R5. Also some types of DD motor Ass'y have not the variable resistor $R 1$ on the PCBA DD motor servo. However, there is interchangeability in function and performance between these PCBAs with the variable resistor and without the variable resistor as far as they have the same parts number ( 8 digits) and the same version number (2 digits). The variable resistors are correctly adjusted before the shipment of the FDD and fundamentally they shall not be readjusted except for by a trained technicians.
(1) R1 on PCBA DD motor servo (Disk rotational speed adjustment)

Variable resistor for adjusting the rotational speed of the disk. It is adjusted so that the index pulse interval at TP4 or at the INDEX output signal is $200_{\mathrm{m} n \mathrm{sec}} \pm 4 \mathrm{msec}$ (see Fig. 315). For the DD motor Ass'y without the variable resistor Rl, the rotation speed of the motor is fixed by the ceramic oscillator in the servo circuit and no adjustment is required.
(2) R5 on PCBA MFD control (Read data asymmetry adjustment)

Variable resistor for adjusting the asymmetry of the read data pulse. Some PCBAs have this variable resistor and others have fixed resistor instead of it.

For a PCBA with the variable resistor, $R 5$, write lf data and observe the pulse intervals at TP5 or at the READ DATA output signal during read operation. Then adjust the variable resistor so that the read data asymmetry in Fig. 321 takes the minimum value. For a double sided FDD, repeat this operation alternately for side 0 and side 1 heads to
obtain the minimum asymmetry for both sides.

(Fig. 321) Read data asymmetry

## SECTION 4

## MAINTENANCE

4-1. GENERAL

4-1-1. Periodic Maintenance

The FDD is designed to be free from periodic maintenance such as replacement of parts, grease-up, etc. when it is operated at a normal operation duty.

However, cleaning of the magnetic head using a cleaning disk is recommended since it is effective to improve the reliability of the data. If some of the parts in the FDD are operated at a specially heavy duty condition, or if the FDD is operated over 5 years, it is recommended to replace the wear parts according to Table 403.

| Periodic maintenance items | Recommended <br> cycle | Required <br> time | Referred <br> items |
| :--- | :---: | :---: | :---: |
| Cleaning of magnetic head | Refer to 4-3-1 <br> and 4-3-2 | 5 min. | $4-3-1$ |
| Replacement of wear parts | Refer to 4-1-3 and 4-5. |  |  |

(Table 401) Periodic maintenance items

## 4-1-2. Check and Adjustment

Table 402 shows all of the check and adjustment items. Following items do not require periodic maintenance. Check and adjustment should be done when required during replacement of the maintenance parts or during trouble shooting referring to items 4-2 and 4-3.

The numbered procedure in Table 402 shows a typical procedure of the general check and adjustment all over the FDD.

| Steps | Check and adjustment items | Required time | Referred items |
| :---: | :--- | :---: | :---: |
| 1 | Adjustment of collet shaft plate | 5 minutes | $4-4-1$ |
| 2 | Adjustment of front lever position | 5 minutes | $4-4-2$ |
| 3 | Check and adjustment of disk pad <br> lever (bail) (double sided only) | 5 minutes | $4-4-3$ |
| 4 | Check of file protect sensor | 5 minutes | $4-4-4$ |
| 5 | Check and adjustment of disk rotation <br> speed | 5 minutes | $4-4-5$ |
| 6 | Check and adjustment of head touch | 5 minutes | $4-4-6$ |
| 7 | Check and adjustment of asymmetry | 5 minutes | $4-4-7$ |
| 8 | Check of read level | 5 minutes | $4-4-8$ |
| 9 | Check of resolution | 5 minutes | $4-4-9$ |
| 10 | Check and adjustment of track <br> alignment | 10 minutes | $4-4-10$ |
| 11 | Check and adjustment of track 00 <br> sensor | 5 minutes | $4-4-11$ |
| 12 | Check and adjustment of track 00 <br> stopper | 5 minutes | $4-4-12$ |
| 13 | Check and adjustment of index burst <br> timing | 5 minutes | $4-4-13$ |

(Table 402) Check and adjustment items

## 4-1-3. Maintenance Parts Replacement


#### Abstract

It is recommended to replace the wear parts periodically if the FDD is operated at a specially heavy duty condition or if it is operated over five years. periodic replacement is not required for the parts if the FDD is operated at a normal operation duty. Table 403 shows all of the maintenance parts. Replace the wear parts according to the recommended replacement cycle. Periodic replacement is not required for parts without a recommended replacement cycle. The replacement of the parts should be done according to each referred item in Table 403.


```
Notes for Table 403:
```

(1) Since the parts number versions of PCBA MFD control (C) vary depending on some factors such as signal interface condition, be sure to confirm the version by checking the name plate on the actual printed circuit board.
(2) The head carriage Ass'y are used always in pair with two guide shafts. The head carriage Ass'y represented by listed parts number in Table 403 includes these guide shafts which parts number is different from that of a head carriage Ass'y itself without these guide shafts.
(3) The listed parts numbers of the front bezel Ass'y and front lever Ass'y are those of standard color (black). For designating other color, use the corresponding parts number.
(4) Periodic replacement is not required for parts without a recommended replacement cycle. Replace the parts when required such as during repair.
(5) If two recommended cycles are listed, the cycle which the parts reach first should have priority.
(6) The required time for replacement includes the time for basic check and adjustment after the replacement.
(7) Order the maintenance parts using the parts number.
(Table 403-1) FD-54A (Single sided, 48tpi) Maintenance parts list

(Table 403-2) FD-54B (Double sided, 48tpi) Maintenance parts list

| Maintenance parts |  |  | Replacement |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parts name | Description | Parts No. | Replacement cycle | Required time | Referred items |
| Head carriage Ass'y (C) <br> (For spare parts) | Note (2) | 17966928-00 | 7,000 head load \& motor on hrs. or $5 \times 10^{6}$ seeks | 45 min . | 4-5-1 |
| Stepping motor Ass'y (C) |  | 14733730-00 | $5 \times 10^{6}$ seeks | 30 min . | 4-5-2 |
| Steel belt |  | 16792300-00 | Replace with stepping motor Ass'y | - | 4-5-2 |
| DD motor Ass'y (C) (Spindle motor) |  | 14733780-00 | 20,000 motor on hrs. | 20 min . | 4-5-3 |
| Collet Ass'y ( C ) |  | 17966923-00 | $3 \times 10^{5}$ clamps | 15 min . | 4-5-4 |
| PCBA TOO sensor |  | 15532004-00 | - | 10 min . | 4-5-5 |
| PCBA MFD control (C) | Not | $15532006-x \mathrm{x}$ | - | 30 min . | 4-5-6 |
| Front OPT Ass'y |  | 15090730-00 | - | 15 min. | 4-5-7 |
| Front bezel Ass'y | Note (3) | 17966807-00 | - | 10 min . | 4-5-9 |
| Front lever Ass'y (C) | Note (3) | 17966924-00 | - | 5 min . | 4-5-10 |
| Css Ass' y |  | 17966927-00 | $3 \times 10$ clamsp | 10 min . | 4-5-11 |
| Clamp cam Ass'y (C) |  | 17966929-00 | $1.5 \times 10^{5}$ clamps | 10 min . |  |
| Eject Ass'y (C) | Option | 17966926-00 | $1.5 \times 10^{5} \mathrm{clamps}$ | 10 min . |  |
|  |  |  |  |  |  |

```
4-1-4. Maintenance Jigs and Tools
    The following are the jigs and tools required for adequate maintenance
    of the FDD.
(1) Equipment
(A) When Simulator \(K A\) (off-line exerciser for \(F D-54\), abbreviated to SKA) is used:
(a) SKA
The following accessories are necessary for operating the SKA (the accessories are supplied with the SKA).
i) SKA/FDD interface cable (-00 type)
ii) Check cable \#1 (for observation of control signals)
iii) Check cable \#2 (for observation of read amp. output signals) iv) SKA/FDD power cable
(b) Oscilloscope (two channels)
(c) DC power supply \((+12 V, 1.2 A\) and \(+5 V, 2 A)\) or SKA power supply. The following accessory is required for the power supply (The accessory is supplied with the SKA power supply).
i) Power cable (4P)
(d) Thermometer and hygrometer
(B) When SKA is not used:
(a) FDD controller and DC power supply (user's system)
(b) Oscilloscope (two channels)
(c) Frequency counter
```

(d) Digital volt meter
(e) DC clip-on ammeter
(f) Thermometer and hygrometer
(2) Tools
(a) Cross-point screwdrivers, M2.6 and M3
(b) Common screwdrivers, small size and medium size
(c) Hexagon wrench key, 1.5mm
(d) A pair of tweezers
(e) Round nose pliers
(f) Cutting pliers
(g) Solder and soldering iron
(h) Hexagon screwdriver, M3
(3) Special jigs
(a) MAX media jig (Jig D, P/N 17890746-01)
(4) Disks
(a) Work disk (commercially available disk)
(b) Cleaning disk (commercially available cleaning disk)
i) Single sided type
ii) Double sided type
(c) Level disk ( $\mathrm{P} / \mathrm{N} 14900015-00$ )
(d) Alignment disk
i) Single sided, 48tpi type ( $\mathrm{P} / \mathrm{N}$ 14900016-20)
ii) Double sided, 48tpi type (P/N 14900016-21)
(5) Other articles used during maintenance
(a) Absolute alcohol (Ethanol)
(b) Cotton swab or gauze
(c) Locking paint (3 Bond, 1401B)
(d) Binding agent (Sumitomo Chemical, Cyano-bond SF, Red)
(e) Screws and washers (Refer to item 5-2-2)
(f) Lubricant (Kantoh Kasei, 946p)

Note: Be sure to use well calibrated equipment and disks.

## 4-2. PRECAUTIONS

4-2-1. Torque Applied to Screws and Locking Paint

The following torque should be applied to screws, unless otherwise specified.

| Size of screws | Torque |
| :---: | :--- |
| M2 | $2 \mathrm{~kg} . \mathrm{cm}$ |
| M2.6 | $4.5 \mathrm{~kg} . \mathrm{cm}$ |
| M3 | $6 \mathrm{kg.cm}$ |
| M3 set screw | $4.5 \mathrm{~kg} . \mathrm{cm}$ |
|  |  |

(Table 404) Torque applied to screws

For tightening or loosening M3 set screws for adjustment and parts replacement, the following procedure should be followed.
(1) For adjustment, remove out the set screw and also remove the locking paint which had applied to the screw itself and around it.
(2) Apply fresh locking paint to the first three threads of the set screw with some narrow object such as a pair of tweezers.
(3) Adjust or tighten the set screw with the specified torque.

For other screws than set screws, apply a drop of locking paint to the designated points after tightening them.

## 4-2-2. Handling of Connectors

(1) Types of connectors

The following connectors are used for the FDD.
(a) Jl: Interface connector
(b) J2: Power connector
(c) J4: Track 00 connector
(d) J5: Front OPT connector
(e) J6: Stepping motor connector
(f) J7: Spindle motor (DD motor Ass'y) connector
(g) J9: Head connector

(Fig. 401) Types of connectors
(2) Connection and disconnection of the connectors

Be sure to turn the power off before connecting and disconnecting the connectors. Connection or disconnection should be done straightly and correctly without applying excessive force to the cables and the post pins.
(3) Precautions for handling the white connectors (J4, J5, J6, J7)
(a) Disconnection of the connector

As shown in Fig. 402, carefully push down the edges of the protruding area of the connector little by little with the finger nails or with a screwdriver.

(b) Connection of the connector

Push the connector into the post pin under the PCBA matching the housing clamper to the groove.
(c) Removal of the pin (for reference)

Refer to Fig. 403.
Depressing the stopper of the pin lightly with a narrow object such
as a pair of tweezers, pull the cable in the direction indicated by the arrow.

(Fig.403) Sectional view of white connectors
(d) Insertion of the pin (for reference)

Before insertion, check the following three points.
i) Confirm that the sheath and the core of the cable are securely clamped.
ii) Confirm that the stopper is lifted as in Fig. 403 and it inhibits accidental removal.
iii) No tarnish or contamination should be on the contact area of the pin or the PCB side post pin. If there is, remove it.

Contact failure may happen if any of these three points is not satisfied.

When you insert the pin, it should be so inserted that the stopper faces the opening side of the housing.

After the insertion, check the connection by pulling the cable lightly.
(4) Precautions for handling the black connector (J9)
(a) Disconnection of the connector

Pull out $J 9$ connector straightly by inserting the narrow points of

(Fig.404) Disconnection of J9
the tweezers into the opening area at the back side of the housing as shown in Fig.404. Be careful not to pull the fine wires.
(b) Connection of the connector

Make the polarizing key position of the housing correspond with the lack of the post pin, and push the housing carefully with the fingers.
(c) Removal of the pin

Lifting up the stopper of the housing with a narrow object such as cutter knife, pull the cable with a pair of tweezers in the direction indicated by the arrow. Refer to Fig. 405 .

(Fig.405) Sectional view of black connector
(d) Insertion of the pin

Before insertion, check the pins according to item (3)-(d), i) through iii).

When you insert the pin, it should be so inserted that the projection side faces the stopper of the housing. After the insertion, pull the cable with a pair of tweezers softly in order to confirm whether it is securely connected.

## 4-2-3. Head Cable Treatment

Head cable should be arranged correctly by the clampers with appropriate margin in length so that the head carriage can move on the guide shafts smoothly.
(1) Clamp the head cable with cable clamper area of the disk guide so that the cable has appropriate looseness when the head carriage is set to track 00 (rear end of the moving area). The appropriate length of the head cable from the head carriage output to the cable clamper is approximately 80 mm (see Fig.406).

Also confirm that the head cable do not touch the tail end of the steel belt.
(2) Thread the head cable through the hole of the disk guide and arrange it under the chassis to hold with a cord clamper. There should be no excessive looseness of the cable between the cable clamper and the cord clamper which may cause undesirable contact of the cable to the disk when inserted. The cable length between the cable clamper and the cord clamper is 65 mm , approx.
(3) Remove the front bezel according to item 4-5-9. Thread the head cable
 connect it to the head connector, J9. The cable length between the U-groove of the disk guide and the head connector is 25 mm , approx. (see Fig.406). If the head cable is too long, turn the cable around the cord clamper under the chassis.


Note: The figure uses the double sided FDD. The same cable arrangement is applied to the single sided FDD.
(Fig. 406 ) Head cable arrangement

4-2-4. Initial Setting of SKA

Following initial setting is required for operating the SKA.

```
Note: Use matched SKA for the FD-54 series. The SKA for the FD-54 has \(430 \Omega\) terminator at the interface receiver which is different from that conventionally used \(150 \Omega\) terminator for the FD-55 series. As to the other performance, SKA for the FD-54 and for the FD-55 are the same. The SKA for the FD-54 series can also be used in the FD-55 series.
```

4-2-4-1. Cable connection and setting of power supply voltage
(1) Set the output voltage of $D C$ power supply to +12 V and +5 V , approx.
(2) Turn the DC power off and connect the power cable to the PSA (SKA PWR) connector of the SKA.
(3) Set the FD PWR switch of the SKA to the OFF position.
(4) Connect the FD PWR OUTPUT of the SKA and the FDD with the SKA/FDD power cable.
(5) Connect the SKA/FDD interface cable. Pay attention to the identification mark of the connector ( $\nabla$ ) so that it locates at the pin 1 and 2 side.
(6) Connect the check cable \#l (Flat cable, 7P connector at the FDD side and 5P connector at the SKA side) between the terminals $1 \sim 5$ of the SKA and TP1 ~ TP6, G of the FDD. For the SKA side, be sure to match the pin numbers of the connector housing and the terminal numbers of the connector. For the FDD, cable connection side pins should be connected to the TPI ~ 5 side.
(7) Connect the check cable \#2 (shield cable is used partially, 5p connectors

(Fig.407) Connection of SKA cable

(Fig.408) Connection of check cable

- 4019 -
at both ends) between the terminals $6 \sim 9, G$ of the SKA and TP7 ~TP10, $G$ of the FDD. Be sure to match the pin numbers of the connector housing and the terminal numbers of the SKA as in Fig. 408.

The shield cable side is TP7, 8, and terminals 6, 7 of the SKA.
(8) Turn the DC power on. Set the FD PWR switch of the SKA to the PSA side.
(9) Key in "CB". (+5V VOLTAGE)
(10) Adjust the DC power voltage so that the DATA indicator of the SKA $\square d \square$ (V) indicates the value within the range of $5.00 \pm 0.1 \mathrm{~V}$.
(11) Key in "F". (STOP)
(12) Key in "CC". ( +12 V VOLTAGE)
(13) Adjust the DC power voltage so that the DATA indicator of the SKA $\square d \square$ (V) indicates the value within the range of $12.00 \pm 0.24 \mathrm{~V}$.
(14) Key in "F". (STOP)

Note: The above items (1), (2), (9) ~ (14) may be omitted for replacement of the FDD or a temporary FDD power off. Remain $D C$ power on and control the FDD power by the SKA PWR switch.

4-2-4-2. Setting of the maximum track number

Before the check and the adjustment of the FDD, set the maximum track number according to the following instructions. Usually the maximum track number is set to 79 at the initial setting, change it to 39.

The setting will be maintained until the main DC power (for SKA) is turned off, or until the RESET switch of the SKA is depressed. Since the FD PWR switch is independent of this setting, it is convenient to maintain the main DC power on for the successive operations.
(1) Key in "CF" (SET TMAX)
(2) The maximum track number set at that time is indecated with the latter two digits of the DATA indicator $\square \perp \square$ (track).

Note: If there is no change in the maximum track number in item (2), depress "F" key.
(3) Key in the maximum track number (39) of the FDD in two digits of decimal notation.
e.g. MAXIMUM TRACK NUMBER 39 (40 cylinders): CF 39

## 4-2-4-3. Setting of step rate and settling time

Generally, the step rate and the settling time of the FDD is the same as the initial value of the SKA (step rate: 6 msec , settling time: 15 msec ) and no initial setting is required.
For the confirmation or the change of the initial setting, execute according to the following procedure. Once the setting is done, it will be maintained until the main $D C$ power (for $S K A$ ) is turned off, or until the RESET switch of the SKA is depressed.
(1) Key in "DB". (SET STEP RATE)
(2) Step rate set at that time is indicated by 0.1 msec scale on the DATA indicator $\square 1]$ (ms).
e.g. DATA indicator $\square \square[\sqrt{6}]$ indicates 6.0msec.
(3) Key in a new step rate down to one decimal place (unit: msec).

Note: If there is no change in step rate in item (2), omit item (3) and forward to item (4).
(4) Key in "F". (STOP ~- Setting of the step rate completes.)
(5) Settling time at that itme is indicated by $0.1 m s e c$ scale on the DATA indicator $\square 1 /$ (ms).
e.g. DATA indicator $\square I I 5$ indicates 15.0 msec .
(6) Key in new settling time down to one decimal place (unit: msec).

Note: If there is no change in settling time in item (5), omit item (6) and depress "F" key to complete the operation.
(7) Depress "F" key. (STOP -- Setting of the settling time completes.)
e.g. STEP RATE 6msec, SETTLING TIME 15msec : DB 30 F 150 F

```
4-2-4-4. Level disk calibration
```

```
Setting of the following calibration value is required for accurate
measurement before the check of the read level or the resolution.
Use a level disk with a calibration value (100% center) written on the
label. The setting will be maintained until the main DC power (for SKA)
is turned off or unitl the RESET switch of the SKA is depressed.
If the calibration value is the same as the initial value (100%) of the
SKA, the initial setting of the following is not required.
```

(1) Innermost track read level
(a) Key in "DO". (CALIBRATION READ LEVEL)
(b) Calibration value set at that time is indicated in the latter three digits of the DATA indicator $\square 1 \square$ (\%).
(c) Key in a new calibration value written on the level disk label (three digits, Max.)
(d) Key in "F". (STOP)

Note: If there is no calibration change in item (b), omit item (c) and depress " $F$ " key.
(2) Innermost track resolution
(a) Key in "Dl". (CALIBRATION RESOLUTION)
(b) Calibration value set at that time is indicated in the latter three digits of the DATA indicator $\square \square \square$ (\%).
(c) Key in a new calibration value written on the level disk label (three digits, Max.)
(d) Key in "F". (STOP)

Note: If there is no calibration change in item (b), omit item (c) and depress "F" key.
e.g. READ LEVEL 103\%, RESOLUTION 96\%: DO 103 F , D1 96 F

## 4-2-4-5. Alignment disk calibration

```
Setting of the following calibration value is required for accurate
measurement before the check and adjustment of the track alignment.
Use a correctly calibrated (0% center) alignment disk with a calibration value written on the label. The setting will be maintained until the main DC power (for SKA) is turned off or until the RESET switch of the SKA is depressed. If the calibration value is the same as the initial value (0\%) of the SKA, the initial setting of the following is not required.
```

(1) SIDE 0 alignment
(a) Key in "EO". (CALIBRATION SIDE 0 ALIGNMENT)
(b) The calibration value set at the time is indicated in the latter two digits of the DATA indicator $\square \perp$ (\%), and the polarity is indicated in the initial digit. If a " 0 " is indicated, the polarity is positive. Polarity indication: plus $;$, minus -
(c) Key in a polarity and a new calibration value (two digits, Max.) written on the alignmerit disk label.
Designation of polarity: Depress " B " key only for minus designation. (No designation is required for plus).
(d) Key in "F". (STOP)
(2) Side 1 alignment (Double sided only)
(a) Key in "El". (CALIBRATION SIDE 1 ALIGNMENT)
(b) The same as in item (1)-(b) ~ (d).


```
    item (c) and depress "F" key.
e.g. Double sided FDD, SIDE O ALIGNMENT + 3%, SIDE 1 ALIGNMENT - 5%,
    INDEX TIMING -25\mus:
    EO 3 F, El B 5 F, E5 B 25 F
INDEX output signal
Index burst (TP7,8)
```



```
Notes: 1. The index timing is calibrated in the SKA according to the following expression.
        Calibrated timing = t - calibration value ( }\mus
2. If the calculated value with the above expression is positive, the polarity is plus, while the polarity is minus when the value is negative.
(Fig. 4l0) Calibration of index burst timing
```

For the check and adjustment of the track alignment using an alignment disk, set the environmental relative humidity to the SKA in order to improve the precision of measurement.

This setting is important when the relative humidity is considerably different from 50\%.

The initial setting of the following is not required if the relative humidity is the same as the initial value (50\%) of the SKA.
(1) Key in "E2". (CALIBRATION RH ALIGNMENT)
(2) The relative humidity set at that time is indicated in the latter two digits of the DATA indicator $\square \square \square$ (\%).
(3) Input the relative humidity percentage in the measurement environment (two digits, Max.).
e.g. RELATIVE HUMIDITY 58\%: E2 58

4-2-4-7. Setting of SKA gain

For this FDD, the SKA gain should be maintained at the initial state (H GAIN indicator is off). If the H GAIN indicator turns on by an erroneous key-in, turn it off by keying in "DD".

4-2-5. Others
(1) Total error test

In the check and adjustment in item 4-4, read/write error test is not included. After the adjustment or the replacement of the maintenance parts, it is recommended to perform a data error test by connecting the FDD to the user's system or the TEAC simulator KB . The window margin test is the most recommended item.
(2) Setting of FDD straps

It is required to confirm. before the operation that the straps (short bars) on the PCBA MFD control are at the appropriate position for the system to be used in the check and adjustment.

When the SKA is used, depress a key which number is the same as the on-state short bar among DSO ~ 3 straps of the FDD and confirm that the indicator is on before various key operations.

If the IU short bar is on, you can turn on the front bezel indicator by "A" (IN USE) key of the SKA.

Notes: l. For simplifying the explanation, following shows only the case when the DSO short bar is on.
2. If the strap position of the FDD is changed from the initial setting at the system installation, be sure to change it back to the initial position after the maintenance operations.
(3) Connection of the probe ground

Connect the probe ground of the equipment as follows:
(a) For the observation at the test points (TP) 7 ~ 10:

Connect the probe ground to the $G$ test point ( $0 V$ ) on the PCBA MFD control.
(b) For the observation at the other test point:

Connect the probe ground to the G test point (OV) on the PCBA MFD control. Or GND (OV) terminal of the system power supply unit, or the SKA GND terminal may be used.
(c) For the observation of the SKA test point: Connect the probe ground to the SKA GND terminal.

Note: When you use the SKA, almost all checks including the read amp. output at TP7 ~ TP10 of the FDD will be done automatically through the check cables \#1 and \#2 and interface cable. Also these signals can be observed by an oscilloscope using the test points on the SKA.
(4) Maintenance environment

Maintenance of the FDD should be done on a clean bench at room temperature and humidity. It is recommended to execute the check and adjustment of the track alignment after leaving the FDD for at least 2 hours at room temperature and humidity. The magnetic head, disk, steel belt, etc. might suffer from dust and dirt if the maintenance is not undertaken in a clean environment.
(5) Orientation of the FDD

Position the FDD as shown in Fig. 411 unless otherwise specified. Horizontal and vertical orientations with lever side up should be used.
(6) Head load

The FD-54 series have no head load solenoid. They are always in head load condition as far as a disk is inserted and the front lever is closed.


Horizontal setting


Vertical setting
(Fig-411) General orientation of the FDD during maintenance
(7) Work disk

When you use the SKA, use a soft sectored disk.

## 4-3. PREVENTIVE MAINTENANCE

4-3-1. Cleaning of Magnetic Head by Cleaning Disk

When you use the FDD in dusty environment, it is recommended to clean the magnetic head surface periodically (e.g. once a month) with a commercially available cleaning disk. Especially for a double sided FDD, it is difficult to clean the head surface, be sure to use the cleaning disk.

For typical usage under typical environmental condition, the cleaning is recommended when data errors often occur.
(A) Equipment
(1) Cleaning disk
(2) SKA or user's system
(B) Cleaning procedure
(1) General method
(a) Start the spindle motor and install an appropriate cleaning disk.

Notes: 1. Do not use a damaged cleaning disk on the surface.
2. For a single sided $F D D$, be sure to install a single sided cleaning disk. The cleaning surface of the disk should be in contact with the head surface. When the FDD is placed horizontally, the magnetic head is located down and it faces the back side of the disk. If a double sided cleaning disk is installed in a single sided FDD, it may damage the head pad.
3. For a double sided FDD, a double sided cleaning disk should be used. Side 0 (lower side) and side 1 (upper side) heads are cleaned simultaneously.
(b) Clean the head at a suitable track position for $10 \sim 30$ seconds, approx. In order to avoid the concentration on a specific track, it is a good way to make the head move between track 00 and the innermost track during cleaning.

Note: The most appropriate cleaning time is different for each type of cleaning disk used.

Excessively long cleaning time is not effective but has possibility to accelerate the head wear.
(c) Remove the cleaning disk.
(2) SKA method
(a) Connect the SKA referring to item 4-2-4 and set the FD PWR switch to the PSA side.
(b) Start the spindle motor by key "5". (MON indicator turns on).
(c) Execute drive select by key "O". (DSO indicator turns on).
(d) Key in "CO" and confirm that the TRACK indication of the SKA becomes "OO". (RECALIBRATE)
(e) Install an appropriate cleaning disk. See item (1)-(a), "Notes".
(f) Key in "C6". (SEEK TEST)
(g) After 10 ~ 30 seconds, depress "F" key.
(h) Eject the cleaning disk.

4-3-2. Direct Cleaning (Single sided FDD only)

This cleaning method is applied only to a single sided FDD.
If this method is applied to a double sided FDD, gimballed mechanism
of the head might be damaged.
If visible dirt is on the head surface when the head pad arm is lifted up manually during maintenance, perform direct cleaning as follows:
(A) Equipment
(1) Absolute alcohol (Ethanol)
(2) Cotton swab or gauze
(B) Cleaning procedure
(1) Lightly dampen a cotton swab or a gauze with alcohol.
(2) Lift up the pad arm (see Fig.412) and clean the head surface carefully with the cotton swab or the gauze.

Note: Do not touch the pad surface.
(3) Wipe the head surface with clean dry cloth after the evaporation of the alcohol.
(4) After confirming that the dirt is cleaned off and no fluff is left on the head surface, let the pad arm down carefully.

(Fia.412) Direct cleaning of magnetic head (Single sided only)

4-4. ChECK AND ADJUSTMENT

4-4-1. Adjustment of Collet Shaft Plate
(A) Equipment
(1) Cross point screwdriver, M3
(2) Locking paint
(B) Adjustment procedure
(1) Remove two fixing screws of the shield cover (see Fig.413) and remove it.
(2) Loosen two fixing screws of the collet shaft plate Ass'y so that the collet shaft plate can be moved manually without getting out of place.
(3) Clamp the collet by turning the front lever.
(4) In this condition, adjust the collet shaft plate and tighten two fixing screws with the specified torque so that the visual distance of the gap between the collet shaft and the hole of the collet holder becomes even (see Fig.414).
(5) Up and down the collet by turning the front lever and confirm that it does so smoothly without being cought by the spindle cup.
(6) Apply a drop of locking paint of the fixing screws.
(7) Install the shield cover in the reverse order of item (1).

(Fig.414) Location of collet shaft plate

'Fig.413) Gap of collet shaft plate

4-4-2. Adjustment of Front Lever Position
(A) Equipment
(1) Hexagon wrench key, 1.5 mm
(2) MAX media jig (Jig D)
(B) Adjustment procedure
(1) Turn the front lever to close position and loosen a lever fixing set screw to pull out the lever for 0.5 mm , approx.
(2) Tighten the set screw.
(3) Turn the front lever to open position and insert the MAX media jig as shown in Fig. 415 (the notch side to be left).
(4) Turn the front lever to close position and loosen the set screw again. Then push the lever against the MAX midia jig. Confirm that the pin of the lever shaft goes into the slot of the front lever.
(5) Position the handle of the front lever forms right angle against the longitudinal side of the front bezel. And tighten the set screw with the specified torque. (See Fig.416).
(6) Close the front lever and confirm that the blade of the lever does not nip the MAX media jig.
(7) Open the front lever and remove the jig.

Note: Refer to item $4-2-1$ as to handling of the set screws.

(Fig.415) Adjustment of front lever

(Fig.416) Front lever position

4-4-3. Check and Adjustment of Disk Pad Lever (Bail)

This item applies only to the double sided FDDs.
(A) Equipment
(1) Cross point screwdriver, M2.6
(2) Binding agent
(B) Check and adjustment procedure
(1) Open the front lever to be able to insert the disk.
(2) Confirm a little gap $(0.1 \sim 0.3 \mathrm{~mm}$, approx.) is spaced between the bail and the top of the stop cam of the CSS Ass'y (C). (See Fig.418).
(3) If the item (2) is not satisfied, turn the outside adjusting screw (see Fig.417) of the bail so that the bail and the top of the stop cam are separated with 0.2 mm , approx.
(4) In the process of inserting a disk slowly, confirm that the disk jacket does not touch the side 0 nor the side 1 head and goes into the FDD smoothly with appropriate space margin.
(5) Open and close the front lever two or three times to confirm the clampings of the disk are done smoothly.
(6) In the process of ejecting the disk slowly, confirm that the side 0 and side 1 heads do not catch the head window edge of the disk jacket (opening area of the jacket to make the head be in contact with the disk surface) and that the disk can be drawn out smoothly with appropriate space margin.
(7) Insert the disk again and close the front lever.
(8) Confirm that a little gap ( $0 \sim 0.5$ mam, approx.) is spaced between the stop cam and the disk jacket without activating the stop cam of the CSS Ass'y when the disk jacket is depressed lightly with a finger from the front bezel side.
(9) If the item (8) is not satisfied, turn the inside adjusting screw (see Fig. 4l7) of the bail so that the gap between the disk jacket and the stop cam becomes $0.1 \sim 0.2 \mathrm{~mm}$, approx.
(10) Apply binding agent to the two adjusting screw to fix it to the bail.
(11) Open the front lever to draw out the disk.

(Fig. 417) Adjustment of bail

(Fig.418) Gap of bail and stop cam

- 4043 -

4-4-4. Check of File Protect Sensor
(A) Equipment
(1) MAX media jig (Jig D)
(2) Digital voltmeter (or oscilloscope)
(3) SKA or user's system
(B) Check procedure
(1) General method
(a) Place the FDD on the work bench with the LED indicator up and the front lever down. (See Fig. 421).
(b) Connect a digital voltmeter or an oscilloscope (DC range,lv/div) to TP6 (File protect sensor) on the PCBA MFD control.
(c) Install the MAX media jig as in Fig. 421 and set it so that the notch A area is located on the light pass from the file protect sensor.
(d) Adjust the orientation of the FDD so that it is not exposed with strong light outside.
(e) Confirm that the voltage measured at TP6 when power is supplied to the FDD is within the following range.

Notch A position TP6 voltage: 0.5 V , Max.
(f) Pull out the jig a little so that the notch B area is located on the light pass.
(g) Confirm that the voltage measured at TP6 when power is supplied to the $F D D$ is within the following range.

Notch B position TP6 voltage: 3v, Min.

(Fig.421) Check of file protect sensor
(2) SKA method
(a) Connect the SKA according to item 4-2-4 and set the FD PWR switch to the PSA side.
(b) Execute the general method described in item (1)-(a) through (e). WRROT indicator of the SKA turns on when drive selection is executed by key "O". (DSO indicator turns on).
(c) Execute the general method described in item (1)-(f) and -(g). WRROT indicator of the SKA turns off.

4-4-5. Check and Adjustment of Disk Rotation Speed

This item is only applied to the FDD which has a DD motor Ass'y with the variable resistor $R 1$ for adjusting the rotational speed of the disk on the PCBA DD motor servo. Refer to Fig. 311 as to the mounting position of the variable resistor Rl. For the DD motor Ass'y without the variable resistor, the rotation speed is fixed by the ceramic oscillator in the servo circuit and no adjustment is required.
(A) Equipment
(1) Common screwdriver, small size
(2) SKA or user's system
(3) Frequency counter (not required when the SKA is used)
(4) Work disk (soft sectored)
(B) Check and adjustment procedure
(1) General method
(a) Connect the frequency counter to TP4 (Index) of the PCBA MFD control or to the INDEX interface signal line.
(b) Start the spindle motor and install a work disk.
(c) Set the head to track 00 .
(d) Confirm that the pulse interval at TP4 is within the following range. TP4 pulse interval: $200 \pm 3 \mathrm{msec}$
(e) If the value in item (d) is out of the specified range, adjust the variable resistor $R 1$ on the $P C B A D D$ motor servo to obtain the median value in the specified range in item (d).
(2) SKA method
(a) Connect the SKA referring to item 4-2-4 and set the FD PWR switch to PSA side.
(b) Start the spindle motor by key "5". (MON indicator turns on).
(c) Insert a soft sectored work disk.
(d) Execute drive select by key "O". (DS 0 indicator turns on).
(e) Key in "CO" and confirm that TRACK indication becomes "OO". (RECALIBRATE)
(f) Key in "C3". (INDEX PERIOD)
(g) Confirm that the DATA indicator $\square \square$ (ms) indicates a value within the following range.

INDEX interval: 200.0 $\pm 3.0 \mathrm{msec}$
(h) If the value in item (g) is out of the specified range, adjust the variable resistor $R 1$ on the PCBA DD motor servo to obtain the median value in the specified range in item (g).

```
4-4-6. Check and Adjustment of Head Touch
    Note: The adjustment applies to a single sided FDD only.
    (A) Equipment
    (1) Work disk
    (2) Common screwdriver, small size
(3) SKA or user's system
(4) Oscilloscope (not required when the SKA is used)
(5) DC clip on ammeter (not required when the SKA is used)
(6) Locking paint
(B) Adjustment procedure
(1) General method
```

(a) Connect an oscilloscope to TP9 or TP10 (Differentiation amp.) on the PCBA MFD control.

Oscilloscope range: AC mode, 0.2 V
(b) Start the spindle motor and install a work disk.
(c) Set the head to the innermost track.
(d) Repeat the cycle of one write rotation and one read rotation. Write data should be the fixed pattern of 2 F ( 250 KHz of WRITE DATA frequency).
(e) Write down the average read level measured during the read operation of item (d).
(f) Execute item (d) and (e) with a slight depression (very slight depression easy to release: $10 \sim 20 \mathrm{~g}$ ) by a finger on the top of the upper head (double sided) or of the pad arm (single sided), and measure the average read level as in item (e).
(g) Confirm that the read level measured in item (e) is greater than $80 \%$ of that in item (f).
(h) For a double sided FDD, execute items (d) through (g) respectively for the side 0 and the side 1 heads.
(i) After making the head move to track 00 , execute items (d) through (h).
(j) Head touch adjustment for a single sided FDD:
i) At the innermost track, turn the groove on the upper side of the head pad by $30^{\circ}$ steps, approx. with a common screwdriver (see Fig. 420). At each turning of the groove, execute write and read operations in item (d).
Be sure to take apart the common screwdriver from the head pad during write or read operation.
Note: Be careful not to push the head pad strongly with the common screwdriver. Also do not touch the pad surface to which a disk will be in contact.
ii) After turning the pad position around $360^{\circ}$, set the position again to the position where the highest read level was obtained. Then execute items (d) through (g) at the innermost track.
iii) Continue the operation until the items ( $q$ ) and (i) are sufficiently satisfied. Following causes are assumed for the insufficient result in item (g) or (i) after fine adjustment of the pad position.


- 4051 -
i) Inferior disk:

Disk and/or jacket is deformed or damaged. Replace the work disk with a new one.

- ii) Inferior head flexture:

Because of the failed performance of the bail or the CSS Ass'y in item 4-4-3, the flexture on which the head piece is located may be deformed. Remove the disk. Then open and close the front lever slowly to observe the gap between the side 0 and the side 1 heads from the front bezel. If the two head surfaces are not in parallel each other, it is considered to be the deformation.

Replace the head carriage Ass'y according to item 4-5-1.
(2) SKA method
(a) Connect the SKA according to item 4-2-4 and set the FD PWR switch to the PSA side.
(b) Start the spindle motor by key "5". (MON indicator turns on). Install a work disk and execute drive select by key "O". (DSO indicator turns on).
(c) Key in "CO" and confirm that the TRACK indicator becomes " 00 ". (RECALIBRATE)
(d) Key in "Cl" (SEEK TMAX)
(e) Key in "D3". (WRITE/READ LEVEL PRE 2F)
(f) Write $2 F$ and read operations are repeated. The DATA indicator $[\square]$ (mV) indicates the average read level of TP7 and TP8 (Pre-amp.) after each cycle of operation (one rotation of write and one rotation of read) is finished.
(g) Observe the DATA indicator $\square \square \square$ ( mV ) with a slight depression (very slight depression easy to release: $10 \sim 20 \mathrm{~g}$ ) by a finger on the top of the upper head (double sided) or of the pad arm (single sided).
(h) Confirm that the read level measured in item (f) is more than $80 \%$ of that in item ( g ).
(i) For a double sided FDD, depress "F" key to stop and then depress "4" key to execute items (e) through (h) for the side 0 and the side 1 heads respectively. The side is changed alternately by a depression of "4" key. If side 1 is selected, SIDE 1 indicator of the SKA turns on.
(j) Key in "C0" (RECALIBRATE) and execute items (e) through (i) in the similar way.
(k) Head touch adjustment for a single sided FDD: Refer to item (j) of "General method".
(L) Possible causes for the inferior head touch in a double sided FDD: Refer to item (k) of "General method".

4-4-7. Check and Adjustment of Asymmetry
(A) Equipment
(1) Work disk
(2) SKA or user's system
(3) Oscilloscope
(B) Check and adjustment procedure
(1) General method
(a) Connect an oscilloscope to TP5 (Read data) on the PCBA MFD control or to the READ DATA interface line.
Oscilloscope range : DC mode, $2 \mathrm{~V}, 1 \mu \mathrm{sec}$
(b) Start the spindle motor and install a work disk.
(c) Set the head to the innermost track.
(d) Execute $1 F$ write operation ( 125 KHz of WRITE DATA frequency).
(e) Measure the asymmetry referring to Fig. 421.

Note: Oscilloscope should be so set that three read data pulses can be observed. Asymmetry width should be measured at the second read data pulse from the trigger pulse.
(f) Confirm that the asymmetry is within the following range. Innermost rrack $1 F$ asymmetry : $0.6 \mu \mathrm{sec}, \mathrm{Max}$.
(g) For a double sided FDD, execute items (d) through (f) for the side 0 and the side 1 heads respectively.

(Fig.421) Measurement of asymmetry
(h) If the value in item (f) or (g) is out of the specified range, adjust according to the following procedure.

The adjustment can be done only for the PCBA versions or the PCBA revision numbers with the variable resistor $R 5$ on the PCBA MFD control. No adjustment can be done without R5.
i) Adjust the variable resistor $R 5$ so that the asymmetry takes the minimum value while repeating $1 F$ write and $1 F$ read operations alternately.
ii) For a double sided FDD, repeat the operation in item i) for the side 0 and the side 1 heads alternately. The variable resistor shall be so adjusted that both asymmetry for side 1 and side 0 heads take the minimum value.
(i) If the values in items (f) and (g) are out of the specified range in the PCBA without the variable resistor $R 5$, or if the adjustment in item (i) cannot be done sufficiently even if 85 is mounted, following causes are assumed.
i) Leakage flux density in the environmental condition of the FDD is high:
If there is some flux source near the FDD such as magnet, transformer, motor, Brown tube, magnetized iron plate, etc., take

```
    it apart from the FDD. Then measure the asymmetry and adjust again.
ii) Inferior disk:
    Replace the work disk.
iii) Inferior head:
    Replace the head carriage Ass'y according to item 4-5-1.
iv) Inferior PCBA MFD control:
    Replace the PCBA according to item 4-5-6.
```

(2) SKA method
(a) Connect the SKA according to item 4-2-4 and set the FD PWR switch to the PSA side.
(b) Key in "BlF". (1F DUTY)
(c) Connect an oscilloscope to the DOUT terminal of the SKA.

Oscilloscope range : DC mode, $2 \mathrm{~V}, 0.2 \mu \mathrm{sec}$
(d) Start the spindle motor by key " 5 ". (MON indicator turns on).
(e) Install a work disk.
(f) Execute drive select by key "O". (DSO indicator turns on).
(g) Key in "CO" and confirm that the TRACK indicator becomes " 00 ". (RECALIBRATE)
(h) Key in "Cl". (SEEK TMAX)
(i) Key in "D4". (WRITE/READ LEVEL PRE 1F)
(j) Measure the asymmetry as in Fig. 422.

SKA DOUT

(Fig.422) Measurement of asymmetry (SKA)
(k) Confirm that the asymmetry is within the following range.

Innermost track $1 F$ asymmetry : $0.6 \mu \mathrm{sec}$, Max.
(L) For a double sided FDD, depress "4" key and execute items (i) through (k) for the side 0 and the side 1 heads respectively. The side is changed alternately by a depression of "4" key. If side 1 is selected, SIDE 1 indicator of the SKA turns on.
( $m$ ) If the value in item ( $k$ ) or (L) is out of the specified range, adjust according to the following procedure. The adjustment can be done only for the PCBA versions or the PCBA revision numbers with the variable resistor $R 5$ on the PCBA MFD control. No adjustment can be done without R5.
i) Adjust the variable resistor $R 5$ so that the asymmetry takes the minimum value by keying in "D4".
ii) For a double sided FDD, execute the operation in item i) for both sides alternately by chainging the side by key "4". The variable resistor shall be so adjusted that both asymmetry for side 1 and side 0 heads take the minimum value.
( $n$ ) If the values in items ( $K$ ) and (L) are out of the specified range in the PCBA without the variable resistor $R 5$, or if the adjustment in item ( $m$ ) cannot be done sufficiently even if $R 5$ is mounted, refer to item (j) of "General method".

```
4-4-8. Check of Read Level
    (A) Equipment
    (1) Level disk
    (2) SKA or user's system
    (3) Oscilloscope (not required when the SKA is used)
    (B) Check procedure
    (1) General method
    (a) Use two channels of an oscilloscope and connect them to TP9 and TP10
        (Differentiation amp.) on the PCBA MFD control.
    Oscilloscope range : AC mode, 0.5V
    Set both channels, l and 2 to the above range. Set either of the
    channels to Invert mode and ADD both channels.
    (b) Start the spindle motor and install a level disk.
    (c) Make the head move to the innermost track.
    (d) Execute 2F write operation for one rotation of the disk (250 KHz of
        WRITE DATA frequency).
    (e) Measure the average amplitude (Vp-p) of the read waveform as in
        Fig.423.
        (f) Calculate the read level by substituting the following expression
        with the measured value in item (e) and READ LEVEL calibration
        value (see level disk label).
    Read level (true value) = Measured value }\times\frac{100}{Calibration value
```

TP9, TP10 (ADD

(Fig.423) Measurement of average read level (2F)
(g) Confirm that the true value of the read level is within the following range.

Innermost track read level : 1.4Vp-p, Min.
( $h$ ) For a double sided FDD, execute items (d) through (g) for the side 0 and the side 1 heads respectively.
(i) If the value in item (g) or ( $h$ ) is out of the specified range, following causes are assumed.
i) Inferior disk:

Disk and/or jacket is deformed or damaged. Replace the level disk with a new one.
ii) Abnormal disk rotational speed:

Check and adjust according to item 4-4-5.
iii) Inferior head touch:

Check and adjust according to item 4-4-6.
iv) Inferior head:

Replace the head carriage Ass'y according to item 4-5-1.
v) Inferior PCBA MFD control:

Replace the PCBA MFD control according to item 4-5-6.
(k) Eject the level disk and release the Invert and ADD modes of the oscilloscope.
(2) SKA method
(a) Connect the SKA referring to item 4-2-4 and set the FD PWR switch to the PSA side.
(b) Start the spindle motor by key "5". (MON indicator turns on).
(c) Install a level disk.
(d) Execute drive select by key "O". (DSO indicator turns on).
(e) Key in "CO" and confirm that the TRACK indication becomes "00". (RECALIBRATE)
(f) Key in "Cl". (SEEK TMAX)
(g) Key in "D7". (WRITE/READ LEVEL DIF 2F) Calibration value of the level disk should be set previously in the SKA.
(h) Confirm that the DATA indicator $\square \square \square$ (mvo-p) indicates the value within the following range.
Innermost track read level : 700 mVo p, Min.
(i) For a double sided FDD, depress key "4" and execute items (g) and (h) for the side 0 and the side 1 heads respectively. The side is changed alternately by a depression of "4" key. If the side 1 is selected, SIDE 1 indicator of the SKA turns on.
(j) If the value in item (h) or (i) is out of the specified range, refer to item (i) of "General method".
(k) Eject the level disk.

## 4-4-9. Check of Resolution

(A) Equipment
(1) Level disk
(2) SKA or user's system
(3) Oscilloscope (not required when the SKA is used)
(B) Check procedure
(1) General method
(a) Use two channels of an oscilloscope and connect them to TP7 and TP8 (Pre-amp.) on the PCBA MFD control.

Oscilloscope range : AC mode, $50 \mathrm{mV} \sim 0.1 V$
Set both channels, 1 and 2 to the above range. Set either of the channels to Invert mode and ADD both channels.
(b) Start the spindle motor and install a level disk.
(c) Make the head move to the innermost track.
(d) Execute $1 F$ write operation for one rotation of the disk $(125 \mathrm{KHz}$ of WRITE DATA frequency).
(e) Measure the average amplitude (V1F) as in Fig. 424.
(f) Execute $2 F$ write operation as in item (d) (double in frequency to that in item (d)).
(g) Measure the average amplitude (V2F) as in Fig. 424 .
(h) Calculate the resolution by substituting the following expression with the measured values V1F, V2F, and RESOLUTION calibration value (see level disk label).

## TP7,TP8 (ADD)


(Fig.424) Measurement of resolution

Resolution (true value) $=$ V2F/V1F $\times 100 /$ Calibration value (\%)
(i) Confirm that the true value is within the following range. Innermost track resolution: 55\%, Min.
(j) For a double sided FDD, execute items (d) through (i) for the side 0 and the side 1 heads respectively.
(k) If the value in item (i) or (j) is out of the specified range, following causes are assumed.
i) Inferior disk:

Disk and/or jacket is deformed or damaged. Replace the level disk with a new one.
ii) Inferior disk rotational speed: Check and adjust according to item 4-4-5.
iii) Inferior head touch:

Check and adjust according to item 4-4-6.
iv) Inferior head: Replace the head carriage Ass'y according to item 4-5-1.
v) Inferior PCBA MFD control:

Replace the PCBA MFD control according to item 4-5-6.
(L) Eject the level disk and release the Invert and Add modes of the oscilloscope.
(2) SKA method
(a) Connect the SKA referring to item 4-2-4 and set the FD PWR switch to the PSA side.
(b) Start the spindle motor by key "5". (MON indicator turns on).
(c) Install a level disk.
(d) Execute drive select by key "O". (DSO indicator turns on).
(e) Key in "CO" and confirm that the TRACK indication becomes "00". (RECALIBRATE)
(f) Key in "Cl". (SEEK TMAX)
(g) Key in "D8". (RESOLUTION)

The calibration value of the level disk should be set previously in the SKA.
(h) Confirm that the DATA indicator $\square \square \square$ (\%) indicates the value within the following range.

Innermost track resolution: 55\%, Min.
(i) For a double sided FDD, depress key "4" and execute items (g) and (h) for the side 0 head and the side 1 head respectively. The side is changed alternately by a depression of "4" key. If the side 1 is selected, SIDE 1 indicator of the SKA turns on.
(j) If the value in item ( $h$ ) or ( $k$ ) is out of the specified range, refer to item ( $k$ ) of "General method".
(k) Eject the level disk.

```
4-4-10. Check and Adjustment of Track Alignment
```

(A) Equipment
(1) Cross point screwdriver, M3
(2) Common screwdriver, medium
(3) Alignment disk
(4) ISKA or user's system
(5) Oscilloscope
(6) Hygrometer.
(7) Locking paint
(B) Check and adjustment procedure

Note: Check and adjustment of track alignment should be done in an
environment of general room temperature and humidity. Even if the environmental condition is within the specified operational condition, extreemly high or low temperature, or extreemly high or low humidity should be avoided. Check and adjustment should be done after two hours, Min. of storing in the above mentioned condition. It is recommended that the orientation of the FDD for the track alignment check is the same as when the FDD is actually installed in the user's system.
(1) General method
(a) Use two channels of an oscilloscope and connect them to TP9 and TP10 (Differentiation amp.) on the PCBA MFD control. Also connect the external trigger of the oscilloscope to TP4 (Index) and apply positive trigger.

Oscilloscope range : AC mode, $0.5 \mathrm{~V}, 20 \mathrm{msec}$
Set both channels, 1 and 2 to the above range. Set either of the channels to Invert mode and Add both channels.

```
(b) Start the spindle motor and install an alignment disk.
(c) Set the head to the alignment check track.
    Alignment check track: track l6
```

(d) Confirm that two lobe patterns as in Fig. 425 can be observed (it is not necessary that the levels of VA and VB are equal). If only one lobe pattern can be observed or if two lobes become one pattern, the head is not on the alignment check track. In such event, execute step-out or step-in operation for 2 tracks space to obtain the most similar waveform to that in Fig. 425.

Note: The above number of tracks to be stepped is required to make the alignment track position be fit with the magnetized condition of the basic magnetized phase " A " of the stepping motor. If the stepped track numbers are inassured, set it again from track 00 (TRACK OO output signal becomes TRUE). For the FDD, the lobe pattern as in rig. 425 should be observed at the track of even number.
(e) After one or several step-outs from the check track, step in the head to the check track again and measure VA and $V B$ at that time.
(f) Calculate the true value of misalignment by substituting the value in item (e) and ALIGNMENT calibration value (see alignment disk label, attention to the side).

Misalignment (true value) $=\frac{V A-V B}{\text { Larger value in } V A \& V B} \times 100$

- Calibration value) - (Relative humidity - 50) $\times \mathrm{K}$

K is humidity compensation factor.
$\mathrm{K}=0.26$

(Fig.425) Alignment check lobe pattern
e.g. $V A=0.58 \mathrm{~V}, \mathrm{VB}=0.61 \mathrm{~V}$, Calibration value $=-6(\%)$, Relative humidity $=65$ \%

$$
\begin{aligned}
\text { Misalignment (true value) } & =\left\{\frac{0.58-0.61}{0.61} \times 100-(-6)\right\}-(65-50) \\
& \times 0.26=-2.8 \%
\end{aligned}
$$

If the calculated value is positive, the magnetic head is shifted inward from the reference position, while the head is shifted outward from the reference position when the value is negative.
(g) Conversely, measure VA and VB when the head is on the alignment check track by stepping-out after one or several step-ins.
(h) Calculate the true value of misalignment as described in item (f).
(i) Confirm that both of the calculated values in items (f) and (h) are within the following range.

True value of misalignment: 30\%, Max.
(j) For a double sided FDD, execute items (c) through (i) for the side 0 and the side 1 heads respectively.
(k) If the value in item (i) or (j) is out of the specified range, adjust the track alignment according to the following procedure:
i) Loosen two fixing screws of the stepping motor a little.

```
ii) Insert a common screwdriver from the back side of the FDD as
    shown in Fig.426 and depress it to the geared area of the stepping
    motor.
iii) Repeat step-in and step-out operations and adjust the misalignment
    to be the smallest on the alignment check track during both
    step-in and step-out operations by the screwdriver (stepping
    motor moves little by little).
Note: When you adjust the alignment by observing the lobe pattern
    using the oscilloscope, pay attention to the calibration value
    on the alignment disk label and the ambient relative humidity.
    (1) Calibration value + (Relative humidity - 50) x K\geq0:
    When the left side lobe pattern level, VA is assumed as "l",
    lobe pattern ratio should be so adjusted that the right side
    lobe pattern level VB takes the following value:
    VB=1-\frac{Calibration value + (Relative humidity - 50) x K}{100}
    (2) Calibration value + (Relative humidity - 50) x K < 0:
        When the right side lobe pattern level, VB is assumed as "1",
        lobe pattern ratio should be so adjusted that the left side
        lobe pattern level VA takes the following value.
        VA = 1 - Calibration value + (Relative humidity -50) x K
        e.g. Calibration value = -6%, Relative humidity = 35%:
            -6+(35-50)\times0.26 = -9.9<0
        VA = 1- -6+(35-50)\times0.26
```

iv) For a double sided $F D D$, repeat the adjusting operation in item iii) alternately for the side 0 and the side 1 heads unitl the both
misalignment take the smallest value.
v) Tighten the two fixing screws of the stepping motor little by little for adjusting the true value of misalignment after tightening the screws with the following specified torque to be within $\pm 20 \%$. Stepping motor fixing torque: $9 \mathrm{Kg} . \mathrm{cm}$
vi) Remove the alignment disk.
vii) Apply a drop of locking paint to the head of the stepping motor fixing screws.
viii) check and adjust the track 00 sensor according to item 4-4-11.
ix) check and adjust the track 00 stopper according to item 4-4-12.
(L) Release the Invert and Add modes of the oscilloscope.

(Fig.426) Adjustment of track alignment
(2) SKA method
(a) Connect the SKA referring to item 4-2-4 and set the FD PWR switch to the PSA side.
(b) Use two channels of an oscilloscope. Connect the lst channel to the DOUT terminal of the SKA and the 2nd channel to the DIF terminal of the SKA. Apply positive trigger by DOUT texminal.

Oscilloscope range
The lst channel: DC mode, $2 \mathrm{~V}, 20 \mathrm{msec}$ The 2nd channel: AC mode, lV, 20 msec
(c) Key in "B9F" (INDEX observation)
(d) Start the spindle motor by key "5". (MON indicator turns on).
(e) Install an alignment disk.
(f) Execute drive select by key "O". (DSO indicator turns on).
(g) Key in "CO" and confirm that the TRACK indicator becomes "00". (RECALIBRATE)
(h) Set the head to the alignment check track. Key in "C2 16" and confirm that the TRACK indication becomes " 16 ".
(i) Confirm that two lobe patterns as in Fig. 425 can be observed by the oscilloscope (it is not necessary that the levels of VA and VB are equal).
If only one lobe pattern can be observed or if two lobes become one pattern, the head is not on the alignment check track. In such event, execute step-in or step-out operation for 2 track space to obtain the most similar waveform to that in Fig. 425. Step operation can be done by key "8" (STEP-IN) and key "9" (STEP-OUT).

By a depression of these keys, head will move for one track space.

Note: The above number of tracks to be stepped is required to make the alignment track position be fit with the magnetized condition of the basic magnetized phase " A " of the stepping motor.
For the FDD, the lobe pattern as in Fig. 425 should be observed at the track of even number.
(j) Confirm that the $H$ GAIN indicator of the SKA is off. If it is on, turn it off by depressing "DD" key.
(k) Key in "E3" (ALIGNMENT)

Calibration value of the alignment $d i s k$ and environmental relative humidity should be set previously in the SKA.
(L) Confirm all the indications on the DATA $\square \square \square$ (\%) indicator are within $\pm 30 \%$.
The initial digit of the DATA indicator is the symbol. $f(+)$ mark indicates that the head is shifted inward from the reference position, while - mark indicates that the head is shifted outward.
(m) For a double sided FDD, execute the same check for the side 1 head according to the following procedure.

```
    i) Key in "O" following the operation of item (L) (during execution of \(E 3\) command) and confirm that SIDE 1 indicator of the SKA turns on.
ii) Confirm as in item (L).
Note: In order to change the head to side 0 , key in "O" again. (SIDE 1 indicator turns off).
```

(n) Depress "F" key (STOP).
(o) If the value in items (L) or ( $m$ ) is out of the specified range, adjust
the track alignment according to the following procedure.

```
    i) Loosen the two fixing screws of the stepping motor a little.
ii) Insert a common screwdriver from the back side of the FDD as shown
    in Fig.426 and depress it to the geared area of the steppint motor.
iii) Key in "E3" and adjust the misalignment so that the DATA indicator
        \square|\ (%) shows the smallest value. The stepping motor moves
        little by little by the screwdriver.
    iv) For a double sided FDD, repeat the adjusting operation in item iii)
        alternately for side 0 and side l heads until the both misalignment
        take the smallest value.
    v) Tighten the two fixing screws of the stepping motor little by
        little to obtain the value within }\pm20%\mathrm{ on the DATA indicator when
        the screws are tightened with the following specified torque.
        Stepping motor fixing torque: 9Kg.cm.
    vi) Remove the alignment disk.
vii) Apply a drop of locking paint to the screw head of the stepping
    motor fixing screws.
viii) Check and adjust the track 00 sensor according to item 4-4-1l.
    ix) Check and adjust the track 00 stopper according to item 4-4-12.
(p) Release the Invert and Add modes of the oscilloscope.
```

4-4-11. Check and Adjustment of Track 00 Sensor
(A) Equipment
(1) Common screwdriver, M3
(2) Work disk
(3) Alignment disk
(4) SKA or user's system
(5) Oscilloscope (or digital voltmeter)
(6) Locking paint
(B) Check and adjustment procedure
(1) General method
(a) Use two channels of an oscilloscope and connect them as follows:
i) The lst channel: STEP interface signal (pin No. 20) or PCBA MFD control U4, pin 5.
ii) The 2nd channel: PCBA MFD control TPl (Track 00 sensor). iv range
iii) External trigger: DIRECTION SELECT interface signal (pin No.18) or PCBA MFD control U4, pin 11.
$(+)$ trigger
(b) Start the spindle motor and install a work disk.
(c) Make the head move to track 00 .
(d) Confirm that the timings tA and tB of the Track 00 sensor signal (TP1) is within the following range when the DIRECTION SELECT (trigger signal) and the STEP signal ( 6 ms interval) as shown in Fig. 427 is supplied.

```
TPl tA: 3.1 ~ 5.4msec
TP1 tB: 0~ 5.8msec
```

(e) If the value in item (d) is out of the specified range, adjust the position of the track 00 sensor according to the following procedure.
i) Loosen the fixing screw of the track 00 stopper (see Fig. 429 and shift the stopper in the step-out direction (make apart from the rear side of the head carriage).
ii) Connect an oscilloscope to TP9 or TPlo (Differentiation amp.) of the PCBA MFD control. Oscilloscope range: AC mode, 0.2 V , 20msec
iii) Install an alignment disk. The track alignment should be adjusted correctly according to item 4-4-10.
iv) Make the head move to the position where the lobe pattern as in Fig. 425 can be observed.
v) Remove the alignment disk.
vi) Step out the head for 16 tracks' space. (The head moves to track 00).
vii) Change the connection of the oscilloscope as item (a).
viii) Loosen the fixing screws of the track 00 sensor (see Fig. 428) and move the sensor a little so that the timing tA in Fig. 427 falls within the following range.

Adjusting target of TP1 tA: $3.4 \sim 4.6 \mathrm{msec}$
ix) Repeat the adjustment of the track 00 sensor position so that the value in item viii) satisfy the specification when the screw has been tightened with the specified torque.
$x$ ) Apply a drop of locking paint on the fixing screw head.
xi) Adjust the track 00 stopper according to item 4-4-12.

(Fig.427) Track 00 sensor waveform

(Fig.428) Adjustment of track 00 sensor
(2) SKA method
(a) Connect the SKA referring to item 4-2-4 and set the FD PWR switch to the PSA side.
(b) Use two channels of oscilloscope and connect them as follows:
i) The lst channel: SKA DOUT terminal

DC mode, 5 V , 1 Omsec
ii) The 2 nd channel: PCBA MFD control TPl (Track 00 sensor), IV range
iii) External trigger: DIRECTION SELECT interface signal (Interface connector pin No.18) or Pin 3 of J3 (resistor network RAl for terminator) on the PCBA MFD control.
$(+)$ trigger.
(c) Key in "B8 F". (STEP observation)
(d) Start the spindle motor by key "5". (MON indicator turns on).
(e) Install a work disk.
(f) Execute drive select by key "0". (DSO indicator turns on).
(g) Set the step rate and the settling time as follows referring to item 4-2-4-3.

Step rate : 6 msec
Settling time : l5msec
(h) Key in "CO" and condirm that the TRACK indicator becomes " 00 ".
(i) Key in "C5". (TOO TIMING, SEEK $\pm 5$ )
(j) Measure the $t A$ and $t B$ timings according to $F i g .427$ and confirm the

```
    timings are within the following range:
tA: 3.1 ~ 5.4msec
tB: 0 ~ 5.8msec
(k) Key in "F". (STOP)
(L) Turn the FD PWR switch of the SKA off at the track OO position and then set it again to the PSA side. Confirm that the stop position of the head carriage did not change at power off and on.
( \(m\) ) If the value in item (j) or (L) is out of the specified range, adjust the position of the track 00 sensor according to the following procedure.
i) Loosen the fixing screw of the track 00 stopper (see Fig. 429) and shift the stopper in the step-out direction (make apart from the rear side of the head carriage).
ii) Connect the 2 nd channel of the oscilloscope to TP9 or TP10 (Differentiation amp.) of the PCBA MFD control and change the trigger to this channel.
Oscilloscope range: AC mode, \(0.2 \mathrm{~V}, 20 \mathrm{msec}\)
iii) Install an alignment disk. The track alignment should be correctly adjusted according to item 4-4-10.
iv) Key in "CO" and confirm that the track indicator becomes " 00 ". (RECALIBRATE).
v) Key in "C2 16" and confirm that two lobe patterns as in Fig. 425 can be observed.
If normal lobe pattern cannot be observed, move the head to the track position where the typical lobe pattern can be observed by stepping in by key "8" or by stepping out by key "9".
vi) Remove the aligrment disk.
vii) Key in "E4 16". (SET TRACK NUMBER)
viii) Key in "C2 00". (SEEK 00)
Don't key in "CO". (RECALIBRATE)
```

```
    ix) Change the connection of the oscilloscope as in item (b).
    x) Key in "C5". (TOO TIMING SEEK }\pm5\mathrm{ )
    xi) Loosen the fixing screw of the track 00 sensor (see Fig.428) and
        adjust the sensor position so that the timing tA in Fig.427 falls
        within the following range.
        Adjusting target of tA: 3.4 ~ 4.6msec
xii) Repeat the adjustment so that the values in item xi) fall within
        the specified range when the fixing screw has been tightened with
        the specified torque.
xiii) Apply a drop of locking paint to the fixing screw head.
xiv) Adjust the track 00 stopper according to item 4-4-12.
```

4-4-12. Check and Adjustment of Track 00 Stopper
(A) Equipment
(1) Cross point screwdriver, M3
(2) SKA or user's system
(3) Locking paint
(B) Check and adjustment procedure
(1) General method
(a) Set the head to track 00 .
(b) Step out the head from the track 00 position.
(c) Confirm that the head carriage does not move by the step-out command (head carriage rests on track 00).
(d) Confirm that the gap between the head carriage and the extreme end of the track 00 stopper is $0.1 \sim 0.4 \mathrm{~mm}$. (See Fig. 429).
(e) Repeat step-in and step-out operations between track 00 and track 05. Confirm that no impact sound can be heard between the head carriage and the track 00 stopper.
(f) Turn off the FDD power and depress the head carriage lightly against the track 00 stopper with fingers.
(g) Confirm that the head carriage automatically returns to the initial position (track 00) when the power is turned on again.
(h) If any one of the items (d), (e), and (g) is not satisfied, adjust the track 00 stopper position according to the following procedure.

(Fig. 429) Adjustment of track 00 stopper
i) Set the head to track 00.
ii) Loosen the fixing screw of the track 00 stopper. (See Fig. 429).
iii) Adjust the stopper position so that the gap between the stopper and the head carriage becomes 0.25 mm , approx. And then tighten the screw with the specified torque.
iv) Execute items (a) through (g).
v) Apply a drop of locking paint on the fixing screw head.
(2) SKA method
(a) Connect the SKA referring to item 4-2-4 and set the FD PWR switch to the PSA side.
(b) Execute drive select by key "0". (DSO indicator turns on).
(c) Key in "C0" and confirm that the TRACK indicator becomes " 00 ". (RECALIBRATE).
(d) Set the step rate and the settling time as follows referring to item 4-2-4-3.

Step rate : 6msec
Settling time : 15msec
(e) Key in "9". (STEP OUT)
(f) Confirm that the head carriage does not move even if "9" is keyed in (head carriage rests on track 00 ).
(g) Confirm that the gap between the head carriage and the extreme end of the track 00 stopper is $0.1 \sim 0.4 \mathrm{~mm}$. (See Fig.429).
(h) Key in "CO" and key in "C5". (STEP TIMING, SEEK $\pm 5$ )
(i) Confirm that no impact sound can be heard between the head carriage and the track 00 stopper.
(j) Turn off the FD PWR switch of the SKA and depress the head carriage lightly against the track 00 stopper.
(k) Confirm that the head carriage automatically returns to the initial position (track 00 ) when the FD PWR switch is set to the PSA side again.
(L) If any one of the items (g), (i), and (k) is not satisfied, adjust the track 00 stopper position according to the following procedure.
i) Key in "CO" and confirm that the TRACK indicator becomes "00" (RECALIBRATE)
ii) Loosen the fixing screw of the track 00 stopper. (See Fig. 429).
iii) Adjust the stopper position so that the gap between the stopper and the head carriage becomes 0.25 mm , approx.
And then tighten the screw with the specified torque.
iv) Execute items (a) $\sim(k)$.
v) Apply a drop of locking paint on the fixing screw head.

4-4-13. Check and Adjustment of Index Burst Timing
(A) Equipment
(1) Cross point screwdriver, M3
(2) Alignment disk
(3) SKA or user's system
(4) Oscilloscope (not required when the SKA is used)
(5) Locking paint
(B) Check and adjustment procedure
(1) General method
(a) Use two channels of the oscilloscope. Connect the lst channel to TP4 (Index) on the PCBA MFD control and the 2nd channel to TP7 or TP8 (Pre-amp.). Apply positive trigger by TP4.

Oscilloscope range
The lst channel: DC mode, $2 \mathrm{~V}, 50 \mu \mathrm{sec}$
The 2nd channel: $A C$ mode, $l v, 50 \mu s e c$
(b) Start the spindle motor and install an alignment disk.
(c) Set the head to track 01.
(d) Measure "t" in Fig. 430.
(e) Substitute the following equation with the measured value in item
(d) and INDEX TIMING calibration value (see alignment disk label).

Index burst timing (true value) = Measured value - Calibration value ( $\mu \mathrm{s}$ )

TP4 (Index)

TP7 or TP8

(Fig. 430) Index burst timing
(f) Confirm that the true value of the index burst timing is within the following range.
Index burst timing : $200 \pm 200 \mu \mathrm{sec}$
(g) If the value in item (f) is out of the specified range, adjust the index sensor Ass'y position according to the following procedure.
i) Loosen the fixing screws (see Fig. 431) of the PCBA index sensor and adjust its position to make the true value of the index burst timing gall in the specified range in item (f).
ii) Repeat the adjustment so that the true value of the index burst timing falls in the range of item ( $f$ ) when the fixing screw has been tightened with the specified torque.
iii) Apply a drop of locking paint on the fixing screw head.
(h) Remove the alignment disk.

(Fig.431) Adjustment of index sensor
(2) SKA method
(a) Connect the SKA referring to item 4-2-4 and set the FD PWR switch to the PSA side.
(b) Start the spindle motor by key "5". (MON indicator turns on).
(c) Install an alignment disk.
(d) Execute drive select by key "0". (DSO indicator turns on).
(e) Key in "C0" and confirm that the TRACK indicator becomes " 00 ". (RECALIBRATE)
(f) Set the head to the index check track. Key in "C2 01" and confirm that the TRACK indication becomes " 01 ".
(g) Key in "E6". (INDEX TIMING)

The calibration value of the index timing should be set previously in the SKA.
(h) Confirm that the DATA indicator $\square \square \square$ ( $\mu \mathrm{s}$ ) indicates the value within the following range.
Index burst timing: 200 200 usec
(i) Key in "F". (STOP)
(j) If the value in item (h) is out of the specified range, adjust the index sensor Ass'y position according to the following procedure.
i) Loosen the fixing screws (see Fig.431) of the PCBA index sensor and its position so that the DATA indication under execution shows the median value in the specified range of item ( $h$ ).
ii) Repeat the adjustment so that the DATA indication takes the median value when the fixing screw has been tightened with the specified torque.
iii) Depress "F" key. (STOP).
iv) Apply a drop of locking paint on the fixing screw head.
(k) Remove the alignment disk.

```
4-5. MAINTENANCE PARTS REPLACEMENT
4-5-1. Replacement of Head Carriage Ass'y
(A) Tools
(1) Cross point screwdriver, M3
(2) Cross point screwdriver, M2.6
(3) Hexagon wrench key, 1.5mm
(4) Box screwdriver for hexagon nut, M3
(5) A pair of tweezers
(6) Lubricant, Kantoh Kasei 946P
(7) Alcohol and gauze (several sheets)
(8) Locking paint
(9) SKA or user's system
(B) Replacement procedure
(1) Turn the front lever (Fig. 505, No.42) to close position and remove the fixing screw (Fig. 505, Sll).
(2) Turn the front lever to open position and draw out the front lever Ass'y.
(3) Remove the fixing screws (Fig.505, S5) of the front bezel Ass'y (Fig. 505, No.41) to remove the Ass'y.
(4) Remove the fixing screw (Fig.505, Sl) of the cord clamper to remove the clamper (Fig. 505, No.39).
(5) Remove two fixing screws (Fig.505, Sl) of the shield cover (Fig.505, No.44) to remove the cover.
(6) Remove three fixing screws (Fig. 505, No. 37 and 51 ) of the PCBA MFD
control(Fig.505, No.35) and lift it up.
(7) Disconnect all of the connectors mounted on the PCBA MFD control and remove the PCBA.
(8) Pull out the head cable from the disk guide \(U\)-groove and cable clamper and draw it out to the head carriage Ass'y (Fig. 505, No.13) side.
(9) Holding the top of the band fixing plate B (Fig.505, No.17) and the head carriage Ass'y with your fingers to release the hook of the steel belt (Fig. 505, No.19) and the band fixing plate 8.
(10) Pull out the band fixing plate B and the band spring (Fig. 505, No. 18) at the same time from the head carriage Ass'y.
(11) Separate the steel belt from the hook of the band fixing plate \(A\) (Fig.505, No.16) to remove the band fixing plate A from the head carriage Ass'y.
When removing the band fixing plate \(A\) from the head carriage, it will be removed easily if it is shifted toward the front bezel side and then drawn out in a right angle.
(12) Remove the belt fixing screw (Fig. 505, S8) on the capstan of the stepping motor Ass'y (Fig.505, No.12) and then remove the band washer (Fig. 505, No.20) and the steel belt.
(13) Remove one of the two guide shaft clips (Fig.505, No.15) which fix the guide shafts. The clip for the rear side one should be removed.
(14) Draw out two guide shafts (Fig. 505, No.14) toward the rear of the FDD and remove them from the fixing area of the front side chassis (Fig. 505, No.1).

Then remove the head carriage Ass'y with two guide shafts and the front
side clip. Refer to Fig. 432.
(15) Draw out two shafts from the head carriage and remove the front guide shaft clip.
(16) Prepare a new head carriage Ass'y and two guide shafts for installation.

Note: When replacing the head carriage Ass' \(y\), feplace the guide shafts at the same time because of matching the hole diameter of the carriage with that of the guide shaft. Guide shafts are to be designated in combination with the head carriage Ass'y. (Refer to item 4-1-3, (2)).

Guide shaft which goes through the hole of the head carriage smoothly with a little clearance is considered to be the best.
(17) Apply specified lubricant to the surface of one guide shaft. Then install it again to the new head carriage as it was.

Note: When applying the lubricant to the guide shaft, dip a piece of gauze to the lubricant and wipe the shaft and then wipe it again lightly with a dry and clean gauze.

The most appropriate quantity of the lublicant for the surface of the shafts forms a thin oil coating.
(18) Apply the lubricant to the another guide shaft and install it to the new head carriage as it was.
(19) Attach the guide shaft clip to the front bezel side groove of the shafts.
(20) Attach the new head carriage Ass'y in item (19) in the reverse order of items (13) and (14).

Note: Pre-load is applied between the two guide shafts to make them approach each other by the guide shaft clip in order to reduce the
variety of the installation position of the head carriage Ass'y. For installing the two guide shafts to the chassis, mount them with pressure to separate them.
(21) Install the steel belt (C) to the capstan of the stepping motor Ass' \(y\) in the reverse order of item (12).

Note: If the surface of steel belt or capstan is smeared, clean it carefully with alcohol and gauze.
(22) Connect the steel belt to the head carriage Ass'y using the band fixing plates \(A\) and \(B\) and band spring in the reverse order of items (9) through (11).
(23) Tighten the fixing screw of the steel belt slightly to the stepping motor Ass'y.
(24) After moving the head carriage several times manually, tighten the steel belt fixing screw carefully with the specified torque. At this time, be careful that the belt is tensioned straightly. Pay attention not to damage the surface of the belt or the capstan.
(25) Form the head cable in the reverse order of items (4) and (6) through (8) and attach the PCBA MFD control. Refer to item 4-2-3 as to the details of the head cable treatment.
(26) Loosen the fixing screw (Fig. 505, S4) of the track 00 stopper (Fig. 505, No.6) and shift the stopper toward the rear side of the FDD.
(27) Attach the front lever temporarily for the following check and adjustment.
(28) Make the head seek continuously between the track 00 and the innermost track and confirm that the steel belt does not meander nor undulate.

When the SKA is used, key in "C6" for this check and key in "F" for stop.

If the steel belt does meander or undulate, readjust the belt to run straightly by the screw in item (12). After the adjustment, tighten the screw carefully with the specified torque.
(29) Check for the head touch according to item 4-4-6.
(30) Check and adjust the asymmetry according to item 4-4-7. (Adjustment is applied only for the FDD with the variable resistor, \(R 5\) on the PCBA MFD control).
(31) Adjust the track alignment according to item 4-4-10.
(32) Adjust the track 00 sensor position according to item 4-4-11.
(33) Adjust the track 00 stopper position according to item 4-4-12.
(34) Check and adjust the index burst timing according to item 4-4-13.
(35) Check for the read level according to item 4-4-8.
(36) Check for the resolution according to item 4-4-9.
(37) Attach the shield cover in the reverse order of item (5).
(38) Remove the fixing screw of the front lever to remove the lever.
(39) Attach the front bezel Ass'y and the front lever Ass'y in the reverse order of items (1) through (3).
(40) Adjust the front lever position according to item 4-4-2.
(41) It is recommended to connect the FDD to the system for overall test.

Refer to item 4-2-5 (1)).

(Fig.432) Replacement of head carriage Ass'y

4-5-2. Replacement of Stepping Motor Ass'y and Steel Belt
(A) Tools
(1) Cross point screwdriver, M3
(2) Cross point screwdriver, M2.6
(3) Hexagon wrench key, 1.5 mm
(4) Box screwdriver for hexagon nut
(5) A pair of tweezers
(6) Alcohol and gauze
(7) Locking paint
(8) SKA or user's system
(B) Replacement procedure
(1) Remove the shield cover (Fig.505, No.44) by removing the two fixing screws (Fig.505, Sl).
(2) Lift the PCBA MFD control (Fig. 505, No. 35) by removing the three fixing screws (Fig. 505, No. 37 and Sl).
(3) Disconnect all the connectors mounted on the PCBA MFD control and remove the PCBA.
(4) Holding the top of the band fixing plate B (Fig. 505 , No.17) and the head carriage Ass'y with your fingers to release the hook of the steel belt (Fig.505, No.19) and the band fixing plate \(B\).
(5) Pull out the band fixing plate \(B\) and the band spring (Fig.505, No.18) at the same time from the head carriage Ass'y.
(6) Separate the steel belt from the hook of the band fixing plate A (Fig. 505, No. 16) to remove the band fixing plate A from the head carriage Ass'y.

When removing the band fixing plate \(A\) from the head carriage, it will be removed easily if it is shifted toward the front bezel side and then drawn out in a right angle
(7) Remove the belt fixing screw (Fig. 505, S8) on the capstan of the steppinc motor Ass'y (Fig.505, No.12) and then remove the band washer (Fig.505, No. 20) and the steel belt.
(8) Remove the stepping motor Ass'y by removing the fixing screws (Fig. 505, S4) .
(9) Install a new stepping motor Ass'y as it was.
(10) Fix a new \(\alpha\)-shape steel belt temporarily to the capstan of the new stepping motor with the band washer and the screw in item (7).

Note: Fundamentally, the steel belt and the band spring should be replaced with the stepping motor. However, if there is no inferior points for these belt and spring, they may be used after cleaning the surface carefully with alcohol and gauze.
(11) Connect the steel belt and the head carriage using the band fixing plates \(A\) and \(B\) and band spring in the reverse order of items (4) through (6).
(12) After moving the head carriage several times manually, tighten the steel belt fixing screw in item (10) carefully with the specified torque. At this time, be careful so that the belt is tensioned straightl; Pay attention not to damage the surface of the belt or the capstan.
(13) Install the PCBA MFD control in the reverse order of items (2) and (3).
(14) Loosen the fixing screw (Fig. 505, S4) of the track 00 stopper (Fig.505, No.6) and shift the stopper toward the rear side of the FDD.
```

(15) Make the head seek continuously between the track 00 and the innermost
track and confirm that the steel belt does not meander nor undulate.
When the SKA is used, key in "C6" for this check and key in "F" for
stop the operation.
If the steel belt meanders or undulates, readjust the belt to run
straightly by the screw in item (10). After the adjustment, tighten
the screw carefully with the specified torque.
(16) Execute the continuous seek operation for five minutes.
When the SKA is used, key in "C6" and key in "F" for stopping the
operation.
(17) Attach the shield cover with two fixing screws.
(18) Adjust the track alignment according to item 4-4-10.
(19) Adjust the track 00 sensor position according to item 4-4-11.
(20) Adjust the track 00 stopper position according to item 4-4-12.

```

4-5-3. Replacement of DD Motor Ass'y (Spindle motor)
(A) Tools
(1) Cross point screwdriver, M3
(2) A pair of tweezers
(3) Cutting pliers
(4) SKA or user's system
(B) Replacement procedure
(1) Remove the shield cover (Fig. 505, No.44) by removing the two fixing screws (Fig. 505, Sl).
(2) Disconnect the spindle motor connector (J7).
(3) Cut and remove the cable tie (Fig. 505, No. 40) for binding the wiring. Throw away the removed cable tie.
(4) Draw out the PCB holder (Fig. 505, No. 38) which holds the PCBA servo of the DD motor Ass'y (C) (Fig. 505, No.7) from the chassis (Fig. 505, No. 1).
(5) Remove three fixing screws (Fig. 505, S2, S7) of the DD motor from the upper side of the \(F D D\) and remove the \(D D\) motor Ass'y from the lower side of the FDD.
(6) Install a new DD motor Ass'y in the reverse order of items (2) through (5).
\begin{tabular}{rl} 
Notes: 1. The spindle area of the \(D D\) motor Ass'y (clamping cup of the disk) \\
is precisely machined. For installing the motor to the frame, \\
place the spindle in parallel to the frame and push into the \\
& frame slowly. Handle the spindle very carefully not to damage
\end{tabular}
```

the spindle surface.
2. Collar B (Fig. 505, No.5) is attached to the screw of the disk insertion side. Confirm that the collar $B$ is not taken out in the process of tightening the screw.
(7) Adjust the collet shaft plate (Fig. 505 , No.29) position according to item 4-4-1.
(8) Bind a new bundle of cables to the chassis made of DD motor cable, TOO sensor Ass'y cable, and front OPT Ass'y cable using a new cable tie.
(9) Check for the file protect sensor according to item 4-4-4.
(10) Check or adjust the disk rotation speed according to item 4-4-5. (Adjustment is applied only for the motor with the variable resistor, R1 on the PCBA DD motor servo).
(11) Check and adjust the track alignment according to item 4-4-10.
(12) Check and adjust the index burst timing according to item 4-4-13.
(13) Attach the shield cover in the reverse order of item (1).

```

\section*{4-5-4. Replacement of Collet Ass'y}
(A) Equipment
(1) Cross point screwdriver, M3
(2) A pair of tweezers
(3) Locking paint
(4) SKA or user's system
(B) Replacement procedure
(1) Remove the shield cover (Fig.505, No.44) by removing the two fixing screws (Fig.505, Sl).
(2) Remove the collet shaft plate Ass'y (Fig. 505 , No. 29 by removing two fixing screws (Fig.505, S3).

Note: For the drive with eject Ass'y (Option), remove the hooks of the eject spring \(A\) and eject spring \(B\) from the collet shaft plate. Then remove the collet shaft plate Ass' \(Y\).
(3) Pull out the collet Ass'y (Fig. 505, No. 30) from the U-groove of the clamp spring (Fig.505, No.27) to remove it.
(4) Install a new collet Ass'y in the reverse order. For installation at this step screw the collet shaft plate Ass'y temporarily.
(5) Adjust the collet shaft plate position according to item 4-4-1.
(6) Check and adjust the track alignment according to item 4-4-10.
(7) Attach the shield cover in the reverse order of item (1).

4-5-5. Replacement of PCBA TOO Sensor
(A) Tools
(1) Cross point screwdriver, M3
(2) Cross point screwdriver, M2
(3) A pair of tweezers
(4) Cutting pliers
(5) Locking paint
(6) SKA or user's system
(B) Replacement procedure
(1) Disconnect the track 00 connector (J4).
(2) Cut and remove the cable tie (Fig. 505, No. 40) for binding the wiring. Throw away the removed tie.
(3) Remove the PCBA TOO sensor (Fig.505, No.9) by removing the fixing screw (Fig.505, Sl0).
(4) Install a new PCBA TOO sensor in the reverse order of item (1) through (3).
(5) Loosen the fixing screw (Fig.505, S6) of the TOO bracket (Fig. 505, No.8) and shift it toward the rear side of the FDD.
(6) Loosen the fixing screw (Fig.505, S4) of the track 00 stopper (Fig. 505, No.6) and shift it toward the rear side of the FDD.
(7) Adjust the track 00 position sensor according to item 4-4-11.
(8) Adjust the track 00 stopper position according to item 4-4-12.

4-5-6. Replacement of PCBA MFD Control (C)
(A) Tools
(1) Cross point screwdriver, M3
(2) Box screwdriver for hexagon nut, M3
(3) SKA or user's system
(B) Replacement procedure
(1) Remove the shield cover (Fig.505, No.44) by removing two fixing screws (Fig.505, S1).
(2) Remove three fixing screws of the PCBA MFD control (Fig. 505, No.35) and lift up the PCBA.
(3) Disconnect all of the connectors mounted to the PCBA MFD control and remove the PCBA.
(4) Install a new PCBA MFD control in the reverse order of items (2) and (3).
(5) Set the straps as they were on the old PCBA.
(6) Check and adjust the asymmetry according to item 4-4-7. (Adjustment is applied only for the PCBA MFD control with the variable resistor, R5.
(7) Check for the read level according to item 4-4-8.
(8) Check for the resolution according to item 4-4-9.
(9) Check for the track 00 sensor according to item 4-4-11.
(10) Attach the shield cover in the reverse order of item (1).
(11) It is recommended to connect the FDD to the system for overall test. (Refer to item 4-2-5, (1)).

4-5-7. Replacement of Front OPT Ass'y
(A) Tools
(1) Cross point screwdriver, M3
(2) Hexagon wrench key, 1.5 mm
(3) Box screwdriver for hexagon nut, M3
(4) Cutting pliers
(5) Locking paint
(6) SKA or user's system
(B) Replacement procedure
(1) Turn the front lever (Fig.505, No.42) to close position and remove the fixing screw (Fig.505, Sll).
(2) Turn the front lever to open position and draw out the front lever Ass'y.
(3) Remove the front bezel Ass'y (Fig.505, No.41) by removing two fixing screws (Fig.505, S5).
(4) Remove the shield cover (Fig.505, No.44) by removing two fixing screws (Fig.505, S5).
(5) Cut and remove the cable tie (Fig.505, No.40) for binding the wiring. Throw away the removed tie.
(6) Disconnect the front OPT connector (J5).
(7) Draw out the cable from the space between the chassis (Fig.505, No.1) and the PCBA DD motor servo and then draw it out from the U-groove of the disk guide (Fig.505, No.3).
(8) Remove two separate fixing screws (Fig. 505, Sl and S5) of the front OPT

Ass'y (Fig.505, No.34) to remove the Ass'y.
(9) Install a new front OPT Ass'y in the reverse order of item (6) through (8).
(10) Check for the file protect sensor according to item 4-4-4.
(11) Adjust the index burst timing according to item 4-4-13.
(12) Form the cables as they were using a new cable tie.
(13) Attach the shield cover in the reverse order of item (4).
(14) Attach the front bezel Ass'y and the front lever Ass'y in the reverse order of items (1) through (3).
(15) Adjust the front lever position according to item 4-4-2.

4-5-8. Replacement of Head Pad (Single sided only)

This item applies only to the single sided FDD.
(A) Tools
(1) A pair of tweezers
(2) Alcohol and gauze
(B) Replacement procedure
(1) Remove the shield cover (Fig. 505, No.44) by removing two fixing screws (Fig. 505, S5).
(2) Lift up the pad arm manually and peel the pad carefully with a pair of tweezers. (See Fig.433).
(3) Apply a new pad to the initial position. Be careful not to press the pad surface strongly.
(4) Clean the magnetic head surface according to item 4-3-2.
(5) Adjust the head pad position according to item 4-4-6.
(6) Check for the read level according to item 4-4-8.
(7) Check for the resolution according to item 4-4-9.
(8) Attach the shield cover in the reverse order of item (1).

(Fig.433) Replacement of head pad

4-5-9. Replacement of Front Bezel Ass'y
(A) Tools
(1) Cross point screwdriver, M3
(2) Hexagon wrench key, 1.5 mm
(B) Replacement procedure
(1) Turn the front lever (Fig.505, No.42) to close position and remove a fixing screw (Fig.505, sll).
(2) Turn the front lever to open position and draw out the front lever Ass'y.
(3) Remove the fixing screws (Fig.505, S5) of the front bezel Ass'y (Fig. 505, No.41) and draw out the front bezel.
(4) Install a new front bezel Ass'y in the reverse order of item (2) and (3).

Note: For the installation of the front bezel, be sure to hold the four installation and support arms of the upper and the lower chassis (Fig.505, No. 1 and No.21) and press the longitudinal sides of the bezel against the chassis and tighten the fixing screws with the specified torque.
(5) Adjust the front lever position according to item 4-4-2.

\section*{4-5-10. Replacement of Front Lever Ass'y}
(A) Tools
(1) Hexagon wrench key, 1.5 mm
(B) Replacement procedure
(1) Turn the front lever (Fig.505, No.42) to close position and remove a fixing screw (Fig.505, Sll).
(2) Turn the front lever to open position and draw out the front lever Ass'y.
(3) Install a new front lever Ass'y in the reverse order.

Note: For installation of the front lever Ass'y, match the slot of the lever to the pin of the lever shaft.
(4) Adjust the front lever position according to item 4-4-2.

\section*{SECTION 5}

DRAWINGS \& PARTS LIST

\section*{5-1. CONFIGURATION}

Following shows the configuration of the main parts of FD-54. (Refer to Fig. 501 Fig.504). Refer to items 5-2 and 5-3 as to detailed break -downs.


(Fig.501) External view (No.1)

(Fig.502) External view (No. 2)

(Fig.503) External view (No.3)

(Fig.504) External view (No.4)

5-2. MECHANICAL BREAK-DOWN AND PARTS LIST

5-2-1. FDD (Refer to Fig. 505)

(Table 502) FDD parts list (1/3)
\begin{tabular}{|c|c|c|c|c|}
\hline Nos. & Parts. Nos. & Parts name & Q'ty & Description \\
\hline 21 & 16152891-00 & Upper chassis & 1 & \\
\hline 22 & 16787150-00 & Insulation sheet & 1 & \\
\hline 23 & 16787151-00 & Disk pad B & 1 & Note 3 \\
\hline 24 & 16802616-00 & Set arm & 1 & \\
\hline 25 & 17966929-00 & Clamp cam Ass'y(C) & 1 & \\
\hline 26 & 16787148-00 & Clamp shaft holder & 1 & \\
\hline 27 & 16392019-00 & Clamp spring & 1 & \\
\hline 28 & 16381104-00 & Clamp return spring & 1 & \\
\hline 29 & 17966933-00 & Collet shaft plate Ass'y & 1 & \\
\hline 30 & 17966923-00 & Collet Ass'y (C) & 1 & \\
\hline 31 & 17966935-00 & Bail Ass'y \({ }^{\text {( }}\) ) & 1*1 & FD-54A \\
\hline & 17966936-00 & Bail Ass' y (B) & & FD-54B \\
\hline 32 & 16787157-00 & Disk pad A-2 & 1 & Note 3 \\
\hline 32B & & Disk pad & 1 & Note 3 \\
\hline 33 & 16381106-00 & Disk pad lever spring & 1 & \\
\hline 34 & 15090730-00 & Front OPT Ass'y \({ }^{\text {(C) }}\) & 1 & \\
\hline 35 & 15532006-XX & PCBA MFD control (C) & 1 & Note 5 \\
\hline 36 & 16787152-00 & Protection sheet & 1 & \\
\hline 37 & 16730434-00 & Fixing shaft & 1 & \\
\hline 38 & 16787149-00 & PCB holder & 1 & \\
\hline 39 & 16322054-00 & Cord clamper & 1 & \\
\hline 40 & 16362418-00 & Cable tie & 4 & \\
\hline & & & & \\
\hline & & & & \\
\hline
\end{tabular}
(Table 502) FDD parts list (2/3)
\begin{tabular}{|c|l|l|l|l|}
\hline Nos & Parts Nos. & Parts name & \(Q^{\prime}\) ty & Description \\
\hline 41 & \(17966807-50\) & Front bezel Ass'y & 1 & Note 6 \\
\hline & & & & \\
\hline & & & 1 & Note 6 \\
\hline 42 & \(17966924-00\) & Front lever Ass'y(C) & 1 & \\
\hline 43 & \(16381109-00\) & Front lever spring & 1 & \\
\hline 44 & \(17966937-00\) & Shield cover Ass'y & & \\
\hline & & & & \\
\hline & & & \\
\hline
\end{tabular}
(Table 502) FDD parts list (3/3)

Notes: 1. As to the parts with an asterisk in the \(Q^{\prime}\) ty column, select appropriate one for the model.
2. As to the parts with model name of FD-54 in the Description column, the parts is used only for the model.
3. Disk pads are included in the Ass'y No. 21 and No. 31 .
4. Guide shafts are always used in combination with the head carriage Ass'y due to make the corresponding diameter match with the hole of the head carriage. When you replace the head carriage Ass'y, be sure to replace the guide shafts together.
5. The parts number versions of the PCBA MFD control (C) are different depending on each model. Refer to the name plate on the actual PCBA installed to designate the same version.
6. The parts numbers of the front bezel Ass'y and the front lever Ass'y are those of \(\mathrm{FD}-54\), standard color, black.

(Fig. 505) Mechanical section break-down

\section*{5-2-2. Screw, Washer}
\begin{tabular}{|c|c|c|c|}
\hline Nos. & Parts Nos. & Parts name & Description \\
\hline Sl & 16410304 & Screw, bind, \(3 \times 4, S\), ZMC & \\
\hline S2 & 16411304 & Screw, bind, \(3 \times 4, \mathrm{~B}, \mathrm{BNM}\) & \\
\hline S3 & 16400304 & Screw, pan, three pieces, \(3 \times 4, \mathrm{~S}, \mathrm{ZMC}\) & \\
\hline S4 & 16498647 & Screw, pan, three pieces, \(3 \times 5, \mathrm{~s}, \mathrm{zMC}\) & \\
\hline S5 & 16410306 & Screw, bind, \(3 \times 6,5, \mathrm{ZMC}\) & \\
\hline S6 & 16498579 & Screw, pan, three pieces, \(3 \times 6,5, \mathrm{ZMC}\) & \\
\hline S 7 & 16476308 & Screw, pan, flat, flat washer, \(3 \times 8, B, B N M\) & \\
\hline S8 & 16470004 & Screw, pan, sems, \(2.6 \times 4, S\), ZMC & \\
\hline S9 & 16400004 & Screw, pan , 2. \(6 \times 4, \mathrm{~s}, \mathrm{ZMC}\) & \\
\hline S10 & 16400204 & Screw, bind, \(2 \mathrm{x} 4,5,2 \mathrm{MC}\) & \\
\hline Sl1 & 16498260-00 & Set screw, \(3 \times 3\) & \\
\hline S12 & 16410316 & Screw, bind, \(3 \times 16, \mathrm{~S}, \mathrm{ZMC}\) & \\
\hline Sl3 & 16351140 & E-ring, 3 J & \\
\hline
\end{tabular}
(Table 503) Parts list of screw \& washer

5-3. PCBA PARTS LIST

Following shows all the parts mounted on the PCBAs of FD-54 series.

5-3-1. PCBA MFD Control (C)
\begin{tabular}{|c|c|c|}
\hline Parts Nos. & Parts name \& rating & Location \\
\hline 13447358-00 & LSI TEAC 7358-00 & U1 \\
\hline 13441922-00 & LSI TEAC 1922-00 & U2 \\
\hline 13441983 & TTL IC 74LS368A & U3 \\
\hline 13441235 & TTL IC 74LSO4 & U4 \\
\hline 13428139 & Transistor array, M54578P & U5 \\
\hline 13424286 & Transistor, 2SC2021R & \\
\hline 13421211 & Transistor,2SA881 \(2 \cdot \mathrm{R}\) & Q1 \\
\hline 13411378 & Diode, pair, MAl 54WA & CRA1, CRA2, CRA5, CRA6,
**CRA3, **CRA4 \\
\hline 13411406 & Diode, pair, MA154WK & CRA 7 \\
\hline 13411243 & Diode,15954 & CR1, CR4~CR8 \\
\hline 13411339 & Diode, DS442X & CR8 \\
\hline 13415408 & Diode, zener, RD6.8EN2 & CR2 \\
\hline 13497262 & Resistor array, SA 9-1K, J & RA1 \\
\hline 13497310 & Resistor array, SA 5-15k & RA3 \\
\hline
\end{tabular}
(Table 504) PCBA MFD control (C) parts list (1/4)
- 511 -
\begin{tabular}{|c|c|c|}
\hline Parts Nos. & Parts name \& rating & Location \\
\hline 13497266 & Resistor array, SA 3-4.7Kת, J & RA4 \\
\hline 13497286 & Resistor array, SC \(4-2.2 \mathrm{~K}, \mathrm{~J}\) & RA2 \\
\hline 13497228-00 & Resistor array, T-7228 & RA5 \\
\hline 13497227-00 & Resistor array, T-7227 & RA7 \\
\hline 13497229-00 & Resistor array, T-7229 & RA6 \\
\hline 11187105 & Resistor, RD, 1/6W, 1M2, J & R16 \\
\hline 11187473 & Resistor, RD, 1/6W, 47K 2 , J & **R15, R18 \\
\hline 11187682 & Resistor, RD, 1/6W, \(6.8 \mathrm{~K} \Omega \mathrm{~J}\) & R17 \\
\hline 11187222 & Resistor, RD, \(1 / 6 \mathrm{~W}, 2.2 \mathrm{~K} \Omega, \mathrm{~J}\) & R20 \\
\hline 11198104 & Resistor, RD, \(1 / 4 \mathrm{~W}, 100 \mathrm{~K}, \mathrm{~J}\) & R10 \\
\hline 11198497 & Resistor, RN, 1/4W, 1. \(24 \mathrm{~K} \Omega, \mathrm{~F}\) & R19 \\
\hline 11051121 & Resistor, RN, 1w, 1208, J & R21 \\
\hline 11051390 & Resistor, RN, 1w, 39R, J & R13, R14 \\
\hline 13040341 & Jumping wire & **S1 \\
\hline \[
\begin{aligned}
& 12903343 \\
& 12903353 \\
& 12903345
\end{aligned}
\] & \[
\begin{aligned}
& \text { Capacitor, CE, 10V }, 100 \mu \mathrm{~F}, \mathrm{M} \\
& \text { Capacitor, } \mathrm{CE}, 25 \mathrm{~V}, 47 \mu \mathrm{~F}, \mathrm{M} \\
& \text { Capacitor, CE, } 16 \mathrm{~V}, 22 \mu \mathrm{~F}, \mathrm{M}
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{C} 2 \\
& \mathrm{c} 24 \\
& \mathrm{C} 6, \mathrm{c} 8
\end{aligned}
\] \\
\hline 12903227 & Capacitor, CS, 20V, 15 \({ }^{\text {F }}\), M & C7.C9 \\
\hline 12903154 & Capacitor, CS, 16V, 47 \(\mathrm{F}, \mathrm{M}\) & **C33, C34 \\
\hline 12903152 & Capacitor, CS, 16V,2.2 \(\mathrm{F}_{\text {, K }}\) & C36 \\
\hline 12903178 & Capacitor, CS, 35V, \(0.22 \mu \mathrm{~F}\), K & C13, C14 \\
\hline 12903177 & Capacitor, CS, 35v,0.15 F , M & C11, Cl 2 \\
\hline 12903375 & Capacitor, CS,16V,14F, M & C17 \\
\hline
\end{tabular}
(Table 504) PCBA MFD control (C) parts list (2/4)
\begin{tabular}{|c|c|c|}
\hline parts Nos. & Parts name \(\&\) rating & Location \\
\hline 12903372 & Capacitor, CS, 16V, 0.33 \(\mathrm{F}, \mathrm{M}\) & C5 \\
\hline 12903080 & Capacitor, CC, 25V, YU, O.1 1 F, M & C26, C28 \\
\hline 12903335 & Capacitor, CC, \(25 \mathrm{~V}, \mathrm{X}, 0.022 \mu \mathrm{~F}, \mathrm{z}\) & \[
\begin{aligned}
& \mathrm{C} 3, \mathrm{C} 4, \mathrm{C} 10, \mathrm{C} 15, \mathrm{C} 16, \mathrm{C} 20 \\
& \mathrm{C} 27, \mathrm{C} 31, \mathrm{C} 32
\end{aligned}
\] \\
\hline 12902530 & Capacitor, CC, 500V, F, \(0.01 \mu \mathrm{~F}, \mathrm{Z}\) & Cl \\
\hline 12901421 & Capacitor, CC, 50V, B, 2200PF, K & C25 \\
\hline 12901417 & Capacitor, CC, 50V, B, 1000PF,K & C29 \\
\hline 12900771 & Capacitor, CC, 50V, SL, 180PF,J & C18, C19 \\
\hline 12902588 & Capacitor, CC, 50V, \(\mathrm{CH}, 56 \mathrm{PF}, \mathrm{J}\) & C 22 \\
\hline 12902578 & Capacitor, CC, 50V, CH, 22PF, J & C23 \\
\hline 12454222 & Capacitor, CQ, 100V, 2200PF,G & C30 \\
\hline 12454152 & Capacitor, CQ, 100V,1500PF,G & C35 \\
\hline 12454101 & Capacitor, CQ, 100V,100PF,G & C21 \\
\hline 13295084-00 & Ceramic oscillator, 480 KHz & Y1 \\
\hline 14723507 & Coil, chalk, \(330 \mu \mathrm{H}, \mathrm{J}\) & L1~L3 \\
\hline 13121234 & Connector, S6P, polarizing & *J9 \\
\hline 13121152 & Connector, Wl (2P, polarizing & \\
\hline 13121361 & Connector, S5p & TP7~10, G \\
\hline 13121363 & Connector, s7P & TPI~6, G \\
\hline 13121332 & Connector, W14P & HS~1U \\
\hline
\end{tabular}
(Table 504) PCMB MFD control (C) parts list (3/4)
- 513 -
\begin{tabular}{|c|c|c|}
\hline Parts No.s & Parts name \& rating & Location \\
\hline 13121109 & Connector, 4P & J2 \\
\hline 16322368 & Connector, clamp & for J 2 installation \\
\hline 13121175 & Connector, 4P & J7 \\
\hline 13121176 & Connector, 5P & J5 \\
\hline 13121177 & Connector, 6P & J4.J6 \\
\hline 13121149 & Short bar & HSM, HL, IU, HS, DSO~3, HM straps \\
\hline 16271169-xX & Name plate & \\
\hline
\end{tabular}
(Table 504) PCBA MFD control (C) parts list (4/4)

Notes: 1. Parts with an asterisk are different depending on the PCBA versions. Select either of them.
2. Parts with a double asterisks are not used in some PCBA versions.
3. Refer to the schematic diagram of the PCBA as to the details of the parts with asterisks.
4. Name plate version is different depending on the PCBA version used.
\begin{tabular}{|c|c|c|}
\hline Parts No.s & Parts name \& rating & Location \\
\hline 13121109 & Connector, 4P & J2 \\
\hline 16322368 & Connector, clamp & for J 2 installation \\
\hline 13121175 & Connector, 4P & J7 \\
\hline 13121176 & Connector, 5P & JS \\
\hline 13121177 & Connector, 6p & J4, J6 \\
\hline 13121149 & Short bar & \[
\begin{aligned}
& \text { HSM, HL, IU, HS, DSO~ } 3, \mathrm{HM} \\
& \text { straps }
\end{aligned}
\] \\
\hline \(16271169-X X\) & Name plate & \\
\hline
\end{tabular}

Notes: 1. Parts with an asterisk are different depending on the PCBA versions. Select either of them.
2. Parts with a double asterisks are not used in some PCBA versions.
3. Refer to the schematic diagram of the PCBA as to the details of the parts with asterisks.
4. Name plate version is different depending on the PCBA version used.

\section*{5-4. SCHEAMTIC DIAGRAMS AND PARTS LOCATION}

\section*{SPARE PAGE}


> PCBA DD MOTOR SERVO (TYPe C) PARTS LOCATION


PCBA DD MOTOR SERVO (Type C)
SCHEMATIC DTACRĀH


PCBA MTD CONTROL, PARTS LOCATION



DC POWER



FRAME GROUND

6. polarizing key positions for connectors (J) are: J1: BETWEEN PIN4 AND 6 J9: PIN6
5. REFER TO SHORT BAR SELECTION TABLE (HSM~OS3) AS TO THE SHIPPING positions.
4. TOLERANCE SYMBOLS FOR R. RA. AND C ARE
\(F: \pm 1 \%, G: \pm 2 \%, J: \pm 5 \%, K: \pm 10 \%, M: \pm 20 \%, \quad Z:+80-20 \%\)
3. CAPACITOR (C) VALUES ARE IN MICROFARADS, SOV OR HIGHER, \(\pm 10 \%(K)\). UNLESS OTHERWISE SPECIFIEO.
3 RESISTOR (R) AND RESISTOR ARRAY(RA) VALUES ARE IN OHMS I/8W OR RESISTOR (R) AND RESISTOR ARRAY(RA) VALUES
GREATER, I \(5 \%\) (J). UNLESS OTHRW/SE SRECIFIGD.
1. Parts with an asterisk (*) are oitrerent in each pcba version. REFER TO vERSION TABLE. UNLISTEO PARTS ARE NOT USEB IN THAT VERSION.


P/N \(15532006-x x\)


\section*{CONNECTORS AND PIN DESIGNATIONS}



\footnotetext{
3. OR EQUIVALENT

2-TOLERANCE: \(\pm \frac{1}{4}\)
1-TY-WRAPS AS REQUIRED
}


Cable, Assembly W2(6008141)
\begin{tabular}{|c|c|c|c|c|}
\hline \multicolumn{5}{|c|}{PARTS LIST} \\
\hline DES & & DESCRIP TIDN & MFG/PN & REMARKS \\
\hline PK2 & 1 & Connectal 2 POS & MOLEX /26-03-4030 & \\
\hline & 2 & CONTACTS & MOLEX / 08-50-0187 & \\
\hline 1 & 1 & CONNECTOR 2 POS & MOLEX / 19-09-1029 & OR EQUIVALENT \\
\hline & ? & CONTACTS & MOLEX O2-09-2101 & DR EQUIVALENT \\
\hline & & & & \\
\hline BR & AR & WIRE 18 AWG BROWN & & \(80^{\circ} \mathrm{C}\) (1/1) \\
\hline BL & AR & WIRE IBAWG BLUE & & \(80^{\circ} \mathrm{C}\) (NELTRAL) \\
\hline & & & & \\
\hline
\end{tabular}

\begin{tabular}{|c|c|l|l|l|l|}
\hline \multicolumn{6}{|c|}{ PARTS LIST } \\
\hline ITEM & QTY & DESCRIPTION & MFG/PARTNO. & REMARKS \\
\hline (1) & 1 & CONNECTOR-34 POS.RECEPTACLE & MOLEX-15-29-3343 & \\
\hline\((2)\) & 1 & CABLE-RIBBON,34CONDUCTOR & & \\
\hline 3 & 2 & CONNECTOR-34 PINEDGE CARD & \(3 M-3463-0001 /\) MMP499930-3 & \\
\hline
\end{tabular}

Cable, Signal W3(6008118)


Keyboard Assembly W5(6008129)


\section*{}

OTESCUNLESS OTHEEWISE SFECHIED):


Cable, Assembly W6(6008121)
\begin{tabular}{|c|c|c|c|c|}
\hline \multicolumn{5}{|c|}{PARTS LIST} \\
\hline LTR & QTY & DESCRIPTION & PART MFG NO & REMARKS \\
\hline 1 & 1 & CONNECTOR-3PIN & MoLEX 26-03-4030 2 & \\
\hline 2 & 2 & CONTACT & MOLEX \(08-50-0187\) Q & \\
\hline 3 & 4 & FASTON-(.25 \(\times .032)\) & AMP\# 2-520183-2 \({ }^{\text {2 }}\) & FuLLY INSULATED \\
\hline 4 & 2 & FASTON -RIGHT ANGLE( \(25 \times 032)\) & AMP \# 2-620128-2 2 & FHLLY INSULATED \\
\hline 5 & 2 & Tr-WrAP & & \\
\hline 6 & 1 & WIRE-18 AWG, BLUE & & \\
\hline 7 & 1 & WIRE-18 AWG, BROWN & & \\
\hline 8 & 1 & WIRE-18 AWGBROWN & & \\
\hline 9 & 1 & WIRE-18 AWG BROWN & & \\
\hline 10 & 1 & FASTON (.25 \(\times .032\) ) & AMP\#3-350819-2 亿 & FULLY INSULATED \\
\hline
\end{tabular}


Cable, Assembly W7(2600009)




Cable, Assembly W15(6008070)
\begin{tabular}{|c|c|c|c|c|}
\hline \multicolumn{5}{|c|}{PARTS LIST} \\
\hline DES & STY & DESCRIPTION & M FG / PART NO. & REMARKS \\
\hline P9 & I & CONIU SOCKET 2 POS & MOLEX / 22-प1-3027 & \\
\hline & 2 & CONTACT & MOLEX / \(08 \cdot 50-8113\) & \\
\hline & & & & \\
\hline & & & & \\
\hline & & & & \\
\hline & & & & \\
\hline
\end{tabular}

\section*{Memory DMA}

Far 7 "n


 \(\stackrel{1}{=} \cdot \frac{c^{c 2}}{}\)




NOTES Whess ofterics secifie.

Bit tumar is reori photectian devices in.


- cad oemerateo ove. - oo not revise manually.


\section*{SCHEMATICS}

\section*{Main Logic}















\section*{RADIO SHACK, A DIVISION OF TANDY CORPORATION}

\section*{U.S.A. FORT WORTH, TEXAS 76102 CANADA: BARRIE, ONTARIO L4M 4W5}

\section*{TANDY CORPORATION}
AUSTRALIA
\begin{tabular}{l} 
91 KURRANONG AVENUE \\
MOUNT DRUIT, N.S.W. 2770
\end{tabular}


\(7 / 85-\mathrm{TM}\)```


[^0]:    5. The hardware logic is configured so that Port C is split with an input at $\mathrm{PC} 4-\mathrm{PC} 7$ and an
[^1]:    continued on next page

[^2]:    -last byte of count being written

[^3]:    ntel Corporation assumes no responsibility for the use of any ctrculiry other than circuitry embodied in an intel product. No other carcuit patent licenses are implied. - Intel Corporation, 1982

[^4]:    Read Data
    Read ID
    Read Deleted Data
    Read a Track
    Scan Equal

    ## Write Data

    Format a Track
    Write Deleted Data
    Seek
    Recalibrate (Restore to

[^5]:    (M) MOTOROLA semiconductor Products Inc.

