```
            Tandy 1000 TX
    Page Insertion Guide
    Important Customer Note:
    A gray stripe has been printed along the right edge of
the title page of each of the sections to facilitate
your finding the begining of the section. Also, a
tabbed divider for each section has been provided for
insertion at this point.
```


## Foldout Pages To Be Inserted At The End of the Main Logic Section



## Tandy 1000 TX Technical Reference Manual <br> Copyright 1987, Tandy Corporation All Rights Reserved.

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

# Tandy 1000 TX <br> Technical Reference Manual <br> Contents 

## Sections

Main Logic Board
Devices
Power Supplies
Keyboard
Disk Drive
Options
Software

## Important Customer Note:

A gray stripe has been printed along the right edge of the title page of each of the sections to facilitate your finding the begining of the section. Also, a tabbed divider for each section has been provided for insertion at this point.

1000 TX Main Logic Board

## 1000 TX Main Logic Board Contents

Section Page
Introduction ..... 3
Specifications ..... 4
Standard Features ..... 4
Optional Features ..... 5
Physical Specifications ..... 6
Switch Settings and Jumper Pin Configurations ..... 7
Theory of Operation ..... 8
80286 Processor ..... 8
80287 processor ..... 9
Clock Generation ..... 10
Command and Control Signal Generation ..... 12
Command Buffer ..... 13
DRAM Control ..... 13
Refresh Control ..... 15
BIOS ROM Control ..... 15
Reset Circuit ..... 15
Wait State and Ready Logic ..... 16
NMI Logic ..... 16
80287 Control Logic ..... 16
CPU Address Buffers ..... 19
Data Buffers and Conversion Logic ..... 20
I/O Decode ..... 21
Floppy Disk Controller ..... 21
Interrupt Controller ..... 22
Video Controller ..... 23
Timer Counter ..... 24
Joystick Interface ..... 24
Keyboard Interface ..... 25
Sound Circuit ..... 25
DMA Controller ..... 26
RS232 Serial Port Interface ..... 27
Parallel Printer Port Interface ..... 27
Expansion Ports ..... 28
System Expansion Bus ..... 28
Expansion Bus Signal Descriptions ..... 29
Memory Map of System ..... 32
I/O Port Map of System ..... 33
Timing Charts ..... 59
System Clock Timing ..... 59
CPU Control Timing ..... 71
Schematic Diagrams ..... 81

## INTRODUCTION TO TEE TANDY* 1000 TX

The Tandy 1000 TX 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 $3 \frac{1}{2} " 720 \mathrm{~K}$ floppy disk drive. The standard types of monitors used with the Tandy 1000 TX are the monochrome composite and the color RGB monitor. Since these units are modular, you can place them on top of the main unit or at any convenient location.

The Tandy 1000 TX comes standard with 640 K of RAM . An optional l28K upgrade can be added to the main logic board, for a total of 768 K of RAM. The upper 128 K is used exclusively as video RAM, leaving 640 K for system use, which is the maximum RAM supported by the TX memory map.

The Tandy 1000 TX comes standard with 640 K of system RAM. An optional 128 K RAM can be added on the system board to expand the memory to a full 768 K bytes, the maximum RAM allowed by the system memory map.

Other features include a parallel printer port, a serial port, two built-in joystick interfaces, a speaker for audio feedback, and a headphone jack with volume control.

The main unit is the heart of the Tandy 1000 TX . It houses the main logic assembly, system power supply, and floppy disk drive.

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 drive by a series of cables.

The power supply is a 67 W switching regulator type, designed to provide adequate power capacity for a fully configured system that has all the option slots in use.

The floppy disk drive uses $3 \frac{1}{2} "$ double-sided, double-density diskettes to read, write, or store data. These are soft sector diskettes. The disk drive assembly comes installed in the main unit. The floppy diskette stores approximately 720 K bytes (formatted) of data. All system programs, with the exception of the system startup sequence, are stored on diskette.

## SPECIFICATIONS

## Standard Features

80286 CPU running at 8 MHz , switchable to 4.77 MHz
Socket for 80287 numerical co-processor
640 K bytes DRAM upgradeable to to 768 K bytes ( 16 bit data bus)
16 K bytes BIOS ROM (l6 bit data bus)
Tandy 1000 TX video controller that supports:

- $\quad 128 \mathrm{~K}$ bytes DRAM (used as system and video memory)
- alphanumeric mode
- graphics modes including:
$160 \times 200$ 16-color
$320 \times 2004$-color
- $320 \times 200$ 16-color
- $640 \times 2002-$ color
- $\quad 640 \times 2004$-color
- 8237-5 DMA controller that supports: 4 DMA channels
- 8 bit transfers
- 4 MHz clock speed

8259A interrupt controller for 8 interrupts

- 8253 interval timer that supports:
- system interrupt timing
- sound timing
- refresh timing
- Custom keyboard interface controller
- 90-key keyboard that includes 12 function keys
- Custom parallel printer port
. Serial port (RS-232-C)
- Audio interface circuit that supports:
- internal 8 -Ohm speaker
- headphone jack with user accessible volume control
- Joystick interface for two joysticks
- Custom floppy disk controller circuit that supports:


## 51/" 360 K floppy disk drives

- One $3^{\frac{1}{2} " ~} 720 \mathrm{~K}$ floppy disk drive
- Five 8-bit expansion slots
- Reset button and support logic
- 67-Watt power supply


## Optional Features

- 80287 numerical math co-processor
- 128 K DRAM upgrade (16-bit data bus memory)
- $\quad 5 \frac{1}{4} " 360 \mathrm{~K}$ floppy disk drive
- $3 \frac{3}{2} " 720 \mathrm{~K}$ floppy disk drive
- Hard disk controller
- Hard disk card (20 meg)
. Display adapter boards that support mono, EGA, or other special video modes
300 , 1200 , or 2400 baud modem boards


## Physical Specifications

(Computer and Keyboard)

```
Processor: Intel* 80286
Dimensions: Computer - 16" x 13夝" x 5"
                                Keyboard - 16\frac{1}{4}" x 8" x l\frac{12}{\prime\prime}
                                Computer - 18 lbs. (with 2 floppy disk drives)
                                Keyboard - 3 lbs. 4 oz.
```


## Power Requirements:

Range: 105 VAC to 135 VAC
Nominal: $120 \mathrm{VAC}, 60 \mathrm{~Hz}, 3 \mathrm{Amp}$ maximum
With 1 Floppy Disk Drive, 640K Memory:
AC Current: 350-400 mA with floppy doing $R / W$ tests. Disk Drive:
+5 VDC $\pm 12$ VDC
$\mathrm{R} / \mathrm{W} \quad 560 \mathrm{~mA}$ (Min.) 340 mA (Max.)
Main Logic Board: $1700 \mathrm{~mA} \quad 450 \mathrm{~mA}$
Operating Environment:

| Temperature: | 55 to 85 degrees $F(13$ to 30 degrees $C)$ |
| :--- | :--- |
| Humidity: | $40 \%$ to $80 \%$ non-condensing |

Non-Operating Environment:
Temperature: -40 to +160 degrees $F(-40$ to 71 degrees $C)$
Humidity: $20 \%$ to $90 \%$ non-condensing

## Disk Drive Specifications

Power:

| Supply |  |  |
| :---: | :---: | :---: |
| Voltage + | +5 VDC Input | +12 VDC Input |
| Ripple |  |  |
| 0 to 50 kHz | 100 mV | 100 mV |
| Tolerance |  |  |
| Including Ripple | +/-5\% | $+/-5 \%$ |
| Standby Current |  |  |
| Nominal | 190 mA | 160 mA |
| Worst Case | 220 mA | 190 mA |
| Operating Current |  |  |
| Nominal | 260 mA | 600 mA |
| Worst Case | 300 mA | 1000 mA |

## SWITCH SETTINGS AND JUMPER PIN CONFIGURATIONS

| Jumper | Function Interrupt | As Shipped |
| :---: | :---: | :---: |
| S2-1 | $\begin{aligned} & \text { Color/Monochrome Monitor } \\ & \text { on }=\text { color } \\ & \text { off }=\text { monochrome/composite } \end{aligned}$ | on |
| S2-2 | $\begin{aligned} & \text { Interrupt } 5 \text { Sync source } \\ & \text { on }=\text { internal sync } \\ & \text { off }=\text { external sync } \end{aligned}$ | on |
| S2-3 | ```FDC Interrupt Int. 6 on = on board FDC controller off = optional FDC controller``` | on |
| S2-4 | ```Printer Interrupt Int. 7 on = enable printer interrupt off = disable printer interrupt``` | on |
| El-E2 | ```Serial (Com) Port Enable Int. 4 installed = port enabled not installed = port disabled``` | installed |
| E3-E4 | COM Port Select <br> installed $=$ CoMl selected <br> not installed $=$ COM2 selected | installed |
| E9-El0 | Memory Configuration installed $=512 \mathrm{~K}$ system memory not installed $=640 \mathrm{~K}$ system memory | installed |

Table l. Switch Settings and Jumper Configurations.

## THEORY OF OPERATION

## 80286 Microprocessor

The 80286 (Ul3) is an advanced, high-performance, 16-bit microprocessor with special capabilities for multi-tasking and multiuser systems. Two modes of operation are available in the 80286, the Real Address mode, and the Protected Virtual Address mode. In the Real Address mode, the 80286 is compatible with existing 8086 and 8088 software and allows addressing of one megabyte of memory space. The Tandy 1000 TX does not support the protected Virtual Address mode.

The optional 80287 (Ul5) performs high-speed arithmetic and logarithmic functions and trigonometric operations that increase the performance of an 80286 system. Performance increases are obtained by the 80287's ability to perform math calculations faster than the 80286, and also by the executing math instructions in parallel with the 80286.

## Clock Generation (Night Blue)

All clocks required by the system are generated by the custom CPU Controller (U52). There are two independent clock circuits supplied by a Dual Oscillator Clock (Yl) from which all other clocks are derived.

The 16 MHz Clock is routed into the CPU Controller (U52), which generates the output signals PRCLK, DMACLK, and SCLK. The Clock Switch circuitry required to toggle the 80286 Microprocessor between 8 MHz and 4 MHz mode, as well as the the logic to prevent any short cycling during a clock switch cycle, are implemented in the CPU Controller IC (U52). If the signal XD3 is asserted high during an $I / O$ write to port 062 (hex), then the output signal PRCLK is 16 MHz , which operates the 80286 in 8 MHz mode. If the signal XD3 is asserted low during an I/O write to port 062 (hex), the output signal PRCLK is at 8 MHz , operating the 80286 in the 4 MHz mode. When Reset is generated, the signal RES* is asserted low and defaults the randy 1000 TX to the 8 MHz mode.

The CPU Controller Chip also controls wait states to insert the proper number of wait states required for a two clock mode of operation. When the PRCLK signal is 16 MHz ( 8 MHz Mode), then four wait states are inserted in all 8-bit Memory and $1 / 0$ cycles. When the signal PRCLK is 8 MHz ( 4 MHz mode) then two wait states are inserted during all 8-bit Memory and $I / O$ cycles. During all 16-bit memory cycles, only one wait state is inserted in both the 8 MHz and 4 MHz modes.

PRCLK is then routed through three damping resistors to produce the signals PRCLK for the 80286 , PRCLKA for the 80287 math coprocessor, and PRCLKB for the DRAM/DMA control logic.

DMACLK and SCLK are output signals for system use. The DMACLK output frequency is $\frac{1}{4}$ of the PRCLK signal, and the SCLK output frequency is $\frac{1}{2}$ of the PRCLK signal. Both are synchronized by Reset to the PRCLK output signal. After a Reset, DMACLK and SCLK are held low until the 80286 asserts status $\mathrm{Sl}=0$. SCLK and DMACLK make the first transition on the falling edge of PRCLK, following with a Ts state that synchronizes them to PRCLK.

SCLK is buffered by IC U68 (74ALS244) and filtered by R5l, Cl98, and FB7, and is then routed to the Expansion Bus for option board use. DMACLK is filtered by R37, FB3, and C171, and is then routed to the DMA Controller (Uli).

Table 2 shows all the clocks generated from 16 MHz in both modes:

|  | 8 MHz Mode | 4 MHz Mode |
| :--- | :--- | :--- |
| PRCLK | 16 MHz | 8 MHz |
| SCLK | 8 MHz | 4 MHz |
| DMACLK | 4 MHz | 2 MHz |
|  |  |  |

Table 2. Clocks Generated From 16 MHz .

The CPU Controller generates three other clocks. They are derived from the 28.63636 MHz clock Oscillator (Yl). These are OSC, 3.58 MHz , and l.l9 MHz. The 28 MHz input signal is divided by 2 to generate OSC, which is buffered by 468 and filtered by R49, Cl90, Cl90A, and FB6. OSC is then routed to the expansion bus slots for video clocks for any optional video boards. The 28 MHz signal is also divided by 8 , generating the 3.58 MHz clock which is routed to the Sound Generator (U7). 28 MHz is also divided by 24 to become the 1.19 MHz clock, which is routed to the clock input of the Interval Timer 8254-2 (U12).

## Command and Control Signal Generation

The command and control signals required for the Tandy 1000 TX operation are generated by the CPU Controller (U52). The command signals are decoded from the CPU status signals S0*-S1* and M/IO* during the $T s$ cycle. The decoded signals indicate the type of cycle that is to be executed (MEMR*, MEMW*, IOR*, IOW*, INTA*). The control signals (ALE, DT/R*, DSDENO*, DSDEN1*, MEMCYC) control the latching of addresses, determine the direction and enabling of the data bus buffers, and start a memory cycle. Table 3 indicates the decoding of the CPU status signals.

| M/IO* SI* SO* Type of Bus Cycle |  |  |  |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | Interrupt Acknowledge |
| 0 | 0 | 1 | I/O Read |
| 0 | 1 | 0 | I/O Write |
| 0 | 1 | 1 | None: Idle |
| 1 | 0 | 0 | Halt or Shutdown |
| 1 | 0 | 1 | Memory Read |
| 1 | 1 | 0 | Memory Write |
| 1 | 1 | 1 | None:Idle |

Table 3. CPU Status Signal Decoding.

AO and BHE* are decoded to determine the data transfer width to and from the CPU. Table 4 shows the data transfer width depending on the state of AO and BHE*.


Table 4. Data Transfer Width Decode.

## Command Buffer

Some of the command signals generated by the CPU Controller (U52) require buffering to the system. The ICs (U68) and (U22) implement this function. The ICs buffer the command signals to the system bus for the expansion bus slots, the peripheral devices, and also the Video Controller. The LMEGCS* and CPUHLDA signals control the buffers. When CPUHLDA is asserted active (high), it disables buffer (U22). (Outputs are tri-stated.) This indicates to the system that the DMA Controller has accessed the system bus. When CPU日LDA is negated (low), then the buffers are enabled, which allows the bus to be driven.

## dram Control

The CPU address decode for the Dynamic Random Access Memory (DRAM) array is generated by the Custom DRAM/DMA Control IC (U53). These signals are latched by ALE internally to the DRAM/DMA Control IC and held for the complete cycle. The address decode signals are RAS0*, RAS1*, RAS2*, CASL*, and CASH*. These are decoded by a certain address, depending on the type of DRAM used and the configuration of the MCO and MCl jumpers. Memory configurations supported by the Tandy 1000 TX are 640 K bytes or 768 K bytes (including 128 K of video memory). Table 5 shows the different options available on the DRAM/DMA Control IC.

| Memory option | Jumper $r$ Config | MCl | MCO | System Memory | Total System Memory* | Control | Bank | Address Range |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | E9-E10 | 0 | 1 | 512K | 640 K | RAS0 | 512K | 000000-07FFFF |
| 2 | None | 1 | 1 | 640 K | 768 K | $\begin{aligned} & \text { RAS0 } \\ & \text { RASI } \end{aligned}$ | $\begin{aligned} & 512 \mathrm{~K} \\ & 128 \mathrm{~K} \end{aligned}$ | $\begin{aligned} & 000000-07 \mathrm{FFFF} \\ & 080000-09 \mathrm{FFFF} \end{aligned}$ |

- Note: Total system memory includes 128 K of video memory.

Table 5. Memory Configurations.

MEMCYC triggers the control signals for the DRAM array. The MEMCYC signal (generated by the CPU Controller (U52) indicates that a DRAM BUS cycle is in progress. MEMCYC enables RASO*, RAS1*, RAS2*, CASH*, and CASL*, depending on the address of the bus cycle. The selected RAS(x)* lines become active at the next falling edge of PRCLKB.

After $\frac{1}{2}$ PRCLKB cycle at the rising edge of the clock, MUX is generated and switches the DRAM address (MA0-MA8) from Row Address to Column Address. After another PRCLKB cycle at the next rising edge of the clock, CASL* and/or CASH* are asserted. Two CAs signals are generated internally to the DRAM/DMA Control IC to provide the ability to access word or byte cycles in the DRAM array. Table 6 shows the state of each control signal during each type of bus cycle.

| Adaress Range |  | Bus Width | RAS0* | RAS1* | RAS2* | CASL* | CASH* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 000000-07FFFFH | Even | Byte | 0 | 1 | 1 | 0 | 1 |
| 000000-07FFFFH | Odd | Byte | 0 | 1 | 1 | 1 | 0 |
| 000000-07FFFFH | Even | Word | 0 | 1 | 1 | 0 | 0 |
| 080000-09FFFFH | Even | Byte | 1 | 0 | 1 | 0 | 1 |
| 080000-09FFFFH | Odd | Byte | 1 | 0 | 1 | 1 | 0 |
| 080000-09FFEFH | Even | Word | 1 | 0 | 1 | 0 | 0 |

Table 6. Signal State Control Signals.

The signals WEO* and WE1* provide read and write control. Both are asserted at the same time by IC (U24) and are controlled by MEMW* (memory write). If WEO* and WE1* are asserted high, it is a read cycle; if they are asserted low, it is a write cycle.

## Refresh Control

The OUTl pin of the 8254-2 Internal Timer (Ul2) generates an active high pulse every 15 usec. The rising edge of the OUTl signal clocks $\frac{1 / 2}{2}$ of a 74 LS 74 (U4), which generates the signal REFREQ. REFREQ is an input signal to the 8237 DMA controller (Ull). This input to Ull is actually Data Transfer Request 0, (DREQO), which requests the DMA to perform a DMA cycle. The DMA controller channel 0 has been programmed to perform a single transfer from memory to an $I / O$ device, such as a floppy drive. This causes a memory read at a certain address to be performed. Each time the REFREQ signal is generated, the DMA controller increments the address and performs another memory read. This causes all memory rows to be read every 4 ms to keep data in the DRAMs stable. Refer to the section on the DMA controller for more information on DMA cycles.

## BIOS ROM Control

The DRAM/DMA IC (U53) provides the CPU address decode used for the ROM select. The signal generated is called ROMCS* (ROM Chip Select) and is used as the Chip Enable for the BIOS ROMs U38 and U39. This output is asserted whenever any of three addressed ranges is detected, CPHLDA is inactive, and ALE is asserted. The three address ranges are 0E0000-0FFFFFH, EE0000-EFFFFFH, and FEO 000-FFFFFFH. The address lines SAl-SAl5 are provided to the BIOS ROMs for lower address control. The standard size of EPROM used in the Tandy 1000 TX is 16 K X 8 ( 128 K bit). The 1000 TX accepts larger EPROMs of $32 \mathrm{~K} \times 8$ ( 256 K bit) if required.

The data is buffered onto the MD0-MDl5 data bus, controlled by the 82C205 IC (Ul4).

## Reset Circuit

The CPU Control IC (U52) controls the system reset required either to initialize the complete system after power-up or to reboot. Two reset output signals, RESET and RESCPU, are active high and generated when a power-up condition is detected or when the reset button on the front of the computer is pressed.

The RESET signal is used as a general system reset, while the RESCPU signal resets the 80286 Processor. The RES* signal is the input to (U52), which signifies a reset condition. The RES* signal is generated either from an RC network during power up or from the reset switch. During a power-up, RES* is held low for the time period generated by the RC time constant of R24 and Cl35. This is the time it takes Cl35 to change to an active high. Also, if the reset switch is pressed, it applies a ground to C135 and discharges it. This asserts RES* low until Cl35 charges again to a logic high.

During power-up, the RES* signal is generated twice to provide a proper reset to the CPU control IC (U52). A second RC time constant is generated by R47A and C171A to the input of a schmidt trigger inverter (U66). This holds the input pin of $U 4$ ( $\frac{1}{2}$ of a 74 LS74) high for approximately 150 ms . When RESCPU is negated after the first reset, the CPU issues the first command to the CPU control IC by driving SI* low. This generates the first rising edge of DMACLK, which latches into U4. The $Q$ output of U4 is then routed to an open collector inverter, \{U67\}, which discharges C135, again asserting RES* low and generating the second reset. CRIA provides a reset to U4 when Cl35 is discharged to at least . 7v. After U4 is reset, RES* is released, and Cl35 is allowed to charge, negating RES* and finishing the second reset pulse. When the CPU issues the first command again, which starts DMACLK, U4 latches a low. This is because the D input of 44 has transitioned to a low by the end of the second reset.

The CPU Control IC (U52) also internally controls the RESCPU signal to meet the requirements of the 80286 during a detected shutdown condition.

## Wait State and Ready Logic

Wait state control is implemented internally to the CPU Control IC. The function of the wait state control logic is to match the speed of the various devices in the Tandy 1000 TX to the speed of the 80286 CPU. Two circuits assert wait states within memory and I/O cycles. One method is controlled by the device being accessed, using the IOCHRDY signal input to the CPU Control IC. If a device requires additional wait states within the bus cycle, the device should negate IOCHRDY low until it can service the bus cycle. After the required number of wait states have been inserted, the device should assert IOCHRDY, causing the READY* output of the CPU Control IC to be asserted low, which tells the $C P U$ to terminate the cycle.

The second method (internal to the CPU Control IC) is several default wait states during the various bus cycles. During a l6bit memory cycle (which is determined by the assertion of AFl6*), one wait state is automatically inserted. The default of an 8-bit memory or $I / O$ cycle is four wait states. This can be overridden by driving IOCHRDY low as mentioned above. As long as IOCHRDY is at a logic low level, wait states are inserted indefinitely.

Note: IOCHRDY should not be held low for longer than 15 usec because it will stop DRAM refresh cycles.

## NMI Logic

In the Tandy 1000 TX, the Non-Maskable Interrupt (NMI) indicates an I/O error condition or a Numerical Math Co-Processor 80287 error condition signal (NMI*). Both error conditions are enabled by the NMIEN signal, which is generated from the Video Controller, Big Blue. The INT287* signal (from the CPU Control IC) becomes active when the ERROR* signal is asserted by the Numerical Math Co-Processor.

## 80287 Control Logic

Incorporated into the CPU Control IC is the logic required to interface the 80287 Math Co-processor to the 80286 CPU. This logic decodes the signals that select and reset the 80287 and also handles the Busy*/Error* signals from the 80287 to the CPU.

The input signal $287 \mathrm{CS*}$ is a user $1 / 0$ address decoded signal used by the CPU Control IC to generate the control signals to the 80287 IC. The $287 \mathrm{CS*}$ signal is asserted during $\mathrm{I} / \mathrm{O}$ address 0 FOh $0 F F h$. Further decoding is provided by the CPU Control IC, which generates RES287, NPCS*, and BUSY287* signals. Table 7 defines the internal decode.

| Hex Address | Description |
| :--- | :--- |
| $0 F 0$ | Clear Math Co-processor Busy <br> $0 F l$ |
| 0 Reset Math Co-processor Busy |  |
| 0 Math Co-processor Chip Select |  |

## Table 7. 287CS* Decode.

Given the command to perform a task, the 80287 co-processor issues a BUSY* signal to the CPU Control IC. With the assertion of the BUSY287* output, this signal is passed to the CPU. Normally the BUSY* input is passed through to the BUSY287* output. Deassertion of BUSY* results in deassertion of BUSY287*. The BUSY287* output is latched, and the INT287* output pin is forced HIGH during this busy period if the ERROR* input becomes active (signaling a Numerical processor error). Until cleared by an $1 / 0$ write cycle to address 0FOh or OFlh, both signals then remain active. Both the interrupt latch for INT287* and the busy latch for BUSY287* are cleared after a system reset.

The CPU Control IC's RES287 output pin handles resetting of the 80287 co-processor. This can be activated by a system reset or an I/O write to address OFlh. This signal is active only for the period of time that the source signal is active, as it is not latched internally.

## CPU Address Buffers

U20, U21 (74ALS573), and U22 (74ALS244) implement buffering of the address lines to the system. SAOl-SAl9 are buffered and latched for the expansion bus slots and I/O peripherals. ALE is used to latch SAOl-SA19 and held for the complete bus cycle. SAOL-SAl. 9 are also used to address the BIOS ROMS and DRAM/DMA Control. Al7-A23 are routed directly to DRAM/DMA control to generate memory address decoded signals. The multiplexed address lines MAO-MA7 are also generated and buffered to the DRAM memory by the DRAM/DMA Control IC (U53). To meet address requirements for the DRAMs, the MUX signal multiplexes SAl-SAl6 internally to the DRAM/DMA Control IC.

During a DMA cycle, a 74 LS 245 (U3), is used to buffer S0-S7 directly from the DMA controller (Ull). S8-Sl6 are buffered internally to the DRAM/DMA controller. Sl7-S19 are buffered by U22 (1/2 of a 74ALS244).

## Data Buffers and Conversion Logic

The 82A205 IC (Ul4) provides the data buses, buffers, and drivers for DO-Dl5 to the system. Three data buses are generated, SDO-SD7 for the expansion bus slots, MD0-MD15 for memory access from ROM and DRAM, and D0-D15, which is routed to the 80286 CPU and 80287 Co-processor data bus. The direction and control of the data buffers are provided by the input signals to the 82A205 IC (DT/R*, DSDENO*, DSDENI*, SBHE*, and SAO).

DT/R* controls the direction of the data path during a read or write. The DSDEN0* and DSDENl* signals control the word and byte data transfers, while SBHE* and SAO determine the buffers to be enabled during a byte access.

Conversion logic is also implemented in the 82 A 205 IC , controlled by ENHLB* and DIRHLB. This conversion logic allows data to be transferred from the lower to upper or upper to lower data byte to meet the requirements of the CPU or receiving device.

A 74 ALS 245 buffers the Internal Peripheral Bus XDO-XD7 from the System Data Bus SDO-SDl. The enabling and direction are controlled by the signals XBUFDIR* and XBUFEN*, which are generated by a PLSl73 IFL (U19).

## 1/O Decode

The Video Control IC (U36), a 74 HCTl 38 (U49), a PLSl73 IFL (Ul9), and a 74 HCTl 38 IC (U34) accomplish the I/O Address decoding. These four ICs provide all the necessary chip select signals to the system. The AAO, BAl, and CA2 output signals of the Video Controller are encoded device select lines that are fed directly to the 74 HCTl 38 IC , in which $\mathrm{I} / \mathrm{O}$ address decoding is generated. The second 74 HCTl38 (U34) and the PLSI73 (U19) decode the system address to generate the other $I / O$ address decode select signals. Refer to the Tandy 1000 TX I/O Map for details.

## Floppy Disk Controller

The onboard Floppy Disk Controller (FDC) interfaces the system to the Floppy Disk Drive (FDD). Up to two internal 720 K (double density MFM format) FDDs can be accommodated.

The FDC circuit can be organized into the following subsections:

- uPD765A FDC Chip
- System Interface
- Clock Generation
- Precompensation
- Data Separator
- Disk Drive Interface
uPD765A Chip. The uPD765A EDC chip (U51) integrates most of the control logic necessary to:
. interface the Serial bit stream to or from the FDD to the parallel bus of the system
- implement the commands necessary to operate the FDD
- maintain information about the status of the FDD

During a read or write data operation to the FDD, the FDC chip generates a DMA request for a byte transfer to or from memory. The FDC chip continues to generate DMA requests until the preprogrammed amount of data is transferred as signified by generation of a Termination Count (TC) Signal. After the TC is reached, the FDC chip generates an inter rupt to the system through INTFDC so that status and result data can be serviced.

Refer to the device data sheet for complete descriptions of the available commands and the command and status registers.

System Interface, Various ICs latch and buffer data to and from the system. A DORWR* is generated at pin 6 of (U62) on an $1 / 0$ write to port 3F2 (hex). This signal latches the data byte that is bit defined as the Drive Select, XDS0* and XDSI*, Motor On, MTRON*, DMA and Interrupt Request (DMA/INTE), and a reset signal to the FDC controller U5l (FDCRST*).

Clock Generation. The FDC Support IC (U64) generates all clocks required by the Floppy Disk circuit. These clocks are derived from a 16 MHz input signal. FDCCLK, required by the FDC Controller (U5l), is derived by dividing the 16 MHz clock by 4 . The resulting 4 MHz clock is also used as a delay counter for the DMA request signal $D R Q$ as well as a reference clock for the write precompensation circuit. The 4 MHz clock also generates a 250 nanosecond pulse at a frequency of 500 KHz . The 500 KHz signal is used as a write clock for the FDC Controller.

Precompensation. The precompensation circuit is implemented internally to the FDC Support IC (U64). The write data bit can be shifted either early or late in the serial bit stream, depending on the requirements of the Floppy Disk Drive. This function is programmable and controlled by the FDC IC signals PSO and PSI.

Data Separator. The FDC Support IC (U64) also contains the data separator circuit. The data separator recovers the clock and data signals from the serial bit stream of the Floppy Disk Drive. The FDC Support IC supports only MFM or Double-density mode.

Disk Drive Interface. All FDC outputs to the FDD are driven by high current 7414 open collector buffers or 7416 open collector inverters. All FDC inputs from the FDD are buffered by 74 HCTl 4 SCHMIDT triggered inverters. The inputs are pulled up on board by 150 ohm terminating resistors. All outputs should be terminated on the last FDD by 1500 ohm resistors.

## Interrupt Controller

The 8259A Interrupt Controller chip (Ul6) supplies the maskable interrupt input to the CPU. The 8259 A has eight interrupt inputs controlled through software commands. It can mask (disable) and prioritize (arrange priority) to generate the interrupt input to the CPU. The eight interrupts are assigned as follows:

| \#0 | Timer Channel 0 | Software Timer |
| :--- | :--- | :--- |
| $\# 1$ | Keyboard | Keyboard Code Received |
| $\# 2$ | Interrupt on the Bus | Hard Disk Controller |
| $\# 3$ | Interrupt on the Bus | Modem |
| $\# 4$ | Interrupt on the Bus | RS-232 |
| $\# \#$ | Vertical Sync | Optional Bus Interrupt |
| $\# 6$ | Floppy Disk Controller | Optional Bus Interrupt |
| $\# 7$ | Printer | Optional Bus Interrupt |

Interrupts 0 and 1 are connected to system board functions as indicated in the chart. Interrupts 2-4 are connected directly to the Expansion Bus, with the normal assigned functions listed in the chart. Interrupts 5-7 are connected through a switch, (S2), to the system board function listed, and are also connected to the Expansion Bus. To use interrupts 5,6 , or 7 on the Bus, the system board function must be disconnected (by setting the appropriate switch to off). Note that disconnecting the normal system board function might cause some application programs to fail or operate incorrectly.

## Video Controller

The next major block of the Tandy 1000 TX is the video interface circuitry. This custom part contains all the logic necessary to generate an IBM-compatible color video display. The video interface logic consists of the $84-\mathrm{pin}$ custom video circuit (U36), four 64K X 4 RAMS (Ul8, U33, U35, and U48), a 74 LS 244 buffer (U71), and associated logic for generating composite and RGBI video.

The Tandy 1000 TX video interface circuitry controls 128 K of memory. This RAM is shared by the CPU and the video. Normally, the video requires only 16 K or 32 K for the video screen, and the remainder of the 128 K is available for system memory use.

The Tandy 1000 TX video interface custom circuit is composed of a 6845 equivalent design, dynamic RAM address generation/timing, and video attribute controller logic.

Normal function of the video interface custom circuit is as follows. After the 6845 is programmed with a correct set of operating values, a 4:l multiplexer generates the address inputs to the dynamic RAMs. This MUX switches between video (6845) address and CPU address as well as between row and column address. Also, the video interface chip provides the RAM timing signals and generates a wait signal, VIDWAIT*, to the CPU for proper synchronization with the video RAM access cycles.

The outputs from the RAM chips are connected only to the video interface custom circuit, so all CPU read/write operations are buffered by this part. During a normal display cycle, video data from the RAM chips is first latched in the Video Attribute latch and the Video Character latch. The video interface requires a memory organization of 64 K X 16 and latches 16 bits of memory during each access to RAM. From the output of the two latches, the data is supplied to the character ROM for the alpha modes or to the shift registers for the graphics modes. A final 2:l MUX switches between foreground or background in the alpha modes.

From the 2:l MUX, the RGBI data is combined with the PC color select data and latched in the Pre-palette latch. This latch synchronizes the RGBI data before it is used to address the palette. The palette mask MUX switches between incoming RGBI data and the palette address register. During a CPU write to the palette, this address register selects one of the 16 palette locations. Also, the palette mask MUX allows any of the input RGBI bits to be set to zero.

The palette allows the 16 colors to be remapped in any desired organization. Normally, the palette is set for a l:l mapping (red $=$ red, blue $=$ blue, and so on) for $P C$ compatibility. However, instantly changing the on-screen colors is a powerful tool for animation or graphics programs.

After the Palette, the RGBI data is resynchronized in the Post palette register. The final logic before the RGBI data is buffered off the chip is the Border MUX. This MUX allows the Border to be replaced with any color selected by the border color latch. This latch is normally disabled in PC modes, but it is used in all PC jr modes.

## Timer

The final Tandy 1000 TX function other than $I / O$ is the 8254-2 timer chip (Ul2). This part is composed of three independent programmable counters. The clock for all three counters is 1.1925 MHz. Counters 0 and 1 are permanently enabled. Counter 2 is controlled by port Hex 0062 , bit 0 . Counter 0 is connected to system interrupt 0 and is used for software timing functions. Counter 1 is used for refresh function timing. Counter 2 is connected to the sound circuit and also to port Hex 0061, bit 5 .

## Joystick Interface

The joystick interface converts positional information from hand-held joysticks (1 or 2) into CPU data. Each joystick provides one or two push-buttons and $X, Y$ position for a total of four bits each. You can use two 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 U9. The other comparator input is the reference signal (a ramp between 0.0 to +5.0 volts).

When the position signal is equal to 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 an I/O Write is made at Port $200 / 201$ Hex. The IOW* and JOYCS* signals turn on $Q 2$, which drains Cll4 to 0.0 volts. When Q2 is turned off, Q1, Rl5, Rl3, R14, and CRl create a constant-current source that linearly charges Cll4 to +5.0 VDC in 1.12 milliseconds. The joystick information is "read" by the CPU at Port 200/201 Hex through Ul0. See the Joystick Block Diagram.

## Keyboard Interface

The next $1 / 0$ function of the Tandy 1000 TX is the Keyboard interface custom circuit. The heart of this custom part is several read-write registers that are used to control the keyboard interface logic. For the interface to the keyboard connector, a l64type shift register is used to load the serial data and allow the CPU to read it as 8 parallel bits.

## Sound Circuit

The sound circuit is one of the five $I / O$ functions of the Tandy 1000 TX. The circuit provides sound output for the internal speaker as well as for an external sound circuit.

The main source of sound in the Tandy 1000 TX is the 76496 complex sound generator (U7). This device has three tone generators and one white noise generator. Each tone generator can be programmed for frequency and attenuation. Also, this device has an audio input pin connected to the gated output of timer channel 2. This audio input signal is mixed with the sound generator signal and supplied to the audio output pin.

From the output of the 76496 , the sound signal is connected to a dual analog multiplexer ( 48 ). The multiplexer is switched by port 61 , bit 4 , and turns off the audio signal to the speaker, headphone jacks, and external audio output. The output of the multiplexer (U8) is routed to audio amplifiers U76 for the external audio output and $U 2$ for the internal speaker and headphone jacks. The volume of the internal speaker can be adjusted by a user-accessible volume control (R6). When the headphone jack is used, the internal speaker is disabled.

## DMA Controller

The major components of the Direct Memory Access (DMA) circuit consists of an 8237A-5 DMA controller (U1l), the DRAM/DMA Control (U53), and a bi-directional address buffer $74 A L S 245$ (U3).

Initialization--A DMA Operation. When a DMA operation is requested by software or by a peripheral through a DREQ line, the $8237 A-5$ DMA controller initiates a Bus Hold Request to the 80286 CPU through the CPU Controller IC. The CPU Controller arbitrates the CPU Hold Request from the DMA controller to the CPU.

When the CPU acknowledges the Hold request, the CPU control, address, and data lines are tri-stated. The CPU Controller controls the direction and enables the memory or peripheral address and data buses that correspond to the requested DMA operation.

During the DMA operation, the $8237 A-5$ acts as the bus master and, along with the CPU Controller IC, generates all bus control signals and address and data signals. The DMA transfers continue for the number of counts and to the destination address that was previously programmed into the DMA registers. See the device data sheet and the $I O$ map for complete descriptions of the registers, their locations, and their functions.

DMA Bus Cycles. During the data bus cycle, the $8237 \mathrm{~A}-5$ first outputs the upper address (A8-A15) on its data outputs (XD0-XD7), to be latched in the buffer internally to the DRAM/DMA Control by the address strobe signal (AS) from the $8237 A-5$. Next, the lower address (A0-A7) is put directly on the $S$ address bus by the 8237A-5.

The DMA request acknowledge signals, DACK2 and DACK3, are used along with RFRSH* and ACK* to enable the page register to be output as the upper address (SAl6 and Al7 through A23), which are buffered by U 22 to the system expansion slots.

A DMA bus cycle can be extended by the RDY input of the DMA controller. The DMA memory read DMAMR* is routed to the CPU Controller IC for extending the DMA bus cycle by inserting on DMA clock period as a wait state. The CPU Controller inserts the wait state by controlling the DMARDY input of the DMA controller.

I/O devices can extend the DMA bus cycle by controliing the IOCHRDY signal of the expansion bus. Setup times must be observed for IOCHRDY to be recognized.

## RS232 Serial Port Interface

The RS232 Port is a single-channel, asynchronous communications port. The heart of the serial port is the WD8250-A Asynchronous Communications Element ACE (U70) that functions as a serial data input/output interface. It performs serial-to-parallel conversion on data characters received from a peripheral device or modem and parallel-to-serial conversion on data characters received from the CPU.

Status information reported includes the type and condition of the ACE's transfer operations as well as any error conditions detected during serial data operations. The WD8250-A includes a programmable Baud Rate Generator that allows operation from 50 to 9600 Baud. The WD8250-A is supplied with a clock of 1.8432 MHz from oscillator (Y2). The WD8250-A can be tailored to the user's requirements by being able to remove start bits, stop bits, and parity bits. It supports $5,6,7$, or 8 data bit characters with I, lk, or 2 stop bits. Diagnostic capabilities provide loopback functions of transmit/receive and input/output signals.

The ACE is programmed by selecting the $I / O$ address $3 F 8-3 F E$ hex for primary and $2 \mathrm{~F} 8-2 \mathrm{FE}$ hex for secondary and writing data out to the port. Adress bits $A 0$. Al, and A2 are used to define the modes of operation by selecting the different registers to be programmed or read.

One interrupt is provided to the system from IRQ4 for primary operation and $I R Q 3$ 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 cause an interrupt.

## Parallel Printer Port Interface

The final $\mathrm{I} / \mathrm{O}$ interface of the Tandy 1000 TX is the Printer Interface. This part supplies all the signals required to interface to a typical parallel printer. These signals are 8 data out lines, plus various handshake control signals. Also, the printer interface generates an interrupt to the CPU if enabled.

## Expansion Ports

## System Expansion Bus

This section identifies the $1 / 0$ interface requirements for the 8bit, PC-compatible option cards. Each of the five slots has a 62-pin connector socket.

The following connector pin assignment is used on the PC option slots; this connector socket has 62 pins.

| Pin | Signal Name | I/O | Pin | Signal Name | I/O |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Al | NMI* | I | B1 | GND | GROUND |
| A2 | SD7 | I/O | B2 | BRESET | $\bigcirc$ |
| A3 | SD6 | I/O | B3 | $+5 \mathrm{~V}$ | POWER |
| A4 | SD5 | I/O | B4 | IRQ2 | I |
| A5 | SD4 | I/O | B5 | -5V | POWER |
| A6 | SD3 | I/O | B6 | FDCDRQ | I |
| A7 | SD2 | 1/0 | B7 | -12V | POWER |
| A8 | SDl | I/O | B8 | N/C |  |
| A9 | SD0 | I/O | B9 | +12V | POWER |
| Al0 | IOCHRDY | I | Bl0 | GND | GROUND |
| All | AEN | 0 | Bll | SMEMW* | 0 |
| Al2 | SAl 9 | 0 | Bl2 | SMEMR* | 0 |
| A13 | SA18 | 0 | B13 | IOW* | 0 |
| Al 4 | SAl7 | 0 | B14 | IOR* | 0 |
| Al5 | SAl6 | 0 | B15 | DACK3* | 0 |
| Al 6 | SAl5 | 0 | B16 | DRQ3 | I |
| Al7 | SA14 | 0 | B17 | DACK1* | 0 |
| Al 8 | SA13 | 0 | B18 | DRQ1 | I |
| Al9 | SAl2 | 0 | B19 | RFRSH* | 0 |
| A20 | SAll | 0 | B20 | SCLK | 0 |
| A21 | SAl0 | 0 | B21 | IRQ7 | I |
| A22 | SA9 | 0 | B22 | IRQ6 | I |
| A23 | SA8 | 0 | B23 | IRQ5 | I |
| A2 4 | SA7 | 0 | B24 | IRQ4 | I |
| A25 | SA6 | 0 | B25 | IRQ3 | I |
| A26 | SA5 | 0 | B26 | FDCDACK* | 0 |
| A27 | SA4 | 0 | B27 | T/C | 0 |
| A28 | SA3 | 0 | B28 | BALE | 0 |
| A29 | SA2 | 0 | B29 | +5V | POWER |
| A30 | SAl | 0 | B30 | OSC | 0 |
| A31 | SAO | 0 | B31 | GND | GROUND |

## Expansion Bus Signal Description

The following signal descriptions for the System I/O Bus are for PC bus-compatible option cards. Note that all signal lines are TTL compatible levels and that $I / O$ adapters should be designed with a maximum of two low power Shottky (LS) loads per line.

SCLK (B20). SCLK is the System clock and has a period of 125 ns in 8 MHz mode, or 250 ns in 4 MHz mode. It has a $50 \%$ duty cycle and is used only for sychronization with the CPU. It is not intended for uses requiring a fixed frequency.

SAO through SAl9 (Al2-A31). These lines are 20 address bits used to address memory and $I / O$ devices within the Tandy 1000 TX . They are gated on the system bus when the BALE signal is high and are latched on the falling edge of the BALE signal. Generation of these signals is accomplished by the CPU or a DMA controller. SAO-SAl9 are active high.

BALE (B28). BALE is a Buffered Address Latch Enable generated by the CPU Control IC. It is used to latch valid addresses from the CPU, and can be used by an I/O board to indicate a valid CPU address, in conjunction with AEN. BALE is pulled to a high state during DMA cycles, which include Refresh cycles. BALE is active high.

AEN (All). AEN is an Address Enable signal used to remove the CPU and other devices from the bus to allow DMA transfers to take place. During AEN active, the DMA controller has control of the address bus, the data bus, the READ command lines, and the WRITE command lines. AEN is active high.

SDO through SD7 (A2-A9). These signals are the data bus bits 0 through 7 from the CPU to memory and $I / O$ devices on the bus. SDO is the least significant bit (lsb), and SD7 is the most significant bit (msb).

BRESET (B2). BRESET is used to reset or initialize the expansion logic during power-up time, line voltage outage, or when the Reset switch on the front panel is pressed. BRESET is active high.

NMI* (AI). This signal indicates an uncorrectable system error when active. The NMI* signal provides the system board with parity information about memory or devices on the bus. NMI* is active low.

IOCARDY (A10). This signal is used to lengthen $I / O$ or memory cycles when driven low by the active device. (This signal should not be held low more than 15 microseconds.) Any slow device using this line should drive it low immediately upon detecting its valid address and a READ or WRITE command. See the timing diagram for setup times. IOCHRDY is active high (Ready condition).

IRQ2 through IRQ7 (B4, B2l-B25). These signals are used to tell the CPU that an $I / O$ device needs attention. The Inter rupt Requests are prioritized with IRQ2 having the highest priority and IRQ7 the lowest. An Interrupt Request is generated when any $I R Q$ signal is driven high and held high until the CPU acknowledges the inter rupt.

IOR* (B14). IOR* is a read signal that instructs an $I / O$ device to drive its data onto the data bus (SD0-SD7). This line can be driven by the CPU Control IC or by the DMA controller. IOR* is active low.

IOW* (Bl3). IOW* is a write signal that instructs an I/O device to read, or latch, the data from the data bus (SDO-SD7). This line can be driven by the CPU Control IC or by the DMA controller. IOW* is active low.

SMEMR* (B12). SMEMR* is a read signal that instructs a memory device to drive its data onto the data bus (SDO-SD7). This line can be driven by the CPU Control IC or by the DMA controller through the CPU Control IC. SMEMR* is active only when the memory address is within the first 1 megabyte range (000000-0FFFFFH). SMEMR* is active low.

SMEMW* (BIl). SMEMW* is a write signal that instructs a memory device to read, or latch, the data from the data bus (SDO-SD7). This line can be driven by the CPU Control IC or by the DMA controller through the CPU Control IC. SMEMW* is active only when the memory address is within the first 1 megabyte range (000000-0FFFFFH). SMEMW* is active low.

DRQ1, FDCDRQ, and DRQ3 (B18, B6, B16). These lines are asynchronous DMA requests by peripheral devices to gain DMA service. They are prioritized with DRQl having the highest priority, FDCDRQ next, and DRQ3 lowest. A DMA request is generated by driving a $D R Q$ line active high and holding it until the corresponding DACK (DMA acknowledge) signal goes active. DRQ1, FDCDRQ, and DRQ3 perform only 8-bit transfers. All DRQ lines are active high.

DACK1*, FDCACK*, and DACK3* (B17, B26, B15). These lines are DMA acknowledge signals used to acknowledge DMA requests DRQl, FDCDRQ, and DRQ3. All DACK signals are active low.

RFRSH* (B19). This signal is used to indicate a refresh cycle that can be used by a memory board to refresh Dynamic memory. RFRSH* is active low and generated every 15 usec.

T/C (B27). T/C is a signal that provides a pulse when the terminal count for any DMA channel is reached. T/C is active high.

OSC (B30). OSC is an oscillator signal that is a high-speed clock with a 70 nanosecond period (14.31818 megahertz). It has a $50 \%$ duty cycle.

| Memory Map |  |  |
| :---: | :---: | :---: |
| Address | Name | Allocated Function |
| 000000-07FFFF | 512K System RAM | System Memory |
| 080000-09FFFF | 128K System/Video RAM or 128 K | System Memory and Video Diplay Memory |
|  | Expansion Memory | or System Memory Memory |
| 0A0000-08FFFF | 128K Video RAM | Reserved For Graphics Display Memory |
| 0E0000-0FFFFF, | 16K BIOS ROM | Reserved For BIOS |
| EE0000-EFFFFF, or | Memory | ROM Memory |
| FE0000-FFFFFF |  |  |

## I/O Port Map Summary

| Block | Usage |
| :---: | :---: |
| 0000-001F | 0000-001F |
| 0020-003F | 0020-0027 |
| 0040-005F | 0040-0047 |
| 0060-007F | 0060-006F |
| 0080-009F | 0080-009F |
| 00A0-00BF | 00 AO |
| 00C0-0 0DF | 00C0-00C7 |
| 00E0-00FF | 00E0-00FF |
| 0100-01FF |  |
| 0200-020F | 0200-0207 |
| 0210-02F7 |  |
| 02F8-02FF | 02F8-02FF |
| 0300-031F |  |
| 0320-032F |  |
| 0330-036F |  |
| 0370-0377 | 0370-0377 |
| 0378-037F | 0378-037F |
| 0380-03CF |  |
| 03D0-03DF | 03D0-03DF |
| 03E0-03EF |  |
| 03F0-03F7 | 03F0-03F7 |
| 03F8-03FF | 03F8-03FF |
| 0400-FEFE |  |

## Function

DMA Function
Interrupt Controller Timer
PIO Function
DMA Page Register
NMI Mask Register
Sound Generator
Numerical Co-processor
Reserved
Joystick Interface
Reserved
Serial Port Secondary (COM2)
Reserved
Hard Disk Controller (optional)
Reserved
Floppy Disk Controller 2 (optional)
Printer
Reserved
System Video
Reserved
Floppy Disk Controller 1
Serial Port Primary (COMl)
Not Usable


```
Address
    Description
0007 DMA Controller
    IOW* = 0: Channel 3 Base and Current Word Count
                        Internal Flip/Flop = 0: Write w0-W7
                        Internal Flip/Flop = 1: Write AW-Wl5
    IOR* = 0: Channel 3 Current Word Count
                        Internal Flip/Flop = 0: Read W0-W7
                        Internal Flip/Flop = l: Read W8-Wl5
0008
    DMA Controller
    IOW* = 0, Write Command Register
Bit Description
    0 0 = Memory to Memory Disable
        l = Memory to Memory Enable
    l 0 = Channel 0 Address Hold Disable
    l = Channel O Address Hold Enable
    X If Bit 0 = 0
    2 0 = Controller Enable
    l = Controller Disable
    3 0 = Normal Timing
        l = Compressed Timing
        X If Bit 0 = l
    4 0 = Fixed Prioroty
    1 = Rotating Priority
    5 0 = Late Write Selection
        l = Extended Write Selection
    X If Bit 3 = l
    6 0 = DREQ Sense Active High
        l = DREQ Sense Active Low
    7 0 = DACK Sense Active Low
        l = DACK Sense Active High
        IOR* = 0, Read Status Register
Bit Description
    0 1 = Channel 0 Has Reached TC
    1 l = Channel 1 Has Reached TC
    2 1 = Channel 2 Has Reached TC
    3 1 = Channel 3 Has Reached TC
    4 1 = Channel 0 Request
    5 1 = Channel I Request
    6 l = Channel 2 Request
    7 l = Channel 3 Request
```

Address Description




```
Address Description
000C DMA Controller
    IOW* = 0, Clear Byte Pointer Flip/Flop
    IOR* = 0, Illegal
000D DMA Controller
    IOW* = 0, Master Clear
    IOR* = 0, Read Temporary Register
000E DMA Controller
    IOW* = 0, Clear Mask Register
    IOR* = 0, Illegal
000F DMA Controller
    IOW* = 0, Write All Mask Register Bits
Bit Description
    0 0 = Clear Channel O Mask Bit (Enable)
        1 = Set Channel 0 Mask Bit (Disable
        0 = Clear Channel l Mask Bit (Enable)
        l = Set Channel l Mask Bit (Disable
    2 0 = Clear Channel 2 Mask Bit (Enable)
    1 = Set Channel 2 Mask Bit (Disable
    3 0 = Clear Channel 3 Mask Bit (Enable)
    l = Set Channel 3 Mask Bit (Disable
4-7 Don't Care
    IOR* = 0, Illegal
0010-001F Same as 0000-000F
```

| Address | Description |
| :---: | :---: |
| 0020 | 8259A Inter rupt Controller |
| Note: Initialization words are set up by the operating system and are generally not to be changed. Writing an initialization word might cancel pending interrupts. |  |
|  |  |
|  |  |
| Bit4 = 1 Initialization Command Word l |  |
| Bit0 $=0 \quad$ ICW4 Needed |  |
|  | 1 ICW4 Not Needed |
| Bitl $=0 \quad$ Cascade Mode |  |
| $=1$ Single Mode |  |
| Bit2 Not Used |  |
| Bit3 $=0 \quad$ Edge Triggered Mode |  |
| Bit5-7 $\quad \begin{array}{ll}\text { l } & \text { Level Triggered Mode } \\ \end{array}$ |  |
|  |  |
| Bit4 $=0$ \& Operation Control Word 2 |  |
| Bit3 $=0$ | Bit0-2: Determine The Inter rupt Level Acted on When The SL Bit Is Active |
|  | Interrupt Level $=\begin{array}{lllllllll}0 & 1 & 2 & 3 & 4 & 5 & 6 & 7\end{array}$ |
|  | Bit0 (L0): 0100100101 |
|  | Bitl (Ll): 00011100011 |
|  | Bit2 (L2): 000001111 |
| Bit5-7: Control Rotate And End Of Interrupt Modes |  |
| B7 B6 B5 |  |
| 001 | Non-Specific EOI Command End Of Interrupt |
| 0111 | Specific EOI Command End Of Interrupt |
| 101 | Rotate On Non-Specific EOI Auto Rotation |
| 100 | Rotate In Automatic EOI Mode (Set) Auto Rotation |
| 000 | Rotate In Automatic EOI Mode (Clear) Auto Rotation |
| 1111 | *Rotate On Specific EOI Command Specific Rotation |
| 1110 | *set Priority Command Specific Rotation |
| 0 1 0 | No Operation |
| (*L0 - L2 Are Used) |  |

## Address Description

```
Bit4=0 & Operation Control Word 3
Bit3 = 1 Bit 0-l:
    Bitl Bit0 - Read Register Command
        0 No Action
        0 1 No Action
        1 0 Read IR Register On Next IOR* Pulse
        I I Read IS Register On Next IOR* Pulse
        Bit2 = 0: No Poll Command
        = 1: Poll Command
        Bit5-6 
        Bit7 = 0
0021
    8259A Interrupt Controller
    Initialization Control Word 2
    Bit0-7: Not Used
    Bit3-7: T3-T7 Of Interrupt Vector Address
                                    (8086/8088/80286 Mode)
    Initialization Control Word 3 (Master Device)
    Bit0-7: = 1 Indicated IR Input Has A Slave
            =0 Indicated IR Input Does Not Have A
        Slave
    Initialization Control Word 3 (Slave Device)
Bit0-2 = IDO-2
    Bit0 Bitl Bit2 - Slave ID #
        0 0 0
        0 0 1 1
        0
        1 0
        0}10
        1 0
        1 0
        Bit3-7=[ccl
```


## Address Description

```
Initialization Control Word 4
Bit0: Type Of Processor
        \(=0 \quad\) MCS-80/85 Mode
        \(=1 \quad 8086 / 8088 / 80286\) Mode
    Bitl: Type of End Of Inter rupt
        =0 Normal EOI
        \(=1 \quad\) Auto EOI
Bit2-3: Buffering Mode
Bit3 Bit2
    0 X Non-Buffered Mode
    1 Buffered Mode/Slave
    1 l Buffered Mode/Master
Bit4: Nesting Mode
        \(=0 \quad\) Not Special Fully Nested Mode
        \(=1 \quad\) Special Fully Nested Mode
Bit5-7: \(=0\) (Not Used)
Operation Control Word l (IOR*/IOW*)
Bit0-7: Interrupt Mask For IRQ0-IRQ7
    \(=0 \quad\) Mask Reset (Enable)
    \(=1 \quad\) Mask Set (Disable)
```

Note: Peripherals requesting an interrupt service must generate a low to high edge and then remain at a logic high level until service is acknowledged. Failure to do so results in a Default Service for IRQ7.

```
0022-0027 Same as 0020-0021
0028-003F Not Used
0040/0044 8254-2 Timer
    IOW* = 0: Load Counter No. 0
    IOR* = 0: Read Counter No. O
0041/0045 8254-2 Timer
    IOW* = 0: Load Counter No. 1
    IOR* = 0: Read Counter No. 1
0042/0046 8254-2 Timer
    IOW* = 0: Load Counter No. 2
    IOR* = 0: Read Counter No. 2
```

Address

## Description

```
0043/0047 8254-2 Timer
    IOW* = 0: Write Mode Word
    Control Word Format
    Bit 0: BCD
        =0: BCD Counter (4 Decades)
        =1: Binary Counter 16 Bits
    Bitl-3: Mode Selection
    Bit3 Bit2 Bitl
        0
        0 0 1 Mode 1
        X 1 0 Mode 2
        X 1 1 Mode 3
        1 0 0 Mode 4
        l 0 1 Mode 5
    Bit4-5: Read/Load
    Bit5 Bit4
        0 0 Counter Latching Operation
        0 1 Read/Load LSB Only
        1 0 Read/Load MSB Only
        l l Read/Load LSB First, Then MSB
    Bit6-7: Select Counter
    Bit7 Bit6
        0 0 Select Counter 0
        0 1 Select Counter 1
        1 0 Select Counter 2
        l l Illegal
    IOR* = 0: No-Operation 3-State
0048-005F Not Used
0060 Port A / Keyboard Interface Control Ports
    (Read Only)
    Bit Description
    0 Keyboard Bit 0-LSB
    1 Keyboard Bit l
    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
```



```
Address Description
0 0 6 9 ~ P o r t ~ J ~ R e a d ~ A n d ~ W r i t e ~ 8 ~ B i t ~ D a t a ~ S t o r a g e ~ F o r ~
    Shutdown
    Status Byte
    Bit0: Data Bit 0
    Bitl: Data Bit l
    Bit2: Data Bit 2
    Bit3: Data Bit 3
    Bit4: Data Bit 4
    Bit5: Data Bit 5
    Bit6: Data Bit 6
    Bit7: Data Bit 7
006A-007F Reserved
0080 DMA Page Register (Reserved for Diagnostics)
    Write Only
0 0 8 1 ~ D M A ~ C h a n n e l ~ 2 ~ P a g e ~ R e g i s t e r ~ - W r i t e ~ O n l y ~
Address Description
Bit0 Address Al6
Bitl Address Al7
Bit2 Address Al8
Bit3 Address Al9
Bit4 Address A20
Bit5 Address A2l
Bit6 Address A22
Bit7 Address A23
0 0 8 2 ~ D M A ~ C h a n n e l ~ 3 ~ P a g e ~ R e g i s t e r ~ - W r i t e ~ O n l y ~
Address Description
Bit0 Address Al6
Bitl Address Al7
Bit2 Address Al8
Bit3 Address Al9
Bit4 Address A20
Bit5 Address A2l
Bit6 Address A22
Bit7 Address A23
0 0 8 3 ~ D M A ~ C h a n n e 1 ~ 0 - 1 ~ P a g e ~ R e g i s t e r ~ - W r i t e ~ O n l y ~
Address Description
Bit0 Address Al6
Bitl Address Al7
Bit2 Address Al8
Bit3 Address Al9
Bit4 Address A20
Bit5 Address A2l
Bit6 Address A22
Bit7 Address A23
```

```
Address Description
0084-008F Same as 0080-0083
OOAO NMI Mask Register, Write Only
    Bit Description
    O External Video
        0 = Normal Operation
        1 = All Video Addresses And Ports Are Disabled
        MEMCONFIG 1 - Al7 128K SW
        MEMCONFIG 2 - Al8 256K SW
        MEMCONFIG 3 - Al9 5l2K SW
        "0" Enable 128K Of Video RAM (Always "0")
        Not Used
        Not Used
    7 1 = Enable NMI
        0 = Disabled
00Al-00A7 Reserved
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline Bit & Bit & Bit & Bit & Memory & Memory & Memory & & \\
\hline 4 & 3 & 2 & 1 & Start & Length & Range & & \\
\hline \multicolumn{9}{|l|}{256K} \\
\hline Enable & A19 & Al 8 & Al7 & & & & & \\
\hline 0 & 0 & 0 & 0 & 00000 & 128K & 0 0000-1 & FFFF & \\
\hline 0 & 0 & 0 & 1 & 20000 & 128K & 2 0000-3 & FFFF & \\
\hline 0 & 0 & 1 & 0 & 40000 & 128K & 4 0000-5 & FFFF & \\
\hline 0 & 0 & 1 & 1 & 60000 & 128 K & 6 0000-7 & FFFF & \\
\hline 0 & 1 & 0 & 0 & 80000 & 128K & 8 0000-9 & FFFF & \\
\hline 0 & 1 & 1 & 1 & B 0000 & 128K & B 0000-B & FFFF & (4 Page) \\
\hline 1 & 0 & 0 & 1 & 00000 & 256K & 0 0000-3 & FFFF & \\
\hline 1 & 0 & 1 & 0 & 20000 & 256K & 2 0000-5 & FFFF & \\
\hline 1 & 0 & 1 & 1 & 40000 & 256K & 4 0000-7 & FFFF & \\
\hline 1 & 1 & 0 & 0 & 60000 & 256K & 6 0000-9 & FFFF & \\
\hline 1 & 1 & 1 & 1 & B 8000 & 256K & B 0000-B & FFFF & (8 Page) \\
\hline
\end{tabular}
NOTE: To turn off on-board video, be sure Port AOH, Data Bit 0 is
    a "1" And Video Array Register 3.
00A8-00AF Not Used
```




Address Description
02 F9 $\quad \begin{aligned} & \text { Divisor Latch MSB (Divisor Latch Access Bit DLAB }=\end{aligned}$

Bit Description
0 Bit 0
1 Bit l
2 Bit 2
3 Bit 3
4 Bit 4
5 Bit 5
6 Bit 6
7 Bit 7
$02 \mathrm{F9}$ Interrupt Enable Register
Bit Description
$0 \quad$ "l" = Enables the Received Data Available Interrupt
1 "l" = Enables the Transmitter Holding Register Int
2 "l" = Enables Receive Line Status Interrupt
3 "l" = Enables the Modem Status Interrupt
4-7 Always Logical "0"
$02 \mathrm{FA} \quad$ Interrupt Identification Register
Bit Description
$0 \quad$ "0" $=$ Inter rupt Pending
1-2 Bit 2 Bit 1

| $" 0 "$ | "0" | Fourth Level Priority |
| :---: | :---: | :--- |
| $" 0 "$ | $" 1 "$ | Third Level Priority |
| "1" | "0" | Second Level Priority |
| "l" | "l" | Highest Level Priority |

```
Address Description
02FB Line Control Register
Bit Description
0-1 Bit 1 Bit 0
    "0" "0" Five Bit Word Length
    "0" "l" Six Bit Word Length
    "l" "0" Seven Bit word Length
    "1" "l" Eight Bit word Length
    "0" = One stop Bit
    "l" = 1\frac{1/2}{2}}\mathrm{ Stop Bits When Five Bit Length Selected
                Two Stop Bits With Six, Seven, or Eight Bit
    "l" = Parity Enable
    "0" = Odd Parity Select
    "l" = Even Parity Select
    5 Stick Parity Bit
    6 "l" = Set Break Enable
    7 "l" = Divisor Latch Access Bit Enable
02FC
Bit Description
    0 "I" = Data Terminal Ready Set (DTR)
    "0" = Data Terminal Ready Reset (DTR)
    l Request To Send (RTS)
    2 Out l
    3 Out 2
    4 Loop
5-7 Always Logical "0"
02FD Line Status Register
Bit Description
    0 Data Ready (DR)
    l Overrun Error (OR)
    2 "1" = Detect Parity Error (PE)
    3 "l" = Detect Framing Error (FE)
    4 "l" = Break Interrupt (BI)
    5 Transmitter Holding Register
        "l" = Character Transferred From Holding To Shift
                        Register
    "0" = Loading Transmitter Holding Register
    6 Transmitter Shift Register Empty
        "l" = Shift Register Idle
        "0" = Data Transfer From Holding Register
        Always Logical "0"
```




| Addres | SS Description |
| :---: | :---: |
| 03 D 4 | 6845 Address Register |
| 03D5 | 6845 Data Register |
| 03D6 | Not Used |
| 03D7 | Not Used |
| $\begin{aligned} & 03 D 8 \\ & \text { Bit0 } \end{aligned}$ | Mode Select Register |
|  | High Resolution Clock |
|  | $=0$ Selects 40 By 25 Alphanumeric Mode |
|  | $=1$ Selects 80 By 25 Alphanumeric Mode |
| Bitl | Graphics Select |
|  | = 0 Selects Alphanumeric Mode |
|  | $=1$ Selects 320 By 200 Graphics Mode |
| Bit2 | Black And White |
|  | $=0$ Selects Color Mode |
|  | = 1 Selects Black And White Mode |
| Bit3 | Video Enable |
|  | $=0$ Disables Video Signal |
|  | $=1$ Enables Video Signal |
| Bit4 $\begin{aligned} & \\ &= \\ &=\end{aligned}$ | 640 Dot Graphics |
|  | $=1$ Enables 640 By 200 B\&W Graphics Mode |
| Bit5 | Blink Enable |
|  | = 0 Disables Blinking |
|  | = 1 Enables Blinking |
| 03D9 | Color Select Register |
| Bit0 B | Background Blue |
| Bitl B | Background Green |
| Bit2 B | Background Red |
| Bit3 Ba | Background Intensity |
| Bit4 F | Foreground Intensity |
| Bit5 | Color Select |





## Address Description

$03 F 9 \begin{aligned} & \text { Divisor Latch MSB (Divisor Latch Access Bit DLAB }= \\ & \text { "I") }\end{aligned}$

## Bit Description

0 Bit 0
1 Bit 1
2 Bit 2
3 Bit 3
4 Bit 4
5 Bit 5
6 Bit 6
7 Bit 7
03F9 Interrupt Enable Register

## Bit Description

$0 \quad$ "l" = Enables the Received Data Available Interrupt
1 "l" = Enables the Transmitter Holding Register Int
2 "l" = Enables Receive Line Status Interrupt
3 "l" = Enables the Modem Status Interrupt
4-7 Always Logical "0"
03FA Interrupt Identification Register
Bit Description
0 "0" = Interrupt Pending
1-2 Bit 2 Bit 1

| $" 0 "$ | "0" | Fourth Level Priority |
| :---: | :---: | :--- |
| $" 0 "$ | $" 1 "$ | Third Level Priority |
| "l" | "0" | Second Level Priority |
| "l" | "l" | Highest Level Priority |

```
Address Description
03FB Line Control Register
Bit Description
0-1 Bit1 Bit 0
    "0" "0" Five Bit Word Length
    "0" "l" Six Bit word Length
    "l" "0" Seven Bit Word Length
    "l" "l" Eight Bit Word Length
    2 "0" = One stop Bit
    "l" = l\frac{1/2}{2}}\mathrm{ Stop Bits When Five Bit Length Selected
                Two Stop Bits With Six, Seven, or Eight Bit
    "1" = Parity Enable
    "0" = Odd Parity Select
    "l" = Even Parity Select
    5 Stick Parity Bit
    6 "l" = Set Break Enable
    7 "l" = Divisor Latch Access Bit Enable
03FC
Bit Description
0 "l" = Data Terminal Ready Set (DTR)
    "0" = Data Terminal Ready Reset (DTR)
    1 Request To Send (RTS)
    2 Out 1
    3 Out 2
4 Loop
5-7 Always Logical "0"
03FD Line Status Register
Bit Description
    0 Data Ready (DR)
    1 Overrun Error (OR)
2 "l" = Detect Parity Error (PE)
3 "l" = Detect Framing Error (FE)
4 "l" = Break Interrupt (BI)
5 Transmitter Holding Register
    "l" = Character Transferred From Holding To Shift
        Register
    "O" = Loading Transmitter Holding Register
6 Transmitter Shift Register Empty
    "l" = Shift Register Idle
    "0" = Data Transfer From Holding Register
7 Always Logical "0"
```

```
Address Description
03FE Modem Status Register
Bit Description
    0 Delta Clear To send (DCTS)
    l Delta Data Set Ready (DDSR)
2 Trailing Edge Ring Indicator
    "l" = On
    "0" = Off
    Delta Received Line Signal Detect (If Bit 0, l, 2,
                or 3 is set to a "1" modem status interrupt is
                generated
    "0" = Clear To Send (CTS)
    "0" = Data Set Ready (DSR)
    "0" = Ring Indicator (RI)
    "0" = Received Line Signal Detect (RLSD)
03FF Reserved
```



TIMING SPECIFICATIONS FOR ROM, DRAM AND SYSTEM TIMING (SH 2 OF 3)


| !T25!ROM access time from | ! | 0 | 200 | !ns | $!$ | ! |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ! !valid SABUS | $!$ |  |  | $!$ | $!$ |  |
| !T26!SABUS delay from ALE |  | 0 | 23 | ! ns | $!$ |  |

## TIMING SPECIFICATIONS FOR IO R/W TIMING (SH 3 OF 3)










NOTES 1. SALE and CONVALE internal signals shoen 2. DIRHLE referance in solid line for 1/0 write cyc dotted line for $1 / 0$ read cycle.
3. Timing shown during $1 / 0$ write cycle.
4. Timing shown during $1 / 0$ read cycle.



























1000 TX Devices

## 1000 TX Devices <br> Contents

| Device | Manufacturer |
| :--- | :--- |
| 82A205 | Chips and Technology |
| 8237A-5 | intel |
| $8254-2$ | intel |
| 8259A | intel |
| 8272 A | intel |
| $80286-8$ | intel |
| $80287-6$ | intel |
|  |  |
| 8250AN | National Semiconductor |
| 8496(Sound) | NCR |
| MCl4529 | Motorola |
| MCl488 | Motorola |
| MCl489 | Motorola |
| Ul9 (I/O Adddress Decode) | Tandy |
| DRAM/DMA Cntl. | Tandy |
| FDC Chip | Tandy |
| Printer Interface | Tandy |
| Keyboard I/F Chip | Universal |
| CPU Cntl. (Nt. Blue) | VTI |

Note: All Intel Chip Specifications are reprinted by permission of Intel Corporation.

Note: All Motorola Chip Specifications are:
Copyright of Motorola, Inc.
and are Used by Permission

## CHIPS

## 82A205 <br> PC/AT COMPATIBLE CHIP

## - Fully IBM $^{\text {™ }}$ PC AT Compatible

- Flexible architecture allows usage in any iAPX 286 design
- 10 or 8 MHz with One Wait State or 6 MHz with Zero Wait State Capability
- 16 Bit to 8 Bit Conversion Logic
- Variable Wait State Selection
- 24 mA sink and -3.3 mA source current for System Bus outputs
- Single 5 Volt Supply
- Complete System Board Memory Decode
- Configurable RAM Selects


Figure 1. PC/AT Block Diagram


## 82A205 Pin Description

| Pin No. | Pin <br> Type | Symbol | Description |
| :--- | :--- | :--- | :--- |

## CHIP's

## 82A205 Pin Description

(Continued)

| Pin No. | Pin Type | Symbol | Description |
| :---: | :---: | :---: | :---: |
| 55 | I | $\overline{\text { MDBEN }}$ | Memory Data Bus Enable is generated by the 82C202. It enables the data bus transceivers connected to the memory devices. |
| 56 | O | PAR | Parity signal, when active, signifies a parity error on a memory read cycle. |
| 59,57 | 1 | MDPOUTO, MDPOUT1 | Memory Data Parity Out 0 and 1 are the parity bits read from the memory banks 0 and 1. They are used to compute the parity during a ready cycle. |
| 60,58 | 0 | MDPINO, MDPIN1 | Memory Data Parity In 0 and 1 are the parity bits written to the memory banks 0 and 1 during a memory write çycle. |

## CHIPS

## Functional Description 82A205

Figure 9 illustrates a TTL equivalent of logic implemented by the 82A205. The chip provides the data bus buffers and drivers for D0-D15. The three data buses controlled are the CPU bus (D0-D15), the System bus (SD0-SD15), and the Memory Data bus (MD0-MD15). The direction and control for these drivers are provided by the DT/ $\overline{\mathrm{R}}, \overline{\mathrm{DSDENO}}, \overline{\mathrm{DSDEN} 1}$, $\overline{X B H E}$, and XAO inputs, as shown in the figure. The low byte to high byte conversion logic is
also implemented on the chip. The conversion logic is controlled by the ENHLB and DIRHLB inputs. The chip also integrates the parity generation and check logic. The parity is computed on the memory data bus signals and output as MDPINO and MDPIN1. During a read cycle, the parity check is computed on the data read from the memory and the parity bits MDPOUT 0 and MDPOUT 1. On a parity error, the PAR output is activated.


Figure 9: 82A205 Functional Block Diagram

## CHIT'

82A205 Absolute Maximum Ratings

| Parameter | Symbol | Min. | Max. | Units |
| :--- | :---: | :--- | :---: | :--- |
| Supply Voltage | $\mathrm{V}_{C C}$ | - | 7.0 | V |
| Input Voltage | $\mathrm{V}_{1}$ | -0.5 | 5.5 | V |
| Output Voltage | $\mathrm{V}_{\mathrm{O}}$ | -0.5 | 5.5 | V |
| Operating Temperature | $\mathrm{T}_{o p}$ | -25 | 85 | C |
| Storage Temperature | $\mathrm{T}_{\text {sig }}$ | -40 | 125 | C |

NOTE: Permanent device damage may occur if Absolute Maximum Ratings are exceeded Functional operation should be restricted to the conditions described under Operating Conditions

## 82A205 Operating Conditions

| Parameter | Symbol | Min. | Max. | Units |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Supply Voltage | $V_{C C}$ | 4.75 | 5.25 | V |
| Ambient Temperature | $\mathrm{T}_{\mathrm{A}}$ | 0 | 70 | C |

82A205 DC Characteristics

| Parameter | Symbol | Min. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ |  | 0.8 | V |
| Input High Voltage | $\mathrm{V}_{1 H}$ | 2.0 |  | V |
| Output Low Voltage $I_{\mathrm{OL}}=10 \mathrm{~mA}$ (Note 1) | $V_{\text {OL1 }}$ |  | 0.5 | V |
| Output Low Voltage $\mathrm{I}_{\mathrm{OL}}=24 \mathrm{~mA}$ (Note 2) | $V_{\text {OL2 }}$ |  | 0.5 | V |
| Output High Voltage $\mathrm{I}_{\mathrm{OH}}=-3.3 \mathrm{~mA}$ (Note 3) | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | V |
| Input Low Current $\mathrm{V}_{1}=0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ | $1 / 1$ |  | -200 | $\mu \mathrm{A}$ |
| Input High Current $V_{1}=2.4 \mathrm{~V}, V_{C C}=5.25 \mathrm{~V}$ | $\mathrm{I}_{\mathrm{H}}$ |  | 20 | $\mu \mathrm{A}$ |
| Input High Current $V_{1}=5.5 \mathrm{~V}, V_{C C}=5.25 \mathrm{~V}$ | 1 |  | 200 | $\mu \mathrm{A}$ |
| Output Short Circuit Current $V_{0}=0 \mathrm{~V}$ | los | -15 | -100 | mA |
| Input Clamp Voltage $I_{1}=-18 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ | $V_{\text {IC }}$ |  | -1.5 | V |
| Power Supply Current | $\mathrm{I}_{\mathrm{CC}}$ | 180 | 300 | mA |
| Output HI-Z Leak Current 3-State Output Pins | $\mathrm{I}_{\mathrm{OZ} 1}$ | -100 | 100 | $\mu \mathrm{A}$ |
| Output HI-Z Leak Current Bidirectional Pins | $\mathrm{I}_{\mathrm{Oz2}}$ | -300 | 120 | $\mu \mathrm{A}$ |

NOTES 1. All non-system and bus outputs only.
2. All system bus outputs,SD0-15, are specified at $\mathrm{I}_{\mathrm{OL}}=24 \mathrm{~mA} @ \mathrm{~V}_{\mathrm{OL}}=0.5 \mathrm{~V}$.
3. All outputs and bidirectional pins.

## CHils

## 82A205 AC Characteristics

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

| Sym | Description | Min. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: |
| $t 1$ | System Data Bus to Memory Bus Delay | 8 | 32 | ns |
| t2 | System Data Bus to CPU Data Bus Delay | 8 | 32 | ns |
| t3 | System Data Bus to Parity Bits MDPIN0, 1 Output | 12 | 42 | ns |
| $t 4$ | CPU Data Bus to Memory Data Bus Delay | 8 | 30 | ns |
| $t 5$ | CPU Data Bus to System Data Bus Delay | 5 | 25 | ns |
| 6 | CPU Data Bus to Parity Bits MDPIN0, MDPIN1 Output | 12 | 42 | ns |
| 77 | Memory Data Bus to CPU Data Bus Delay | 8 | 30 | ns |
| 18 | Memory Data Bus to System Data Bus Delay | 6 | 27 | ns |
| t9 | Memory Data Bus to Parity Bits MDPINO, 1 Output | 10 | 38 | ns |
| 110 | System Data Bus Low Byte to High Byte Conversion | 8 | 32 | ns |
| t11 | System Bus to CPU Data Bus Hi-Lo Byte Conversion | 10 | 33 | ns |
| 112 | System Bus to Mem Data Bus Hi-Lo Byte Conversion | 10 | 35 | ns |
| t13 | XAO to CPU Data Bus Low Byte Delay | 8 | 30 | ns |
| t14 | XA0 to Memory Data Bus $\mathrm{HI}-\mathrm{Z}$ | 6 | 26 | ns |
| t15 | XAO to Memory Data Bus Address Valid | 8 | 30 | ns |
| +16 | XMEMR Going High to Parity Delay | 7 | 28 | ns |
| +17 | $\overline{\text { PAREN }}$ to Parity Delay | 4 | 20 | ns |
| t18 | Parity Input Bits to Parity Output Bits Delay | 12 | 40 | ns |
| 119 | ENHLB to SD8-SD15 delay | - | 30 | ns |
| 120 | SD BUS to CNTLOFF set-up time | 10 |  | ns |

## CriPs



## CHips

## Load Circuit Measurement Conditions

| Parameter | Output Type | Symbol | $\mathbf{C}_{\mathbf{L}}(\mathbf{p F})$ | $\mathbf{R}_{\mathbf{1}}(\Omega)$ | $\mathbf{R}_{\mathbf{L}}(\Omega)$ | $\mathbf{S W}_{\mathbf{1}}$ | $\mathbf{s W}_{\mathbf{2}}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Propagation <br> Delay <br> Time | Totem pole <br> 3-state <br> Bidirectional | $\mathrm{t}_{\mathrm{PLH}}$ | 50 | - | 1.0 K | OFF | ON |
| Propagation | Open drain or <br> Open Collector | $\mathrm{t}_{\mathrm{PLH}}$ | $\mathrm{t}_{\mathrm{PHL}}$ |  |  |  |  |



Figure 10. Load Circuit and AC Characteristics Measurement Waveform

## Crifs

48-PIN PLASTIC DUAL-IN-LINE PACKAGE
UNIT (mm)



## CHIP'S

84-PIN PLASTIC LEADED CHIP CARRIER


UNIT (mm)


## Ordering Information

| Order Number | Package Type <br> Note 1 | Remarks |
| :--- | :--- | :--- |
| P82C201, P82C201-10 | PLCC-84 | C (Note 2) |
| P82C202 | PDIP-48 | C |
| P82A203 | PLCC-68 | C |
| P82A204 | PLCC-68 | C |
| P82A205 | PLCC-68 | C |
| CS8220 | - | Standard CHIPSet (Note 3) |
| CS8220-10 | - | $10 \mathrm{MHz} \mathrm{CHIPSet} \mathrm{(Note} \mathrm{4)}$ |

## NOTES

1. PLCC $=$ Plastic Leaded Chip Carrier 84 Pins

PDIP = Plastic Dual-In-Line Package 48 Pins
2. $\mathrm{C}=$ Commercial Range, 0 to $70^{\circ} \mathrm{C}, V_{D D}=4.75$ to 5.25 V
3. CS8220 consists of P82C201, P82C202, P82A203, P82A204, P82A205
4. CS8220-10 consists of P82C201-10, P82C202, P82A203, P82A204, P82A205

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

\author{

- Enable/Disable Control of Individual DMA Requests <br> - Four Independent DMA Channels <br> - Independent Autoinitiallzation of All Channels <br> - Memory-to-Memory Transfers <br> - Memory Block Initialization <br> ■ Address Increment or Decrement <br> - High Performance: Transfers up to 1.6M 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
- Available In EXPRESS - Standard Temperature Range
- Avallable in 40-Lead Cerdip and Plastic Packages
(See Packaging Spec, Order 231369)

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 latch. 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 8273A-4 and 8237A-5 are 4 MHz and 5 MHz versions of the standard 3 MHz 8237 A respectively.


Figure 1. Block Diagram

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

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ |  | POWER: +5 V supply. |
| $\mathrm{V}_{\text {S }}$ |  | GROUND: Ground. |
| 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. |
| CS | 1 | CHIP SELECT: Chip Select is an active low input used to select the 8237A as an I/O 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 first/ last flip/flop and sets the Mask register. Following a Reset the device is in the idle cycle. |
| 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 setup/hold time. |
| 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, DREQO 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 initializes these lines to active high. DREC must be maintained until the corresponding DACK goes active. |
| DB0-DB7 | 1/0 | DATA BUS: The Data Bus lines are bidirectional 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 register 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 strobed into an external latch by ADSTB. In memory-to-memory operations, data from the memory comes into the 8237A on the data bus during the read-frommemory transfer. In the write-to-memory transfer, the data bus outputs place the data into the new memory location. |
| IOR | 1/0 | I/O READ: I/O Read is a bidirectional active low three-state line. In the ldle 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. |
| Iow | 1/0 | I/O WRITE: I/O Write is a bidirectional active low three-state line. In the Idle cycle, it is an input control signal 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 peripheral during a DMA Read transfer. |

Table 1. Pin Description (Continued)

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| 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 signal to terminate an active DMA service. This is accomplished by pulling the EOP input low with an external EOP 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 EOP 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 for the currently active channel by EOP 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. EOP should be tied high with a pull-up resistor if it is not used to prevent erroneous end of process inputs. |
| 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. |
| A4-A7 | 0 | ADDRESS: The four most significant address lines are three-state outputs and provide 4 bits of address. These lines are enabled only during the DMA service. |
| HRQ | 0 | HOLD REQUEST: This is the Hold Request to the CPU and is used to request control of the system bus. If the corresponding mask bit is clear, the presence of any valid DREQ causes 8237A to issue the HRQ. |
| DACKO-DACK3 | 0 | DMA ACKNOWLEDGE: DMA Acknowledge is used to notify the individual peripherals when one has been granted a DMA cycle. The sense of these lines is programmable. Reset initializes them to active low. |
| AEN | 0 | ADDRESS ENABLE: Address Enable enables the 8 -bit latch containing the upper 8 address bits onto the system address bus. AEN can also be used to disable other system bus drivers during DMA transfers. AEN is active HIGH. |
| ADSTB | 0 | ADDRESS STROBE: The active nigh, Address Strobe is used to strobe the upper address byte into an external latch. |
| $\overline{\text { MEMR }}$ | 0 | MEMORY READ: The Memory Read signal is an active low threestate output used to access data from the selected memory location during a DMA Read or a memory-to-memory transfer. |
| $\overline{\text { MEMW }}$ | 0 | MEMORY WRITE: The Memory Write is an active low three-state output used to write data to the selected memory location during a DMA Write or a memory-to-memory transfer. |

## 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 | 8ize | 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 be the $\phi 2$ TTL clock from an 8224 or CLK from an 8085AH or 8284A. 33\% duty cycle clock generators, however, may not meet the clock high time requirement of the 8237A of the same frequency. For example, 82C84A-5 CLK output violates the clock high time requirement of 8237A-5. In this case 82C84A CLK can simply be inverted to meet 8237A-5 clock high and low time requirements. For 8085AH-2 systems above 3.9 MHz , the 8085 CLK(OUT) does not satisfy 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 (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 SO (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 transfer 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 I/O device to memory (or vice versa) with $\overline{\mathrm{IOR}}$ and $\overline{\text { MEMW (or MEMR and IOW) being ac- }}$ tive at the same time. The data is not read into or driven out of the 8237A in 1/O-to-memory or memo-ry-to-I/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, S12, S13, S14) are used for the read-from-memory half and the last four states (S21, S22, $\mathrm{S} 23, \mathrm{~S} 24$ ) for the write-to-memory half of the transfer.

## IDLE CYCLE

When no channel is requesting service, the 8237A will enter the Idle cycle and perform "S1" 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 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 AO-A3 are inputs to the device and select which registers will be read or written. The TOR and TOW 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 additional bit of address. This bit is used to determine the upper or lower byte of the 16-blt Address and Word Count registers. The flip-flop is reset by Master Clear or Reset. A separate software command can also reset this flip-flop.

Special software commands can be executed by the 8237A in the Program Condition. These commands are decoded as sets of addresses with the CS and 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 nonmasked channel requests a DMA service, the device will output an HRQ to the microprocessor and enter the Active cycle. It is in this cycle 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 decremented or incremented following each transfer. 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 until 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 receipt 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 Transfor Mode-In Block Transfer mode the device is activated by DREQ to continue making transfers during the service until 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 until 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 re-established 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. EOP is generated either by TC or by an external signal. DREQ has to be low before S4 to prevent another Transfer.

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


Figure 4. Cascaded 8237As
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 level. Additional devices can also be added by cascading into the channels of the second level device, forming a third level.

## TRANSFER TYPES

Each of the three active transfer modes can perform three different types of transfers. These are Read, Write and Verify. Write transfers move data from an I/O device to the memory by activating MEMW and $\overline{\text { IOR. Read transfers move data from memory to an }}$ I/O device by activating $\overline{M E M R}$ and $\overline{\mathrm{OWW}}$. 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-to-memory transfer feature. Programming a bit in the Command register selects channels 0 and 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 transfer 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 transfers. This allows a single word to be written to a block of memory.

The 8237A will respond to external $\overline{\mathrm{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 transfers 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 Autoinitialize 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 interfering with that service until it is completed.

After completion of a service, HRQ will go inactive and the 8237A will wait for HLDA to go low before activating HRQ to service another channel.

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 recognized after no more than three higher priority services have occurred. This prevents any one channei 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 S2 to change the address and state S4 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 S1 is used to output the higher order address bits to an external latch from which they may be placed on the address bus. The falling 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 three-state enable. The lower order address bits are output by the 8237A directly. Lines AO-A7 should be connected to the address bus. Figure 11 shows the time relationships between CLK, AEN, ADST8, DB0-DB7 and $\mathrm{AO}-\mathrm{A} 7$.

During Block and Demand Transfer mode services, which include multiple transfers, the addresses generated will be sequential. For many transfers 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 transfers, a savings of 255 clock cycles for 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 EOP.

Current Word Register-Each channel has a 16bit 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 FFFFFH, 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 EOP occurs. If it is not Autoinitialized, this register will have a count of FFFFH after TC.

Base Address and Base Word Count RegistersEach 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 channel 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 non-maskable and subject to prioritization by the Priority Encoder network. Each register bit is set or reset separately under software control or is cleared upon generation of a TC or external EOP. 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.

Command Register


Mode Reglster


## Request Register



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 | Signals |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  | CS | IOR | IOW | A3 | A2 A1 | A0 |
| Command |  | 0 | 1 | 0 | 1 | 0 | 0 | 0 |
| Mode |  | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
| Request |  | 0 | 1 | 0 | 1 | 0 | 0 | 1 |
| Mask |  | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| Mask |  | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| Temporary |  | 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 chan-


231466-10
nels have pending DMA requests. Bits $0-3$ are set every time a TC is reached by that channel or an external EOP is applied. These bits are cleared upon Reset and on each Status Read. Bits 4-7 are set whenever their corresponding channel is requesting service.

Temporary Register-The Temporary register is used to hold data during memory-to-memory transfers. 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 must be executed prior to writing or reading new address or word count information to the 8237A. This initializes the flip-flop to a known state so that subsequent accesses to register 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-Flop 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.

| Signals |  |  |  |  |  | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A3 | A2 | A1 | AO | $\overline{\text { IOR }}$ | IOW |  |
| 1 | 0 | 0 | 0 | 0 | 1 | Read Status Register |
| 1 | 0 | 0 | 0 | 1 | 0 | Write Command Register |
| 1 | 0 | 0 | 1 | 0 | 1 | Illegal |
| 1 | 0 | 0 | 1 | 1 | 0 | Write Request Register |
| 1 | 0 | 1 | 0 | 0 | 1 | tilegal |
| 1 | 0 | 1 | 0 | 1 | 0 | Write Single Mask Register Bit |
| 1 | 0 | 1 | 1 | 0 | 1 | Illegal |
| 1 | 0 | 1 | 1 | 1 | 0 | Write Mode Register |
| 1 | 1 | 0 | 0 | 0 | 1 | Illegal |
| 1 | 1 | 0 | 0 | 1 | 0 | Clear Byte Pointer Flip/Flop |
| 1 | 1 | 0 | 1 | 0 | 1 | Read Temporary Register |
| 1 | 1 | 0 | 1 | 1 | 0 | Master Clear |
| 1 | 1 | 1 | 0 | 0 | 1 | Illegal |
| 1 | 1 | 1 | 0 | 1 | 0 | Clear Mask Register |
| 1 | 1 | 1 | 1 | 0 | 1 | lliegal |
| 1 | 1 | 1 | 1 | 1 | 0 | Write All Mask Register Bits |

Figure 6. Software Command Codes


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 if a DMA request occurs, on an unmasked channel while the 8237A 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. An invalid mode may force all control signals to go active at the same time.

## APPLICATION INFORMATION(1)

Figure 8 shows a convenient method for configuring a DMA system with the 8237A controller and an 8080A/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 an 8 -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 significant address byte. Four DMA channels are provided when one 8237A is used.


Figure 8. 8237A System Interface

## NOTE:

1. See Application Note AP-67 for 8086 design information.

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature under Bias $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Case Temperature . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin with
Respect to Ground. . . . . . . . . . . . . . -0.5 V to +7 V
Power Dissipation
1.5 Watt
*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

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, T_{\text {CASE }}=0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 5 \%, \mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min | Typ(1) | Max | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
|  |  | 3.3 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ (HRQ Only) |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage |  |  | 0.40 | V | $\mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input HIGH Voltage | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V | (Note 8$)$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Voltage | -0.5 |  | 0.8 | V |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current |  |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LO}}$ | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0.45 \mathrm{~V} \leq \mathrm{V}_{\mathrm{OUT}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{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}_{\mathrm{O}}$ | Output Capacitance |  | 4 | 8 | pF |  |
| $\mathrm{C}_{\mathrm{I}}$ | Input Capacitance |  | 8 | 15 | pF |  |
| $\mathrm{C}_{\mathrm{IO}}$ | I/O Capacitance |  | 10 | 18 | pF |  |

A.C. CHARACTERISTICS-DMA (MASTER) MODE
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{T}_{\text {CASE }}=0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | 8237A |  | 8237A-4 |  | 8237A-5 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | M ${ }^{\prime}$ n | 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 |  |  | 150 |  | 120 |  | 120 | ns |
| TAFDB | DB Active to Float Delay from CLK HIGH |  | 250 |  | 190 |  | 170 | ns |
| TAHR | ADR from $\overline{\text { PEAD HIGH Hold Time }}$ | TCY-100 |  | TCY-100 |  | TCY-100 |  | ns |
| TAHS | DB from ADSTB LOW Hold Time | 40 |  | 40 |  | 30 |  | ns |
| TAHW | ADR from WRITE HIGH Hold Time | TCY-50 |  | TCY-50 |  | TCY-50 |  | ns |
| TAK | DACK Valid from CLK LOW Delay Time (Note 7) |  | 250 |  | 220 |  | 170 | ns |
|  | 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 $\leq 10 \mathrm{~ns}$ ) | 120 |  | 100 |  | 80 |  | ns |
| TCL | Clock LOW Time (Transitions $\leq 10 \mathrm{~ns}$ ) | 150 |  | 110 |  | 68 |  | ns |
| TCY | CLK Cycle Time | 320 |  | 250 |  | 200 |  | ns |
| TDCL | CLK HIGH to $\overline{\text { READ }}$ or WRITE LOW Delay (Note 4) |  | 270 |  | 200 |  | 190 | ns |
| TDCTR | READ HIGH from CLK HIGH <br> (S4) Delay Time (Note 4) |  | 270 |  | 210 |  | 190 | ns |
| TOCTW | WRITE HIGH from CLK HIGH <br> (S4) Delay Time (Note 4) |  | 200 |  | 150 |  | 130 | ns |
| TDQ1 | HRQ Valid from CLK HIGH Delay Time (Note 5) |  | 160 |  | 120 |  | 120 | ns |
| TDQ2 |  |  | 250 |  | 190 |  | 120 | ns |
| TEPS | EOP LOW from CLK LOW Setup Time | 60 |  | 45 |  | 40 |  | ns |
| TEPW | EOP Pulse Width | 300 |  | 225 |  | 220 |  | ns |
| TFAAB | ADR Float to Active Delay from CLK HIGH |  | 250 |  | 190 |  | 170 | ns |
| TFAC | 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 MEMR HIGH Hold Time | 0 |  | 0 |  | 0 |  | ns |
| TIDS | Input Data to MEMR HIGH Setup Time | 250 |  | 190 |  | 170 |  | ns |
| TODH | Output Data from MEMW HIGH Hold Time | 20 |  | 20 |  | 10 |  | ns |
| TODV | Output Data Valid to MEMW HIGH | 200 |  | 125 |  | 125 |  | ns |
| TQS | 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 |

A.C. CHARACTERISTICS--PERIPHERAL (SLAVE) MODE
$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{T}_{\text {CASE }}=0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | 8237A |  | 8237A-4 |  | 8237A-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| TAR | ADR Valid or $\overline{C S}$ LOW to $\overline{\text { READ }}$ LOW | 50 |  | 50 |  | 50 |  | ns |
| TAW | ADR 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{R E A D}$ LOW (Note 12) |  | 200 |  | 200 |  | 140 | ns |
| TRDF | DB Float Delay from $\overline{\text { 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 IOWR | 2TCY |  | 2TCY |  | 2 TCY |  | ns |
| TRSTW | RESET Pulse Width | 300 |  | 300 |  | 300 |  | ns |
| TRW | 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 |
| TWR | End of Write to End of Read in DMA Transfer | 0 |  | 0 |  | 0 |  | ns |

## NOTES:

1. Typical values are for $T_{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 otherwise noted.
3. Output loading is 1 TTL gate plus 150 pF capacitance, unless otherwise noted.
4. The net IOW or MEMW Pulse width for normal write will be TCY-100 ns and for extended write will be $2 T C Y-100 \mathrm{~ns}$. The net $\overline{I O R}$ or MEMR pulse width for normal read will be $2 T C Y-50$ ns and for compressed read will be TCY-50 ns.
5. TDQ is specified for two different output HIGH levels. TDQ1 is measured at 2.0V. TDQ2 is measured at 3.3V. The value for TDQ2 assumes an external $3.3 \mathrm{~K} \Omega$ pull-up resistor connected from HRQ to $V_{C C}$.
6. DREQ shouid 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. 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 8237A, at least 500 ns for the 8237A-4 and at least 400 ns for the 8237A-5, as recovery time between active read or write pulses. The same recovery time is needed between an active read or write pulse followed by a DMA transfer.
9. $\overline{\text { EOP }}$ is an open collector output. This parameter assumes the presence of a 2.2 K pullup to $\mathrm{V}_{\mathrm{CC}}$.
10. Pin 5 is an input that should always be at a logic high level. An internal pull-up resistor will establish a logic high when the pin is left floating. It is recommended however, that pin 5 be tied to $V_{\mathrm{CC}}$.
11. Output Loading on the Data Bus is 1 TTL Gate plus 100 pF capacitance.
A.C. TESTING INPUT/OUTPUT WAVEFORM

A.C. Testing: Inputs are driven at 2.4 V for a Logic " 1 " and 0.45 V for a Logic " 0 ." Timing measurements are made at 2.0 V for a Logic " 1 " and 0.8 V for a Logic " 0 ." (Note 2)

## WAVEFORMS

SLAVE MODE WRITE TIMING


231466-13
Figure 9. Slave Mode Write

SLAVE MODE READ TIMING


Figure 10. Slave Mode Read

WAVEFORMS (Continued)
DMA TRANSFER TIMING


Figure 11. DMA Transfer

WAVEFORMS (Contirued)
MEMORY-TO-MEMORY TRANSFER TIMING


Figure 12. Memory-to-Memory Transfer

READY TIMING


Figure 13. Ready

## WAVEFORMS (Continued)

COMPRESSED TRANSFER TIMING


Figure 14. Compressad Transfer

## RESET TIMING



Figure 15. Reset

## 8254 <br> PROGRAMMABLE INTERVAL TIMER

## - Compatible with All Intel and Most Other Microprocessors

- Handles Inputs from DC to 10 MHz
- 5 MHz 8254-5
- 8 MHz 8254
- 10 MHz 8254-2
- Six Programmable Counter Modes
- Three Independent 16-Bit Counters
- Binary or BCD Counting
n Single +5 V Supply
- Available in EXPRESS - Standard Temperature Range

The intel ${ }^{\circ} 8254$ is a counter/timer device designed to solve the common timing control problems in microcomputer system design. It provides three independent 16-bit counters, each capabie of handling clock inputs up to 10 MHz . All modes are software programmable. The 8254 is a superset of the 8253.

The 8254 uses HMOS technology and comes in a 24-pin plastic or CERDIP package.


Figure 2. Pin Configuration

231164-2


Figure 1. 8254 Block Dlagram

Table 1. Pin Description

| Symbol | Pin <br> No. | Type | Name and Function |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | 1-8 | 1/O | DATA: Bi-directional three state data bus lines, connected to system data bus. |  |  |
| CLK 0 | 9 | 1 | CLOCK 0: Clock input of Counter 0. |  |  |
| OUT 0 | 10 | 0 | OUTPUT 0: Output of Counter 0 . |  |  |
| GATE 0 | 11 | 1 | GATE 0: Gate input of Counter 0. |  |  |
| GND | 12 |  | GROUND: Power supply connection. |  |  |
| $\mathrm{V}_{\text {CC }}$ | 24 |  | POWER: +5 V power supply connection. |  |  |
| $\overline{\mathrm{WR}}$ | 23 | 1 | WRITE CONTROL: This input is low during CPU write operations. |  |  |
| $\overline{\text { RD }}$ | 22 | 1 | READ CONTROL: This input is low during CPU read operations. |  |  |
| CS | 21 | I | CHIP SELECT: A low on this input enables the 8254 to respond to $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ signals. $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ are ignored otherwise. |  |  |
| $\mathrm{A}_{1}, \mathrm{~A}_{0}$ | 20-19 | 1 | ADDRESS: Used to select one of the three Counters or the Control Word Register for read or write operations. Normally connected to the system address bus. |  |  |
|  |  |  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ | Selects |
|  |  |  | 0 <br> 0 <br> 1 <br> 1 | 0 <br> 1 <br> 0 <br> 1 | Counter 0 <br> Counter 1 <br> Counter 2 <br> Control Word Register |
| CLK 2 | 18 | 1 | CLOCK 2: Clock input of Counter 2. |  |  |
| OUT 2 | 17 | 0 | OUT 2: Output of Counter 2. |  |  |
| GATE 2 | 16 | 1 | GATE 2: Gate input of Counter 2. |  |  |
| CLK 1 | 15 | 1 | CLOCK 1: Clock input of Counter 1. |  |  |
| GATE 1 | 14 | 1 | GATE 1: Gate input of Counter 1. |  |  |
| OUT 1 | 13 | 0 | OUT 1: Output of Counter 1. |  |  |

## FUNCTIONAL DESCRIPTION

## General

The 8254 is a programmable interval timer/counter designed for use with Intel microcomputer systems. It is a general purpose, multi-timing element that can be treated as an array of I/O ports in the system software.

The 8254 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 software, the programmer configures the 8254 to match his requirements and programs one of the counters for the desired delay. After the desired delay, the 8254 will interrupt the CPU. Software overhead is minimal and variable length delays can easily be accommodated.

Some of the other counter/timer functions common to microcomputers which can be implemented with the 8254 are:

- Real time clock
- Event-counter
- Digital one-shot
- Programmable rate generator
- Square wave generator
- Binary rate multiplier
- Complex waveform generator
- Complex motor controller


## Block Diagram

## DATA BUS BUFFER

This 3-state, bi-directional, 8-bit buffer is used to interface the 8254 to the system bus (see Figure 3).


Figure 3. Block Diagram Showing Data Bus Buffer and Read/Write Logic Functions

## READ/WRITE LOGIC

The Read/Write Logic accepts inputs from the system bus and generates control signals for the other functional blocks of the 8254. $A_{1}$ and $A_{0}$ select one of the three counters or the Control Word Register to be read from/written into. A "low" on the $\overline{R D}$ input tells the 8254 that the CPU is reading one of the counters. A "low" on the WR input tells the 8254 that the CPU is writing either a Control Word or an initial count. Both $\overline{R D}$ and $\overline{W R}$ are qualified by $\overline{\mathrm{CS}}$; $\overline{\mathrm{RD}}$ and $\overline{W R}$ are ignored unless the 8254 has been selected by holding $\overline{\mathrm{CS}}$ low.

## CONTROL WORD REGISTER

The Control Word Register (see Figure 4) is selected by the Read/Write Logic when $A_{1}, A_{0}=11$. If the CPU then does a write operation to the 8254, the data is stored in the Control Word Register and is interpreted as a Control Word used to define the operation of the Counters.

The Control Word Register can only be written to; status information is available with the Read-Back Command.

## COUNTER 0, COUNTER 1, COUNTER 2

These three functional blocks are identical in operation, so only a single Counter will be described. The internal block diagram of a single counter is shown in Figure 5.

The Counters are fully independent. Each Counter may operate in a different Mode.

The Control Word Register is shown in the figure; it is not part of the Counter itself, but its contents determine how the Counter operates.

The status register, shown in Figure 5, when latched, contains the current contents of the Control Word Register and status of the output and null count flag. (See detailed explanation of the ReadBack command.)

The actual counter is labelled CE (for "Counting Element"). It is a 16 -bit presettable synchronous down counter.

OLM and OLL $L_{L}$ are two 8 -bit latches. OL stands for "Output Latch"; the subscripts $M$ and $L$ stand for "Most significant byte" and "Least significant byte"


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


231164-5
Figure 5. Internal Block Diagram of a Counter
respectively. Both are normally referred to as one unit and called just OL. These latches normally "follow" the CE, but if a suitable Counter Latch Command is sent to the 8254, the latches "latch" the present count until read by the CPU and then return to "following" the CE. One latch at a time is enabled by the counter's Control Logic to drive the internal bus. This is how the 16 -bit Counter communicates over the 8 -bit internal bus. Note that the CE itself cannot be read; whenever you read the count, it is the OL that is being read.

Similarly, there are two 8 -bit registers called $\mathrm{CR}_{M}$ and $\mathrm{CR}_{\mathrm{L}}$ (for "Count Register"). Both are normally referred to as one unit and called just CR. When a new count is written to the Counter, the count is stored in the CR and later transferred to the CE. The Control Logic allows one register at a time to be loaded from the internal bus. Both bytes are transferred to the CE simultaneously. $\mathrm{CR}_{M}$ and $\mathrm{CR}_{\mathrm{L}}$ are cleared when the Counter is programmed. In this way, if the Counter has been programmed for one byte counts (either most significant byte only or least significant byte only) the other byte will be zero. Note that the CE cannot be written into; whenever a count is written, it is written into the CR.

The Control Logic is also shown in the diagram. CLK $n$, GATE $n$, and OUT $n$ are all connected to the outside world through the Control Logic.

## 8254 SYSTEM INTERFACE

The 8254 is a component of the Intel Microcomputer Systems and interfaces in the same manner as all
other peripherals of the family. It is treated by the system's 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 $A_{0}, A_{1}$ connect to the $A_{0}$, $A_{1}$ address bus signals of the CPU. The CS can be derived directly from 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.

## OPERATIONAL DESCRIPTION

## General

After power-up, the state of the 8254 is undefined. The Mode, count value, and output of all Counters are undefined.

How each Counter operates is determined when it is programmed. Each Counter must be programmed before it can be used. Unused counters need not be programmed.

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

Counters are programmed by writing a Control Word and then an initial count.

The Control Words are written into the Control Word Register, which is selected when $A_{1}, A_{0}=11$. The Control Word itself specifies which Counter is being programmed.


Figure 6. 8254 System Interface

Control Word Format
$A_{1}, A_{0}=11 \quad \overline{C S}=0 \quad \overline{\mathrm{RD}}=1 \quad \overline{\mathrm{WR}}=0$

|  |  |  | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $D_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SC1 | SC0 | RW1 | RW0 | M2 | M1 | M0 | BCD |  |  |
| SC-Select Counter |  |  |  |  |  |  | $\begin{gathered} \text { M-Mode } \\ \text { M2 } \end{gathered}$ |  | M1 M0 |  |  |  |
|  |  | 0 | Select Counter 0 |  |  |  | 0 |  | 0 |  | 0 | Mode 0 |
| 0 |  | 1 | Select Counter 1 |  |  |  | 0 |  | 0 |  | 1 | Mode 1 |
| 1 |  | 0 | Select Counter 2 |  |  |  | X |  |  | 1 | 0 | Mode 2 |
|  |  | 1 | Read-Back Command (see Read Operations) |  |  |  | X |  |  | 1 | 1 | Mode 3 |
|  |  |  |  |  |  |  | 1 |  |  | 0 | 0 | Mode 4 |
|  |  |  |  |  |  |  | 1 |  |  | 0 | 1 | Mode 5 |
| RW-Read/Write RW1 RW0 |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | Counter Latch Command (see Read Operations) |  |  |  |  | 0 |  | Binary | Count | 6-bi |  |
| 0 | 1 | Read | least sign | ficant | byte only |  | 1 |  | Bina | Coded | ecima | Counter |
| 1 | 0 | Read | most sign | ificant | byte only |  |  |  |  |  |  |  |
| 1 | 1 | Read then | least sign significant | ficant byte | byte firs |  |  |  |  |  |  |  |
| NOTE: <br> Don't care bits $(X)$ should be 0 to insure compatibility with future Intel products. |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 7. Control Word Format

By contrast, initial counts are written into the Counters, not the Control Word Register. The $A_{1}, A_{0}$ inputs are used to select the Counter to be written into. The format of the initial count is determined by the Control Word used.

## Write Operations

The programming procedure for the 8254 is very flexible. Only two conventions need to be remembered:

1) For each Counter, the Control Word must be written before the initial count is written.
2) The initial count must follow the count format specified in the Control Word (least significant byte only, most significant byte only, or least significant byte and then most significant byte).

Since the Control Word Register and the three Counters have separate addresses (selected by the $A_{1}, A_{0}$ inputs), and each Control Word specifies the Counter it applies to (SC0,SC1 bits), no special instruction sequence is required. Any programming sequence that follows the conventions in Figure 7 is acceptable.

A new initial count may be written to a Counter at any time without affecting the Counter's programmed Mode in any way. Counting will be affected as described in the Mode definitions. The new count must follow the programmed count format.

If a Counter is programmed to read/write two-byte counts, the following precaution applies: A program must not transfer control between writing the first and second byte to another routine which also writes into that same Counter. Otherwise, the Counter will be loaded with an incorrect count.

|  | $A_{1}$ | $\mathrm{A}_{0}$ |  | $\mathrm{A}_{1}$ | $A_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Control Word-Counter 0 | 1 | 1 | Control Word-Counter 2 | 1 | 1 |
| LSB of count-Counter 0 | 0 | 0 | Control Word-Counter 1 | 1 | 1 |
| MSB of count-Counter 0 | 0 | 0 | Control Word-Counter 0 | 1 | 1 |
| Control Word-Counter 1 | 1 | 1 | LSB of count-Counter 2 | 1 | 0 |
| LSB of count-Counter 1 | 0 | 1 | MSB of count-Counter 2 | 1 | 0 |
| MSB of count-Counter 1 | 0 | 1 | LSB of count-Counter 1 | 0 | 1 |
| Control Word-Counter 2 | 1 | 1 | MSB of count-Counter 1 | 0 | 1 |
| LSB of count-Counter 2 | 1 | 0 | LSB of count-Counter 0 | 0 | 0 |
| MSB of count-Counter 2 | 1 | 0 | MSB of count-Counter 0 | 0 | 0 |
|  | $A_{1}$ | $A_{0}$ |  | $A_{1}$ | $A_{0}$ |
| Control Word--Counter 0 | 1 | 1 | Control Word-Counter 1 | 1 | 1 |
| Control Word--Counter 1 | 1 | 1 | Control Word-Counter 0 | 1 | 1 |
| Control Word-Counter 2 | 1 | 1 | LSB of count-Counter 1 | 0 | 1 |
| LSB of count-Counter 2 | 1 | 0 | Control Word-Counter 2 | 1 | 1 |
| LSB of count-Counter 1 | 0 | 1 | LSB of count-Counter 0 | 0 | 0 |
| LSB of count-Counter 0 | 0 | 0 | MSB of count-Counter 1 | 0 | 1 |
| MSB of count-Counter 0 | 0 | 0 | LSB of count-Counter 2 | 1 | 0 |
| MSB of count-Counter 1 | 0 | 1 | MSB of count-Counter 0 | 0 | 0 |
| MSB of count-Counter 2 | 1 | 0 | MSB of count-Counter 2 | 1 | 0 |

## NOTE:

In all four examples, all Counters are programmed to read/write two-byte counts. These are only four of many possible programming sequences.

Figure 8. A Few Possible Programming Sequences

## Read Operations

It is often desirable to read the value of a Counter without disturbing the count in progress. This is easily done in the 8254 .

There are three possible methods for reading the counters: a simple read operation, the Counter Latch Command, and the Read-Back Command. Each is explained below. The first method is to perform a simple read operation. To read the Counter, which is selected with the A1, A0 inputs, the CLK input of the selected Counter must be inhibited by using either the GATE input or external logic. Otherwise, the count may be in the process of changing when it is read, giving an undefined result.

## COUNTER LATCH COMMAND

The second method uses the "Counter Latch Command". Like a Control Word, this command is written to the Control Word Register, which is selected when $A_{1}, A_{0}=11$. Also like a Control Word, the SC0, SC1 bits select one of the three Counters, but two other bits, D5 and D4, distinguish this command from a Control Word.


| $\mathbf{D}_{\mathbf{7}}$ | $\mathbf{D}_{6}$ | $\mathbf{D}_{\mathbf{5}}$ | $\mathbf{D}_{\mathbf{4}}$ | $\mathbf{D}_{\mathbf{3}}$ | $\mathbf{D}_{\mathbf{2}}$ | $\mathbf{D}_{\mathbf{1}}$ | $\mathbf{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC 1 | SC 0 | 0 | 0 | X | X | X | X |

SC1,SCO—specify counter to be latched

| SC1 |
| :---: | | 0 | 0 | Counter |
| :---: | :---: | :---: |
| 0 | 1 | 0 |
| 1 | 0 | 1 |
| 1 | 1 | Read-Back Command |

D5,D4-00 designates Counter Latch Command
X-don't care

## NOTE:

Don't care bits ( X ) should be 0 to insure compatibility with future intel products.

Flgure 9. Counter Latching Command Format

The selected Counter's output latch (OL) latches the count at the time the Counter Latch Command is received. This count is held in the latch until it is read by the CPU (or until the Counter is reprogrammed). The count is then unlatched automatically and the OL returns to "following" the counting element (CE). This allows reading the contents of the Counters "on the fly" without affecting counting in progress. Multiple Counter Latch Commands may be used to latch more than one Counter. Each latched Counter's OL holds its count until it is read. Counter Latch Commands do not affect the programmed Mode of the Counter in any way.

If a Counter is latched and then, some time later, latched again before the count is read, the second Counter Latch Command is ignored. The count read will be the count at the time the first Counter Latch Command was issued.

With either method, the count must be read according to the programmed format; specifically, if the Counter is programmed for two byte counts, two bytes must be read. The two bytes do not have to be read one right after the other; read or write or programming operations of other Counters may be inserted between them.

Another feature of the 8254 is that reads and writes of the same Counter may be interleaved; for example, if the Counter is programmed for two byte counts, the following sequence is valid.

1) Read least significant byte.
2) Write new least significant byte.
3) Read most significant byte.
4) Write new most significant byte.

If a Counter is programmed to read/write two-byte counts, the following precaution applies: A program must not transfer control between reading the first and second byte to another routine which also reads from that same Counter. Otherwise, an incorrect count will be read.

## READ-BACK COMMAND

The third method uses the Read-Back Command. This command allows the user to check the count value, programmed Mode, and current states of the OUT pin and Null Count flag of the selected counter(s).

The command is written into the Control Word Register and has the format shown in Figure 10. The command applies to the counters selected by setting their corresponding bits D3, D2, D1 $=1$.

$\mathrm{D}_{5}: 0=$ Latch count of selected counter(s)
$\mathrm{D}_{4}: 0=$ Latch status of selected counters(s)
$\mathrm{D}_{3}: 1=$ Select Counter 2
$D_{2}: 1=$ Select Counter 1
$\mathrm{D}_{1}: 1=$ Select Counter 0
$D_{0}$ : Reserved for future expansion; Must be 0
Figure 10. Read-Back Command Format
The read-back command may be used to latch multiple counter output latches (OL) by setting the COUNT bit D5 $=0$ and selecting the desired counter(s). This single command is functionally equivalent to several counter latch commands, one for each counter latched. Each counter's latched count is held until it is read (or the counter is reprogrammed). The counter is automatically unlatched when read, but other counters remain latched until they are read. If multiple count read-back commands are issued to the same counter without reading the count, all but the first are ignored; i.e., the count which will be read is the count at the time the first read-back command was issued.

The read-back command may also be used to latch status information of selected counter(s) by setting STATUS bit D4 $=0$. Status must be latched to be read; status of a counter is accessed by a read from that counter.

The counter status format is shown in Figure 11. Bits D5 through D0 contain the counter's programmed Mode exactly as written in the last Mode Control Word. OUTPUT bit D7 contains the current state of the OUT pin. This allows the user to monitor the counter's output via software, possibly eliminating some hardware from a system.


Figure 11. Status Byte

NULL COUNT bit D6 indicates when the last count written to the counter register (CR) has been loaded into the counting element (CE). The exact time this happens depends on the Mode of the counter and is described in the Mode Definitions, but until the count is loaded into the counting element (CE), it can't be read from the counter. If the count is latched or read before this time, the count value will not reflect the new count just written. The operation of Null Count is shown in Figure 12.

## This Action

Causes
A. Write to the control word register; (1) Null Count $=1$
B. Write to the count register (CR); (2) Null Count $=1$
C. New Count is loaded into Null Count $=0$

$$
C E(C R \rightarrow C E) ;
$$

## NOTE:

1. Only the counter specified by the control word will have its Null Count set to 1. Null count bits of other counters are unaffected.
2. If the counter is programmed for two-byte counts (least significant byte then most significant byte) Null Count goes to 1 when the second byte is written.

Figure 12. Null Count Operation
If multiple status latch operations of the counter(s) are performed without reading the status, all but the first are ignored; i.e., the status that will be read is the status of the counter at the time the first status read-back command was issued.

Both count and status of the selected counter(s) may be latched simultaneously by setting both
$\overline{\text { COUNT }}$ and STATUS bits D5,D4 $=0$. This is functionally the same as issuing two separate read-back commands at once, and the above discussions apply here also. Specifically, if multiple count and/or status read-back commands are issued to the same counter(s) without any intervening reads, all but the first are ignored. This is illustrated in Figure 13.

If both count and status of a counter are latched, the first read operation of that counter will return latched status, regardless of which was latched first. The next one or two reads (depending on whether the counter is programmed for one or two type counts) return latched count. Subsequent reads return unlatched count.

| $\overline{\mathbf{C S}}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ | $\mathbf{A}_{\mathbf{1}}$ | $\mathbf{A}_{\mathbf{0}}$ |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 1 | 0 | 0 | 0 | Write into Counter 0 |
| 0 | 1 | 0 | 0 | 1 | Write into Counter 1 |
| 0 | 1 | 0 | 1 | 0 | Write into Counter 2 |
| 0 | 1 | 0 | 1 | 1 | Write Control Word |
| 0 | 0 | 1 | 0 | 0 | Read from Counter 0 |
| 0 | 0 | 1 | 0 | 1 | Read from Counter 1 |
| 0 | 0 | 1 | 1 | 0 | Read from Counter 2 |
| 0 | 0 | 1 | 1 | 1 | No-Operation (3-State) |
| 1 | X | X | X | X | No-Operation (3-State) |
| 0 | 1 | 1 | X | X | No-Operation (3-State) |

Figure 14. Read/Write Operatlons Summary

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | Command |  | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | Description | Result |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | Read back count and status of Counter 0 | Count and status latched for Counter 0 |
| 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | Read back status of Counter 1 | Status latched for Counter 1 |
| 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | Read back status of Counters 2, 1 | Status latched for Counter 2, but not Counter 1 |
| 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | Read back count of Counter 2 | Count latched for Counter 2 |
| 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | Read back count and status of Counter 1 | Count latched for Counter 1, but not status |
| 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | Read back status of Counter 1 | Command ignored, status already latched for Counter 1 |

Figure 13. Read-Back Command Example

## Mode Definitions

The following are defined for use in describing the operation of the 8254.
CLK Pulse: a rising edge, then a falling edge, in that order, of a Counter's CL.K input.
Trigger: a rising edge of a Counter's GATE input.
Counter loading: the transfer of a count from the CR to the CE (refer to the "Functiona Description')

## MODE O: INTERRUPT ON TERMINAL COUNT

Mode 0 is typically used for event counting. After the Control Word is written, OUT is initially low, and will remain low until the Counter reaches zero. OUT then goes high and remains high until a new count or a new Mode 0 Control Word is written into the Counter.

GATE $=1$ enables counting; GATE $=0$ disables counting. GATE has no effect on OUT

After the Control Word and initial count are written to a Counter, the initial count will be loaded on the next CLK pulse. This CLK pulse does not decrement the count, so for an initial count of N, OUT does not go high until $N+1$ CLK pulses after the initial count is written.

If a new count is written to the Counter, it will be loaded on the next CLK pulse and counting will continue from the new count. If a two-byte count is written, the following happens:

1) Writing the first byte disables counting. OUT is set low immediately (no clock pulse required)
2) Writing the second byte allows the new count to be loaded on the next CLK pulse.

This allows the counting sequence to be synchronized by software. Again, OUT does not go high until $N+1$ CLK pulses after the new count of $N$ is written.

If an initial count is written while GATE $=0$, it will still be loaded on the next CLK pulse. When GATE goes high, OUT will go high N CLK pulses later; no CLK pulse is needed to load the Counter as this has already been done.

## MODE 1: HARDWARE RETRIGGERABLE ONE-SHOT

OUT will be initially high. OUT will go low on the CLK pulse following a trigger to begin the one-shot pulse, and will remain low until the Counter reaches zero.

OUT will then go high and remain high until the CLK pulse after the next trigger.

After writing the Control Word and initial count, the Counter is armed. A trigger results in loading the Counter and setting OUT low on the next CLK pulse, thus starting the one-shot pulse. An initial count of N will result in a one-shot pulse N CLK cycles in duration. The one-shot is retriggerable, hence OUT will remain low for N CLK pulses after any trigger. The one-shot pulse can be repeated without rewriting the same count into the counter. GATE has no effect on OUT.

If a new count is written to the Counter during a oneshot pulse, the current one-shot is not affected unless the counter is retriggered. In that case, the Counter is loaded with the new count and the oneshot pulse continues until the new count expires.

## MODE 2: RATE GENERATOR

This Mode functions like a divide-by-N counter. It is typically used to generate a Real Time Clock interrupt. OUT will initially be high. When the initial count has decremented to 1 , OUT goes low for one CLK pulse. OUT then goes high again, the Counter reloads the initial count and the process is repeated. Mode 2 is periodic; the same sequence is repeated indefinitely. For an initial count of $N$, the sequence repeats every N CLK cycles.

GATE $=1$ enables counting; GATE $=0$ disables counting. If GATE goes low during an output pulse, OUT is set high immediately. A trigger reloads the Counter with the initial count on the next CLK pulse; OUT goes low N CLK pulses after the trigger. Thus the GATE input can be used to synchronize the Counter.

After writing a Control Word and initial count, the Counter will be loaded on the next CLK pulse. OUT goes low N CLK Pulses after the initial count is written. This allows the Counter to be synchronized by software also.

Writing a new count while counting does not affect the current counting sequence. If a trigger is received after writing a new count but before the end of the current period, the Counter will be loaded with the new count on the next CLK pulse and counting will continue from the new count. Otherwise, the new count will be loaded at the end of the current counting cycle. In mode 2, a COUNT of 1 is illegal.

## MODE 3: SQUARE WAVE MODE

Mode 3 is typically used for Baud rate generation. Mode 3 is similar to Mode 2 except for the duty cycle of OUT. OUT will initially be high. When half the


Figure 15. Mode 0


Figure 16. Mode 1
initial count has expired, OUT goes low for the remainder of the count. Mode 3 is periodic; the sequence above is repeated indefinitely. An initial count of $N$ results in a square wave with a period of N CLK cycles.

GATE $=1$ enables counting; GATE $=0$ disables counting. If GATE goes low while OUT is low, OUT is set high immediately; no CLK pulse is required. A trigger reloads the Counter with the initial count on the next CLK pulse. Thus the GATE input can be used to synchronize the Counter.

After writing a Control Word and initial count, the Counter will be loaded on the next CLK pulse. This allows the Counter to be synchronized by software also.

Writing a new count while counting does not affect the current counting sequence. If a trigger is received after writing a new count but before the end of the current half-cycle of the square wave, the Counter will be loaded with the new count on the next CLK pulse and counting will continue from the


NOTE:
A GATE transition should not occur one clock prior to terminal count.
Figure 17. Mode 2
new count. Otherwise, the new count will be loaded at the end of the current half-cycle.

Mode 3 is implemented as follows:
Even counts: OUT is initially high. The initial count is loaded on one CLK pulse and then is decremented by two on succeeding CLK pulses. When the count expires OUT changes value and the Counter is reloaded with the initial count. The above process is repeated indefinitely.

Odd counts: OUT is initially high. The initial count minus one (an even number) is loaded on one CLK pulse and then is decremented by two on succeeding CLK pulses. One CLK pulse after the count expires, OUT goes low and the Counter is reloaded with the initial count minus one. Succeeding CLK pulses decrement the count by two. When the count expires, OUT goes high again and the Counter is reloaded with the initial count minus one. The above process is repeated indefinitely. So for odd counts, OUT will be high for $(\mathrm{N}+1) / 2$ counts and low for ( $\mathrm{N}-1$ )/2 counts.


NOTE:
A GATE transition should not occur one clock prior to terminal count.
Figure 18. Mode 3

## MODE 4: SOFTWARE TRIGGERED STROBE

OUT will be initially high. When the initial count expires, OUT will go low for one CLK pulse and then go high again. The counting sequence is "triggered" by writing the initial count.

GATE $=1$ enables counting; GATE $=0$ disables counting. GATE has no effect on OUT.

After writing a Control Word and initial count, the Counter will be loaded on the next CLK pulse. This CLK pulse does not decrement the count, so for an
initial count of N , OUT does not strobe low until $\mathrm{N}+$ 1 CLK pulses after the initial count is written.

If a new count is written during counting, it will be loaded on the next CLK pulse and counting will continue from the new count. If a two-byte count is written, the following happens:

1) Writing the first byte has no effect on counting.
2) Writing the second byte allows the new count to be loaded on the next CLK pulse.

This allows the sequence to be "retriggered" by software. OUT strobes low $\mathbf{N}+1$ CLK pulses after the new count of N is written.


Figure 19. Mode 4

## MODE 5: HARDWARE TRIGGERED STROBE (RETRIGGERABLE)

OUT will initially be high. Counting is triggered by a rising edge of GATE. When the initial count has expired, OUT will go low for one CLK pulse and then go high again.

After writing the Control Word and initial count, the counter will not be loaded until the CLK pulse after a trigger. This CLK pulse does not decrement the count, so for an initial count of N, OUT does not strobe low until $\mathbf{N}+1$ CLK pulses after a trigger.

A trigger results in the Counter being loaded with the initial count on the next CLK pulse. The counting sequence is retriggerable. OUT will not strobe low for $N+1$ CLK pulses after any trigger. GATE has no effect on OUT.

If a new count is written during counting, the current counting sequence will not be affected. If a trigger occurs after the new count is written but before the current count expires, the Counter will be loaded with the new count on the next CLK pulse and counting will continue from there.


Figure 20. Mode 5

| Signal Status Modes | $\begin{gathered} \text { Low } \\ \text { Or Golng } \\ \text { Low } \end{gathered}$ | Rising | High |
| :---: | :---: | :---: | :---: |
| 0 | Disables Counting | - - | Enables Counting |
| 1 | - - | 1) Initiates Counting <br> 2) Resets Output after Next Clock | -- |
| 2 | 1) Disables Counting <br> 2) Sets Output Immediately High | Initiates Counting | Enables Counting |
| 3 | 1) Disables Counting <br> 2) Sets Output Immediately High | Initiates Counting | Enables Counting |
| 4 | Disables Counting | - | Enables Counting |
| 5 | -- | Initiates Counting | -- |

Figure 21. Gate PIn Operations Summary

| Mode | Min <br> Count | Max <br> Count |
| :---: | :---: | :---: |
| 0 | 1 | 0 |
| 1 | 1 | 0 |
| 2 | 2 | 0 |
| 3 | 2 | 0 |
| 4 | 1 | 0 |
| 5 | 1 | 0 |

NOTE:
0 is equivalent to $2^{16}$ for binary counting and $10^{4}$ for $B C D$ counting.

Figure 22. Minimum and Maximum Initial Counts

## Operation Common to All Modes

## PROGRAMMING

When a Control Word is written to a Counter, all Control Logic is immediately reset and OUT goes to a known initial state; no CLK pulses are required for this.

## GATE

The GATE input is always sampled on the rising edge of CLK. In Modes 0, 2, 3, and 4 the GATE input is level sensitive, and the logic level is sampled on the rising edge of CLK. In Modes 1, 2, 3, and 5 the GATE input is rising-edge sensitive. In these Modes, a rising edge of GATE (trigger) sets an edge-sensitive flip-flop in the Counter. This flip-flop is then sampled on the next rising edge of CLK; the flip-flop is reset immediately after it is sampled. in this way, a trigger will be detected no matter when it occurs-a high logic level does not have to be maintained until the next rising edge of CLK. Note that in Modes 2 and 3 , the GATE input is both edge- and level-sensitive. In Modes 2 and 3, if a CLK source other than the system clock is used, GATE should be pulsed immediately following WR of a new count value.

## COUNTER

New counts are loaded and Counters are decremented on the falling edge of CLK.

The largest possible initial count is 0 ; this is equivalent to $2^{16}$ for binary counting and $10^{4}$ for BCD counting.

The Counter does not stop when it reaches zero. In Modes 0, 1, 4, and 5 the Counter "wraps around" to the highest count, either FFFF hex for binary counting or 9999 for BCD counting, and continues counting. Modes 2 and 3 are periodic; the Counter reloads itself with the initial count and continues counting from there.

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\ldots . .0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin with
Respect to Ground. . . . . . . . . . . . . . -0.5 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . . . 1W
*Notice: Stresses above those listed under "AbsoIute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

NOTICE: Specifications contained within the following tables are subject to change.
D.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{I L}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Load Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| IOFL | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ to 0.45 V |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 170 | mA |  |

CAPACITANCE $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF | $\mathrm{f}_{\mathrm{C}}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{1 / 0}$ | I/O Capacitance |  | 20 | pF | Unmeasured pins <br> returned to $\mathrm{V}_{\mathrm{SS}}$ |

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

## Bus Parameters(1)

READ CYCLE

| Symbol | Parameter | 8254-5 |  | 8254 |  | 8254-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{A R}$ | Address Stable Before $\overline{\mathrm{RD}} \downarrow$ | 45 |  | 45 |  | 30 |  | ns |
| $t_{\text {SR }}$ | $\overline{\mathrm{CS}}$ Stable Before $\overline{\mathrm{RD}} \downarrow$ | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {fa }}$ | Address Hold Time After $\overline{\mathrm{R}} \mathrm{T} \uparrow$ | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{RR}}$ | $\overline{\mathrm{RD}}$ Pulse Width | 150 |  | 150 |  | 95 |  | ns |
| $t_{\text {RD }}$ | Data Delay from $\overline{\mathrm{RD}} \downarrow$ |  | 120 |  | 120 |  | 85 | ns |
| $t_{A D}$ | Data Delay from Address |  | 220 |  | 220 |  | 185 | ns |
| $t_{\text {t }}$ | $\overline{\mathrm{RD}} \uparrow$ to Data Floating | 5 | 90 | 5 | 90 | 5 | 65 | ns |
| $t_{\text {RV }}$ | Command Recovery Time | 200 |  | 200 |  | 165 |  | ns |

## NOTE:

1. AC timings measured at $\mathrm{V}_{\mathrm{OH}}=2.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.8 \mathrm{~V}$.

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

WRITE CYCLE

| Symbol | Parameter | 8254-5 |  | 8254 |  | 8254-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {AW }}$ | Address Stable Before $\overline{\mathrm{WR}} \downarrow$ | 0 |  | 0 |  | 0 |  | ns |
| tsw | $\overline{\mathrm{CS}}$ Stable Before $\overline{\mathrm{WR}} \downarrow$ | 0 |  | 0 |  | 0 |  | ns |
| tWA | Address Hold Time After $\overline{\text { WR }} \downarrow$ | 0 |  | 0 |  | 0 |  | ns |
| tww | $\overline{\text { WR Pulse Width }}$ | 150 |  | 150 |  | 95 |  | ns |
| tbw | Data Setup Time Before $\overline{W R} \uparrow$ | 120 |  | 120 |  | 95 |  | ns |
| two | Data Hold Time After $\overline{W R} \uparrow$ | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {RV }}$ | Command Recovery Time | 200 |  | 200 |  | 165 |  | ns |

CLOCK AND GATE

| Symbol | Parameter | 8254-5 |  | 8254 |  | 8254-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| ${ }_{\text {t CLK }}$ | Clock Period | 200 | DC | 125 | DC | 100 | DC | ns |
| tpwh | High Pulse Width | 60(3) |  | 60(3) |  | 30(3) |  | ns |
| $\mathrm{t}_{\text {PWL }}$ | Low Pulse Width | 60(3) |  | 60(3) |  | 50(3) |  | ns |
| $t_{R}$ | Clock Rise Time |  | 25 |  | 25 |  | 25 | ns |
| $t_{F}$ | Clock Fall Time |  | 25 |  | 25 |  | 25 | ns |
| $\mathrm{t}_{\mathrm{GW}}$ | Gate Width High | 50 |  | 50 |  | 50 |  | ns |
| $\mathrm{t}_{\mathrm{GL}}$ | Gate Width Low | 50 |  | 50 |  | 50 |  | ns |
| $\mathrm{t}_{\mathrm{GS}}$ | Gate Setup Time to CLK $\uparrow$ | 50 |  | 50 |  | 40 |  | ns |
| $\mathrm{t}_{\mathrm{GH}}$ | Gate Setup Time After CLK $\uparrow$ | 50(2) |  | 50(2) |  | 50(2) |  | ns |
| too | Output Delay from CLK $\downarrow$ |  | 150 |  | 150 |  | 100 | ns |
| todg | Output Delay from Gate $\downarrow$ |  | 120 |  | 120 |  | 100 | ns |
| $t_{\text {w }}$ | CLK Delay for Loading $\downarrow$ | 0 | 55 | 0 | 55 | 0 | 55 | ns |
| $t_{\text {wg }}$ | Gate Delay for Sampling | -5 | 50 | -5 | 50 | -5 | 40 | ns |
| two | OUT Delay from Mode Write |  | 260 |  | 260 |  | 240 | ns |
| $\mathrm{t}_{\mathrm{CL}}$ | CLK Set Up for Count Latch | -40 | 45 | -40 | 45 | -40 | 40 | ns |

## NOTES:

2. In Modes 1 and 5 triggers are sampled on each rising clock edge. A second trigger within 120 ns ( 70 ns for the 8254-2) of the rising clock edge may not be detected.
3. Low-going glitches that violate tpWH, tpWL may cause errors requiring counter reprogramming.

## WAVEFORMS

## WRITE



231164-13

READ


WAVEFORMS (Continued)
RECOVERY


CLOCK AND GATE


## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## intel

## 8259A <br> PROGRAMMABLE INTERRUPT CONTROLLER 8259A/8259A-2/8259A-8

- 8086, 8088 Compatible

■ MCS-80®, MCS-85 ${ }^{\text {® }}$ Compatible
■ Eight-Level Priority Controller
■ Expandable to 64 Levels

- Programmable Interrupt Modes
- Individual Request Mask Capability
- Single +5 V Supply (No Clocks)
- 28-Pin Dual-In-Line Package
- Available in EXPRESS
- Standard Temperature Range
- Extended Temperature Range

The Intel 8259A Programmable Interrupt Controller handles up to eight vectored priority interrupts for the CPU. It is cascadable for up to 64 vectored priority interrupts without additional circuitry. It is packaged in a 28 -pin DIP, uses NMOS technology and requires a single +5 V supply. Circuitry is static, requiring no clock input.

The 8259A is designed to minimize the software and real time overhead in handling 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 for the 8259 will operate the 8259A in all 8259 equivalent modes (MCS-80/85, Non-Buffered, Edge Triggered).



Figure 2. Pin Configuration

Figure 1. Block Dlagram

Table 1. Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $V_{C C}$ | 28 | 1 | SUPPLY: +5V Supply. |
| GND | 14 | 1 | GROUND |
| $\overline{C S}$ | 1 | 1 | CHIP SELECT: A IOW on this pin enables $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ communication between the CPU and the 8259A. INTA functions are independent of CS. |
| $\bar{W}$ | 2 | 1 | WRITE: A low on this pin when CS is low enables the 8259A to accept command words from the CPU. |
| $\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 | BIDIRECTIONAL DATA BUS: 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{\text { SP/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 $(S P=1)$ or slave ( $\mathrm{SP}=0$ ). |
| INT | 17 | 0 | 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. |
| $\mathrm{IR}_{0}-\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 IR 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 acknowiedge pulses issued by the CPU. |
| $\mathrm{A}_{0}$ | 27 | 1 | AO ADDRESS LINE: This pin acts in conjunction with the $\overline{\mathrm{CS}}, \overline{\mathrm{WR}}$, and $\overline{\text { 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 A0 address line (A1 for 8086, 8088). |

## FUNCTIONAL DESCRIPTION

## Interrupts in Microcomputer Systems

Microcomputer system design requires that 1.0 devices such as keyboards, displays, sensors and other components receive servicing in a 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 fetch 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.


Figure 3a. Polled Method


Figure 3b. Interrupt Method

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 sotware as an I/O peripheral. A selection of priority modes is available to the programmer so that the manner in which the requests are processed by the 8259A can be configured to match his system requirements. The priority modes can be changed or reconfigured dynamicaily 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.

## 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 (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 priorites 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 quality.

## INT (INTERRUPT)

This output goes directly to the CPU interrupt input. The $V_{O H}$ level on this line is designed to be fully compatible with the 8080A, 8085A and 8086 input levels.

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

## READ/WRITE CONTROL LOGIC

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

## $\overline{\mathbf{C S}}$ (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{\mathrm{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.

## $A_{0}$

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


Figure 4a. 8259A Block Diagram


Figure 4b. 8259A Block Diagram

## THE CASCADE BUFFER/COMPARATOR

This function block stores and compares the IDs of all 8259A's used in the system. The associated three 1/O pins (CAS0-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 CAS0-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 (IR7-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 $\overline{N T A}$ 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 instruction code (11001101) onto the 8-bit Data Bus through its D7-0 pins.
5. This CALL instruction will initiate two more $\overline{\mathrm{NTA}}$ pulses to be sent to the 8259A from the CPU group.
6. These two INTA 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 the higher 8 -bit address is released at the second INTA 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 occuring in an 8086 system are the same until step 4.
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 does not drive the Data Bus during this cycle.
5. The 8086 will initiate a second INTA 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 ${ }^{\circledR}$, MCS-85 ${ }^{\text {® }}$

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

Content of First Interrupt Vector Byte

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 |

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

Content of Second Interrupt Vector Byte

| IR | Interval $=4$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| 7 | A7 | A6 | A5 | 1 | 1 | 1 | 0 | 0 |
| 6 | A7 | A6 | A5 | 1 | 1 | 0 | 0 | 0 |
| 5 | A7 | A6 | A5 | 1 | 0 | 1 | 0 | 0 |
| 4 | A7 | A6 | A5 | 1 | 0 | 0 | 0 | 0 |
| 3 | A7 | A6 | A5 | 0 | 1 | 1 | 0 | 0 |
| 2 | A7 | A6 | A5 | 0 | 1 | 0 | 0 | 0 |
| 1 | A7 | A6 | A5 | 0 | 0 | 1 | 0 | 0 |
| 0 | A7 | A6 | A5 | 0 | 0 | 0 | 0 | 0 |


| IR | Interval $=\mathbf{8}$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | 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 | A7 | 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 | A7 | A6 | 0 | 0 | 1 | 0 | 0 | 0 |
| D | A7 | 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 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 |

## 8086, 8088

8086 mode is similar to MCS-80 mode except that only two Interrupt Acknowledge cycles are issued by the processor and no CALL opcode is sent to the processor. The first interrupt acknowledge cycle is similar to that of MCS-80, 85 systems in that the 8259A uses it to internally freeze the state of the interrupts for priority resolution and as a master it issues the interrupt code on the cascade lines at the end of the INTA pulse. On this first cycle it does not issue any data to the processor and leaves its data bus buffers disabled. On the second interrupt acknowledge cycle in 8086 mode the master (or siave 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 $\mathrm{A}_{5}-\mathrm{A}_{11}$ are unused in 8086 mode):

## Content of Interrupt Vector Byte

for 8086 System Mode

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IR7 | T7 | T6 | T5 | T4 | T3 | 1 | 1 | 1 |
| IR6 | T7 | T6 | T5 | T4 | T3 | 1 | 1 | 0 |
| IR5 | T7 | T6 | T5 | T4 | T3 | 1 | 0 | 1 |
| IR4 | T7 | T6 | T5 | T4 | T3 | 1 | 0 | 0 |
| IR3 | T7 | T6 | T5 | T4 | T3 | 0 | 1 | 1 |
| IR2 | T7 | T6 | T5 | T4 | T3 | 0 | 1 | 0 |
| IR1 | T7 | T6 | T5 | T4 | T3 | 0 | 0 | 1 |
| IR0 | T7 | T6 | T5 | T4 | T3 | 0 | 0 | 0 |

## 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 system must be brought to a starting point-by a sequence of 2 to 4 bytes timed by WR pulses.
2. Operation Command Words (OCWs): These are the command words which command the 8259A to operate in various interrupt modes. These modes are:
a. Fully nested mode
b. Rotating priority mode
c. Special mask mode
d. Polled mode

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

## INITIALIZATION COMMAND WORDS (ICWS)

## General

Whenever a command is issued with AO $=0$ and D4 $=1$, this is interpreted as Initialization Command Word 1 (ICW1). ICW1 starts the intiitalization 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 transistion 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 AutoEOI, MCS-80, 85 system).

## *NOTE:

Master/Slave 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 locations equally spaced in memory. These can be programmed to be spaced at intervals of 4 or 8 memory locations, thus the 8 routines will occupy a page of 32 or 64 bytes, respectively.

The address format is 2 bytes long $\left(A_{0}-A_{15}\right)$. When the routine interval is $4, A_{0}-A_{4}$ are automatically inserted by the 8259 A , while $\mathrm{A}_{5}-\mathrm{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 8086 system $\mathrm{A}_{15}-\mathrm{A}_{11}$ 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. $A_{10}-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.
ADI: CALL address interval. $A D=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 MCS80/85 system) and will enable the corresponding slave to release bytes 2 and 3 (for 8086 only byte 2) through the cascade lines.
b. In the slave mode (either when $\overline{S \bar{P}}=0$, or if 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 8086) are released by it on the Data Bus.


Figure 6. Initialization Sequence

Initialization Command Word 4 (ICW4)
SFNM: If SFNM = 1 the special fully nested mode is programmed.
BUF: If BUF $=1$ the buffered mode is programmed. In buffered mode $\overline{S P} / E N$ becomes an enable output and the master/ slave determination is by $\mathrm{M} / \mathrm{S}$.
M/S: If buffered mode is selected: $M / S=1$ means the 8259A is programmed to be a
master, $\mathrm{M} / \mathrm{S}=0$ means the 8259A is programmed to be a slave. If BUF $=0, M / S$ has no function.
AEOI: If AEOI $=1$ the automatic end of interrupt mode is programmed.
$\mu \mathrm{PM}$ : Microprocessor mode: $\mu \mathrm{PM}=0$ sets the 8259A for MCS-80, 85 system operation, $\mu \mathrm{PM}=1$ sets the 8259A for 8086 system operation.


231468-10


231468-11
Figure 7. Initialization Command Word Format


231468-12


231468-13


231468-14

## NOTE:

Slave ID is equal to the corresponding master IR input
Figure 7. Initialization Command Word Format (Continued)

8259A

## OPERATION COMMAND WORDS (OCWS)

After the Initialization 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)

OCW1

| A0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | M7 M6 M5 M4 M3 M2 M1 M0 <br>         |  |  |  |  |  |  |  |
| 0 | OCW2 |  |  |  |  |  |  |  |

OCW3


OCW2


Figure 8. Operation Command Word Format

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_{1}, L_{0}$-These bits determine the interrupt level acted upon when the SL bit is active.


Figure 8. Operation Command Word Format (Continued)

## Operation Control Word 3 (OCW3)

ESMM-Enable Special Mask Mode. When this bit is set to 1 it enables the SMM bit to set or reset the Special Mask Mode. When ESMM $=0$ the SMM bit becomes a "don't care".

SMM—Special Mask Mode. If ESMM $=1$ and SMM $=1$ the 8259A will enter Special Mask Mode. If ESMM $=1$ and $S M M=0$ the 8259A will revert to normal mask mode. When ESMM $=0$, SMM has no effect.

## Fully Nested Mode

This mode is entered after initialization unless another mode is programmed. The interrupt requests are ordered in priority from 0 through 7 ( 0 highest). When an interrupt is acknowledged the highest priority request is determined and its vector placed on the bus. Additionally, a bit of the Interrupt Service register (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 Interupt enable flip-flop has been re-enabled through software).

After the initialization sequence, IRO has the highest prioirity 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 trailing 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 Non-Specific. When the 8259A is operated in modes which perserve the fully nested structure, it can determine which is bit to reset on EOI. When a NonSpecific 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 $L 0-L 2$ is the binary level of the IS bit to be reset).

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

## Automatic End of Interrupt (AEOI) Mode

If AEOI $=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 non-specific EOI operation at the trailing edge of the last interrupt acknowledge pulse (third pulse in MCS-80/85, second in 8086). 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 (Equal Priority Devices)

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

Before Rotate (IR4 the highest prioirity requiring service)


After Rotate (IR4 was serviced, all other priorities rotated correspondingly)


There are two ways to accomplish Automatic Rotation using OCW2, the Rotation on Non-Specific EOI Command $(R=1, S L=0, E O I=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$. $\mathrm{EOI}=0$ ).

## Specific Rotation <br> (Specific Priority)

The programmer can change priorities by programming the bottom priority and thus fixing all other priorities; i.e., if IR5 is programmed as the bottom priority device, then IR6 will have the highest one.

The Set Priority command is issued in OCW2 where: $R=1, S L=1, L 0-L 2$ 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$, SL $=1, \mathrm{EOI}=1$ and $L O-L 2=\mid R$ level to receive bottom priority).

## Interrupt Masks

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

## Special Mask Mode

Some applications may require an interrupt service routine to dynamically alter the system priority struc-
ture 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 interrupts from all other levels (lower as well as higher) that are not masked.

Thus, any interrupts may be selectively enabled by loading the mask register.

The special Mask Mode is set by OWC3 where: SSMM $=1, S M M=1$, and cleared where SSMM $=$ $1, S M M=0$.

## Poll Command

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

The Poll command is issued by setting $P=$ ' 1 ' in OCW3. The 8259A treats the next $\overline{\mathrm{RD}}$ pulse to the 8259A (i.e., $\overline{R D}=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 $\overline{W R}$ to $\overline{\mathrm{RD}}$.

The word enabled onto the data bus during $\overline{R D}$ is:

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| I | - | - | - | - | W2 | W1 | W0 |

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

## Reading the 8259A Status

The input status of several internal registers can be read to update the user information on the system.


Figure 9. Priority Cell-Simplified Logic Diagram

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 puise, a Read Register Command is issued with OCW3 (RR $=1, \operatorname{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 set to IRR.
For reading the IMR, no OCW3 is needed. The output data bus will contain the IMR whenever $\overline{\mathrm{RD}}$ is active and $A 0=1$ (OCW1).

Polling overrides status read when $P=1, R R=1$ in OCW3.

## Edge and Level Triggered Modes

This mode is programmed using bit 3 in ICW1.
If $L T I M={ }^{\circ} 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.


Figure 10. IR Triggering Timing Requirements

If LTIM = ' 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 interrupts 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 8259 A . 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 useful safeguard for detecting interrupts caused by spurious noise glitches on the IR inputs. To implement this feature the IR7 routine is used for "clean up" simply executing a return instruction, thus ignoring the interrupt. If IR7 is needed for other purposes a default IR7 can still be detected by reading the ISR. A normal IR7 interrupt will set the corresponding ISR bit, a default IR7 won't. If a default IR7 routine occurs during a normal IR7 routine, however, the ISR will remain set. In this case it is necessary to keep track of whether or not the IR7 routine was previously entered. If another IR7 occurs it is a default.

## The Special Fully Nest 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 (us-
ing ICW4). This mode is similar to the normal nested mode with the following exceptions:
a. When an interrupt request from a certain slave is in service this slave is not locked out from the master's priority logic and further interrupt requests from higher priority IR's within the slave will be recognized by the master and will initiate interrupts to the processor. (in the normal nested mode a slave is masked out when its request is in service and no higher requests from the same slave can be serviced.)
b. When exiting the Interrupt Service routine the software has to check whether the interrupt serviced was the only one from that slave. This is done by sending a non-specific End of Interrupt (EOI) command to the slave and then reading its 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 signal on SP/EN 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

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\ldots . .0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Storage Temperature $\qquad$ $-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 .1W
*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 \mathrm{~V} \pm 5 \%(8259 \mathrm{~A}-8), \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ (8259A, 8259A-2))

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | $2.0 *$ | $\mathrm{V}_{C C}+0.5 \mathrm{~V}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=2.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} \text { (INT) }}$ | Interrupt Output High Voltage | 3.5 |  | V | $\mathrm{IOH}=-100 \mu \mathrm{~A}$ |
|  |  | 2.4 |  | V | $\mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{L}}$ | Input Load Current | -10 | $+10$ | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |
| LOL | Output Leakage Current | -10 | +10 | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 85 | mA |  |
| ILIR | IR Input Load Current |  | -300 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ |
|  |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{C C}$ |

*NOTE:
For Extended Temperature EXPRESS $\mathrm{V}_{\mathrm{IH}}=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}_{\mathbb{N}}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{1 / O}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured Pins Returned to $V_{\mathrm{SS}}$ |

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

*Worst case timing for TCHCL in an actual microprocessor system is typically much greater than 500 ns (i.e. 8085A $=$ $1.6 \mu \mathrm{~s}, 8085 \mathrm{~A}-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 from $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}} \downarrow$ |  | 300 |  | 200 |  | 120 | ns | C of Data Bus = 100 pF <br> C of Data Bus Max Test C $=100 \mathrm{pF}$ Min Test $\mathrm{C}=15 \mathrm{pF}$ $C_{I N T}=100 \mathrm{pF}$ $\mathrm{C}_{\mathrm{CASCADE}}=100 \mathrm{pF}$ |
| TRHDZ | Data Float after $\overline{\mathrm{RD}} / \overline{\mathrm{NTTA}} \uparrow$ | 10 | 200 | 10 | 100 | 10 | 85 | ns |  |
| TJHIH | Interrupt Output Delay |  | 400 |  | 350 |  | . 300 | ns |  |
| TIALCV | Cascade Valid from First INTA $\downarrow$ (Master Only) |  | 565 |  | 565 |  | 360 | ns |  |
| TRLEL | Enable Active from $\overline{\mathrm{RD}} \downarrow$ or $\overline{\mathrm{NTTA}} \downarrow$ |  | 160 |  | 125 |  | 100 | ns |  |
| TRHEH | Enable Inactive from $\overline{\mathrm{RD}} \uparrow$ or $\overline{\text { ITTA }} \uparrow$ |  | 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

WRITE


## WAVEFORMS (Continued)

READ/INTA


OTHER TIMING


WAVEFORMS (Continued)
INTA SEQUENCE


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

1. Cycle 1 in 8086, 8088 systems, the Data Bus is not active.

## inte'

## 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
- Controls $\mathbf{8}^{\prime \prime}, 51 / 4^{\prime \prime}$ and $31 / 2^{\prime \prime}$ Floppy Disk Drives
- 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 V Power Supply ( $\pm 10 \%$ )
- Plastic 40 Pin DIP or 40 Pin CERDIP Packages

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 handles most of the burdens associated with implementing a Floppy Disk Drive interface. The 8272A is a pin-compatible upgrade to the 8272.


210606-1

Figure 1. 8272A Internal Block Dlagram


Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | Pin No. | Type | Connection 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 specify command. |
| $\overline{\mathrm{RD}}$ | 2 | I(1) | $\mu \mathrm{P}$ | READ: Control signal for transfer of data from FDC to Data Bus, when "0" (low). |
| $\overline{W R}$ | 3 | I(1) | $\mu \mathrm{P}$ | WRITE: Control signal for transfer of data to FDC via Data Bus, when "0" (low). |
| $\overline{C S}$ | 4 | 1 | $\mu \mathrm{P}$ | CHIP SELECT: IC selected when " 0 " (low) allowing $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ to be enabled. |
| $A_{0}$ | 5 | I(1) | $\mu \mathrm{P}$ | DATA/STATUS REGISTER SELECT: Selects Data Reg $\left(A_{0}=1\right)$ or Status Reg $\left(A_{0}=0\right)$ contents to be sent to Data Bus. |
| $\mathrm{DB}_{0}-\mathrm{OB}_{7}$ | 6-13 | 1/O(1) | $\mu \mathrm{P}$ | DATA BUS: Bidirectional 8-Bit Data Bus. |
| DRQ | 14 | $\bigcirc$ | DMA | DATA DMA REQUEST: DMA Request is being made by FDC when DRQ "1".(3) |
| $\overline{\text { DACK }}$ | 15 | 1 | DMA | DMA ACKNOWLEDGE: DMA cycle is active when " 0 " (low) and Controller is performing DMA transfer. |
| TC | 16 | 1 | DMA | TERMINAL COUNT: Indicates the termination of a DMA transfer when " 1 " (high) ${ }^{(2)}$. |
| IDX | 17 | 1 | FDD | INDEX: Indicates the beginning of a disk track. |
| INT | 18 | 0 | $\mu \mathrm{P}$ | INTERRUPT: Interrupt Request 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. |
| $V_{C C}$ | 40 |  |  | D.C. POWER: +5V |
| $\overline{\mathrm{RW}} / \mathrm{SEEK}$ | 39 | 0 | FDD | READ WRITE/SEEK: When " 1 " (high) Seek mode selected and when " 0 " (low) Read/Write mode selected. |
| LCT/DIR | 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 to move head to another cylinder in Seek mode. |
| HDL | 36 | 0 | FDD | HEAD LOAD: Command which causes Read/Write head in FDD to contact diskette. |
| RDY | 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/TWO-SIDE: Senses Write Protect status in Read/ Write mode, and Two Side Media in Seek mode. |
| FLT/TRKO | 33 | 1 | FDD | FAULT/TRACK 0: Senses FDD fault condition in Read/Write mode and Track 0 condition in Seek mode. |
| $\mathrm{PS}_{1}, \mathrm{PS}_{0}$ | 31, 32 | 0 | FDD | PRECOMPENSATION (PRE-SHIFT): Write precompensation status during MFM mode. Determines early, late, and normal times. |
| WR DATA | 30 | 0 | FDD | WRITE DATA: Serial clock and data bits to FDD. |
| $\mathrm{DS}_{1}, \mathrm{DS}_{0}$ | 28,29 | 0 | FDD | DRIVE SELECT: Selects FDD unit. |

Table 1. Pin Description (Continued)

| Symbol | Pin <br> No. | Type | Connec- <br> tion To | Name and Function |
| :--- | :---: | :---: | :---: | :--- |
| HDSEL | 27 | 0 | FDD | HEAD SELECT: Head 1 selected when "1" (high) Head 0 selected <br> when "0" (low). |
| MFM | 26 | 0 | PLL | MFM MODE: MFM mode when "1," FM mode when "0". |
| WE | 25 | 0 | FDD | WRITE ENABLE: Enables write data into FDD. |
| VCO | 24 | 0 | PLL | VCO SYNC: Inhibits VCO in PLL when "0" (low), enables VCO when <br> "1." |
| RD DATA | 23 | 1 | FDD | READ DATA: Read data from FDD, containing clock and data bits. |
| DW | 22 | 1 | PLL | DATA WINDOW: Generated by PLL, and used to sample data from <br> FDD. |
| WR CLK | 21 | 1 |  | WRITE CLOCK: Write data rate to FDD FM $=500 \mathrm{kHz}$, MFM $=1$ <br> MHz, with a pulse width of 250 ns for both FM and MFM. <br> Must be enabled for all operations, both Read and Write. |

## NOTES:

1. Disabled when $\overline{C S}=1$.
2. TC must be activated to terminate the Execution Phase of any command
3. DRQ is also an input for certain test modes. It should have a $5 \mathrm{k} \Omega$ pull-up resistor to prevent activation.


Figure 3. 8272A System Block Dlagram

## 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 control ler.

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.
Read Data
Read ID
Read Deleted Data
Read a Track
Scan Equal
Scan High or Equal
Scan Low or Equal
Specify

Write Data
Format a Track
Write Deleted Data
Seek
Recalibrate (Restore to 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/Down registers and the signals $\overline{R D}, 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.

| $\mathbf{A}_{\mathbf{0}}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathrm{WR}}$ | Function |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 1 | Read Main Status Register |
| 0 | 1 | 0 | Illegal(1) |
| 0 | 0 | 0 | Illegal(1) |
| 1 | 0 | 0 | Illegal(1) |
| 1 | 0 | 1 | Read from Data Register |
| 1 | 1 | 0 | Write into Data Register |

## NOTE:

1. Design must guarantee that the 8272 A is not subjected to illegal inputs.

The Main Status Register bits are defined in Table 3.

Table 3. Main Status Register Bit Description

| Bit Number | Name | Symbol | Descriptlon |
| :---: | :--- | :---: | :--- |
| $D_{0}$ | FDD 0 Busy | $D_{0} B$ | FDD number 0 is in the Seek mode. |
| $D_{1}$ | FDD 1 Busy | $D_{1} B$ | FDD number 1 is in the Seek mode. |
| $D_{2}$ | FDD 2 Busy | $D_{2} B$ | FDD number 2 is in the Seek mode. |
| $D_{3}$ | FDD 3 Busy | $D_{3} B$ | FDD number 3 is in the Seek mode. |
| $D_{4}$ | FDC Busy | CB | A read or write command is in process. |
| $D_{5}$ | Non-DMA Mode | NDM | The FDC is in the non-DMA mode. This bit is set only <br> during the execution phase in non-DMA mode. <br> Transition to "0" state indicates execution phase has <br> ended. |
| $D_{6}$ | Data Input/Output | DIO | Indicates direction of data transfer between FDC and <br> Data Register. If DIO = "1" then transfer is from Data <br> Register to the Processor. If DIO = " 0 ", then transfer <br> is from the Processor to Data Register. |
| $D_{7}$ | Request for Master | RQM | Indicates Data Register is ready to send or receive <br> data to or from the Processor. Both bits DIO and RQM <br> should be used to perform the handshaking functions <br> 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.


NOTES:
A-Data register ready to be written into by processor
B-Data register not ready to be written into by processor
C-Data register ready for next data byte to be read by the processor
D-Data register not ready for next data byte to be read by processor
Figure 5. Status Register Timing

The 8272A is capable of executing 15 different commands. Each command is initiated by a multi-byte transfer from the processor, and the result after execution of the command may also be a multi-byte transfer back to the processor. Because of this mul-ti-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 only the Command and Result Phases, and NOT during the Execution Phase.

During the Execution Phase, the Main Status Register need not be read. If the 8272A is in the non-DMA Mode, then the receipt of each data byte (if 8272A 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 DACK $=0$ (DMA Acknowledge) and a $\overline{\text { RD }}=0$ (Read signal). When the DMA Acknowledge signal goes low ( $\overline{\mathrm{DACK}}=0$ ) then the DMA Request is reset ( $\mathrm{DRQ}=0$ ). If a Write Command has been programmed then a WR signal will appear instead of RD. After the Execution Phase has been completed (Terminal Count has occurred) then an Interrupt will occur (INT = 1). This signifies the beginning of the Result Phase. When the first byte of data is read during the Result Phase, the Interrupt is automatically reset (INT $=0$ ).

It is important to note that during the Result Phase all bytes shown in the Command Table must 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 automatically starts. In a similar fashion, when the last byte of

8272A

Table 4. 8272A Command Set


Table 4. 8272A Command Set (Continued)


Table 4. 8272A Command Set (Continued)


Table 4. 8272A Command Set (Continued)


Table 4. 8272A Command Set (Continued)


Table 4. 8272A Command Set (Continued)


Table 4. 8272A Command Set (Continued)

| Phase | R/W | Data Bus |  |  |  |  |  |  |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| SPECIFY |  |  |  |  |  |  |  |  |  |  |
| Command | $\begin{aligned} & w \\ & w \\ & w \end{aligned}$ | 0 - - | 0 SRT HLT |  | $\xrightarrow{0}$ | $\stackrel{+}{<}$ | 0 | $\xrightarrow{\text { HUT }}$ | 1 $\overline{N D}$ | Command Codes |
| SENSE DRIVE STATUS |  |  |  |  |  |  |  |  |  |  |
| Command <br> Result | $\begin{aligned} & W \\ & W \\ & R \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ |  | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{gathered} 1 \\ \text { HDS } \end{gathered}$ | $\begin{gathered} 0 \\ \text { DS1 } \end{gathered}$ | $\begin{gathered} 0 \\ \text { DSO } \end{gathered}$ | Command Codes <br> Status Information about FDD |
| SEEK |  |  |  |  |  |  |  |  |  |  |
| Command <br> Execution | $\begin{aligned} & w \\ & w \\ & w \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{gathered} 1 \\ \text { HDS } \end{gathered}$ | $\begin{gathered} 1 \\ \text { DS1 } \end{gathered}$ | $\begin{gathered} 1 \\ \text { DSO } \end{gathered}$ | Command Codes <br> Head is Positioned Over Proper Cylinder on Diskette |
| INVALID |  |  |  |  |  |  |  |  |  |  |
| Command <br> Result | W R |  |  |  | Invalid <br> S | des |  |  |  | Invalid Command <br> Codes (NoOp-FDC <br> Goes Into Standby State) $\text { ST } 0=80$ <br> (16) |

Table 5. Command Mnemonics

| Symbol | Name | Description |
| :---: | :---: | :---: |
| $\mathrm{A}_{0}$ | Address Line 0 | $A_{0}$ controls selection of Main Status Register ( $A_{0}=0$ ) or Data Register ( $A_{0}=1$ ). |
| C | Cylinder Number | C stands for the current selected Cylinder track number 0 through 76 of the medium. |
| D | Data | D stands for the data pattern which is going to be written into a Sector. |
| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | Data Bus | 8 -bit Data bus where $D_{7}$ is the most significant bit, and $D_{0}$ is the least significant bit. |
| DS0, DS1 | Drive Select | DS stands for a selected drive number 0 or 1. |
| DTL | Data Length | When N is defined as 00 , DTL stands for the data length which users are going to read out or write into the Sector. |
| EOT | End of Track | EOT stands for the final Sector number of a Cylinder. |
| GPL | Gap Length | GPL stands for the length of Gap 3 (spacing between Sectors excluding VCO Sync Field). |
| H | Head Address | $H$ stands for head number 0 or 1 , as specified in ID field. |
| HDS | Head Select | HDS stands for a selected head number 0 or $1(\mathrm{H}=$ HDS in all command words). |
| HLT | Head Load Time | HLT stands for the head load time in the FDD (2 to 254 ms in 2 ms increments). |
| HUT | Head Unload Time | HUT stands for the head unload time after a read or write operation has occurred ( 16 to 240 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 | If MT is high, a multi-track operation is to be peformed (a cylinder under both HD0 and HD1 will be read or written). |
| N | Number | N stands for the number of data bytes written in a Sector. |
| 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 Cylinder Number | PCN stands for the Cylinder number at the completion of SENSE INTERRUPT STATUS Command. Position of Head at present time. |
| R | Record | $R$ stands for the Sector number, which will be read or written. |
| R/W | Read/Write | R/W stands for either Read (R) or 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 | SRT stands for the Stepping Rate for the FDD ( 1 to 16 ms in 1 ms increments). The same Stepping Rate applies to all drives ( $F=1 \mathrm{~ms}$, $E=2 \mathrm{~ms}$, etc.). |

Table 5. Command Mnemonics (Continued)

| Symbol | Name | Description |
| :--- | :--- | :--- |
| ST 0 | Status 0 | ST 0-3 stand for one of four registers which store the status information after <br> ST 1 command has been executed. This information is available during the result |
| ST 2 | Status 1 | Status 2 |
| shase after command execution. These registers should not be confused with |  |  |
| ST 3 | Status 3 main status register (selected by $A_{0}=0$. ST 0-3 may be read only after |  |
| a command has been executed and contain information relevant to that |  |  |
| particular command. |  |  |

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

| DS1 | DS0 | Approximate Scan Timing |
| :---: | :---: | :---: |
| 0 | 0 | $220 \mu \mathrm{~s}$ |
| 0 | 1 | $220 \mu \mathrm{~s}$ |
| 1 | 0 | $220 \mu \mathbf{S}$ |
| 1 | 1 | $440 \mu \mathrm{~s}$ |

## COMMAND DESCRIPTIONS

During the Command Phase, the Main Status Register must be polled by the CPU before each byte is
written into the Data Register. The DIO (DB6) and RQM (BD7) 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 fieids. 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-by-byte to the main system via the data bus.

After completion of the read operation from the current sector, the Sector Number is incremented by one, and the data from the next sector is read and output on the data bus. This continuous 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 (mul-ti-track), MFM (MFM/FM), and N (Number of Bytes/ Sector). Table 7 on the next page shows the Transfer Capacity.

Table 7. Transfer Capacity


The "multi-track" function (MT) allows the FDC to read data from both sides of the diskette. For a particular cylinder, data will be transferred starting at Sector 1, Side 0 and completing at Sector L, Side 1 (Sector $\mathrm{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 nonzero, 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 Unioad Time Interval (specified in the Specify Command) has elapsed. If the processor issues another command before the head unioads then the head settling time may be saved between subsequent reads. This time out is particularly valuable when a diskette is copied from one drive to another.

If the FDC detects the Index Hole twice without finding the right sector, (indicated in "R"), then the FDC sets the ND (No Data) flag in Status Register 1 to a 1 (high), and terminates the Read Data Command. (Status Register 0 also has bits 7 and 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 $(S K=0)$, then the FDC sets the CM (Control Mark) flag in Status Register 2 to a 1 (high), and terminates the Read Data Command, after reading all the data in the Sector. If $\mathrm{SK}=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 \mathrm{~s}$ in the FM Mode, and every $13 \mu \mathrm{~s}$ in the MFM Mode, or the FDC sets the OR (Over Run) flag in Status Register 1 to a 1 (high), and terminates the Read Data Command.

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

8272A

Table 8. ID Information When Processor Terminates Command

| MT | EOT | Final Sector Transferred to Processor | ID Information at Result Phase |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | C | H | R | N |
| 0 | $\begin{aligned} & 1 \mathrm{~A} \\ & 0 \mathrm{~F} \\ & 08 \end{aligned}$ | Sector 1 to 25 at Side 0 <br> Sector 1 to 14 at Side 0 <br> Sector 1 to 7 at Side 0 | NC | NC | R + 1 | NC |
|  | $\begin{aligned} & 1 A \\ & 0 F \\ & 08 \end{aligned}$ | Sector 26 at Side 0 <br> Sector 15 at Side 0 <br> Sector 8 at Side 0 | $C+1$ | NC | $\mathrm{R}=01$ | NC |
|  | $\begin{aligned} & 1 \mathrm{~A} \\ & \mathrm{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 1 | NC | NC | $R+1$ | NC |
|  | 1A <br> OF <br> 08 | Sector 26 at Side 1 Sector 15 at Side 1 Sector 8 at Side 1 | $C+1$ | NC | $R=01$ | NC |
| 1 | $\begin{aligned} & 1 \mathrm{~A} \\ & 0 \mathrm{~F} \\ & 08 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { Sector } 1 \text { to } 25 \text { at Side } 0 \\ & \text { Sector } 1 \text { to } 14 \text { at Side } 0 \\ & \text { Sector } 1 \text { to } 7 \text { at Side } 0 \end{aligned}$ | NC | NC | $R+1$ | NC |
|  | $\begin{aligned} & 1 \mathrm{~A} \\ & 0 \mathrm{~F} \\ & 08 \end{aligned}$ | Sector 26 at Side 0 Sector 15 at Side 0 Sector 8 at Side 0 | NC | LSB | $R=01$ | NC |
|  | $\begin{aligned} & \hline \text { 1A } \\ & 0 \mathrm{~F} \\ & 08 \\ & \hline \end{aligned}$ | Sector 1 to 25 at Side 1 Sector 1 to 14 at Side 1 Sector 1 to 7 at Side 1 | NC | NC | $R+1$ | NC |
|  | $\begin{aligned} & 1 \mathrm{~A} \\ & 0 \mathrm{~F} \\ & 08 \end{aligned}$ | Sector 26 at Side 1 <br> Sector 15 at Side 1 <br> Sector 8 at Side 1 | $C+1$ | LSB | $R=01$ | NC |

## NOTES:

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

## WRITE DATA

A set of nine (9) bytes are required to set the FDC into the Write Data mode. After the Write Data command has been issued the FDC loads the head (if it is in the unloaded state), waits the specified head settling time (defined in the Specify Command), and begins reading ID Fields. When 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 issu-
ance of a Terminal Count signal. If a Terminal Count signal is sent to the FDC it continues writing into the current sector to complete the data field. If the Terminal Count signal is received while a data field is being written then the remainder of the data field is filled with 00 (zeros).

The FDC reads the ID field of each sector and checks the CRC bytes. If the FDC detects a read error (incorrect CRC) in one of the ID Fields, it sets the DE (Data Error) 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; refer to the Read Data Command for details:

- Transfer 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, and every $15 \mu \mathrm{~s}$ in the MFM mode. If the time interval between data transfers is longer than this then the FDC sets the OR (Over Run) flag in Status Register 1 to a 1 (high), and terminates the Write Data Command.

For mini-floppies, multiple track writes are usually not permitted. This is because of the turn-off time of the erase head coils-the head switches tracks before the erase head turns off. Therefore the system should typically wait 1.3 ms before attempting to step or change 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

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

## READ A TRACK

This command is similar to READ DATA Command except that 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 INDEX HOLE is encountered for the second time then the MA (Missing Address Mark) flag in Status Register 1 is set to a 1 (high), and if no data is found then the ND (No Data) flag is also set in Status Register 1 to a 1 (high) 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$ (Number 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 sector 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 $\mathrm{R}+$ 1 when it is read during the Result Phase. This incrementing and formatting continues for the whole track until the FDC encounters the INDEX HOLE for the second time, whereupon it terminates the command.

If a FAULT signal is received from the FDD at the end of a write operation, then the FDC sets the EC flag of Status Register 0 to a 1 (high), and terminates the command after setting bits 7 and 6 of Status Register 0 to 0 and 1 respectively. Also the loss of a READY signal at the beginning of a com-
mand execution phase causes command termination.

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

Table 9. Sector Size Relationships

| Format | Bytes/ Sector | 8" Floppy |  |  |  | Bytes/ Sector | 51/4" Floppy |  |  |  | Bytes/ Sector | 31/2" Mini Floppy |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | N | SC | GPL(1) | GPL(2) |  | N | SC | GPL(1) | GPL(2) |  | N | SC | GPL(1) | GPL(2) |
| FM Mode | 128 | 00 | 1A | 07 | 1B | 128 | 00 | 12 | 07 | 09 | 128 | 0 | OF | 07 | 1B |
|  | 256 | 01 | OF | OE | 2 A | 128 | 00 | 10 | 10 | 19 | - | - | - | - | - |
|  | 512 | 02 | 08 | 1B | 3A | 256 | 01 | 08 | 18 | 30 | 256 | 1 | 09 | OF | 2A |
|  | 1024 | 03 | 04 | 47 | 8A | 512 | 02 | 04 | 46 | 87 | 512 | 2 | 05 | 1B | 3A |
|  | 2048 | 04 | 02 | C8 | FF | 1024 | 03 | 02 | C8 | FF | - | - | - | - | - |
|  | 4096 | 05 | 01 | C8 | FF | 2048 | 04 | 01 | C8 | FF | - | - | - | - | - |
| MPM <br> Mode | 256 | 01 | 1A | OE | 36 | 256 | 01 | 12 | OA | OC | 256 | 1 | OF | CE | 36 |
|  | 512 | 02 | OF | 1 B | 54 | 256 | 01 | 10 | 20 | 32 | - | - | - | - | - |
|  | 1024 | 03 | 08 | 35 | 74 | 512 | 02 | 08 | 2A | 50 | 512 | 2 | 09 | 18 | 54 |
|  | 2048 | 04 | 04 | 99 | FF | 1024 | 03 | 04 | 80 | F0 | 1024 | 3 | 05 | 35 | 74 |
|  | 4096 | 05 | 02 | C8 | FF | 2048 | 04 | 02 | C8 | FF | - | - | - | - | - |
|  | 8192 | 06 | 01 | C8 | FF | 4096 | 05 | 01 | C8 | FF | - | - | - | - | - |

## NOTES:

1. Suggested values of GPL in Read or Write Commands to avoid splice point between data field and ID field of contiguous sections.
2. Suggested values of GPL in 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 $\mathrm{D}_{\text {FDD }}=$ DProcessor $\mathrm{D}_{\text {FDD }} \leq$ $D_{\text {Processor, }}$ or $D_{F D D} \geq$ 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 ( $\mathrm{R}+\mathrm{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

Table 10. Scan Status Codes

| Command | Status Register 2 |  | Comments |
| :---: | :---: | :---: | :---: |
|  | Bit $2=S N$ | Bit $3=$ SH |  |
| Scan Equal | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=\text { DProcessor } \\ & D_{\text {FDD }} \neq \text { D Processor }^{\text {Pr }} \end{aligned}$ |
| Scan Low or Equal | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=D_{\text {Processor }} \\ & D_{\text {FDD }}<D_{\text {Processor }} \\ & D_{\text {FDD }}>D_{\text {Processor }} \end{aligned}$ |
| Scan High or Equal | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=\text { DProcessor } \\ & D_{\text {FDD }}>\text { DProcessor } \\ & D_{\text {FDD }} \& \text { DProcessor }^{\text {P }} \end{aligned}$ |

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.

If the FDC encounters a Deleted Data Address Mark on one of the sectors (and SK = 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 $\mathrm{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 STP $=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 encountered before the EOT value of 26 can be read. This will result in an abnormal termination of the command. If the EOT had been set at 25 or the scanning started at sector 20, then the Scan Command would be completed in a normal manner.

During the Scan Command data is supplied by either the processor or DMA Controller for comparison against the data read from the diskette. In order to avoid having the OR (Over Run) flag set in Status Register 1, it is necessary to have the data available in less than $27 \mu \mathrm{~s}$ (FM Mode) or $13 \mu \mathrm{~s}$ (MFM Mode). If an Overrun occurs the FDC terminates the command.

## SEEK

The read/write 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 parallel 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 implied 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 Pulses have been issued, the FDC sets the SE (SEEK END) and EC (EQUIPMENT CHECK) flags of Status Register 0 to both is (highs), and terminates the command.

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 | Causerrupt Code  <br>  Bit 6 Bit 7 |  |  |
| :---: | :---: | :---: | :--- |
|  | 1 | 1 | Ready Line Changed <br> State, Either Polarity |
| 1 | 0 | 0 | Normal Termination <br> of Seek or Recalibrate <br> Command |
| 1 | 1 | 0 | Abnormal Termination <br> of Seek or Recalibrate <br> Command |

## SPECIFY

The Specify Command sets the intitial values for each of the three internal timers. The HUT (Head Unioad Time) defines the time from the end of the Execution Phase of one of the Read/Write Com-
mands 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 \mathrm{OF}=$ 240 ms ). The SRT (Step Rate Time) defines the time interval between adjacent step pulses. This timer is programmable from 1 to 16 ms in increments of $1 \mathrm{~ms}(F=1 \mathrm{~ms}, E=2 \mathrm{~ms}, \mathrm{D}=3 \mathrm{~ms}$, etc.). The HLT (Head Load Time) defines the time between when the Head Load signal goes high and when the Read/Write operation starts. This timer is programmable from 2 to 254 ms in increments of 2 ms ( $01=$ $2 \mathrm{~ms}, 02=4 \mathrm{~ms}, 03=6 \mathrm{~ms} \ldots \mathrm{FE}=254 \mathrm{~ms}$ ) .

The step rate should be programmed 1 ms longer 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 ( $\mathrm{ND}=1$ ) the NON-DMA mode is selected, and when ND $=0$ the DMA mode is selected.

## SENSE DRIVE STATUS

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

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

\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{3}{|c|}{Bit} \& \multirow[t]{2}{*}{Description} <br>
\hline No. \& Name \& Symbol \& <br>
\hline \multicolumn{4}{|l|}{STATUS REGISTER 0} <br>
\hline \multirow[t]{4}{*}{D 7

$\mathrm{D}_{6}$} \& \multirow[t]{4}{*}{Interrupt Code} \& \multirow[t]{4}{*}{IC} \& | $D_{7}=0 \text { and } D_{6}=0$ |
| :--- |
| Normal Termination of Command, (NT). Command was completed and properly executed. | <br>


\hline \& \& \& | $D_{7}=0 \text { and } D_{6}=1$ |
| :--- |
| Abnormal Termination of Command, (AT). Execution of Command was started, but was not successfully completed. | <br>


\hline \& \& \& | $D_{7}=1 \text { and } D_{6}=0$ |
| :--- |
| Invalid Command issue, (IC). Command which was issued was never started. | <br>


\hline \& \& \& | $D_{7}=1 \text { and } D_{6}=1$ |
| :--- |
| Abnormal Termination because during command execution the ready signal from FDD changed state. | <br>

\hline $\mathrm{D}_{5}$ \& Seek End \& SE \& When the FDC completes the SEEK Command, this flag is set to 1 (high). <br>
\hline $\mathrm{D}_{4}$ \& Equipment Check \& EC \& If a fault Signal is received from the FDD, or if the Track 0 Signal fails to occur after 77 Step Pulses (Recalibrate Command) then this flag is set. <br>
\hline $\mathrm{D}_{3}$ \& Not Ready \& NR \& When the FDD is in the not-ready state and a read or write command is issued, this flag is set. If a read or write command is issued to Side 1 of a single sided drive, then this flag is set. <br>
\hline $\mathrm{D}_{2}$ \& Head Address \& HD \& This flag is used to indicate the state of the head at Interrupt. <br>
\hline $\mathrm{D}_{1}$ \& Unit Select 1 \& US 1 \& These flags are used to indicate a Drive Unit Number at Interrupt. <br>
\hline $\mathrm{D}_{0}$ \& Unit Select 0 \& USO \& <br>
\hline \multicolumn{4}{|l|}{STATUS REGISTER 1} <br>
\hline $\mathrm{D}_{7}$ \& End of Cylinder \& EN \& When the FDC tries to access a Sector beyond the final Sector of a Cylinder, this flag is set. <br>
\hline $\mathrm{D}_{6}$ \& \& \& Not used. This bit is always 0 (low). <br>
\hline $\mathrm{D}_{5}$ \& Data Error \& DE \& When the FDC detects a CRC error in either the ID field or the data field, this flag is set. <br>
\hline $\mathrm{D}_{4}$ \& Over Run \& OR \& If the FDC is not serviced by the main-systems during data transfers, within a certain time interval, this flag is set. <br>
\hline $\mathrm{D}_{3}$ \& \& \& Not used. This bit always 0 (low). <br>
\hline \multirow[t]{3}{*}{$\mathrm{D}_{2}$} \& \multirow[t]{3}{*}{No Data} \& \multirow[t]{3}{*}{ND} \& During execution of READ DATA, WRITE DELETED DATA or SCAN Command, if the FDC cannot find the Sector specified in the IDR Register, this flag is set. <br>
\hline \& \& \& During executing the READ ID Command, if the FDC cannot read the ID field without an error, then this flag is set. <br>
\hline \& \& \& During the execution of the READ A Cylinder Command, if the starting sector cannot be found, then this flag is set. <br>
\hline
\end{tabular}

Table 12. Status Register (Continued)

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

ABSOLUTE MAXIMUM RATINGS*

| Operating Temperature | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $0^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| All Output Voltages | -0.5 to +7 V |
| All input Voltages | -0.5 to +7 V |
| Supply Voltage $\mathrm{V}_{\mathrm{CC}}$ | -0.5 to +7V |
| Power Dissipation $T_{A}=25^{\circ} \mathrm{C}$ |  |

*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 $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | $v$ |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{V}_{C C}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $1 \mathrm{OL}=2.0 \mathrm{~mA}$ |
| $\mathrm{VOH}^{\text {O }}$ | Output High Voltage | 2.4 | $\mathrm{V}_{\text {CC }}$ | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| ${ }^{\text {I CC }}$ | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 120 | mA |  |
| 111 | Input Load Current (All Input Pins) |  | $\begin{gathered} 10 \\ -10 \\ \hline \end{gathered}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & V_{I N}=V_{C C} \\ & V_{I N}=O V \end{aligned}$ |
| ILOH | High Level Output Leakage Current |  | 10 | $\mu \mathrm{A}$ | $V_{\text {OUT }}=V_{\text {CC }}$ |
| lofl | Output Float Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{C} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ |

CAPACITANCE $T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}_{\mathrm{C}}=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}$

| Symbol | Parameter | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| $\mathrm{C}_{1 \times(\phi)}$ | Clock Input Capacitance |  | 20 | pF | All Pins Except Pin Under Test Tied to AC Ground |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF |  |
| $\mathrm{C}_{1 / 0}$ | Input/Output Capacitance |  | 20 | pF |  |

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

| Symbol | Parameter | Typ(1) | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CLOCK TIMING |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{Cr}}$ | Clock Period |  | 120 | 500 | ns | (Note 5) |
| ${ }_{\text {t }}$ | Clock High Period |  | 40 |  | ns | (Note 4, 5) |
| $\mathrm{t}_{\text {RST }}$ | Reset Width |  | 14 |  | tcy |  |
| READ CYCLE |  |  |  |  |  |  |
| $t_{\text {AR }}$ | Select Setup to $\overline{\mathrm{RD}} \downarrow$ |  | 0 |  | ns |  |
| $t_{\text {RA }}$ | Select Hold from $\overline{\mathrm{DD}} \uparrow$ |  | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{RA}}$ | R RD Pulse Width |  | 250 |  | ns |  |
| $t_{\text {RD }}$ | Data Delay from $\overline{\text { RD }} \downarrow$ |  |  | 200 | ns |  |
| $t_{\text {DF }}$ | Output Float Delay |  | 20 | 100 | ns |  |
| WRITE CYCLE |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{AW}}$ | Select Setup to WR $\downarrow$ |  | 0 |  | ns |  |
| twa | Select Hold from WR $\uparrow$ |  | 0 |  | ns |  |
| tww | WR Pulse Width |  | 250 |  | ns |  |
| tow | Data Setup to $\overline{\mathrm{WR}} \uparrow$ |  | 150 |  | ns |  |
| two | Data Hold from WR $\uparrow$ |  | 5 |  | ns |  |
| INTERRUPTS |  |  |  |  |  |  |
| $t_{\text {RI }}$ | INT Delay from $\overline{\mathrm{R}}$ ¢ $\uparrow$ |  |  | 500 | ns | (Note 6) |
| twi | INT Delay from $\overline{\mathrm{WR}} \uparrow$ |  |  | 500 | ns | (Note 6) |
| DMA |  |  |  |  |  |  |
| $\mathrm{t}_{\text {RQCY }}$ | DRQ Cycle Period |  | 13 |  | $\mu \mathrm{s}$ | (Note 6) |
| takRQ |  |  |  | 200 | ns |  |
| $\mathrm{t}_{\text {ROR }}$ | DRQ $\uparrow$ to $\overline{\mathrm{RD}} \downarrow$ |  | 800 |  | ns | (Note 6) |
| traw | DRQ $\uparrow$ to $\overline{\mathrm{WR}} \downarrow$ |  | 250 |  | ns | (Note 6) |
| trarw | $\mathrm{DRQ} \uparrow$ to $\overline{\mathrm{RD}} \uparrow$ or $\overline{\mathrm{WR}} \uparrow$ |  |  | 12 | $\mu \mathrm{s}$ | (Note 6) |

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

| Symbol | Parameter | Typ(1) | Min | Max | Unlt | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FDD INTERFACE |  |  |  |  |  |  |
| twCy | WCK Cycle Time | $\begin{aligned} & 2 \text { or } 4 \\ & 1 \text { or } 2 \end{aligned}$ |  |  | $\mu \mathrm{S}$ | $\begin{aligned} & \text { MFM }=0 \\ & \text { MFM }=1 \text { (Note 2) } \end{aligned}$ |
| $\mathrm{t}_{\text {WCH }}$ | WCK High Time | 250 | 80 | 350 | ns |  |
| $\mathrm{t}_{\mathrm{CP}}$ | Pre-Shift Delay from WCK $\uparrow$ |  | 20 | 100 | ns |  |
| $\mathrm{t}_{\mathrm{CD}}$ | WDA Delay from WCK $\uparrow$ |  | 20 | 100 | ns |  |
| twDD | Write Data Width |  | $t_{\text {WCH - }} 50$ |  | ns |  |
| twe | WE $\uparrow$ to $W C K \uparrow$ or WE $\downarrow$ to WCK $\downarrow$ Delay |  | 20 | 100 | ns |  |
| twwey | Window Cycle Time | $\begin{aligned} & 2 \\ & 1 \end{aligned}$ |  |  | $\mu \mathrm{s}$ | $\begin{aligned} & M M=0 \\ & M F M=1 \end{aligned}$ |
| ${ }^{\text {twRD }}$ | Window Setup to RDD $\uparrow$ |  | 15 |  | ns |  |
| $t_{\text {RDW }}$ | Window Hold from RDD $\downarrow$ |  | 15 |  | ns |  |
| $t_{\text {R }}$ | RDD Active Time (HIGH) |  | 40 |  | ns |  |

FDD SEEK/DIRECTION/STEP

| tus | US ${ }_{0,1}$ Setup to $\overline{\text { RW }} /$ SEEK $\uparrow$ |  | 12 |  | $\mu \mathrm{s}$ | (Note 6) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tsu | US ${ }_{0,1}$ Hold after $\overline{\text { RW/SEEK } \downarrow}$ |  | 15 |  | $\mu \mathrm{S}$ | (Note 6) |
| tso | $\overline{\mathrm{RW}} / \mathrm{SEEK}$ Setup to LCT/DIR |  | 7 |  | $\mu \mathrm{s}$ | (Note 6) |
| tos | RW/SEEK Hold from LCT/DIR |  | 30 |  | $\mu \mathrm{s}$ | (Note 6) |
| tDST | LCT/DIR Setup to FR/STEP $\uparrow$ |  | 1 |  | $\mu \mathrm{s}$ | (Note 6) |
| ${ }^{\text {t }}$ STD | LCT/DIR Hold from FR/STEP $\downarrow$ |  | 24 |  | $\mu \mathrm{s}$ | (Note 6) |
| tstu | $D S_{2,1}$ Hold from FR/Step $\downarrow$ |  | 5 |  | $\mu \mathrm{s}$ | (Note 6) |
| tSTP | STEP Active Time (High) | 5 |  |  | $\mu \mathrm{s}$ | (Note 6) |
| ${ }_{\text {ts }}$ S | STEP Cycle Time |  | 33 |  | $\mu \mathrm{s}$ | (Note 3, 6) |
| $t_{\text {fr }}$ | FAULT RESET Active Time (High) |  | 8 | 10 | $\mu \mathrm{s}$ | (Note 6) |
| tiox | INDEX Pulse Width | 10 |  |  | $t_{\text {cr }}$ |  |
| ${ }_{t}$ | Terminal Count Width |  | 1 |  | tor |  |

NOTES:

1. Typical values for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. The former values are used for standard floppy and the latter values are used for mini-floppies.
3. $\mathrm{tsC}=33 \mu \mathrm{~s}$ min. is for different drive units. In the case of same unit, tsc can be ranged from 1 ms to 16 ms with 8 MHz clock period, and 2 ms to 32 ms with 4 MHz clock, under software control.
4. From 2.0 V to +2.0 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\left(\mathrm{t}_{\mathrm{CH}} \div \mathrm{t}_{\mathrm{CY}}\right)$ with typical rise and fall times of 5 ns.
6. The specified values listed are 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: Inputs are driven at 2.4 V for a Logic "1" and 0.45 V for a Logic " 0 ". Timing measurements are made at 2.0 V for a Logic " 1 " and 0.8 V for a Logic " 0 ".
A.C. TESTING LOAD CIRCUIT


210606-8
$C_{L}=100 \mathrm{pF}$
$C_{\text {L }}$ Includes Jig Capacitance

## WAVEFORMS

## PROCESSOR READ OPERATION



WAVEFORMS (Continued)

## PROCESSOR WRITE OPERATION



DMA OPERATION


## intel

WAVEFORMS (Continued)

## CLOCK TIMING



FDD WRITE OPERATION


WAVEFORMS (Continued)

## SEEK OPERATION



## FLT RESET



INDEX


WAVEFORMS (Continued)

FDD READ OPERATION


## TERMINAL COUNT



RESET


## intel

## 80286 <br> High Performance Microprocessor with Memory Management and Protection

- High Performance Processor (Up to six times 8086)
- Large Address Space:
- 16 Megabytes Physical
- 1 Gigabyte Virtual per Task
- Integrated Memory Management, FourLevel Memory Protection and Support for Virtual Memory and Operating Systems
- Two 8086 Upward Compatible Operating Modes:


## - 8086 Real Address Mode

- Protected Virtual Address Mode
- Optional Processor Extension:
- 80287 High Performance 80-bit Numeric Data Processor
- Available in EXPRESS:
- Standard Temperature Range
- Range of clock rates
- 12.5 MHz for 80286 -12
- 10 MHz for 80286-10
- 8 MHz for $80826-8$
-6 MHz for $80286-6$
- Complete System Development Support:
-Development Software: Assembler, PL/M, Pascal, FORTRAN, and System Utilities
— In-Circuit-Emulator (ICETM-286)
- High Bandwidth Bus Interface (12.5 Megabyte/Sec)
- Available in 68 Pin Ceramic LCC (Leadless Chip Carrier) and PGA (Pin Grid Array) Packages
(See Packaging Spec., Order \#231369)

The 80286 is an advanced, high-performance microprocessor with specially optimized capabilities for multiple user and multi-tasking systems. The 80286 has built-in memory protection that supports operating system and task isolation as well as program and data privacy within tasks. A 10 MHz 80286 provides five times or more throughput than the standard 5 MHz 8086 . The 80286 includes memory management capabilities that map $2^{30}$ (one gigabyte) of virtual address space per task into $2^{24}$ bytes ( 16 megabytes) of physical memory.
The 80286 is upward compatible with 8086 and 88 software. Using 8086 real address mode, the 80286 is object code compatible with existing 8086, 88 software. In protected virtual address mode, the 80286 is source code compatible with 8086,88 software and may require upgrading to use virtual addresses supported by the 80286 's integrated memory management and protection mechanism. Both modes operate at full 80286 performance and execute a superset of the 8086 and 88 instructions.
The 80286 provides special operations to support the efficient implementation and execution of operating systems. For example, one instruction can end execution of one task, save its state, switch to a new task, load its state, and start execution of the new task. The 80286 also supports virtual memory systems by providing a segment-not-present exception and restartable instructions.


Figure 1. 80286 Internal Block Diagram

Component Pad Views-As viewed from underside of component when mounted on the board.


P.C. Board Views-As viewed from the component side of the P.C. board.


NOTE:
N.C. signals must not be connected


FIGURE 2. 80286 Pin Configuration
Table 1. Pin Description
The following pin function descriptions are for the 80286 microprocessor:

| Symbol | тype | Name and Function |  |  |
| :---: | :---: | :---: | :---: | :---: |
| CLK | 1 | SYSTEM CLOCK provides the fundamental timing for 80286 systems. It is divided by two inside the 80286 to generate the processor clock. The internal divide-by-two circuitry can be synchronized to an external clock generator by a LOW to HIGH transition on the RESET input. |  |  |
| $\mathrm{D}_{15}-\mathrm{D}_{0}$ | 1/0 | DATA BUS inputs data during memory, 1/O, and interrupt acknowledge read cycles; outputs data during memory and I/O write cycles. The data bus is active HIGH and floats to 3-state OFF during bus hold acknowledge. |  |  |
| $A_{23}-A_{0}$ | 0 | ADDRESS BUS outputs physical memory and I/O port addresses. AO is LOW when data is to be transferred on pins $D_{7-0} . A_{23}-A_{18}$ are LOW during I/O transfers. The address bus is active HIGH and floats to 3 -state OFF during bus hold acknowledge. |  |  |
| BHE | 0 | BU8 HICH ENABLE indicates transfer or data on the upper byte of the data bus. $D_{15-8}$. Elight-bit oriented devices assigned to the upper byte of the data bus would normally use $\overline{B H E}$ to condition chip select functions. BHE is active LOW and floats to 3 -state OFF during bus hold acknowledge. |  |  |
|  |  | THE and AO Encodinge |  |  |
|  |  | DHE Value | AO Value | Function |
|  |  | 0 0 1 1 | 0 1 0 1 | Word transfer <br> Byte transfer on upper half of data bus $\left(\mathrm{D}_{15}-\mathrm{D}_{8}\right)$ <br> Byte transfer on lower half of data bus ( $\mathrm{D}_{7-0}$ ) <br> Will never occur |

Table I. Pin Description (Continued)

| Symbol | Type | Name and Function |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{S1}}, \overline{\mathrm{~s} 0}$ | 0 | BUS CYCLE STATUS indicates initiation of a bus cycle and, along with M/Ī and COD/ $\mathbb{I N T A}$, defines the type of bus cycle. The bus is in a $T_{s}$ state whenever one or both are LOW, $\overline{\mathrm{S} 1}$ and $\mathrm{S0}$ are active LOW and float to 3 -state OFF during bus hold acknowledge. |  |  |  |  |
|  |  | 80286 Bus Cycle Status Definition |  |  |  |  |
|  |  | CODIINTA | M/ $\overline{10}$ | S1 | $\overline{50}$ | Bus Cycle Initiated |
|  |  | $\begin{aligned} & 0 \text { (LOW) } \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \text { (HIGH) } \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | 0 0 0 0 1 1 1 1 0 0 0 0 1 1 1 1 | 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Interrupt acknowledge <br> Will not occur <br> Will not occur <br> None; not a status cycle <br> IF A1 = 1 then halt; else shutdown <br> Memory data read <br> Memory data write <br> None; not a status cycle <br> Will not occur <br> 1/Oread <br> 1/O write <br> None; not a status cycle <br> Will not occur <br> Memory instruction read <br> Will not occur <br> None; not a status cycle |
| M/市 | 0 | MEMORY I/O SELECT distinguishes memory access from I/O access. If HIGH during $T_{s}$, a memory cycle or a halt/shutdown cycle is in progress. If LOW, an I/O cycle or an interrupt acknowledge cycle is in progress. M/IO floats to 3 -state OFF during bus hold acknowledge. |  |  |  |  |
| COD/INTA | 0 | CODE/INTERRUPT ACKNOWLEDGE distinguishes instruction fetch cycles from memory data read cycles. Also distinguishes interrupt acknowledge cycles from I/O cycles. COD/ $\overline{\operatorname{INTA}}$ floats to 3 -state OFF during bus hold acknowledge. Its timing is the same as $\mathrm{M} / \overline{\mathrm{IO}}$. |  |  |  |  |
| $\overline{\text { LOCK }}$ | 0 | BUS LOCK indicates that other system bus masters are not to gain control of the system bus for the current and the following bus cycle. The LOCK signal may be activated explicitly by the "LOCK" instruction prefix or automatically by 80286 hardware during memory XCHG instructions, interrupt acknowledge, or descriptor table access. LOCK is active LOW and floats to 3 -state OFF during bus hold acknowledge. |  |  |  |  |
| READY | 1 | BUS READY terminates a bus cycle. Bus cycles are extended without limit until terminated by READY LOW. $\overline{R E A D Y}$ is an active LOW synchronous input requiring setup and hold times relative to the system clock be met for correct operation. READY is ignored during bus hold acknowledge. |  |  |  |  |
| $\begin{aligned} & \text { HOLD } \\ & \text { HLDA } \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | BUS HOLD REQUEST AND HOLD ACKNOWLEDGE control ownership of the 80286 local bus. The HOLD input aliows another local bus master to request control of the local bus. When control is granted, the 80286 will float its bus drivers to 3 -state OFF and then activate HLDA, thus entering the bus hold acknowledge condition. The local bus will remain granted to the requesting master until HOLD becomes inactive which results in the 80286 deactivating HLDA and regaining control of the local bus. This terminates the bus hold acknowledge condition. HOLD may be asynchronous to the system clock. These signals are active HIGH. |  |  |  |  |
| INTR | 1 | INTERRUPT REQUEST requests the 80286 to suspend its current program execution and service a pending external request. Interrupt requests are masked whenever the interrupt enable bit in the flag word is cleared. When the 80286 responds to an interrupt request, it performs two interrupt acknowledge bus cycles to read an 8 -bit interrupt vector that identifies the source of the interrupt. To assure program interruption, INTR must remain active until the first interrupt acknowledge cycle is completed. INTR is sampled at the beginning of each processor cycle and must be active HIGH at least two processor cycles before the current instruction ends in order to interrupt before the next instruction. INTR is level sensitive, active HIGH, and may be asynchronous to the system clock. |  |  |  |  |
| NMI | 1 | NON-MASKABLE INTERRUPT REQUEST interrupts the 80286 with an internally supplied vector value of 2. No interrupt acknowledge cycles are performed. The interrupt enable bit in the 80286 flag word does not affect this input. The NMI input is active HIGH, may be asynchronous to the system clock, and is edge triggered after internal synchronization. For proper reçognition, the input must have been previously LOW for at least four system clock cycles and remain HIGH for at least four system clock cycles. |  |  |  |  |

Table 1. PIn Description (Continued)

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| PEREQ PEACK | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | PROCESSOR EXTENSION OPERAND REQUEST AND ACKNOWLEDGE extend the memory management and protection capabilities of the 80286 to processor extensions. The PEREQ input requests the 80286 to perform a data operand transfer for a processor extension. The PEACK output signals the processor extension when the requested operand is being transferred. PEREQ is active HIGH and floats to 3 -state OFF during bus hold acknowledge. PEACK may be asynchronous to the system clock. PEACK is active LOW. |
| $\begin{aligned} & \text { BUSY } \\ & \text { ERROA } \end{aligned}$ | I | PROCESSOR EXTENSION BUSY AND ERROR indicate the operating condition of a processor extension to the 80286. An active BUSY input stops 80286 program execution on WAIT and some ESC instructions until BUSY becomes inactive (HIGH). The 80286 may be interrupted while waiting for BUSY to become inactive. An active ERROR input causes the 80286 to perform a processor extension interrupt when executing WAIT or some ESC instructions. These inputs are active LOW and may be asynchronous to the system clock. |
| RESET | 1 | SYSTEM RESET clears the internal logic of the 80286 and is active HIGH. The 80286 may be reinitialized at any time with a LOW to HIGH transition on RESET which remains active for more than 16 system clock cycles. During RESET active, the output pins of the 80286 enter the state shown below: |
|  |  | 80286 Pin State During Reset |
|  |  | Pin Value $\quad$ Pin Names |
|  |  | 1 (HIGH) $\overline{S O}, \overline{S 1}$, PEACR, A23-AO, BHE, $\overline{L O C K}$ <br> 0 (LOW) $M / \overline{O O}$, COD/INTA, HLDA (Note 1) <br> 3-state OFF $D_{15}-D_{0}$ |
|  |  | Operation of the 80286 begins after a HIGH to LOW transition on RESET. The HIGH to LOW transition of RESET must be synchronous to the system clock. Approximately 38 CLK cycles from the trailing edge of RESET are required by the 80288 for internal initialization before the first bus cycle, to fetch code from the power-on execution address, occurs. <br> A LOW to HIGH transition of RESET synchronous to the system clock will end a processor cycle at the second HIGH to LOW transition of the system clock. The LOW to HIGH transition of RESET may be asynchronous to the system clock; however, in this case it cannot be predetermined which phase of the processor clock will occur during the next system clock period. Synchronous LOW to HIGH transitions of RESET are required only for systems where the processor clock must be phase synchronous to another clock. |
| $V_{\text {SS }}$ | 1 | SYSTEM GROUND: 0 Voits. |
| $V_{\text {cc }}$ | 1 | SYSTEM POWER: + 5 Volt Power Supply. |
| CAP | 1 | SUBSTRATE FILTER CAPACITOR: a $0.047 \mu \mathrm{~F} \pm 20 \% 12 \mathrm{~V}$ capacitor must be connected between this pin and ground. This capacitor filters the output of the internal substrate bias generator. A maximum DC leakage current of $1 \mu \mathrm{~A}$ is allowed through the capacitor. <br> For correct operation of the 80286, the substrate bias generator must charge this capacitor to its operating voltage. The capacitor chargeup time is 5 milliseconds (max.) after $V_{C C}$ and CLK reach their specified AC and DC parameters. RESET may be applied to prevent spurious activity by the CPU during this time. After this time, the 80286 processor clock can be synchronized to another clock by pulsing RESET LOW synchronous to the system clock. |

## NOTE:

1. HLOA is only Low if HOLO is inactive (Low).

## FUNCTIONAL DESCRIPTION

## Introduction

The 80286 is an advanced, high-performance microprocessor with specially optimized capabilities for multiple user and multi-tasking systems. Depending on the application, an 8 MHz 80286 's performance is up to six times faster than the standard 5 MHz 8086's, while providing complete upward software compatibility with Intel's 8086, 88, and 186 family of CPU's.

The 80286 operates in two modes: 8086 real address mode and protected virtual address mode. Both modes execute a superset of the 8086 and 88 instruction set.

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

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

## 80286 BASE ARCHITECTURE

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

## Register Set

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

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

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

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

Status and Control Registers: The 3 16-bit special purpose registers in figure 3A record or control certain aspects of the 80286 processor state including the Instruction Pointer, which contains the offset address of the next sequential instruction to be executed.


Figure 3. Register Set


Figure 3a. Status and Control Register Bit Functions

## Flags Word Description

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

## Instruction Set

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

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

Table 2. Fiags Word Bit Functions

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

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

For detailed operation and usage of each instruction, see Appendix of 80286 Programmer's Reference Manual (Order No. 210498)

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

Figure 4a. Data Transfer Instructions

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

Figure 4c. String Instructions

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

Figure 4b. Arithmetic Instructions

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

Figure 4d. Shift/Rotate Logical Instructions

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

Figure 4e. Program Transfer Instructions

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

Figure 4f. Processor Control Instructions

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

Figure 4g. High Level Instructions

## Memory Organization

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


Figure 5. Two Component Address

Table 3. Segment Register Selection Rules

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

All instructions that address operands in memory must specify the segment and the offset. For speed and compact instruction encoding, segment selectors are usually stored in the high speed segment registers. An instruction need specify only the desired segment register and an offset in order to address a memory operand.

Most instructions need not explicitly specify which segment register is used. The correct segment register is automatically chosen according to the rules of Table 3. These rules follow the way programs are written (see Figure 6) as independent modules that require areas for code and data, a stack, and access to external data areas.

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

## Addressing Modes

The 80286 provides a total of eight addressing modes for instructions to specity operands. Two addressing modes are provided for instructions that operate on register or immediate operands:

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

Six modes are provided to specify the location of an operand in a memory segment. A memory operand address consists of two 16 -bit components: segment selector and offset. The segment selector is supplied by a segment register either implicitly chosen by the addressing mode or explicitly chosen by a segment override prefix. The offset is calculated by summing any combination of the following three address elements:
the displacement (an 8 or 16 -bit immediate value contained in the instruction)
the base (contents of either the 3 X or BP base registers)


Figure 6. Segmented Memory Helps Structure Software
the index (contents of either the SI or DI index registers)

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

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

Direct Mode: The operand's offset is contained in the instruction as an 8 or 16 -bit displacement element.

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

Based Mode: The operand's offset is the sum of an 8 or 16-bit displacement and the contents of a base register ( $B X$ or $B P$ ).

Indexed Mode: The operand's offset is the sum of an 8 or 16 -bit displacement and the contents of an index register (SI or DI).

Based Indexed Mode: The operand's offset is the sum of the contents of a base register and an index register.

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

## Data Types

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

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

Figure 7 graphically represents the data types supported by the 80286.
either an 8-bit port address, specified in the instruction, or a 16 -bit port address in the DX register. 8 -bit port addresses are zero extended such that $A_{15}-A_{8}$ are LOW. $/ / \mathrm{O}$ port addresses $00 \mathrm{FB}(\mathrm{H})$ through $00 F F(H)$ are reserved.


Figure 7. 80286 Supported Data Types

## I/O Space

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

Table 4. Interrupt Vector Assignments

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

## Interrupts

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

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

## MASKABLE INTERRUPT (INTR)

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

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

## NON-MASKABLE INTERRUPT REQUEST (NMI)

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

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

## SINGLE STEP INTERRUPT

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

## Interrupt Priorities

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

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

## Initialization and Processor Reset

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

Table 6. 80286 Initial Register State after RESET

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

HOLD must not be active during the time from the leading edge of the initial RESET to 34 CLKs after the trailing edge of the initial RESET of an 80286 system.

## Machine Status Word Description

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

Table 7. MSW Bit Functions

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

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

Table 8. Recommended MSW Encodings For Processor Extension Control

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

## Halt

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

## 8086 REAL ADDRESS MODE

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

## Memory Size

Physical memory is a contiguous array of up to 1,048,576 bytes (one megabyte) addressed by pins $\mathrm{A}_{0}$ through $\mathrm{A}_{19}$ and $\overline{B H E}$. $\mathrm{A}_{20}$ through $\mathrm{A}_{23}$ should be ignored.

## Memory Addressing

In real address mode physical memory is a contiguous array of up to $1,048,576$ bytes (one megabyte) addressed by pins $\mathrm{A}_{0}$ through $\mathrm{A}_{19}$ and $\overline{B H E}$. Address bits $A_{20}-A_{23}$ may not always be zero in real mode. $A_{20}-A_{23}$ should not be used by the system while the 80286 is operating in Real Mode.

The selector portion of a pointer is interpreted as the upper 16 bits of a 20 -bit segment address. The lower four bits of the 20 -bit segment address are always zero. Segment addresses, therefore, begin on multiples of 16 bytes. See Figure 8 for a graphic representation of address information.

All segments in real address mode are 64 K bytes in size and may be read, written, or executed. An exception or interrupt can occur if data operands or instructions attempt to wrap around the end of a segment (e.g. a word with its low order byte at offset FFFF(H) and its high order byte at offset $0000(\mathrm{H})$. If, in real address mode, the information contained in a segment does not use the full 64 K bytes, the unused end of the segment may be overlayed by another segment to reduce physical memory requirements.
tion area and interrupt table area. Locations from addresses $\operatorname{FFFFO}(\mathrm{H})$ through $\operatorname{FFFFF}(\mathrm{H})$ are reserved for system initialization. Initial execution begins at location $\operatorname{FFFFO}(\mathrm{H})$. Locations $00000(\mathrm{H})$ through $003 \mathrm{FF}(\mathrm{H})$ are reserved for interrupt vectors.


Figure 8. 8086 Real Address Mode Address Calculation


Figure 9. 8086 Real Address Mode Initially Reserved Memory Locations

## Reserved Memory Locations

The 80286 reserves two fixed areas of memory in real address mode (see Figure 9); system initializa-

Table 9. Real Address Mode Addressing Interrupts

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

## Interrupts

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

## Protected Mode Initialization

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

## Shutdown

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

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

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

## PROTECTED VIRTUAL ADDRESS MODE

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

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

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

## Memory Size

The protected mode 80286 provides a 1 gigabyte virtual address space per task mapped into a 16 megabyte physical address space defined by the address pin $A_{23}-A_{0}$ and $B H E$. The virtual address space may be larger than the physical address space since any use of an address that does not map to a physical memory location will cause a restartable exception.

## Memory Addressing

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


Figure 10. Protected Mode Memory Addressing

## DESCRIPTORS

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

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

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

Code or Data Segment Descriptor


Access Rights Byte Definition

\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[t]{3}{*}{} \& Blt Position \& Name \& \multicolumn{3}{|c|}{Function} \\
\hline \& 7
\(6-5\)
4 \& \begin{tabular}{l}
Present (P) \\
Descriptor Privilege Level (DPL) Segment Descriptor (S)
\end{tabular} \& \[
\begin{aligned}
\& P=1 \\
\& P=0 \\
\& S=1 \\
\& S=0
\end{aligned}
\] \& \multicolumn{2}{|l|}{\begin{tabular}{l}
Segment is mapped into physical memory. \\
No mapping to physical memory exits. base and limit are not used. \\
Segment privilege attribute used in privilege tests. \\
Code or Data (includes stacks) segment descriptor System Segment Descriptor or Gate Descriptor
\end{tabular}} \\
\hline \& 3
2
1 \& Executable (E) Expansion Direction (ED) Writeable (W) \& \[
\begin{aligned}
\& E=0 \\
\& E D=0 \\
\& E D=1 \\
\& W=0 \\
\& W=1
\end{aligned}
\] \& \begin{tabular}{l}
Data segment descriptor type is: \\
Expand up segment, offsets must be \(\leq\) limit. \\
Expand down segment, offsets must be > limit. \\
Data segment may not be written into. \\
Data segment may be written into.
\end{tabular} \& \begin{tabular}{l}
If \\
Data \\
Segment
\[
(S=1,
\]
\[
E=0 \text { ) }
\]
\end{tabular} \\
\hline \multirow[t]{2}{*}{\begin{tabular}{l}
Type \\
Field Definition
\end{tabular}} \& 3
2

1 \& | Executable (E) |
| :--- |
| Conforming (C) |
| Readable (R) | \& \[

$$
\begin{aligned}
& E=1 \\
& C=1 \\
& R=0 \\
& R=1
\end{aligned}
$$

\] \& | Code Segment Descriptor type is: Code segment may only be executed when CPL 2 DPL and CPL remains unchanged. |
| :--- |
| Code segment may not be read Code segment may be read. | \& If Code Segment

$$
\begin{aligned}
& (S=1, \\
& E=1)
\end{aligned}
$$ <br>

\hline \& 0 \& Accessed (A) \& $$
\begin{aligned}
& A=0 \\
& A=1
\end{aligned}
$$ \& \multicolumn{2}{|l|}{Segment has not been accessed. Segment selector has been loaded into segment register or used by selector test instructions.} <br>

\hline
\end{tabular}

Figure 11. Code and Data Segment Descriptor Formats

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

Data segments ( $S=1, E=0$ ) may be either readonly or read-write as controlled by the $W$ bit of the access rights byte. Read-only ( $\mathrm{W}=0$ ) data segments may not be written into. Data segments may grow in two directions, as determined by the Expansion Direction ( $E D$ ) bit: upwards ( $E D=0$ ) for data segments, and downwards (ED = 1) for a segment containing a stack. The limit field for a data segment descriptor is interpreted differently depending on the ED bit (see Figure 11).

A code segment ( $S=1, E=1$ ) may be executeonly or execute/read as determined by the Readable ( $R$ ) bit. Code segments may never be written into and execute-only code segments $(R=0)$ may not be read. A code segment may also have an attribute called conforming (C). A conforming code segment may be shared by programs that execute at different privilege levels. The DPL of a conforming code segment defines the range of privilege levels at which the segment may be executed (reter to privilege discussion below). The limit field identifies the last byte of a code segment.

## SYSTEM SEGMENT DESCRIPTORS ( $\mathbf{S}=\mathbf{0}$, TYPE $=1-3$ )

In addition to code and data segment descriptors, the protected mode 80286 defines System Segment Descriptors. These descriptors define special system data segments which contain a table of descriptors (Local Descriptor Table Descriptor) or segments which contain the execution state of a task (Task State Segment Descriptor).
Figure 12 gives the formats for the special system data segment descriptors. The descriptors contain a 24-bit base address of the segment and a 16-bit limit. The access byte defines the type of descriptor, its state and privilege level. The descriptor contents are valid and the segment is in physical memory if $P=1$. If $P=0$, the segment is not valid. The DPL field is only used in Task State Segment descriptors and indicates the privilege level at which the descrip-
tor may be used (see Privilege). Since the Local Descriptor Table descriptor may only be used by a special privileged instruction, the DPL field is not used. Bit 4 of the access byte is 0 to indicate that it is a system control descriptor. The type field specifies the descriptor type as indicated in Figure 12

## System Segment Descriptor



System Segment Descriptor Fields

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

Figure 12. System Segment Descriptor Format

## GATE DESCRIPTORS (S = 0, TYPE = 4-7)

Gates are used to control access to entry points within the target code segment. The gate descriptors are call gates, task gates, interrupt gates and trap gates. Gates provide a level of indirection between the source and destination of the control transfer. This indirection allows the CPU to automatically perform protection checks and control entry point of the destination. Call gates are used to change privilege levels (see Privilege), task gates are used to perform a task switch, and interrupt and trap gates are used to specify interrupt service routines. The interrupt gate disables interrupts (resets IF) while the trap gate does not.

Gate Descriptor


Gate Descriptor Fields

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

## Figure 13. Gate Descriptor Format

Figure 13 shows the format of the gate descriptors. The descriptor contains a destination pointer that points to the descriptor of the target segment and the entry point offset. The destination selector in an interrupt gate, trap gate, and call gate must refer to a code segment descriptor. These gate descriptors contain the entry point to prevent a program from constructing and using an illegal entry point. Task gates may only refer to a task state segment. Since task gates invoke a task switch, the destination offset is not used in the task gate.
Exception 13 is generated when the gate is used if a destination selector does not refer to the correct descriptor type. The word count field is used in the call gate descriptor to indicate the number of parameters ( $0-31$ words) to be automatically copied from the caller's stack to the stack of the called routine when a control transfer changes privilege levels. The word count field is not used by any other gate descriptor.
The access byte format is the same for all gate descriptors. $\mathbf{P}=1$ indicates that the gate contents are valid. $P=0$ indicates the contents are not valid and


Figure 14. Descriptor Cache Registers

## LOCAL AND GLOBAL DESCRIPTOR TABLES

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

One table, called the Global Descriptor table (GDT), contains descriptors available to all tasks. The other table, called the Local Descriptor Table (LDT), contains descriptors that can be private to a task. Each task may have its own private LDT. The GDT may contain all descriptor types except interrupt and trap descriptors. The LDT may contain only segment, task gate, and call gate descriptors. A segment cannot be accessed by a task if its segment descriptor does not exist in either descriptor table at the time of access.


Figure 16. Local and GIobal
Descriptor Table Definition
The LGDT and LLDT instructions load the base and limit of the global and local descriptor tables. LGDT and LLDT are privileged, i.e. they may only be executed by trusted programs operating at level 0 . The LGDT instruction loads a six byte field containing the 16 -bit table limit and 24 -bit physical base address of the Global Descriptor Table as shown in Figure 17. The LDT instruction loads a selector which refers to a Local Descriptor Table descriptor containing the
base address and limit for an LDT, as shown in Figure 12.


Figure 17. Global Descriptor Table and Interrupt Descriptor Table Data Type

## INTERRUPT DESCRIPTOR TABLE

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


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

## Privilege

The 80286 has a four-tevel hierarchical privilege system which controls the use of privileged instructions and access to descriptors (and their associated segments) within a task. Four-level privilege, as shown in Figure 19, is an extension of the user/supervisor mode commonly found in minicomputers. The privilege levels are numbered 0 through 3 . Level 0 is the

most privileged level. Privilege levels provide protection within a task. (Tasks are isolated by providing private LDT's for each task.) Operating system routines, interrupt handlers, and other system software can be included and protected within the virtual address space of each task using the four levels of privilege. Each task in the system has a separate stack for each of its privilege levels.
Tasks, descriptors, and selectors have a privilege level attribute that determines whether the descriptor may be used. Task privilege effects the use of instructions and descriptors. Descriptor and selector privilege only effect access to the descriptor.

## TASK PRIVILEGE

A task always executes at one of the four privilege levels. The task privilege level at any specific instant is called the Current Privilege Level (CPL) and is defined by the lower two bits of the CS register. CPL cannot change during execution in a single code segment. A task's CPL may only be changed by control transfers through gate descriptors to a new code segment (See Control Transfer). Tasks begin executing at the CPL value specified by the code segment selector within TSS when the task is initiated via a task switch operation (See Figure 20). A task executing at Level 0 can access all data segments defined in the GDT and the task's LDT and is considered the most trusted level. A task executing a Level 3 has the most restricted access to data and is considered the least trusted level.

## DESCRIPTOR PRIVILEGE

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

## SELECTOR PRIVILEGE

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

## Descriptor Access and Privilege Validation

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

## DATA SEGMENT ACCESS

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

An exception to the rule is a readable conforming code segment. This type of code segment can be read from any privilege level.
If the privilege checks fail (e.g. DPL is numerically less than the maximum of CPL and RPL) or an incorrect type of descriptor is referenced (e.g. gate de-
scriptor or execute only code segment) exception 13 occurs. If the segment is not present, exception 11 is generated.
Instructions that load selectors into SS must refer to data segment descriptors for writable data segments. The descriptor privilege (DPL) and RPL must equal CPL. All other descriptor types or a privilege level violation will cause exception 13. A not present fault causes exception 12

## CONTROL TRANSFER

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

The ability to reference a descriptor for control transfer is also subject to rules of privilege. A CALL or JUMP instruction may only reference a code segment descriptor with DPL equal to the task CPL or a conforming segment with DPL of equal or greater privilege than CPL. The RPL of the selector used to reference the code descriptor must have as much privilege as CPL

RET and IRET instructions may only reference code segment descriptors with descriptor privilege equal to or less privileged than the task CPL. The selector loaded into CS is the return address from the stack. After the return, the selector RPL is the task's new CPL. If CPL changes, the old stack pointer is popped after the return address.

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

The privilege rules on control transfer require:

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

Table 10. Descriptor Types Used for Control Transfer

| Control Transfer Types | Operation Types | Descriptor Referenced | $\begin{aligned} & \text { Deecriptor } \\ & \text { Table } \end{aligned}$ |
| :---: | :---: | :---: | :---: |
| Intersegment within the same privilege level | JMP. CALL, RET, IRET* | Code Segment | GDT/LDT |
| Intersegment to the same or higher privilege level Interrupt within task may change CPL | CALL | Call Gate | GDT/LDT |
|  | Interrupt Instruction. Exception, External Interrupt | Trap or Interrupt Gate | IDT |
| Intersegment to a lower privilege level (changes task CPL) | RET, IRET* | Code Segment | GDT/LDT |
|  | CALL. JMP | Task State Segment | GDT |
| Task Switch | CALL, JMP | Task Gate | GDT/LDT |
|  | IRET*" <br> Interrupt Instruction. Exception, External Interrupt | Task Gate | IDT |

[^0]
## PRIVILEGE LEVEL ChANGES

Any control transfer that changes CPL within the task, causes a change of stacks as part of the operation. Initial values of SS:SP for privilege levels 0,1 , and 2 are kept in the task state segment (refer to Task Switch Operation). During a JMP or CALL control transfer, the new stack pointer is loaded into the SS and SP registers and the previous stack pointer is pushed onto the new stack.
When returning to the original privilege level, its stack is restored as part of the RET or IRET instruction operation. For subroutine calls that pass parameters on the stack and cross privilege levels, a fixed number of words, as specified in the gate, are copied from the previous stack to the current stack. The inter-segment RET instruction with a stack adjustment value will correctly restore the previous stack pointer upon return.

## Protection

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

Restricted usage of segments (e.g. no write allowed to read-only data segments). The only segments available for use are defined by descriptors in the Local Descriptor Table (LDT) and Global Descriptor Table (GDT).
Restricted access to segments via the rules of privilege and descriptor usage.
Privileged instructions or operations that may only be executed at certain privilege levels as determined by the CPL and I/O Privilege Level (IOPL). The IOPL is defined by bits 14 and 13 of the flag word.
These checks are performed for all instructions and can be split into three categories: segment load checks (Table 11), operand reference checks (Table 12), and privileged instruction checks (Table 13). Any violation of the rules shown will result in an exception. A not-present exception related to the stack segment causes exception 12.

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

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

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

Table 11
Segment Register Load Checks

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

Table 12. Operand Reference Checks

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

## NOTE:

Carry out in offset calculations is ignored.
Table 13. Privileged Instruction Checks

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

## EXCEPTIONS

The 80286 detects several types of exceptions and interrupts, in protected mode (see Table 14). Most are restartable after the exceptional condition is removed. Interrupt handiers for most exceptions can read an error code, pushed on the stack after the return address, that identifies the selector involved ( 0 if none). The return address normally points to the failing instruction, including all leading prefixes. For a processor extension segment overrun exception, the return address will not point at the ESC instruction that caused the exception; however, the processor extension registers may contain the address of the failing instruction.

Table 14. Protected Mode Exceptions

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

## NOTE:

1. When a PUSHA or POPA instruction attempts to wrap around the stack segment, the machine state after the exception will not be restartable because stack segment wrap around is not permitted. This condition is identified by the value of the saved SP being either $0000(\mathrm{H})$, $0001(\mathrm{H})$, $\operatorname{FFFE}(\mathrm{H})$, or FFFF( H ).
2. These exceptions indicate a violation to privilege rules or usage rules has occurred. Restart is generally not attempted under those conditions.

These exceptions indicate a violation to privilege rules or usage rules has occurred. Restart is generally not attempted under those conditions.

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

## Speclal Operations

## TASK SWITCH OPERATION

The 80286 provides a built-in task switch operation which saves the entire 80286 execution state (registers, address space, and a link to the previous task), loads a new execution state, and commences execution in the new task. Like gates, the task switch operation is invoked by executing an inter-segment JMP or CALL instruction which refers to a Task State Segment (TSS) or task gate descriptor in the GDT or LDT. An INT n instruction, exception, or external interrupt may also invoke the task switch operation by selecting a task gate descriptor in the associated IDT descriptor entry.

The TSS descriptor points at a segment (see Figure 20) containing the entire 80286 execution state while a task gate descriptor contains a TSS selector. The limit field of the descriptor must be $>002 \mathrm{~B}(\mathrm{H})$.

Each task must have a TSS associated with it. The current TSS is identified by a special register in the 80286 called the Task Register (TR). This register contains a selector referring to the task state segment descriptor that defines the current TSS. A hidden base and limit register associated with TR are loaded whenever TR is loaded with a new selector.

The IRET instruction is used to return control to the task that called the current task or was interrupted. Bit 14 in the flag register is called the Nested Task (NT) bit. It controls the function of the IRET instruction. If NT $=0$, the IRET instruction performs the regular current task by popping values off the stack; when NT $=1$, IRET performs a task switch operation back to the previous task.
When a CALL, JMP, or INT instruction initiates a task switch, the old (except for case of JMP) and new TSS will be marked busy and the back link field of the new TSS set to the old TSS selector. The NT bit of the new task is set by CALL or INT initiated task switches. An interrupt that does not cause a task switch will clear NT. NT may also be set or cleared by POPF or IRET instructions.
The task state segment is marked busy by changing the descriptor type field from Type 1 to Type 3. Use of a selector that references a busy task state segment causes Exception 13.

## PROCESSOR EXTENSION CONTEXT SWITCHING

The context of a processor extension (such as the 80287 numerics processor) is not changed by the task switch operation. A processor extension context need only be changed when a different task attempts to use the processor extension (which still contains the context of a previous task). The 80286 detects the first use of a processor extension after a task switch by causing the processor extension not present exception (7). The interrupt handler may then decide whether a context change is necessary.
Whenever the 80286 switches tasks, it sets the Task Switched (TS) bit of the MSW. TS indicates that a processor extension context may belong to a different task than the current one. The processor extension not present exception (7) will occur when attempting to execute an ESC or WAIT instruction if $\mathrm{TS}=1$ and a processor extension is present (MP=1 in MSW).

## POINTER TESTING INSTRUCTIONS

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


Figure 20. Task State Segment and TSS Reglsters

Table 15. 80286 Pointer Test Instructions

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

## DOUBLE FAULT AND SHUTDOWN

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

## PROTECTED MODE INITIALIZATION

The 80286 initially executes in real address mode after RESET. To allow initialization code to be placed at the top of physical memory, $A_{23}-A_{20}$ will be HIGH when the 80286 performs memory references relative to the CS register until CS is changed. $A_{23}-A_{20}$ will be zero for references to the DS, ES, or SS segments. Changing CS in real address mode will force $A_{23}-A_{20}$ LOW whenever CS is used again. The initial CS:IP value of F000:FFF0 provides 64 K bytes of code space for initialization code without changing CS.
Protected mode operation requires several registers to be initialized. The GDT and IDT base registers must refer to a valid GDT and IDT. After executing the LMSW instruction to set PE, the 80286 must im-
mediately execute an intra-segment JMP instruction to clear the instruction queue of instructions decoded in real address mode.

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

## SYSTEM INTERFACE

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

## Bus Interface Signals and Timing

The 80286 microsystem local bus interfaces the 80286 to local memory and 1/O components. The interface has 24 address lines, 16 data lines, and 8 status and control signals.
The 80286 CPU, 82284 clock generator, 82288 bus controiler, 82289 bus arbiter, tranceivers, and latches provide a buffered and decoded system bus interface. The 82284 generates the system clock and synchronizes READY and RESET. The 82288 converts bus operation status encoded by the 80286 into command and bus control signals. The 82289 bus arbiter generates Multibus bus arbitration signals. These components can provide the timing and electrical power drive levels required for most system bus interfaces including the Multibus.

## Physical Memory and I/O Interface

A maximum of 16 megabytes of physical memory can be addressed in protected mode. One megabyte can be addressed in real address mode. Memory is accessible as bytes or words. Words consist of any two consecutive bytes addressed with the least significant byte stored in the lowest address.
Byte transfers occur on either half of the 16-bit local data bus. Even bytes are accessed over $D_{7-0}$ while odd bytes are transferred over $\mathrm{D}_{15-8}$. Even-addressed words are transferred over $D_{15-0}$ in one bus cycle, while odd-addressed word require two bus operations. The first transfers data on $D_{15-8}$, and the second transfers data on $D_{7-0}$. Both byte data transfers occur automatically, transparent to software.

Two bus signals, $A_{0}$ and $\overline{B H E}$, control transfers over the lower and upper halves of the data bus. Even address byte transfers are indicated by $A_{0}$ LOW and $\overline{\text { BHE HIGH. Odd address byte transfers are indicat- }}$ ed by $\mathrm{A}_{0} \mathrm{HIGH}$ and $\overline{\mathrm{BHE}}$ LOW. Both $\mathrm{A}_{0}$ and $\overline{\mathrm{BHE}}$ are LOW for even address word transfers.

The I/O address space contains 64 K addresses in both modes. The I/O space is accessible as either bytes or words, as is memory. Byte wide peripheral devices may be attached to either the upper or lower byte of the data bus. Byte-wide I/O devices attached to the upper data byte ( $\mathrm{D}_{15-8}$ ) are accessed with odd I/O addresses. Devices on the lower data byte are accessed with even I/O addresses. An interrupt controller such as intel's 8259A must be connected to the lower data byte $\left(D_{7-0}\right)$ for proper return of the interrupt vector.

## Bus Operation

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


Figure 21. System and Processor Clock Relationships
Six types of bus operations are supported; memory read, memory write, I/O read, I/O write, interrupt acknowledge, and halt/shutdown. Data can be transferred at a maximum rate of one word per two processor clock cycles.

The 80286 bus has three basic states: idle $\left(T_{i}\right)$, send status $\left(T_{s}\right)$, and perform command ( $\mathrm{T}_{\mathrm{c}}$ ). The 80286 CPU also has a fourth local bus state called hold $\left(T_{h}\right)$. $T_{h}$ indicates that the 80286 has surrendered control of the local bus to another bus master in response to a HOLD request.

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


Figure 22. 80286 Bus States

## Bus States

The idle ( $\mathrm{T}_{\mathrm{i}}$ ) state indicates that no data transfers are in progress or requested. The first active state $\mathrm{T}_{\mathbf{S}}$ is signaled by status line $\overline{\mathbf{S} 1}$ or $\mathbf{S 0}$ going LOW and identifying phase 1 of the processor clock. During $\mathrm{T}_{\mathrm{S}}$, the command encoding, the address, and data (for a write operation) are available on the 80286 output pins. The 82288 bus controller decodes the status signals and generates Multibus compatible read/write command and local transceiver control signals.
After $T_{S}$, the perform command ( $T_{C}$ ) state is entered. Memory or I/O devices respond to the bus operation during $T_{C}$, either transferring read data to the CPU or accepting write data. TC states may be repeated as often as necessary to assure sufficient time for the memory or I/O device to respond. The READY signal determines whether $T_{C}$ is repeated. $A$ repeated $T_{C}$ state is called a wait state.
During hold ( $T_{h}$ ), the 80286 will float all adioress, data, and status output pins enabling another bus master to use the local bus. The 80286 HOLD input signal is used to place the 80286 into the $T_{h}$ state. The 80286 HLDA output signal indicates that the CF - has entered $T_{h}$.

## Pipelined Addressing

The 80286 uses a local bus interface with pipelined timing to allow as much time as possible for data access. Pipelined timing allows a new bus operation to be initiated every two processor cycles, while allowing each individual bus operation to last for three processor cycles.

The timing of the address outputs is pipelined such that the address of the next bus operation becomes available during the current bus operation. Or in other words, the first clock of the next bus operation is overlapped with the last clock of the current bus operation. Therefore, address decode and routing logic can operate in advance of the next bus operation.


Figure 23. Basic Bus Cycle

External address latches may hold the address stable for the entire bus operation, and provide additional $A C$ and $D C$ buffering.

The 80286 does not maintain the address of the current bus operation during all $T_{c}$ states. Instead, the address for the next bus operation may be emitted during phase 2 of any $\mathrm{T}_{\mathrm{c}}$. The address remains valid during phase 1 of the first $T_{c}$ to guarantee hold time, relative to ALE, for the address latch inputs.

## Bus Control Signals

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

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

## Command Timing Controls

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

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

Command delay allows an increase of address or write data setup time to system bus command active for any bus operation by delaying when the system bus command becomes active. Command delay is controlled by the 82288 CMDLY input. After $\mathrm{T}_{\mathrm{S}}$, the bus controller samples CMDLY at each failing edge of CLK. If CMDLY is HIGH, the 82288 will not activate the command signal. When CMDLY is LOW, the 82288 will activate the command signal. After the command becomes active, the CMDLY input is not sampled.

When a command is delayed, the available response time from command active to return read data or accept write data is less. To customize system bus timing, an address decoder can determine which bus operations require delaying the command. The CMDLY input does not affect the timing of ALE, DEN, or DT/R.


Figure 24. CMDLY Controls the Leading Edge of Command Signal

Figure 24 illustrates four uses of CMDLY. Example 1 shows delaying the read command two system CLKs for cycle $\mathrm{N}-1$ and no delay for cycle N , and example 2 shows delaying the read command one system CLK for cycle $\mathrm{N}-1$ and one system CLK delay for cycle N .

## Bus Cycle Termination

At maximum transfer rates, the 80286 bus alternates between $t_{i}^{t}: a$ status and command states. The bus status signals become inactive after $\mathrm{T}_{\mathbf{s}}$ so that they may correctly signal the start of the next bus operation after the completion of the current cycle. No external indication of $T_{c}$ exists on the 80286 local bus. The bus master and bus controller enter $T_{c}$ directly after $T_{s}$ and continue executing $T_{c}$ cycles until terminated by READY.

## READY Operation

The current bus master and 82288 bus controller terminate each bus operation simultaneously to achieve maximum bus operation bandwidth. Both are informed in advance by READY active (opencollector output from 82284) which identifies the last $\mathrm{T}_{\mathrm{C}}$ cycle of the current bus operation. The bus master and bus controller must see the same sense of
the $\overline{\mathrm{READY}}$ signal, thereby requiring $\overline{\mathrm{READY}}$ be synchronous to the system clock.

## Synchronous Ready

The 82284 clock generator provides $\overline{R E A D Y}$ synchronization from both synchronous and asynchronous sources (see Figure 25). The synchronous ready input (SRDY) of the clock generator is sampled with the falling edge of CLK at the end of phase 1 of each $T_{c}$. The state of SRDY is then broadcast to the bus master and bus controller via the READY output line.

## Asynchronous Ready

Many systems have devices or subsystems that are asynchronous to the system clock. As a result, their ready outputs cannot be guaranteed to meet the 82284 SRDY setup and hold time requirements. But the 82284 asynchronous ready input ( $\overline{\text { ARDV }}$ ) is designed to accept such signals. The ARDY input is sampled at the beginning of each $T_{C}$ cycle by 82284 synchronization logic. This provides one system CLK cycle time to resolve its value before broadcasting it to the bus master and bus controller.

## NOTES:

210253-25

1. SRDYEN is active low.
2. If SRDYEN is high, the state of SRDY will no affect READY.
3. $\overline{\text { ARDYEN }}$ is active low.

Figure 25. Synchronous and Asynchronous Ready
$\overline{\text { ARDY }}$ or ARDYEN must be HIGH at the end of Ts. $\overline{\text { ARDY cannot be used to terminate bus cycle with no }}$ wait states.

Each ready input of the 82284 has an enable pin (SRDYEN and ARDYEN) to select whether the current bus operation will be terminated by the synchronous or asynchronous ready. Either of the ready inputs may terminate a bus operation. These enable inputs are active low and have the same timing as their respective ready inputs. Address decode logic usually selects whether the current bus operation should be terminated by $\overline{\text { ARDY }}$ or SRDY.

## Data Bus Control

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

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

## Bus Usage

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

## inter



Figure 26. Back to Back Read-Write Cycles


Flgure 27. Back to Back Write-Read Cycles


Figure 28. Back to Back Write-Write Cycles

## HOLD and HLDA

HOLD AND HLDA allow another bus master to gain control of the local bus by placing the 80286 bus into the $T_{h}$ state. The sequence of events required to pass control between the 80286 and another local bus master are shown in Figure 29.

In this example, the 80286 is initially in the $T_{h}$ state as signaled by HLDA being active. Upon leaving $T_{h}$, as signaled by HLDA going inactive, a write operation is started. During the write operation another local bus master requests the local bus from the 80286 as shown by the HOLD signal. After completing the write operation, the 80286 performs one $T_{i}$ bus cycle, to guarantee write data hold time, then enters $T_{h}$ as signaled by HLDA going active.
The CMDLY signal and $\overline{\text { ARDY ready are used to }}$ start and stop the write bus command, respectively. Note that SRDY must be inactive or disabled by SRDYEN to guarantee ARDY will terminate the cycle.

HOLD must not be active during the time from the leading edge of RESET until 34 CLKs following the trailing edge of RESET unless the 80286 is in the Halt condition. To insure that the 80286 remains in the Halt condition until the processor Reset operation is complete, no interrupts should occur after the execution of HLT until 34 CLKs after the trailing edge of the RESET puise.

## Lock

The CPU asserts an active lock signal during inter-rupt-Acknowledge cycles, the XCHG instruction, and during some descriptor accesses. Lock is also asserted when the LOCK prefix is used. The LOCK
prefix may be used with the following ASM-286 assembly instructions; MOVS, INS, and OUTS. For bus cycles other than Interrupt-Acknowledge cycles, Lock will be active for the first and subsequent cycles of a series of cycles to be locked. Lock will not be shown active during the last cycle to be locked. For the next-to-last cycle, Lock will become inactive at the end of the first $T_{c}$ regardless of the number of wait-states inserted. For interrupt-Acknowledge cycles, Lock will be active for each cycle, and will become inactive at the end of the first $T_{c}$ for each cycle regardless of the number of wait-states inserted.

## Instruction Fetching

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

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

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

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

In protected mode, the prefetcher will never cause a segment overrun exception. The prefetcher stops at the last physical memory word of the code segment. Exception 13 will occur if the program attempts to execute beyond the last full instruction in the code segment.

If the last byte of a code segment appears on an even physical memory address, the prefetcher will read the next physical byte of memory (perform a word code fetch). The value of this byte is ignored and any attempt to execute it causes exception 13.


Figure 29. MULTIBUS ${ }^{\text {© }}$ Write Terminated by Asynchronous Ready with Bus Hold

## Processor Extension Transfers

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

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

## Interrupt Acknowledge Sequence

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

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

Three idle processor clocks are provided by the 80286 between INTA bus operations to allow for the minimum INTA to INTA time and CAS (cascade address) out delay of the 8259A. The second INTA bus operation must always have at least one extra $T_{c}$ state added via logic controlling READY. This is needed to meet the 8259A minimum INTA pulse width.

## Local Bus Usage Priorities

The 80286 local bus is shared among several internal units and external HOLD requests. In case of simultaneous requests, their relative priorities are:
(Highest) Any transfers which assert LOCK either explicitly (via the LOCK instruction prefix) or implicitly (i.e. some segment descriptor accesses, interrupt acknowledge sequence, or an XCHG with memory).
The second of the two byte bus operations required for an odd aligned word operand.
The second or third cycle of a processor extension data transfer.
Local bus request via HOLD input.
Processor extension data operand transfer via PEREQ input.
Data transfer performed by EU as part of an instruction.
(Lowest) An instruction prefetch request from BU. The EU will inhibit prefetching two processor clocks in advance of any data transfers to minimize waiting by EU for a prefetch to finish.

## Halt or Shutdown Cycles

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

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


## NOTES:

1. Data is ignored, upper data bus, $D_{8}-D_{15}$, should not change state during this time.
2. First INTA cycle should have at least one wait state inserted to meet 8259A minimum INTA puise width
3. Second INTA cycle should have at least one wait state inserted to meet 8259A minimum INTA pulse width.
4. LOCK is active for the first INTA cycle to prevent the 82289 from releasing the bus between INTA cycles in a multimaster system. LOCK is also active for the second INTA cycle.
5. $A_{23}-A_{0}$ exits 3 -state OFF during $\phi 2$ of the second $T_{C}$ in the INTA cycle.
6. Upper data bus should not change state during this time.

Figure 30. Interrupt Acknowledge Sequence


Figure 31. Basic 80286 System Configuration

## SYSTEM CONFIGURATIONS

The versatile bus structure of the 80286 microsystem, with a full complement of support chips, allows flexible configuration of a wide range of systems. The basic configuration, shown in Figure 31, is similar to an 8086 maximum mode system. It includes the CPU plus an 8259A interrupt controller, 82284 clock generator, and the 82288 Bus Controller.

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

The 80287 has all the instructions and data types of an 8087. The 80287 NPX can perform numeric calculations and data transfers concurrently with CPU program execution. Numerics code and data have the same integrity as all other information protected by the 80286 protection mechanism.

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

The optional decode logic shown in Figure 31 takes advantage of the overlap between address and data of the 80286 bus cycle to generate advanced memory and 10 -select signals. This minimizes system


Figure 32. MULTIBUS* System Bus Interface
performance degradation caused by address propagation and decode delays. In addition to selecting memory and I/O, the advanced selects may be used with configurations supporting local and system buses to enable the appropriate bus interface for each bus cycle. The COD/NTA and M/IO signals are applied to the decode logic to distinguish between interrupt, I/O, code and data bus cycles.

By adding the 82289 bus arbiter chip, the 80286 provides a MULTIBUS system bus interface as shown in Figure 32. The ALE output of the 82288 for the

MULTIBUS bus is connected to its CMDLY input to delay the start of commands one system CLK as required to meet MULTIBUS address and write data setup times. This arrangement will add at least one extra $T_{c}$ state to each bus operation which uses the MULTIBUS.

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


Figure 33. 80286 System Conflguration with Dual-Ported Memory

Figure 33 shows the addition of dual ported dynamic memory between the MULTIBUS system bus and the 80286 local bus. The dual port interface is provided by the 8207 Dual Port DRAM Controller. The 8207 runs synchronously with the CPU to maximize throughput for local memory references. It also arbitrates between requests from the local and system buses and performs functions such as refresh,
initialization of RAM, and read/modify/write cycles. The 8207 combined with the 8206 Error Checking and Correction memory controller provide for single bit error correction. The dual-ported memory can be combined with a standard MULTIBUS system bus interface to maximize performance and protection in multiprocessor system configurations.

Table 16. 80286 Systems Recommended Pull Up Resistor Values

| 80286 PIn and Name | Pullup Value | Purpose |
| :---: | :---: | :---: |
| 4-51 | $20 \mathrm{~K} \Omega \pm 10 \%$ | Pull $\overline{\mathbf{S O}}, \overline{\mathrm{S1} 1}$, and $\overline{\mathrm{PE} E A C K}$ inactive during 80286 hold periods |
| 5-50 |  |  |
| 6-PEACR |  |  |
| 53-ERROR | $20 \mathrm{~K} \Omega \pm 10 \%$ | Pull ERROR and EUSY inactive when 80287 not present (or temporarily removed from socket) |
| 54-BUSY |  |  |
| 63-READY | $910 \Omega \pm 5 \%$ | Pull $\overline{R E A D Y}$ inactive within required minimum time $\left(C_{L}=150 \mathrm{pF}\right.$, $\left.I_{R} \leq 7 \mathrm{~mA}\right)$ |

## ${ }^{12}$ ICETM -286 System Design <br> \section*{Considerations}

One of the advantages of using the 80286 is that full in-circuit emulation debugging support is provided through the $\mathrm{I}^{2} \mid \mathrm{CE}$ system 80286 probe. To utilize this powerful tool it is necessary that the system designer be aware of a few minor parametric and
functional differences between the 80286 and 12ICE system 80286 probe. The ${ }^{2} \mid$ ICE data sheet (I2ICE Integrated Instrumentation and In-Circuit Emulation System, order \#210469) contains a detailed description of these design considerations. It is recommended that this document be reviewed by the 80286 system designer to determine whether or not these differences affect his design.

## ABSOLUTE MAXIMUM RATINGS*

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

Respect to Ground. . . . . . . . . . . . . . -1.0 V to +7 V
Power Dissipation .3.3W
*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{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\text {CASE }}=0^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Min | Max | Unit | Test Condition |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{\mathrm{IL}}$ | Input LOW Voltage | -.5 | .8 | V |  |
| $V_{\mathrm{IH}}$ | Input HIGH Voltage | 2.0 | $V_{C C}+.5$ | $V$ |  |
| $V_{\mathrm{ILC}}$ | CLK Input LOW Voltage | -.5 | .6 | V |  |
| $V_{\mathrm{IHC}}$ | CLK Input HIGH Voltage | 3.8 | $V_{C C}+.5$ | $V$ |  |

D.C. CHARACTERISTICS $\left(V_{C C}=5 V \pm 5 \%, T_{\text {CASE }}=0^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Min | Max | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\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{lOH}=-400 \mu \mathrm{~A}$ |
| ILI | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| LCR | Input CLK Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ILCR | Input CLK Leakage Current |  | $\pm 1$ | mA | $0 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq 0.45 \mathrm{~V}$ |
| ILL | Input Sustaining Current on BUSY and ERROR Pins | 30 | 500 | $\mu \mathrm{A}$ | $V_{1 N}=0 \mathrm{~V}$ |
| Lo | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| LLO | Output Leakage Current |  | $\pm 1$ | $m \mathrm{~A}$ | $0 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }}<0.45 \mathrm{~V}$ |
| lcc | Supply Current |  | 600 | mA | $25^{\circ} \mathrm{C}, 1 \mathrm{OH}$ Max |
| $\mathrm{C}_{\text {CLK }}$ | CLK Input Capacitance |  | 20 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |
| $\mathrm{CIN}^{\text {N }}$ | Other Input Capacitance |  | 10 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |
| $\mathrm{Co}_{0}$ | Input/Output Capacitance |  | 20 | pF | $F_{C}=1 \mathrm{MHz}$ |

A.C. CHARACTERISTICS $\left(V_{C C}=5 \mathrm{~V} \pm 5 \%, T_{C A S E}=0^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}\right)^{*}$

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

| Symbol | Parameter | 6 MHz |  | 8 MHz |  | 10 MHz(Prellminary) |  | $\begin{gathered} 12.5 \mathrm{MHz} \\ \text { (Prellminary) } \end{gathered}$ |  | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{array}{\|c\|} \hline-6 \\ \text { Min } \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline-6 \\ \operatorname{Max} \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline-8 \\ \text { MIn } \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline-8 \\ \text { Max } \\ \hline \end{array}$ | $\begin{aligned} & -10 \\ & \text { Min } \end{aligned}$ | $\begin{aligned} & -10 \\ & \text { Max } \end{aligned}$ | $\begin{aligned} & -12 \\ & \operatorname{Max} \\ & \hline \end{aligned}$ | $\begin{aligned} & -12 \\ & \text { Min } \end{aligned}$ |  |  |
| 1 | System Clock (CLK) Period | 83 | 250 | 62 | 250 | 50 | 250 | 40 | 250 | ns |  |
| 2 | System Clock (CLK) LOW Time | 20 | 225 | 15 | 225 | 12 | 232 | 11 | 237 | ns | at 1.0 V |
| 3 | System Clock (CLK) HIGH Time | 25 | 230 | 25 | 235 | 16 | 238 | 13 | 239 | ns | at 3.6 V |
| 17 | System Clock (CLK) Rise Time |  | 10 |  | 10 |  | 8 | - | 8 | ns | 1.0 V to 3.6 V |
| 18 | System Clock (CLK) Fall Time |  | 10 |  | 10 |  | 8 | - | 8 | ns | 3.6 V to 1.0 V |
| 4 | Asynch. Inputs Setup Time | 30 |  | 20 |  | 20 |  | 15 |  | ns | Note 1 |
| 5 | Asynch. Inputs Hold Time | 30 |  | 20 |  | 20 |  | 15 |  | ns | Note 1 |
| 6 | RESET Setup Time | 33 |  | 28 |  | 23 |  | 18 |  | ns |  |
| 7 | RESET Hold Time | 5 |  | 5 |  | 5 |  | 5 |  | ns |  |
| 8 | Read Data Setup Time | 20 |  | 10 |  | 8 |  | 5 |  | ns |  |
| 9 | Read Data Hold Time | 8 |  | 8 |  | 8 |  | 6 |  | ns |  |
| 10 | READY Setup Time | 50 |  | 38 |  | 26 |  | 22 |  | ns |  |
| 11 | READY Hold Time | 35 |  | 25 |  | 25 |  | 20 |  | ns |  |
| 12 | Status/PEACK Valid Delay | 1 | 55 | 1 | 40 | - | - | - | - | ns | Note 2 Note 3 |
| 12a | Status/PEACK Active Delay | - | - | - | - | 1 | 22 | 3 | 18 | ns | Note 2 Note 3 |
| 12b | Status/PEACK Inactive Delay | - | - | - | - | 1 | 30 | 3 | 20 | ns | Note 2 Note 3 |
| 13 | Address Valid Delay | 1 | 80 | 1 | 60 | 1 | 35 | 1 | 32 | ns | Note 2 Note 3 |
| 14 | Write Data Valid Delay | 0 | 65 | 0 | 50 | 0 | 30 | 0 | 30 | ns | Note 2 Note 3 |
| 15 | Address/Status/Data Float Delay | 0 | 80 | 0 | 50 | 0 | 47 | 0 | 32 | ns | Note 2 Note 4 |
| 16 | HLDA Valid Delay | 0 | 80 | 0 | 50 | 0 | 47 | 0 | 25 | ns | Note 2 Note 3 |
| 19 | Address Valid To Status Valid Setup Time | - |  | 38 |  | 27 |  | 22 |  | ns | Note 3 <br> Note 5 Note 6 |

${ }^{*} T_{A}$ is guaranteed as long as $T_{\text {CASE }}$ is not exceeded.

## NOTES:

1. Asynchronous inputs are INTR, NMI, HOLD, PEREQ, ERROR, and BUSY. This specification is given only for testing purposes, to assure recognition at a specific CLK edge.
2. Delay from 1.0 V on the CLK, to 0.8 V or 2.0 V or float on the output as appropriate for valid or floating condition.
3. Output load: $C_{L}=100 \mathrm{pF}$.
4. Float condition occurs when output current is less than ILO in magnitude.
5. Delay measured from address either reaching 0.8 V or 2.0 V (valid) to status going active reaching 2.0 V or status going inactive reaching 0.8 V .
6. For load capacitance of 10 pF on STATUS/PEACK lines, subtract typically 7 ns for 8 MHz spec, and maximum 7 ns for 10 MHz spec.
A.C. CHARACTERISTICS (Continued)


NOTE 7:
AC Test Loading on Outputs


## A.C. CHARACTERISTICS (Continued)

## 82284 Timing Requirements

| Symbol | Parameter | 82284-6 |  | 82284-8 |  | $\begin{gathered} \hline 82284-10 \\ \text { (Preliminary) } \\ \hline \end{gathered}$ |  | Units | Test Condilions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| 11 | $\overline{\text { SRDY/SRDYEN Setup Time }}$ | 25 |  | 17 |  | 15 |  | ns |  |
| 12 | $\overline{\text { SRDY/SRDYEN }}$ Hold Time | 0 |  | 0 |  | 0 |  | ns |  |
| 13 | $\overline{\text { ARDY / ARDYEN }}$ Setup Time | 5 |  | 0 |  | 0 |  | ns | (Note 1) |
| 14 | $\overline{\text { ARDY } / \overline{A R D Y E N ~}}$ Hold Time | 30 |  | 30 |  | 30 |  | ns | (Note 1) |
| 19 | PCLK Delay | 0 | 45 | 0 | 45 | 0 | 35 | ns | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=75 \mathrm{pF} \\ & \mathrm{l}_{\mathrm{OL}}=5 \mathrm{~mA} \\ & \mathrm{O}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |

NOTE 1:
These times are given for testing purposes to assure a predetermined action.

82288 Timing Requirements

| Symbol | Parameter |  | 82288-6 |  | 82288-8 |  | $\begin{gathered} 82288-10 \\ \text { (Preliminary) } \\ \hline \end{gathered}$ |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |  |
| 12 | CMDLY Setup Time |  | 25 |  | 20 |  | 15 |  | ns |  |
| 13 | CMDL Y Hold Time |  | 1 |  | 1 |  | 1 |  | ns |  |
| $\begin{aligned} & 30 \\ & 29 \end{aligned}$ | Command Delay from CLK | Command Inactive | 5 | 30 | 5 | 25 | 5 | 20 | ns | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF} \text { max } \\ & \mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA} \text { max } \\ & \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA} \text { max } \end{aligned}$ |
|  |  | Command Active | 3 | 40 | 3 | 25 | 3 | 21 |  |  |
| 16 | ALE Active Delay |  | 3 | 25 | 3 | 20 | 3 | 16 | ns | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \text { max } \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \text { max } \end{aligned}$ |
| 17 | ALE Inactive Delay |  |  | 35 |  | 25 |  | 19 | ns |  |
| 19 | DT/信 Read Active Delay |  |  | 40 |  | 25 |  | 23 | ns |  |
| 22 | DT/可 Read Inactive Delay |  | 5 | 45 | 5 | 35 | 5 | 20 | ns |  |
| 20 | DEN Read Active Delay |  | 5 | 50 | 5 | 35 | 5 | 21 | ns |  |
| 21 | DEN Read Inactive Delay |  | 3 | 40 | 3 | 35 | 3 | 21 | ns |  |
| 23 | DEN Write Active Delay |  |  | 35 |  | 30 |  | 23 | ns |  |
| 24 | DEN Write Inactive Delay |  | 3 | 35 | 3 | 30 | 3 | 19 | ns |  |

## inter

## 80286

WAVEFORMS


NOTE:

1. The modified timing is due to the $\overline{\mathrm{CMDLY}}$ signal being active.

WAVEFORMS (Contirued)

## 80286 ASYNCHRONOUS INPUT SIGNAL TIMING



## NOTES:

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


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

## EXITING AND ENTERING HOLD



## NOTES:

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

WAVEFORMS (Continued)

## 80286 PEREQ/PEACK TIMING FOR ONE TRANSFER ONLY



ASSUMING WORD-ALIGNED MEMORY OPERAND. IF ODD ALIGNED. 80285 TRANSFERS TO/FROM MEMOAY BYTE-AT-A-TMME WITH TWO MEMORY CYCLES.

## NOTES:

1. $\overline{\text { PEACK }}$ always goes active during the first bus operation of a processor extension data operand transfer sequence. The first bus operation will be either a memory read at operand address or $1 / 0$ read at port address OOFA(H).
2. To prevent a second processor extension data operand transier, the woret case maximum time (Shown above) is: $3 \times$ a

$A$ is the number of extra $T_{C}$ states added to either the first or secord bus operaticr the processor extension data operand transfer sequence.

## INITIAL 80286 PJN STATE DURING RESET



NOTES:

1. Setup time for RESET $\uparrow$ may be violated with the consideration that $\phi 1$ of the processor ciock may begin one system CLK period later.
2. Setup and hold times for RESET $\downarrow$ must be met for proper operation, but RESET $\downarrow$ may occur during $\phi 1$ or $\phi 2$.
3. The data bus is only guaranteed to be in 3-state OFF at the time shown.


Figure 35. 80286 Instruction Format Examples

## 80286 INSTRUCTION SET SUMMARY

## Instruction Timing Notes

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

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

## Instruction Clock Count Assumptions

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

## Instruction Set Summary Notes

Addressing displacements selected by the MOD field are not shown. If necessary they appear after the instruction fields shown.

Above/below refers to unsigned value
Greater refers to positive signed value
Less refers to less positive (more negative) signed values
if $d=1$ then to register; if $d=0$ then from register
if $\mathbf{w}=1$ then word instruction; if $\mathbf{w}=0$ then byte instruction
if $s=0$ then 16 -bit immediate data form the operand
if $s=1$ then an immediate data byte is sign-extended to form the 16 -bit operand
$x$ don't care
z used for string primitives for comparison with ZF FLAG

If two clock counts are given, the smaller refers to a register operand and the larger refers to a memory operand

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

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

## REAL ADDRESS MODE ONLY

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

## EITHER MODE

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

## PROTECTED VIRTUAL ADDRESS MODE ONLY

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

80286 INSTRUCTION SET SUMMARY


Shaded areas indicate instructions not available in 8086, 88 microsystems.
All mnemonics copyright Intel Corporation 1987.

80286 INSTRUCTION SET SUMMARY (Continued)

| FUNCTION | FORMAT |  |  |  | CLOCK COUNT |  | COMMENTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Real Addrass Mode | Protected Virtual Address Mode | Real <br> Address Mode | Protected Virtual Address Mode |
| DATA TRANSFER (Continued) |  |  |  |  |  |  |  |  |
| LAHF Load AH with flags | 10011111 |  |  |  | 2 | 2 |  |  |
| SAHF $=$ Store AH into flags | 10011110 |  |  |  | 2 | 2 |  |  |
| PUSHF = Push flags | 10011100 |  |  |  | 3 | 3 | 2 | 9 |
| POPF $=$ Pop flags | 10011101 |  |  |  | 5 | 5 | 2.4 | 9.15 |
| ARITHMETIC ADD = Add: |  |  |  |  |  |  |  |  |
| Feg/memory with register to either | 000000 dw | modreg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| Immediate to register/memory | 100000 sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s} w=01$ | 3,7* | 3,7* | 2 | 9 |
| Immediate to accumulator | 0000010 w | data | data if $w=1$ |  | 3 | 3 |  |  |
| ADC = Add with carry: |  |  |  |  |  |  |  |  |
| Reg/memory with register to either | 000100 dw | modreg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| Immediate to register/memory | 100000 sw | $\bmod 010 \mathrm{f} / \mathrm{m}$ | data | data if $\mathrm{s} \mathbf{w}=01$ | 3,7* | 3,7* | 2 | 9 |
| mmediate to accumulator | 000:010w | data | data if $w=1$ |  | 3 | 3 |  |  |
| \|NC = Increment: |  |  |  |  |  |  |  |  |
| Aegister/memory | 1111111 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |  |  | $2.7 *$ | 2,7* | 2 | 9 |
| Register | 01000 reg |  |  |  | 2 | 2 |  |  |
| SUB $=$ Subtract: |  |  |  |  |  |  |  |  |
| Reg/memory and register to either | 001010 dw | modreg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| Immediate from register/memory | 100000 sw | mad $101 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s} w=01$ | 3,7* | 3,7* | 2 | 9 |
| Immediate from accumulator | 0010110 w | data | data if $w=1$ |  | 3 | 3 |  |  |
| SBE = Subtract with borrow: |  |  |  |  |  |  |  |  |
| Reg/memory and register to either | 000110 dw | modreg r/m |  |  | 2,7* | 2,7* | 2 | 9 |
| Immediate from register/memory | 100000 sw | $\bmod 011 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s} w=01$ | 3,7* | 3,7* | 2 | 9 |
| Immediate from accumulator | 0001110 w | data | data if $w=1$ |  | 3 | 3 |  |  |
| DEC $=$ Decrement |  |  |  |  |  |  |  |  |
| Pegister/memory | 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |  |  | $2.7 *$ | 2,7* | 2 | 9 |
| Pegister | 01001 reg |  |  |  | 2 | 2 |  |  |
| CMP = Compare |  |  |  |  |  |  |  |  |
| Register/memory with register | 0011101 w | modreg $\quad \mathrm{r} / \mathrm{m}$ |  |  | 2,6' | 2,6* | 2 | 9 |
| Register with register/memory | 0011100 w | modreg r/m |  |  | 2,7* | $2.7^{*}$ | 2 | 9 |
| mmediate with register/memory | 100000sw | mod $111 \mathrm{r} / \mathrm{m}$ | data | data if $s w=01$ | 3,6* | 3,6* | 2 | 9 |
| mmediate with accumulator | 0011110 w | data | data if w=1 |  | 3 | 3 |  |  |
| NEG $=$ Change sign | 1111011 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ |  |  | 2 | 7* | 2 | 9 |
| AAA $=$ ASCII adjust for add | 00110111 |  |  |  | 3 | 3 |  |  |
| DAA $=$ Decimal adjust for add | 00100111 |  |  |  | 3 | 3 |  |  |

All mnemonics copyright Intel Corporation 1987.

80286 INSTRUCTION SET SUMMARY (Continued)


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

$$
\text { All mnemonics copyright Intel Corporation } 1987 .
$$

inter

80286 INSTRUCTION SET SUMMARY (Continued)


Shaded areas indicate instructions not available in 8086, 88 microsystems.
All mnemonics copyright Intel Corporation 1987.

80286 INSTRUCTION SET SUMMARY (Continued)


All mnemonics copyright Intel Corporation 1987.

80286 INSTRUCTION SET SUMMARY (Continued)


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

All mnemonics copyright Intel Corporation 1987.

80286 INSTRUCTION SET SUMMARY (Continued)


[^1]All mnemonics copyright Intel Corporation 1987.

80286 INSTRUCTION SET SUMMARY (Continued)


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

All mnemonics copyright Intel Corporation 1987.

## Footnotes

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

REG is assigned according to the following table:

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

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

SEGMENT OVERRIDE PREFIX
001 reg 1110
reg is assigned according to the following:

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

All mnemonics copyright Intel Corporation 1987.

80287
80-BIT HMOS
NUMERIC PROCESSOR EXTENSION (80287-3, 80287-6, 80287-8, 80287-10)

- High Performance 80-Bit Internal Architecture
- Implements Proposed IEEE Floating Point Standard 754
- Expands 80286 Data types to Include 32-, 64-, 80-Bit Floating Point, 32-, $64-$ Bit Integers and 18-Digit BCD Operands
- Object Code Compatible with 8087
- Built-in Exception Handling
- Operates in Both Real and Protected Mode 80286 Systems
■ 8x80-Bit, Individually Addressable, Numeric Register Stack
- Protected Mode Operation Completely Conforms to the $\mathbf{8 0 2 8 6}$ Memory Management and Protection Mechanisms

■ Directly Extends 80286 Instruction Set to Trigonometric, Logarithmic, Exponential and Arithmetic Instructions for All Data types

- Operates with 80386 CPU without Software Modification
- Avallable In EXPRESS-Standard Temperature Range
- Avallable in $\mathbf{4 0}$ pin-CERDIP package (see Packaging Spec: Order *231369)

The Intel 80287 is a high performance numerics processor extension that extends the 80286 architecture with floating point, extended integer and BCD data types. The 80286/80287 computing system fully conforms to the proposed IEEE Floating Point Standard. Using a numerics oriented architecture, the 80287 adds over fifty mnemonics to the 80286/80287 instruction set, making the 80286/80287 a complete solution for high performance numeric processing. The 80287 is implemented in N -channel, depletion load, silicon gate technology (HMOS) and packaged in a 40-pin cerdip package. The 80286/80287 is object code compatible with the 8086/8087 and 8088/8087.


Figure 1. 80287 Block Diagram


NOTE:
N/C Pins should not be connected
Figure 2.
80287 Pin Configuration

Table 1. 80287 Pin Description

| Symbols | Type | Name and Functon |
| :---: | :---: | :---: |
| CLK | 1 | CLOCK INPUT: this clock provides the basic timing for internal 80287 operations. Special MOS level inputs are required. The 82284 or 8284A CLK outputs are compatible to this input. |
| CKM | 1 | CLOCK MODE SIGNAL: indicates whether CLK input is to be divided by 3 or used directly. A HIGH input will cause CLK to be used directly. This input must be connected to $\mathrm{V}_{C c}$ or $\mathrm{V}_{S S}$ as appropriate. This input must be either HIGH or LOW 20 CLK cycles before RESET goes LOW. |
| RESET | 1 | SYSTEM RESET: causes the 80287 to immediately terminate its present activity and enter a dormant state. RESET is required to be HIGH for more than 480287 CLK cycles. For proper initialization the HIGH-LOW transition must occur no sooner than $50 \mu \mathrm{~s}$ after $\mathrm{V}_{\mathrm{CC}}$ and CLK meet their D.C. and A.C. specifications. |
| D15-D0 | 1/0 | DATA: 1-bit bidirectional data bus. Inputs to these pins may be applied asynchronous to the 80287 clock. |
| $\overline{B U S Y}$ | 0 | BUSY STATUS: asserted by the 80287 to indicate that it is currently executing a command. |
| ERROR | 0 | ERROR STATUS: reflects the ES bit of the status word. This signal indicates that an unmasked error condition exists. |
| PEREQ | 0 | PROCESSOR EXTENSION DATA CHANNEL OPERAND TRANSFER REQUEST: a HIGH on this output indicates that the 80287 is ready to transfer data. PEREQ will be disabled upon assertion of PEACK or upon actual data transfer, whichever occurs first, if no more transfers are required. |
| PEACK | 1 | PROCESSOR EXTENSION DATA CHANNEL OPERAND TRANSFER ACKNOWLEDGE: acknowledges that the request signal (PEREQ) has been recognized. Will cause the request (PEREQ) to be withdrawn in case there are no more transfers required. PEACK may be asynchronous to the 80287 clock. |
| $\overline{\text { NPRD }}$ | 1 | NUMERIC PROCESSOR READ: Enables transfer of data from the 80287. This input may be asynchronous to the 80287 clock. |
| NPWR | 1 | NUMERIC PROCESSOR READ: Enables transfer of data from the 80287. This input may be asynchronous to the 80287 clock. |
| $\overline{\text { NPS1, }}$ NPS2 | 1 | NUMERIC PROCESSOR SELECTS: indicate the CPU is performing an ESCAPE instruction. Concurrent assertion of these signals (i.e., NPS1 is LOW and NPS2 is HIGH) enables the 80287 to perform floating point instrucctions. No data transfers involving the 80287 will occur unless the device is selected via these lines. These inputs may be asynchronous to the 80287 clock. |
| CMD1, CMD0 | 1 | COMMAND LINES: These, along with select inputs, allow the CPU to direct the operation of the 80287. <br> These inputs may be asynchronous to the 80287 clock. |

Table 1. 80187 Pin Description (Continued)

| Symbols | Type | Name and Function |
| :---: | :---: | :--- |
| $V_{S S}$ | 1 | System ground, both pins must be connected to ground. |
| $V_{C C}$ | 1 | +5 V supply |

## FUNCTIONAL DESCRIPTION

The 80287 Numeric Processor Extension (NPX) provides arithmetic instructions for a variety of numeric data types in 80286/80287 systems. It also executes numerous built-in transcendental functions (e.g., tangent and log functions). The 80287 executes instructions in parallel with an 80286. It effec-
tively extends the register and instruction set of an 80286 system for existing 80286 data types and adds several new data types as well. Figure 3 presents the program visible register model of the 80286/80287. Essentially, the 80287 can be treated as an additional resource or an extension to the 80286 that can be used as a single unified system, the 80286/80287.


Figure 3. 80286/80287 Architecture

The 80287 has two operating modes similar to the two modes of the 80286. When reset, 80287 is in the real address mode. It can be placed in the protected virtual address mode by executing the SETPM ESC instruction. The 80287 cannot be switched back to the real address mode except by reset. In the real address mode, the 80286/80287 is completely software compatible with 8086/8087 and 8088/8087.

Once in protected mode, all references to memory for numerics data or status information, obey the 80286 memory management and protection rules giving a fully protected extension of the 80286 CPU. In the protected mode, 80286/80287 numerics software is also completely compatible with 8086/8087 and 8088/8087.

## SYSTEM CONFIGURATION WITH 80286

As a processor extension to an 80286, the 80287 can be connected to the CPU as shown in Figure 4A. The data channel control signals (PEREQ, PEACK), the BUSY signal and the NPRD, NPWR signals, allow the NPX to receive instructions and data from the CPU. When in the protected mode, all information received by the NPX is validated by the 80286 memory management and protection unit. Once started, the 80287 can process in parallel with and independent of the host CPU. When the NPX detects an error or exception, it will indicate this to the CPU by asserting the ERROR signal.

The NPX uses the processor extension request and acknowledge pins of the 80286 CPU to implement data transfers with memory under the protection model of the CPU. The full virtual and physical address space of the 80286 is available. Data for the 80287 in memory is addressed and represented in the same manner as for an 8087.

The 80287 can operate either directly from the CPU clock or with a dedicated clock. For operation with the CPU clock (CKM $=0$ ), the 80287 works at onethird the frequency of the system clock (i.e., for an 8 MHz 80286 , the 16 MHz system clock is divided down to 5.3 MHz ). The 80287 provides a capability to internally divide the CPU clock by three to produce the required internal clock ( $33 \%$ duty cycle). To use a higher performance 80287 ( 8 MHz ), an 8284A clock driver and appropriate crystal may be used to directly drive the 80287 with a $1 / 3$ duty cycle clock on the CLK input (CKM = 1). The foilowing table describes the relationship between the clock speed and the 287 operating speed as a function of the CKM state.

| 287 Speed | CLK Spead |  |
| :---: | :---: | :---: |
|  | CKM $=0$ | CKM $=1$ |
| 5 MHz | 12 MHz | 5 MHz |
| 6 MHz | 16 MHz | 6 MHz |
| 8 MHz | 20 MHz | 8 MHz |
| 10 MHz | 25 MHz | 10 MHz |

## SYSTEM CONFIGURATION WITH 80386

The 80287 can also be connected as a processor extension to the 80386 CPU as shown in Figure 4b. All software written for 8086/8087 and 80286/ 80287 is object code compatible with $80386 / 80287$ and can benefit from the increased speed of the 80386 CPU.

Note that the PEACK input pin is pulled high. This is because the 80287 is not required to keep track of the number of words transterred during an operand transfer when it is connected to the 80386 CPU . Unlike the 80286 CPU, the 80386 CPU knows the exact length of the operand being transferred to/from the 80287. After an ESC instruction has been sent to the 80287, the 80386 processor extension data channel will initiate the data transfer as soon as it receives the PEREQ signal from the 80287. The transfer is automatically terminated by the 80386 CPU as soon as all the words of the operand have been transferred.

Because of the very high speed local local bus of the 80386 CPU , the 80287 cannot reside directly on the CPU local bus. A local bus controller logic is used to generate the necessary read and write cycle timings as well as the chip select timings for the 80287. The 80386 CPU uses 1/O addresses 800000F8 through 800000FF to communicate with the 80287. This is beyond the normal I/O address space of the CPU and makes it easier to generate the chip select signals using A31 and M/IO. It may also be noted that the 80386 CPU automatically generates 16 -bit bus cycles whenever it communicates with the 80287.

## HARDWARE INTERFACE

Communication of instructions and data operands between the 80286 and 80287 is handled by the CMD0, CMD1, $\overline{N P S} 1$, NPS2, $\overline{\text { NPRD, and NPWR sig- }}$ nals. I/O port addresses $00 \mathrm{~F} 8 \mathrm{H}, 00 \mathrm{FAH}$, and 00 FCH are used by the 80286 for this communication. When any of these addresses are used, the NPS1 input must be LOW and NPS2 input HIGH. The $\overline{\text { IOAC }}$ and IOWC outputs of the 82288 identify $1 / O$ space transfers (see Figure 4A). CMDO should be connected to latched 80286 A1 and CMD1 should be connected to latched 80286 A2.

1/O ports 00F8H to 00FFH are reserved for the 80286/80287 interface. To guarantee correct operation of the 80287, programs must not perform any I/O operations to these ports.

The PEREQ, $\overline{P E A C K}, \overline{B U S Y}$, and $\overline{E R R O R}$ signals of the 80287 are connected to the same-named 80286 input. The data pins of the 80287 should be directly connected to the 80286 data bus. Note that all bus drivers connected to the 80286 local bus must be inhibited when the 80286 reads from the 80287. The use of $M / \overline{\mathrm{IO}}$ in the decoder prevents INTA bus cycles from disabling the data transceivers.

## PROGRAMMING INTERFACE

Table 2 lists the seven data types the 80287 supports and presents the format for each type. These
values are stored in memory with the least significant digits at the lowest memory address. Programs retrieve these values by generating the lowest address. All values should start at even addresses for maximum system performance.

Internally the 80287 holds all numbers in the temporary real format. Load instructions automatically convert operands represented in memory as $16-, 32$-, or 64 -bit integers, 32 - or 64 -bit floating point number or

18-digit packed BCD numbers into temporary real format. Store instructions perform the reverse type conversion.

80287 computations use the processor's register stack. These eight 80 -bit registers provide the equivalent capacity of 4016 -bit registers. The 80287 register set can be accessed as a stack, with instructions operating on the top one or two stack elements, or as a fixed register set, with instructions operating on explicitly designated registers.


Figure 4A. 80286/80287 System Configuration


210920-5
Figure 4B. 80386/80287 System Configuration

Table 2. 80287 Data Type Representation In Memory


## NOTES:

210920-6

1. $S=$ Sign bit $(0=$ positive, $1=$ negative $)$
2. $d_{n}=$ Decimal digit (two per byte)
3. $X=$ Bits have no significance; 8087 ignores when loading, zeros when storing.
4. $\Delta=$ Position of implicit binary point
5. I = Integer bit of significant; stored in temporary real, implicit in short and long real.
6. Exponent Bias (normalized values):

Short Real: 127 (7FH)
Long Real: 1023 (3FFH)
Temporary Real: 16383 (3FFFH)
7. Packed BCD: $(-1)^{s}\left(D_{17} \ldots D_{0}\right)$
8. Real: $(-1)^{\mathrm{s}}\left(2^{\mathrm{E}-\mathrm{BIAS}}\right)\left(\mathrm{F}_{0} \mathrm{~F}_{1} \ldots\right)$

Table 6 lists the 80287's instructions by class. No special programming tools are necessary to use the 80287 since all new instructions and data types are directly supported by the 80286 assembler and
appropriate high level languages. All 8086/8088 development tools which support the 8087 can also be used to develop software for the 80286/80287 in real address mode.

## SOFTWARE INTERFACE

The 80286/80287 is programmed as a single processor. All communication between the 80286 and the 80287 is transparent to software. The CPU automatically controls the 80287 whenever a numeric instruction is executed. All memory addressing modes, physical memory, and virtual memory of the CPU are available for use by the NPX.

Since the NPX operates in parallel with the CPU, any errors detected by the NPX may be reported after the CPU has executed the ESCAPE instruction which caused it. To allow identification of the failing numeric instruction, the NPX contains two pointer registers which identify the address of the failing numeric instruction and the numeric memory operand if appropriate for the instruction encountering this error.

## INTERRUPT DESCRIPTION

Several interrupts of the 80286 are used to report exceptional conditions while executing numeric programs in either real or protected mode. The interrupts and their functions are shown in Table 3.

## PROCESSOR ARCHITECTURE

As shown in Figure 1, the NPX is internally divided into two processing elements, the bus interface unit (BIU) and the numeric execution unit (NEU). The NEU executes all numeric instructions, while the BIU receives and decodes instructions, requests operand transfers to and from memory and executes processor control instructions. The two units are able to operate independently of one another allowing the BIU to maintain asynchronous communication with the CPU while the NEU is busy processing a numeric instruction.

## BUS INTERFACE UNIT

The BIU decodes the ESC instruction executed by the CPU. If the ESC code defines a math instruction, the BIU transmits the formatted instruction to the NEU. If the ESC code defines an administrative instruction, the BIU executes it independently of the NEU. The parallel operation of the NPX with the CPU is normally transparent to the user. The BIU generates the BUSY and ERROR signals for 80826/ 80287 processor synchronization and error notification, respectively.

The 80287 executes a single numeric instruction at a time. When executing most ESC instructions, the

Table 3. 80286 interrupt Vectors Reserved for NPX

| Interrupt Number | Interrupt Function <br> 7 <br> 9An ESC instruction was encountered when EM or TS of the 80286 MSW was <br> set. EM = 1 indicates that software emulation of the instruction is required. <br> When TS is set, either an ESC or WAIT instruction will cause interrupt 7. This <br> indicates that the current NPX context may not belong to the current task. |
| :---: | :--- |
| The second or subsequent words of a numeric operand in memory exceeded a <br> segment's limit. This interrupt occurs after executing an ESC instruction. The <br> saved return address will not point at the numeric instruction causing this <br> interrupt. After processing the addressing error, the 80286 program can be <br> restarted at the return address with IRET. The address of the failing numeric <br> instruction and numeric operand and saved in the 80287. An interrupt handler <br> for this interrupt must execute FNINIT before any other ESC or WAIT <br> instruction. |  |
| 13 | The starting address of a numeric operand is not in the segment's limit. The <br> return address will point at the ESC instruction, including prefixes, causing this <br> error. The 80287 has not executed this instruction. The instruction and data <br> address is 80287 refer to a previous, correctly executed, instruction. |
| 16 | The previous numeric instruction caused an unmasked numeric error. The <br> address of the faulty numeric instruction or numeric data operand is stored in <br> the 80287. Only ESC or WAIT instructions can cause this interrupt. The 80286 <br> return address will point at a WAIT or ESC instruction, including prefixes, which <br> may be restarted after clearing the error condition in the NPX. |

80286 tests the BUSY pin and waits untll the 80287 indicates that it is not busy before initiating the command. Once initiated, the 80286 continues program execution while the 80287 executes the ESC instruction. In 8086/8087 systems, this synchronization is achieved by placing a WAIT instruction before an ESC instruction. For most ESC instructions, the 80287 does not require a WAIT instruction before the ESC opcode. However, the 80287 will operate correctly with these WAIT instruction. In all cases, a WAIT or ESC instruction should be inserted after any 80287 store to memory (except FSTSW and FSTCW) or load from memory (except FLDENV or FRSTOR) before the 80286 reads or changes the value to be sure the numeric value has already been wrtten or read by the NPX.

Data transfers between memory and the 80287, when needed, are controlled by the PEREQ PEACK, NPRD, NPWR, NPS1, NPS2 signals. The 80286 does the actual data transfer with memory through its processor extension data channel. Numeric data transiers with memory performed by the 80286 use the same timing as any other bus cycle. Control signal for the 80287 are generated by the 80826 as
shown in Figure 4a, and meet the timing requirements shown in the $A C$ requirements section.

## NUMERIC EXECUTION UNIT

The NEU executes all instructions that involve the register stack; these include arithmetic, logical, transcendental, constant and data transfer instructions. The data path in the NEU is 84 bits wide ( 68 significand bits, 15 exponent bits and a sign bit) which allows internal operand transfers to be performed at very high speeds.

When the NEU begins executing an instruction, it activated the BIU BUSY signal. This signal is used in conjunction with the CPU WAIT instruction or automatically with most of the ESC instructions to synchronize both processors.

## REGISTER SET

The 80287 register set is shown in Figure 5. Each of the eight data registers in the 8087's register stack


Figure 5. 80287 Regiater Set
is 80 bits wide and is divided into "fields" corresponding to the NPX's temporary real data type.

At a given point in time the TOP field in the status word identifies the current top-of-stack register. A "push" operation decrements TOP by 1 and loads a value into the new top register. A "pop" operation stores the value from the current top register and then increments TOP by 1. Like 80286 stacks in memory; the 80287 register stack grows "down" toward lower-addressed registers.

Instructions may address the data registers either implicitly or explicitly. Many instructions operate on the register at the TOP of the stack. These instructions implicitly address the register pointed by the TOP. Other instructions allow the programmer to explicitly specity the register which is to be used. This explicit register addressing is also "top-relative."

## STATUS WORD

The 16 -bit status word (in the status register) shown in Figure 6 reflects the overall state of the 80287. It may be read and inspected by CPU code. The busy bit (bit 15) indicates whether the NEU is executing an instruction $(B=1)$ or is idle $(B=0)$.

The instructions FSTSW, FSTSW AX, FSTENV, and FSAVE which store the status word are executed exclusively by the BIU and do not set the busy bit themselves or require the Busy bit be cleared in order to be executed.

The four numeric condition code bits $\left(\mathrm{C}_{0}-\mathrm{C}_{3}\right)$ are similar to the flags in a CPU: instructions that perform arithmetic operations update these bits to reflect the outcome of NPX operations. The effect of these instructions on the condition code is summerized in Tables 4a and 4b.

Bits 14-12 of the status word point to the 80287 register that is the current top-of-stack (TOP) as described above. Figure 6 shows the six error flags in bits 5-0 of the status word. Bits 5-0 are set to indicate that the NEU has detected an exception while executing an instruction. The section on exception handling explains how they are set and used.

Git 7 is the error summary status bit. This bit is set if any unmasked exception bit is set and cleared otherwise. If this bit is set, the ERROR signal is assert$\theta$ d.


Figure 6. 80287 Status Word

## TAG WORD

The tag word marks the content of each register as shown in Figure 7. The principal function of the tag word is to optimize the NPX's performance. The eight two-bit tags in the tag word can be used, however, to interpret the contents of 80287 registers.

## INSTRUCTION AND DATA POINTERS

The instruction and data pointers (See Figures 8a and 8 b ) are provided for user-written error handlers. Whenever the 80287 executes a new instruction, the BIU saves the instruction address, the operand address (if present) and the instruction opcode. 80287 instructions can store this data into memory.

The instruction and data pointers appear in one of two formats depending on the operating mode of the 80287. In real mode, these values are the 20 -bit physical address and 11-bit opcode formatted like the 8087. In protection mode, these values are the

32-bit virtual address used by the program which executed an ESC instruction. The same FLDENV/ FSTENV/FSAVE/FRSTOR instructions as those of the 8087 are used to transfer these values between the 80287 registers and memory.

The saved instruction address in the 80287 will point at any prefixes which preceded the instruction. This is different than in the 8087 which only pointed at the ESCAPE instruction opcode.

## CONTROL WORD

The NPX provides several processing options which are selected by loading a word from memory into the control word. Figure 9 shows the format and encoding of fields in the control word.

The low order byte of this control word configures the 80287 error and exception masking. Bits 5-0 of the control word contain individual masks for each of the six exceptions that the 80287 recognizes. The high order byte of the control word configures the

Table 4a. Condition Code Interpretation

| Instruction Type | $\mathrm{C}_{3}$ | $\mathrm{C}_{2}$ | $\mathrm{C}_{1}$ | $\mathrm{C}_{0}$ | Interpretation |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Compare, Test | 0 | 0 | X | 0 | ST > Source or 0 (FTST) |
|  | 0 | 0 | X | 1 | ST < Source or 0 (FTST) |
|  | 1 | 0 | X | 0 | ST = Source or 0 (FTST) |
|  | 1 | 1 | X | 1 | ST is not comparable |
| Remainder | $\mathrm{Q}_{1}$ | 0 | $Q_{0}$ | $\mathrm{Q}_{2}$ | Complete reduction with three low bits of quotient (See Table 5b) |
|  | U | 1 | U | U | Incomplete Reduction |
| Examine | 0 | 0 | 0 | 0 | Valid, positive unnormalized |
|  | 0 | 0 | 0 | 1 | Invalid, positive, exponent = 0 |
|  | 0 | 0 | 1 | 0 | Valid, negative, unnormalized |
|  | 0 | 0 | 1 | 1 | Invalid, negative, exponent = 0 |
|  | 0 | 1 | 0 | 0 | Valid, positive, normalized |
|  | 0 | 1 | 0 | 1 | Infinity, positive |
|  | 0 | 1 | 1 | 0 | Valid, negative, normalized |
|  | 0 | 1 | 1 | 1 | Infinity, negative |
|  | 1 | 0 | 0 | 0 | Zero, positive |
|  | 1 | 0 | 0 | 1 | Empty |
|  | 1 | 0 | 1 | 0 | Zero, Negative |
|  | 1 | 0 | 1 | 1 | Empty |
|  | 1 | 1 | 0 | 0 | Invalid, positive, exponent = 0 |
|  | 1 | 1 | 0 | 1 | Empty |
|  | , | 1 | 1 | 0 | Invalid, negative, exponent = 0 |
|  | 1 | 1 | 1 | 1 | Empty |

## NOTES:

1. ST $=$ Top of Stack
2. $X=$ value is not affected by instruction
3. $U=$ value is undefined following instruction
4. $\mathrm{Q}_{\mathrm{n}}=$ Quotient bit n

Table 4b. Condition Code Interpretation after FPREM (See Note 1) Instruction as a Function of Dividend Value

| Dividend Range | $\mathbf{Q}_{2}$ | $\mathbf{a}_{1}$ | $\mathbf{Q}_{0}$ |
| :--- | :--- | :--- | :--- |
| Dividend $<2 \cdot$ Modulus | $\mathrm{C}_{3}$ | $\mathrm{C}_{1}$ | $\mathrm{Q}_{0}$ |
| Dividend $<4^{*}$ Modulus | $\mathrm{C}_{3}$ | $\mathrm{Q}_{1}$ | $\mathbf{Q}_{0}$ |
| Dividend $\geq 4^{*}$ Modulus | $\mathrm{Q}_{2}$ | $\mathrm{Q}_{1}$ | $\mathrm{Q}_{0}$ |

## NOTE:

1. Previous value of indicated bit, not affected by FPREM instruction execution.

80287 operating mode including precision, rounding, and infinity control. The precision control bits (bits $9-8$ ) can be used to set the 80287 internal operating precision at less than the default of temporary real (80-bit) precision. This can be useful in providing compatibility with the early generation arithmetic processors of smaller precision than the 80287. The rounding control bits (bits 11-10) provide for directed rounding and true chop as well as the unbiased round to nearest even mode specified in the IEEE standard. Control over closure of the number space at infinity is also provided (either affine closure: $\pm$ $\infty$, or projective closure: $\infty$, is treated as unsigned, may be specified).


Figure 7. 80287 Tag Word


Figure 8a. Protected Mode 80287 Instruction and Data Pointer Image in Memory

## EXCEPTION HANDLING

The 80287 detects six different exception conditions that can occur during instruction execution. Any or all exceptions will cause the assertion of external ERROR signal and ES bit of the Status Word if the appropriate exception masks are not set.

The exceptions that the 80287 detects and the 'default' procedures that will be carried out if the exception is masked, are as follows:

Invalid Operation: Stack overflow, stack underflow, indeterminate form ( $0 / 0, \infty,-\infty$, etc) or the use of a Non-Number (NAN) as an operand. An exponent value of all ones and non-zero significand is reserved to identify NANs. If this exception is masked, the 80287 default response is to generate a specific

NAN called INDEFINITE, or to propogate already existing NANs as the calculation result.

Overflow: The result is too large in magnitude to fit the specified format. The 80287 will generate an encoding for infinity if this exception is masked.

Zero Divisor: The divisor is zero while the dividend is a non-infinite, non-zero number. Again, the 80287 will generate an encoding for infinity if this exception is masked.

Underflow: The result in non-zero but too small in magnitude to fit in the specified format. If this exception is masked the 80287 will denormalize (shift right) the fraction until the exponent is in range. The process is called gradual underflow.


Figure 8b. Real Mode 80287 Instruction and Data Pointer Image in Memory

| 16 |
| :--- | :--- |

Figure 9. 80287 Control Word

Denormalized Operand: At least one of the operands is denormalized; it has the smallest exponent but a non-zero significand. Normal processing continues if this exception is masked off.

Inexact Result: The true result is not exactly representable in the specified format, the result is rounded according to the rounding mode, and this flag is set. If this exception is masked, processing will simply continue.

If the error is not masked, the corresponding error bit and the error status bit (ES) in the control word will be set, and the ERROR output signal will be asserted. If the CPU attempts to execute another ESC or WAIT instruction, exception 7 will occur.

The error condition must be resolved via an interrupt service routine. The 80287 saves the address of the floating point instruction causing the error as well as the address of the lowest memory location of any memory operand required by that instruction.

## 8086/8087 COMPATIBILITY:

The 80286/80287 supports portability of 8086/8087 programs when it is in the real address mode. However, because of differences in the numeric error handling techniques, error handling routines may need to be changed. The differences between an 80286/80287 and 8086/8087 are:

1. The NPX error signal does not pass through an interrupt controller ( 8087 INT signal does).

Therefore, any interrupt controller oriented instructions for the 8086/8087 may have to be deleted.
2. Interrupt vector 16 must point at the numeric error handler routine.
3. The saved floating point instruction address in the 80287 includes any leading prefixes before the ESCAPE opcode. The corresponding saved address of the 8087 does not include leading prefixes.
4. In protected mode, the format of the saved instruction and operand pointers is different than for the 8087. The instruction opcode is not saved-it must be read from memory if needed.
5. Interrupt 7 will occur when executing ESC instructions with either TS or EM or MSW = 1. If TS of MSW = 1 then WAIT will also cause interrupt 7. An interrupt handler should be added to handle this situation.
6. Interrupt 9 will occur if the second or subsequent words of a floating point operand fall outside a segment's size. Interrupt 13 will occur if the starting address of a numeric operand falls outside a segment's size. An interrupt handler should be added to report these programming errors.

In the protected mode, 8086/8087 application code can be directly ported via recompilation if the 80286 memory protection rules are not violated.

80287

## 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}$
Case Temperature $.0^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
Voltage on any Pin with
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 $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{T}_{\mathrm{C}}=0^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$

## ALL SPEEDS SELECTIONS

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{tL}}$ | Input LOW Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{tH}}$ | Input HIGH Voltage | 2.0 | $\mathrm{v}_{C C}+0.5$ | V |  |
| $\mathrm{V}_{\text {HCC }}$ | $\begin{aligned} & \text { Clock Input HIGH Voltage } \\ & \text { CKM }=1 \text { : } \\ & \text { CKM }=0: \end{aligned}$ | $\begin{aligned} & 2.0 \\ & 3.8 \\ & \hline \end{aligned}$ | $\begin{aligned} & v_{c c}+1 \\ & v_{c c}+1 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ |  |
| $\mathrm{V}_{\text {ILC }}$ | $\begin{aligned} & \text { Clock Input LOW Voltage } \\ & \text { CKM }=1 \\ & \text { CKM }=0 \end{aligned}$ | $\begin{aligned} & -0.5 \\ & -0.5 \end{aligned}$ | $\begin{aligned} & 0.8 \\ & 0.6 \end{aligned}$ | $\stackrel{v}{v}$ |  |
| $\mathrm{V}_{\text {OL }}$ | Output LOW Voltage |  | 0.45 | v | $1 \mathrm{OL}=3.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 2.4 |  | V | $\mathrm{lOH}^{\mathrm{H}}=-400 \mu \mathrm{~A}$ |
| ${ }^{\prime}$ | Input Leakage Current | $\bullet$ | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| Lo | Output Leakage Current | - | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ |
| ICC | Power Supply Current | - | $\begin{aligned} & 600 \\ & 475 \\ & 375 \end{aligned}$ | $\begin{aligned} & \hline \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \hline \end{aligned}$ | $\begin{aligned} & T_{A}=0^{\circ} \mathrm{C} \\ & T_{A}=25^{\circ} \mathrm{C} \\ & T_{A}=70^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ |
| $\mathrm{CiN}^{\text {IN }}$ | Input Capacitance | $\bullet$ | 10 | pF | $\mathrm{F}_{\mathrm{C}}=\mathrm{MHz}$ |
| Co | $\begin{aligned} & \text { Input/Output Capacitance } \\ & \text { (D0-D15) } \end{aligned}$ | - | 20 | pF | $\mathrm{V}_{\mathrm{C}}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\text {CLK }}$ | CLK Capacitance | - | 12 | pF | $\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}$ |

## A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{T}_{\mathrm{CASE}}=0^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$

## TIMING REQUIREMENTS

A.C. timings are referenced to 0.8 V and 2.0 V points on signals unless otherwise noted.

| Symbol | Parameter | 80287-3 5 MHz |  | 80287-6 <br> 6 MHz |  | 80287-8 <br> 8 MHz |  | $\begin{gathered} 80287-10 \\ 10 \mathrm{MHz} \end{gathered}$ <br> Preliminary |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |  |
| TClcl | $\begin{aligned} & \hline \text { CLK Period } \\ & \text { CKM }=1: \\ & \text { CKM }=0 \end{aligned}$ | $\begin{aligned} & 200 \\ & 62.5 \end{aligned}$ | $\begin{array}{r} 500 \\ 250 \\ \hline \end{array}$ | $\begin{aligned} & 166 \\ & 62.5 \end{aligned}$ | $\begin{array}{\|l\|} \hline 500 \\ 166 \\ \hline \end{array}$ | $\begin{array}{r} 125 \\ 50 \\ \hline \end{array}$ | $\begin{array}{r} 500 \\ 166 \\ \hline \end{array}$ | $\begin{array}{r} 100 \\ 40 \\ \hline \end{array}$ | $\begin{array}{r} 500 \\ 166 \\ \hline \end{array}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \hline \end{aligned}$ |  |
| TCLCH | $\begin{gathered} \text { CLK LOW Time } \\ \text { CKM }=1: \\ \text { CKM }=0: \end{gathered}$ | $\begin{array}{r} 118 \\ 15 \end{array}$ | 230 | $\begin{gathered} 100 \\ 15 \\ \hline \end{gathered}$ | $\begin{array}{r} 343 \\ 146 \end{array}$ | $\begin{aligned} & 68 \\ & 15 \end{aligned}$ | $\begin{array}{\|l} 343 \\ 146 \\ \hline \end{array}$ | $\begin{aligned} & 62 \\ & 11 \\ & \hline \end{aligned}$ | $\begin{array}{r} 343 \\ 146 \\ \hline \end{array}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ | At 0.8 V <br> At 0.6V |
| $\mathrm{T}_{\text {CHCL }}$ | $\begin{aligned} & \text { CLK HIGH Time } \\ & \text { CKM }=1: \\ & \text { CKM }=0: \\ & \hline \end{aligned}$ | $\begin{aligned} & 69 \\ & 20 \end{aligned}$ | 235 | $\begin{aligned} & 50 \\ & 20 \end{aligned}$ | $\begin{array}{\|l} 230 \\ 151 \\ \hline \end{array}$ | $\begin{aligned} & 43 \\ & 20 \\ & \hline \end{aligned}$ | $\begin{array}{\|l} 230 \\ 151 \\ \hline \end{array}$ | $\begin{aligned} & 28 \\ & 18 \\ & \hline \end{aligned}$ | $\begin{array}{r} 230 \\ 151 \\ \hline \end{array}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ | At 2.0 V <br> At 3.6V |
| $\mathrm{T}_{\mathrm{CH} 1 \mathrm{CH} 2}$ | CLK Rise Time |  | 10 |  | 10 |  | 10 |  | 10 | ns | 1.0 V to 3.6 V <br> if $\mathrm{CKM}=0$ |
| TCL2CL1 | CLK Fall Time |  | 10 |  | 10 |  | 10 |  | 10 | ns | 3.6 V to 1.0 V <br> if $C K M=0$ |
| TOYWH | Data Setup to NPWR Inactive | 75 |  | 75 |  | 75 |  | 75 |  | ns |  |
| T WHDX | Data Hold from $\overline{N P W R}$ Inactive | 30 |  | 30 |  | 18 |  | 18 |  | ns |  |
| TWLWH <br> TRLRH | $\overline{\text { NPWR }} \overline{\text { NPRD }}$ Active Time | 95 |  | 95 |  | 90 |  | 90 |  | ns | At 0.8V |
| TAVRL <br> TAVWL | Command Valid to NPWR or $\bar{N}$ PRDActive | 0 |  | 0 |  | 0 |  | 0 |  | ns |  |
| TMHRL | Minimum Delay from PEREQ Active to NPRD Active | 130 |  | 130 |  | 130 |  | 100 |  | ns |  |
| TKLKH | PEAK Active Time | 85 |  | 85 |  | 85 |  | 60 |  | ns | At 0.8 V |
| TKHKL | PEAK Inactive Time | 250 |  | 250 |  | 250 |  | 200 |  | ns | At 2.0 V |
| $\mathrm{T}_{\text {KHCH }}$ | PEAK Inactive to NPWR, $\overline{\text { NPRD }}$ Inactive | 50 |  | 50 |  | 40 |  | 40 |  | ns |  |
| TCHKL | $\overline{\text { NPWR, }}$ NPRD Inactive to PEAK Active | -30 |  | -30 |  | -30 |  | -30 |  | ns |  |
| Twhax TRHAX | Command Hold from NPWR, $\overline{\text { NPRD }}$ Inactive | 30 |  | 30 |  | 30 |  | 22 |  | ns |  |
| TKLCL | $\overline{\text { PEAK }}$ Active Setup to NPWR NPRD Active | 50 |  | 50 |  | 40 |  | 40 |  | ns |  |

80287
A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$, $\mathrm{T}_{\text {CASE }}=0^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ (Continued)

TIMING REQUIREMENTS (Continued)
A.C. timings are referenced to 0.8 V and 2.0 V points on signals uniess otherwise noted.

| Symbol | Parameter | $\begin{gathered} 80287-3 \\ 5 \mathrm{MHz} \end{gathered}$ |  | $\begin{gathered} 80287-6 \\ 6 \mathrm{MHz} \end{gathered}$ |  | 80287-8 8 MHz |  | $\begin{array}{\|c\|} \hline 80287-10 \\ 10 \mathrm{MHz} \\ \text { Preliminary } \\ \hline \end{array}$ |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |  |
| TIVCL | $\overline{\text { NPWR }}, \overline{\text { NPRD }}$ to CLK Setup Time | 70 |  | 70 |  | 70 |  | 53 |  | ns | (Note 1) |
| TCLIH | NPWR, $\overline{\text { NPRD }}$ from CLK Hold Time | 45 |  | 45 |  | 45 |  | 37 |  | ns | (Note 1) |
| T RSCL | RESET to CLK Setup Time | 20 |  | 20 |  | 20 |  | 20 |  | ns | (Note 1) |
| TCLRS | RESET from CLK Hold Time | 20 |  | 20 |  | 20 |  | 20 |  | ns | (Note 1) |

TIMING RESPONSES

| Symbol | Parameter | 80287-3 5 MHz |  | 80287-6 <br> 6 MHz |  | $\begin{gathered} 80287-8 \\ 8 \mathrm{MHz} \end{gathered}$ |  | $\begin{array}{\|c\|} \hline 80287-10 \\ 10 \mathrm{MHz} \\ \text { Preliminary } \\ \hline \end{array}$ |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |  |
| TrHOZ | $\overline{\text { NPRD }}$ Inactive to Data Float |  | 37.5 |  | 37.5 |  | 35 |  | 21 | ns | (Note 2) |
| TRLOV | $\overline{\text { NPRD }}$ Active to Data Valid |  | 60 |  | 60 |  | 60 |  | 60 | ns | (Note 3) |
| TILBH | ERROR Active to BUSY Inactive | 100 |  | 100 |  | 100 |  | 100 |  | ns | (Note 4) |
| TWLBV | NPWR Active to BUSY Active |  | 100 |  | 100 |  | 100 |  | 100 | ns | (Note 5) |
| TKLML | PEAK Active to PEREQ Inactive |  | 127 |  | 127 |  | 127 |  | 100 | ns | (Note 6) |
| TCMDI | Command Inactive Time Write-to-Write Read-to-Read Write-to-Read Read-to-Write | $\begin{gathered} 95 \\ 250 \\ 105 \\ 95 \\ \hline \end{gathered}$ |  | $\begin{aligned} & 95 \\ & 95 \\ & 95 \\ & 95 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 95 \\ & 95 \\ & 95 \\ & 95 \end{aligned}$ |  | $\begin{aligned} & 75 \\ & 75 \\ & 75 \\ & 75 \\ & \hline \end{aligned}$ |  | ns <br> ns <br> ns <br> ns | At 2.0 V <br> At 2.0 V <br> At 2.0 V <br> At 2.0 V |
| T ${ }_{\text {RHOH }}$ | Data Hold from NPRD Inactive | 5 |  | 3 |  | 3 |  | 3 |  | ns | (Note 7) |

## NOTES:

1. This is an asynchronous input. This specification is given for testing purposes only, to assure recognition at a specific CLK edge.
2. Float condition occurs when output current is less than ILO on D0-D15.
3. D0-D15 loSINF $\$$ : $\mathrm{XL}=100 \mathrm{pF}$.
4. $\overline{B U S Y}$ loading: $C L=100 \mathrm{pF}$.
5. $\overline{B U S Y}$ loading: $\mathrm{CL}=100 \mathrm{pF}$.
6. On last data transfer on numeric instruction.
7. D0-D15 loading: $C L=100 \mathrm{pF}$.

## WAVEFORMS

DATA TRANSFER TIMING (Initiated by 80286)


DATA CHANNEL TIMING (Initiated by 80287)


WAVEFORMS (Continued)

## ERROR OUTPUT TIMING



CLK, RESET TIMING (CKM = 1)


NOTE:
Reset, NPWR, NPRD are inputs asynchronous to CLK. Timing requirements on this page are given for testing purposes only, to assure recognition at a specific CLK edge.

WAVEFORMS (Continued)
CLK, NPRD, NPWR TIMING (CKM = 1)


CLK, RESET TIMING (CKM $=0$ )


NOTE:
Reset must meet timing shown to guarantee known phase of internal $\div 3$ circuit.

CLK, NPRD, NPWR TIMING (CKM $=0$ )


Table 6. 80287 Extensions to the 80286 Instruction Set


All mnemonics copyright Intel Corporation 1987.


AC Drive and Measurement Points-CLK Input


AC Setup, Hold and Delay Time Measurement-General


AC Test Loading on Outputs

Table 6. 80287 Extensions to the 80286 Instruction Set (Continued)


## NOTE:

1. If $P=1$ then add 5 clocks.

All mnemonics copyright Intel Corporation 1987.

Table 6. 80287 Extensions to the 80286 Instruction Set (Continued)


All mnemonics copyright Intel Corporation 1987.

Table 6. 80287 Extensions to the 80286 instruction Set (Continued)


## NOTES:

1. if mod $=00$ then DISP $=0^{*}$, disp-low and disp-high are absent
if mod $=01$ then DISP $=$ disp-low sign-extended to 16 -bits, disp-high is absent
if mod $=10$ then DISP $=$ disp-high; disp-low
if $\bmod =11$ then $\mathrm{r} / \mathrm{m}$ is treated as an ST(i) field
2. if $\mathrm{r} / \mathrm{m}=000$ then $E A=(B X)+(S I)+$ DISP
if $\mathrm{r} / \mathrm{m}=001$ then $E A=(B X)+(D I)+$ DISP
if $\mathrm{r} / \mathrm{m}=010$ then $E A=(B P)+(S I)+D I S P$
if $\mathrm{r} / \mathrm{m}=011$ then $\mathrm{EA}=(\mathrm{BP})+(\mathrm{DI})+\mathrm{DISP}$
if $\mathrm{r} / \mathrm{m}=100$ then $E A=(S I)+$ DISP
if $r / m=101$ then $E A=$ (DI) + DISP
if $\mathrm{r} / \mathrm{m}=110$ then $E A=(B P)+$ DISP
if $\mathrm{r} / \mathrm{m}=111$ then $E A=(B X)+$ DISP
*except if $\bmod =000$ and $\mathrm{r} / \mathrm{m}=110$ then EA $=$ disp-high; disp-low.
3. $\mathrm{MF}=$ Memory Format

00-32-bit Real
01-32-bit integer
10-64-bit Real
11-16-bit Integer
4. $\mathrm{ST}(0)=$ Current stack top

ST(i) $=$ ith register below stack top
5. $d=$ Destination
$0-$ Destination is $\mathrm{ST}(0)$
1-Destination is ST(i)
6. $P=P O D$

O-No pop
1-Mop ST(0)
7. $R=$ Reverse: When $d=1$ reverse the sense of $R$

0 -Destination (op) Source
1-Source (op) Destination
8. For FSQRT: $\quad-0 \leq S T(0) \leq+\infty$

For FSCALE: $\quad-2^{15} \leq \operatorname{ST}(1)<+2^{15}$ and $\operatorname{ST}(1)$ integer
For $\operatorname{F2XM} 1: \quad 0 \leq \mathrm{ST}(0) \leq 2^{-1}$
For FYL2X: $\quad 0<\mathrm{ST}(0)<\infty$
$-\infty<\mathrm{ST}(1)<+\infty$
For FYL2XP1: $\quad 0 \leq \operatorname{IST}(0) \mid<(2-\sqrt{ } 2) / 2$
$0 \leq<$ ST( 1 ) <
For FPATAN: $\quad 0 \leq \mathrm{ST}(0)<\mathrm{ST}(1)<+\infty$
9. ESCAPE bit pattern is 11011 .

All mnemonics copyright Intel Corporation 1987.

## 分 National

## NS16450/INS8250A/NS16C450/INS82C50A Asynchronous Communications Element

## General Description

The NS16450 is an improved specification version of the INS8250A Asynchronous Communications Element (ACE). The improved specifications ensure compatibility with the NS32016 and other state-of-the-art CPUs. Functionally, the NS16450 is equivalent to the INS8250A. The INS8250A is available in both $5 \mathrm{~V} \pm 5 \%$ and $5 \mathrm{~V} \pm 10 \%$ operating ranges. See ordering instructions on the last page. The ACE is fabricated using National Semiconductor's advanced scaled N -channel silicon-gate MOS process, XMOS.
The NS16C450 and INS82C50A are functionally equivalent to their XMOS counterparts, except that they are CMOS parts. (The CMOS parts will be available after June 1985.) it functions as a serial data input/output interface in a microcomputer system. The functional configuration of the ACE is programmed by the system software via a TRI-STATE* 8 -bit bidirectional data bus; this includes the on-board baud rate generator.
The ACE 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. The CPU can read the complete status of the ACE at any time during the functional operation. Status information reported includes the type and condition of the transfer operations being performed by the ACE, as well as any error conditions (parity, overrun, framing, or break interrupt)
The ACE includes a programmable baud generator that is capable of dividing the timing reference clock input by divisors of 1 to (216-1), and producing a $16 \times$ clock for driving the internal transmitter logic. Provisions are also included to use this $16 \times$ clock to drive the receiver logic. Also included in the ACE is a complete MODEM-control capability, and a processor-interrupt system that may be software tailored to the user's requirements to minimize the computing required to handie the communications link.

## Features

- Easily interfaces to most popular microprocessors.
- Adds or deletes standard asynchronous communication bits (start, stop, and parity) to or from serial data stream.
- Full double buffering eliminates need for precise synchronization.
- Independently controlled transmit, receive, line status, and data set interrupts.
- Programmable baud generator allows division of any input clock by 1 to ( $2^{16}-1$ ) and generates the internal $16 \times$ clock.
- Independent receiver clock input.
- MODEM control functions (CTS, RTS, DSR, DTR, RI, and $D C D$ ).
- Fully programmable serial-interface characteristics: - 5-, 6-, 7-, or 8-bit characters
- Even, odd, or no-parity bit generation and detection - 1 -, $1 \frac{1}{2}$-, or 2 -stop bit generation
- Baud generation (DC to 56k baud).
- False start bit detection.
- Complete status reporting capabilities.
- TRI-STATE TTL drive capabilities for bidirectional data bus and control bus.
- Line break generation and detection.
- Internal diagnostic capabilities:
- Loopback controls for communications link fault isolation
- Break, parity, overrun, framing error simulation.
- Full prioritized interrupt system controls.

Basic Configuration


## Absolute Maximum Ratings

Temperature Under Bias
Storage Temperature
All Input or Output Voltages
with Respect to $V_{S S}$
Power Dissipation
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
-0.5 V to +7.0 V
700 mW

Note: Maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended and should be limited to those conditions specified under DC electrical characteristics.

## DC Electrical Characteristics

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, V_{C C}=+5 \mathrm{~V} \pm 5 \%, V_{S S}=0 \mathrm{~V}$, unless otherwise specified.

| Symbol | Parameter | Conditions | $\begin{gathered} \text { NS16450 } \\ \text { NS 16C450 (Note 1) } \\ \hline \end{gathered}$ |  | INS8250A,AWN INS82C50A (Note 1) |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| $V_{\text {IL }}$ X | Clock Input Low Voltage |  | -0.5 | 0.8 | -0.5 | 0.8 | $V$ |
| $V_{\text {IHX }}$ | Clock Input High Voltage |  | 2.0 | $\mathrm{V}_{\mathrm{CC}}$ | 2.0 | $V_{C C}$ | $\checkmark$ |
| $V_{\text {IL }}$ | Input Low Voltage |  | $-0.5$ | 0.8 | -0.5 | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.0 | $\mathrm{V}_{\text {CC }}$ | 2.0 | $\mathrm{V}_{\mathrm{CC}}$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{OL}=1.6 \mathrm{~mA}$ on all * |  | 0.4 |  | 0.4 | V |
| VOH | Output High Voltage | $\mathrm{IOH}=-1.0 \mathrm{~mA}$. | 2.4 |  | 2.4 |  | V |
| $\operatorname{Icco(AV)}$ | Avg. Power Supply Current (VCC) | $V_{C C}=5.25 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C}$ <br> No Loads on output <br> SIN, DSR, RLSD, <br> CTS, $\mathrm{RI}=2.0 \mathrm{~V}$ <br> All other inputs $=0.8 \mathrm{~V}$ |  | 120 |  | 95 | mA |
| $\operatorname{Icc}(A V)$ | Avg. Power Supply Current ( $V_{\mathrm{CC}}$ ) CMOS Parts Only | $V_{C C}=5.25 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ <br> No Loads on output <br> SIN, DSR, RLSD, <br> CTS, RI $=2.0 \mathrm{~V}$ <br> All other inputs $=0.8 \mathrm{~V}$ <br> Baud Rate Generator <br> is 4 MHz <br> Baud Rate is 56 k |  | 10 |  | 10 | mA |
| IIL | input Leakge | $V_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ <br> All other pins floating. $V_{I N}=0 \mathrm{~V}, 5.25 \mathrm{~V}$ |  | $\pm 10$ |  | $\pm 10$ | $\mu \mathrm{A}$ |
| ${ }^{\mathrm{I}} \mathrm{CL}$ | Clock Leakage |  |  | $\pm 10$ |  | $\pm 10$ | $\mu \mathrm{A}$ |
| 102 | TRI-STATE Leakage | $\begin{aligned} & V_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} \\ & V_{\mathrm{OUT}}=0 \mathrm{~V}, 5.25 \mathrm{~V} \end{aligned}$ <br> 1) Chip deselected <br> 2) WRITE mode, chip selucted |  | $\pm 20$ |  | $\pm 20$ | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {LIM }}$ | MR Schmitt $\mathrm{V}_{\text {IL }}$ |  |  | 0.8 |  | 0.8 | V |
| $V_{\text {IHMR }}$ | MR Schmitt $\mathrm{V}_{1 H}$ |  | 2.0 |  | 2.0 |  | V |

- Does not apply to XTAL2

Capacitance $T_{A}=25^{\circ} \mathrm{C}, \mathrm{v}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{SS}}=\mathrm{V}$

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{CxTAL}_{2}$ | Clock Input Capacitance | $\mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz}$ <br> Unmeasured pins returned to $V_{S S}$ |  | 15 | 20 | pF |
| CXTAL 1 | Clock Output Capacitance |  |  | 20 | 30 | pF |
| $\mathrm{CIN}^{\text {I }}$ | Input Capacitance |  |  | 6 | 10 | pF |
| COUT | Output Capacitance |  |  | 10 | 20 | pF |


| Symbol | Parameter | Conditions | NS16450 <br> NS16C450 (Note 1) |  | INS8250A,AWNINS82C50A (Note 1) |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| $t_{\text {AW }}$ | Address Strobe Width |  | 60 |  | 90 |  | ns |
| ${ }^{\text {t }}$ AS | Address Setup Time |  | 60 |  | 90 |  | ns |
| ${ }_{\text {t }}^{\text {AH }}$ | Address Hold Time |  | 0 |  | 0 |  | ns |
| ${ }^{\text {t CS }}$ | Chip Select Setup Time |  | 60 |  | 90 |  | ns |
| ${ }^{\text {t }} \mathrm{CH}$ | Chip Select Hold Time |  | 0 |  | 0 |  | ns |
| t ${ }_{\text {diw }}$ | DISTR/DISTR Strobe Width |  | 125 |  | 175 |  | ns |
| ${ }_{\text {t }}^{\text {R }} \mathrm{C}$ | Ready Cycie Delay |  | 175 |  | 500 |  | ns |
| RC | Ready Cycle $=t_{\text {AR }}{ }^{*}+t_{\text {DIW }}+t_{\text {RC }}$ |  | 360 |  | 755 |  | ns |
| tob | DISTR/DISTR to Driver Disable Delay | @ 100 pF loading*** |  | 60 |  | 75 | ns |
| tDDD | Delay from DISTR/DISTR to Data | @100 pF loading |  | 125 |  | 175 | ns |
| ${ }_{t}{ }_{\text {Hz }}$ | DISTR/DISTR to Floating Data Delay | @100 pF loading*** | 0 | 100 | 100 |  | ns |
| toow | $\overline{\text { DOSTR/DOSTR Strobe Width }}$ |  | 100 |  | 175 |  | ns |
| twe | Write Cycle Delay |  | 200 |  | 500 |  | ns |
| WC | Write CyCle $=t_{\text {AW }}+t_{\text {DOW }}+t_{W C}$ |  | 360 |  | 755 |  | ns |
| tos | Data Setup Time |  | 40 |  | 90 |  | ns |
| ${ }_{\text {t }}$ | Data Hold Time |  | 40 |  | 60 |  | ns |
| ${ }^{\text {tesc*}}$ | Chip Select Output Delay from Select | @100 pF loading |  | 100 |  | 125 | ns |
| ${ }^{\text {tra* }}$ | Address Hold Time from DISTR/DISTR |  | 20 |  | 20 |  | ns |
| $\mathrm{t}_{\text {RCS** }}$ | Chip Select Hold Time from DISTR/DISTR |  | 20 |  | 20 |  | ns |
| $t_{A R}{ }^{\circ}$ | DISTR/DISTR Delay from Address |  | 60 |  | 80 |  | ns |
| ${ }^{\text {t }}{ }^{\text {csi }}{ }^{*}$ | DİITR/DISTR Delay from Chip Select |  | 50 |  | 80 |  | ns |
| ${ }^{\text {IWA }}$ | Address Hołd Time from DOSTR/DOSTR |  | 20 |  | 20 |  | ns |
| ${ }^{\text {tw }}$ ( ${ }^{\text {a }}$ | Chip Select Hold Time from DOSTR/DOSTR |  | 20 |  | 20 |  | ns |
| ${ }^{\text {t }}{ }^{\text {W }}$ | $\overline{\text { DOSTR/DOSTR Delay from Address }}$ |  | 60 |  | 80 |  | ns |
| $\mathrm{tcsw}^{*}$ | $\overline{\text { DOSTR/DOSTR Delay from Select }}$ |  | 50 |  | 80 |  | ns |
| ${ }_{\text {tMRW }}$ | Master Reset Pulse Width |  | 5 |  | 10 |  | $\mu \mathrm{s}$ |
| ${ }^{\mathrm{t}_{\mathrm{X}} \mathrm{H}}$ | Duration of Clock High Pulse | External Clock (3.1 MHz Max.) | 140 |  | 140 |  | ns |
| ${ }^{\mathrm{t}_{\mathrm{C}_{2}}}$ | Duration of Clock Low Pulse | External Clock (3.1 MHz Max.) | 140 |  | 140 |  | ns |
| Baud Generator |  |  |  |  |  |  |  |
| $\underline{N}$ | Baud Divisor |  | 1 | 216-1 | 1 | $2^{16-1}$ |  |
| tBLD | Baud Output Negative Edge Delay | 100 pF Load |  | 125 |  | 250 | ns |
| ${ }_{\text {tBHD }}$ | Baud Output Positive Edge Delay | 100 pF Load |  | 125 |  | 250 | ns |
| tLW | Baud Output Down Time | $\mathrm{fx}^{\prime}=2 \mathrm{MHz}, \div 2,100 \mathrm{pF}$ Load | 425 |  | 425 |  | ns |
| thw | Baud Output Up Time | $\mathrm{f}_{\mathrm{x}}=3 \mathrm{MHz} . \div 3,100 \mathrm{pF}$ Load | 330 |  | 330 |  | ns |
| Recelver |  |  |  |  |  |  |  |
| ${ }^{\text {tSCD }}$ | Delay from RCLK K to Sample Time |  |  | 2 |  | 2 | $\mu \mathrm{s}$ |
| ${ }^{\text {I SINT }}$ | Delay from Stop to Set Interrupt |  | 1 | 1 | 1 | 1 | $\begin{aligned} & \text { RCLK** } \\ & \text { Cycles } \end{aligned}$ |
| ${ }^{\text {tRINT }}$ | Delay from DISTR/DISTR (RD RBR/RDLSA) to Reset Interrupt | 100 pF Load |  | 1 |  | 1 | $\mu \mathrm{S}$ |
| -Applicable only when $\overline{A D S}$ is tied low. <br> $\cdots$ RCLK is equal to $1_{\mathrm{XH}}$ and $\mathrm{I}_{\mathrm{XL}}$. <br> *- Charge and discharge time is determined by $\mathrm{V}_{\mathrm{OL}}$. $\mathrm{V}_{\mathrm{OH}}$ and the external loading. <br> Note 1: All specifications for CMOS parts are preliminary. |  |  |  |  |  |  |  |


| AC Electrical Characteristics (Continued) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Conditions | $\begin{gathered} \text { NS16450 } \\ \text { NS 16C450 (Note 1) } \end{gathered}$ |  | INS8250A,AWN INS82C50A (Note 1) |  | Units |
|  |  |  | Min | Max | Min | Max |  |
| Transmitter |  |  |  |  |  |  |  |
| $t_{\text {HR }}$ | Delay from DOSTR/DOSTR (WR THR) to Reset Interrupt | 100 pF Load |  | 175 |  | 1000 | ns |
| tins | Delay from Initial INTR Reset to Transmit Start |  | 8 | 24 | 8 | 24 | RCLK <br> Cycles |
| $\mathrm{t}_{\mathrm{s}}$ | Delay from Initial Write to Interrupt |  | 16 | 32 | 16 | 32 | RCLK Cycles |
| ${ }^{\text {t }}$ ST ${ }^{\text {P }}$ | Delay from Stop to Interrupt (THRE) |  | 8 | 8 | 8 | 8 | RCLK Cycles |
| $\mathrm{I}_{1 \times}$ | Delay from DISTR/DISTR (RD IIR) to Reset Interrupt (THRE) | 100 pF Load |  | 250 |  | 1000 | ns |
| Modem Control |  |  |  |  |  |  |  |
| ${ }^{\text {m M O }}$ | Delay from DOSTR/DOSTR (WR MCR) to Output | 100 pF Load |  | 200 |  | 1000 | ns |
| ${ }^{\text {tsim }}$ | Delay to Set Interrupt from MODEM Input | 100 pF Load |  |  |  | 1000 | ns |
| ${ }^{\text {t }}$ RIM | Delay to Reset Interrupt from DISTR/DISTR (RD MSR) | 100 pF Load |  | 250 |  | 1000 | ns |
| Note 1: All <br> Timi | ecifications for CMOS parts are preliminary. <br> Waveforms (All timings are referen <br> External Clock Input (3.1 MHz Max.) <br> TL/C/8 | ced to valid 0 a <br> 401-2 <br> AUDOUTT Tim <br> T <br> L | valid 1 |  | Poin | TL/ | $8401-3$ |

Timing Waveforms (Continued)


TL/C/8401-5

- Applicable Only When $\overline{A D S}$ is Tied Low.


TL/C/8401-6

- Applicable Only When $\overline{A D S}$ is Tied Low.

Timing Waveforms (Continued)


## Block Diagram



TL/C/8401-10

Note: Applicable pinout numbers are included within parenthesis.

## Functional Pin Description

The following describes the function of all NS16450, NS16C450 and INS8250A, INS82C50A input and output pins. Some of these descriptions reference internal circuits.
Note: in the following descriptions, a low represents a sogic 0 (OV nominal) and a high represents a logic $1(+2.4 \mathrm{~V}$ nominal).

## NPUT SIGNALS

Chip Select (CSO, CS1, CS2), Pins 12-14: When CSO and CS1 are high and CS2 is low, the chip is selected. Chip selection is complete when the decoded chip select signal is latched with an active (low) Address Strobe ( $\overline{\mathrm{ADS}}$ ) input. This enables communication between the ACE and the CPU.

Data Input Strobe (DISTR, DISTR), Pins 22 and 21: When DISTR is high or DISTR is low while the chip is selected, it allows the CPU to read status information or data from a selected register of the ACE.
Note: Onily an active DISTR or DISTR input is required to transfer data from the ACE during a read operation. Therefore, tie either the DISTR input per manently low or the DISTR input permanently high, if not used.

Dats Output Strobe (DOSTR, DOSTR), Pins 19 and 18: When DOSTR is high or DOSTR is low while the chip is selected, allows the CPU to write data or control words into a selected register of the ACE.
Note: Only an active DOSTR or DOSTA input is required to transfer data to the ACE during a write operation. Therefore, tie either the DOSTR input permanently low or the DOSTR input permanently high, if not used.
Address Strobe ( $\overline{\text { ADS }}$ ), Pin 25: When low, provides latching for the Register Select (AO, A1, A2) and Chip Select (CSO, CS1, CS2) signals.
Note: An active ADS input is required when the Register Select (A0, A1, A2) signats are not stable lor the duration of a read or write operation. If not required. tie the $\overline{A D S}$ input permanently low.

Register Select (A0, A1, A2), Pins 26-28: These three inputs are used during a read or write operation to select an ACE register to read from or write into as indicated in the table below. Note that the state of the Divisor Latch Access Bit (DLAB), which is the most significant bit of the Line Control Register, affects the selection of certain INS8250A registers. The DLAB must be set high by the system, software to access the Baud Generator Divisor Latches.

Functional Pin Description (Continued)

| DLAB | $A_{2}$ | $A_{1}$ | $A_{0}$ | Regiater |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | Receiver Bufter Transmitter Holding Register (write) | (read), |
| 0 | 0 | 0 | 1 | Interrupt Enable |  |
| X | 0 | 1 | 0 | Interrupt Identification (read only) |  |
| $x$ | 0 | 1 | 1 | Line Control |  |
| X | 1 | 0 | 0 | MODEM Control |  |
| X | 1 | 0 | 1 | Line Status |  |
| X | 1 | 1 | 0 | MODEM Status |  |
| X | 1 | 1 | 1 | Scratch |  |
| 1 | 0 | 0 | 0 | Divisor Latch (least significant byte) |  |
| 1 | 0 | 0 | 1 | Divisor Latch (most significant byte) |  |

Master Reset (MR), Pin 35: This input is buffered with a TTL-compatible Schmitt Trigger with 0.5 V typical hysteresis. When high, it clears all the registers (except the Receiver Buffer, Transmitter Holding, and Divisor Latches), and the control logic of the ACE. Also, the state of various output signals (SOUT, INTRPT, OUT 1, OUT 2, RTS, DTR) are affected by an active MR input. (Refer to Table I.)
Recelver Clock (RCLK), Pin 9: This input is the $16 \times$ baud rate clock for the receiver section of the chip.
Serial Input (SIN), Pin 10: Serial data input from the communications link (peripheral device, MODEM, or data set).
Clear to Send (CTS), Pin 36: The CTS signal is a MODEM control function input whose conditions can be tested by the CPU by reading bit 4 (CTS) of the MODEM Status Register. Bit 0 (DCTS) of the MODEM Status Register indicates whether the CTS input has changed state since the previous reading of the MODEM Status Register. CTS has no effect on the Transmitter.
Note: Whenever the CTS bit of the MODEM Status Register changes state. an interrupt is generated it the MODEM Status Interrupt is enabled.
Data Set Ready ( $\overline{\mathrm{DSR}}$ ), Pin 37: When low, this indicates that the MODEM or data set is ready to establish the communications link and transfer data with the ACE. The DSF signal is a MODEM-control function input whose condition can be tested by the CPU by reading bit 5 (DSR) of the MODEM Status Register. Bit 1 (DDSR) of the MODEM Status Register indicates whether the $\overline{\mathrm{D} S \bar{R}}$ input has changed state since the previous reading of the MODEM Status Register.
Note: Whenever the OSR bit of the MODEM Status Register changes state, an interrupt is generated it the MODEM Status interrupt is enabled.
Data Carrier Detect ( $\overline{\mathrm{DCD}}$ ), Pin 38: When low, indicates that the data carrier has been detected by the MODEM or data set. The $\overline{\mathrm{DCD}}$ signal is a MODEM-control function input whose condition can be tested by the CPU by reading bit 7 (DCD) of the MODEM Status Register. Bit 3 (DDCD) of the MODEM Status Register indicates whether the $\overline{D C D}$ input has changed state since the previous reading of the MODEM Status Register. $\overline{\mathrm{DCD}}$ has no effect on the receiver.
Note: Whenever the OCD bit of the MODEM Status Pegister changes state. an interrupt is generated if the MODEM Status interrupt is enabled.

Ring Indicator ( $\overline{\text { RII }}$ ), Pin 39: When low, indicates that a telephone ringing signal has been received by the MODEM or data set. The $\overline{\mathrm{RI}}$ signal is a MODEM-control function input whose condition can be tested by the CPU by reading bit 6 (RI) of the MODEM Status Register. Bit 2 (TERI) of the MODEM Status Register indicates whether the $\overline{\operatorname{RI}}$ input has changed from a low to a high state since the previous reading of the MODEM Status Register.
Note: Whenever the RI bit of the MODEM Status Register changes from a high to a low state, an interrupt is generated if the MODEM Status Register is enabled.
$\mathbf{V}_{\text {cc }}$, Pin 40: +5 V supply.
$\mathbf{V}_{\text {SS }}$, Pin 20: Ground ( OV ) reference.

## OUTPUT SIGNALS

Data Terminal Ready (DTR), Pin 33: When low, informs the MODEM or data set that the ACE is ready to communicate. The DTR output signal can be set to an active low by programming bit 0 (DTR) of the MODEM Control Register to a high level. The DTR signal is set high upon a Master Reset operation. The DTR signal is forced to its inactive state (high) during loop mode operation.
Request to Send (RTS), Pin 32: When low, informs the MODEM or data set that the ACE is ready to transmit data. The RTS output signal can be set to an active low by programming bit 1 (RTS) of the MODEM Control Register. The RTS signal is set high upon a Master Reset operation. The RTS signal is forced to its inactive state (high) during loop mode operation.
Output 1 (OUT 1), Pin 34: User-designated output that can be set to an active low by programming bit 2 (OUT 1) of the MODEM Control Register to a high level. The OUT 1 signal is set high upon a Master Reset Operation. The OUT 1 signal is forced to its inactive state (high) during loop mode operation.
Output 2 (ОUT 2), Pin 31: User-designated output that can be set to an active low by programming bit 3 (OUT 2) of the MODEM Control Register to a high level. The OUT 2 signal is set high upon a Master Reset Operation. The OU'² $\mathbf{2}$ signal is forced to its inactive state (high) during loop mode operation.
Chip Select Out (CSOUT), Pin 24: When high, indicates that the chip has been selected by active, CSO, CS1, and CS2 inputs. No data transfer can be initiated until the CSOUT signal is a logic 1. CSOUT goes low when chip is deselected.
Driver Disable (DDIS), Pin 23: Goes low whenever the CPU is reading data from the ACE. A high-tevel DDIS output can be used to disable an external transceiver (if used between the CPU and ACE on the $D_{7}-D_{0}$ Data Bus) at all times, except when the CPU is reading data.
Baud Out (BAUDOUT), Pin 15: $16 \times$ clock signal for the transmitter section of the ACE. The clock rate is equal to the main reference oscillator frequency divided by the specified divisor in the Baud Generator Divisor Latches. The BAUDOUT may also be used for the receiver section by tying this output to the RCLK input of the chip.

Functional Pin Description (Continued)
Interrupt (INTRPT), Pin 30: Goes high whenever any one of the foliowing interrupt types has an active high condition and is enabled via the IER: Receiver Error Flag; Received Data Available; Transmitter Holding Register Empty; and MODEM Status. The INTRPT signal is reset low upon the appropriate interrupt service or a Master Reset operation.
Serlal Output (SOUT), Pin 11: Composite serial data output to the communications link (peripheral, MODEM or data set). The SOUT signal is set to the Marking (logic 1) state upon a Master Reset operation.

## Connection Diagrams



## INPUT/OUTPUT SIGNALS

Data ( $D_{7}-D_{0}$ ) Bus, Pins 1-8: This bus comprises eight TRI-STATE input/output lines. The bus provides bidirectional communications between the ACE and the CPU. Data, control words, and status information are transferred via the $\mathrm{D}_{7}-\mathrm{D}_{0}$ Data Bus.
External Clock Input/Output (XTAL 1, XTAL 2) Pins 16 and 17: These two pins connect the main timing reference (crystal or signal clock) to the ACE.


TL/C/8401-18
T.ABLE I. ACE Reset Functions

| Register/Signal | Reset Control | Reset State |
| :---: | :---: | :---: |
| Interrupt Enable Register | Master Reset | All Bits Low (0-3 forced and 4-7 permanent) |
| Interrupt Identification Register | Master Reset | Bit 0 is High, Bits 1 and 2 Low Bits 3-7 are Permanently Low |
| Line Control Register | Master Reset | All Bits Low |
| MODEM Control Register | Master Reset | All Bits Low |
| Line Status Register | Master Reset | All Bits Low, <br> Except Bits 5 and 6 are High |
| MODEM Status Register | Master Reset | Bits 0-3 Low Bits 4-7-Input Signal |
| SOUT | Master Reset | High |
| INTRPT (RCVR Errs) | Read LSR/MR | Low |
| INTRPT (RCVR Data Ready) | Read RBR/MR | Low |
| INTRPT (THRE) | Read IIR/Write THR/MR | Low |
| INTRPT (Modem Status Changes) | Read MSR/MR | Low |
| OUT 2 | Master Reset | High |
| RTS | Master Reset | High |
| $\overline{\text { OTR }}$ | Master Reset | High |
| OUT 1 | Master Reset | High |

## Accessible Registers

The system programmer may access or control any of the ACE registers summarized in Table II via the CPU. These registers are used to control ACE operations and to transmit and receive data.

## LINE CONTROL REGISTER

The system programmer specifies the format of the asynchronous data communications exchange via the Line Control Register. In addition to controlling the format, the programmer may retreive the contents of the Line Control Register for inspection. This feature simplifies system programming and eliminates the need for separate storage in system memory of the line characteristics. The contents of the Line Control Register are indicated in Table 11 and are described below.

Bits 0 and 1: These two bits specity the number of bits in each transmitted or received serial character. The encoding of bits 0 and 1 is as follows:

| Bit 1 | Bit 0 | Word Length |
| :---: | :---: | :---: |
| 0 | 0 | 5 Bits |
| 0 | 1 | 6 Bits |
| 1 | 0 | 7 Bits |
| 1 | 1 | 8 Bits |

Bit 2: This bit specifies the number of Stop bits in each transmitted character. If bit 2 is a logic 0 , one Stop bit is generated in the transmitted data. If bit 2 is a logic 1 when a 5 -bit word length is selected via bits 0 and 1 , one and a

Table II. Summary of Accessible Registers

|  | Register Address |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 DLAB $=0$ | 0 DLAB = 0 | 1 DLAB $=0$ | 2 | 3 | 4 | 5 | 6 | 7 | O DLAB $=1$ | 1 DLAB = 1 |
| Blt <br> No. | Receiver Buffer Register (Read Only) | Transmitter <br> Holding <br> Register <br> (Write <br> Only) | Interrupt Enable Register | Interrupt Ident. Register (Read Only) | Line Control Register | MODEM Control Register | Line Status Register | MODEM Status Register | Scratch RegIster | Divisor Latch (LS) | Latch (MS) |
|  | RBR | THR | IER | IIR | LCR | MCR | LSA | MSR | SCR | DLL | DLM |
| 0 | Data Bit $0^{*}$ | Data Bit 0 | Enable Received Data Available Interrupt (ERBFI) | " 0 " if Interrupt Pending | Word Length Select Bit 0 (WLSO) | Data Terminal Ready (DTR) | Data Ready (DR) | Delta Clear to Send (DCTS) | Bit 0 | Bit 0 | Bit 8 |
| 1 | Data Bit 1 | Data Bit 1 | Enable <br> Transmitter <br> Holding <br> Register <br> Empty <br> Interrupt <br> (ETBEI) | $\begin{aligned} & \text { Interrupt } \\ & \text { ID } \\ & \text { Bit (0) } \end{aligned}$ | Word Length Select Bit 1 (WLS1) | $\begin{gathered} \text { Request } \\ \text { to Send } \\ \text { (RTS) } \end{gathered}$ | Overrun Error (OE) | Delta <br> Data Set Ready (DDSR) | Bit 1 | Bit 1 | Bit 9 |
| 2 | Data Bit 2 | Data Bit 2 | Enable Receiver Line Status Interrupt (ELSI) | $\begin{gathered} \text { Interrupt } \\ \text { ID } \\ \text { Bit (1) } \end{gathered}$ | Number of Stop Bits (STB) | Out 1 | Parity Error (PE) | Trailing Edge Ring Indicator (TER1) | Bit 2 | Bit 2 | Bit 10 |
| 3 | Data Bit 3 | Data Bit 3 | Enable MODEM Status Interrupt (EDSSI) | 0 | Parity Enable (PEN) | Out 2 | Framing Error (FE) | Delta <br> Data Carrier Detect (DDCD) | Bit 3 | Bit 3 | Bit 11 |
| 4 | Data Bit 4 | Data Bit 4 | 0 | 0 | Even Parity Select (EPS) | Loop | Break Interrupt (BI) | Clear to Send (CTS) | Bit 4 | Bit 4 | Bit 12 |
| 5 | Data Bit 5 | Data Bit 5 | 0 | 0 | Stick Parity | 0 | Transmitter Holding Register (THRE) | Data Set Ready (DSR) | Bit 5 | Bit 5 | Bit 13 |
| 6 | Data Bit 6 | Data Bit 6 | 0 | 0 | Set Break | 0 | Transmitter <br> Empty <br> (TEMT) | Ring Indicator (RI) | Bit 6 | Bit 6 | Bit 14 |
| 7 | Data Bit 7 | Data Bit 7 | 0 | 0 | Divisor Latch Access Bit (DLAB) | 0 | 0 | Data <br> Carrier Detect (DCD) | Bit 7 | Bit 7 | Bit 15 |

## Accessible Registers (Continued)

half Stop bits are generated. If bit 2 is a logic 1 when either a 6-, 7 -, or 8 -bit word length is selected, two Stop bits are generated. The Receiver checks the first Stop-bit only, regardless of the number of Stop bits selected.
Bit 3: This bit is the Parity Enable bit. When bit 3 is a logic 1, a Parity bit is generated (transmit data) or checked (receive data) between the last data word bit and Stop bit of the serial data. (The Parity bit is used to produce an even or odd number of 1 s when the data word bits and the Parity bit are summed.)
Bit 4: This bit is the Even Parity Select bit. When bit 3 is a logic 1 and bit 4 is a logic 0 , an odd number of logic 1 s is transmitted or checked in the data word bits and Parity bit. When bit 3 is a logic 1 and bit 4 is a logic 1 , an even number of logic 1 s is transmitted or checked.
Bit 5: This bit is the Stick Parity bit. When bits 3, 4 and 5 are logic 1 the Parity bit is transmitted and checked by the receiver as a logic 0 . If bits 3 and 5 are 1 and bit 4 is a logic 0 then the Parity bit is transmitted as a 0 .
Bit 6: This bit is the Break Control bit. When it is set to a logic 1, the serial output (SOUT) is forced to the Spacing (logic 0) state. The break is disabled by setting bit 6 to a logic 0. The Break Control bit acts only on SOUT and has no effect on the transmitter logic.
Note: This feature enables the CPU to alert a terminal in a computer communications system. If the following sequence is followed, no erroneous or extraneous characters will be transmitted because of the break.

1. Load an all Os , pad character, in response to THRE.
2. Set break after the next THRE.
3. Wait for the transmitter to be idle, (TEMT = 1), and clear break when normal transmission has to be restored.
During the break, the Transmitter can be used as a character timer to accurately estabtish the break duration.
Bit 7: This bit is the Divisor Latch Access Bit (DLAB). It must be set high (logic 1) to access the Divisor Latches of the Baud Generator during a Read or Write operation. It must be set low (logic 0) to access the Receiver Buffer, the Transmitter Holding Register, or the Interrupt Enable Register.

Table III. Baud Rates Using 1.8432 MHz Crystal

| Desired <br> Baud Rate | Divisor Used <br> to Generate <br> $\mathbf{1 6 \times}$ Clock | Percent Error <br> Difference Between <br> Desired and Actual |
| :---: | :---: | :---: |
| 50 | 2304 | - |
| 75 | 1536 | - |
| 110 | 1047 | 0.026 |
| 134.5 | 857 | 0.058 |
| 150 | 768 | - |
| 300 | 384 | - |
| 600 | 192 | - |
| 1200 | 96 | - |
| 1800 | 64 | - |
| 2000 | 58 | 0.69 |
| 2400 | 48 | - |
| 3600 | 32 | - |
| 4800 | 24 | - |
| 7200 | 16 | - |
| 9600 | 12 | - |
| 19200 | 6 | 2.86 |
| 88400 | 3 |  |
| 6000 | 2 |  |

## Typical Clock Circuits



TL/C/8401-12


TL/C/8401-13

Typical Crystal Oscillator Network

| CRYSTAL | $\boldsymbol{R}_{\mathbf{p}}$ | $\mathbf{R}_{\mathbf{X 2}}$ | $\mathbf{C}_{\mathbf{1}}$ | $\mathbf{C}_{\mathbf{2}}$ |
| :---: | :---: | :---: | :---: | :---: |
| 3.1 MHz | $1 \mathrm{M} \Omega$ | 1.5 k | $10-30 \mathrm{pF}$ | $40-60 \mathrm{pF}$ |
| 1.8 MHz | $1 \mathrm{M} \Omega$ | 1.5 k | $10-30 \mathrm{pF}$ | $40-60 \mathrm{pF}$ |

Table IV. Baud Rates Using $\mathbf{3 . 0 7 2} \mathbf{M H z}$ Crystal

| Desired <br> Baud Rate | Divisor Used <br> to Generate <br> $\mathbf{1 6 ~ x ~ C l o c k ~}$ | Percent Error <br> Difference Between <br> Desired and Actual |
| :---: | :---: | :---: |
| 50 | 3840 | - |
| 75 | 2560 | - |
| 110 | 1745 | 0.026 |
| 134.5 | 1428 | 0.034 |
| 150 | 1280 | - |
| 300 | 640 | - |
| 600 | 320 | - |
| 1200 | 160 | - |
| 1800 | 107 | 0.312 |
| 2000 | 96 | - |
| 2400 | 80 | - |
| 3600 | 53 | - |
| 4800 | 40 | - |
| 7200 | 27 | - |
| 9600 | 20 | - |
| 19200 | 10 | - |
| 38400 | 5 |  |

## Accessible Registers (Continued)

## PROGRAMMABLE BAUD GENERATOR

The ACE contains a programmable Baud Generator that is capable of taking any clock input ( $D C$ to 3.1 MHz ) and dividing it by any divisor from 1 to $\mathbf{2}^{16-1}$ ). The output frequency of the Baud Generator is $16 \times$ the Baud ldivisor ${ }^{*}=$ (frequency input) - (baud rate $\times 16$ )]. Two 8 -bit latches store the divisor in a 16 -bit binary format. These Diviscr Latches must be loaded during initialization in order to ensure desired operation of the Baud Generator. Upon loading either of the Divisor Latches, a 16 bit Baud counter is immediately loaded. This prevents long counts on initial load.
Tables III and IV illustrate the use of the Baud Generator with crystal frequencies of 1.8432 MHz and 3.072 MHz respectively. For baud rates of 38400 and below, the error obtained is minimal. The accuracy of the desired baud rate is dependent on the crystal frequency chosen.
Note: The maximum operating frequency of the Baud Generator is 3.1 MHz . However, when using divisors of 3 and below, the maximum frequency is equal to the divisor in MHz. For example, if the divisor is 1 , then the maximum frequency is 7 MHz . In no case should the date rate be greater than 56k Baud.

## LINE STATUS REGISTER

This 8-bit register provides status information to the CPU concerning the data transfer. The contents of the Line Status Register are indicated in Table 2 and are described below.
Bit 0: This bit is the receiver Data Ready (DR) indicator. Bit 0 is set to a logic 1 whenever a complete incoming character has been received and transferred into the Receiver Buffer Register. Bit 0 is reset to a logic 0 by reading the data in the Receiver Butfer Register.
Bit 1: This bit is the Overrun Error (OE) indicator. Bit 1 indicates that data in the Receiver Buffer Register was not read by the CPU before the next character was transferred into the Receiver Buffer Register, thereby destroying the previous character. The OE indicator is reset whenever the CPU reads the contents of the Line Status Register.

Bit 2: This bit is the Parity Error (PE) indicator. Bit 2 indicates that the received data character does not have the correct even or odd parity, as selected by the even-parityselect bit. The PE bit is set to a logic 1 upon detection of a parity error and is reset to a logic 0 whenever the CPU reads the contents of the Line Status Register.
Bit 3: This bit is the Framing Error (FE) indicator. Bit 3 indicates that the received character did not have a valid Stop bit. Bit 3 is set to a logic 1 whenever the Stop bit following the last data bit or parity bit is detected as a zero bit (Spacing level). The FE indicator is reset whenever the CPU reads the contents of the Line Status indicator.
Bit 4: This bit is the Break Interrupt (BI) indicator. Bit 4 is set to a logic 1 whenever the received data input is held in the Spacing (logic 0 ) state for longer than a full word transmission time (that is, the total time of Start bit + data bits + Parity + Stop bits). The BI indicator is reset whenever the CPU reads the contents of the Line Status indicator.
Note: Bits, 1 through 4 are the error conditions that produce a Receiver Line Status interrupt whenever any of the corresponding conditions are detected.
Bit 5: The bit is the Transmitter Holding Register Empty (THRE) indicator. Bit 5 indicates that the ACE is ready to accept a new character for transmission. In addition, this bit causes the ACE to issue an interrupt to the CPU when the Transmit Holding Register Empty Interrupt enable is set high. The THRE bit is set to a logic 1 when a character is transferred from the Transmitter Holding Register into the Transmitter Shift Register. The bit is reset to logic 0 concurrently with the loading of the Transmitter Holding Register by the CPU.
Blt 6: This bit is the Transmitter Empty (TEMT) indicator. Bit 6 is set to a logic 1 whenever the Transmitter Holding Register (THR) and the Transmitter Shift Register (TSR) are both empty. It is reset to a logic 0 whenever either the THR or TSR contains a data character.
Blt 7: This bit is permanently set to logic 0 .
Mote: The Line Status Fegister is intended tor read operations only. Witing to this register is not recommended as this operation is used for factory testing.

TABLE V. Interrupt Control Functions

| Interrupt Identification Register |  |  | Interrupt Set and Reset Functions |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bit 2 | Bit 1 | Bit 0 | Priority Level | Interrupt Type | Interrupt Source | Interrupt Reset Control |
| 0 | 0 | 1 | - | None | None | - |
| 1 | 1 | 0 | Highest | Receiver Line Status | Overrun Error or Parity Error or Framing Error or Break Interrupt | Reading the Line Status Register |
| 1 | 0 | 0 | Second | Received Data Available | Receiver Data Available | Reading the Receiver Buffer Register |
| 0 | 1 | 0 | Third | Transmitter Holding Register Empty | Transmitter Holding Register Empty | Reading the IIR Register (if source of interrupt) or Writing into the Transmitter Holding Register |
| 0 | 0 | 0 | Fourth | MODEM Status | Clear to Send or <br> Data Set Ready or Ring Indicator or Data Carrier Detect | Reading the MODEM Status Register |

## Accessible Registers (Continued)

## INTERRUPT IDENTIFICATION REGISTER

The ACE has an on-chip interrupt capability that allows for flexibility in interfacing popular microprocessors presently available. In order to provide minimum software overhead during data character transfers, the ACE prioritizes interrupts into four levels. The four levels of interrupt conditions are as follows: Receiver Line Status (priority 1); Received Data Ready (priority 2); Transmitter Holding Register Empty (priority 3); and MODEM Status (priority 4).
Information indicating that a prioritized interrupt is pending and the type of that interrupt are stored in the Interrupt Identification Register (IIR). When addressed during chip-select time, the lIR freezes the highest priority interrupt pending and no other interrupts are acknowledged until the particular interrupt is serviced by the CPU. The contents of the IIR are indicated in Table Il and are described below.
Bit 0: This bit can be used in either a hardwired prioritized or polled environment to indicate whether an interrupt is pending. When bit 0 is a logic 0 , an interrupt is pending and the IIR contents may be used as a pointer to the appropriate interrupt service routine. When bit 0 is a logic 1 , no interrupt is pending and polling (if used) continues.
Bits 1 and 2: These two bits of the IIR are used to identify the highest priority interrupt pending as indicated in Table V . Bits 3 through 7: These five bits of the IIR are always logic 0.

## INTERRUPT ENABLE REGISTER

This 8-bit register enables the four types of interrupts of the ACE to separately activate the chip interrupt (INTRPT) output signal. It is possible to totally disable the interrupt system by resetting bits 0 through 3 of the Interrupt Enable Register. Similarly, by setting the appropriate bits of this register to a logic 1, selected interrupts can be enabled. Disabling the interrupt system inhibits the Interrupt Identification Register and the active (high) INTRPT output from the chip. All other system functions operate in their normal manner, including the setting of the Line Status and MODEM Status Registers. The contents of the Interrupt Enable Register are indicated in Table II and are described below.
Bit 0 : This bit enabies the Received Data Available Interrupt when set to logic 1 .
Blt 1: This bit enables the Transmitter Holding Register Empty Interrupt when set to logic 1.
Bit 2: This bit enables the Receiver Line Status Interrupt when set to logic 1 .
Bit 3: This bit enables the MODEM Status Interrupt when set to logic 1.
Bits 4 through 7: These four bits are always logic 0 .

## MODEM CONTROL REGISTER

This 8 -bit register controls the interface with the MODEM or data set (or a peripheral device emulating a MODEM). The contents of the MODEM Control Register are indicated in Table II and are described below.
Bit 0 : This bit controls the Data Terminal Ready ( $\overline{\text { TTR }}$ ) output. When bit 0 is set to a logic 1 , the DTR output is forced to a logic 0 . When bit 0 is reset to a logic 0 , the DTB output is forced to a logic 1.
Note: The DTR output of the ACE may be applied to an EIA inverting line driver (such as the DS1488) to obtain the proper polarity input at the succeeding MODEM or data set.
Bit 1: This bit controls the Request to Send $\bar{R} \bar{T} \bar{\prime}$ ) output. Bit 1 affects the RTS output in a manner identical to that described above for bit 0 .
Bit 2: This bit controls the Output 1 (OUT ${ }^{1}$ ) signal, which is an auxiliary user-designated output. Bit 2 affects the OUT 1 output in a manner identical to that described above for bit 0.

Bit 3: This bit controls the Output 2 (ठUT 2) signal, which is an auxiliary user-designated output. Bit 3 affects the OUT 2 output in a manner identical to that described above for bit 0.

Bit 4: This bit provides a local loopback feature for diagnostic testing of the ACE. When bit 4 is set to logic 1 , the following occur: the transmitter Serial Output (SOUT) is set to the Marking (logic 1) state; the receiver Serial Input (SIN) is disconnected; the output of the Transmitter Shift Register is "looped back" into the Receiver Shift Register input; the four MODEM Control inputs (CTS, $\overline{\mathrm{DSR}}, \overline{\mathrm{DCD}}$, and $\overline{\text { FII }}$ ) are disconnected; and the four MODEM Control outputs (DTR, $\overline{\text { RTS, OUT 1, and OUT 2) are internally connected to the }}$ four MODEM Control inputs, and the MODEM Control output pins are forced to their inactive state (high). In the diagnostic mode, data that is transmitted is immediately received. This feature allows the processor to verify the trans-mit-and received-data paths of the ACE.
In the diagnostic mode, the receiver and transmitter interrupts are fully operational. The MODEM Control Interrupts are also operational, but the interrupts' sources are now the lower four bits of the MODEM Control Register instead of the four MODEM Control inputs. The interrupts are still controlled by the Interrupt Enable Register.
Bits 5 through 7: These bits are permanently set to logic 0.

## MODEM STATUS REGISTER

This 8 -bit register provides the current state of the control lines from the MODEM (or peripheral device) to the CPU. In addition to this current-state information, four bits of the MODEM Status Register provide change information. These bits are set to a logic 1 whenever a control input from the MODEM changes state. They are reset to logic 0 whenever the CPU reads the MODEM Status Register.

## Accessible Registers (Continued)

The contents of the MODEM Status Register are indicated in Table II and are described below.
Bit 0: This bit is the Delta Clear to Send (DCTS) indicator. Bit 0 indicates that the CTS input to the chip has changed state since the last time it was read by the CPU.
Bit 1: This bit is the Delta Data Set Ready (DDSR) indicator. Bit 1 indicates that the $\overline{D S R}$ input to the chip has changed state since the last time it was read by the CPU.
Bit 2: This bit is the Trailing Edge of Ring Indicator (TERI) detector. Bit 2 indicates that the $\overline{\mathrm{RI}}$ input to the chip has changed from a low to a high state.
Bit 3: This bit is the Delta Data Carrier Detect (DDCD) indicator. Bit 3 indicates that the $\overline{0} C \overline{0}$ input to the chip has changed state.
Note: Whenever bit $0,1,2$ or 3 is sel to logic 1, a MOCEM Status Intertupt is generated.

Bit 4: This bit is the complement of the Clear to Send (CTS) input. It bit 4 (loop) of the MCR is set to a 1, this bit is equivalent to RTS in the MCR.
Bit 5: This bit is the complement of the Data Set Ready (DSR) input. If bit 4 of the MCR is set to a 1 , this bit is equivalent of DTR in the MCR.
Bit 6: This bit is the complement of the Ring Indicator (RI) input. If bit 4 of the MCR is set to a 1 , this bit is equivalent to OUT 1 in the MCR.
Bit 7: This bit is the complement of the Data Carrier Detect (DCD) input. If bit 4 of the MCR is set to a 1, this bit is equivalent to OUT 2 of the MCR.

## SCRATCHPAD REGISTER

This 8-bit Read/Write Register does not control the ACE in any way. It is intended as a scratchpad register to be used by the programmer to hold data temporarily.

## Typical Applications

This shows the basic connections of an NS16450 to an NS32016 CPU


Typical Applications (Conitinued)
This shows the basic connections of an INS8250A to an 8088 CPU


TL/C/8401-15

Typical Interface for a High-Capacity Data Bus


Typical Supply Current vs. Temperature, Normalized


## Ordering Information

\left.| Order Number | Description |
| :---: | :--- |
| Plastic Dip Package |  |
| NS16450N |  |
| or |  |
| NS-16450N |  |\(\right\left.\} \quad \begin{array}{l}high speed part <br>

INS8250AN <br>
INS8250AWN <br>
NS16C450N* <br>
INS82C50AN* <br>
Plastic Chip Carrier Package <br>
NS16450V <br>
or <br>

NS-16450V\end{array}\right\} \quad\)| VCC $=5 \mathrm{~V} \pm 5 \%$ |
| :--- |
| INS8250A |
| NS16C450V |$\quad$| CMOS high speed part |
| :--- |
| INS82C50AV |

[^2]


## Physical Dimensions inches (millimeters) (Continued)



44-Lead Plastic Chip Carrier (V) Order Number NS16450V, NS-16450V, iNS6250A, NS16C450V or INSe2C50AV NS Package Number V44A

## LIFE SUPPORT POLICY

NATIONAL'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS WRITTEN APPROVAL OF THE PRESIDENT OF NATIONAL SEMICONDUCTOR CORPORATION. As used herein:

1. Life support devices or systems are devices or systems which, (a) are intended for surgical implant into the body, or (b) support or sustain life, and whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user.
2. A critical component is any component of a life support device or system whose failure to pertorm can be reasonably expected to cause the failure of the life support device or system, or to affect its safety or effectiveness.

|  | Mationel Semiconductor Corporation 2900 Sermiconductor Drve PO Box 58080 <br> Saris Clual Cal 95052-8090 <br> Tel: (400) 721.5000 <br> TWX: 1910) 339.9240 | Montional semiconductior <br> Onbl <br> Furstennederstrasie $\operatorname{Nr} .5$ <br> 0-6000 Munction 21 <br> Weat Gemmery <br> Tol ( $\mathbf{0 0 9 1} 560120$ <br> Telex: 522772 | ms Jupen K.K. <br> 4-403 ikebukuro. <br> Toshima-ku, <br> Tokyo 171. Jepan <br> tel (00) 808-2131 <br> FAX: 017-81-3.989.1700 | Mshak. Led. <br>  <br> Austin Tower, ith Flocr <br> 22-25 Austin Avenut <br> Trimenataxi, Kowloon. <br> Hong Kong <br> Tel: 3-7231290, 3.7243045 <br> Crble: NSSEAnKTG <br> Telec: 52008 NSSEA HX | Metionel sembeondeterve <br> Do Eruell Lata. <br> 6 Ander <br> 01452 Seo Pailo. SP. Braw <br> Tet: (55/t1) 212-5096 <br> Telex: 391+1131931 NSER BR | metional samioenduction <br> (Alatratol PTY, LDA. <br> 21/3 rimb Struen <br> Beymwater. victorias 3153 <br> T*; (03) 7290333 <br> Telex: A A3200s |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |

[^3]MICROELECTRONICS DIVISION

NCR 8496
SOUND GENERATOR
DATA SHEET

## NCR 8496 SOUND GENERATOR

TABLE OF CONTENTS
SECTION1 GENERAL DESCRIPTION2
2 FUNCTIONAL DESCRIPTIONS ..... 4
2.1 Control Registers ..... 4
2.2 Tone Generation ..... 4
2.3 Noise Generation ..... 5
2.4 Data Transfer ..... 6
2.5 CPU Interface ..... 7
2.6 Output Circuitry ..... 8
3 INTERFACE DEFINITIONS ..... 9
3.1 Microprocessor Interface ..... 9
3.2 Audio Application Interface ..... 10
3.3 Power Interface ..... 10
4 ELECTRICAL CHARACTERISTICS ..... 11
4.1 Operating Conditions ..... 11
4.2 Input Characteristics ..... 11
4.3 Output Characteristics ..... 12
4.4 Audio Characteristics ..... 12
5 TIMING REQUIREMENTS ..... 13
LIST OF ILLUSTRATIONS

1. FUNCTIONAL PIN GROUPING ..... 2
2. FUNCTIONAL PIN OUT ..... 2
3. FUNCTIONAL BLOCK DIAGRAM ..... 3
4. DATA TRANSFER TIMING ..... 13

## SECTION 1

## GENERAL DESCRIPTION

The NCR 8496 is an NMOS digital sound generator capable of providing applications with a low cost solution for noise and sound generation.

FEATURES

- Functionally and Pin compatible with the SNR76496
- Programmable white or periodic noise generator
- Three programmable tone generators
- Programmable attenuation values
- Simultaneous multiple sound generation
- TTL compatible
- 4 MHz maximum clock input
- External audio input added to Internal Generators

NCR 8496 FUNCTIONAL PIN OUT


NCR 8496
FUNCTIONAL PIN GROUPING


NCR 8496 FUNCTIONAL BLOCK DIAGRAM

SECTION 2

## FUNCTIONAL DESCRIPTIONS

### 2.1 Control Registers

The NCR 8496 Sound Generator has eight (8) internal registers used to control three (3) tone generators and one (1) noise generator. A three (3) bit data word used to determine the destination control register is contained in the first byte of data for all data transfers. The internal register designations are as follows:

| Address Bits |  | Register Destination |  |
| :---: | :---: | :---: | :---: |
| RO | R1 | $\underline{R 2}$ | Description |
| 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 |

Note: RO is the most significant address bit

### 2.2 Tone Generation

The NCR 8496 sound generator has three (3) programmable tone generators, each with separate frequency synthesis and attenuation sections. The frequency synthesis section requires ten (10) bits of data (F0 to F9) to define half the period of the desired frequency. This data is entered into a ten (10) stage tone counter, which is decremented at a rate of $N / 16$ where $N$ is the clock input frequency. A signal is produced when this tone counter decrements to one, which toggles a divide by two counter and reloads the tone counter. Therefore, the period of the desired frequency is twice the value of the tone generator.

The frequency of each tone generation is calculated using the equation:

$$
\begin{gathered}
\mathrm{f}=\mathrm{N} / 32 \mathrm{n} \\
\mathrm{n}=\mathrm{N}=\text { the clock input frequency } \\
\mathrm{N}=\text { bit binary number }[2<\mathrm{n}<1023]
\end{gathered}
$$

The divide by two counter is directly connected to a four stage attenuator whose values and bit position in the data word are shown in the following table:

## ATTENUATION CONTROL

| Data |  |  |  | Value | Data |  |  |  | Value |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AO | Al | A2 | A3 | dB | A0 | Al | A2 | A3 | $\underline{\text { dB }}$ |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | -16 |
| 0 | 0 | 0 | 1 | -2 | 1 | 0 | 0 | 1 | -18 |
| 0 | 0 | 1 | 0 | -4 | 1 | 0 | 1 | 0 | -20 |
| 0 | 0 | 1 | 1 | -6 | 1 | 0 | 1 | 1 | -22 |
| 0 | 1 | 0 | 0 | -8 | 1 | 1 | 0 | 0 | -24 |
| 0 | 1 | 0 | 1 | -10 | 1 | 1 | 0 | 1 | -26 |
| 0 | 1 | 1 | 0 | -12 | 1 | 1 | 1 | 0 | -28 |
| 0 | 1 | 1 | 1 | -14 | 1 | 1 | 1 | 1 | OFF |

Note: A0 is the most significant bit of data

### 2.3 Noise Generation

The NCR Sound Generator has two (2) noise sources (periodic and white), which share a common attenuator. These noise sources are shift registers with an exclusive NOR feedback network. One (1) of four (4) noise generator shift rates, each rate being derived from the input clock, will be controlled by the two (2) NF bits, as is shown in the following table:

NOISE GENERATOR FREQUENCY CONTROL

| NF BITS  FREQUENCY CONTROL <br> NFO NFI SHIFT RATE <br> 0 0 N/512 <br> 0 1 N/1024 <br> 1 0 N/2048 <br> 1 1 Tone Generator <br> \#3 Output   |
| :--- |

The choice of either periodic or white noise is controlled by the noise feedback control bit FB, as is shown in the following table:

| NOISE FEEDBACK CONTROL |
| :--- |
| FB CONFIGURATION <br> 0 Periodic Noise <br> 1 White Noise |

### 2.4 Data Transfer

The NCR 8496 Sound Generator is enabled by the CPU by asserting a low logic level to $\overline{\mathrm{CE}}$. $\overline{\mathrm{WE}}$ strobes the contents of the data bus to the appropriate control register. Data bus contents must be valid at this time. Data transfers cannot occur unless $\overline{C E}$ is true.

Thirty two (32) clock cycles are required by the NCR 8496 to load data into the control register. The READY output used as a handshake signal to synchronize the CPU, is asserted to a low logic level immediately following the leading edge of $\overline{\mathrm{CE}}$. READY assumes a true state via an external pull up register once the data transfer has been completed.

Formats for Data Transfer are as follows:

FREQUENCY UPDATE (Double Byte Transfer)

FIRST BYTE SECOND BYTE



NOISE SOURCE UPDATE (Single Byte Transfer)

| SHIFT RATE | FEEDBACK |  | REGISTER ADDRESS | BIT 0 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| NFI NFO | FB | X | R2 R1 R0 | 1 |

ATTENUATOR UPDATE (Single Byte Transfer)

| DATA |  |  | REGISTER ADDRESS |  | BIT 0 |  |
| :--- | :--- | :--- | ---: | ---: | ---: | ---: |
| A3 | A2 | A1 | A0 | R2 | R1 | R0 |
| D7 |  |  | 1 |  |  |  |

### 2.5 CPU INTERFACE

Eight (8) data lines (D0-D7) and three (3) control lines ( $\overline{W E}, \overline{C E}, ~ R E A D Y$ ) interface the NCR 8496 Sound Generator to the CPU. As indicated in Section 2.2, Tone Generation, ten (10) bits of data are required by each tone generator in selecting frequency values. Frequency updates require double byte data transfers. An additional four (4) bits of data are required to select the attenuation values. Attenuation updates require only single byte data transfers. (See Section 2.4: Data Transfer).

Tone generators can be quickly updated by initially sending both bytes of frequency and register data, followed by only the second byte of data for succeeding values only if no other control registers are accessed at the time of generator updating. This action is accomplished by latching the register address and permitting the continued transfer of data into the same register. This updating feature permits the expedited modification of the six (6) most significant bits of data needed for frequency sweeps.

### 2.6 OUTPUT CIRCUITRY

The NCR 8496 Sound Generator output circuitry, emulating a conventional op amp summing circuit, sums the three (3) tone and one (l) noise generator outputs, and will source/sink current to 2 mA . The 0 dB output signal per generator is nominally a 450 mV square in the negative direction from a 2 V quiescent level. The output should be OR coupled into the application audio circuit via a filtering network similar to the following:


The upper and lower frequency poles for the application are determined from the following equations:

Lower Pole
$\mathrm{f} \cong \frac{1}{2 \pi\left(\mathrm{R}_{\mathrm{A}}+\mathrm{R}_{\mathrm{B}}\right) \mathrm{C}_{\mathrm{A}}}$

Upper Pole
$\mathrm{f} \cong \frac{1}{2 \pi\left(\mathrm{R}_{\mathrm{A}} / / \mathrm{R}_{\mathrm{B}}\right) \mathrm{C}_{\mathrm{B}}}$

Attenuation of the output signal is:


Typically $R_{B} \geq 10 R_{A}$ so that the attenuation can be small while achieving desired filtering at the same time.

### 2.7 AUDIO INPUT CIRCUIT

This input node can be biased on with a current to give an approximate transfer function at the output of :
$V_{O}=R_{\text {Amp }} I_{\text {in }}$ where $R_{\text {Amp }}$ is on the order of 1 K Ohms
Typical input application:

$R_{B}$ provides the bias current to put the amplifier in the linear range.
$R_{\text {sig }}$ controls the input current causing the signal swing.

| SECTION 3 |  |  |
| :---: | :---: | :---: |
| INTERFACE DEFINITION |  |  |
| 3.1 MICROPROCESSOR INTERFACE |  |  |
| Signal | Pin | Description |
| READY | 4 | OUTPUT: Open collector, READY indicates that data has been read when true (high). The CPU must be placed in a wait state until READY is true. |
| WE | 5 | INPUT: Write Enable $\overline{W E}$ indicates that data is available to the NCR 8496 when true (low). |
| CE | 6 | INPUT: Chip Enable $\overline{C E}$ indicates that data may be transferred to the NCR 8496. |
| RST | 9 | INPUT: Master Reset $\overline{R S T}$ is used for testing purposes only. This pin is a no connect on the SN 76489A and is internally pulled high. |
| D7 | 10 | Inputs: D0-D7 is the data bust |
| D6 | 11 | through which data is |
| D5 | 12 | transferred. D0 is the most |
| D4 | 13 | significant data bit. D7 is the |
| D3 | 15 | least significant data bit. |
| D2 | 1 |  |
| D1 | 2 |  |
| D0 | 3 |  |
| CLK | 14 | Input clock |

3.2 AUDIO APPLICATION INTERFACE

| Signal | pin | Description |
| :--- | ---: | :--- |
| Audio | 7 | OUTPUT: Audio signal to <br> application. Refer to section <br> 2.6 .0 Otput Circuitry for <br> recommended output connections. |
| Audio In | 9 | INPUT: Audio input signal from <br> application. Refer to section <br> 2.7. |

### 3.3 POWER INTERFACE

| Signal | Pin | Description |
| :--- | ---: | ---: | :--- |
| VCC | 16 | Supply Voltage |
| GND | 8 | Ground Reference |

## SECTION 4

## ELECTRICAL CHARACTERISTICS

### 4.1 OPERATING CONDITIONS

| Parameter | Symbol | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ |  | 4.5 | 5.5 | V |
| Supply Current | $I_{C C}$ | Outputs Open |  | 40 | mA |
| Operating Temperature | $\mathrm{T}_{0}$ |  | 0 | +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\mathrm{S}}$ |  | -65 | +150 | ${ }^{\circ} \mathrm{C}$ |
| Absolute Maximum | $\mathrm{V}_{\text {max }}$ | To Any Pin |  | 7.0 | V |

### 4.2 INPUT CHARACTERISTICS

| Parameter | Symbol | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input <br> Voltage Low | $\mathrm{V}_{\text {IL }}$ | $\begin{aligned} & \text { D0-D7, } \overline{\mathrm{WE}}, \\ & \overline{\mathrm{CE}}, \mathrm{CLK} \end{aligned}$ |  | 0.8 | V |
| Input <br> Voltage High | $\mathrm{V}_{\text {IH }}$ | $\begin{aligned} & \mathrm{D} 0-\mathrm{D} 7, \overline{\mathrm{WE}} \\ & \overline{\mathrm{CE}}, \mathrm{CLK} \end{aligned}$ | 2.0 |  | V |
| Input <br> Current | $\mathrm{I}_{\mathrm{I}}$ | $\mathrm{v}_{\mathrm{in}}-\mathrm{GND} \rightarrow \mathrm{v}_{\mathrm{CC}}$ | -10 | +10 | uA |
| Input <br> Capacitance | $\mathrm{C}_{\text {I }}$ |  |  | 15 | pf |

4.3 OUTPUT CHARACTERISTICS

| Parameter | Symbol | Conditions Min | Max | Units |
| :--- | :--- | :--- | :--- | :---: |
| Output <br> Voltage Low | $\mathrm{V}_{\text {OL }}$ | $\mathrm{I}_{\text {OUT }}=-2 \mathrm{~mA}$ (READY) | 0.4 | V |

4.4 AUDIO CHARACTERISTICS

| Parameter | Symbol | Conditions | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Audio Input Current |  | Causing half scale output swing |  | 2.0 | mA |
| Source Current | $\mathrm{I}_{\text {SO }}$ | Over Output Voltage Swing |  | -3 | mA |
| $\begin{aligned} & \text { Sink } \\ & \text { Current } \end{aligned}$ | $\mathrm{I}_{\text {So }}$ | Over Output Voltage Swing |  | 2 | mA |
| Quiescent Output | $\mathrm{v}_{0 Q}$ |  | 2.1 |  | v |
| Maximum output | $\mathrm{v}_{\mathrm{OM}}$ | Generators at 0 dB | 0.5 |  | v |
| $\begin{aligned} & \text { Signal } \\ & \text { Swing } \end{aligned}$ | $\mathrm{v}_{\text {SW }}$ | Generators at 0 dB | 450 |  | mV |
| Capacitance Loading * | $\mathrm{C}_{\mathrm{OL}}$ | From Pin 7 to Ground for Stability |  | 200 | pf |
| Audio Input Bias Voltage |  | $\mathrm{R}=4.7 \mathrm{k}$ ohms | 1.0 V | 1.2 V |  |

* Does not apply to coupling capacitors which are connected to loads $>500$ ohms. It is recommended that capacitors to ground be isolated by a series resistance of 500 ohms for stability.


## SECTION 5

## TIMING REQUIREMENTS

| Parameter | Symbol | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CE READY | ${ }^{\text {ceR }}$ | $\begin{aligned} & \mathrm{CL}=225 \mathrm{pf} \\ & \mathrm{RL}=2 \mathrm{~K} \text { to } \mathrm{vCC} \end{aligned}$ |  | 150 | ns |
| Frequency Input | CLOCK | Transition Time | . 05 | 4 | MHz |
| Set up Time | $\begin{aligned} & \mathrm{t}_{\text {su2 }} \\ & \mathrm{t}_{\text {sul }} \end{aligned}$ | $\frac{\text { Data }}{\mathrm{CE}} \rightarrow \overline{\mathrm{WE}} \overline{\mathrm{WE}}$ | 0 |  | ns |
| Hold Time | $t_{\text {h }}$ | Data $\rightarrow$ READY | 0 |  | nS |

DATA TRANSFER TIMING


## DUAL 4.CHANNEL ANALOG DATA SELECTOR

The MC145298 analog data selector is a dual 4 -channel or single 8 -channel device depending on the input coding. The device is suitable for digital as well as analog application, including various one-of-four and one-of-eight data selector functions. Since the device has bidirectional analog characteristics it can also be used as a dual binary to 1 -of-4 or a binary to 1 -of- 8 decoder.

- Data Paths Are Bidirectional
- Ouiescent Current $=1.0 \mathrm{nA} /$ package typical @ 5.0 Vdc
- $10-\mathrm{MHz}$ Operation (typical)
- 3-State Outputs
- Linear "On" Resistance
- "On" Resistance 120 Ohms typical @ 15 V
- Low Noise - $12 \mathrm{nV} / \sqrt{\text { Cycle }}, \mathrm{f} \geqslant 1 \mathrm{kHz}$ typical
- Supply Voltage Range $=3.0 \mathrm{Vdc}$ to 18 Vdc
- Capable of Driving Two Low-power TTL Loads, One Low-power Schottky TTL Load or Two HTL Loads Over the Rated Temperature Range

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| DC Supply Voltage | $V_{\text {DD }}$ | -05 to +18 | Voc |
| Input Voltage, All inputs | $V_{\text {In }}$ | -0.5 to $\mathrm{V}_{\text {DD }}+0.5$ | Vdc |
| DC Current Drain per Pin | 1 | 10 | mAdc |
| Operating Temperature Range . AL Device CL/CP Device | $\mathrm{T}_{\text {A }}$ | $\begin{aligned} & -55 \text { to }+125 \\ & -40 \text { to }+85 \\ & \hline \end{aligned}$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{5 \text { stg }}$ | $-6510+150$ | ${ }^{\circ} \mathrm{C}$ |


| TRUTH TABLE |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| STX | STY | B | A | Z | W |  |
| ! | 1 | 0 | 0 | $\times$ | Yo | Dual 4 Channel Mode 2 Outputs |
| 1 | 1 | 0 | 1 | $\times 1$ | Y1 |  |
| 1 | 1 | 1 | 0 | $\times 2$ | $Y 2$ |  |
| 1 | 1 | 1 | 1 | $\times 3$ | Y3 |  |
| 1 | 0 | 0 | 0 | $\times 0$ |  |  |
| 1 | 0 | 0 | 1 | $\times 1$ |  |  |
| 1 | 0 | 1 | 0 | $\times 2$ |  | Single 8 Channel Mode |
| 1 | 0 | 1 | 1 | $\times 3$ |  | 1 Output |
| 0 | 1 | 0 | 0 | YO |  | ( $Z$ and $W$ tied together) |
| 0 | 1 | 0 | 1 | Y 1 |  |  |
| 0 | ; | 1 | 0 | Y2 |  |  |
| 0 | 1 | 1 | 1 | $\bigcirc 3$ |  |  |
| 0 | 0 | $\phi$ | ¢ |  |  |  |

> This device contains circuitry to protect the control inputs against damage due to high static voltages or electric fields: however, it is advised that normat precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high-impedance circuit. A destructive high-current mode may occur if $V_{\text {in }}$ or $V_{\text {out }}$ is not constrained to the range $V_{S S} \leqslant V_{\text {in }}$ or $V_{\text {out }} \leqslant V_{D D}$.

## CMOS SSI

(LOW POWER COMPLEMENTARY MOS)
DUAL 4-CHANNEL ANALOG DATA SELECTOR OR
8.CHANNEL ANALOG DATA SELECTOR


ELECTRICAL CHARACTERISTICS

$* T$ Tow $=-55^{\circ} \mathrm{C}$ for $A L$ Device, $-40^{\circ} \mathrm{C}$ for CL/CP Device
${ }^{-}$Thigh $=+125^{\circ} \mathrm{C}$ for AL Device, $+85^{\circ} \mathrm{C}$ for CL/CP Device.
\#Noise immunity specified for worst-case input combination
Noise Margin for both " 1 " and " 0 " level $=1.0 \mathrm{Vdc} \min @ \mathrm{~V}_{D D}=5.0 \mathrm{Vdc}$ $2.0 \mathrm{Vdc} \min @ V_{D D}=10 \mathrm{Vdc}$ $2.5 \mathrm{Vdc} \min @ V_{D D}=15 \mathrm{Vdc}$

SWITCHING CHARACTERISTICS $\mathrm{IT}_{A}=25^{\circ} \mathrm{C}$

| Characteristic | Figure | Symbol | $\mathrm{V}_{\mathbf{S S}}$ | VDD | Typical All Types | Maximum |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | AL Dovico | CL/CP Doviee |  |
| $V_{\text {in }}$ to $V_{\text {out }}$ Propagation Delay Time $\left(C_{L}=50 \mathrm{pF}, R_{L}=1.0 \mathrm{k} \Omega\right)$ | 7 | ${ }^{\text {TPLH, }}$ PHL | 0.0 | $\begin{aligned} & 5.0 \\ & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & 20 \\ & 10 \\ & 8.0 \end{aligned}$ | $\begin{aligned} & 40 \\ & 20 \\ & 15 \end{aligned}$ | $\begin{aligned} & 60 \\ & 30 \\ & 25 \\ & \hline \end{aligned}$ | ns |
| $\begin{aligned} & \text { Propagation Delay Time, Control to } \\ & \text { Output, } V_{\text {in }}=V_{D D} \text { or } V_{S S} \\ & \left\{V_{\text {in }}<10 \mathrm{Vdc}, C_{L}=50 \mathrm{pF},\right. \\ & \left.R_{L}=1.0 \mathrm{k} \Omega\right) \\ & \hline \end{aligned}$ | 8 | tPhL. PLCH | 0.0 | $\begin{aligned} & 5.0 \\ & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & 200 \\ & 80 \\ & 50 \end{aligned}$ | $\begin{aligned} & 400 \\ & 160 \\ & 120 \end{aligned}$ | $\begin{aligned} & 600 \\ & 240 \\ & 180 \end{aligned}$ | ns |
| $\begin{aligned} & \text { Crosstalk, Control to Output } \\ & \left(C_{L}=50 \mathrm{pF}, R_{\mathrm{L}}=1.0 \mathrm{k} \Omega\right) \\ & \left.\mathcal{R}_{\text {out }}=10 \mathrm{k} \Omega\right) \end{aligned}$ | 9 | - | 0.0 | $\begin{aligned} & 5.0 \\ & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & 5.0 \\ & 5.0 \\ & 5.0 \end{aligned}$ | - | - | $m V$ |
| Maximum Control input Putse Frequency $\left.1 C_{L}=50 \mathrm{pF}, R_{L}=1.0 \mathrm{k} \Omega\right\}$ | 10 | - | 0.0 | $\begin{aligned} & 5.0 \\ & 10 \\ & 15 \\ & \hline \end{aligned}$ | $\begin{gathered} 5.0 \\ 10 \\ 12 \\ \hline \end{gathered}$ | - | - | MHz |
| $\begin{aligned} & \text { Noise Voltage } \\ & (f=100 \mathrm{~Hz}) \\ & (f=100 \mathrm{kHz}) \end{aligned}$ | 11.12 | $\cdots$ | 0.0 | $\begin{aligned} & 5.0 \\ & 10 \\ & 15 \\ & 5.0 \\ & 10 \\ & 15 \\ & \hline \end{aligned}$ | $\begin{aligned} & 24 \\ & 25 \\ & 30 \\ & 12 \\ & 12 \\ & 15 \\ & \hline \end{aligned}$ | $\begin{aligned} & - \\ & - \\ & - \\ & - \end{aligned}$ |  | $\mathrm{nV} / \sqrt{\text { Cracte }}$ |
| Sine Wave (Distortion) $\begin{aligned} & \left(V_{\text {in }}=1.77 \mathrm{Vdc}\right. \text { RMS } \\ & \text { Centered @ } 0.0 \mathrm{Vdc} \end{aligned}$ <br> Centered@ 0.0 Vdc, $R_{L}=10 \mathrm{ksi}, \mathrm{f}=1.0 \mathrm{kHz}$ | -- | - | -5.0 | 5.0 | 0.36 | - | - | \% |
| Input/Output Leakage Current $\begin{aligned} & \left(\mathrm{V}_{\text {in }}=+5.0 \mathrm{Vdc}, \mathrm{~V}_{\text {out }}=-5.0 \mathrm{Vdc}\right) \\ & \left(\mathrm{V}_{\text {in }}=-5.0 \mathrm{Vdc}, \mathrm{~V}_{\text {out }}=+5.0 \mathrm{Vdc}\right) \\ & \left(\mathrm{V}_{\text {in }}=+7.5 \mathrm{Vdc}, \mathrm{~V}_{\text {out }}=-7.5 \mathrm{Vdc}\right) \\ & \left(\mathrm{V}_{\text {in }}=-7.5 \mathrm{Vdc}, \mathrm{~V}_{\text {out }}=+7.5 \mathrm{Vdc}\right) \end{aligned}$ | - | - | $\begin{aligned} & -5.0 \\ & -5.0 \\ & -7.5 \\ & -7.5 \end{aligned}$ | $\begin{aligned} & 5.0 \\ & 5.0 \\ & 7.5 \\ & 7.5 \end{aligned}$ | $\begin{aligned} & \pm 0.001 \\ & \pm 0.001 \\ & \pm 0.0015 \\ & \pm 0.0015 \end{aligned}$ | $\begin{aligned} & \pm 125 \\ & \pm 125 \\ & \pm 250 \\ & \pm 250 \end{aligned}$ | $\begin{aligned} & \pm 125 \\ & \pm 125 \\ & \pm 250 \\ & \pm 250 \end{aligned}$ | nA |
| Insertion Loss $1 \mathrm{~V}_{\mathrm{in}}=1.77 \mathrm{Vdr}$ <br> RMS centered @ 0.0 Vdc , $f=1.0 \mathrm{MHz}$ $\begin{gathered} I_{\text {loss }}=20 \log 10 \frac{V_{\text {out }}}{V_{\text {in }}} \\ \left(R_{L}=1.0 \mathrm{k} \Omega\right) \\ \left(R_{L}=10 \mathrm{k} \Omega\right) \\ \left(R_{L}=100 \mathrm{k} \Omega\right) \\ \left(R_{L}=1.0 \mathrm{~m} \Omega\right) \\ \hline \end{gathered}$ | - | - | -5.0 | 5.0 | $\begin{gathered} 2.0 \\ 0.8 \\ 0.25 \\ 0.01 \\ \hline \end{gathered}$ | - | - | dB |
| Bandwidth ( -3 dB ) $1 \mathrm{~V}_{\text {in }}=1.77 \mathrm{Vdc}$ <br> RMS centered @ 0.0 Vdc ) $\begin{aligned} & \left(R_{L}=1.0 \mathrm{k} \Omega\right) \\ & \left(R_{L}=10 \mathrm{k} \Omega\right) \\ & \left(R_{L}=100 \mathrm{k} \Omega\right) \\ & \left(R_{L}=1.0 \mathrm{~m} \Omega\right) \end{aligned}$ | - | BW | -5.0 | 5.0 | $\begin{aligned} & 35 \\ & 28 \\ & 27 \\ & 26 \end{aligned}$ | - | - | MHz |
| $\begin{aligned} & \text { Feedthrough and Crosstalk } \\ & \qquad \begin{array}{l} \left(20 \log 10 \frac{V_{\text {out }}}{V_{\text {in }}}=-50 \mathrm{~dB}\right) \\ \left(R_{L}=1.0 \mathrm{k} \Omega\right) \\ \left(R_{L}=10 \mathrm{k} \Omega\right) \\ \left(R_{L}=100 \mathrm{k} \Omega\right) \\ \left(R_{L}=1.0 \mathrm{M} \Omega\right) \end{array} \end{aligned}$ | - | - | -5.0 | 5.0 | $\begin{gathered} 850 \\ 100 \\ 12 \\ 1.5 \end{gathered}$ | - - - - | - - - - | kHz |



TYPICAL RON versus INPUT VOLTAGE


## MC14529B



FIGURE 8 - TURN-ON DELAY TIME TEST CIRCUIT AND WAVEFORMS


FIGURE 10 - FREQUENCY RESPONSE TEST CIRCUIT


FIGURE 11 - NOISE VOLTAGE TEST CIRCUIT


FIGURE 12 - TYPICAL NOISE CHARACTERISTICS


## MC14529B

## FIGURE 13 - TYPICAL INSERTION LOSS/BANDWIDTH <br> CHARACTERISTICS




## (M) motorola

## SEMICONDUCTORS

P.O. BOX 20912 • PHOENIX, ARIZONA 85036


## QUAD LINE DRIVER

The MC1488 is a monolithic quad line driver designed to interface data terminal equipment with data communications equipment in conformance with the specifications of EIA Standard No. RS-232C.

## Features:

- Current Limited Output

$$
\pm 10 \mathrm{~mA} \text { typ }
$$

- Power Off Source Impedance 300 Ohms min
- Simple Slew Rate Control with External Capacitor
- Flexible Operating Supply Range
- Compatible with All Motorola MDTL and MTTL Logic Families


MAXIMUM RATINGS ( $T_{A}=+25^{\circ} \mathrm{C}$ unless otherwise noted.)

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Power Supply Voltage | $\begin{aligned} & v_{C C} \\ & v_{E E} \end{aligned}$ | $\begin{array}{r} +15 \\ -15 \\ \hline \end{array}$ | Vdc |
| Input Voltage Range | $V_{\text {IR }}$ | $-15 \leqslant V_{\text {IR }} \leqslant 7.0$ | Vdc |
| Output Signal Voltage | $\mathrm{V}_{\mathrm{O}}$ | $\pm 15$ | Vdc |
| Power Derating (Package Limitation, Ceramic and Plastic Dual-In-Line Package) Derate above $T_{A}=+25^{\circ} \mathrm{C}$ | $\begin{gathered} P_{D} \\ 1 / R_{A J A} \end{gathered}$ | $\begin{gathered} 1000 \\ 6.7 \end{gathered}$ | $\mathrm{mW}_{\mathrm{mW} /{ }^{\circ} \mathrm{C}}$ |
| Operating Ambient Temperature Range | $\mathrm{T}_{\text {A }}$ | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{\mathrm{stg}}$ | -65 to +175 | ${ }^{\circ} \mathrm{C}$ |

ELECTRICAL CHARACTERISTICS $\left\{V_{C C}=+9.0 \pm 1 \% V\right.$ óc, $V_{E E}-9.0 \pm 1 \% V d C . T_{A}=0$ to $+75^{\circ} \mathrm{C}$ unless otherwise noted)

| Characteristic | Figure | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input Current - Low Logic State $\left(\mathrm{V}_{\text {IL }}=0\right)$ | 1 | ${ }_{1} \mathrm{IL}$ |  | 10 | 16 | $m \mathrm{~A}$ |
| Input Current . High Logic State ( $\mathrm{V}_{1 \mathrm{H}}=5.0 \mathrm{~V}$ ) | 1 | $\mathrm{I}_{1 \mathrm{H}}$ |  |  | 10 | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { Output Voltage High Logic State } \\ & \left(\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{Vdc}, \mathrm{R}_{\mathrm{L}}=3.0 \mathrm{ks}, \mathrm{~V}_{\mathrm{CC}}=+9.0 \mathrm{Vdc}, \mathrm{~V}_{\mathrm{EE}}=-9.0 \mathrm{Vdc}\right) \\ & \left(\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{Vdc}, \mathrm{R}_{\mathrm{L}}=30 \mathrm{ks}, \mathrm{~V}_{\mathrm{CC}}=+13.2 \mathrm{Vdc}, \mathrm{~V}_{E E}=-13.2 \mathrm{Vdc}\right) \end{aligned}$ | 2 | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & +6.0 \\ & +90 \end{aligned}$ | $\begin{aligned} & +70 \\ & +105 \end{aligned}$ |  | Vdc |
| Output Voltage Low Logic State $\left.\mathrm{V}_{1 H}=1.9 \mathrm{Vdc}, R_{L}=3.0 \mathrm{ks}, V_{C C}=+9.0 \mathrm{Vdc}, V_{E E}=-9.0 \mathrm{Vdc}\right)$ $\left(V_{I H}=19 \mathrm{Vdc}, R_{L}=3.0 \mathrm{ks}, V_{C C}=+132 \mathrm{Vdc}, V_{E E}=-13.2 \mathrm{Vdc}\right)$ | 2 | VOL | $\begin{aligned} & -6.0 \\ & -9.0 \end{aligned}$ | $\begin{aligned} & -70 \\ & -10.5 \end{aligned}$ |  | Vdc |
| Positive Output Short-Circuit Current (1) | 3 | 'OS+ | $+6.0$ | +10 | +12 | $m A$ |
| Negative Output Short Circuit Current (1) | 3 | Ios. | -6.0 | -10 | -12 | mA |
| Output Resistance ( $\left.\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\text {EE }}=0 .\left\|\mathrm{V}_{\mathrm{O}}\right\|- \pm 2.0 \mathrm{~V}\right)$ | 4 | ro | 300 |  |  | Onms |
| $\begin{gathered} \text { Positive Supply Current }\left(R_{1} \infty\right) \\ \left(V_{I H}=1.9 \mathrm{Vdc}, V_{C C}=+9.0 \mathrm{Vdc}\right) \\ \left(V_{I L}=0.8 \mathrm{Vdc}, V_{C C}=+9.0 \mathrm{Vdc}\right) \\ \left(V_{I H}=1.9 \mathrm{Vdc}, V_{C C}=+12 \mathrm{Vdc}\right) \\ \left(V_{I L}=0.8 \mathrm{Vdc}, V_{C C}=+12 \mathrm{Vdc}\right) \\ \left(V_{I H}=1.9 \mathrm{Vdc}, V_{C C}=+15 \mathrm{Vdc}\right) \\ \left(V_{I L}=0.8 \mathrm{Vdc}, V_{C C}=+15 \mathrm{Vdc}\right) \end{gathered}$ | 5 | ${ }^{1} \mathrm{CC}$ | - | $\begin{aligned} & +15 \\ & +45 \\ & +19 \\ & +55 \end{aligned}$ | $\begin{aligned} & +20 \\ & +6.0 \\ & +25 \\ & +7.0 \\ & +34 \\ & +12 \end{aligned}$ | $m A$ |
|  | 5 | 'EE |  | $\begin{gathered} -13 \\ - \\ -18 \end{gathered}$ | $\begin{array}{r} -17 \\ -500 \\ -23 \\ -500 \\ -34 \\ -2.5 \end{array}$ | mA <br> $\mu \mathrm{A}$ <br> $m A$ <br> $\mu \mathrm{A}$ <br> mA <br> mA |
| Power Consumption $\begin{aligned} & \left(V_{C C}=9.0 \mathrm{Vdc}, V_{E E}=-9.0 \mathrm{Vdc}\right) \\ & \left(V_{C C}=12 \mathrm{Vdc}, V_{E E}=-12 \mathrm{Vdc}\right) \end{aligned}$ |  | $P_{\text {C }}$ | - | $\cdots$ | $\begin{aligned} & 333 \\ & 576 \\ & \hline \end{aligned}$ | $m W$ |

SWITCHING CHARACTERISTICS $\left(V_{C C}=+9.0 \pm 1 \% V_{d c}, V_{E E}=-9.0 \pm 1 \% \mathrm{Vdc} . T_{A}=+25^{\circ} \mathrm{C}\right.$.)

| Propagation Delay Time | $\left(z_{1}=3.0 \mathrm{k}\right.$ and 15 pF$)$ | 6 | ${ }^{\text {P PLH }}$ | - | 275 | 350 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Fall Time | $\left(z_{i}=3.0 \mathrm{k}\right.$ and 15 pF$)$ | 6 | ${ }^{\text {t }}$ THL | - | 45 | 75 | ns |
| Propagation Delay Time | $\left(z_{1}=3.0 \mathrm{k}\right.$ and 15 pF$)$ | 6 | tPHL | - | 110 | 175 | ns |
| Rise Time | $\left(z_{1}=3.0 \mathrm{k}\right.$ and 15 pF$)$ | 6 | TILH | - | 55 | 100 | ns |

(1) Maximum Package Power Dissipation may be exceeded if all outputs are shorted simultaneousiy


MC1488

$\stackrel{4}{4}$
MOTOROLA Semiconductor Products Inc.

## MC1488

## APPLICATIONS INFORMATION

The Electronic Industries Association (E1A) RS232C specification detail the requirements for the interface between data processing equipment and data communications equipment. This standard specifies not only the number and type of interface leads, but aiso the voltage levels to be used. The MC1488 quad driver and its companion circuit, the MC1489 quad receiver, provide a complete interface system between DTL or TTL logic leveis and the RS232C defined levels. The RS232C requirements as applied to drivers are discussed herein.

The required driver voltages are defined as between 5 and 15 volts in magnitude and are positive for a logic " 0 " and negative for a logic " 1 ". These voltages are so defined when the orivers are terminated with a 3000 to 7000 -ohm resistor. The MC1488 meets this voltage requirement by converting a DTL/TTL logic level into RS232C levels with one stage of inversion

The RS232C specification further requires that during transitions, the driver output slew rate must not exceed 30 volts per microsecond. The inherent slew rate of the MC1488 is much too

FIGURE 12 - SLEW RATE versus CAPACITANCE FOR ${ }^{1} \mathrm{SC}=10 \mathrm{~mA}$

C. CAPACITANCE (DF)
fast for this requirement. The current limited output of the device can be used to control this slew rate by connecting a capacitor to each driver output. The required capacitor can be easily determined by using the relatimship $C=I O S \times \Delta T / \Delta V$ from which Figure 12 is derived. Accordingly, a 330 -pF capacitor on each output will guarantee a worst case slew rate of 30 volts per microsecond.

The interface driver is also required to withstand an accidental short to any other conductor in an interconnecting cable. The worst possible signal on any conductor would be another driver using a plus or minus 15 -volt, $500-\mathrm{mA}$ source. The MC 1488 is designed to indefinitely withstand such a short to all four outputs in a package as long as the power supply voltages are greater than 9.0 volts li.e. $V_{C C} \geqslant 9.0 \quad V_{:} V_{E E} \leqslant-9.0 \mathrm{~V}$. In some power-supply designs, a loss of system power causes a low impedance on the power-supply out. puts. When this occurs, a low impedance to ground would exist at the power inputs to the MC 1488 effectively shorting the 300 -ohm output resistors to ground. If all four outputs were then shorted to plus or minus 15 volts, the power dissipation in these resistors

FIGURE 13 - POWER SUPPLY PROTECTION TO MEET POWER-OFF FAULT CONDITIONS

would be excessive. Therefore, if the system is designed to permit low impedances to ground at the power suppties of the drivers, a diode should be placed in each power supply lead to prevent over. heating in this fault condition These two diodes, as shown in Figure 13, could be used to decouple all the driver packages in a system. (These same diodes will allow the MC1488 to withstand momentary shorts to the $\tau 25$-volt limits specified in the earlier Standard RS2328.) The addition of the diodes also permits the MC1488 to withstand faults with power-supplies of less than the 9.0 volts stated above.

The maximum short circuit current allowable under tawlt con ditions is more than guaranteed by the previously mentioned 10 mA output current himiting

## Other Applications

The MC1488 is an extremely versatile line driver with a myriad of possible applications. Several features of the drivers enhance this versatility

1. Output Current Lumiting this enables the circuit designer to define the output voltage tevels independent of power supplies and can be accomplished by diode clamping of the output pins Figure 14 shows the MC 1488 used as a DTL to MOS translator where the high level voltage output is clamped one diode above ground. The resistor divider shown is used to reduce the outgut voltage below the 300 mV above ground MOS input level timit
2. Power-Supply Range as can be seen from the schematic drawing of the drivers, the positive and negative driving elements of the device are essentially independent and do not requrre match ing power supplies In fact, the positive supply can vary from a minimum seven volts (required for driving the negative nulldown section) to the maximum specified 15 volts. The negative supply can vary from approximately -2.5 volts to the minimum specified -15 volts. The MC1488 will drive the output 10 within 2 volts of the positive or negative supplies as long as the current output limits are not exceeded. The combination of the current-limiting and supply-voltage features allow a wide combination of possible out puts within the same quad package. Thus if only a portion of the four drivers are used for driving RS 232 C lines, the remarnder could be used for DTL to MOS or even DTL to DTL translation Figure 15 shows one such combination

FIGURE 14 - MDTL/MTTL.TO.MOS TRANSLATOR


FIGURE 15 - LOGIC TRANSLATOR APPLICATIONS

THERMAL INFORMATION

The maximum power consumption an integrated circuit can tolerate at a given operating ambient temperature, can be found from the equation:

$$
P_{D}\left(T_{A}\right)=\frac{T_{J}(\text { max })-T_{A}}{R_{0 J A}\left(T_{y p}\right)}
$$

Where: $P_{D}\left(T_{A}\right)=$ Power Dissipation allowable at a given operating ambient temperature. This must be greater than
the sum of the products of the supply voltages and supply currents at the worst case operating condition.
$T_{J}(\max )=$ Maximum Operating Junction Temperature as listed in the Maximum Ratıngs Section
$T_{A}=$ Maximum Desired Operating Ambient Temperature
RoJA $\mid$ Typ $\mid=$ Typical Thermal Resistance Junction to Ambient

OUTLINE DIMENSIONS

1. DIMENSION "L"TO CENTER OF LEAOS WHEN FORMED PARALLEL.

| OIM | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
| A | 19.05 | 19.94 | 0.750 | 0.785 |
| B | 6.22 | 7.11 | 0.245 | 0.280 |
| C | 3.94 | 5.08 | 0.155 | 0.200 |
| D | 0.38 | 0.51 | 0.015 | 0.020 |
| F | 0.89 | 1.65 | 0.035 | 0.065 |
| G | 2.54 | BSC | 0.100 | BSC |
| H | 1.65 | 2.29 | 0.065 | 0.090 |
| J | 0.20 | 0.30 | 0.008 | 0.012 |
| K | 3.18 | 4.06 | 0.125 | 0.160 |
| L | 7.37 | 8.13 | 0.290 | 0.320 |
| M | - | 150 | - | 150 |
| N | 0.51 | 1.27 | 0.020 | 0.050 |


P SUFFIX PLASTIC PACKAGE CASE 646-05

NOTES:

1. LEADS WITHIN 0.13 mm (0.005) RAQIUS OF TRUE POSITION AT SEATING PLANE AT MAXIMUM MATERIAL CONDITION.
2. DIMENSION "L" TO CENTER OF LEADS WHEN FORMED PARALLEL.
3. DIMENSION "B" DOES NOT
INCLUDE MOLD FLASH.
4. ROUNDED CORNERS OPTIONAL.


## QUAD LINE RECEIVERS

The MC1489 monolithic quad line receivers are designed to inter face data terminal equipment with data communications equipment in conformance with the specifications of EIA Standard No. RS-232C

- Input Resistance -3.0 k to 7.0 kilohms
- Input Signal Range $- \pm 30$ Volts
- Input Threshold Hysteresis Built In
- Response Control
a) Logic Threshold Shifting
b) Input Noise Filtering






## MC1489 • MC1489A

MAXIMUM RATINGS $\left(T_{A}=+25^{\circ} \mathrm{C}\right.$ unless otherwise roted)

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Power Supply Voltage | $V_{C C}$ | 10 | Vdc |
| Input Voltage Range | $V{ }_{\text {IR }}$ | $\pm 30$ | Vdc |
| Output Load Current | $T_{L}$ | 20 | mA |
| Power Dissipation (Package Limitation, Ceramic and Plastic Dual In-Line Package) <br> Derate above $T_{A}=+25^{\circ} \mathrm{C}$ | $\begin{gathered} \mathrm{PD}_{\mathrm{D}} \\ 1 / 1 / \mathrm{JA} \end{gathered}$ | $\begin{gathered} 1000 \\ 6.7 \end{gathered}$ | $\begin{gathered} \mathrm{mW} \\ \mathrm{~mW} /{ }^{\circ} \mathrm{C} \end{gathered}$ |
| Operating Ambient Temperature R ange | $\mathrm{T}_{\text {A }}$ | 0 to +75 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{\text {stg }}$ | -65 to +175 | ${ }^{\circ} \mathrm{C}$ |

ELECTRICAL CHARACTERISTICS (Response control pin is open) ( $\mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{Vdc} \pm 1 \%, \mathrm{~T}_{\mathrm{A}}=0$ to $+75^{\circ} \mathrm{C}$ unless otherwise noted)

| Characteristics | Figure | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Positive Input Current $\quad \begin{aligned} & \left(\mathrm{V}_{1 \mathrm{H}}=+25 \overline{\mathrm{~V}} \mathrm{dc}\right) \\ & \left(\mathrm{V}_{1 \mathrm{H}}=+3.0 \mathrm{Vdc}\right)\end{aligned}$ | 1 | $\mathrm{I}_{1} \mathrm{H}$ | $\begin{gathered} 3.6 \\ 0.43 \end{gathered}$ |  | 8.3 | mA |
| Negative input Current - $\begin{aligned} & \left(V_{1 L}=-25 \mathrm{Vdc}\right) \\ & \left(V_{1 L}=-3.0 \mathrm{Vdc}\right)\end{aligned}$ | 1 | $1 / 15$ | $\begin{gathered} -3.6 \\ -0.43 \end{gathered}$ |  | -8.3 | mA |
| ```Input Turn On Threshold Voltage (TA}=+2\mp@subsup{5}{}{\circ}\textrm{C},\mp@subsup{V}{OL}{}\leq0.45\textrm{V} MC1489 MC1489A``` | 2 | $V_{\text {IHL }}$ | $\begin{gathered} 1.0 \\ 1.75 \end{gathered}$ | 1.95 | $\begin{gathered} 1.5 \\ 2.25 \end{gathered}$ | Vdc |
| $\begin{array}{ll} \text { Input Turn-Off Threshold Voltage } \\ \\ \qquad\left(\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{VOH}_{\mathrm{OH}} \geq 25 \mathrm{~V}, \mathrm{I}_{\mathrm{L}}=-0.5 \mathrm{~mA}\right) & \mathrm{MC} 1489 \\ & \end{array}$ | 2 | $\overline{\mathrm{V} \text { LH }}$ | $\begin{aligned} & 0.75 \\ & 0.75 \end{aligned}$ | 0.8 | $\begin{aligned} & 1.25 \\ & 1.25 \end{aligned}$ | Vde |
| Output Voltage High $\left(\mathrm{V}_{1 H}=0.75 \mathrm{~V}, \mathrm{I}_{\mathrm{L}}=-0.5 \mathrm{~mA}\right)$ <br> (Input Open Circuit, $\left.I_{L}=-0.5 \mathrm{~mA}\right)$ | 2 | VOH | $\begin{aligned} & 2.6 \\ & 2.6 \end{aligned}$ | $\begin{aligned} & 4.0 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & 50 \\ & 5.0 \end{aligned}$ | Vdc |
| Output Voltage Low $\left(\mathrm{V}_{1 \mathrm{~L}}=3.0 \mathrm{~V} . \mathrm{I}_{\mathrm{L}}=10 \mathrm{~mA}\right)$ | 2 | VOL |  | 0.2 | 0.45 | Vac |
| Qutpat Short Circuit Current | 3 | Ios |  | 3.0 |  | mA |
| Power Supply Current $\quad\left(\mathrm{V}_{1 \mathrm{H}}=+5.0 \mathrm{Vdc}\right)$ | 4 | ${ }^{1} \mathrm{CC}$ |  | 20 | 26 | mA |
| Power Consumption $\quad\left(\mathrm{V}_{1 \mathrm{H}}=+5.0 \mathrm{Voc}\right)$ | 4 | ${ }^{P} \mathrm{C}$ |  | 100 | 130 | mW |

SWITCHING CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 1 \%, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ )

| Pronagation Delay Time | $\left(R_{L}=39 \mathrm{k} \Omega 2\right)$ | 5 | ${ }^{\text {P PLH }}$ | 25 | 85 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Rise Time | $\left(\mathrm{R}_{L}-3.9 \mathrm{ks2}\right)$ | 5 | ${ }^{\text {t TLLH }}$ | 120 | 175 | ns |
| Propagation Delay Time | $\left(\mathrm{R}_{\mathrm{L}}=390 \mathrm{~s}!\right)$ | 5 | ${ }_{\text {t PHL }}$ | 25 | 50 | ns |
| Fall Time | $\left(R_{L}=390 \mathrm{~s}\right)$ | 5 | ${ }_{\text {THL }}$ | 10 | 20 | ns |

## MC1489 - MC1489A



## MC1488 • MC1489A



4
MOTOROLA Semiconductor Products Inc. $\qquad$

## MC1489 - MC1489A

## APPLICATIONS INFORMATION

## General Information

The Electronic Industries Association (E IA) has released the RS 232 C specification detailing the requirements for the interface between data processing equipment and data communications equipment This standard specifies not only the number and type of interface leads, but also the voltage levels to be used. The MC 1488 quad driver and its companion circuit. the MC 1489 quad receiver provide a complete interface system between DTL or TTL logic levels and the RS 232 C defmed levels. The RS 232 C requirements as applied to receivers are discussed herein

The required input impedance is defined as between 3000 ohms and 7000 ohms for input voltages between 3.0 and 25 volts in magnitude: and any voltage on the receiver input in an open circuit condition must be less than 2.0 volts in magnitude. The MC 1489 circuits meet these requirements with a maximum open circuit volt age of one $V_{B E}$ (Ref Sect 2.4)

The receiver shall detect a voltage between -3.0 and -25 volts as a logic " 1 " and inputs between +3.0 and +25 volts as a logic " 0 " (Ref. Sect. 2.3). On some interchange leads, an open circuit or power "OFF" condition $\$ 300$ ohms or more to groundl shall be decoded as an "OFF" condition or logic "1" (Ref Sect. 2.5). For this reason, the input hysteresis thresholds of the MC 1489 circuits are all above ground. Thus an open or grounded imput will cause the same output as a negative or logic " 1 " input

## Device Characteristics

The MC1489 interface receivers have internal feedback from the second stage to the input stage providing input hysteresis for noise

FIGURE 12 - TURN-ON THRESHOLD versus CAPACITANCE FROM RESPONSE CONTROL PINTO GND

rejection. The MC1489 input has typical turn-on voltage of 1.25 volts and turn-off of 1.0 volt for a typical hysteresis of 250 mV . The MC1489A has typical turn-on of 1.95 volts and turn-off of 0.8 volt for typicalty 1.15 volts of hysterests

Each receiver section has an external response control node in addition to the input and output pins, thereby allowing the design. er to vary the input threshold voltage levels. A resistor can be connected between this riode and an external power-supply. Figures 6,8 and 9 illustrate the input threshold voltage shift possible through this technique

This response node can also be used for the filtering of high. frequency, high-energy noise pulses. Figures 12 and 13 show typical noise-pulse rejection for external capacitors of various sizes.

These two operations on the response node can be combined or used individually for many combinations of interfacing appli. cations. The MC1489 circuits are particularly useful for interfacing between MOS circuits and MOTLMMTL logic systems. In this application, the input threshold voitages are adjusted (with the appropriate supply and resistor values) to fall in the center of the MOS voltage togic levels. (See Figure 14)

The response node may also be used as the receiver input as long as the designer realizes that he may not drive this node with a low impedance source to a voltage greater than one diode above ground or less than one diode below ground. This feature is demonstrated in Figure 15 where two receivers are slaved to the same line that must still meet the RS.232C impedance requirement

FIGURE 13 - TURN.ON THRESHOLO versus CAPACITANCE FROM RESPONSE CONTROL PIN TO GND


FIGURE 14 - TYPICAL TRANSLATOR APPLICATION MOS TO DTL ORTTL


MOTOROLA Semiconductor Products Inc.

FIGURE 15 - TYPICAL PARALLELING OF TWO MC1489,A RECEIVERS TO MEET RS 232 C


THERMAL INFORMATION

The maximum power consumption an integrated circuit can tolerate at a given operating ambient temperature, can be found from the equation

$$
P_{D}\left(T_{A}\right)=\frac{T_{J(m a x)}-T_{A}}{R_{\theta J A}\left(T_{Y p)}\right.}
$$

Where: $\operatorname{PD}\left(T_{A}\right)=$ Power Dissipation allowable at a given operating ambient temperature. This must be greater than
the sum of the products of the supply voltages and supply currents at the worst case operating condition
$T_{J(\text { max })}=$ Maximuin Operating Junction Temperature as listed in the Maximum Ratings Section
$T_{A}=$ Maximum Desired Operating Ambient Temperature
$R_{\theta\lrcorner A}($ Typ $)=$ Typical Thermal! Resistance Junction to Ambient

OUTLINE DIMENSIONS


NOTES: 1. LEADS WITHIN 0.13 mm (0.005) RADIUS GF TRUE POSITION AT SEATING PLANE AT MAXIMUM MATERIAL CONDITION
2. DIMENSTON "L "TO

CENTER OF LEA
WHEN FORME
PARALLEL.
3. DIMENSION "B" DOES NOT INCLUDE MOLD FLASH 4. ROUNDED CORNERS OPTIONAL.


P SUFFIX


[^4]MOTOROLA Semiconductor Products Inc.

I/O Address Decode Chip (Ul9)

| Partno | $8075173 ;$ |
| :--- | :--- |
| Name | iflrfi ; |
| Date | $06 / 05 / 87 ;$ |
| Rev | $01 ;$ |
| Designer |  |
| Company | Tandy ; |
| Assembly |  |
| Location | Ul9; |


/** Declarations and Intermediate Variable Definitions **/
FIELD PORT $=$ [SA9..3] ;


## TAELE OF CONTENTS

1. Functiomel Deseriptimas
2. Memwry comfinuretiom
Z. DrA Gontrol Eigmed Eguztimm
3. E1世世 एi
4. Fim Comfigumation
$E$ Fin Number Assigmment
5. Timimg Specifioxtimm
E. Timimg एiegrem
6. Efecticad Eweificetiom

Tandy lootx DRAM/DMA Comtrel re comsists of the following fumetiman whack:

- FOM DRAM Decone tatwh and Gontrol sionelf
- Fage Figisters
-- Memory mudress MuItiplexer


## FUM/DFAM Decode Latch and Control signal



 - Aes topether with MCo - Moz tetermine whith segment bame or memwry is being selected pewed on one of six pessible menwry configurations. (see memony mar figure 1. ) The memory


Actitional suphort for memory refrest ig else provided in tmis
 cerse the circuitry to igmore fre currert adgress inouts and
 MENCYC End FRCLE =igmals are Lsed for controilimptraytart of a


 active. The ROH address rampes from otoooot to omFFFFH for the 1. ow eddress, EEOOOOH to EFFFFFH and FEOOOOH to FFFFFFH for High
 aduress remges is detected ame REGRESHA is inwtive.

The two Dutputs LMEGCEt and MreEMt are intended to be used as memory buffer enable signed. AEGCed is active whenever amy memory eccess is mede to an adoress twelow olo000n on when REFFESHt is active. MDEEN: is memory otta bus buffer and becomes


The FOM/DFAM Decoue' a internel Ietctis comtroilen by two input sigmals - HLDA and ALE. Dumimg a CFU Memmy Oycle. ALE will Enatie the FAM Decore leteh and alow the input form ouenouer to be transferred to the outmut pins bhen ALE ges inettive, the "ecomer outputs is latrow for the remainder of the cycle Asserting HDDA will enchle the decoder outputs to the output pins arod force FOMCSt inactive. This wiock hes whe wutput signal that.
 extermad. circuitry as an inedicetimm that a fembitmemory tramsfer is taking plece.

## Fage Fiegister

At the time the Excga-s - DMA Controller takes iontrol at the address bus, the first operation cones in two bytes. The first byte is a lower adruess bue (sAO through sat) thet is put directiv on the s address bus by DMA controller. The Eecoma byte is a upper aduress (SAE through SAtc) that is wn its deta ulfputs, to be latated in the 74 alsoge imdermally by Address Strobe (Ag) signal from DMA Gontrollev.

Two 4 by \& registers are bsed to perform Fage Fegister function. Duning DMA Eus Cycle, the read function is combridled by the DMA
 with HLDAs emables the Page Fegister to be output as the upper

 Gata bits - XDO to XD7 into Fage Fegister.

## Address Multiplexer

The Memory Adraess Multiplexer is used to provide the Fow Acdress or Colum Adorese and retresh coumter that is required by bynamio Rams. Additiomaly, it provimes the drive amutuffering cepabllity for memory adraess bus mag to met May is gemerated
 adoresses for the memory are maltiplexed as stioun below.

Equation For Moitiplexed Memory Ambres ines

| Fow Address |  |
| :---: | :---: |
| (fingt) | Golum Andress |
| (Ewond) |  |


| MAO |  | S91 | 5 a |
| :---: | :---: | :---: | :---: |
| MAI | - - - - - - - - | 9A2 | क1\% |
| MAE | -------- | SA3 | SA11 |
| Mas | - -7.......-- | 5 A 4 | $9 \mathrm{Al2}$ |
| MA4 | -------- | SAS | EAls |
| MAE | ………- | SAE | 5Al4 |
| MAE | ---- | ¢A7 | EAIE |
| Mat | --->------ | SAE/SAO | EATE |
| MAB | ---*---- | EA17 | EA1S |

## 2. MEMOFY CONFIGURATION

OFTION MCZ MCI MCO EANEO EANEI EGNE CONTROL ADORESS FANGE

| 1 | $\bigcirc$ | 0 | 0 |  | 128\% | 1EK | Fes 1 | (000000-07FFFF) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | Fasこ | (ODOOOOMOEFFFF) |
| 2 | 0 | 0 | 1 | 512 C |  |  | Ras0 | (000000-07FFFF) |
| 3 | 0 | 1 | 1 | 512 |  |  | Ras0 | (OOOOOO-O7FFFF) |
|  |  |  |  |  | 12 C |  | Ras 1 | (OBOOOO-OGFFFF) |
| 4 | 0 | 1 | 0 | 512 C |  |  | Ras0 | (000000-07FFFF) |
|  |  |  |  |  | 1 ¢ek |  | Fes 1 | (OEFFFF-OEFFFF) |
|  |  |  |  |  |  | 19 E | FaEz | (10000\%-17FFFF) |
| 5 | 1 | 1 | 1 | 512 C |  |  | Reso | (000000-07FFFFF) |
|  |  |  |  |  | 12 Ex |  | Res? | (080000-O日FFFF) |
|  |  |  |  |  |  | $51 \%$ | Fesz | (100000-17FFFF) |
| $\varepsilon$ | 1 | 1 | 0 | 512 c |  |  | Faso | (000000-07FFFF) |
|  |  |  |  |  | $1 \times 8 \mathrm{C}$ |  | Res 1 | (0¢0000-OEFFFF) |
|  |  |  |  |  |  | 518 | Fesz | (100000-17FFFF) |
|  |  |  |  |  |  | $51 \%$ | FE 53 | (190000-1FFFFFF) |


| 7 | 1 | 0 | 1 | NOT DEFINED |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 8 | 1 | 0 | 0 | NOT DEFINED |

FIGURE i. MEMOFY COHFIGURATION.

## 3. DMA Control Loqic Equations



```
    +/1a2% &/1a22 %/1a<l &/La2O &/1alg & mсl
    +refresh;
```



```
    &/mcl & /moz
```



```
    +refrest!;
```



```
    & /mcl & /moz
    +/1azg & /1a22 &/1a21 & la<0 &/1al9 g/lale 2/1al7 8/mco & mel
        & /racz
        +/1az3 & /1aza & /laz| & lazo & /lalg & mcl & mcz
        +Mefrest!
```



```
    +Mefrest:
```



```
        & /me0 & /refresh
```





```
        & /refres5
```



```
        & /moco & /refresh
```








5. PIN CONFIGURATION

FIGURE 3. PIN CONFIGURATION

| FIN\# | PIN NAME | TYFE | DESCRIFTION |
| :---: | :---: | :---: | :---: |
| 9 | GAO | INFUT | CFU ADDFESE LINE |
| $\varepsilon$ | EA1 | TVFUT | CPU ADDRESE LINE |
| 7 | SAZ | Infut | CFU ADDRESS LINE |
| 6 | EAS | Inmeut | CFy Adoress linde |
| 5 | SA4 | INFUT | CFU ADDRESS LINE |
| 4 | SAS | InFUT | CFU ADORESE LINE |
| 3 | SaE | Infut | CPU ADDRESS LINE |
| 2 | SA7 | TNFUT | CPU ADDRESS LINE |
| 1 | EAE | InFUT/GUTFUT | CfU AdDRESE LINE |
| 58 | 5 AS | infut outaut | Cfu ampress line |
| 67 | SAlO | InPUT/GUTPUT | CPU ADORESS LINE |
| $6 E$ | SAll | TNFUT/GUTFUT | Ofu adores Line |
| 65 | SAl2 | INFUT/OUTFUT | Cfu addrese line |
| 64 | SA1S | InFUT/GUTFUT | Cfu adoress line |
| 63 | SAT4 | IHFUT/DUTFUT | CFU ADDRESS LINE |
| 62 | SA15 | Infut/DutFut | CFU ADORES LINE |
| 60 | sale | INPUT/DUTFUT | CFU ADDFESS LINE |
| 59 | A 17 | Input / outayt | CPU ADDRESS LINE |
| 59 | A18 | INPUT/DUTEUT | CPU ADDRESS LTME |
| 57 | A19 | INFUT/OUTFUT | Ofy amorese line |
| 56 | A20 | InFUT/OUTEUT | CFU ADDRESS LINE |
| 55 | AZ 1 | InFUT/OUTEUT | CFU ADORESS LINE |
| 54 | A22 | InPut/DUTPUT | CPU ADDRESS LINE |
| 55 | ARS | theut/DUTFUT | Cfu admaes line |
| 45 | ALEE | INPUT | ADDRESE LATCH ENAELE Active HIGH -. to latch generated RAS/CAS/LMEG |
| 43 | FEFRESH: | Inmut | REFEESH - Active LOW to initiate a refrest cycle for gymamic FAMs. |
| 14 | DACK2* | Infut | 2237 Channel 2 DMA ACKMOULEEGE |
| 16 | DACK3* | INPUT | 227 Chamel $\because$ DMA ACKNOWLEDGE |
| 13 | HLDA | InFUT | HOLE ACKNOWLEDGE |
|  |  |  | Active HIGH - it indicates thet the DMA Has the system bus. |
| 4.4 | FGREGURE: | INFUT | FAGE REGTSTER WRTTEactive Low to perform I/Q WRITE cycle to the DMA Page Register. |
| 46 | MEMCYE | IAFUT | memory cycle - Active HIGH to initiate FAG/CAS/MAO-MAE Dutputs |
| 19 | AS | TNFUT | ADDRES STROEE - Active HeH it latches the adyres lines GAB-SATS Do-07 into external latet for Dría cycle |


| FIN\# | PIN NAME | TYFE | DESCRIFTIUN |
| :---: | :---: | :---: | :---: |
| 10 | XEHE: | Infut | EyTE HIGH ENAELE <br> To enable the high menory data bytes De-DIS |
| 47 | PRCLE | InFut | 1 IHME CLOCK. |
| 11 | MCO | TAFUT | MEMORY CONFIGURGT ION EELECT LSE. |
| 12 | MCl | INFUT | MEHOEY CONF TGURAT ION EELECT. |
| 42 | MCL | TMFUT | MENORY CONFIG. SEEET MSE. |
| 20 | MaO | OUTPET | MULTIFLEXED MEMOEY ADDFESE - addressing reguired for DFAM memory. |
| 22 | HA1 | Duteut | MULTPLEXED MEVOFY ADDFESE - addressing reguired for DFAM memory. |
| 24 | MAL | Qutpet | MULTAFLEXED MEMORY ADOFESS - addressing reguired for DRAM menory. |
| 25 | MAS | OUTPUT | MUTIFLEXED MEVMEY ADDEES - addreseing required for Dfam memory |
| 29 | MAA | OUTEUT | MULTPIEXED MEMORY ADDFESE - adtressing required for DRAM memory. |
| 31 | MAS | gutpet | MULTIFLEXED MEMORY ADDFESS - adressing required for DRAM menory. |
| 33 | MAE | Uutput | MULTIFLEXED MEMORY ADDRESS - addreswing reguired for DRAM menury |
| 35 | MA7 | OUTPUT | MULTIFLEXED MEMORY ADDFES - adtressing reguired for Dram mentry. |
| 37 | MAS | OUTPUT | MULTAFLEXED MEMORY ADDFESE -- addressing required for DRAM memory. |
| 17 | CASH* | OUTEUT | COLOMN ADDRES STROEE HIGH - Active LTW, it's used to select the high cata byte MDe MDis for a DRAM access cycle. |


| FIN\# | FIN NAME | TYFE | DESCRIFTION |
| :---: | :---: | :---: | :---: |
| 15 | CASL* | DUTFUT | COLUH ADDRESS STROEE <br> Low - Active Low, it's used to select low deta byte MDo-MDT for a DFim acress cycle |
| 5 | Ragow | OUTPUT | ROW ADDRESS STROEE O Active Low, it's used for selecting DRAm Eanko. |
| 39 | FASI* | OUTFUT | FOW ADORESE STROEE 1 Active Low, it's used for selecting Dram Eank! |
| 40 | FASEs | DUTFUT | ROW ADDRES STROEE $2-$ Active Low, it's used for selerting ORAM Eank. |
| 41 | Ras? | Qutput | ROW ADDRESS STROEE 3 Active Low, it's used for selecting DRAM Eank: |
| 51 | LIAEGCE* | Dutput | LOWER MEGAEYTE CHIP SELECT - Active Low, it indicates that bellow 1 megatyte |
| 50 | MDEEN* | DUTPUT | memory data bus enable <br> Active Lob it is used to. enctue the data tus buffer. |
| 49 | AFIE* | QUTPET | AFIE ACtive LOb -- it stgnals the control loge © ©FU GNTL that the memory cycle $1 s$ a 16 bit 1 wat Etate cycie. |
| 46 | FOMCS* | OUTFUT | ROM CHEF EELECT <br> Active Low |
| 21 | x00 | InFut | DATA EUS O for the aeripheral bus. |
| 23 | XD1 | INPUT | DATA EUG 1 fur tre peripheral bus. |
| 25 | xD2 | Infet | data Eus 2 for the peripheral bus. |
| 28 | $\times 0 \mathrm{O}$ | INFUT | DATA EUS 3 for the peripherel bus. |
| 30 | XD 4. | TNFUT | Data bue 4 for the peripherel bus. |
| 32 | XD5 | INFUT | Data eus 5 for the peripheral bus. |
| 34 | XDE | INFUT | Data Eus e for the perioteral bus. |
| 36 | $\times 07$ | INFUT | DATA EUS 7 For the peripheral tue. |
| $\begin{aligned} & 16,52 \\ & 27,61 \end{aligned}$ | vec GND |  | +EV FOUER SUPFLY GROUND |

## 7．TIMING SFECIFICATIDNS

| SYM | FARAMETER： | mIN | MAX | UHITS | REMAFICS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $T 1$ | PRCtE Perimd | E， | 50 | Tぁぁ |  |
| Tim | FRCiE Low Tame | 25 | $12=$ | П玉se |  |
| Tb |  | $\square 5$ | 12 E | Mcem |  |
| 72 | Alm Active Delay | $\sigma$ | 4 E | TEEC |  |
| T\％ | AE Jmactive Delav | 5 | 6 | T5sm |  |
| T4 | Ablames Deley | ！ | 5 | 或女5 |  |
| TE | Laterat Amincse mom mb Active | $\cdots$ | $2 \%$ | $m \mathrm{ma}$ |  |
| TE | vemcye Active Delev Fown $\downarrow$ FFCLE | 5 | － | n＝5 |  |
| T\％ | MEMCY Inertive Delay From $\downarrow$ FRCl | E | 5 | ワ®er |  |
| $T E$ |  $\downarrow$ FCL | 5 | 45 | T5er | at Topt |
| T9 | FaSx＋Inertve Delay From $\uparrow$ PRCLK | 5 | \％ | T： |  |
| T10 | FA\％at Fremterce Time | 110 |  | n¢sc |  |
| 711 | Fexat Hold Thme | \％ |  | П巨ec |  |
| T2 |  $\uparrow$ FRCLE | 5 | ब | ワ\％\％ |  |
| T13 |  From $\downarrow$ MEMCYC | 5 | 30 | П¢E\％ |  |
| T14 | Fow futres5 Embum Tuma | 4 |  |  |  |
| T 9 |  From Sm te mam | \％ | 5 | Heme | ＂t 200 t |
| T 19 | Mernery figtress Deley Fob ALE | $\cdots$ | 50 | Texem |  |
| 177 | Memorv AdMrese toble Deday From 个 FCOLK |  | 50 | T＝5e | at 玉opf |
| T18 | Sow actress Hold Trme | 9 |  | HEEe |  |
| 79 | Columm Amthess 5etum Time | 5 |  | $\mathrm{n}=\mathrm{E}$ |  |
| 720 | Column Ambress Hole Thme | 0 |  | ワ¢EC |  |
| T21 | colum Abdrese Hole Thme Referenced TO FASX | 10 |  | п56\％ |  |
| T22 | MLE $\uparrow+$ NDEEM $\uparrow \downarrow$ ¢ $/ \mathrm{T}$ |  | 5 | me＝e |  |
| 12 O | ALE $\uparrow$ U0 MEGC\％$\downarrow \uparrow$ A／T |  | 5 | Hec\％ |  |
| $T 24$ | ALE $\uparrow$ WO FOMCSt $\downarrow \uparrow$ A $/$ T |  | 50 | TEE\％ | $\begin{aligned} & \text { GyHBDA } \\ & \text { HaH } \end{aligned}$ |


| SYM | PARAMETER | MIN | MAX | UNITS | FEMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| T25 |  |  | 50 | ก¢5 |  |
| T\％ 6 | CFUHLDA¢ $\downarrow$ to MOEEM $\uparrow 1$ |  | 50 | msec |  |
| TV7 | CFUHLDAT $\downarrow$ ¢ FTMCS＊$\downarrow \uparrow$ A／T |  | 60 | ワ玉心e |  |
| T29 | CFUHDDA $\downarrow$ tw＝AE－5ATE $\downarrow \uparrow$ |  | 50 | T¢EC |  |
| T29 | CFUHLDA¢ to 9Ale，At 7 A2e $\downarrow \downarrow$ |  | 50 | nees |  |
| TO |  A17－A23 |  | 50 | nsem |  |
| T： 7 |  |  |  |  |  |
| $\begin{gathered} T 2 \\ T E \end{gathered}$ |  1 MEGCO |  | 0 | M6em |  |
| Ted |  |  | 50 | ワ¢es | at egomp |
| 155 | xD0－xD7 Setum to as $\downarrow$ | 109 |  | ワ¢e\％ |  |
| TE |  | 100 |  | ก玉e \％ |  |
| T\％7 | SAO－Sm3 Setum to Preghrs | 100 |  | 可㤩 |  |
| T\％ | REFRESHT $\downarrow \uparrow$ tw AFIET |  | 50 | nsec |  |
| 759 | GEFRESH＊$\downarrow \hat{\uparrow}$ to MOEENt |  | 50 | п¢es |  |

```
E. Timing Diagram.
```



## 9. ELECTFICAL SFECIFICATIONS

AESOLUTE MAX FATINGS (NON-DFEFATING, VSS=O.OV)

|  | MIN |  | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: |
| GTOFAGE TEIFEFATURE | $\cdots 5$ |  | $+150$ | Degrees C. |
| VOUTAGE DN ANY FTN W.F.T GFOUND | $-9.5$ |  | 7.0 | volts |
| OPEFATING ELECTFICAL SFECIFICATIONS: |  |  |  |  |
| OFEFATING AMEIENT | MIN | TYF | MAX | UNITS |
| ATF TEMF. FANGE | 0 | 25 | 70 | Degrees 6 |
| FDWER EUFFLIES |  |  |  |  |
| VCO | 4.5 | E. 0 | 5.5 | Velts |
| $v 5 \%$ | 0 | o | 0 | Velts |
|  | MIN | TYF | MAX | UNITS |
| LEAKAGE CURFENT |  |  |  |  |
| Vin = 0.0v |  | 20 |  | Microwmps |
| vin $=5.0 \vee$ | --9 |  |  | Miterommps |

## INPUT VDLTAGES

```
LOGTC "O" (Vil) O.E volt=
LOGIC "j" (Vit") z.0 volts
```


## OUTFUT VOLTAGES CURFENT LOADING

```
LOGTC "O" (voI)
    0.4 volts
MALO]-MA[.%] 0 Emacmin)
EXAE-SXATE,A17-A2S (6 Ama(mim)
FA&%* (% Ama(mim)
CAEXN & E ma(min)
OtHEr= must be awle
to SINK minimedm o zma
LOGIC "ן" (VOW) 2.& volts
MA[O]-MA[S],
EXAB-EXATE,A17-A2E 0 Ema
CASO$,FASX$ & 4ma
CASX半 - E ma
Otters must be mble
ta DFRIVE mimimum o Zme
```


## INFUT CAFACITANCE

A11 inputs 0.0 \& Vin 5.0
10
picofarats

OUTFUT CAFACITANCE

| MALOT-MALE] | \%0 | picofarads |
| :---: | :---: | :---: |
| CAS | 165 | picwfarads |
| FAE | 100 | Ficofareds |
| SAE-5AlE | 150 | picataneds |
| All ether outputs | 50 | picofarabs |

Floppy Disk Support Chip Specification

## Floppy Disk Support Chip Specification Contents

Section Page
General Description ..... 1
Pin Description ..... 2
Block Diagram ..... 3
Environmental Specifications ..... 5
DC Electrical Specifications ..... 5
AC Characteristics ..... 6
Timing Diagrams ..... 9

```
Floppy Disk Support Logic
Tandy Part # 8xxxxxx
Jan 29, 1987
Preliminary
```


### 1.0 GENERAL DESECRIPTION

1.1 The Tandy Part \# 8xxxxxx - Floppy Disk Support logic:

- Generates the clock to the 765 Floppy Disk Controller.
- Generates the write clock to the Floppy Disk Controller.
- Generaters step pulses, track 0 indicator, DMA request, and FDC interrupt signals.
- Generates the Read Data and Read Data Window signals.
- Generates the Write Data to the Floppy Disk.

| 1-- | CLK16M | +5V | --24 |
| :---: | :---: | :---: | :---: |
| 2-- | WCK | SWITCH | --23 |
| 3- | FDCCLK | INT+ | --22 |
| 4-- | RDDATA* | DMA/INTE | --21 |
| 5-- | RDD | DRQ | --20 |
| 6-- | RDW | FDCINT | --19 |
| 7-- | FRES/S | FDCDMRQ* | --18 |
| 8-- | RW* / SEEK | PS0 | --17 |
| 9-- | TRK0* | PSI | --16 |
| 10-- | F/TRK0 | WRD | --15 |
| 11-- | STEP* | WRE | --14 |
| 12-- | GND | WRDATA* | --13 |

FIGURE 1. Pin Assignment

### 1.2 DESCRIPTION OF PINS:

| PIN \# | PIN NAME | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| 1 | CLK16M | INPUT | Frequency $=16.0000$ Tolerance $=100 \mathrm{pmm}$ |
| 2 | WCK | output | If $\operatorname{SWITCH}=0$, period $=2 \mathrm{us}, 250 \mathrm{~ns}$ pulse <br> If $\operatorname{SWITCH}=1$, period $=1$ us, 250 ns pulse |
| 3 | FDCCLK | OUTPUT | If $\operatorname{SWITCH}=0$, then CLKI6M/4 <br> If SWITCH $=1$, then CLKl6M/2 |
| 4 | RDDATA | InPut | Serial data from FDD |
| 5 | RDD | OUTPUT | Serial data from FDC |
| 6 | RDW | OUTPUT | Read Data Window |
| 7 | FRES/S | INPUT | Step pulses to move head to another cylinder |
| 8 | RW*/SEEK | INPUT | Specifies seek mode when high |
| 9 | TRK0* | INPUT | From FDD, indicating head is on track 0 |
| 10 | F/TRK0 | OUTPUT | To FDC, indicating head is on track 0 |
| 11 | STEP* | OUTPUT | Moves head of FDD |
| 12 | GND |  | Ground |
| 13 | WRDATA* | OUTPUT | Serial Data to FDD |
| 14 | WRE | INPUT | Write Enable |
| 15 | WRD | INPUT | Serial Data from FDC |
| 16 | PSI | InPUT | Write precompensation status |
| 17 | PS0 | INPUT | Write precompensation status |
| 18 | FDCDMRQ* | OUTPUT | DRQ delayed by 1.0 usec. |
| 19 | FDCINT | output | Interrupt request |
| 20 | DRQ | INPUT | FDC DMA Request |
| 21 | DMA/INTE | INPUT | DMA request and FDC interrupt enable |
| 22 | INT+ | INPUT | Interrupt request generated by FDC |
| 23 | SWITCH | INPUT | $\begin{aligned} & 0=\text { low density drive } \\ & 1=\text { high density drive } \end{aligned}$ |
| 24 | +5V |  | +5 Volts |




### 4.0 AC CHARACTERISTICS

4.1 FDCCLK Timing

```
Parameter
---------
\({ }_{t_{R}}^{t_{R}}, t_{F}\)
```

4.2 WCK Timing

4.3 WRDATA* Timing

| $\mathrm{WCK}_{H}-\mathrm{WE}_{\mathrm{H}}$ | 20 |  | nSec |
| :---: | :---: | :---: | :---: |
| WCK ${ }_{\text {H }}-\mathrm{WE}_{5}$ | 20 |  | nSec |
| PSD ${ }^{\text {L }}$ L | 20 | 100 | nSec |
| WDD | 20 | 100 | nSec |
| $\mathrm{WDA}_{\text {W }}$ |  | $\mathrm{WCK}_{\mathrm{H}}{ }^{-50}$ | nSec |
| WRD ${ }_{\text {W }}$ | 115 | $125 \quad 135$ | nSec |
| WDD ${ }_{H}^{W}-W R D_{L}$ early | 150 | 250 | nSec |
| WDD ${ }_{H}^{H}-W R D_{\text {L }}$ nominal | 275 | 375 | nsec |
| $\mathrm{WDD}_{\mathrm{H}}^{\mathrm{H}}-W R D_{\mathrm{L}}$ late | 400 | 500 | nSec |

4.4 DMA/INTERRUPT Timing

| $\mathrm{I}_{\mathrm{H}}-\mathrm{FI} \mathrm{I}_{\mathrm{H}}$ |  | 30 | nSec |
| :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{H}}-\mathrm{FI}$ |  | 30 | nSec |
| $\mathrm{DL}^{\text {L }}$ - $\mathrm{I}_{1}$ |  | 30 | nSec |
| $\mathrm{WCR}_{H}-\mathrm{DRQ} \mathrm{Q}_{\mathrm{H}}$ | 0 |  | nSec |
| $\mathrm{WCK}_{\mathrm{L}}-\mathrm{DRQ} \mathrm{H}^{\text {r }}$ |  |  | nSec |
| $\mathrm{DRQ}_{\mathrm{H}}^{\mathrm{L}}-\mathrm{FDRQ} \mathrm{Q}_{\mathrm{H}}$ | 750 | 1050 | nSec |
| $\mathrm{DRQ}_{\mathrm{L}}-\mathrm{FDRQ} \mathrm{L}_{\mathrm{L}}$ |  | 30 | nSec |
| $\mathrm{DI}_{\mathrm{T}}{ }^{-} \mathrm{FDRQ}_{\mathrm{L}}$ |  | 30 | nSec |
| $\mathrm{FCR}_{\mathrm{H}}-\mathrm{FDRQ}_{\mathrm{H}}$ |  | 30 | nSec |



## FDSL AC TIMING

FIG. 1 FDCCLK


FIG. 2 WCK


FIG. 3 WRITE DATA TIMING.


FIG. 4 DMA/INTERRUPT TIMING.


FIG. 5 CONTROL LOGIC TIMING.


FIG. 6 DATA SEPARATOR TIMING.

## PRINTER INTERFACE SPECIFICATION CONTENTS

GENERAL DESCRIPTION ..... 1
SPECIFICATIONS ..... 3

## PRINTER INTERFACE SPECIFICATION TANDY PART \# BD75068 APRIL 30, 1986

## 1. GENERAL DESCRIPTION

1.1 The Tandy part\# 8075068 - Printer Interface I.C provides the interface between the system $I / 0$ bus and the printer. Figure 1 shows Block diagram of Printer Intertace chlp. Figure 2 shows pin configurations of Printer Intertace


Figure 1.


Figure 2.
1 OF 5

### 1.2 DESCRIPTION OF EACH PINS:

| Pin\# | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
| 1 | INT | qutput | Interrupt signal |
| 2 | SWITCH | input | Switch for totem pale output or apen callector autput an INITB, AF, STROBEB. |
| 3 | AD1 | input | CPU address line |
| 4 | ADD | input | CPL address line |
| 5 | OUTO | input/output | Data I/O !ine |
| 6 | OUT 1 | input/autput | Data I/O line |
| 7 | OUT2 | input/autput | Data l/O line |
| 8 | OUT3 | input/autput | Data $1 / 0$ line |
| 9 | OUT7 | input/autput | Data $1 / 0$ line |
| 10 | OUT6 | input/autput | Data 1/0 line |
| 11 | OUTS | input/autput | Data I/O line |
| 12 | OUT4 | input/autput | Data I/O line |
| 13 | STROBEB | -utput | Printer Strabe sigmal |
| 14 | AFB | autput | Printer Autofeed signal |
| 15 | INITB | -utput | Printer Initialize signal |
| 16 | SEL | ロutput | Printer Select signal |
| 17 | FAULTB | input | Printer Fault signal |
| 18 | PE | input | Printer Paper empty 5 ignal |
| 19 | BUSY | input | Printer Busy signal |
| 20 | USS | ground | Ground |
| 21 | ACKB | input | Printer Acknowledge signal |
| 22 | FDCTC | input | FDC Terminal Count |
| 23 | FDCDACKB | input | FDC-DMA Acknowledge sismal |
| 24 | DMATC | input | DMA Terminal Count |
| 25 | TC | qutput | FDC Terminal Count signal |
| 26 | SLCTINB | input | Printer Select input |
| 27 | NC | -- | Not used |
| 28 | RSTB | input | System Reset |
| 29 | IORB | input | CPU 1/O Read strobe |
| 30 | IOWB | input | CPU I/O Write strobe |
| 31 | CSB | input | Chip select signal |
| 32 | D6 | Input/output | CPU Data I/O |
| 33 | 04 | Input/autput | CPU Data 1/0 |
| 34 | D2 | Input/output | CPU Data 1/0 |
| 35 | DO | Input/output | CPU Data 1/0 |
| 36 | D1 | Input/autput | CPU Data 1/0 |
| 37 | D3 | Input/output | CPU Data 1/0 |
| 38 | D5 | Input/autput | CPU Data I/O |
| 39 | 07 | Input/output | CPU Data 1/0 |
| 40 | UDD | power | +5 Valt Power Supply |

## 2. ENVIRONMENTAL SPECIFICATIONS

2.1 Storage Temperature -65 C to 150 C
2.2 Operating Temperature $\quad$ C ta 70 C
3. ELECTRICAL SPECIFICATIONS
3.1 Absolute Maximum Rating

| Parameter | Min. | TYP. | Max. | Units | Cand. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| tage, any pin | -1.0 |  | 7.0 | Volts | W.R.T graund |
| er Dissipation |  |  | 0.5 | Watts |  |


| Symb. | Parameter | Min. | Typ. | Max. | Units | Cund. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOD | Supply Voltage | 4.5 | 5.0 | 5.5 | Volts |  |
| Inc (a) | Quiescent current |  |  | 50 | UA |  |
| Iec(a) | Operating Current |  |  | 40 | $m A$ |  |
| Vi.l | Input Low Voltage |  |  | 0.8 | Volts | TTL inouts |
| Vih | Input High Voltage | 2.0 |  |  | Valts | TTL inputs |
| Iin | Input Leakage | $-10$ |  | 10 | $u A$ |  |
| Cin | Input Capacitance |  |  | 7 | pF |  |
| Val | Output Low Valtage |  |  | 0.4 | Volts | D4 mA |
| Voh | Output High Valtage | 2.4 |  |  | Volts | $\square-2 \mathrm{~mA}$ |
| I az | High Impedance Leak | $-10$ |  | 10 | $\cup A$ |  |

3.3 A.C Electrical Characteristics
3.3.1 Write Cycle

Symb. Parameter
---- --------
Tasu Address Setup
Twpw Write Pulse Width
Tdsu Data Setup
Tdh Data Hold

Min. Typ. Max. Units Cond. ---- ---- ---- ----- -----------------
15 n5
69
29
$6 \quad n 5$


Symb. Parameter
Tespw Chip Select Width
Trpw Read Pulse Width
Tda Data Access
Tdz Bus Hald/release
Min. Typ. Max. Units Cand.

5 OF 5

## KEYBOARD INTERFACE SPECIFICATION CONTENTS

GENERAL DESCRIPTION ..... 1
SPECIFICATIONS .....  3

```
KEYBOARD INTERFACE SPECIFICATION
    TANDY PART # 8075069
    MAY [5, 1986
```


## 1. GENERAL DESCRIPTION

1.1 The Tandy part\# B075069 - Keyboard Interface I.C provides twa functions:
a. Interface between the system $1 / 0$ bus and keybaard.
b. FDC suppart lagie that generates DRIVE SELECT SIGNAL, MOTOR ON SIGNAL, FDC TERMINAL COLNT, FDC RESET and DMA/I.
Figure 1. shows block diagram of Keyboard Interface chip Figure 2. shows pin configuration of Keyboard Interface chip.


Figure 1.

| 1-KBOCLK | VOD-40 |
| :---: | :---: |
| 2-KBDDATA | MULTICLK- -39 |
| 3--K8DBUSY日 | MLLTIDAT--38 |
| $4-K B D I N T$ | FAST- 37 |
| 5-1RS120 | TCH2G-36 |
| 6-fRS121 | PPITIM-35 |
| 7-j00 | DSD-34 |
| $8-\mathrm{D} 1$ | D51--33 |
| 9--D2 | FDCRST- -32 |
| 10--03 | DMA/I--31 |
| 11-04 | MTRON-30 |
| 12--05 | FOCTC-29 |
| 13-06 | SNDCNTL $2-28$ |
| 14-- 07 | SNDCNTLD- -27 |
| 15-1P10C5B | SNDCNTL $1-26$ |
| 16--BAOL | TMROUT $2--25$ |
| 17- BAOI | PC4--24 |
| 18-HIORB | SYSRSTB- 23 |
| 19-1810WB | KBDRSTE-22 |
| 20-vivs | DORCLK-21 |

Figure 2.

### 1.2 DESCRIPTION OF EACH PINS:

| Pin\# | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
| 1 | KBOCLK | input | Keyboard clock |
| 2 | KBDDATA | input | Keyboard data |
| 3 | KbDBuSyb | वutput | Keyboard busy signal |
| 4 | KBDINT | qutput | Keyboard interrupt signal |
| 5 | RSIZ0 | input | Manachrame/calar monitar mode |
| 6 | RSIZ1 | imput | Reserved |
| 7 | DO | input/autput | Data 1/0 line |
| 8 | D1 | input/ロutput | Data 1/O Iine |
| 9 | D2 | input/autput | Data 1/0 line |
| 10 | D3 | input/rutput | Data l/O line |
| 11 | D4 | input/autput | Data 1/0 \|ine |
| 12 | D5 | input/autput | Data 1/0 line |
| 13 | D6 | input/autput | Data 1/0 line |
| 14 | 07 | input/autput | Data 1/0 line |
| 15 | PIOCSB | input | Chip select strabe |
| 16 | BADO | input | CPU address line |
| 17 | BAD1 | input | CPU address line |
| 18 | BIORB | input | CPU I/O read strabe |
| 19 | BIOWB | input | CPU I/O write strobe |
| 20 | US5 | graund | Ground |
| 21 | DORCLK | input | Decode latch clock |
| 22 | KBDRSTB | -utput | Keyboard reset signal |
| 23 | SYSRSTB | input | System reset signal |
| 24 | PC4 | input | Videa memary 5 ize made |
| 25 | TMROUT2 | input | Timer counter from 8253 out2 |
| 26 | 5NDCNTL1 | -utput | Sound contral 1 |
| 27 | SNDCNTLO | 唯put | Sound contral |
| 28 | SNDCNTLZ | qutput | Sound contral 2 |
| 29 | FDCTC | output | FDC terminal count |
| 30 | MTRON | वutput | Motor ON signal to disk drive |
| 31 | DMA/I | वutput | DMA Request \& FDC Interrupt enable |
| 32 | FDCRSTB | -utput | FDC reset signal |
| 33 | DS1 | वutput | Drive select 1 signal |
| 34 | DSO | autput | Drive select 0 signal |
| 35 | PPITIM | -utput | Timer Vided signal |
| 36 | TCH2G | qutput | Timer channel 2 gate |
| 37 | FAST | input | 4.77Mhz or 7.16 Mhz mode select |
| 38 | MULTIDAT | output | Multi-data |
| 39 | MULTICLK | -utput | Multi-clark |
| 40 | VDD | power | +5 Volt Pawar Supply |

2. ENVIRONMENTAL SPECIFICATIONS
2.1 Starage Temperature -65 C ta 150 C
2.2 Operating Temperature $\quad \mathrm{C}$ ta 70 C
3. ELECTRICAL SPECIFICATIONS
3.1 Absalute Maximum Rating

3.2 D.C. Electrical Characteristics

| Symb. | Parameter | Min. | TYP. | Max. | Units | cond. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VDD | Supply Valtage | 4.5 | 5.10 | 5.5 | Volts |  |
| Icc(a) | Quiescent current |  |  | 50 | UA |  |
| Ice(a) | Operating Current |  |  | 40 | $m A$ |  |
| vil | Input Low Voltage |  |  | 0.8 | Volts | TTL inputs |
| Vih | Input High Valtage | 2.0 |  |  | Volts | TTL inputs |
| I in | Input Leakage | -10 |  | 10 | $\cup A$ |  |
| Cin | Input Capacitance |  |  | 7 | pF |  |
| Val | Output Law Valtage |  |  | 0.4 | Volts | 24 mA |
| Vah | Output High Valtage | 2.4 |  |  | Volts | a-2 mA |
| 102 | High Impedance Leak | $-10$ |  | 10 | $U A$ |  |

3.3 A.C Electrical Characteristics
3.3.1 Write Cycle


Symb. Parameter
Tasu Address Setup
Twow Write Pulse Width
Data Setup
Min. Typ. Max. Units Cond.
--- --- --- ---

Tdh Data Hald
69
29
ns
ns
3.3.2 Read Cycle


| Symb. | Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Tespw | Chip Select Width | 69 |  | nS |
| Trpw | Read Pulse Width | 69 |  | nS |
| Tda | Data Access |  | 69 | n5 |
| Tdz | Bus Holdrelease | 6 | 25 | n 5 |

## Contents

Block Diagram ..... 3
Functional Description ..... 4
Clock Generation, Ready, and Reset Control Logic .....  4
Bus Control Logic ..... 6
Data Conversion Logic ..... 7
Wait State Control Logic ..... 8
DMA Arbitration Logic ..... 8
Numerical Co-processor Control Logic ..... 9
A20Gate and CPU Reset Logic ..... 10
Pin Configuration ..... 12
Pin and Signal Descriptions ..... 13
Electrical Specifications ..... 19
Timing Specifications ..... 21
Timing Diagrams ..... 25

## Block Diagram



## Functional Description

The Tandy $1000 T X$ CPU Control IC consists of the following function blocks:

- Clock Generation, Ready and Reset Control Logic
- Bus Control Logic
- Data Conversion Logic
- Wait State Control Logic
- DMA Arbitration Logic
- Numerical Co-processor Control Logic
. - A20Gate and CPU Reset Logic


## Clock Generation, Ready and Reset Control Logic

The clock generation logic includes the clock inputs used to derive all of the system clocks. The 16 MHz clock input is used to generate the CPU clock (PRCLK), and is twice the CPU operation frequency of 8 MHz . The 28.6 MHz clock input is used to generate the 14.31818 MHz clock (OSC) and other clocks required by the system.

Three clocks are generated from the 28.6 MHz clock input. These are OSC, 3.58 MHz , and the 1.19 MHz clock outputs. The 28.6 MHz signal input is divided by 2 to generate the OSC output which is 14.31818 MHz . The 28.6 MHz clock is divided by 8 to generate the 3.58 MHz clock which is used by the sound generator circuit. The 28.6 MHz clock is also divided by 24 to generate the 1.19 MHz clock that is used by the Interval Timer 8254.

All other system clocks are generated from the 16 MHz clock input. PRCLK is used to drive the CPU, the Co-processor, and the DRAM/DMA Control IC. PRCLK is output as 16 MHz in the 8 MHz (FAST) mode and is divided by 2 to 8 MHz in the 4 MHz (SLOW) mode. PRCLK output buffer has sufficient drive capability to meet the 3.8 volt minimum Vin requirement of the $80286 / 80287$ clock inputs.

SCLK and DMACLK are system clocks generated from 16 MHz . SCLK is generated by dividing PRCLK by 2 and DMACLK is generated by dividing PRCLK by 4. Both SCLK and DMACLK are held in a LOW state immediately following a reset and will not start operation until the CPU issues the first bus cycle by asserting S1* LOW. Immediately following Sl* asserted LOW, SCLK and DMACLK will make their first LOW to HIGH transition at the falling edge of PRCLK during the start of TC. This will synchronize SCLK and DMACLK with PRCLK. Refer to timing diagrams for an illustration of the startup of SCLK and DMACLK.

A ready signal (READY*) is generated by the CPU Control IC to allow the CPU to operated with slower devices such as peripherals and slow memory. READY* is synchronized with PRCLK in this control block by the control logic of READY* located in the wait State Control Logic.

Two reset output signals are generated by the CPU Control IC to provide a reset to the main system and a separate reset to the CPU. RESET which is active HIGH is a synchronized reset and is used for reseting the main system. RESCPU is dedicated to the CPU for proper reseting of the 80286. Both RESET and RESCPU are generated when RES* input is asserted LOW to indicate a power-on reset or when RES* is asserted LOW by a reset switch. RESCPU is also generated when a shutdown condition of the CPU is detected. When a Shutdown condition is detected, RESCPU is asserted HIGH for 16 PRCLK cycles and then negated to assure proper CPU operation. RESCPU can also be generated by doing an I/O write to Port 068 with bit $2=0$. This will generated RESCPU to reset the CPU and can be used to jump from protected mode to real time mode of the CPU.

The RES* input is buffered internal to the CPU Control IC with a Schmitt trigger input buffer. This signal should be held in a LOW state during power-up for at least 10 msec or until all operating voltages have reached their specified range of operation.

## Bus Control Logic

The Bus Control Logic of the CPU Control IC generates several Memory and I/O command and control signals that are issued by the 80286. There are two types of control signals that are generated as output signals. The command outputs are the first type of control signals generated which are decoded from the CPU status inputs MI/O*, S1*, SO*. The generated output command signals are MEMR*, MEMW*, IOR*, IOW*, INTA* which determine which type of cycle is to be performed. The second type of signals are the control signals which is ALE, DT/R*, DSDENO*, DSDEN1*, and MEMCYC. These signals latch the address from the CPU, control the direction and enabling of the data bus buffers, and determine the start of an on board memory cycle. Table l. contains a list of the command output signals that are generated from the CPU status line inputs.

| MI/O* Sl* SO* | Type of Cycle |  |  |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | Interrupt Acknowledge |
| 0 | 0 | 1 | I/O Read |
| 0 | 1 | 0 | I/O Write |
| 0 | 1 | 1 | None; Idle |
| 1 | 0 | 0 | Halt or Shutdown |
| 1 | 0 | 1 | Memory Read |
| 1 | 1 | 0 | Memory Write |
| 1 | 1 | 1 | None; Idle |

## Table 1. CPO Control Signal Generation

The state machine that controls the output timing of the command and control signals has three bus states, which are the Idle state (Ti), the Status state (Ts), and the command state (Tc). The Idle state (Ti) is generated when the CPU is not actively issuing a bus cycle. During an Idle state, all command and control output signals are in an inactive condition. The beginning of a bus cycle is detected when the CPU asserts Sl* or S0*. The state machine will start a Status state (Ts) and will assert ALE to an active HIGH state until the end of Ts. At the end of the status state, the state machine enters the command state (Tc) and will assert the decoded command issued by the CPU. The command signal may be delayed by one half bus cycle or one PRCLK clock cycle, if the conditions exist to produce a command delay. A Command delay will be generated on all I/O cycles, all Memory cycles in which both AF16* and MEMCSl6* are negated are inactive HIGH, and on all INTA* cycles.

For the control of the data bus buffer, three control signals are generated which are $D T / R^{*}$, DSDEN0*, and DSDEN1*. DT/R* is used to control the direction of the data bus to and from the CPU. DSDENO* and DSDEN1* are enable signals for the data bus buffers. DSDENO* is qualified with AO to control the lower 8 bits of the data bus (DO-D7). DSDEN1* is qualified with BHE* to control the upper 8 data bits (D8-D15). Control of the upper and lower data bits independently is required in the AT type architecture to control the 8 to 16 bit data conversions.

ALE is a control signal used to latch the address line from the CPU so that the address will remain stable throughout the complete command cycle. ALE as generated when either so* or Sl* is asserted from the CPU to start a bus cycle. This allows the address latches to be enabled as early as possible to provide sufficient address setup time to the on board memory array. ALE is negated at the start of the command state (Tc) to latch the address while they are guaranteed from the CPU.

The last control signal generated is MEMCYC which is used to control the start of a memory access to the on board memory array. MEMCYC is asserted HIGH at the middle of the status state (Ts) and is held active during the complete bus cycle. MEMCYC is negated at the end of a bus cycle or the end of the command state (TC).

## Bus Conversion Logic

This block of the CPU Control IC provides the logic to control the 16 bit transfers to and from an 8 bit device or memory. The conversion logic detects when a conversion is required, asserts a wait to the CPU by asserting the READY* line to a HIGH or inactive state, and then generates the required control signals to the data buffers to perform the conversion. A conversion is required during all 16 bit transfers to all $\mathrm{I} / \mathrm{O}$ devices, the Interrupt Controller, and 8 bit memory. An 8 bit memory cycle is detected by sampling the state of AF16* and/or MEMCS16* at the beginning of a memory cycle. If both are inactive HIGH then the conversion logic acknowledges it as an 8 bit memory cycle. The control signals that are generated are DIRHLB (Direction High Low Byte), ENHLB (Enable High Low Byte), and CNTLOFF (Control off). ENHLB enables the conversion buffer during the conversion cycle and DIRHLB determines the direction of the buffer. CNTLOFF is used to latch the lower 8 bits ( $D 0-D 7$ ) during a 16 bit read from an 8 bit device. SAO is also controlled and generated by the conversion logic so the even byte is read first then SAO is toggled to a HIGH state so the odd byte will be read.

## Wait State Control Logic

The Wait state Control Logic is used to allow slow memory and peripheral devices to be used with a faster CPU. Wait states are controlled by the CPU Control IC by negating the READY* line to the CPU to inactive state. The CPU will not end the cycle in progress until the READY* line is reasserted to an active LOW state. The READY* line is negated at the middle of the status state (Ts) to an inactive $H I G H$ to guarantee recognition of a wait state by the CPU. The READY* line is reasserted at the middle of the Command state or Wait State to end the existing cycle.

There are several default wait state cycles that are generated by the CPU Control IC for control of all bus cycles. During a 16 bit memory cycle which is determined by the assertion of AFl6* or MEMCSl6*, a default of one wait state is automatically inserted. During a 8 bit memory cycle which is determined when both AFl6* and MEMCSI6* are negated, a default of four wait states are automatically inserted. All $I / O$ cycles have a default of four wait states inserted to guarantee timing compatibility with existing $I / O$ channel add in boards. All of the default wait state are the same in the 8 MHz (FAST) mode and the 4 MHz (SLOW) mode except for the $I / O$ bus cycles. During an $I / O$ cycles in the 4 MHz (SLOW) mode, a default of only two wait states are inserted. This allows only the memory cycles to be effected to slow down the program speed without degrading the performance of I/O accesses.

All bus cycles can be extended above the default number of wait states by negating the IOCHRDY (I/O Channel Ready) to inactive LOW. The CPU Control IC will continue to insert wait states to the CPU until IOCHRDY is released allowing it to be asserted. IOCHRDY should not be held LOW for more that 15 usec. because Refresh to the DRAMs will be inhibited.

## DMA Arbitration Logic

The DMA Arbitration Logic in the CPU Control IC control the arbitration of the bus between the CPU and the DMA Controller. The arbitration logic detects when the DMA is requesting the bus when HRQ (Hold Request) is asserted HIGH. After HRQ is recognized, the arbitration logic will assert CPUHRQ to the CPU to request release of the bus. The CPU will respond to CPUHRQ after finishing the cycle in progress by suspending operation and asserting CPUHLDA to the CPU Control IC. The arbitration Logic will then tri-state the output command signals and generate HLDA to the DMA, allowing it to take control over the bus.

All DMA cycles have a default of one wait state automatically inserted to maintain compatibility with existing $1 / 0$ channel boards and peripheral devices. The DMA cycle can be extended by and I/O device by applying a LOW state to the IOCHRDY signal. The DMA Controller will be held in a wait state until IOCHRDY is returned to a HIGH state. Refer to Timing Diagrams for Timing specifications of a DMA cycle and DMA Arbitration operation.

The CPU Control IC also controls two functions required in the 80286 architecture during a DMA cycle. In order to guarantee the integrity of an Interrupt Acknowledge (INTA) cycle, which requires two bus cycles to complete, a DMA arbitration inhibit is included in the arbitration logic. After an INTA cycle has started, a DMA cycle will be inhibited until the CPU performs a memory write cycle. The memory write cycle will normally be executed after the INTA cycle due the stack operation of the CPU required to service an interrupt routine. The inhibit will guarantee the a DMA cycle can not be allowed until both bus cycles of an INTA cycle is complete.

## Numerical Co-processor Control Logic

The Numerical Co-processor Control Logic provides an interface for the 80286 CPU to control an 80287 Co-processor. This logic controls the decoding required to select and reset the 80287 , control of the BUSY* and ERROR* signals from the 80287 to the CPU, and generating the interrupt signal during an error condition.

The input signal 287 CS * is an $1 / 0$ decode at 0F0-0FFh I/O address. 287CS* is used by the CPU Control IC to generate the Numerical Co-processor Chip Select (NPCS*), and the reset signal (RES287*) to the 80287. Refer to the I/O decode table for details about the further internal decode done by the CPU Control IC.

When the 80287 receives a command to perform a task, it will output the BUSY* signal which is input to the CPU Control IC. The CPU Control IC will then assert BUSY287* to the CPU. During normal operation of the 80287 , when it finishes the task, it will negate BUSY* which will in turn negate BUSY287* to the CPU. If the ERROR input from the 80287 is asserted during this busy time, which indicates a 80287 error, BUSY287* output is latched and INT287* is asserted LOW to generate an interrupt to the CPU. Both BUSY287* and INT287* will remain latched in an active LOW state until they are cleared by writing to the $I / O$ address $0 F O h$ or OFlh. These signals are cleared after a system reset.

RES287* is generated to reset the 80287 . It is generated by writing to $I / O$ address 0 Flh or when a system reset is issued.

## A20 and CPO Reset Control Logic

The CPU Control IC incorporates the logic required to control the Address line $A 20$ and to reset the CPU. In the PC architecture, A20 must be held in a LOW state so the some programs that do wrapping will function correctly. After a reset, the output signal GA20 is help in a LOW state. If a program needs to address above the 1 MEG limit, OUT to $1 / O$ address 068 h with data bit 1 to a HIGH or "l" state will allow A20 to be muxed to GA20.

The CPU can reset itself by doing an $1 / 0$ wtrie to address 068 h with bit 2 at a LOW or "0" state. After a reset has occurred, by Reading $I / 0$ address 068 , it can be determined it was a power up reset or if the CPU reset itself. Refer to the $I / O$ address map for further details.

| Address | Description |
| :---: | :---: |
| 062 | Port C（Write Only） |
| Bit |  |
| $\begin{array}{llllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$ |  |
| ¢｜｜ข｜｜｜｜｜｜｜ข｜｜｜ |  |
| ｜｜｜｜ข｜｜｜｜｜｜｜＋－－ | Reserved |
| ｜｜｜｜｜｜｜｜｜＋－－－－－ | Reserved |
| ｜｜｜｜｜｜｜＋－－－－－－－ | Reserved |
| ｜｜｜｜ข｜ | $0=4 \mathrm{MHz}$（SLOW）Mode |
| ｜｜｜｜｜ | $1=8 \mathrm{MHz}$（FAST）Mode |
| ｜｜ 11 \｜ | Default after Reset |
| ｜｜｜｜ $\mid$＋－－－－－－－－－－－ | Reserved |
| 11 | Reserved |
| 1 ＋ | Reserved |
| ＋－－－－－－－－－－－－－－－－－ | Reserved |
| 068 | Port I（Read and Write） |
| Bit |  |
| $\begin{array}{llllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$ |  |
| ｜｜｜｜｜｜｜｜｜｜｜｜｜｜ |  |
| ｜1｜｜｜｜｜｜1｜｜｜1＋－－ | Not Used |
| \％ข｜｜｜｜｜｜｜＋－－－－－ | $0=$ GA20 always 0 |
| \｜\｜\｜\｜\｜\｜ | Default after Reset |
| ｜｜介｜介｜\｜｜｜｜ | 1 ＝A20 Muxed to GA20 |
| ｜｜｜｜｜｜｜ $\mid$＋－－－－－－－ | Write Mode $0=$ Reset CPU |
| \｜\｜\｜\｜\｜ | 1 ＝No Effect |
| ฯ ๆ｜リ｜1 | Read Mode $0=$ Power on Reset |
| ข1 ข｜｜1｜1 | $1=C P U$ Reset |
| ｜｜｜｜｜｜ $\mid$＋－－－－－－－－－ | Not Used |
| ｜｜｜｜｜｜＋－－－－－－－－－－－ | Not Used |
| ｜｜ 4 ＋－－－－－－－－－－－－－－ | Not Used |
| \｜＋－－－－－－－－－－－－－－－－ | Not Used |
| ＋－－－－－－－－－－－－－－－－－－ | Not Used |
| 0 FO | Clear Numerical Co－processor Busy |
| 0 Fl | Reset Numerical Co－processor |
| 0F8－0FF | Numerical Co－processor Chip Selec |

## Pin Configuration



## Functional Pin Description

| Pin\# | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
| 62 | 16 MHz | I | 16 MHZ Clock Input |
| 63 | PRCLK | 0 | 80286 Processor Clock - 16:8 MHZ |
| 64 | SCLK | 0 | System Clock - 8:4 MHZ |
| 65 | DMACLK | 0 | DMA Controller Clock - 4:2 MHz |
| 60 | 28.6MHz | I | 28.63636 MHZ Clock Input |
| 59 | OSC | 0 | 14.31818 MHZ Clock |
| 58 | 3.58 MHZ | 0 | 3.5795 MHZ Clock for sound chip |
| 57 | 1.19MHZ | 0 | 1.19 MHz Clock for Interval Timer chip 8254. |
| 18 | MI/O | I | Memory Input/Output from the CPU. Indicates a memory access when HIGH and a I/O access when LOW. Used to generate the memory and $I / O$ command signals for the system. |
| 17 | S1* | I | Status Line 1 from the CPU |
| 16 | S0* | I | Status Line 0 from the CPU |
| 19 | READY* | 0 | Ready signal to the 80286 Processor Indicates the current bus be completed when LOW. |
| 68 | CPUHRQ | 0 | CPU hold request signal for the CPU. Indicates DMA transfers by the DMA controller when HIGH. It is also active during refresh cycles. |
| 4 | CPUHLDA | I | Hold Acknowledge. signal from CPU. Indicates the CPU granting a DMA cycle to the DMA controller when HIGH. And causes all command signals to be tri-stated provided the CNTLOFF output is LOW |
| 33 | MEMR* | 0 | Memory Read Command output signal instructs a memory device to place data on the bus when LOW. It is also active during refresh. $13$ |


| 32 | MEMW* | I/O | Memory Write Command Input/Output signal. Instructs a memory device to read the data on the bus when LOW. |
| :---: | :---: | :---: | :---: |
| 22 | IOR* | I/O | Input/Output Read signal. Indicates a Read cycle is performed with an I/O device or port when LOW. |
| 21 | IOW* | I/O | Input/Output Write signal. <br> Indicates a Read cycle is performed with an I/O device or port when LOW. |
| 20 | INTA* | 0 | Interrupt Acknowledge for the <br> Interrupt Controller. It is used by the Interrupt controller to output the interrupt vector onto the data bus when LoW. |
| 55 | ALE | 0 | Address Latch Enable. It is used to hold the address during bus cycle when HIGH. |
| 56 | MEMCYC | 0 | Memory cycle signal. It is used to generate memory control signal, RAS, MUX and CAS when HIGH. |
| 36 | RES* | I | Reset signal. It is connected to the power good and used to reset the system when LOW. |
| 37 | RESET | 0 | Reset output signal. It is a synchronized reset signal for general system reset when HIGH, |
| 34 | RESCPU | 0 | CPU Reset output signal. It is used to reset CPU when HIGH. |
| 47 | XBHE* | (SBHE*) $1 / 0$ | Bus High Enable Input/Output signal. It is used to enable the high byte data bus signals when LOW |
| 45 | SA0 | 0 | System Address 0 . |
| 8 | AO | I | Address 0 input signal from CPU. It is used to generate the enable signal for the data bus. |


| 9 | A1 | I | Address 1 input signal from CPU. It is used to detect the SHUT DOWN condition of the CPU. |
| :---: | :---: | :---: | :---: |
| 10 | SA3 | I | System Address 3 input signal. It is used to generate the chip select and reset signal for 80287. |
| 11 | SA4 | I | System Address 4 input signal. It is used to generate the chip select. |
| 12 | A20 | I | Address 20 from the CPU. It is used to generate GA20 signal when CPUHLDA LOW. |
| 46 | GA2 0 | 0 | Gated Address 20. Address 20 is being negated by XDl and PORTI (internal). When XDl is LOW, Gated A20 on the CPU address bus is forced LOW. When XDl is HIGH, GA20 is transmited as Address 20. |
| 7 | PPICS* | I | Programable Peripheral Interface Chip Select input signal. It is used to generate Chip Select Signal signal for the peripheral interface device when is LoW. |
| 6 | 287CS* | I | 287 Chip Select input signal. It is used for generating the Numerical Processor Select NPCS for 80287 when is HIGH. |
| 5 | HRQ | I | Hold Request input signal from DMA controller. It is used to generate the CPU Hold Request Signal when is HIGH. |
| 67 | HLDA | 0 | Hold Acknowledge output signal for DMA Controller. It is used to provide Hold Acknowledge for DMA controller when is HIGH. |
| 3 | DMAAEN | I | DMA Address Enable input Signal from DMA Controller. It is used to provide enable signal for any $1 / 0$ device during DMA Access to the system memory when is HIGH. |


| 2 | DMAMR* | I | DMA Memory Read signal from DMA controller. It is used to generate Memory Read - MEMR* signal when is LOW. |
| :---: | :---: | :---: | :---: |
| 66 | DMARDY | 0 | DMA Ready output signal for DMA Controller. It is used to extend memory Read and Write cycles from the DMA Controller for slower memory or $\mathrm{I} / \mathrm{O}$ device when is HIGH. |
| 52 | BUSY* | I | Busy input signal from 80287. It indicates that 80287 is currently executing a command when is LOW. |
| 53 | ERROR* | I | Error input signal from 80287. It indicates an unmasked error condition exists. |
| 51 | BUSY287* | 0 | Busy 80287 output signal for the CPU. It indicates to the processor the operating condition of the 80287 when is LOW. |
| 50 | INT287* | 0 | Interrupt 80287 output signal for the Interrupt controller. It is the interrupt request from 80287 |
| 49 | RES 287 | 0 | Reset 80287 output signal for the 80287. It is used to reset to the 80287 when is HIGH. |
| 48 | NPCS* | 0 | Numerical Processor Chip Select output signal for the 80287 . It is used to select the 80287 device when is LOW. |
| 38 | DT/R* | 0 | Data Transmit/Received output signal. It is used to determine the data direction to and from local data bus. It is a write bus cycle when is HIGH and read bus cycle when is LOW. |
| 39 | DSDEN0* | 0 | Data Strobe Data Enable 0 output. It is used to enable the data transceivers connected to the low byte (DO-D7) when is LOW. |
| 40 | DSDEN1* | 0 | Data Strobe Data Enable 1 output signal. It is used to enable the data transceivers connected to the high byte (D8-D15) data bus when is LOW. $16$ |


| 41 | ENHLB* | 0 | Enable High To Low byte output signal. It is used to perform the high to low conversion when is LOW. |
| :---: | :---: | :---: | :---: |
| 42 | CNTLOFF | 0 | Control Off output signal. It is used to enable the low data bus latch during byte accesses when is LOW. |
| 43 | DIRHLD | 0 | Direction High to Low byte output signal. It is used to perform high to low byte conversion when is HIGH. |
| 13 | AF16* | I | AF16* output signal. It is used to control the 16 bit memory accesses and to inhibit the command delays for memory accesses by $1 / 0$ device when is LOW. |
| 14 | MEMCS16* | I | Memory Chip select input signal. It is used to inhibit command delays when 16 bit memory accesses are made when is LOW. |
| 54 | IOCHRDY | I | I/O Channel Ready input signal from I/O device. It is used generate wait states in I/O or memory accesses by $1 / 0$ device when is HIGH. |
| 15 | VIDWAIT* | I | Video Wait input signal from video controller. It is used to generate Video delay ready signal when is HIGH. |
| 31 | D0 | I/O | Data Bus Bit 0 of the peripheral data bus. |
| 30 | D1 | I/O | Data Bus Bitt 1 of the peripheral data bus. |
| 29 | D2 | I/O | Data Bus Bit 2 of the peripheral data bus. |
| 28 | D3 | 1/0 | Data Bus Bit 3 of the peripheral data bus. |
| 26 | D4 | I/O | Data Bus Bit 4 of the peripheral data bus. |


| 25 | D5 | I/O | Data Bus Bit 5 of the peripheral <br> data bus. |
| :--- | :--- | :--- | :--- |
| 24 | D6 | D7 | Data Bus Bit 6 of the peripheral <br> data bus. |
| 1,35 | VCC | PWR | Data Bus Bit 7 of the peripheral <br> data bus. |
| 27,44 | VSS | GND | Ground. |

## ELECTRICAL SPECIFICATIONS

| ABSOLUTE MAX RATINGS (NON-OPERATING, VSS $=0.0 \mathrm{~V}$ ) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN |  | MAX | UNITS |
| STORAGE TEMPERATURE | -65 |  | +150 | Degrees C. |
| VOLTGAE ON ANY PIN W.R.T GROUND | -0.5 |  | 7.0 | volts |
| OPERATING ELECTRICAL SPECIFICATIONS: |  |  |  |  |
| OPERATING AMBIENT | MIN | TYP | MAX | UNITS |
| AIR TEMP. RANGE | 0 | 25 | 70 | Degrees C |
| POWER SUPPLIES |  |  |  |  |
| VCC | 4.5 | 5.0 | 5.5 | Volts |
| vSs | 0 | 0 | 0 | Volts |
|  | MIN | TYP | MAX | UNITS |
| LEAKAGE CURRENT |  |  |  |  |
| V in $=0.0 \mathrm{~V}$ |  | 20 |  | Microamps |
| Vin $=5.0 \mathrm{v}$ | -20 |  |  | Microamps |
| DC ELECTRICAL CEARACTERISTICS |  |  |  |  |
| INPUT VOLTAGES AND CURRENTS |  |  |  |  |
|  | MIN | TYP | MAX | UNITS |
| LOGIC "0" (Vil) @ 8ma |  |  | 0.8 | Volts |
| LOGIC "l" (Vih) @ 8ma | 2 |  |  | Volts |
| INPUT CURRENT |  |  | +10 | Microamps |
| All inputs $0.0 \frac{1}{4} \mathrm{Vin} \frac{1}{4} 5.0$ | 10 |  |  | Picofarads |
| OUTPUT VOLTAGES CURRENT LOADING |  |  |  |  |
|  | MIN | TYP | MAX | UNITS |
| LOGIC "0" (Vol) @ 8ma |  |  | 0.45 | Volts |
| LOGIC "l" (Voh) @ 8ma | 2 |  |  | Volts |


| CURRENT LOADING AND CAPACITANCE OF EACH OUTPUT |  |  |  |
| :---: | :---: | :---: | :---: |
| At Vol $=0.45$ volts, Voh $=2.4$ volts |  |  |  |
| PIN NAME | MIN | UNITS | CAPACITANCE NOTES |
| OUPPUT |  |  |  |
| RESCPU, $\overline{N P C S}, \overline{B U S Y 287, ~ \overline{I N T 287}}$ <br> RES287,CPUHRQ, HLDA, DIRHLB |  |  |  |
| RESET, GA20 | 2 | ma | 50 pf |
| READY, MEMCYC, DT/ $\overline{\mathrm{R}}, \overline{\mathrm{DSDENO}}$ DSDEN1 | 4 | ma | 20pf |
| SCLK, DMACLK, OSC, 1.19MHZ 3.58MHZ | 4 | ma | 50pf |
| PRCLK, $\overline{\text { INTA }}$ | 8 | ma | 50 pf |
| ALE | 8 | ma | 50 pf |
| MEMR | 8 | ma | 80pf |
| INPUT/OUTPUT |  |  |  |
| XD0 - XD7 | 2 | ma | 80pf |
| $\overline{\mathrm{XBHE}}$ | 4 | ma | 50 pf |
| MEMW | 8 | ma | 80 pf |
| $\overline{\text { IOR, }}$, $\overline{\text { IOW }}$ | 8 | ma | 115 pf |
| SAO | 4 | ma | 120pf |

## Timing Diagram Specifications

| !SYM! DESCRIPTION | IMIN ! MAX |  | ! UNITS ! NOTES |  |
| :---: | :---: | :---: | :---: | :---: |
| $!== \pm!==$ |  |  |  | ! |
| ! ! | - | $!$ | $!$ | $!$ |
| 1 !PRCLK Period | $!62$ | ! 250 | !ns | $!$ |
| 1 | $!$ | ! | ! | $!$ |
| ! 2 !PRCLK Low Time | ! 25 | ! 125 | !ns | $!$ |
| $!$ ! | $!$ | ! | $!$ | $!$ |
| 13 1PRCLK High Time | 125 | 1125 | !ns | $!$ |
| $!$ ! | $!$ | ! | $!$ | ! |
| $4!\overline{S O}, \overline{S 1}, M / \overline{I O}$ Setup time to PRCLK $\downarrow$ | 120 | $!$ | ! ns | $!$ |
| 1 ! | ! | ! | $!$ | ! |
| ! 5 ! $\overline{S O}, \overline{S 1}, \mathrm{M} / \overline{\mathrm{IO}}$ Hold time to PRCLK. | 11 | $!$ | ! ns | $!$ |
| 1 ! | $!$ | $!$ | $!$ | $!$ |
| ! 6 ! ALE active from $\overline{S O}, \overline{\mathrm{SI}}$ | 15 | 125 | ! ns | 1 |
| 1 ! | $!$ | ! | $!$ | $!$ |
| ! 7 ! ALE inactive from PRCLKd | 15 | 125 | ! ns | $!$ |
| 1 ! | ! | ! | $!$ | ! |
| !7A ! OSC delay from 28.6 MHZ | $!$ | ! 30 | ! ns | 1 |
| $!1$ | ! | ! | $!$ | $!$ |
| ! 8 !MEMCYC active from PRCLK | 15 | 125 | !ns | $!$ |
| $!$ | ! | ! | $!$ | $!$ |
| 18 A 13.85 MHz delay from OSC | $!$ | $!15$ | ! ns | $!$ |
| ! ! | ! | ! | $!$ | $!$ |
| ! 9 ! MEMCYC inactive delay from PRCLK | ! 8 | 135 | ! ns | $!$ |
| $!$ ! | ! | ! | $!$ | $!$ |
| !9A ! 1.19 MHZ delay from OSC | $!$ | 115 | ! ns | 1 |
| $!$ | $!$ | ! | $!$ | $!$ |
| $!10$ ! Command active delay from PRCLK | 15 | 145 | ! ns | $!$ |
| ! ! |  | $!$ | $!$ | $!$ |
| !11 ! Command inactive delay from PRCLK | $!5$ | 45 | ! ns | 1 |
|  | ! | 150 | ! | , |
| 112 !DT/R active delay from PRCLK | 15 | 50 | ! ns | $!$ Read |
| $!\quad!$ |  | 1 | $!$ | $!$ |
| !13 !DT/R inactive delay from PRCLK | 110 | 40 | ! ns | $!$ Read |
| ! ! |  | ! | $!$ |  |
| !14 ! DSDENO, 1 active delay from PRCLK | 110 | $!50$ | !ns | ! Read |
| ! ! | ! | ! | $!$ |  |
| !15 !DSDENO, 1 inactive delay from DT/R | 13 | $!$ | ! ns | ! Read |
| ! ! | ! | ! | $!$ | 1 |
| 116 ! DSDEN0,1 inactive delay from PRCLK | 8 | 150 | ! ns | $!$ Read |
| ! ! - |  | ! | $!$ | $!$ |
| $!17!D T / \bar{R}$ inactive delay from $\overline{\text { DSDENO,1 }}$ | 13 | $!$ | ! ns | $!$ Read |
| ! ! | ! | ! | $!$ | ! |
| !18 !DSDENO,1 active delay from PRCLK | 18 | $!60$ | 1 ns | ! Write |
| $!$ ! |  | - | $!$ | $!$ |
| !19 ! DSDENO, 1 inactive delay from PRCLK! | ! 8 | 150 | !ns | 1Write |






1. Setup and Hold times are required to guarantee recognition of signa' at clock edge.
2. CMD = MEMR, MEMW,IOR and IOW.
$A / I=$ Active and Inactive

1000 TX Power Supplies
Yity h2l 4hatixtz

 "4xym:

 DEy

## 1000 TX 67 Watt Single Input Power Supply Contents

Section Page
Operating Characteristics ..... 1
Block Diagram ..... 2
Theory of Operation ..... 3

| OPERATING CHARAGTERISTICS |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MINIMUM | TYPICAL | MAXIMUM | UNITS |
| Operating Voltage Range | 90 | 120 | 135 | VAC |
| Line Frequency | 47 | 50/60 | 63 | Hz |
| Output Voltages |  |  |  |  |
| Vol | 4.85 | 5.00 | 5.15 | V |
| Vo2 | 11.40 | 12.00 | 12.60 | V |
| Vo3 | -13.20 | -12.00 | -10.80 | V |
| Output Loads |  |  |  |  |
| Iol | 1.25 | - | 7.0 | A |
| Io2 | 0.15 | - | 2.4 | A |
| Io3 | 0 | - | 0.25 | A |
| Over Current Protection |  |  |  |  |
| Current Limit ICLI | - | - | 14.0 | A |
| ICL2 | - | - | 4.8 | A |
| ICL3 | - | - | 1.0 | A |
| Over Voltage Protection |  |  |  |  |
| Crowbar | 5.8 | - | 6.8 | V |
| Output Noise |  |  |  |  |
| Vol | - | - | 50 | mV P-P |
| Vo2 | - | - | 100 | mV P-P |
| Vo3 | - | - | 150 | mV P-P |
| Efficiency | 63 | 65 | - | \% |
| Holdup Time |  |  |  |  |
| Full Load at Nominal Line | 16 | - | - | mSec. |
| Insulation Resistance |  |  |  |  |
| Input to Output | 7 | 1000 | - | M ohms |
| Input to Ground | 7 | 1000 | - | M ohms |
| Isolation |  |  |  |  |
| Input to Ground | 1.7 | - | - | KVDC |

## 5v Output Voltage Detecting Circuit

The circuit detects the change of output load current compared with the output voltage and $A C$ line input voltage, which feeds back to the control circuit through a photo coupler PHCl to keep the output voltage stable. The photo coupler isolates the primary and secondary circuits.

## Over-Voltage Protection

When the +5 output voltage rises, between 5.8 V to 6.8 V , a control signal turns on the photo coupler PHC2 (Photo Thyristor) with the current of zener diode (Dll) and stops oscillation by turning on Q3, which turns of $f$ Ql in the switching circuit.

In the case of stopped oscillation, correct the cause of the failure, and reinput the power. The overvoltage protection circuit will reset automatically under good conditions.

The Photo Thyristor isolates the primary and secondary circuits.

## 1000 TX 67 Watt Dual Input Power Supply Contents

Section Page
Operating Characteristics ..... 1
Block Diagram ..... 2
Theory of Operation ..... 3

| OPERATING CHARACTERISTICS |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MINIMUM | TYPICAL | MAXIMUM | UNITS |
| Operating Voltage Range | $\begin{array}{r} 90 \\ 198 \end{array}$ | $\begin{aligned} & 120 \\ & 240 \end{aligned}$ | $\begin{aligned} & 135 \\ & 264 \end{aligned}$ | VAC |
| Line Frequency | 47 | 50/60 | 63 | Hz |
| Output Voltages |  |  |  |  |
| Vol | 4.85 | 5.00 | 5.15 | V |
| Vo2 | 11.40 | 12.00 | 12.60 | V |
| Vo3 | -13.20 | -12.00 | -10.80 | V |
| Output Loads |  |  |  |  |
| Iol | 1.25 | - | 7.0 | A |
| Io2 | 0.15 | - | 2.4 | A |
| Io3 | 0 | - | 0.25 | A |
| Over Current Protection |  |  |  |  |
| Current Limit ICLI | - | - | 14.0 | A |
| ICL2 | - | - | 4.8 | A |
| ICL3 | - | - | 1.0 | A |
| Over Voltage Protection |  |  |  |  |
| Crowbar | 5.8 | - | 6.8 | V |
| Output Noise |  |  |  |  |
| Vol | - | - | 50 | mV P-P |
| Vo2 | - | - | 100 | mV P-P |
| Vo3 | - | - | 150 | mV P-P |
| Efficiency | 63 | 65 | - | $\%$ |
| Holdup Time |  |  |  |  |
| Full Load at Nominal Line | 16 | - | - | mSec. |
| Insulation Resistance |  |  |  |  |
| Input to Output | 7 | 1000 | - | M ohms |
| Input to Ground | 7 | 1000 | - | M ohms |
| Isolation |  |  |  |  |
| Input to Ground | 1.25 | - | - | KVAC |
| Input to Output | 3.75 | - | - | KVAC |



Power Supply Block Diagram

## Theory of Operation

## AC Input Circuit

This circuit is composed of an AC Power Switch, a fuse, a line filter, and an inrush current limiting circuit and rectifying smoothing circuit. The inrush current limiting circuit controls the charging current to electrolytic capacitors when power is ON. The line filter reduces noise that leaks from the power source to the AC line or that returns from the unit to the power souce; it satisfies the specifications of noise regulations.

## Control Circuit \& Power Converter Circuit

This circuit is a self oscillation switching system, generally called an R.C.C. (Ringing Choke Converter). The R.C.C. circuit does not fix the oscillating frequency. Whenever input voltage is high or the load becomes light, the oscillating frequency will be high.

The current through R4 and R5 supplies transistor Ql's base, then Ql turns ON. When transistor Ql is On, the Ql current excites the transformer $T l$ and voltage rises in the bias coil of $T l(2-3)$ which leads transistor Q1 positive bias, then transistor Ql turns ON .

When transistor Q1 turns ON, collector current charges the energy to primary inductance of transformer $T 1$ (4-6). Increasing the collector current of transistor Ql to the point of:

$$
\begin{array}{rl}
I & > \\
C & I \cdot h f e \\
\end{array}
$$

Then, transistor Q1 immediately turns OFF. In a moment, transformer $T l$ will have negative voltage which will be supplied to the secondary circuit through a rectifier. A Short circuit Protector is provided to protect transistor Ql from excess amounts of current when the secondary circuit becomes shorted. When transistor Q2 detects the voltage drop at R13, the collector of $Q 2$ shorts the base and emitter of Q1. Then Q1 stops working so that the circuit protects $Q 1$ from over current.

The over current protector in the -12 V line is provided by the three terminal positive voltage regulators IC2, IC3 (built-in current fold back protection , which protects Ql against excessive current from the -12 V line.

## 5V Output Voltage Detecting Circuit

The circuit detects the change of output load current compared with the output voltage and AC line input voltage, which feeds back to the control circuit through a photo coupler PHCl to keep the output voltage stable. The Photo coupler isolates the primary and secondary circuits.

## Over-Voltage Protection

When the +5 output voltage rises, between 5.8 V to 6.8 V , a control signal turns on the photo coupler PHC2 (Photo Thyristor) with the current of zener diode (Dll) and stops oscillation by turning on Q3, which turns off $Q 1$ in the switching circuit.

In the case of stopped oscillation, correct the cause of the failure, and reinput the power. The overvoltage protection circuit will reset automatically under good conditions.

The Photo Thyristor isolates the primary and secondary circuits.

## 1000 TX Keyboard Contents

Section Page
Specifications ..... 1
Keyboard Timing ..... 2
Keyboard Scan Codes ..... 3
Keyboard Key Layout ..... 5

## 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 1 shows the interconnecting cable connector to the keyboard assembly. The cable assembly can be disconnected from the keyboard assembly during repair.


Keyboard Assembly Connector
Figure 1

## 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 80 H 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.

## Keyboard Timing

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


Keyboard Assembly Timing Chart

Figure 2

## Key Code Chart

## Key Number <br> Legend <br> Scan Code


$\begin{array}{lll}10 & \text { F10 } & 44 \\ 11 & \text { F11 } & 59\end{array}$
12 F12 5A
13
14
15

15 | F12 |
| :---: |
| INERT |
| DELETE |

| 16 | ESC | 01 |
| :--- | :--- | :--- |
| 17 | $1!$ | 02 |


| 18 | $2 @$ | 03 |
| :---: | :---: | :---: |
| 19 | 3 | 04 |
| 20 | $\$$ | 05 |
| 21 | $5 \%$ | 06 |

$226^{\wedge} 07$
$23 \quad 7$ \& 08
24 8 * 09

| 25 | $9(4)$ |
| :---: | :---: |
| 26 | $0)$ |
| 27 | $O A$ |
| 27 |  |

28 = + OD
29 BACKSPACE OE
30 ALT 38

| 31 | PRINT | (backslash) |
| :---: | :---: | :---: |
| 32 | 8 (Tilde) | 47 |
| 33 | 9 PG UP | 48 |
| 34 | TAB | 49 |
| 35 | $Q$ | $0 F$ |
| 36 | W | 10 |
| 37 | R | 11 |
| 38 | $T$ | 12 |
| 39 | $Y$ | 13 |
| 40 | $U$ | 14 |
| 41 |  | 15 |
| 42 | $P$ | 16 |
| 43 |  | 17 |



## 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 3 Keyboard Identification

| 1 | 2 | 3 |  | 4 |  |  | 5 |  | 6 | 7 |  | 8 |  |  |  | 10 | 41 | 12 |  |  |  | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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 | 49 | 42 |  | 43 | 44 |  | 45 | 46 | 47 |  | 48 | 49 | 50 | 51 | 52 |
| 53 |  | 54 | 55 |  | 56 | 57 |  | 58 | 59 |  | 60 | 61 | 62 |  | 63 | 64 | 65 |  | 66 | 67 | 68 | 69 | 70 |
| 71 | 72 | 7 |  | 74 | 475 |  | 76 | 77 |  | 78 |  | 79 | 80 | 81 |  | 82 | 83 | 84 | 85 | 86 | 67 | 88 | 89 |
|  | 91 |  | 92 |  |  |  |  |  | 90 |  |  |  |  |  |  | 93 | 94 | 95 |  |  |  |  |  |

NOTE: KEYS 9 I THRU 95 HOT USED ON U.S VERSION, USED ON INTERNATIONAL VERSION ONLY

Figure 4 Key Number Identification


Figure 5

## Specifications <br> of

MP-F63W-72D

\author{
Double Sided 80 Tracks Recording Capacity lMBytes Transfer Rate 250 Kbits/sec [TrL interface, without Ready signalJ <br> ```
VALID for MP-F63W-72D, with the following serial numbers :

```
}


\section*{SONY CORPORATION}
1. Description
2. Specifications

\subsection*{2.1 Configuration}
2.2 Physical Dimensions
2.3 Performance
2.3.1 Capacity
2.3.2 Transfer Rate
2.3.3 Access Time
2.3.4 Functional
2.3.5 Reliability
2.4 Input Power Requirements
2.4.1 Power Consumption
2.4.2 Supply Voltages
2.5 Environmental Limits and Orientation
2.5.1 Temperature
2.5.2 Humidity
2.5.3 Vibration
2.5.4 Shock
2.5.5 Orientation
3. Interface
3.1 Pin Assignment
3.1.1 Signal Connector
3.1.2 Signal Connector Pin Assignment
3.1.3 Power Supply Connector
3.1.4 Power Supply Connector Pin Assignment
3.2 DC Characteristics of Interface Signals
3.2.1 Output Signals from Drive
3.2.2 Inputs Signals to Drive
3.3 Signal Definitions
3.3.1 DRIVE SELECT \(0,1,2,3\)
3.3.2 MOTOR ON
3.3.3 STEP
3.3.4 DIRECTION
3.3.5 HEAD SELECT
3.3.6 WRITE GATE
3.3.7 WRITE DATA
3.3.8 INDEX
3.3.9 TRACK 00
3.3.10 WRITE PROTECT
3.3.11 READ DATA
3.3.12 DISK CHANGE
3.4 Timing Requirements
3.4.1 Head Access
3.4.2 TRACK 00 Signal
3.4.3 Write Data Timing
3.4.4 Read Data Timing
3.4.5 Index Pulse
3.4.6 Disk Change
3.5 Power on and Power off Requirements
3.5.1 Data Protection
3.5.2 Power Supply Sequencing
3.6 Disk Motor Rotation and Disk Insertion.
3.7 Power-On Reset Timing
4. Safety
5. Power On Initialization
6. Test Points
1. Description

This document describes the specifications for the MP-F63W-72D of which the recording capacity is lMB, the maximum track-to-track access time is 3 msec and a TML compatible signal interface. The main features of the MP-F63W-72D are low power consumption, low height, and nigh reliability with a simple mechanism and electric circuit.

NB: The specifications defined in this booklet are valid only if the drive is used with Sony media or any other ANSI specification media agreed upon by Sony and the drive customer.
2. Specifications

\subsection*{2.1 Configuration}

The drive consists of Read/Write neads, head positioning mechanism, disk motor, interface logic circuit and Read/Write circuit.

\subsection*{2.2 Pnysical Dimensions}

The detailed pnysical dimensions are shown in Figure 2.1. The main dimensions are:
1) Height : 30 mm
2) Width : 101.6 mm
3) Depth : 150 mm
4) Weight : 480 g max.

\subsection*{2.3 Performance}

2.3.1 Recording Capacity

Unformated capacity : 1.0 Mbyte/disk for MFM
 0.5 Mbyte/surface for MFM
 6.25 Kbyte/track for MFM

\author{
2.3.2 Transfer Rate \\ Burst transfer rate : 250 Kbits/Gec for MFM
}


Figure 2-1. PHYSICAL DIMENSIONS
```

2.3.3 Access Time
a. Track to Track Slew Rate : 3 msec max.
b. Head Settling Time : }15\textrm{msec}\mathrm{ max.
c. Motor Start Time : 500 msec max.
(700 msec max.*)
Motor start time is defined as the time period necessary to
stabilise the Motor Rotational Speed variance to less than
+/-l.5% after turning the MOTOR ON signal on.
NB. When a disk is inserted in the drive, the Motor Start
Time will be }700\mathrm{ msec at maximum, but, after that it will be
500 msec max. as the disk is kept inserted.
2.3.4 Functional
a. Rotation Speed : 300 rpm
The continuous speed variation is within +/-1.5%.
The instantanuous speed variation is within +/-1.0%.
b. Recording Density : 8717 BPI (Side 1, Track 79) in a lMB mode
c. Track Density : 135 TPI
d. Cylinders : 80
e. Tracks : 160
f. R/W Heads : 2
2.3.5 Reliability
a. Mean Time Between Failures (MTBF) : 10,000 POH
b. Mean Time to Repair (MTTR) : 30 minutes
c. Preventive Maintenance (PM) : Not Required
d. Components life : 5 years or l5000 POH
e. Error Rate :
1. Soft Read Error : Less than l per 10 }\mp@subsup{0}{}{9}\mathrm{ bits read
2. Hard Read Error : Less than l per 10 }\mp@subsup{0}{}{12}\mathrm{ bits read
3. Seek Error : Less than l per }1\mp@subsup{0}{}{6}\mathrm{ seeks

```

\subsection*{2.4 Input Power Requirements}

\subsection*{2.4.1 Power Consumption}

\section*{TTL Interface}

Standby
250 mW
Operation (read/write mode)
2.8 W
2.4.2 Supply Voltages
\begin{tabular}{ll}
\(\frac{\text { Voltage }}{+12.0 \mathrm{~V}+/-5 \%}\) & \begin{tabular}{l} 
Max. Ripple \\
0.1 Vpp \\
\(+5.0 \mathrm{~V}+/-5 \%\)
\end{tabular} \\
\end{tabular}

\subsection*{2.5 Environmental Limits}

\subsection*{2.5.1 Temperature Range}

Operating \(\quad: 5^{\circ} \mathrm{C}\) to \(50^{\circ} \mathrm{C}\) ambient ( \(40^{\circ} \mathrm{F}\) to \(122^{\circ} \mathrm{F}\) )
Transportation : \(-40^{\circ} \mathrm{C}\) to \(60^{\circ} \mathrm{C} \quad\left(-40^{\circ} \mathrm{F}\right.\) to \(\left.140^{\circ} \mathrm{F}\right)\)
Storage \(\quad=-20^{\circ} \mathrm{C}\) to \(60^{\circ} \mathrm{C} \quad\left(-20^{\circ} \mathrm{F}\right.\) to \(\left.140^{\circ} \mathrm{F}\right)\)
2.5.2 Humidity Range

Operating : \(8 \%\) to \(80 \%\) relative humidity with a wet bulb temperature of \(29^{\circ} \mathrm{C}\) ( 85 F ) and no condensation.

Transportation
and Storage : \(\begin{aligned} & 5 \% \text { to } 95 \% \text { relative humidity and no } \\ & \text { condensation }\end{aligned}\)
2.5.3 Vibration

Operating : The unit can perform Read/Write operations without errors at continuous vibration from 10 to 500 Hz at a maximum of 0.5 G along each of the three mutually perpendicular axes.

Transportation
and Storage : The unit can withstand continuous vibration from 10 to 300 Hz with a maximum level of 2.0 G along each of the three mutually perpendicular axes without any degradation of any characteristics below the performance specifications.

\subsection*{2.5.4 Shock}

> Operating \(\quad \begin{aligned} & \text { The unit can withstand a shock of } 5.0 \mathrm{G} \\ & \\ & \text { shock for } 11 \text { msec with a } 1 / 2 \text { sine } \\ & \\ & \text { wave shape in each of the three mutually } \\ & \text { perpendicular axis while performing normal } \\ & \\ & \text { read/write functions without damage or any }\end{aligned}\) loss of data.

Transportation and Storage : The unit when unpacked can withstand an ll msec with a \(1 / 2\) sine wave shock of 60 G on any of the three mutually perpendicular axes.

\subsection*{2.5.5 Orientation}

The drive does not necessarily need to be horizontally positioned. In fact, as seen in figure 2-3, there are many other possible orientations.
3. Signal Interface

\subsection*{3.1 Connector and Pin Assignments}

\subsection*{3.1.1 Signal connector}
\begin{tabular}{ll} 
Receptacle & \(: 3 M 3414-6500 x x\) or Equivalent \\
Cable & \(: 3 M 3365 / 34\) or Equivalent
\end{tabular}


Figure 3.1. PIN ASSIGNMENT (REAR VIEW OF DRIVE)


Figure 3.2. DRIVE SELECT SWITCH


Figure 2-3. ORIENTATIONS
```

3.1.2 Signal Connector Pin Assignment

```
\begin{tabular}{|c|c|c|c|}
\hline PIN & SIGNAL DESCRIPTION & PIN & SIGNAL DESCRIPTION \\
\hline 1 & CN & 2 & N.C. \\
\hline 3 & 5V & 4 & N.C. \\
\hline 5 & 5 V & 6 & DRIVE SELECT 3 \\
\hline 7 & 5V & 8 & INDEX \\
\hline 9 & 5 V & 10 & DRIVE SELECT 0 \\
\hline 11 & 5 V & 12 & DRIVE SELECT 1 \\
\hline 13 & RETURN & 14 & DRIVE SELECT 2 \\
\hline 15 & RETURN & 16 & MOTOR ON \\
\hline 17 & RETURN & 18 & DIRECTION \\
\hline 19 & RETURN & 20 & STEP \\
\hline 21 & RETURN & 22 & WRITE DATA \\
\hline 23 & RETURN & 24 & WRITE GATE \\
\hline 25 & RETURN & 26 & TRACK 00 \\
\hline 27 & RETURN & 28 & WRITE PROTECT \\
\hline 29 & 12V & 30 & READ DATA \\
\hline 31 & 12 V & 32 & HEAD SELECT \\
\hline 33 & 12 V & 34 & DISK CHANGE \\
\hline
\end{tabular}

\subsection*{3.1.3 Power Supply Connector}
\begin{tabular}{ll} 
Receptacle & : AMP 171822-4 or Equivalent \\
Contact & : AMP 170262-1 or Equivalent \\
Wire & : AWG 20
\end{tabular}
3.1.4 Power Supply Connector Pin Assignment
\begin{tabular}{|c|c|}
\hline PIN & SIGNAL DESCRIPTION \\
\hline 1 & +5 V \\
\hline 2 & GND \((+5 \mathrm{~V}\) Return \()\) \\
\hline 3 & GND \\
\hline 4 & +12 V Return \()\) \\
\hline
\end{tabular}
3.2 DC Characteristics of Interface Signals
3.2.1 Output Signal from Drive
\begin{tabular}{ccccc} 
Name & \begin{tabular}{c} 
Output \\
\(\mathrm{IOH}(\mathrm{mA})\)
\end{tabular} & \begin{tabular}{c} 
Current \\
\(\mathrm{IOL}(\mathrm{mA})\)
\end{tabular} & \begin{tabular}{c} 
Output \\
VOH(V)
\end{tabular} & \begin{tabular}{c} 
Voltage \\
TTL interface
\end{tabular} \\
\begin{tabular}{c} 
VOL V\()\)
\end{tabular} \\
All outputs & 0.25 & 40 & & 0.7
\end{tabular}
3.2.2 Input Signal to Drive
\begin{tabular}{cccc} 
& \begin{tabular}{c} 
Input Current \\
VIN \(=0.4 \mathrm{~V}\)
\end{tabular} & Input Voltage Threshold \\
Name & \(\underline{I I L(m A)}\) & VIH(V) & \(\underline{\text { VIL(V) }}\) \\
\begin{tabular}{c} 
TTL interface \\
All inputs
\end{tabular} & \begin{tabular}{c}
-5.0
\end{tabular} & 2.2 & 0.8
\end{tabular}

\subsection*{3.2.3 Recommended Circuit for Signal Interface}


The Interface signals in parethesis are only for MP-F63W-72D The line from the drive to the controller should be pulled up by a resistor of lk ohm.

The cable length must be less than 1.5 m . (4.92ft.)
Recommended driver IC : 7406, 7438

\subsection*{3.3 Signal Definitions}

\subsection*{3.3.1 DRIVE SELECT \(0,1,2,3\)}

The select lines are used to enable or disable all other interface lines except a MOTOR ON line. When the SELECT line is true (low), the drive is enabled and is considered active. When the SELECT line is false (high), all controller inputs except the MOTOR ON line are ignored and all output lines are disabled.

NB. IN USE (LED) lamp:
When a drive is selected, the IN USE lamp on the selected drive is turned on, and when a drive is not selected, it is turned off.

\subsection*{3.3.2 MOTOR ON}

When this input is true (low) and a disk is inserted, the spindle motor will start to run. When this line is made false (high) or a disk is ejected, the spindle motor will decelerate and stop.

However, if the MOTOR ON signal becomes false (high) during either a write or erase operation, the disk motor will not stop rotating until both the ERASE GATE signal and the WRITE GATE signal become false (high).

\subsection*{3.3.3 STEP}

When a drive is selected, a true (low) pulse on this line will cause the Read/Write head to move to the adjacent track. The direction of the head movement is determined by the DIRECTION input at the trailing edge of the pulse. The step operation can be performed even if there is no disk inserted in the drive.

\subsection*{3.3.4 DIRECTION}

When a drive is selected, a false (high) level on this input will cause a STEP pulse input to move the Read/Write head away from the disk spindle. A true (low) level will cause a STEP input to move the Read/write head toward the drive spindle.

\subsection*{3.3.5 HEAD SELECT}

When a drive is selected, a true (low) level on this input will cause Head \(l\) (upper) to be selected. A false (high) level on this input will cause Head 0 (lower) to be selected.

If the HEAD SELECT signal changes during either write or erase operation, the head is not be changed until both ERASE GATE and WRITE GATE signal becomes high (false).

\subsection*{3.3.6 WRITE GATE}

When this line is made true (low) while a drive is selected, the write current circuits are enabled and information may be written under control of the WRITE DATA input.

\subsection*{3.3.7 WRITE DATA}

If the WRITE GATE is true (low), a true pulse (low) on the WRITE DATA line causes a bit to be written on the disk. Pulses on this line is neglected when WRITE GATE signal is false (high). No pre-compensation is required.

\subsection*{3.3.8 INDEX}

When the drive is selected, a true (low) pulse is generated on this line by each revolution of the spindle.

\subsection*{3.3.9 TRACK 00}

This line is true (low) when the drive is selected and the Read/Write head is positioned on track 00.

\subsection*{3.3.10 WRITE PROTECT}

If a write-protect disk is inserted while a drive is selected, this line will be true (low) and the drive will not be able to write data. At all other times, except when a disk is ejected while the drive is selected, this line will be false (high).

\subsection*{3.3.11 READ DATA}

When the drive is selected, a true (low) pulse is generated on this line every time a bit is detected.

\subsection*{3.3.12 DISK CHANGE}

This line is true (low) whenever a disk is removed from the drive. The line remains true (low) until both the following conditions have been met:
1. A disk is inserted,
and
2. A STEP pulse has been received when the drive is selected.
3.4 Timing Requirements
3.4.1 Head Access

DRIVE SELECT

DIRECTION

STEP


Tl : 0.5 us min.
T2 : 1.3 us min.
T3 : 3.0 ms min.
T4 : 2.4 us min.
T 5 : 0.5 us min.
T6 : 18 ms min.
T7 : 2.5 us min.

DIRECTION


Tl : 2.9 msec max.
T2 : 2.9 msec max.

\subsection*{3.4.3 Write Data Timing}


*NB. When a disk is inserted in the drive, the Motor Start Time is 700 msec at maximum, but, after that, it is \(500 \mathrm{msec} \max\). as the disk is kept inserted.

\subsection*{3.4.4 Read Data Timing}



NB. When a disk is inserted in the drive, the \(T 2\) is 700 msec at maximum, but, after that it is 500 msec max. as the disk is kept inserted.

\subsection*{3.4.5 Index Pulse}


T2

Tl* : \(\quad 197 \mathrm{~ms}\) min., 203 ms max.
T2 : 1.25 ms min., 1.45 ms max.
*When the disk motor rotation is at the stationary state.
3.4.6 Disk Change

\[
\begin{aligned}
& \mathrm{TI}: 0.5 \text { us max. } \mathrm{T} 2: 1.6 \text { us max. } \\
& \text { *DISK IN, the disk-in sensor signal inside the drive, is } \\
& \text { high when a disk is inserted in the drive. }
\end{aligned}
\]
3.5 Power On and Power off Requirements
3.5.1 Data Protection.

Turning power on or off does not cause any damage to recorded data on the disk as the drive is not in the midst of writing when the power is shut off or supplied.
3.5.2 Power Supply Sequencing

No special supply sequencing is required by the disk drive as long as both the 5 V and 12 V power supplies have a monotonic rise time of less than lo0msec. Then the power is turned off, although there are no sequencing or timing requirements, both power supplies must fall monotonically to 0 V .
3.6 Disk motor rotation and Disk Insertion.

Even if the MOTOR ON signal is true (low), the disk motor does not rotate until a disk is inserted.
4. Safety

MP-F63W-00D will meet the following product safety regulations:
U.L. 478
C.S.A. C.22.2, No. 154
U.L. \(94 \mathrm{~V}-0\) for Front Bezel

\section*{5. Power On Initialization}

In order to reduce the peak current requirement when used in a daisy chain, the MP-F63W-72D has been disigned not to seek track 00 automatically. If all the drives connected in the daisy chain sought track 00 simultaneously, this would place a significant power drain on the host system. Thus, the host system must perform the following routine just after power on in order to reset the track counter inside the drive.

\section*{Power On Initialization}




\section*{SOFTWARE}

\section*{Software Contents}
BIOS Services
Device I/O Services ..... 1
Keyboard ..... 3
Video Display ..... 5
Serial Communications ..... 13
Line Printer ..... 16
System Clock ..... 17
Floppy Disk I/O Support ..... 19
Equipment ..... 22
Memory Size ..... 22
EEROM ..... 23
Keyboard ASCII and Scan Codes
Keyboard ASCII and Scan Codes ..... 24
MS-DOS Memory Map
ROM BIOS Data Area ..... 29
Additional Data Area ..... 33

\section*{BIOS Services}

\section*{Device I/O Services}

\section*{Introduction}

The BIOS (Basic Input/Output System) is the lowest-level interface between other software (application programs and the operating system itself) and the hardware. The BIOS routines provide various device input/output services, as well as boot strap and print screen and other services. Some of the services that BIOS provides are not available through the operating system, such as the graphics routines.

All calls to the BIOS are made through software interrupts (that is, by means of assembly language "INT x" instructions). Each I/O device is provided with a software interrupt, which transfers execution to the routine.

Entry parameters to BIOS routines are normally passed in CPU registers. Similarly, exit parameters are generally returned from these routines to the caller in CPU registers. To insure BIOS compatibility with other machines, the register usage and conventions are, for the most part, identical.

The following pages describe the entry and exit requirements for each BIOS rutine. To execute a BIOS call, load the registers as indicated under the "Entry Conditions." (Register AH will contain the function number in cases where a single interrupt can perform more than one operation.) Then issue the interrupt given for the call. The example, the following can be used to read a character from the keyboard:
```

MOV AH, Ø
INT 16H

```

Upon return, AL contains the ASCII character and AH the keyboard scan code.

Note: All registers except those used to return parameters to the caller are saved and restored by the BIOS routines.

Below is a quick reference list of software interrupts for all device I/O and system status services.

Service
Keyboard
Video Display
Serial Communications
Line Printer
System Clock
Floppy Disk
Equipment
Memory Size

Software Interrupts
16 hex ( 22 dec )
10 hex ( 16 dec )
14 hex ( 20 dec )
17 hex ( 23 dec )
1A hex ( 26 dec )
13 hex ( 19 dec )
11 hex ( 17 dec )
12 hex ( 18 dec )

\section*{Keyboard}

16 hex ( 22 dec )

\section*{Function Summary:}
\(\mathrm{AH}=0\) : Read Keyboard (destructive with wait)
\(\mathrm{AH}=1:\) Scan Keyboard (nondestructive, no wait)
AH \(=2\) : Get Current Shift Status

\section*{Function Descriptions: \\ Read Keyboard}

Read the next character typed at the keyboard. Return the ASCII value of the character and the keyboard scan code, removing the entry from the keyboard buffer (destructive read).

\section*{Entry Conditions:}
\(\mathrm{AH}=0\)

\section*{Exit Conditions:}
\(\mathrm{AL}=\) ASCII value of character
AH \(=\) keyboard scan code

\section*{Scan Keyboard}

Set up the zero flag (Z flag) to indicate whether a character is available to be read from the keyboard or not. If a character is available, return the ASCII value of the character and the keyboard scan code. The entry remains in the keyboard buffer (nondestructive read).

\section*{Entry Conditions:}
\(\mathrm{AH}=1\)

\section*{Exit Conditions:}
\(\mathrm{Z}=\) no character is available
\(\mathrm{NZ}=\) a character is available, in which case:
\(\mathrm{AL}=\) ASCII value of character
\(\mathrm{AH}=\) keyboard scan code

\section*{Get Shift Status}

Return the current shift status.

\section*{Entry Conditions:}

AH \(=2\)

\section*{Exit Conditions:}
\(\mathrm{AL}=\) current shift status (bit settings: set \(=\) true, reset \(=\) false)
bit \(\emptyset=\) RIGHT SHIFT key depressed
bit \(1=\) LEFT SHIFT key depressed
bit \(2=\) CTRL (control) key depressed
bit \(3=\) ALT (alternate mode) key depressed
bit \(4=\) SCROLL state active
bit \(5=\) NUMBER lock engaged
bit \(6=\) CAPS lock engaged
bit \(7=\) INSERT state active

\section*{Video Display}

These routines provide an interface to the video display, which is the output half of the console (CON) device. MS-DOS considers the video display to be the default standard output (STDOUT) device.

\section*{Software Interrupts:}

10 hex ( 16 dec )

\section*{Function Summary:}

Control Routines:
\(\mathrm{AH}=\emptyset:\) Set CRT Mode
AH = 1: Set Cursor Type
AH \(=2\) : Set Cursor Position
AH \(=3\) : Get Cursor Position
\(\mathrm{AH}=4\) : Read Light Pen Position
AH \(=5\) : Select Active Page
\(\mathrm{AH}=6:\) Scroll Active Page Up
AH = 7: Scroll Active Page Down

\section*{Text Routines:}
\(\mathrm{AH}=8:\) Read Attribute/Character
AH = 9: Write Attribute/Character
AH = 10: Write Character Only
Graphics Routines:
AH = 11: Set Color Palette
\(\mathrm{AH}=12\) : Write Dot
AH \(=13:\) Read Dot
Other Routines:
AH = 14: Write TTY* to active page
AH \(=15\) : Get CRT Mode
\(\mathrm{AH}=16\) : Set Palette Registers
*Screen width is determined by the mode previously set. Some "control" characters (ASCII \(00 \mathrm{H}-1 \mathrm{FH}\) ) perform the usual special terminal function. These include (but are not limited to) BEL \((07 \mathrm{H}), \mathrm{BS}(08 \mathrm{H}), \mathrm{LF}(0 \mathrm{AH})\), and CR ( 0 DH ).

\section*{Function Descriptions:}

\section*{Set CRT Mode}

\section*{Entry Conditions:}
\(\mathrm{AH}=\emptyset\)
\(\mathrm{AL}=\) mode value, as follows:
Alpha Modes
\(\mathrm{AL}=\emptyset: 40 \times 25\) black and white
AL \(=1: 40 \times 25\) color
\(\mathrm{AL}=2: 80 \times 25\) black and white
AL \(=3: 80 \times 25\) color
Graphics Modes
\(\mathrm{AL}=4: 320 \times 200\) color graphics
\(\mathrm{AL}=5: 320 \times 200\) black and white graphics with 4 shades
\(\mathrm{AL}=6: 640 \times 200\) black and white graphics with 2 shades
\(\mathrm{AL}=7:\) Reserved
Additional Modes
\(\mathrm{AL}=8: 160 \times 200\) color graphics with 16 colors
\(\mathrm{AL}=9: 320 \times 200\) color graphics with 16 colors
\(\mathrm{AH}=\mathrm{A}: 640 \times 200\) color graphics with 4 colors
Note: If the high order bit of the AL register is 1 then the video buffer is not cleared.

\section*{Set Cursor Type}

Set the cursor type and attribute.
Entry Conditions:
\(\mathrm{AH}=1\)
\(\mathrm{CH}=\) bit values:
bits 5-6 = cause an invisible or erratically blinking cursor
bits 5-6 = 00 produces a visible, blinking cursor.
bits 4-0 = start line for cursor within character cell
\(\mathrm{CL}=\) bit values:
bits 4-0 = end line for cursor within character cell

\section*{Set Cursor Position}

Write (set) cursor position.

\section*{Entry Conditions:}
\(\mathrm{AH}=2\)
\(\mathrm{BH}=\) page number (must be 0 for graphics modes)
\(\mathrm{DH}=\operatorname{row}(0=\) top row \()\)
\(\mathrm{DL}=\) column \((0=\) leftmost column \()\)

\section*{Get Cursor Position}

Read (get) cursor position.

\section*{Entry Conditions:}
\(\mathrm{AH}=3\)
\(\mathrm{BH}=\) page number (must be 0 for graphics modes)

\section*{Exit Conditions:}
\(\mathrm{DH}=\) row of current cursor position ( \(0=\) top row)
\(\mathrm{DL}=\) column of current cursor position ( \(0=\) leftmost column)
CX \(=\) cursor type currently set [1]:
See Set Cursor Type ( \(\mathrm{AH}=1\) ) above.

\section*{Read Light Pen Position}

Reads light pen position.

\section*{Entry Conditions:}
\(\mathrm{AH}=4\)

\section*{Exit Conditions:}
\(\mathrm{AH}=0\) : light pen switch not activated
\(\mathrm{AH}=1\) : light pen values in registers
\(\mathrm{DH}=\) row of current light pen position
\(\mathrm{DL}=\) column of current light pen position
CH \(=\) raster line (0-199)
\(\mathrm{BX}=\) pixel column (0-319 or 0-639)

\section*{Select Active Page}

Select active display page (valid in alpha mode only).

\section*{Entry Conditions:}
\(\mathrm{AH}=5\)
AL \(=0\) through 7: new page value for modes 0,1
\(\mathrm{AL}=\emptyset\) through 3: new page value for modes 2,3
\(\mathrm{AL}=80 \mathrm{H}:\) read CRT/CPU page registers
\(\mathrm{AL}=81 \mathrm{H}\) : set CPU page register to value in \(B L\)
\(\mathrm{AL}=82 \mathrm{H}\) : set CRT page register to value in \(B H\)
\(\mathrm{AL}=83 \mathrm{H}\) : set both CRT and CPU page registers in \(B H\) and \(B L\)

\section*{Exit Conditions:}

If bit 7 of \(\mathrm{AL}=1\) upon entry, \(\mathrm{BH}=\) contents of \(C R T\) page register
\[
\mathrm{BL}=\text { contents of CPU page register }
\]

\section*{Scroll Up}

Scroll active page up.

\section*{Entry Conditions:}
\(\mathrm{AH}=6\)
\(\mathrm{AL}=\) numbers of lines to scroll. The number of lines that will be left blank at the bottom of the window. (0 means blank entire window)
\(\mathrm{CH}=\) row of upper left corner of scroll window
CL \(=\) column of upper left corner of scroll window
\(\mathrm{DH}=\) row of lower right corner of scroll window
\(\mathrm{DL}=\) column of lower right corner of scroll window
\(\mathrm{BH}=\) attribute (alpha modes) or color (graphics modes) to be used on blank line

\section*{Attributes:}

Color modes:
foreground color:
bit \(0=\) blue
bit \(1=\) green
bit \(2=\operatorname{red}\)
bit \(3=\) intensity
All bits off = black
background color:
bit \(4=\) blue
bit \(5=\) green
bit \(6=\) red
bit \(7=\) blink
All bits off \(=\) white

\section*{Scroll Down}

Scroll active page down.

\section*{Entry Conditions:}
\(\mathrm{AH}=7\)
\(\mathrm{AL}=\) number of lines to scroll (0 means blank entire window)
\(\mathrm{CH}=\) row of upper left corner of scroll window
\(\mathrm{CL}=\) column of upper left corner of scroll window
\(\mathrm{DH}=\) row of lower right corner of scroll window
\(\mathrm{DL}=\) column of lower right corner of scroll window
\(\mathrm{BH}=\) attribute (alpha modes) or color (graphics modes) to be used on blank line. See Scroll Up \((A H=6)\) for attribute values and Set Color Palette ( \(\mathrm{AH}=11\) ) for color values.

\section*{Read Attribute or Color/Character}

Read a character and its attribute or color at the current cursor position.

\section*{Entry Conditions:}

AH \(=8\)
\(\mathrm{BH}=\) display page number (not used in graphics modes)

\section*{Exit Conditions:}
\(\mathrm{AL}=\) character read
\(\mathrm{AH}=\) attribute of character (alpha modes only)

\section*{Write Attribute or Color/Character}

Write a character and its attribute or color at the current cursor position.

\section*{Entry Conditions:}
\(\mathrm{AH}=9\)
\(\mathrm{BH}=\) display page number (not used in graphics modes)
CX \(=\) number of characters to write
\(\mathrm{AL}=\) character to write
\(\mathrm{BL}=\) attribute of character (for alpha modes) or color of character (for graphics modes; if bit 7 of BL is set, the color of the character is XOR'ed with the color value). See Scroll Up ( \(A H=6\) ) for attribute values and Set Color Palette ( \(A H=\) 11) for color values.

\section*{Write Character Only}

Write character only at current cursor position.

\section*{Entry Conditions:}
\(\mathrm{AH}=10\)
\(\mathrm{BH}=\) display page number (valid for alpha modes only
\(\mathrm{CX}=\) number of characters to write
\(\mathrm{AL}=\) character to write
BL \(=\) color of character (graphics mode)

\section*{Set Color Palette [3]}

Select the color palette.

\section*{Entry Conditions:}
\(\mathrm{AH}=11\)
\(\mathrm{BH}=\emptyset\) Set background color ( \(0-15\) ) to color value in BL. \(\mathrm{BL}=\) color value \((0=\) black \(/ 1=\) blue \(/ 2=\) green \(/ 3=\) cyan \(/ 4=\) red \(/ 5=\) magenta \(/ 6=\) yellow \(/ 7=\) gray \(/ 8\) \(=\) dark gray \(/ 9=\) light blue \(/ 10=\) light green \(/ 11=\) light cyan \(/ 12=\) light red \(/ 13=\) light magenta \(/ 14=\) light yellow \(/ 15=\) white)
\(\mathrm{BH}=1\) Set default palette to the number (0 or 1 ) in BL .

In black and white modes:
\(\mathrm{BL}=0: 1\) for white
\(\mathrm{BL}=1: 1\) for black
In 4 color graphics modes:
\(\mathrm{BL}=\emptyset(1=\) green \(/ 2=\mathrm{red} / 3=\) yellow \()\)
\(\mathrm{BL}=1(1=\) cyan \(/ 2=\) magenta \(/ 3=\) white \()\)
In 16 color graphics modes:
( \(1=\) blue \(/ 2=\) green \(/ 3=\) cyan \(/ 4=\operatorname{red} / 5=\) magenta \(/ 6=\) yellow \(/ 7=\) light gray \(/ 8=\) dark gray \(/ 9=\) light blue / \(10=\) light green / \(11=\) light cyan \(/ 12=\) light red \(/\)
\(13=\) light magenta \(/ 14=\) yellow \(/ 15=\) white)
Note: For alpha modes palette entry \(\emptyset\) indicates the border color. For graphics mode palette entry \(\emptyset\) indicates the border and the background color.

\section*{Write Dot}

Write a pixel (dot).

\section*{Entry Conditions:}
\(\mathrm{AH}=12\)
\(\mathrm{DX}=\) row number
\(\mathrm{CX}=\) column number
\(\mathrm{AL}=\) color value (When bit 7 of AL is set, the resultant color value of the dot is the exclusive OR of the current dot color value and the value in \(A L\).)

\section*{Read Dot}

Read a pixel (dot).

\section*{Entry Conditions:}
\(\mathrm{AH}=13\)
\(\mathrm{DX}=\) row number
\(\mathrm{CX}=\) column number

\section*{Exit Conditions:}
\(\mathrm{AL}=\) color value of dot read

\section*{Write TTY}

Write a character in teletype fashion. (Control characters are interpreted in the normal manner.)

\section*{Entry Conditions:}
\(\mathrm{AH}=14\)
\(\mathrm{AL}=\) character to write
\(\mathrm{BL}=\) foreground color (graphics mode)

\section*{Get CRT Mode}

Get the current video mode.

\section*{Entry Conditions:}
\(\mathrm{AH}=15\)

\section*{Exit Conditions:}
\(\mathrm{AL}=\) current video mode; see Set CRT Mode ( \(\mathrm{AH}=0\) ) above for values
\(\mathrm{AH}=\) number of columns on screen
\(\mathrm{BH}=\) current active display page

\section*{Set Palette Registers}

Sets palette registers.

\section*{Entry Conditions:}
\(\mathrm{AH}=16\)
\(\mathrm{AL}=0\) Set Palette register
\(\mathrm{BL}=\) number of the palette register (0-15) to set
\(\mathrm{BH}=\) color value to store
\(\mathrm{AL}=1\) Set border color register
\(\mathrm{BH}=\) color value to store
\(\mathrm{AL}=2\) Set palette color value to store and border registers ES:DX :points to a 17 byte list. bytes \(0-15=\) values for palette registers 0-15 byte \(16=\) value for the border register
Note: CS,SS,DS,ES,BX,CX,DX are preserved.

\section*{Serial Communications}

These routines provide asynchronous byte stream I/O from and to the RS-232C serial communications port. This device is labeled the auxiliary (AUX) I/O device in the device list maintained by MS-DOS.

\section*{Software Interrupts:}

14 hex ( 20 dec )

\section*{Function Summary:}
\(\mathrm{AH}=0\) : Reset Comm Port
AH = 1: Transmit Character
\(\mathrm{AH}=2\) : Receive Character
\(\mathrm{AH}=3\) : Get Current Comm Status
DX = communication port number ( 0 or 1 ).

\section*{Function Descriptions:}

\section*{Reset Comm Port}

Reset (or initialize) the communication port according to the parameters in AL, DL, and DH.

\section*{Entry Conditions:}
\(\mathrm{AH}=\emptyset\)
\(\mathrm{AL}=R S-232 C\) parameters, as follows:
\(\mathrm{DX}=\) port number (0 or 1)
\begin{tabular}{|c|c|c|c|}
\hline \(\begin{array}{lll}7 & 6 & 5\end{array}\) & 43 & 2 & 10 \\
\hline Baud Rate & Parity & Stop Bits & Word Length \\
\hline \(000=110\) baud & \(\mathrm{x} 0=\) none & \(\emptyset=1 \mathrm{bit}\) & \(10=7 \mathrm{bits}\) \\
\hline \(001=150\) baud & 01 = odd & \(1=2 \mathrm{bits}\) & \(11=8 \mathrm{bits}\) \\
\hline \(010=300 \mathrm{baud}\) & 11 = even & & \\
\hline \(011=600\) baud & & & \\
\hline \(100=1200\) baud & & & \\
\hline \(101=2400\) baud & & & \\
\hline \(110=4800\) baud & & & \\
\hline \(111=9600\) baud & & & \\
\hline
\end{tabular}

\section*{Exit Conditions:}
\(\mathrm{AX}=R S-232\) status; see Get Current Comm Status \((\mathrm{AH}=3)\) following

\section*{Transmit Character}

Transmit (output) the character in AL (which is preserved).

\section*{Entry Conditions:}
\(\mathrm{AH}=1\)
\(\mathrm{AL}=\) character to transmit
DX = port number (0 or 1)

\section*{Exit Conditions:}
\[
\begin{aligned}
\mathrm{AH}= & \text { RS-232 status; see Get Current Comm Status }(\mathrm{AH}=3) \\
& \text { below (If bit } 7 \text { is set, the routine was unable to transmit } \\
& \text { the character because of a timeout error.) }
\end{aligned}
\]

AL is preserved.

\section*{Receive Character}

Receive (input) a character in AL (wait for a character, if necessary). On exit, AH will contain the RS- 232 status, except that only the error bits ( \(1,2,3,4,7\) ) may be set; the timeout bit (7), if set, indicates that data set ready was not received and the bits in AH are not meaningful. Thus, AH is non-zero only when an error occurred.

\section*{Entry Conditions:}
\(\mathrm{AH}=2\)
\(\mathrm{DX}=\) port number (0 or 1)

\section*{Exit Conditions:}
\(\mathrm{AL}=\) character received
\(\mathrm{AH}=\) RS-232 status; see Get Current Comm Status \((A H=3)\) below

\section*{Get Current Comm Status}

Read the communication status into AX.

\section*{Entry Conditions:}

AH \(=3\)
\(\mathrm{DX}=\) port number (0 or 1)

\section*{Exit Conditions:}
\(\mathrm{AH}=\) RS-232 status, as follows (set \(=\) true \()\) :
bit \(\emptyset=\) data ready
bit \(1=\) overrun error
bit \(2=\) parity error
bit \(3=\) framing error
bit \(4=\) break detect
bit \(5=\) transmitter holding register empty
bit \(6=\) transmitter shift register empty
bit \(7=\) timeout occurred
\(\mathrm{AL}=\) modem status, as follows (set \(=\) true \():\)
bit \(0=\) delta clear to send
bit \(1=\) delta data set ready
bit \(2=\) trailing edge ring detector
bit \(3=\) delta receive line signal detect
bit \(4=\) clear to send
bit \(5=\) data set ready
bit \(6=\) ring indicator
bit \(7=\) receive line signal detect

\section*{Line Printer}

These routines provide an interface to the parallel line printer. This device is labeled "PRN" in the device list maintained by the operating system.

\section*{Software Interrupts:}

17 hex ( 23 dec)

\section*{Function Summary:}

AH \(=0\) : Print Character
AH = 1: Reset Printer Port
AH \(=2\) : Get Current Printer Status

\section*{Function Descriptions: \\ Print Character}

Print a character.

\section*{Entry Conditions:}
\(\mathrm{AH}=\emptyset\)
\(\mathrm{AL}=\) character to print
\(\mathrm{DX}=\) printer to be used (0-2)

\section*{Exit Conditions:}

0AH \(=\) printer status; see Get Current Printer Status ( \(\mathrm{AH}=2\) ) below
(If bit 0 is set, the character could not be printed because of a timeout error.)

\section*{Reset Printer Port}

Reset (or initialize) the printer port.

\section*{Entry Conditions:}
\(\mathrm{AH}=1\)
\(\mathrm{DX}=\) printer to be used (0-2)

\section*{Exit Conditions:}

AH \(=\) printer status; see Get Current Printer Status ( \(\mathrm{AH}=2\) ) below

\section*{Get Current Printer Status}

Read the printer status into AH.

\section*{Entry Conditions:}
\(\mathrm{AH}=2\)

\section*{Exit Conditions:}
\(\mathrm{DX}=\) printer to be used (0-2)
\(\mathrm{AH}=\) printer status, as follows (set \(=\) true):
bit \(\emptyset=\) timeout occurred
bit \(1=\) [unused]
bit \(2=\) [unused]
bit \(3=\mathrm{I} / \mathrm{O}\) error
bit \(4=\) selected
bit \(5=\) out of paper
bit \(6=\) acknowledge
bit \(7=\) not busy

\section*{System Clock}

These routines provide methods of reading and setting the clock maintained by the system. This device is labeled CLOCK in the device list of the operating system. An interface for setting the multiplexer for audio source is also provided.

\section*{Software Interrupts:}

1A hex (26 dec)

\section*{Function Summary:}
\(\mathrm{AH}=\emptyset: \quad\) Get Time of Day
AH \(=1\) : \(\quad\) Set Time Of Day
\(\mathrm{AH}=80 \mathrm{H}:\) Set Up Sound Multiplexer
The clock runs at the rate of \(1,193,180 / 65,536\) per second (about 18.2 times per second).

\section*{Function Descriptions: \\ Get Time Of Day}

Get (read) the time of day in binary format.

\section*{Entry Conditions:}
\(\mathrm{AH}=0\)

\section*{Exit Conditions:}

CX \(=\) high (most significant) portion of clock count
\(\mathrm{DX}=\) low (least significant) portion of clock count
\(\mathrm{AL}=\emptyset\) of the clock was read or written (via \(\mathrm{AH}=0,1\) ) within the current 24-hour period; othrwise, \(\mathrm{AL}>0\)

\section*{Set Time Of Day}

Set (write) the time of day using binary format.

\section*{Entry Conditions:}
\(\mathrm{AH}=1\)
CX \(=\) high (most significant) portion of clock count
DX \(=\) low (least significant) portion of clock count

\section*{Sound Multiplexer}

Sets the multiplexer for audio source.

\section*{Entry Conditions:}
```

AH = 80
AL = source of sound
00=8253 channel 2
02 = audio in
03 = complex sound generator chip

```

\section*{Disk I/O Support for the Floppy Only System Configuration}

\section*{Software Interrupt:}

13 hex (19 dec)

\section*{Function Summary:}

AH \(=0\) : Reset Floppy Disk
AH \(=1\) : Return Status of Last Floppy Disk Operation
\(\mathrm{AH}=2:\) Read Sector(s) from Floppy Disk
\(\mathrm{AH}=3\) : Write Sector(s) to Floppy Disk
\(\mathrm{AH}=4\) : Verify Sector(s) on Floppy Disk
AH \(=5\) : Format Track on Floppy Disk

\section*{Function Descriptions:}

Reset Floppy Disk
Reset the diskette system. Resets associated hardware and recalibrates all diskette drives.

\section*{Entry Conditions:}
\(\mathrm{AH}=\emptyset\)

\section*{Exit Conditions:}

See "Exits From All Calls" below.

\section*{Return Status of Last Floppy Disk Operation}

Return the diskette status of the last operation in AH.

\section*{Entry Conditions}

AH = 1

\section*{Exit Conditions:}
\(\mathrm{AL}=\begin{aligned} & \text { status of the last operation; see "Exits From All Calls" } \\ & \text { below for values }\end{aligned}\)
Read Sector(s) from Floppy Disk
Read the desired sector(s) from disk into RAM.

\section*{Entry Conditions:}
\(\mathrm{AH}=2\)
\(\mathrm{DL}=\) drive number (0-1)
\(\mathrm{DH}=\) head number (0-1)
\(\mathrm{CH}=\) track number (0-79)
\(\mathrm{CL}=\) sector number (1 to 9)
\(\mathrm{AL}=\) sector count (1 to 9)
ES:BX = pointer to disk buffer

\section*{Exit Conditions:}

See "Exits From All Calls" below.
\(\mathrm{AL}=\) number of sectors read

\section*{Write Sector(s) to Floppy Disk}

Write the desired sector(s) from RAM to disk.

\section*{Entry Conditions:}
\(\mathrm{AH}=3\)
\(\mathrm{DL}=\) drive number (0-1)
\(\mathrm{DH}=\) head number (0-1)
\(\mathrm{CH}=\) track number (0-79)
\(\mathrm{CL}=\) sector number (1 to 9)
\(\mathrm{AL}=\) sector count ( 1 to 9 )
\(\mathrm{ES}: \mathrm{BX}=\) pointer to disk buffer

\section*{Exit Conditions:}

See "Exits From All Calls" below.
\(\mathrm{AL}=\) number of sectors written

\section*{Verify Sector(s) on Floppy Disk}

Verify the desired sector(s).

\section*{Entry Conditions:}
\(\mathrm{AH}=4\)
\(\mathrm{DL}=\) drive number (0-1)
\(\mathrm{DH}=\) head number (0-1)
\(\mathrm{CH}=\) track number (0-79)
CL \(=\) sector number (1 to 9)
\(\mathrm{AL}=\) sector count (1 to 9)

\section*{Exit Conditions:}

See "Exits From All Calls" below.
\(\mathrm{AL}=\) number of sectors verified

\section*{Format on Floppy Disk}

Format the desired track.

\section*{Entry Conditions:}
\(\mathrm{AH}=5\)
\(\mathrm{DL}=\) drive number (0-1)
\(\mathrm{DH}=\) head number (0-1)
\(\mathrm{CH}=\) track number (0-79)
CL \(=\) sector number (1-9)
\(\mathrm{ES}: \mathrm{BX}=\) pointer to a group of address fields for each track. Each address field is made up of 4 bytes. These are C,H,R, and N , where:
\(\mathrm{C}=\) track number
\(\mathrm{H}=\) head number
\(\mathrm{R}=\) sector number
\(\mathrm{N}=\) the number of bytes per sector \((00=128,01=\) \(256,02=512,03=1024\) )
There is one entry for every sector on a given track.

\section*{Exit Conditions:}

See "Exits From All Calls" below.

\section*{Exits From All Calls:}
\(\mathrm{AH}=\) Status of operation, where set \(=\) true:

\section*{Error Code Condition}

01H Illegal Function
02H Address Mark Not Found
03H Write Protect Error
04H Sector Not Found
08H DMA Overrun
09H Attempt To DMA Across A 64K Boundary
10H Bad CRC on Disk Read
\(20 \mathrm{H} \quad\) Controller Failure
40H Seek Failure
80H Device Timeout, Device Failed To Respond
\([\mathrm{NC}]=\) operation successful \((\mathrm{AH}=0)\)
\([\mathrm{C}]=\) operation failed \((\mathrm{AH}=\) error status \()\)

\section*{Equipment}

This service returns the "equipment flag" (hardware configuration of the computer system) in the AX register.

\section*{Software Interrupts:}

11 hex ( 17 dec )
The "equipment flag" returned in the AX register has the meanings listed below for each bit:
Reset \(=\) the indicated equipment is not in the system
Set \(=\) the indicated equipment is in the system
bit 0 diskette installed
bit 1 math coprocessor
bit \(2,3 \quad\) always \(=11\)
bit 4,5 initial video mode
\(01=40 \times 25\) BW
\(10=80 \times 25\) BW
bit 6,7 number of diskette drives (only if bit 0=1)
\(00=1\)
\(01=2\)
bit \(8 \quad 0=\) dma present
\(1=\) no dma on system
bit \(9,10,11\) number of RS 232 cards
bit 12 game I/O attached
bit 13 not used
bit 14,15 number of printers

\section*{Memory Size}

This service returns the total number of kilobytes of RAM in the computer system (contiguous starting from address \(\emptyset\) ) in the AX register. The maximum value returned is 640 .

\section*{Software Interrupts:}

12 hex ( 18 dec )

\section*{EEROM (Tandy 1000 HX only)}

15 hex ( 21 dec )

\section*{Function Summary}
\(\mathrm{AH}=70 \mathrm{H}, \mathrm{AL}=\emptyset:\) Read a 16 bit word from EEROM
\(\mathrm{AH}=70 \mathrm{H}, \mathrm{AL}=1\) : Write a 16 bit word to EEROM

\section*{Function Descriptions Read From EEROM}

Read the 16 bit value from the indicated EEROM word.

\section*{Entry Conditions:}
\(\mathrm{AH}=70 \mathrm{H}\)
\(\mathrm{AL}=0\)
\(\mathrm{BL}=\) word number to read (0-15)

\section*{Exit Conditions:}

DX = word value
Carry Flag set indicates EEROM call not supported, system is not a 1000 HX

\section*{Write To EEROME}

Write a 16 bit value to the indicated EEROM word
Entry Conditions:
\(\mathrm{AH}=70 \mathrm{H}\)
\(\mathrm{AL}=1\)
\(\mathrm{BL}=\) word number to write (0-15)
DX = word value to write

\section*{Exit Conditions:}

Carry Flag set indicates EEROM call not supported, system is not a 1000 HX

\section*{KEYBOARD ASCII AND SCAN CODES}

The table in this appendix lists the keys on the Tandy 1000 keyboard in scan code order, along with the ASCII codes they generate. For each key, the following entries are given:

Scan Code - A value in the range 01H-5AH which uniquely identifies the physical key on the keyboard that is pressed.

Keyboard Legend - The physical marking(s) on the key. If there is more than one marking, the upper one is listed first.

ASCII Code - The ASCII codes associated with the key. The four modes are:

Normal - The normal ASCII value (returned when only the indicated key is depressed).
SHIFT - The shifted ASCII value (returned when SHIFT is also depressed).

CTRL - The control ASCII value (returned when CTRL is also depressed).

ALT - The alternate ASCII value (returned when ALT is also depressed).

Remarks - Any remarks or special functions.
The following special symbols appear in the table:
- Values preceded by "x" are extended ASCII codes (codes preceded by an ASCII NUL, 00).
- No ASCII code is generated.
* No ASCII code is generated, but the special function described in the Remarks column is performed. If no comment is included, the key does not generate a code and no function is performed.

Note: All numeric values in the table are expressed in hexadecimal.

\section*{QWERTY (USA) - MODEL 1000}

\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{3}{*}{\begin{tabular}{l}
Scan \\
Code
\end{tabular}} & \multirow[b]{3}{*}{Keyboard Legend} & \multirow[b]{3}{*}{Normal} & \multicolumn{2}{|l|}{ASCII Code} & \multirow[b]{3}{*}{ALT} & \multirow[t]{3}{*}{\begin{tabular}{l}
As of Oct. 221984 \\
Remarks
\end{tabular}} \\
\hline & & & SHIFT & CTRL & & \\
\hline & & & & & & \\
\hline 30 & B & 62 & 42 & 02 & \(\times 30\) & \\
\hline 31 & N & 6 E & 4E & 0E & x31 & \\
\hline 32 & M & 6 D & 4D & OD & \(\times 32\) & \\
\hline 33 & \(<\) & 2 C & 3C & xF9 & x89 & \\
\hline 34 & > & 2 E & 3E & xFA & X8A & \\
\hline 35 & 1 ? & 2 F & 3F & xFB & xF2 & \\
\hline 36 & SHIFT & * & * & * & * & Right SHIFT \\
\hline 37 & PRINT & 10 & * & x72 & x46 & SCR Print Toggle \\
\hline 38 & ALT & * & * & * & * & Alternate Mode \\
\hline 39 & space bar & 20 & 20 & 20 & 20 & \\
\hline 3A & CAPS & * & * & * & * & Caps lock \\
\hline 3B & F1 & x3B & \(\times 54\) & x5E & x68 & \\
\hline 3C & F2 & x3C & \(\times 55\) & x5F & \(\times 69\) & \\
\hline 3D & F3 & x3D & \(\times 56\) & \(\times 60\) & x6A & \\
\hline 3E & F4 & x3E & \(\times 57\) & \(\times 61\) & x6B & \\
\hline 3F & F5 & x3F & \(\times 58\) & \(\times 62\) & \(\times 6 \mathrm{C}\) & \\
\hline 40 & F6 & \(\times 40\) & \(\times 59\) & \(\times 63\) & \(\times 6 \mathrm{D}\) & \\
\hline 41 & F7 & x 41 & x5A & \(\times 64\) & \(\times 6 \mathrm{E}\) & \\
\hline 42 & F8 & x 42 & x5B & \(\times 65\) & x 6 F & \\
\hline 43 & F9 & x43 & \(\times 5 \mathrm{C}\) & \(\times 66\) & \(\times 70\) & \\
\hline 44 & F10 & x44 & \(\times 50\) & \(\times 67\) & \(\times 71\) & \\
\hline 45 & NUM LOCK & * & * & * & * & number lock \\
\hline 46 & HOLD & * & * & * & * & Freeze display \\
\hline 47 & 7 \} & 37 & 5 C & \(\times 93\) & * & \\
\hline 48 & 8 & 38 & 7E & \(\times 94\) & * & \\
\hline 49 & 9 PG UP & 39 & x49 & \(\times 84\) & * & \\
\hline 4A & DOWN ARROW & \(\times 50\) & x86 & \(\times 96\) & \(\times 97\) & \\
\hline 4B & 4 | & 34 & 7 C & \(\times 95\) & * & \\
\hline 4C & 5 & 35 & xF3 & xFC & * & \\
\hline 4D & 6 & 36 & xF4 & xFD & * & \\
\hline 4E & RIGHT ARROW & x 4 D & \(\times 88\) & x74 & xEA & \\
\hline 4 F & 1 END & 31 & \(\times 4 \mathrm{~F}\) & \(\times 75\) & * & \\
\hline 50 & 2 & 32 & 60 & x9A & * & \\
\hline 51 & 3 PG DN & 33 & \(\times 51\) & x76 & * & \\
\hline 52 & 0 & 30 & x9B & x9C & * & \\
\hline 53 & DELETE & 2D & \(\times 53\) & x9D & x9E & \\
\hline 54 & BREAK & \(\times 0 \square\) & \(\times 00\) & * & * & scroll lock bit toggle control brk routine (INT 1BH) \\
\hline 55 & + INSERT & 2B & x52 & x9F & xA0 & \\
\hline 56 & & 2 E & xA1 & xA4 & xA5 & Numeric keypad \\
\hline 57 & ENTER & 0D & 0D & 0 A & x8F & Numeric keypad \\
\hline 58 & HOME & \(\times 47\) & x4A & \(\times 77\) & xA6 & \\
\hline 59 & F11 & \(\times 98\) & xA2 & xAC & xB6 & \\
\hline 5A & F12 & \(\times 99\) & xA3 & xAD & xB7 & \\
\hline
\end{tabular}
* Indicates special functions performed
- means this key combination is suppressed in the keyboard driver

X values preceded by "X" are extended ASCII codes (codes preceded by an ASCII NUL)
\(\dagger\) The ALT key provides a way to generate the ASCII codes of decimal numbers between 1 and 255. Hold down the ALT key while you type on the numeric keypad any decimal number between 1 and 255 . When you release ALT, the ASCII code of the number typed is generated and displayed.

Note: When the NUM LOCK light is off, the Normal and SHIFT columns for these keys should be reversed.

\section*{MS-DOS Memory Map}

HEXADECIMAL
STARTING ADDRESS
(SEGMENT:OFFSET)
000:00
000:80
0040:001
0050:00
0070:00
\(0190.00^{2}\)
05B0:00 \({ }^{2}\)
X800:00 \({ }^{3}\)
XC00:00 \({ }^{3}\)
B800:00 \({ }^{4}\)
F000:00
FC00:00

\section*{DESCRIPTION}

\author{
BIOS Interrupt Vectors
}

Available Interrupt Vectors
ROM BIOS Data Area
MSDOS and BASIC Data Area
I/O.SYS Drivers
MS-DOS
Available to user
Video RAM in 32 K video modes
Video RAM in 16 K video modes
Video RAM Window (32K)
Reserved for system ROM
System BIOS ROM

\section*{Notes:}
1. Detailed description in following pages.
2. Approximate address; subject to change.
3. "X" is defined as follows:

\section*{Memory Size}

128K
256K
384K
512K
640K
768K

X Value
1
3
5

B
4. Video memory accessed through the B800:0 window for all video modes.

\section*{ROM BIOS Data Area}

The following table gives the starting offset, and length of each BIOS device driver. This area is located at segment 40:00.
\begin{tabular}{lll} 
Comm card addresses & 0000 & 8 (1 word per card) \\
Printer addresses & 0008 & 8 (1 word per printer) \\
Devices installed & 0010 & 2 (16 bits) \\
Not used & 0012 & 1 \\
Memory size & 0013 & 2 (1 word) \\
I/O channel RAM size & 0015 & 2 (1 word) \\
KBD data area & 0017 & 39 \\
Disk data area & 003 E & 11 \\
Video data area & 0049 & 30 \\
Not used & 0067 & 5 \\
Clock data area & 006 C & 5 \\
KBD Break \& Reset flags 0071 & 3 \\
Not used & 0074 & 4 \\
Printer Timeout counter & 0078 & 4 (1 byte per printer) \\
Comm Timeout counter & 007 C & 4 (1 byte per card) \\
KBD extra data area & 0080 & 4 (2 words)
\end{tabular}

The structure and usage of the Video driver RAM data area is as follows:

HEX Offset From
Segment 0040:000
49H
4 AH
4 CH
4EH
50H

60H

62H
63H
65H
66 H

\section*{Length and Intended Use}

1 byte - current CRT mode (0-7)
1 word - screen column width
1 word - byte length of screen
1 word - address/offset of beginning of current display page
8 words - row/col coordinates of the cursor for each of up to 8 display pages
1 word - current cursor type (See "set cursor type" for correct encoding)
1 byte - current display page
1 word - base address +4 of the CRT controller card
1 byte - copy of value written to the Mode Select Register
1 byte - current color palette setting

The equipment check BIOS call (INT 11H) and memory size BIOS call (INT 12H) return information from the following data areas:

\section*{HEX Offset From \\ Segment 0040:000}
\(10 \mathrm{H} \quad\) Devices installed word
13H

\section*{Length and Intended Use} Memory installed word

The structure and usage of the floppy disk driver RAM data area is as follows:

\section*{HEX Offset From \\ Segment 0040:0000}

1 byte - drive recalibration status -
bit \(3-\emptyset\), if \(\emptyset\) then drive \(3-\emptyset\) needs recal before next seek bit 7 indicates interrupt occurrence
1 byte - motor status - bit 3-0 drive 3 - 0 motor is on/off, bit 7 current operation is write, requires delay
40 H
41H
42H
7 bytes - 7 bytes of status returned by the controller during result phase of operation

\section*{Error Condition}

Illegal Function
Address Mark Not Found
Write Protect Error
Sector Not Found
DMA Overrun
Attempt to DMA Across a 64K Boundary Bad CRC on Disk Read
Controller Failure
Seek Failure
Device Timeout, Device Failed to Respond

The structure and usage of the RS232 driver RAM data area is as follows:

HEX Offset From
Segment 0040:00
00H
7 CH

Length and Intended Use

4 words - Base address of each one of 4 possible comm cards
4 words - 1 word timeout count for each of 4 possible comm cards

The structure and usage of the Keyboard driver RAM data area is as follows:

HEX Offset From
Segment 0040:0010
\begin{tabular}{|c|c|c|}
\hline 17 & 1 byte
bits 7 & \begin{tabular}{l}
Keyboard shift state flag returned by function 02 \\
-INSERT state active, \\
6 - CAPS LOCK on/off, \\
5 - NUM LOCK on/off, \\
4 - SCROLL LOCK on/off, \\
3 - ALT key depressed, \\
2 - CTRL key depressed, \\
1 - Left SHIFT key depressed, \\
0 - Right SHIFT key depressed
\end{tabular} \\
\hline 18 & 1 byte bits & \begin{tabular}{l}
-Secondary shift state flag INSERT key depressed, \\
6 - CAPS LOCK depressed, \\
5 - NUM LOCK depressed, \\
4 - SCROLL LOCK NUM LOCK depressed, \\
4 - SCROLL depressed, \\
4 - SCROLL LOCK depressed, \\
3 - Pause on/off, depressed, \\
3 - Pause on/off, \\
\(2,1, \emptyset\) - not used
\end{tabular} \\
\hline 19 & 1 byte & - used to store ALT keypad entry \\
\hline 1A & 1 word & - pointer to beginning of the keyboard buffer \\
\hline 1 C & 1 word & - pointer to end of the keyboard buffer \\
\hline 1E & 16 & - keyboard buffer (enough for words) \\
\hline & 15 & -typeahead entries \\
\hline
\end{tabular}

The structure and usage of the clock service routine is as follows:

\section*{HEX Offset From Segment 0040:0000}

\section*{Length and Intended Use}
\(6 \mathrm{CH} \quad 1\) word - Least significant 16 bits of clock count
6EH 1 word -Most significant 16 bits of clock count
\(70 \mathrm{H} \quad 1\) byte -Twenty four hour rollover flag

\section*{ADDITIONAL DATA AREA}

\section*{HEX Offset From}

\section*{Segment 0040:000}
\begin{tabular}{|c|c|c|}
\hline B ØH & \multicolumn{2}{|l|}{2 words international support} \\
\hline \multirow[t]{2}{*}{B4H} & \multirow[t]{2}{*}{1 byte} & \(\theta=\) No monochrome monitor \\
\hline & & FFH = monochrome monitor \\
\hline \multirow[t]{11}{*}{B5H} & \multirow[t]{11}{*}{1 byte} & Bit \(0: 0=\) drive A is \(5-1 / 4\) \\
\hline & & \(1=\) drive \(A\) is \(3-1 / 2\) \\
\hline & & Bit 1: \(0=\) drive B is \(5-1 / 4\) \\
\hline & & \(1=\) drive B is \(3-1 / 2\) \\
\hline & & Bit 2: \(0=\) Tandy 1000 keyboard layout \\
\hline & & \(1=\) IBM keyboard layout \\
\hline & & Bit 3: \(0=\) Slow CPU speed mode \(1=\) Fast CPU speed mode \\
\hline & & Bit 4: \(\emptyset=\) Internal color video support enabled \\
\hline & & \(1=\) Internal color video support disabled, external color video enabled \\
\hline & & Bit 5: \(\emptyset=\) No external monochrome video installed \\
\hline & & \[
\begin{aligned}
& 1=\text { External monochrome } \\
& \text { video installed }
\end{aligned}
\] \\
\hline \multirow[t]{2}{*}{B6H} & 1 byte & Bit 0: \(0=\) drive C is \(5-1 / 4\) \\
\hline & & \(1=\) drive C is \(3-1 / 2\) \\
\hline
\end{tabular}

\section*{RADIO SHACK}

A Division of Tandy Corpo ration Fort Worth, Texas 76102```


[^0]:    - NT (Nested Task bit of flag word) :-
    **NT (Nested Task bit of flag word) $=1$

[^1]:    Shaded areas indicate instructions not available in 8086, 88 microsystems.

[^2]:    *The CMOS parts will be available after 6/85

[^3]:    

[^4]:    Motorola reserves the right to make changes to any products herein to improve reliability. function or design Motorola does not assume any liability arising out of the application or use of any product or circuit described herein, neither does it convey any license under its patent rights nor the rights of other ts

