## STANDARD <br> MICROSYSTEMS <br> CORPORATION

# DALA CAIALOG 1982/83 

INDEX
PART NUMBER ..... 3
FUNCTIONAL
DATA COMMUNICATION PRODUCTS $\ldots .$.




| part number | Page | part number | PAGE |
| :---: | :---: | :---: | :---: |
| CCC 3500 | 339 | COM 8502 | 141 |
| CG 4103 | 357 | CRT 5027 | 197 |
| COM 1553A | 27 | CRT 5037 | 197 |
| COM 1671 | 43 | CRT 5047 | 205 |
| COM 1863 | 59 | CRT 5057 | 197 |
| COM 2017 | 67 | CRT 7004 | 255 |
| COM 2017H | 67 | CRT 8002 | 235 |
| COM 2449 | 75 | CRT 8002H | 247 |
| COM 2502 | 67 | CRT 8021 | 273 |
| COM 2502H | 67 | CRT 9006 | 261 |
| COM 2601 | 91 | CRT 9007 | 207 |
| COM 2651 | 99 | CRT 9021 | 281 |
| COM 2661 | 111 | CRT 9212 | 267 |
| COM 5016 | 167 | CRT 96364 | 227 |
| COM 5016T | 167 | FDC 1761 | 295 |
| COM 5025 | 123 | FDC 1763 | 295 |
| COM 5026 | 169 | FDC 1765 | 295 |
| COM 5026T | 169 | FDC 1767 | 295 |
| COM 5036 | 171 | FDC 1791 | 311 |
| СОМ 5036T | 171 | FDC 1792 | 311 |
| COM 5046 | 173 | FDC 1793 | 311 |
| COM 5046T | 173 | FDC 1794 | 311 |
| COM 8004 | 135 | FDC 1795 | 311 |
| COM 8017 | 141 | FDC 1797 | 311 |
| COM 8046 | 179 | FDC 3400 | 339 |
| COM 8116 | 181 | FDC 9216/B | 327 |
| COM 8116 T | 181 | KR 2376 | 371 |
| COM 8126 | 183 | KR 3600 | 375 |
| COM 8126 T | 183 | MPU 3870 | 383 |
| COM 8136 | 185 | ROM 4732 | 347 |
| Сом 8136 T | 185 | ROM 36000 | 351 |
| COM 8146 | 187 | SR 5015 | 361 |
| COM 8146T | 187 | SR 5017 | 365 |
| COM 8251A | 149 | SR 5018 | 365 |

## FUNCTIONAL INDEX

## Data Communication Products

| Part Number | Name | Description |  | Power Supplies | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| COM 1563A | $\begin{aligned} & \text { MII-STD- } \\ & \text { 1553A UART } \end{aligned}$ | MIL-STD-1553 (Manchester) Interface Controller | 1 MB | +5 | 40 DIP | 27-42 |
| COM 1671 | AsTRO | Asynchronous/Synchronous Transmitter/Receiver, Full Duplex, 5-8 data bit, 1X or 32X clock | 1 MB | +5, -5, +12 | 40 DIP | 43-58 |
| COM 1863 | UART | Universal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, $1,1^{1 / 2}, 2$ stop bit, enhanced distortion margin | 62.5 KB | +5 | 40 DIP | 59-66 |
| COM 2017 | UART | Universal Asynchronous Receiver Transmitter, Full Duplex, 5-8 data bit, 1, $11 / 2$, 2 stop bit | 25 KB | +5, -12 | 40 DIP | 67-74 |
| COM 2017H | UART | Universal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, 1, $1^{1 / 2}, 2$ stop bit | 40 KB | +5, -12 | 40 DIP | 67-74 |
| COM 2449 | RS449-USART | RS 449 Compatible Universal Synchronous/Asynchronous Receiver/Transmitter | 1 MB | +5 | 40 DIP | 75-90 |
| COM 2502 | UART | Universal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, 1, 2 stop bit | 25 KB | +5, -12 | 40 DIP | 67-74 |
| COM 2502H | UART | Universal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, 1, 2 stop bit | 40 KB | +5, -12 | 40 DIP | 67-74 |
| COM 2601 | USRT | Universal Synchronous Receiver/ Transmitter, STR, BSC, Bi-sync compatible | 250 KB | +5, -12 | 40 DIP | 91-98 |
| COM 2651 | USART/PCI | Universal Synchronous/Asynchronous Receiver/Transmitter, Full Duplex, 5-8 data bits; 1, $1^{112}$, 2 stop bit, 1X, 16X, 64X clock | 1 MB | +5 | 28 DIP | 99-110 |
| COM 2661 | USART/EPCI | Universal Synchronous/Asynchronous Receiver/Transmitter, Full Duplex, 5-8 data bits; 1, $1^{112}$, 2 stop bit, 1X, 16X, 64X clock | 1 MB | +5 | 28 DIP | 111-122 |
| COM 5025 | Multi-Protocol USYNRT | SDLC, HDLC, ADCCP, Bi-sync, DDCMP compatible, automatic bit stuffing/ stripping, frame detection/generation, CRC generation/checking, sync detection | 1.5 MB | +5, +12 | 40 DIP | 123-134 |
| COM 8004 | 32 Bit CRC Generator/ Checker | Companion device to COM 5025 for 32 bit CRC | 2.0 MB | +5 | 20 DIP | 135-140 |
| COM 8017 | UART | Universal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, 1, $1^{1 / 2,2}$ stop bit | 40 KB | +5 | 40 DIP | 141-148 |
| COM 8018 | UART | Universal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, 1, $11 / 2,2$ stop bit, enhanced distortion margin | 62.5 KB | +5 | 40 DIP | 59-66 |
| COM 8251A | USART | Universal Synchronous/Asynchronous Receiver/Transmitter, Full Duplex, 5-8 data bit, 1, $1^{1 / 2}, 2$ stop bit | $\begin{aligned} & 64 \mathrm{~KB} \text { (sync) } \\ & 9.6 \mathrm{~KB} \text { (async) } \end{aligned}$ | +5 | 28 DIP | 149-164 |
| COM 8502 | UART | Universal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, 1, 2 stop bit | 40 KB | +5 | 40 DIP | 141-148 |

All Baud Rate Generators are programmable dividers capable of providing 16 output frequencies* for UARTs or USARTS from either an on-chip crystal oscillator or an external frequency input. " $T$ " versions utilize an external frequency input only. Dual Baud Rate Generators provide two out-
put frequencies simultaneously for full duplex communications.
Baud Rate Generators providing all standard baud rates from various popular crystal frequencies are available. In addition the baud rate generator may be custom mask programmed for other divisors.
*except as noted

| Part Number | Description | Features | Power Supplies | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| COM 5016 | Dual Baud Rate Generator | On-chip oscillator or external frequency input | +5, +12 | 18 DIP | 167-168 |
| COM 5016T ${ }^{(3)}$ | Dual Baud Rate Generator | External frequency input | +5, +12 | 18 DIP | 167-168 |
| COM 5026 | Single Baud Rate Generator | On-chip oscillator or external frequency input | $+5,+12$ | 14 DIP | 169-170 |
| COM 5026T ${ }^{(3)}$ | Single Baud Rate Generator | External frequency input | +5, +12 | 14 DIP | 169-170 |
| COM 5036 | Dual Baud Rate Generator | COM 5016 with additional output of input frequency $\div 4$ | +5, +12 | 18 DIP | 171-172 |
| COM 5036T ${ }^{(3)}$ | Dual Baud Rate Generator | COM 5016 T with additional output of input frequency $\div 4$ | +5, +12 | 18 DIP | 171-172 |
| COM 5046 | Single Baud Rate Generator | COM 5026 with additional output of input frequency $\div 4$ | +5, +12 | 14 DIP | 173-174 |
| COM 5046T ${ }^{(3)}$ | Single Baud Rate Generator | COM 5026T with additional output of input frequency $\div 4$ | +5, +12 | 14 DIP | 173-174 |
| COM 8046 | Single Baud Rate Generator | 32 baud rates; 1X, 16X, 32X clock outputs; single +5 volt supply | +5 | 16 DIP | 179-180 |
| COM 8046T ${ }^{(3)}$ | Single Baud Rate Generator | COM 8046 with external frequency input only | +5 | 16 DIP | 179-180 |
| COM 8116 | Dual Baud Rate Generator | Single +5 volt version of COM 5016 | +5 | 18 DIP | 181-182 |
| COM 8116T ${ }^{(3)}$ | Dual Baud Rate Generator | Single +5 volt version of COM 5016T | +5 | 18 DIP | 181-182 |
| COM 8126 | Single Baud Rate Generator | Single +5 volt version of COM 5026 | +5 | 14 DIP | 183-184 |
| COM 8126T ${ }^{(3)}$ | Single Baud Rate Generator | Single +5 volt version of COM 5026T | +5 | 14 DIP | 183-184 |
| COM 8136 | Dual Baud Rate Generator | Single +5 volt version of COM 5036 | +5 | 18 DIP. | 185-186 |
| COM 8136T ${ }^{(3)}$ | Dual Baud Rate Generator | Single +5 volt version of COM 5036T | +5 | 18 DIP | 185-186 |
| COM 8146 | Single Baud Rate Generator | Single +5 volt version of COM 5046 | +5 | 14 DIP | 187-188 |
| COM 8146T ${ }^{(3)}$ | Single Baud Rate Generator | Single +5 volt version of COM 5046T | +5 | 14 DIP | 187-188 |

## (inuin Keyboard Encoder

| Part Number | No. of Keys | Modes | Features | Suffix | ndard Fonts Description | Power Supplies | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| KR-2376 XX ${ }^{(3)}$ | 88 | 3 | 2 Key Rollover | -ST | ASCII | +5, -12 | 40 DIP | 371-374 |
| KR-3600 XX ${ }^{(3)}$ | 90 | 4 | 2 Key or N Key Rollover | $\begin{aligned} & \hline \text {-ST } \\ & \text {-STD } \\ & \text {-PRO } \\ & \hline \end{aligned}$ | ASCII ASCII Binary Sequential | +5, -12 | 40 DIP | 375-382 |

[^0]CHARACTER GFNERATOR

| Part Number | Description | Scan | Max Access Time | Power Bupplies | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CG $4103^{(3)}$ | $5 \times 7 \times 64$ | Column | $1.2 \mu \mathrm{sec}$ | $+5,-12$ or $\pm 12$ | 28 DIP | $357-360$ |

SHIFT REGISTER

| Part Number | Description | Feature | $\begin{gathered} \text { Max } \\ \text { Clock Freq. } \end{gathered}$ | Power Supply | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SR 5016-XX ${ }^{(3)}$ | Quad Static Shift Register Mask Programmable Length | Load, Recirculate, Shift Controls, | 1 MHz | +5 | 16 DIP | 361-364 |
| SR 5015-80 | Quad 80 Bit Static |  |  |  |  |  |
| SR 5015-81 | Quad 81 Bit Static |  |  |  |  |  |
| SR 5015-133 | Quad 133 Bit Static |  |  |  |  |  |
| SR 5017 | Quad 81 Bit | Shift Left/Shift Right, Recirculate | 1 MHz | +5 | 16 DIP | 365-368 |
| SR 5018 | Quad 133 Bit | Controls, Asynchronous clear |  |  |  |  |

## Microprocessor Peripheral

## numur ROM

| Part Number | Description | Access Time | Power Supply | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ROM 4732(3) | 32K ROM; 32,768 bits <br> organized 4096x8 | 450 nsec | +5 | 24 DIP | $347-350$ |
| ROM $36000^{(1)(3)}$ | 64K ROM; 65,536 bits <br> organized $8192 \times 8$ | 250 nsec | +5 | 24 DIP | $351-354$ |

HuमuLuम4hif FTOPPY DISK

| Part <br> Number | Description | Sector/ <br> Format | Density | Data <br> Bus | Side Select <br> Output | Power <br> Supplies | Package | Page |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FDC1761 | Floppy Disk Controller/ <br> Formatter (mini-floppy only) | Soft | Double | Inverted | No | $+5,+12$ | 40 DIP | $295-310$ |
| FDC1763 | Floppy Disk Controller/ <br> Formatter (mini-floppy only) | Soft | Double | True | No | $+5,+12$ | 40 DIP | $295-310$ |
| FDC1765 | Floppy Disk Controller/ <br> Formatter (mini-floppy only) | Soft | Double | Inverted | Yes | $+5,+12$ | 40 DIP | $295-310$ |
| FDC1767 | Floppy Disk Controller/ <br> Formatter (mini-floppy only) | Soft | Double | True | Yes | $+5,+12$ | 40 DIP | $295-310$ |
| FDC1791 | Floppy Disk Controller/ <br> Formatter | Soft | Double | Inverted | No | $+5,+12$ | 40 DIP | $311-326$ |
| FDC1792 | Floppy Disk Controller/ <br> Formatter | Soft | Single | Inverted | No | $+5,+12$ | 40 DIP | $311-326$ |
| FDC1793 | Floppy Disk Controller/ <br> Formatter | Soft | Double | True | No | $+5,+12$ | 40 DIP | $311-326$ |
| FDC1794 | Floppy Disk Controller/ <br> Formatter | Soft | Single | True | No | $+5,+12$ | 40 DIP | $311-326$ |
| FDC1795 | Floppy Disk Controller/ <br> Formatter | Soft | Double | Inverted | Yes | $+5,+12$ | 40 DIP | $311-326$ |
| FDC1797 | Floppy Disk Controller/ <br> Formatter | Soft | Double | True | Yes | $+5,+12$ | 40 DIP | $311-326$ |
| FDC3400 | Floppy Disk Data Handler | Hard | N/A | True | NA | $+5,-12$ | 40 DIP | $331-338$ |
| FDC9216/B | Floppy Disk Data Separator | Soft/ Hard | Double | NA | NA | +5 | 8 DIP | $327-330$ |


| Part Number | Description | Max <br> Data Rate | Features | Power <br> Supply | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CCC 3500 | Cassette/Cartridge Data Handler | 250 K bps | Sync byte detection, <br> Read While Write | $+5,-12$ | 40 DIP | $339-346$ |

[^1]maniurn CRT Display

## TIMING CONTROLLERS

| Part Number | Description | Features | Display Format | Max Clock | Power Supplies | Packrage | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CRT 5027 | provides all of the timing and control for interlaced and non-interlaced CRT display |  | programmable | 4 MHz | +5, +12 | 40 DIP | 197-204 |
| CRT 6037 |  | balanced beam interlace | programmable | 4 MHz | +6, +12 | 40 DIP | 197-204 |
| CRT $5047^{(3)}$ |  | fixed format | $\begin{aligned} & 80 \text { column } \\ & 24 \text { row } \end{aligned}$ | 4 MHz | +5, +12 | 40 DIP | 205-206 |
| CRT 5057 |  | lino-lock | programmable | 4 MHz | +5,+12 | 40 DIP | 197-204 |
| CRT 9007 | CRT video processor and controller | sequential or rowtable driven memory | programmable | 4 MHz | +6 | 40 DIP | 207-226 |
| CRT 96364A/B | complete CRT processor | on-chip cursor and write control | 64 column 16 row | 1.6 MHz | +5 | 28 DIP | 227-234 |

## VDAC ${ }^{\text {TM }}$ DISPLAY CONTROLLERS

| Part Tumber | Description | Display | Attributes | Max Clock | Power Supply | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CRT 8002H ${ }^{(1,2,3)}$ | Provides complete display and attributes control for alphanumeric and graphics display. Consists of $7 \times 11 \times 128$ character generator, video shift register, latches, graphics and attributes circuits. | $7 \times 11$ dot matrix, wide graphics, thin graphics, on-chip cursor | reverse videoblankblinkunderlinestrike-thru | 25 MHz | +5 | 28 DIP | 247-254 |
| CRT 8002A ${ }^{(2,3)}$ |  |  |  | 20 MHz |  |  | 235-244 |
| CRT 80023 ${ }^{(2.3)}$ |  |  |  | 15 MHz |  |  | 235-244 |
| CRT 8002C ${ }^{(2,3)}$ |  |  |  | 10 MHz |  |  | 235-244 |

## CHARACTHR GFNFRATORS

| Part Number | Description | Max <br> Frequency | Power Supply | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CRT 7004A (3,4) | $7 \times 11 \times 128$ character generator, latches, video shift register | 20 MHz | +5 | 24 DIP | 255-260 |
| CRT 7004B ${ }^{(3,4)}$ |  | 15 MHz |  |  |  |
| CRT 7004C ${ }^{(3,4)}$ |  | 10 MHz |  |  |  |

ROW BUFFFR

| Part Number | Description | Max Row Length | Power Supply | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CRT 9006-83 | 8 bit wide serial cascadable single row buffer memory for CRT or printer | 83 characters | +5 | 24 DIP | 261-266 |
| CRT 9006-135 |  | 135 characters |  |  |  |
| CRT 9212 | 8 bit wide serial cascadable double row buffer memory for CRT or printer | 135 characters | +5 | 28 DIP | 267-272 |

## VIDFO ATTRIBUTFS CONTROL工FRS

| Part Number | Description | Display | Attributes | $\begin{array}{c}\text { Max } \\ \text { Clock }\end{array}$ | $\begin{array}{l}\text { Power } \\ \text { Supply }\end{array}$ | Package | Page |
| :--- | :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| CRT 8021 | $\begin{array}{l}\text { Provides attributes } \\ \text { and graphics control } \\ \text { for CRT video } \\ \text { displays }\end{array}$ | $\begin{array}{l}\text { Alphanumeric, wide } \\ \text { graphics, thingraphics, } \\ \text { on-chip cursor }\end{array}$ | $\begin{array}{l}\text { Reverse video, } \\ \text { blank, blink, } \\ \text { underline, } \\ \text { strike-thru }\end{array}$ | 20 MHz | +5 | 28 DIP | $273-280$ |
| CRT 9021B | $\begin{array}{l}\text { Provides attributes } \\ \text { and graphics control } \\ \text { for CRT video } \\ \text { displays }\end{array}$ | $\begin{array}{l}\text { Alphanumeric, wide } \\ \text { graphics, thingraphics, }\end{array}$ | $\begin{array}{l}\text { Reverse video, } \\ \text { blank, blink, } \\ \text { on-chip cursor, double } \\ \text { height, double width }\end{array}$ | 28.5 MHz | +5 | 28 DIP | $281-292$ |
| intersine, |  |  |  |  |  |  |  |$]$

[^2]| Description | SMC <br> Part \# | AMI | Fairchild | General Instrument | Harris | Intel | Intersil |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| UART ( $11 / 2 \mathrm{SB})^{* *}$ | COM 2017 | S1883 | - | AY 5-1013A | - | - | - |
| UART (1,2 SB)** | COM 2502 | - | - | AY 5-1013 | - | - | - |
| UART ( n -Channel)** | COM 8017 | S6850* | - | AY 3-1015 | HM6402 | - | IM6402 |
| UART ( n -Channel)** | COM 8502 | - | - | AY 3-1015 | HM6403* | 8251* | 1M6403* |
| UART ( n -Channel)* | COM 1863 | S1602 | - | - | - | - | - |
| USRT | COM 2601 | S2350* | - | - | - | - | - |
| ASTRO | COM 1671 | - | - | - | - | - | - |
| PCl | COM 2651 | - | - | - | - | - | - |
| EPCI | COM 2661 | - | - | - | - | - | - |
| USART | COM 8251 A | - | - | - | - | 8251A | - |
| Multi-Protocol, USYNRT | COM 5025 | - | $\begin{aligned} & \text { F3846* } \\ & \text { F6856 } \end{aligned}$ | - | - | - | - |
| Dual Baud Rate Gen. | $\begin{aligned} & \text { COM } 5016 / 36 \\ & \text { COM } 8116 / 36 \end{aligned}$ | - | - | - | - | - | - |
| Single Baud Rate Gen. | $\begin{aligned} & \text { COM 5026/46 } \\ & \text { COM } 8126 / 46 \\ & \hline \end{aligned}$ | - | F4702* | - | $\begin{aligned} & \text { HD4702* } \\ & \text { HD6405* } \\ & \hline \end{aligned}$ | - | - |
| 88 Key KB Encoder | KR 2376 | - | - | AY 5-2376 | - | - | - |
| 90 Key KB Encoder | KR 3600 | - | - | AY 5-3600 | - | - | - |
| CRT Controller | CRT 5037 | - | - | - | - | 8275* | - |
| Character Generator | CRT 7004 | S8564* | - | - | - | - | - |
| Character Generator | CRT 8002 | - | - | - | - | - | - |
| Character Generator | CG 4100 | S8499 | - | RO 5-2240S* | - | - | - |
| Shift Register | SR 5015 | S2182/3/5 | - | - | - | - | - |
| ROM | ROM 4732 | S68332 | - | RO 3-9332 | - | 2332* | - |
| ROM | ROM 36000 | S4264* | - | RO 3-9364 | - | - | - |

*Functional Equivalent
**Most UART's are interchangeable; consult the factory for detailed information on interchangeability.

## REFERENCE GUIDE

| :ommodore (MOS echnology) | Mostek | Motorola | National | NEC | Signetics | Solid State Scientific | Synertec | Texas Instruments | Western Digital |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | MM5303* | $\mu$ PD369* | - | - | - | TMS6011 | TR1602 |
| - | - | - | - | - | 2536 | - | - | - | TR1402 |
| - | - | MC6850* | - | - | - | SCR1854 | - | - | - |
| - | - | - | - | - | - | - | - | - | TR1983* |
| - | - | - | - | - | - | - | - | - | TR1863 |
| - | - | - | - | - | - | - | - | - | - |
| - | - | - | INS1671 | - | - | - | - | - | UC1671 |
| - | - | - | INS2651 | - | 2651 | - | - | - | - |
| - | - | - | - | - | 2661 | - | SY2661 | - | - |
| - | - | - | INS8251 | $\mu$ PD8251A | - | - | - | - | - |
| - | - | - | - | $\mu \mathrm{PD} 379 *$ | 2652 | SND5025 | - | - | SD1933* |
| - | - | - | - | - | - | - | - | - | BR1941L |
| - | - | MC14411* | MM5307* | - | - | - | - | - | - |
| - | - | - | - | - | - | - | - | - | - |
| MCS1009* | - | - | MM5740* | $\mu$ PD364* | - | - | - | TMS5001 | - |
| - | MK3807 | MC6845* | DP8350* | - | - | $\begin{aligned} & \text { SND5027 } \\ & \text { SND5037 } \end{aligned}$ | 6545* | TMS9927 | - |
| - | - | $\begin{aligned} & \text { MCM66700* } \\ & \text { MC6570* } \end{aligned}$ | DM8678* | - | 2609* | - | - | - | - |
| - | - | - | - | - | - | SND8002 | - | - | - |
| $\begin{aligned} & \text { MCS1004* } \\ & \text { MCS2027* } \end{aligned}$ | MK2002 | MC1132* | M5240* | - | - | - | - | TMS4103 | - |
| - | MK1007* | - | 5054* | - | 2532* | - | - | $\begin{aligned} & \text { TMS3113* } \\ & \text { TMS3114* } \\ & \hline \end{aligned}$ | - |
| 2332 | - | MCM8332 | - | $\mu$ PD2332 | 2632 | - | SY2332 | TMS4732 | - |
| 2364* | MK36000 | MCM68A364* | MM52864* | $\mu \mathrm{PD} 2364{ }^{*}$ | 2664* | - | SY2364* | TMS4764* | - |

## FLOPPY DISK CONTROLLERS

| Description | SMC <br> Part \# | Fairchild | Fujitsu | Mostek | Synertec | Western <br> Digital |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Floppy Disk Controller | FDC 1791-02 | - | MB8876 | - | SY1791-02 | FD 1791-02 |
| Floppy Disk Controller | FDC 1792-02 | - | - | - | - | FD 1792-02 |
| Floppy Disk Controller | FDC 1793-02 | - | M8877 | - | SY1793-02 | FD 1793-02 |
| Floppy Disk Controller | FDC 1794-02 | - | - | - | - | FD 1794-02 |
| Floppy Disk Controller | FDC 1795-02 | - | - | - | - | FD 1795-02 |
| Floppy Disk Controller | FDC 1797-02 | - | - | - | - | FD 1797-02 |
| Floppy Disk Controller | FDC 1761-02 | - | - | - | - | FD 1761-02 |
| Floppy Disk Controller | FDC 1763-02 | - | - | - | - | FD 1763-02 |
| Floppy Disk Controller | FDC 1765-02 | - | - | - | - | FD 1765-02 |
| Floppy Disk Controller | FDC 1767-02 | - | - | - | - | FD 1767-02 |
| Floppy Disk Data Separator | FDC 9216 | - | - | - | - | FD 1691* |
| Microcomputer | MPU 3870 | F3870-2 | - | MK3870/20 | - | - |

*Functional Equivalent

## Innovation in microelectronic technology is the key to growth at Standard Microsystems.

Since its inception, Standard Microsystems has been a leader in creating new technology for metal oxide semiconductor large scale integrated (MOS/LSI) circuits.

For example, while the first MOS/LSI processes were p-channel, it was recognized very early that an n-channel process would greatly improve switching speeds and circuit density. However, the fundamental problem of parasitic currents needed to be solved. The research and development staff at Standard Microsystems recognized this problem and directed its energy toward the development of its now-famous COPLAMOS ${ }^{\circledR}$ technology. COPLAMOS ${ }^{\circledR}$ defines a self-aligned, field-doped, locally oxidized structure which produces high-speed, high-density n-channel IC's.

In addition, on-chip generation of substrate bias, also pioneered by Standard Microsystems, when added to the COPLAMOS ${ }^{\circledR}$ technology, results in the ability to design dense, high-speed, low-power n-channel MOS integrated circuits through the use of one external power supply voltage.

Again recognizing a need and utilizing its staff of qualified process experts, Standard Microsystems developed the CLASP ${ }^{\oplus}$ process. The need was for fast turnaround, easily programmable semi-custom LSI technology. The development was CLASP ${ }^{\circledR}$, a process that utilizes ion implantation to define either an active or passive device which allows for the presence of a logical 1 or 0 in the matrix of a memory or logic array. This step is accomplished after all wafer manufacturing steps are performed including metalization and final passiviation layer formation. Thus, the wafer can be tested and stored until customer needs dictate the application, a huge saving in turnaround time and inventory costs.

These innovations in both process and circuit technology have received widespread industry recognition: In fact, many of the world's most prominent semiconductor companies have been granted patent and patent/technology licenses covering various aspects of these technologies. The companies include Texas Instruments, IBM, General Motors, ITT, Western Electric, Mostek, Hitachi and Fujitsu.

Over the past few years, scientists and engineers at Standard Microsystems have been developing a technology to significantly reduce the sheet resistivity of polycrystalline silicon and thereby dramatically decrease internal time constants in MOS devices. Their work has culminated in the successful completion of a program to replace polycrystalline silicon in n-channel MOS devices with an alternate material, titanium disilicide. This has enabled Standard Microsystems to become the first semiconductor manufacturer to market and sell MOS/VLSI circuits which employ a metal silicide to replace the conventional doped polycrystalline silicon layer.


## Our engineering staff follows the principle that "necessity is the mother of invention."

This philosophy led Standard Microsystems Corporation to COPLAMOS ${ }^{\circledR}$, CLASP ${ }^{\circledR}$, and Titanium Disilicide gate technology, as well as other innovative developments. It also brings companies to us to solve tough problems that other suppliers can't.

But it's a philosophy that involves more than just developing the next generation of MOS/LSI devices.

Such exploration, for example, helped Standard Microsystems recognize the need for communication controllers to handle the latest data communication protocols. As a result, Standard Microsystems was the first to introduce a one-chip LSI controller for HDLC protocols-the COM 5025.

The COM 5025 is so versatile it can actually provide the receiver/transmitter functions for all the standard bit and byte oriented synchronous protocols, including SDLC, HDLC, ADCCP, bi-sync and DDCMP.

In another area, CRT display systems have traditionally required a great deal of support circuitry for the complex timing, refresh and control functions.

This need led the engineers at Standard Microsystems to develop the CRT 5027 Video Timer and Controller (VTAC ${ }^{\circledR}$ ) that provides all these functions on a single chip. This left the display, graphics and attributes control spread over another 20 or 30 SSI, MSI and LSI devices. Standard Microsystems combined all these functions in the CRT 8002 Video Display Attributes Controller (VDAC ${ }^{\text {TNI }}$ ). The COPLAMOS ${ }^{\circledR}$ pro ccess was used to achieve a 20 MHz video shift register, and CLASP ${ }^{\circledR}$ was used for fast turnaround of character font changes through its last stage programmability.

So from 60 to 80 integrated circuits, Standard Microsystems reduced display and timing to 2 devices, drastically reducing the cost and size of today's CRT terminals.

Another major achievement was the development of the "next generation" Video Processor And Controller (VPAC ${ }^{\mathrm{TM}}$ ), the CRT 9007. This chip replaces up to 80 SSI and MSI TTL devices as well as providing a hardware solution to many of the software problems of CRT Video Controller design.

Achievements like these help keep Standard Microsystems custom and standard products in the forefront of technology with increased speeds and densities, and a lower cost per function.


## Improvements in processing and manufacturing keep pace with advances in semiconductors.

With the phenomenal growth of the electronics industry, innovation is, of course, highly desirable. But if the products are to perform as designed, they also have to be reliable.

That's why at Standard Microsystems we take every means to insure the utmost quality and dependability. Consequently, "state-of-the-art" applies not only to our products, but to the way we manufacture them.

In wafer fabrication, the latest equipment and techniques areemployed. In addition to conventional processing equipment, we use ion implantation technology extensively. We also use plasma reactors for much of our etching and stripping operations to maintain tight tolerances on process parameters.

To make plastic packaging immune to moisture, we use a process that deposits a protective (passivating) layer of silicon nitride on the device surface.

Standard Microsystems processes include high and low voltage p-channel metal gate, $n$-channel silicon gate (COPLAMOS ${ }^{\circledR}$ ), high-speed $n$-channel silicon gate with depletion mode devices, CLASP ${ }^{\oplus}$ and titanium disilicide gate. In general, these processes have been engineered so that they are also compatible with most industry standard processes.

One obvious advantage our total capability gives customers, is that they can bring us their project at any stage in the development process. For instance, they may already have gone through system definition. Or they may have gone all the way to prototype masks, and only want production runs.

It makes no difference to Standard Microsystems. We can enter the process at any level.

Our full service capability lets us make full use of the technologies we develop. We can produce any quantity of semiconductors customers may require. And we can offer them one of the fastest turnaround times in the industry.


## Standard Microsystems' Custom Capability.

## Custom MOS. A Small Revolution with a Large Impact.

Remarkable advances in semiconductor technology, combined with the availability of quality, low-cost electronics, continue to open new markets for products incorporating microelectronic components.

Today, metal-oxide semiconductor/large scale integrated (MOS/LSI) circuits are integral components in computers and computer peripherals, automobiles, televisions, electrical appliances, electronic toys and games, bank terminals, telephones and a host of other significant applications.

With further applications for large scale integrated and very large scale integrated (VLSI) circuits being discovered every day, one thing is certain. They will have a profound effect on our lifestyle.

## Custom Commitment

Standard Microsystems is organized into two separate Product Lines; Custom Products and Standard Products. Custom Products has its own management, marketing, and engineering team that is fully dedicated to developing and producing custom products.

Custom MOS/LSI is a major portion of our business. Fully one-third of all our revenue is a direct result of our custom MOS/LSI projects.

Over the years, Standard Microsystems has developed custom circuits for a wide variety of applications: Computers and computer peripherals, telecommunications and data communications, garage door openers and burglar alarms, electronic toys and games, musical instruments and more. Both over-the-air and cable T.V. systems have made use of our custom circuits. One company's line of word processing equipment makes almost exclusive use of our custom LSI.

As a company committed to serve the custom marketplace, Standard Microsystems has developed the resources and established procedures for MOS/LSI circuit development that enables the company to respond rapidly to growing customer needs.

## System Design-The Alternatives

The electronic system designer can select from several alternatives in the implementation of the system. The optimum selection for any system will depend upon the relative significance of the following factors-

- Costs-developmental, production and maintenance;
- Performance-speed, power dissipation;
- Form factor-system size and weight;
- Uniqueness-proprietary features;
- Development time-product introduction;
- Reliability-mean time between failures (MTBF).
No single alternative is best for all caseseach represents a combination of advantages and disadvantages to be evaluated for the system under consideration. The major alternatives available are listed below.


## Standard Circuits

The use of "off the shelf" small scale (SSI), medium scale (MSI), or large scale (LSI) integrated circuits is appropriate whenever development costs and time must be kept to a minimum, and system performance requirements can be met by interconnecting numbers of such standard components. Standard Microsystems is a recognized industry leader in standard LSI components for the data communications and computer peripheral markets.

## Microprocessors

These programmable LSI standard circuits can be the elements of choice for certain classes of systems where there is a good fit between the microprocessor capability and the system performance requirements. The system parts count is reduced at the expense of a longer (software) development time.

## Gate Arrays

A gate array is a semi-custom circuit containing a pattern of elements which can be selectively interconnected to form the desired logic. The interconnections are typically accomplished by a customized metal pattern.

For low to medium volume production, these "hardware programmable" circuits can reduce parts count and offer some degree of uniqueness, at modest development cost and time.

## The Custom Option

FOR HIGH VOLUME PRODUCTION, WHERE THE DEVELOPMENT INVESTMENT CAN BE MADE, THE CLEAR CHOICE IS THE FULLYCRAFTED CUSTOM CIRCUIT. A custom circuit implementation will provide-

## Lowest Overall Cost

The overall cost savings realized with custom LSI can be substantial, especially when highvolume production is encountered.
Savings are effected in several ways. Because custom designed circuits contain only necessary components, the cost of unused circuitry on standard microprocessors or integrated circuits is eliminated. Costs for troubleshooting, repair and warranty claims are reduced. In addition, custom MOS can be more economical over SSI and MSI when purchase, inventory and assembly costs are considered. Also, when a system contains a large amount of SSI and MSI, its custom counterpart can significantly reduce power consumption.

## Lowest Parts Count

There are many applications where a singlepackage custom LSI circuit can out-perform a microprocessor and its ROM and RAM circuits while reducing costs. A custom LSI unit can rapidly execute repetitive functions using high speed logic. A microprocessor needs time-consuming algorithms to do the same thing.

## Highest Reliability

Higher reliability is achieved, especially when replacing circuits that contain significant amounts of SSI and MSI. Fewer parts and solder points reduce the failure rate and raise the reliability. This means low MTTR (mean time to repair), which translates into lower maintenance costs and higher customer satisfaction.

## Minimum Size, Weight, Power Dissipation

The size and complexity of printed circuit boards are greatly reduced when using a custom circuit. The custom circuit results in a most compact package, specifically designed to perform only the necessary tasks utilizing minimum power and space.

## Unique Proprietary Features

Proprietary design is another major benefit. It protects your design from would-be copiers because it makes testing and support difficult. This, coupled with the complexity of custom semiconductor fabrication, makes duplicating your custom circuit far less probable.

## The Full Design Custom Program

Typically in a custom program where Standard Microsystems performs all of the operationsfrom design through to finished product-the following sequence applies:

## Evaluation

The customer's system characteristics are carefully evaluated from the information provided to determine the feasibility of the custom approach, considering such factors as system partitioning, functional performance, operational environment, operating speed, power requirements, process selection, packaging and testing.

If the conclusion is positive, Standard Microsystems will quickly provide a Quotation to the potential customer, which will include-

- a firm development schedule
- the non-recurring engineering charge (NRE)
- a production price schedule


## System Definition

Once the design is authorized, a thorough specification review takes place between Standard Microsystems' engineers and the customer's engineers. In this critical phase, Standard Microsystems' years of successful design experience are applied as an extension of the customer's design resource in a close working relationship.

## Circuit Design

Required functions are converted to detailed MOS logic. The logic is verified via advanced logic simulation routines, utilizing our in-house computers (VAX, Eclipse, PDP-11), and/or breadboard emulators. Circuit simulation is done using SPICE, MOSAID, and Standard Microsystems written software.

## Artwork Generation

At Standard Microsystems, device layout is a blend of custom "hand-crafting" and sophisticated CAD, using our Calma GDS I and GDS II color graphics systems, to achieve the optimum composite drawing in terms of size and schedule. Check plots are obtained on our Xynetics and Versatec plotters, and advanced design rule checks (DRC) and electrical rule checks (ERC) provide comprehensive artwork verification.

## Mask Fabrication

Production tooling is obtained from qualified mask vendors to Standard Microsystems' exact-
ing, above-industry standards. Colored overlays of each mask layer are typically used as a final check point.

## Wafer Fabrication

Standard Microsystems offers a variety of processes, including a mature p-channel metal gate process, and a range of n-channel silicon gate processes. We will determine the appropriate process to satisfy each customer's cost/ performance requirements.

All wafer processing is done in our facilities, utilizing state-of-the-art equipment. Standard

Microsystems has made substantial investments in direct-step-on-wafer equipment, and advanced ion-implantation, sputtering, deposition and plasma etch equipment.

## Assembly

Standard Microsystems can provide a wide variety of industry-standard packages, including ceramic, plastic and CERDIP dual-in-line types, flat-packs and chip carriers. The latest in automated equipment, such as our automatic wire bonders, insure high quality and high volume throughput.

| SMC PROCESS CHARACTERISTICS |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| PROCESS | MASK LEVELS | TYPICAL SUPPLY VOLTAGES |  | FEATURES/COMMENTS |
| 3000 | 5 | $+5,-12$ | 1 to 3 | p-channel metal gate. Enhancement mode, most mature process, low performance. |
| 5000 | 5 | $\begin{aligned} & +5,+12 \\ & -3 \text { (or pump) } \end{aligned}$ | 3 to 7 | n-channel si-gate. Enhancement mode, most mature n-channel process, moderate performance. Substrate bias required. |
| 6000 | 6 | $\begin{aligned} & +5,+12, \\ & -3 \text { (or pump) } \end{aligned}$ | 3 to 7 | Same as 5000 process with buried contacts. |
| 7000 | 7 | +5 | 6 to 15 | n-channel si-gate. Enhancement/ depletion mode, buried contacts, moderate to high performance. No substrate bias required. |
| 8000 | 6 | +5 | 6 to 15 | Same as 7000 process without buried contacts. |
| 9000 | 7 | $\begin{aligned} & +5 \\ & +12 \text { (optional) } \\ & -3 \text { (or pump) } \end{aligned}$ | 9 to 25 | Very high performance n-channel sigate. Enhancement/depletion mode. Substrate bias required. |

## Customer Owned Tooling

An area of continuing interest to Standard Microsystems is that of Customer Owned Tooling (COT) or Customer Supplied Tooling (CST). In contrast to a full custom design program where Standard Microsystems is responsible for the MOS design, a COT/CST program is one in which the design function will be completed by the customer or an outside design house.

Many customers find it desirable to develop an in-house LSI design capability, for their internal circuit requirements. Standard Microsystems can provide valuable assistance in achieving this goal.

The customer then provides Standard Microsystems with either a completed composite drawing, a data base tape (in suitable format), or an actual processing mask set. Whatever the entry level, Standard Microsystems is prepared to carry the program through to completion.

If the design is in the formative stages, the requirements will be studied and the most suitable set of design rules will be provided.

If the design is already completed, Standard Microsystems will examine the design rules used and recommend which of our processes is most compatible. If small variations to our "standard" processing are required, they can usually be accommodated at little or no expense.

Standard Microsystems has developed comprehensive test sites that are incorporated into our masks for the purpose of parametric and quality assurance measurements. Automated equipment collects and stores measurements from these test sites. If a customer purchases wafers from us, these measurements are provided with the wafers. If a customer chooses to have masks fabricated himself, our test site can be provided for incorporation into the masks.

Standard Microsystems is also prepared to work with customers in establishing a suitable test interface which will enable us to provide the wafer probe and final test operations. Of course, packaging and burn-in are also available.

Whichever approach is taken, Standard Microsystems wants to partcipate in a partnership that makes best use of our respective areas of expertise. We'll work together to bring the project to completion; on time and on budget.

## Customer Interface

Standard Microsystems is a "full capability" company. We have the resources-an experienced staff and state-of-the-art equipment-to design, process, package and test our Custom MOS circuits.

Our customers are becoming increasingly aware of the benefits of custom circuits in their product lines. They know their products and markets best. Some have developed the technical expertise to perform or participate in the early design phases of a custom program. For this reason, Standard Microsystems offers a variety of customer interface possibilities to serve the broadest possible market.

## Communications: The Key to Custom Development

On every Custom program, we establish communications with our customers that last throughout the development and production phases.

Our engineers work in an environment that stimulates creativity while encouraging adherence to pragmatic objectives. The status of each program is closely monitored. Strict scheduling, thorough program management and frequent customer contact have become the hallmark of a Standard Microsystems Custom program. Numerous testimonials from satisfied customers give evidence of our ability to performto specification and on time.


## Quality Assurance and Quality Control

Volume manufacturing of quality products requires a rigorous commitment on behalf of STANDARD MICROSYSTEMS and all of its employees. Each phase of the operation from design to shipping must adhere stringently to documented procedures which have produced a product of proven reliability.
The design of a reliable product is assured by adherence to tested and proven design rules. Any change in design rules must be evaluated using a design-rule test vehicle. Each new product is evaluated first by prototype wafer runs and thorough preliminary production and device characterization.
Manufacturing flow is monitored by Quality Control to insure that parameters meet specifications on incoming
material, within the line and at outgoing inspection. Clean room standards, calibration and work methods are also monitored. Quality Circles operate within the manufacturing organization to reduce the cost of quality and improve the product.

The Quality Assurance Department is the customer representative with the primary responsibility of evaluating product to current industry standards and related responsibilities of evaluating developmental processes, product and the standards themselves.

The following is a more detailed description of the types of screening performed and how SMC is organized to produce quality products.

### 1.0 Scope

The measures taken by SMC to produce reliable integrated circuits and the assembly/screening options available to the customer are given in this section.

### 2.0 Approach

Factors relating to quality and reliability are discussed in the following order: package options, screening, process control, test and characterization, quality conformance/reliability testing, and failure analysis.

### 3.0 Applicable Documentation

SMC internal specifications define every phase of production and must be approved by the designated representatives of Engineering, Manufacturing, Processing, Quality Control and Quality Assurance departments.

### 3.1 Design Rules (DR-XXXX)

3.1.1 Geometric design rules define layout considerations, alignment structures, critical-dimension targets, and input-protection networks.
3.1.2 Electrical design rules define performance criteria, measurement methods, device parameters, and process parameters.

### 3.2 Purchase Specifications (PS-XX)

All critical material is purchased to SMC specifications from qualified vendors.

### 3.3 Process Specifications (WX-XX, AX-XX)

3.3.1 The procedures used for wafer processing and assembly of microcircuits are fully documented.

### 3.4 Quality Control Procedures (QC-XX)

QC procedures define the sampling techniques, accept/ reject criteria and test methods used in quality audits.

### 3.5 Quality Assurance Procedures (QA-XX)

QA procedures define methods for product/process qualification, reliability testing and failure analysis.

| 4.0 | Military |
| :--- | :--- |
| MIL-C-45662 | Standards and Specifications <br> Calibration System |
| MIL-M-38510 | Requirements <br> General |
| circuits |  |

### 5.0 Package Options, Features

5.1 Ceramic (no suffix)
$50 \mu$ inches gold plating on external leads and die cavity, gold eutectic die attach.

### 5.2 Tin-Plated Ceramic (Suffix "TC")

Over $200 \mu$ inches tin plating on external leads, gold on die cavity, gold eutectic die attach.

### 5.3 Cerdip (Suffix '"CD')

Meets MIL-STD-883 internal moisture content requirements of Method 5005 . Substrate connections are made through jumper chips, gold eutectic die attach.

### 5.4 Plastic (Suffix "P")

The plastic used is a B-type epoxy or an approved advanced type having better resistance to a humid environment. Gold eutectic die attach and gold bond wires
are used. Lead material is MIL-M-38510 para 3.5.6 type B (42 Alloy) with a solder lead finish.

### 6.0 Screening Options

### 6.1 High-Reliability Screening

The routing is as defined in MIL-STD-883 Method 5004 for Class B product. Periodic Quality Conformance data (para. 10.2) is taken on generically similar parts. A sample flow chart for ceramic product is given on page 6.

### 6.1.1 Internal Visual

Both Die and Preseal Visual inspections are to the criteria of Method 2010, Condition B of MIL-STD-883. An AQL audit is performed on each lot by Quality Control.
6.1.2 Stabilization Bake

All parts are placed in $150^{\circ} \mathrm{C}$ storage for 24 hours per Method 1008, Condition C of MIL-STD-883.
6.1.3 Temperature Cycling

All parts are subjected to 10 cycles of $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ per Method 1010, Condition C of MIL-STD-883.
6.1.4 Constant Acceleration

All parts are subjected to a $30,000 \mathrm{~g}$ force in the Y 1 orientation per Method 2001, Condition E.

### 6.1.5 Seal

Hermeticity testing is performed to conditions A and C of MIL-STD-883 Method 1014.
6.1.6 Pre burn-in Electrical Test

Ordinarily this is the same as final electrical test.

### 6.1.7 Burn-in

Condition A and Condition D of MIL-STD-883, Method 1015 are available. The stress is applied for 168 hours at $125^{\circ} \mathrm{C}$ or at other temperatures according to the timetemperature regression.
6.1.8 Final Electrical Test

Verifies functional and parametric performance to the device specifications.
6.1.9 Final Visual Inspection

All parts are inspected to Method 2009 of MIL-STD-883.

### 6.2 Standard Screening

Standard Screening is designed for the industrial-commercial customer and is available in all package types. For hermetic packages, temperature cycling, centrifuge and hermeticity are specified as well as die, preseal, and final visual inspection.
6.2.1 Standard Die and Preseal Visual Inspections (AC-04, AC-08)
These inspections were developed from Method 2010 of MIL-STD-883.The inspection criteria are specific to SMC's pMOS and nMOS COPLAMOS ${ }^{\circledR}$ technologies.
6.2.2 Temperature Cycling (AC-15, AD-13)

Temperature cycling is performed to the MIL-STD-883, equivalent of Method 1010 , Condition $\mathrm{C},-65^{\circ} \mathrm{C} /+150^{\circ} \mathrm{C}$, ten cycles.
6.2.3 Constant Acceleration (centrifuge) (AC-16, AD-14)

Constant Acceleration is performed to the MIL-STD-883, equivalent of Method 2001, Condition E, 30,000 g in the Y1 orientation.
6.2.4 Hermeticity (AC-11, AD-15)

Includes fine and gross leak testing to SMC equivalent of MIL-STD-883 Method 1014 Conditions A and C.

### 6.2.5 Final Electrical Test

Verifies functional and parametric performance to the device specifications.

### 6.3 Custom Screening

Certain applications require special screening which can be arranged upon request.

### 7.0 Electrical Test

### 7.1 Probe and Final Test

SMC test programs are developed by the Test Engineering Department and verified by device characterization. An approval procedure is required for the transfer of a new test program or a revised test program from engineering to production.

### 7.2 Characterization/correlation

Characterization of parts and correlation of test results with customer incoming testing performed on SMC test equipment, including Megatest and Sentry ${ }^{\text {™ }}$ test systems.

### 7.3 Product Engineering

SMC product engineers characterize parts to improve processing target parameters and test correlation with customers.

### 8.0 Purchased Material

All manufacturing materials are purchased from qualified vendors to SMC procurement specification.

### 9.0 Quality Control

The Quality Control Department reports at the same level as the manufacturing, test and process engineering departments. QC is responsible for incoming inspection, in-process audits, out-going inspection, document control, processing returned material and certification of compliance to specification.

### 9.1 Incoming Inspection

Inspectors verify critical parameters on all material used in manufacturing. The department maintains an approved vendor list and interfaces directly with vendor QC departments.

### 9.2 In-process Audits

QC performs an on-going monitoring of wafer processing, test and assembly functions.

### 9.3 Outgoing Inspection

QC inspectors verify proper documentation and perform an external mechanical/visual inspection on each lot prior to shipment.

### 9.4 Document Control

All procedures for design, wafer processing, assembly, quality control and quality assurance are maintained by document control.

### 9.5 Returned Material Processing

Returned material, whether for device performance or clerical reasons, is processed through visual and electrical testing.

### 9.6 Certificates of Compliance

Certificates of Compliance are available for specified screening and/or for products ordered under a customer part number/specification.

### 10.0 Quality Assurance

The Quality Assurance Department is the customer's
representative and is independent of the product line and manufacturing organizations. Quality Assurance is responsible for reliability assessment of new and existing processes, material analysis, failure analysis, and development of evaluation methods.

### 10.1 Process Qualification

All new processes and process revisions must equal or exceed the reliability of existing processes on applicable sections of the SMC Quality Conformance Test.

### 10.2 Quality Conformance Test

Samples of finished product are tested periodically to the criteria of QA-01 (see table 2). This test sequence provides historical data which is also used for qualification of new products and processes. The various subgroups contain tests referenced in Method 5005 of MIL-STD-883 as well as tests designed around industry requirements not yet incorporated in military standards.

### 10.3 Analysis

10.3.1 The analytical facilities include a scanning electron microscope (SEM), an infrared microscope, optical microscopes, an X-ray unit and electronic test instruments.
10.3.2 Scanning electron microscopy is used in the periodic evaluation of workmanship in wafer processing and assembly, to support engineering efforts at process development and improvement, and in failure analysis.
10.3.3 Failure Analysis is performed upon request by sales, marketing or manufacturing organizations and is also performed on reliability test failures. The failure analysis procedures support the development of new product, process improvements, and the evaluation of screening methods.
10.3.4 Material analysis is performed on layers of the integrated circuit and on packaging to support the engineering development. This characterization is performed on in-house facilities. Independent outside analytical laboratories are used to supplement SMC facilities if and when required.

### 11.0 Lot Traceability

SMC maintains full lot traceability on all product types in all packaging options (including plastic). The information available includes:

### 11.1 Wafer Processing Records

Sign-off and date on all operations, critical measurements and inspection records.

## TABLE 1

WAFER LOT ACCEPTANCE

| TEST | LIMIT | SAMPLING PLAN |
| :---: | :---: | :---: |
| wafer thickness | minimum thickness 0.010 in. exceeds MIL-M-38510 minimum of .006 in. | LTPD $=10$ (Incoming) |
| metallization thickness | $17,500 \AA \pm 2,500 \AA$ | one wafer per metallization run |
| stability | $\Delta \mathrm{V}_{\mathrm{FB}} \leqslant 0.5$ volts | test piece each tube change, each week, and each wafer lot |
| device parameters | $\mathrm{V}_{\mathrm{th}}$ enhancement, depletion as applicable <br> $\mathrm{K}^{\prime}$ enhancement, depletion as applicable <br> $\rho$ s polysilicon <br> $\rho$ s mesa ( $\mathrm{n}^{+}$) <br> dielectric strength ( $\mathrm{BV}_{\mathrm{ox}}$ ) <br> $n+$ diode breakdown $\left(B V_{n}+\right)$ | each wafer |
| SEM | Mil-Std 883 Method 2018 | each week on each process |
| Glassivation | 3,000 Å minimum Silicon Nitride 5,000 Å minimum Silicon Dioxide | one test piece per deposition run |



### 11.2 Wafer Lot Acceptance (Mapping) (see table 1)

Device parameters are recorded using a precision parametric interface to a Digital Equipment Corporation PDP 11/23 computer. The data base at wafer map includes probe, final test and wafer processing records (run sheets).

### 11.3 Wafer Probe and Final Test Data

These are correlated with mapping results to develop optimized process targets and yield improvement.

### 11.4 Assembly Records

Inspection results and screening throughput is recorded with date and sign-off for each lot.

TABLE 2-QA-01 QUALITY CONFORMANCE TEST
GROUP B TESTS

| Test | SMC Test Method | $\begin{aligned} & \text { Mil Std } \\ & 883 \\ & \text { Method } \end{aligned}$ | Condition | $\qquad$ accept no. or LTPD | Frequency |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\frac{\text { Subgroup } 1}{\text { Physical dimensions }}$ | QC-22 | 2016 |  | 2 devices (no failures) | every package lot |
| Subgroup 2 Resistance to solvents | QC-21 | 2015 | Marking Permanence | 4 devices (no failures) | every shipment |
| $\frac{\text { Subgroup 3 }}{\text { Solderability }}$ |  | 2003 | Soldering temperature of $260 \pm 10^{\circ} \mathrm{C}$ | 15 | periodic conformance |
| Subgroup 4 <br> Internal visual and mechanical |  | 2014 | Failure criteria from design and construction requirements of applicable procurement document | $\begin{gathered} 1 \text { device } \\ \text { (no failures) } \end{gathered}$ | periodic conformance |
| Subgroup 5 <br> Bond strength <br> (1) Thermocompression <br> (2) Ultrasonic or wedge <br> Die sheer strength | $\begin{aligned} & \text { QC-12 } \\ & \text { QC-13 } \\ & \hline \end{aligned}$ | $\begin{array}{r} 2011 \\ 2019 \\ \hline \end{array}$ | (1) Test condition C or D <br> (2) Test condition C or D | 15 | periodic conformance |
| $\frac{\text { Subgroup } 6}{$ Internal water-vapor  <br>  content } |  | 1018 | $5,000 \mathrm{ppm}$ maximum water content at $100^{\circ} \mathrm{C}$ | 3 devices (no failures) or 5 devices (1 failure) | periodic conformance |
| Subgroup 7 <br> Seal <br> (a) Fine <br> (b) Gross | AC-11 | 1014 | As applicable | 5 | periodic conformance |
| Subgroup 8 <br> Electrical parameters Electrostatic discharge sensitivity Electrical parameters |  | 3015 | Group A, subgroup 1 Test condition A or B <br> Group A, subgroup 1 | 15 | new device types |

GROUP C TESTS—DIE RELATED

| Test | SMC Test Method | $\begin{aligned} & \hline \text { Mil Std } \\ & 883 \\ & \text { Method } \end{aligned}$ | Condition | $\qquad$ accept no. or LTPD | Package Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Subgroup 1 |  |  |  |  |  |
| Steady state life test | QA-02 | 1005 | Test condition to be | 5 | all |
|  |  |  | specified ( 1,000 hours at $125^{\circ} \mathrm{C}$ ) |  |  |
| End-point electrical parameters | Final test |  | As specified in the applicable device specification |  |  |
| Subgroup 2 |  |  |  |  |  |
| Temperature cycling | AC-15 | 1010 | Test condition C | 15 |  |
| Constant acceleration | AC-16 | 2001 | Test condition E min. |  | hermetic |
|  |  |  | $Y$, orientation only |  |  |
| Seal | AC-09 | 1014 | As applicable |  |  |
| (a) Fine |  |  |  |  |  |
| (b) Gross |  |  |  |  |  |
| Visual examination | QC-22 |  |  |  |  |
| End-point electrical | Final test |  | As specified in the |  |  |
| parameters |  |  | applicable device specification |  |  |

GROUP D-PACKAGE RELATED

| Test | SMC Test Method | $\begin{aligned} & \text { Mil Std } \\ & 883 \\ & \text { Method } \end{aligned}$ | Condition | $\begin{gathered} \text { Quantity/ } \\ \text { accept no. or } \\ \text { LTPD } \end{gathered}$ | Package Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\frac{\text { Subgroup } 1}{\text { Physical dimensions }}$ | QC-22 | 2016 |  | 15 | all |
| Subgroup 2 <br> Lead integrity <br> Seal <br> (a) Fine <br> (b) Gross <br> Lid torque | $\begin{aligned} & \text { QC-19 } \\ & \text { AC-11 } \end{aligned}$ | $\begin{array}{r} 2004 \\ 1014 \\ 2024 \\ \hline \end{array}$ | Test condition B2 (lead fatigue As applicable <br> As applicable | 15 | all <br> all hermetic cerdip only |
| Subgroup 3 <br> Thermal shock Temperature cycling <br> Moisture resistance Seal <br> (a) Fine <br> (b) Gross <br> Visual examination <br> End-point electrical parameters | $\begin{aligned} & \text { AC-15 } \\ & \text { QA-03 } \\ & \text { AC-11 } \end{aligned}$ | $\begin{aligned} & 1011 \\ & 1010 \\ & 1004 \\ & 1014 \end{aligned}$ | Test condition B, 15 cycles <br> Test condition C, 100 <br> cycles <br> As applicable <br> Per visual criteria of Method 1004 and 1010 As specified in the applicable device specification | 15 | $\begin{gathered} \text { all } \\ \text { hermetic } \end{gathered}$ |
| Subgroup 4 <br> Mechanical shock Vibration, variable frequency Constant acceleration <br> Seal <br> (a) Fine <br> (b) Gross Visual examination End-point electrical parameters | $\begin{aligned} & A C-16 \\ & A C-11 \end{aligned}$ | $\begin{aligned} & 2002 \\ & 2007 \\ & 2001 \\ & 1014 \end{aligned}$ | Test condition B minimum Test condition A minimum <br> Test condition E minimum, Y, orientation As applicable <br> As specified in the applicable device specification | 15 | all hermetic |
| Subgroup 5 <br> Salt atmosphere Seal <br> (a) Fine <br> (b) Gross <br> Visual examination | AC-11 | $\begin{aligned} & 1009 \\ & 1014 \end{aligned}$ | Test condition A minimum As applicable <br> Per visual criteria of Method 1009 | 15 | all hermetic |
| $\frac{\text { Subgroup 6 }}{\substack{\text { Internal water-vapor } \\ \text { content }}}$ |  | 1018 | $5,000 \mathrm{ppm}$ maximum water content at $100^{\circ} \mathrm{C}$ | 3 devices (no failures) or 5 devices (1 failure) | all hermetic |
| Subgroup 7 <br> Adhesion of lead finish |  | 2025 |  | 15 | all |
| Subgroup 8 <br> Humid Environment <br> End-point electrical parameters | QA-04 <br> Final test |  | 1000 hours $85^{\circ} \mathrm{C} / 85 \%$ Relative Humidity | 15 | plastic |
| Subgroup 9 <br> Autoclave (Pressure Cooker) End-point electrical parameters | QA-05 <br> Final test |  | 24 hours at $2 \mathrm{~atm} 121^{\circ} \mathrm{C}$ | 15 | plastic |

CERAMIC

*This High Reliability flow chart applies to ceramic product. Similar flow charts exist for cerdip and TC packaging. All ACXX, QCXX procedures are under SMC Document Control. All Method XXXX procedures are MIL-STD-883 Test Methods.

HI REL AVAILABLE ON ALL HERMETIC PACKAGES*


PLASTIC (NOTE 1)


CERDIP


Note 1-Plastic assembly is sub-contracted. Assembly operations are controlled by SMC approved sub-contractor specifications.

## Data Communication Products

| Part Number | Name | Description | $\begin{gathered} \text { Max } \\ \text { Baud Rate } \end{gathered}$ | $\begin{gathered} \text { Power } \\ \text { Supplies } \end{gathered}$ | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| COM 1653A | MII STD1553A UART | MIL-STD-1553 (Manchester) Interface Controller | 1 MB | +5 | 40 DIP | 27-42 |
| COM 1671 | ASTRO | Asynchronous/Synchronous Transmitter/Receiver, Full Duplex, 5-8 data bit, 1X or 32X clock | 1 MB | $+5,-5,+12$ | 40 DIP | 43-58 |
| COM 1863 | UART | Untversal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, $1,11 / 2,2$ stop bit, enhanced distortion margin | 62.5 KB | $+5$ | 40 DIP | 59-66 |
| COM 2017 | UART | Universal Asynchronous Recelver Transmitter, Full Duplex, 5-8 data bit, $1,11 / 2,2$ stop bit | 25 KB | $+5,-12$ | 40 DIP | 67-74 |
| COM 2017H | UART | Untversal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, 1, 11/2, 2 stop bit | 40 KB | $+5,-12$ | 40 DIP | 67-74 |
| COM 2449 | RSA49-USART | RS 449 Compatible Universal Synchronous/Asynchronous Receiver/Transmitter | 1 MB | +5 | 40 DIP | 75-90 |
| COM 2502 | UART | Universal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, 1, 2 stop bit | 25 KB | $+5,-12$ | 40 DIP | 67-74 |
| COM 2502H | UART | Universal Asynchronous Recelver/ Transmitter, Full Duplex, 5-8 data bit, 1, 2 stop bit | 40 KB | $+5,-12$ | 40 DIP | 67-74 |
| COM 2601 | USRT | Universal Synchronous Recelver/ Transmitter, STR, BSC, Bi-sync compatible | 250 KB | $+5,-12$ | 40 DIP | 91-98 |
| COM 2651 | USART/PCI | Universal Synchronous/Asynchronous Receiver/Transmitter, Full Duplex, 5-8 data bits; 1, 112, 2 stop bit, 1X, 16X, 64 X clock | 1 MB | +5 | 28. DIP | 99.110 |
| COM 2681 | USART/EPCI | Universal Synchronous/Asynchronous Receiver/Transmitter, Full Duplex, 5-8 data bits; 1, 1 1/2, 2 stop bit, 1X, 16X, 64X clock | 1 MB | +5 | 28 DIP | 111-122 |
| COM 5025 | Multi-Protocol USYNRT | SDLC, HDLC, ADCCP, Bi-sync, DDCMP compatible, automatic bit stuffing/ stripping, frame detection/generation, CRC generation/checking, sync detection | 1.5 MB | $+5,+12$ | 40 DIP | 123-134 |
| COM 8004 | 32 Bit CRC Generator/ Checker | Companion device to COM 5025 for 32 blt CRC | 2.0 MB | +5 | 20 DIP | 135-140 |
| COM 8017 | UART | Universal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, 1, $11 / 2,2$ stop bit | 40 KB | $+5$ | 40 DIP | 141-148 |
| COM 8018 | UART | Universal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, 1, $1^{1 / 2}, 2$ stop bit, enhanced distortion margin | 62.5 KB | $+5$ | 40 DIP | 59-66 |
| COM 8251A | USART | Universal Synchronous/Asynchronous Receiver/Transmitter, Full Duplex, 5-8 data bit, $1,11 / 2,2$ stop bit | $\begin{aligned} & 64 \mathrm{~KB} \text { (sync) } \\ & 9.6 \mathrm{~KB} \text { (async) } \end{aligned}$ | +5 | 28 DIP | 149-164 |
| COM 8502 | UART | Untversal Asynchronous Receiver/ Transmitter, Full Duplex, 5-8 data bit, 1, 2 stop bit | 40 KB | +5 | 40 DIP | 141-148 |

# MIL-STD-1553A "SMART" 

## FEATURES

Support of MIL-STD-1553AOperates as a: Remote Terminal Responding Bus Controller InitiatingPerforms Parallel to Serial Conversion when TransmittingPerforms Serial to Parallel Conversion when ReceivingCompatible with HD-15531 Manchester Encoder/ DecoderAll Inputs and Outputs are TTL Compatible Single +5 Volt SupplyCOPLAMOS® $N$ Channel MOS Technology
$\square$ Available in PC Board Form from Grumman
Aerospace Corporation

PIN CONFIGURATION


## GENERAL DESCRIPTION

The COM 1553A SMART® (Synchronous Mode Avionics Receiver/Transmitter) is a special purpose COPLAMOS N -Channel MOS/LSI device designed to provide the interface between a parallel 8 -bit bus and a MIL-STD1553A serial bit stream.
The COM 1553A is a double buffered serial/parallel and parallel/serial converter providing all of the "hand shaking" required between a Manchester decoder/ encoder and a microprocessor as well as the protocol handling for both a MIL-STD-1553 bus controller and remote terminal.

The COM 1553A performs the following functions in response to a 16 bit Command Word. It provides address detection for the first five bits of the serial data input. If all 1's appear in the address field, a broadcast signal is generated. The sixth bit is decoded as mode: transmit or receive. The next five bits are decoded for zero message flag and special flags in the subaddress/mode field. The last five bits (word-count field) are decoded determining the number of words to be received or transmitted.

When receiving data sync the COM 1553A performs a serial to parallel conversion, buffers the 16 bit message
word, and formats it into two parallel (8 bit) bytes for presentation to the I/O bus under processor or hard wired logic control.
In the transmit mode the COM 1553A takes two parallel 8 bit data words from the I/O bus and serially transmits the resultant 16 bit word to the Manchester encoder. This is done under the control of Send Data. To facilitate data transfer the COM 1553A provides all necessary buffering and storage for transmitted and received data. It also provides all necessary hand shaking, control flags and interrupts to a processor or hard wired logic terminal. See block diagram 1.
The COM 1553A can be set up as either a remote terminal or a bus controller interface.
The COM 1553A is compatible with Harris' HD-15531 CMOS Manchester Encoder-Decoder chip and interfaces directly with it. A 3 device kit consisting of: SMC's COM 1553A, Harris' HD-15531 and Circuit Technology's CT1231 forms a complete system interface for the message structure of MIL-STD-1553A. See block diagram 2.
Note: All terminology utilized in this data sheet is consistent with MIL-STD-1553.


| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 1 | " 0 " MESSAGE FLAG | QMF | The ZERO MESSAGE FLAG output is set when the 7th through 11th bits of the NRZ serial input data in a command envelope (see figure 1) are zero. 6MF is an open drain output. |
| 2 | " 0 " WORD FLAG | ØWF | The ZERO WORD FLAG output is set when the 12th through 16th bits of the NRZ serial input data in a command envelope (see figure 1 ) are zero. ØWF is an open drain output. |
| 3 | INVALID WORD FLAG | IVWF | The INVALID WORD FLAG output is set when the word just received has an invalid parity bit or invalid format. IVWF is an open drain output. |
| 4 | DATA AVAILABLE | DTA AVL | DATA AVAILABLE is set when a word received is ready to be read. When the COM 1553A is the bus controller, DTA AVL occurs on command, status or data words. When the COM 1553A is a remote terminal, DTA AVL is set only on data words. DTA AVL is an open drain output. |
| 5 | RECEIVE INTERRUPT | $\overline{\mathrm{RCV}}$ INT | RECEIVE INTERRUPT is set to zero when the 6th bit following a command sync is a zero and the first5 bits match AD1-AD5. $\overline{\text { RCV INT }}$ is reset to one by IA or POR, or if the line is not active for 32 receive clocks. |
| 6 | TRANSMIT INTERRUPT | $\overline{\text { TX INT }}$ | TRANSMIT INTERRUPT is set to zero when the 6th bit following a command sync is a one, and the first 5 bits matchAD1-AD5. TXINT is reset to one by $\overline{\mathrm{A}}$ or $\overline{\mathrm{POR}}$. |
| 7 | COMMAND SYNC | CMD SYN | COMMAND SYNC is an input from the Manchester decoder and must be high for 16 receive clocks enveloping the receive NRZ data of a command word. |
| 8 | DATA SYNC | DTA SYN | DATA SYNC is an input from the Manchester decoder and must be high for 16 receive clocks enveloping the receive NRZ data of a data word. |
| 9 | RECEIVER NRZ | RCV NRZ | Receiver serial input from Manchester decoder. Data must be stable during the rising edge of the receive clock. |
| 10 | $\begin{aligned} & \text { STATUS WORD } \\ & \text { ENABLE } \end{aligned}$ | $\overline{\text { SWE }}$ | $\overline{\text { SWE }}$ is the output enable for the following open drain outputs: <br> 0MF <br> ØWF <br> IVWF <br> DTA AVL <br> DTA RQ <br> MSG CPLT |
| 11 | POWER ON RESET | $\overrightarrow{\text { POR }}$ | POWER ON RESET. Active low for reset. |
| 12 | INTERRUPT ACKNOWLEDGE | $\overline{\text { IA }}$ | $\overline{\mathrm{IA}}$ resets $\overline{\mathrm{TX} \text { INT, }} \overline{\mathrm{REC} \text { INT, }}$ ØMF, ØWF and $\overline{\mathrm{BRD} \mathrm{CST}} \overline{\mathrm{IA}}$ may occur between the trailing edges of receive clocks 6 and 10, or between the leading edge of receive clock 12 and the falling edge of receiveclock 15 , or after the falling edge of clock 17. |
| 13 | RECEIVE CLOCK | RCV CLK | The RECEIVE CLOCK is synchronous with the Receiver NRZ input during the command sync or data sync envelopes. |
| 14 | VALID WORD | VW | This input is driven by the VALID WORD output of the Manchester Decoder. VW should occur immediately after the rise of the first RCV CLK following the fall DATA SYNC or COMMAND SYNC. |

DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 15 | SEND DATA | SD | SEND DATA is a "handshake" signal received from the Manchester encoder indicating that the encoder is ready for the COM 1553A to transmit data. SD will bracket 16 transmit data clocks. The contents of the transmitter buffer will be transferred into the transmit register when SD is low. |
| 16 | DATA REQUEST | DTA RQST | DATA REQUEST is an open drain output which is set high when the transmitter holding register is ready to accept more data. |
| 17 | MESSAGE COMPLETE | $\overline{\text { MSG CMPLT }}$ | In the receive mode the MESSAGE COMPLETE output is set low when the appropriate number of data words have been received. In the transmit mode, MSG CMPLT indicates that the appropriate number of command, status or data words have been transmitted. When the COM 1553A is a bus controller, MSG CMPLT will be asserted low when 33 command status or data words have been transmitted. MSG CMPLT is an open drain output. |
| 18 | TRANSMIT ENABLE | TXENA | A TRANSMIT ENABLE signal will be sent to the Manchester Encoder to initiate transmission of a word. TXENA is generated under the following conditions: <br> 1) COM 1553A is a bus controller: A TXMODE pulse will set TXENA. A second TXMODE pulse will reset TXENA. <br> 2) COM 1553A is a remote terminal. A Transmit Command from the Controller will cause a TRANSMIT INTERRUPT (see pin 6). When this is acknowledged by a TXMODE pulse from the system, TXENA will be set. <br> TXENA will then be reset by either <br> A) Send Data Command associated with the last data word. <br> B) a second TXMODEpulse. <br> 3) COM 1553 A is a remote terminal. The falling edge of a DATA SYNC associated with the last data word of a message while in the receive mode. TXENA will be reset during the next SEND DATA envelope. |
| 19 | TRANSMIT CLOCK | TXCLK | Transmitter shift clock. |
| 20 | TRANSMIT NRZ | XMIT NRZ | Serial data output to the Manchester Encoder. |
| 21 | $\overline{\text { BUS CONTROLLER }}$ | $\overline{B C}$ | $\overline{\mathrm{BC}}$ determines whether the COM 1553A is acting as bus controller ( $\overline{\mathrm{BC}}=0$ ) or as a remote terminal $(\overline{\mathrm{BC}}=1)$. |
| 22 | TRANSMIT MODE | TXMODE | TXMODE is a system input controlling transmission. See TXENA (pin 18). |
| 23 | TAKE DATA ENABLE | $\overline{T D E}$ | $\overline{T D E}$ is an input from the system initiating transmission. Two $\overline{T D E}$ pulses are required for each 16 bit data word, one for each 8 data bits placed on D $\emptyset-D 7$. |
| 24-31 | DATA BUS | D0-D7 | Bidirectional 8 bit Data Bus to the system. D0 is the LSB. Dø-D7 present open drain outputs. |
| 32 | $\overline{\text { READ DATA ENABLE }}$ | $\overline{\text { RDE }}$ | $\overline{R D E}$ is an input from the system instructing the COM 1553A to place the received data onto D0-D7. Two $\overline{\text { RDE }}$ pulses are required per 16 bit data word, one for each 8 bits. |
| 33-37 | ADDRESS | AD5-AD1 | AD1-AD5 provide addressing to the COM 1553A. Each input has a pull-up resister allowing simple switching to ground to select theuser address. |
| 38 | POWER SUPPLY | VCC | +5 Volt supply. |
| 39 | BROADCAST | $\overline{\text { BDCST }}$ | $\overline{\mathrm{BDCST}}$ is set low when a "broadcast" command word (the address bits all set to "one") is being received. $\overline{B D C S T}$ is reset by $\overline{\mathrm{I}}$. |
| 40 | GROUND | GND | Ground |

## OPERATION...RECEIVE MODE

The COM 1553A is considered in the receive mode when TXENA $=0$. The most significant bit of both command and data words is received first.
Message reception is initiated when CMD SYN goes high. The next 16 receive clocks are used to shift serial data into RCV NRZ.
The first 5 bits of a command word designate a remote terminal address. These 5 bits are compared with AD1-5. Should the address bits compare, the sixth bit is examined. If it is a zero, a RECEIVE INTERRUPT is generated. If it is a one, a TRANSMIT INTERRUPT is generated.
Bit fields $7-11$ and 12-16 are examined for all zeros. All zeros in bit field 7-11 denotes a "ZERO MESSAGE" and all zeros in bit field 12-16 denotes a "ZERO WORD."
Receipt of a data word is indicated when DTA SYN goes high.
When DTA SYN or CMD SYN goes low, the contents of the 16 bit receive register are loaded into the receive buffer. The buffer is organized into two groups of 8 bits each. The most significant 8 bits (byte 1) will be enabled onto the 8 bit data bus on receipt of the first $\widehat{\text { RDE pulse }}$ ( $\overline{\mathrm{RDE}}$ ). The second byte will be enabled on receipt of the second $\overline{\mathrm{RDE}}$ pulse ( $\overline{\mathrm{RDE} 2}$ ).
A DATA AVAILABLE is generated for data words only. However, data will be available on DO-D7 for both command and data words.

If 32 clocks are received after the rising edge of CMD SYN or DTA SYN an "Idle Line Reset" condition exists. This implies that a new CMD SYN or DTA SYN has not yet been received within 16 clocks of the fall of the previous sync signal. The "Idle Line Reset"will reset the following signals:
REC INT
TX INT $\quad$ " 0 " MSG FLG
$\overline{B R D}$ CST
When the commanded number of data words have been received, a MESSAGE COMPLETE signal is generated.
As the transmitter and receiver registers operate independently, the COM 1553A will receive its own transmission. The following signals are inhibited during transmission:


## OPERATION...TRANSMIT MODE

The COM 1553A is considered in the transmit mode when TXENA $=1$. This is caused by a TXMODE pulse (see description of pin functions, pin 18). The TXMODE pulse in turn is a system response to a transmit command from the receiver.
When the Manchester Encoder receives TXENA $=1$, it will respond with SEND DATA $=1$. The COM 1553A will then send the system a DATA REQUEST.
Data is loaded into the transmitter data buffer from the 8 bit data bus by pulsing TDE. The 8 most significant bits are loaded in by the first TDE pulse (TDE1), the 8 least significant bits by the second TDE pulse (TDE2).
When SEND DATA (pin 15) is low, the transmitter shift register inputs will follow either the transmit buffer output, JAM ADDRESS or JAM MESSAGE ERROR signals. When SEND DATA is high, the shift register parallel inputs are disabled and the shift register contents are shifted out in NRZ form using the 16 negative edges in the send data envelope.
To facilitate transmission of the status word from a remote terminal, the COM 1553A will "jam" the first (most significant) 6 bits of the status word into the transmit register when $\overline{B C}$ is high. These bits will automatically be sent at the first SEND DATA pulse. In general for MIL-STD-1553A the remaining 10 bits will normally be all zeros and will automatically be sent out as such. If it is desired to send additional status information (for MIL-STD-1553B), a TDE1 pulse will load
the least significant 2 bits of the first 8 bit byte, and a TDE2 will load all 8 bits of the second byte. Note that these TDE pulses must be sent (and data presented) before the first SD $=1$ response from the Manchester Encoder.
A JAM ADDRESS occurs when 1) a transmit command is addressed to the COM 1553A 2) A TXMODE pulse is received and 3) a valid word signal is received. Upon a JAM ADDRESS the COM 1553A will load its address into the first 5 bits of the transmit register.
Alternatively, a JAM ADDRESS will also occur at the fall of the last data sync after valid receive command has been detected.
The JAM ADDRESS function will be inhibited if a " 0 " word and " 0 " message condition exists in the command word. The JAM ADDRESS will be reset by the leading edge of SEND DATA.
The JAM MESSAGE ERROR function occurs when, in the receive mode, a data word is not followed by a VALID WORD signal. JAM MESSAGE ERROR consists of loading a one in the sixth bit location of the transmit shift register (the message error location).
JAM MESSAGE ERROR is inhibited when the transmit command word contains " 0 " Message and " 0 " Word fields.
When the commanded number of data words has been transmitted a MESSAGE COMPLETE signal will be generated.

## general operation notes

1. $\overline{B U S}$ CONTROLLER. When $\overline{B C}=0$, signifying that the COM 1553 A is the bus controller the following is true:
A. DTA AVL is generated on the rising edge of the 17 th receive clock following a Command Sync or Data Sync. This allows the bus controller to receive command, status or data words regardless of their address.
B. TXENA is contingent only on TXMODE. A bus controller can therefore transmit whenever it desires.
C. The jam functions are inhibited.
2. INVALID WORD FLAG. When $\overline{B C}=0$, IVWF will be set if the Valid Word input (from the Manchester decorder) does not go high following receipt of all words. This includes words received from the same device's transmitter. (This provides a validity test of the controller transmission).
When $\overline{B C}=1$, IVWF will be set if Valid Word does not go high following receipt of all command and address words addressed to the terminal.
IVWF will be set for the following conditions:

| Message type | Word | Terminal is | IVWF generated |
| :--- | :--- | :--- | :--- |
| Transit Group | Transmit command | receiving | yes |
|  | Status word | transmitting | no |
| Receive Group | Data word | transmitting | no |
|  | Receive command | receiving | yes |
|  | Data word | receiving | yes |
| Receive/Transmit | Status word | transmitting | no |
| Group (this | Receive command | receiving | yes |
| terminal addressed | Transmit command | receiving | no |
| to receive) | Status word | receiving | no |
|  | Data word | receiving | yes |
| Receive/Transmit | Status word | transmitting | no |
| group (this terminal | Receive command | receiving | no |
| addressed to | Transmit command | receiving | yes |
| transmit) | Status word | transmitting | no |
|  | Data word | transmitting | no |

3. $\overline{\text { POWER ON RESET. During power-up, } \overline{\text { POR }} \text { is a low to high exponential with a minimum low time, after the }}$ supply is within specified limits, of 10 microseconds. $\overline{\text { POR }}$ may also occur asynchronously anytime after power has stabilized.
$\overline{\text { POR }}$ initializes the following outputs:

| ØMG | $\overline{R E C ~ I N T ~}$ | $\overline{T D E}$ |
| :--- | :--- | :--- |
| ØWF | $\overline{M S G ~ C M P L T}$ | DTA AVL |
| $\overline{\text { BRD CST }}$ | IVW | TXENA |
| $\overline{\text { XMT INT }}$ | $\overline{\text { RDE }}$ | DTA RQ |

The following circuit may be used to implement $\overline{\text { POR }}$.

4. WORD COUNT: Word count is decoded as follows:

| $D 1$ | D2 | D3 | D4 | D5 | Word Count |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 1 | 1 |
| 0 | 0 | 0 | 1 | 0 | 2 |
| 1 | 1 | 1 | 1 | 1 | 31 |
| 0 | 0 | 0 | 0 | 0 | 32 |

## TRANSMIT TIMING FIGURE 1



## MAXIMUM GUARANTEED RATINGS*


*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the $A C$ power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS ( $T_{A}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{cc}}=+5 \pm 5 \%$, unless otherwise noted)

| PARAMETER | MIN | TYP | MAX | UNIT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DC CHARACTERISTICS |  |  |  |  |  |
| Input Voltage Levels Low Level, VIL High Level, $\mathrm{V}_{\mathrm{IH}}$ | 3.0 |  | 0.8 | V |  |
| Output Voltage Levels Low Level Vol High Level Vон Low Level Vol | 3.0 | 4.0 | 0.4 0.4 | $V$ $V$ $V$ | los $=-1.6 \mathrm{~mA}$, except open drain Іон $=100 \mu \mathrm{~A}$, except open drain lot $=-1.6 \mathrm{~mA}$, open drain output |
| Output Leakage, ILo |  |  | 10 | $\mu \mathrm{A}$ |  |
| Input Current, AD1-AD5 |  | 60 |  | $\mu \mathrm{A}$ | $\mathrm{V}_{1 \mathrm{~N}}=0 \mathrm{~V}$ |
| Output Capacitance |  | 5 | 10 | pf |  |
| Input Capacitance |  | 10 | 25 | pf |  |
| Power Dissipation |  |  | 500 | mW |  |


| PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AC CHARACTERISTICS |  |  |  |  |  |  |
| Clock Frequency |  | 980 | 1000 | 1020 | KHz |  |
| Clock Duty Cycle |  | 45 | 50 | 55 | \% |  |
| Rise and fall times, $\overline{\mathrm{IA}}, \overline{\text { TDE }}$ TXMODE, SWE, RDE | tr, tf |  |  | 20 | ns |  |
| rise and fall times, all other inputs | tr, t f |  |  | 50 | ns |  |
| receiver clock-NRZ | trn |  |  | 65 | ns | figure 3B |
| receiver clock-sync delay | tsh |  |  | 85 | ns | figure $3 B$ |
| receiver clock-VW delay | trv |  |  | 100 | ns | figure 3 B |
| VW reset delay | tvs |  |  | 500 | ns | figure 3 C |
| transmit clock-TX ENA delay | ttx | 25 |  |  | ns | figure 4A |
| TX ENA pulse width | txw | 60 |  |  | ns | figure 4A |
| transmit clock-send data set-up | trs |  |  | 40 | ns | figure 4B |
| transmit clock-send data hold time | tst |  |  | 140 | ns | figure 4C |
| transmit clock fall to NRZ | tin | 0 |  |  | ns | figure 4B |
| transmit clock rise to NRZ | tnt | 95 |  |  | ns | figure 4B |
| TXMODE pulse width | tmw | 150 |  |  | ns | figure 5A |
| TXMODE to TX ENA delay | tmx |  |  | 750 | ns | figure 5 B |
| VALID word to TX ENA delay | tux |  |  | 750 | ns | figure 5B |
| Data sync to TX ENA delay | tox |  |  | 750 | ns | figure 5C |
| TX ENA reset delay | tsx |  |  | 750 | ns | figure 5C |
| DATA SET-up time | tor | 100 |  |  | ns | figure 6A |
| TDE pulse width | to2 | 150 |  |  | ns | figure 6A |
| Data Hold time | to3 | 100 |  |  | ns | figure6A |
| Cycle time | to4 | 450 |  | 16000 | ns | figure 6A |
| DTA RQST Delay | tos | 450 |  |  | ns | figure 6A |
| Output Enable time | tob | 100 |  |  | ns | figure 6B |
| RDE Pulse width | tor | 150 |  |  | ns | figure 6B |
| receive cycle time | tos | 450 |  | 17000 | ns | figure 6 B |
| Flag delay time | tog | 450 |  |  | ns | figure 68 |
| Output disable time | tol0 | 100 |  |  | ns | figure 68 |
| SEND DATA delay | tol1 | 2.5 |  | 3.5 | $\mu \mathrm{s}$ | figure6C |
| TDE off delay | to 12 | 1.5 |  |  | $\mu \mathrm{s}$ | figure 6C |
| TDE1 delay | to 13 | 500 |  |  | ns | figure6C |
| SYN to $\overline{\text { RDE }}$ | to14 | 500 |  |  | ns | figure 6 D |
| RDE to SYN | to15 |  |  | 2.5 | $\mu \mathrm{s}$ | figure 6 D |
| Status word Enable | tse |  |  | 100 | ns | figure 8A |
| Status word Disable | tso |  |  | 100 | ns | figure 8A |
| Flag delay time | tcf |  |  | 1 | $\mu \mathrm{s}$ | figure 8B |
| VW delay time | tcv |  |  | 90 | ns | figure 8B |
| IVWF delay time | tcı |  |  | 450 | ns | figure 8B |
| DTA AVL delay time | tco |  |  | 500 | ns | figure 8B |
| DTA RQST delay time | tsh |  |  | 450 | ns | figure 8C |
| BRD CST delay time | tre |  |  | 2 | $\mu \mathrm{s}$ | figure 8 C |
| BRD CST pulse width | tew | 1 |  |  | $\mu \mathrm{s}$ | figure 8D |
| flag reset delay | tis |  |  | 750 | ns | figure 8D, 8E |
| Interrupt delay | tri |  |  | 1.5 | $\mu \mathrm{s}$ | figure 8D |
| IA pulse width | tia | 150 |  |  | ns | figure 8D |
| Interrupt pulse width | tiw | 1 |  |  | $\mu \mathrm{s}$ | figure 8D |
| Flag reset time | $t_{\text {tra }}$ |  |  | 450 | ns | figure 8 F |
| DTA AVL reset delay | tro |  |  | 750 | ns | figure 8 F |
| IVWF reset delay | tav |  |  | 750 | ns | figure 8 F |
| MSG CMPLT turn-on delay | tma |  |  | 1.5 | $\mu \mathrm{s}$ | figure 9A, 9B |
| MSG CMPLT turn-on delay | tmp |  |  | 1.5 | $\mu \mathrm{s}$ | figure9A, 9C |

RECEIVE TIMING FIGURE 2


RECEIVER INPUT TIMING FIGURE 3
3A


3B


3C


TRANSMITTER TIMING FIGURE 4
4A


4C


## TRANSMIT ENABLE (TX ENA) TIMING FIGURE 5

5A

*THIS IS A CMD WORD BEING RECEIVED, IT IS ADDRESSED TO THIS BUFFER AND THE T/R BIT = 1. TX ENA IS RESET BY 2ND TXMODE NEGATIVE TRANSITION OR BY LAST SEND DATA (MESSAGE COMPLETE FUNCTION).

** THIS IS THE LAST DATA WORD BRING RECEIVED. THIS TERMINAL PREVIOUSLY
HAD RECEIVED A REC CMD WORD WITH OUR ADDRESS AND A REC/XMIT BIT $=0$ DURING THIS MESSAGE SEQUENCE. TX ENABLE IS SET BY MSG CMPLT FUNCTION AND RESET BY RECEIPT OF SEND DATA.

## DATA BUS TIMING FIGURE 6



DATA BUS TIMING FIGURE 6

6C


NOTE: SEND DATA RISING EDGE INITIALIZES TDE TO TDE1 STATE

6D


## $\overline{\text { IA }}$ RESETS FIGURE 7



T̄A OCCURRING DURING ZONE A RESETS: BRD CST. TX INT. REC INT. $\bar{I} \bar{A}$ OCCURRING DURING ZONE B RESETS: BRD CST. TX INT. REC INT. "0" MSG FLG IA OCCURRING DURING ZONE C RESETS: BRD CST. TX INT. REC INT. "0" MSG FLG. " 0 " WRD FLG

## STATUS FLAGS FIGURE 8

8A

8B


8C


8D


## message Complete figure 9

## BUS CONTROLLER MODE


*WORD COUNTER IS PRESET TO 33
-"MSG CMPLT SET tma MAX AFTER RISE OF 33RD SEND DATA PULSE

REMOTE TERMINAL, RECEIVE COMMAND RECEIVED

9B

9C

*WORD COUNTER PRESET TO COUNT IN COMMAND WORD **MSG CMPLT GENERATED BY LAST DATA SYNC OF THE MESSAGE GROUP

REMOTE TERMINAL, TRANSMIT COMMAND RECEIVED


[^3] PLUS 1. THIS ALLOWS FOR THE STATUS WORD.
*MSG CMPLT GENERATED BY THE LAST SEND DATA OF THE TRANSMIT MESSAGE GROUP.

TYPICAL SYSTEM OPERATION



## OPEN DRAIN OUTPUT

FIGURE 10


## D0-D7 INPUT/OUTPUT

FIGURE 11


## OTHER OUTPUTS

FIGURE 12


# Asynchronous/Synchronous Transmitter-Receiver 

## ASTRO

FEATURES
$\square$ SYNCHRONOUS AND
ASYNCHRONOUS
Full Duplex Operations
SYNCHRONOUS MODE
Selectable 5-8 Bit Characters
Two Successive SYN Characters Sets Synchronization
Programmable SYN and DLE Character Stripping
Programmable SYN and DLE-SYN Fill
ASYNCHRONOUS MODE
Selectable 5-8 Bit Characters
Line Break Detection and Generation
1-, 11/2-, or 2-Stop Bit Selection
Start Bit Verification
Automatic Serial Echo Mode
BAUD RATE-DC TO 1M BAUD
8 SELECTABLE CLOCK RATES
Accepts $1 \times$ Clock and Up To 4 Different 32X Baud Rate Clock Inputs
Up to 47\% Distortion Allowance With 32X Clock
SYSTEM COMPATIBILITY
Double Buffering of Data
8-Bit Bi-Directional Bus For Data, Status, and Control Words
All Inputs and Outputs TTL Compatible
Up To 32 ASTROS Can Be Addressed On Bus
On-Line Diagnostic Capability
ERROR DETECTION
Parity, Overrun and Framing

PIN CONFIGURATION

| Vbs 1 | 40 Vdo |
| :---: | :---: |
| IACKIC 2 | 39 PE |
| CSO 3 | $38 . \overline{C A}$ (RTS) |
| WEL | 37 P BA (tso) |
| IACKO 5 | $36 \sim$ CB (CTS) |
| RPLY 6 | $350 \overline{D B}$ ( $\overline{1 \times T C})$ |
| INTR 7 | $34 \bigcirc \overline{\mathrm{DD}}$ ( (\%) $\overline{\mathrm{ICC}})$ |
| DAL $\varnothing$ ¢ 8 | 33 P 4 |
| $\overline{\text { DALT }} 9$ | 32 P R |
| DAL2 10 | 31 R2 |
| DAL3 11 | $30 \mathrm{PR1}$ |
| DAL4 12 | 29 PCF (CARA) |
| DALS 13 | $28 \mathrm{p}_{\text {CC }}$ (DSF) |
| DAL6 14 | 27 P 昭 (HSI) |
| DAL7 15 | $26 \mathrm{~T} \overline{\text { D3 }}$ |
| (DTR) $\overline{C D} 16$ | 25 ¢ $\overline{\text { D4 }}$ |
| 10717 | $24 \overline{\text { D5 }}$ |
| ( RING ) $\overline{\mathrm{CE}}$ ( 18 | 23 MR |
| $\overline{\text { MISC }} 19$ | $22 \bigcirc \overline{\mathrm{DC}}$ |
| $\left(V_{5 s}\right)$ GND[ 20 | 21 JVcc |

COPLAMOS ${ }^{\circledR}$ n-Channel Silicon Gate Technology
$\square$ Pin for Pin replacement for Western Digital UC1671 and National INS 1671
$\square$ Baud Rate Clocks Generated by COM5036@1X and COM5016-6@32X

## APPLICATIONS

Synchronous Communications Asynchronous Communications Serial/Parallel Communications

## General Description

The COM1671 (ASTRO) is a MOS/LSI device which performs the functions of interfacing a serial data communication channel to a parallel digital system. The device is capable of full duplex communications (receiving and transmitting) with synchronous or asynchronous systems. The ASTRO is designed to operate on a multiplexed bus with other bus-oriented devices. Its operation is programmed by a processor or controller via the bus and all parallel data transfers with these machines are accomplished over the bus lines.

The ASTRO contains several "handshaking" signals to insure easy interfacing with modems or other peripheral devices such as display terminals. In addition, a programmable diagnostic mode allows the selection of an internal looping feature which allows the device to be internally connected for processor testing.

The COM1671 provides the system communication designer with a software responsive device capable of handling complex communication formats in a variety of system applications.


## Organization

Data Access Lines - The DAL bus is an 8-bit bi-directional port over which all address, data, control, and status transfers occur. In addition to transferring data and control words the DAL bus also transfers information related to addressing of the device, reading and writing requests, and interrupting information.
Receiver Buffer - This 8-bit parallel register presents assembled received characters to the DAL bus when requested through a Read operation.
Receiver Register - This 8-bit shift register inputs the received data at a clock rate determined by Control Register 2. The incoming data is assembled to the selected character length and then transferred to the Receiver Buffer with logic zeroes filling out any unused high-order bit positions.
Syn Register - This 8-bit register is loaded from the DAL bus by a Write operation and holds the synchronization code used for receiver character synchronization. It serves as a fill character when no new data is available in the Transmitter Buffer during transmission. This register cannot be read onto the DAL bus. It must be loaded with logic zeroes in all unused high-order bits.

Comparator - The 8-bit comparator is used in the Synchronous mode to compare the assembled contents of the Receiver Register and the SYN register or the DLE register. A match between the registers sets up stripping of the received character, when programmed, by preventing the data from being loaded into the Receiver Buffer. A bit in the Status Register is set when stripping is effected. The comparator output also enables character synchronization of the Receiver on two successive matches with the SYN register.
DLE Register - This 8-bit register is loaded from the DAL bus by a Write operation and holds the DLE character used in the Transparent mode of operation in which an idle transmit period is filled with the combination DLE-SYN pair of characters rather than a single SYN character. In addition the ASTRO may be programmed to force a single DLE character prior to any data character transmission while in the transmitter transparent mode.
Status Register - This 8-bit register holds information on communication errors, interface data register status, match character conditions, and communication equipment status. This register may be read onto the DAL bus by a Read operation.

Control Registers - There are two 8-bit Control Registers which hold device programming signals such as mode selection, clock selection, interface signal control, and data format. Each of the Control Registers can be loaded from the DAL bus by a Write operation or read onto the DAL bus by a Read operation. The registers are cleared by a Master Reset.
Transmitter Buffer - This 8-bit parallel register holds data transferred from the DAL bus by a Write operation. This data is transferred to the Transmitter Register when the transmitter section is enabled and the Transmitter Register is ready to send new data.
Transmitter Register - This 8-bit shift register is loaded from the Transmitter Buffer, SYN register, or DLE register. The purpose of this register is to serialize data and present it to the serial data output.

## Astro Operation

## Asynchronous Mode

Framing of asynchronous characters is provided by a Start bit (logic 0 ) at the beginning of a character and a Stop bit(s) (logic 1) at the end of a character. Reception of a character is initiated on recognition of the first Start bit by a positive transition of the receiver clock, after a preceding Stop bit(s). The Start and Stop bits are stripped off while assembling the serial input into a parallel character.

The character assembly is completed by the reception of the Stop bit(s) after reception of the last character bit (including the parity bit, if selected). If the Stop bit(s) is a logic 1, the character is determined to have correct framing and the ASTRO is prepared to receive the next character. If the Stop bit(s) is a logic 0, the Framing Error Status flag is set and the Receiver assumes this bit to be the Start bit of the next character. Character assembly continues from this point if the input is still a logic 0 when sampled at the theoretical center of the assumed Start bit. As long as the Receiver input is spacing, all zero characters are assembled and error flags and data received interrupts are generated so that line breaks can be determined. After a character of all zeroes is assembled along with a zero in the Stop bit(s) location, the first sampled logic one is determined as a Stop bit and this resets the Receiver circuit to a Ready state for assembly of the next character.

In the Asynchronous mode the character transmission occurs when information contained in the Transmitter Buffer is transferred to the Transmitter Register. Transmission is initiated by the insertion of a Start bit, followed by the serial output of the character (including the parity bit, if selected), then the insertion of a $1,1.5$, or 2 bit length Stop condition. If the Transmitter Buffer is full, the next character transmission starts after the transmission of the Stop bit(s) of the present character in the Transmitter Register. Otherwise, the Mark (logic 1) condition is continually transmitted until the Transmitter Buffer is loaded.

## Synchronous Mode

Framing of characters is carried out by a special Synchronization Character Code (SYN) transmitted at the beginning of a block of characters. The Receiver, when enabled, searches for two contiguous characters matching the bit pattern contained in the SYN register. During the time the Receiver is searching, data is not transferred to the Receiver Buffer, status bits are not updated, and the Receiver interrupt is not activated. After the detection of the first SYN character, the Receiver assembles subsequent bits into characters whose length is determined by the contents of Control Register 2. If, after the first SYN character detection, a second SYN character is present, the Receiver enters the Synchronization mode until the Receiver Enable Bit is turned off. If a second successive SYN character is not found, the Receiver reverts back to the Search mode.

In the Synchronous mode a continuous stream of characters are transmitted once the Transmitter is enabled. If the Transmitter Buffer is not loaded at the time the Transmitter Register has completed transmission of a character, this idle time will be filled by a transmission of the character contained in the SYN register in the Non-transparent mode, or the characters contained in the DLE and SYN registers respectively while in the Transparent mode of operation.

## Astro Operation

## Receiver

The Receiver Data input is clocked into the Receiver Register by a $1 \times$ Receiver Clock from a modem Data Set, or by a local 32 X bit rate clock selected from one of four externally supplied clock.inputs. When using the 1 X clock, the Receiver Data is sampled on the positive transition of the clock in both the Asynchronous and Synchronous modes. When using a 32X clock in the Asynchronous mode, the Receiver Sampling Clock is phased to the Mark-To-Space transition of the Received Data Start bit and defines, through clock counts, the center of each received Data bit with $+0 \%,-3 \%$ at the positive transition 16 clock periods later.

In the Synchronous mode the Sampling Clock is phased to all Mark-To-Space transitions of the Received Data inputs when using a 32X clock. Each transition of the data causes an incremental correction of the Sampling Check by $1 / 32$ nd of a bit period. The Sampling clock can be immediately phased to every Mark-To-Space Data transition by setting Bit 4 of Control Register 1 to a logic one, while the Receiver is disabled.

When the complete character has been shifted into the Receiver Register it is transferred to the Receiver Buffer; the unused, higher order bits are filled with logic zero's. At this time the Receiver Status bits (Framing Error/Sync Detect, Parity Error/DLE Detect, Overrun Error, and Data Received) are updated in the Status Register and the Data Received interrupt is activated. Parity Error is set, if encountered while the Receiver parity check is enabled in the Control Registers. Overrun Error is set if the Data Received status bit is not cleared through a Read operation by an external device when a new character is transferred to the Receiver Buffer. This error flag indicates that a character has been lost; new data is lost while the old data and its status flags are saved.

The characters assembled in the Receiver Register that match the content of the SYN or the DLE register are not loaded into the Receiver Buffer, and the DR interrupt is not generated, if Bit 3 of Control Register 2 (CR23) or Bit 4 of Control Register 1 (CR14) are set respectively, and SYN Detect and DLE Detect are set with the next non SYN or non DLE character. When both CR23 and CR14 are set (Transparent mode), the DLE-SYN combination is stripped. The SYN comparison occurs only with the character received after the DLE character. If two successive DLE characters are received only the first DLE character is stripped. No parity check is made while in this mode.

## Transmitter

Information is transferred to the Transmitter Buffer by a Write operation. Information can be loaded into this register at any time, even when the Transmitter is not enabled. Transmission of data occurs only when the Request to Send bit is set to a logic 1 in Control Register 1 and the Clear To Send input is logic 0 . Information is normally transferred from the Transmitter Buffer to the Transmitter Register when the latter has completed transmission of a character. However, information in the DLE register may be transferred prior to the information contained in the Transmitter Buffer if the Force DLE signal condition is enabled (Bits 5 and 6 of Control Register 1 set to a logic 1). The control bit CR15 must be set prior to loading of a new character in the Transmitter Buffer to insure forcing the DLE character prior to transmission of the data character. The Transmitter Register output passes through a flip-flop which delays the output by one clock period. When using the $1 \times$ clock generated by the Modem Data Set, the output data changes state on the negative clock transition and the delay is one bit period. When using a local 32X clock the the transmitter section selects one of the four selected rate inputs and divides the clock down to the baud rate. This clock is phased to the Transmitter Buffer Empty Flag such that transmission of characters occurs within two clock times of the loading of the Transmitter Buffer, when the Transmitter Register is empty.

When the Transmitter is enabled, a Transmitter interrupt is generated each time the Transmitter Buffer is empty. If the Transmitter Buffer is empty, when the Transmitter Register is ready for a new character, the Transmitter enters an idle state. During this idle time a logic 1 will be presented to the Transmitted Data output in the Asynchronous mode or the contents of the SYN register will be presented in the Synchronous Non-transparent mode (CR16 $=0$ ). In the Synchronous Transmit Transparent mode (CR16 $=1$ ), the idle state will be filled by DLE-SYN character transmission in that order. When entering the Transparent mode DLE must precede the contents of the Transmitter Buffer. This is accomplished by setting of Bit 5 of Control Register 1.

If the transmitter section is disabled by a reset of the Request to Send, any partially transmitted character is completed before the transmitter section of the ASTRO is disabled. As soon as the Clear To Send goes high the transmitted data output will go high.

When the Transmitter parity is enabled, the selected Odd or Even parity bit is inserted into the last data bit of the character in place of the last bit of the Transmitter Register. This limits transfer of character information to a maximum of seven bits plus parity or eight bits without parity. Parity cannot be enabled in the Synchronous Transparency mode.

## Input/Outpuł Operations

All Data, Control, and Status words are transferred over the Data Access Lines (DAL 0-7). Additional input lines provide controls for addressing a particular ASTRO, and regulating all input and output operations. Other lines provide interrupt capability to indicate to a Controller that an input operation is requested by the ASTRO. All input/output terminology below is referenced to the Controller so that a Read or input takes data from the ASTRO and places it on the DAL bus, while a Write or Output places data from the DAL bus into the ASTRO.

A Read or Write operation is initiated by the placement of an eight-bit address on the DAL bus by the Controller. When the Chip Select signal goes to a logic 0 state, the ASTRO compares Bits $7-3$ of the DAL bus with its hard-wired ID code (Pins 17,22,24,25, and 26) and becomes selected on a Match condition. The ASTRO then sets its $\overline{\text { RPLY }}$ line low to acknowledge its readiness to transfer data. Bit 0 must be a logic O in Read or Write operation. A setup time must exist between $\overline{C S}$ and the $\overline{R E}$ or $\overline{W E}$ signals to allow chip selection prior to read/write operations.

Read
Bits 2-0 of the address are used to select ASTRO registers to read from as follows:

| Bits 2-0 | Selected Register |
| :---: | :--- |
| 000 | Control Register 1 |
| 010 | Control Register 2 |
| 100 | Status Register |
| 110 | Receiver Buffer |

When the $\overline{\text { Read Enable }} \overline{(\mathrm{RE})}$ line is set to a logic 0 condition by the Controlter the ASTRO gates the contents of the addressed register onto the DAL bus. The Read operation terminates, and the device becomes unselected, when both the Chip Select and Read Enable return to a logic 1 condition. Reading of the Receiver Buffer clears the Data Received Status bit. The data is removed from the DAL bus when the RE signal returns to the logic high state.

## Write

Bits 2-0 of the address are used to select ASTRO registers to be written into as follows:

| Bits 2-0 | Selected Register |
| :---: | :--- |
| 000 | Control Register 1 |
| 010 | Control Register 2 |
| 100 | SYN and DLE Register |
| 110 | Transmitter Buffer |

When the $\overline{\text { Write Enable }} \overline{(W E)}$ line is set to a logic 0 condition by the Controller the ASTRO gates the data from the DAL bus into the addressed register. If data is written into the Transmitter Buffer, the TBMT Status bit is cleared to a logic zero.

The 100 address loads both the SYN and DLE registers. After writing into the SYN register the device is conditioned to write into the DLE if followed by another Write pulse with the 100 address. Any intervening Read or Write operation with other addresses or other ASTROs resets this condition such that the next 100 will address the SYN register.

The following conditions generate interrupts:

## Data Received (DR)

Indicates transfer of a new character to the Receiver Buffer while the Receiver is enabled.
Transmitter Buffer Empty (TBMT)
Indicates that the Transmitter Buffer is empty while the Transmitter is enabled. The first interrupt occurs when the Transmitter becomes enabled if there is an empty Transmitter Buffer, or after the character is transferred to the Transmitter Register making the Transmitter Buffer empty.

## Carrier On

Indicates Carrier Detector input goes low and the Data Terminal Ready (DTR) bit (CR10) is high. Carrier Off
Indicates Carrier Detector input goes high and the Data Terminal Ready (DTR) bit (CR10) is high.
Data Set Ready On
Indicates the Data Set Ready input goes low and the Data Terminal Ready (DTR) bit (CR10) is high. Data Set Ready Off
Indicates the Data Set Ready input goes high and the Data Terminal Ready (DTR) bit (CR10) is high. Ring $0 n$
Indicates the Ring Indicator input goes low and the Data Terminal Ready (DTR) bit (CR10) is low.
Each time an interrupt condition exists the INTR output from the ASTRO is made a logic low. The following interrupt procedure is then carried out even if the interrupt condition is removed.

The Controller acknowledges the Interrupt request by setting the Chip Select ( $\overline{\mathrm{CS}}$ ) and the Interrupt Acknowledge Input (IACKI) to the ASTRO to a low state. On this transition all non-interrupting devices receiving the $\overline{\mathrm{ACKI}}$ signal set their Interrupt Acknowledge Output (IACKO) low, enabling lower priority daisy-chained devices to respond to the interrupt request. The highest priority device that is interrupting will then set its $\overline{R P L Y}$ line low. This device will place its ID code on Bit Positions 7-3 of the DAL bus when a low $\overline{R E}$ signal is received. The data is removed from the DAL bus when the Read Enable (RE) signal returns to the logic one state. To reset the Interrupt condition (INTR) Chip Select $\overline{(C S)}$ and $\overline{\mathrm{IACKI}}$ must be received by the ASTRO.

| Pin No. | Symbol | Pin Name | I/O | Function |
| :---: | :---: | :---: | :---: | :---: |
| 1 | $V_{\text {Bb }}$ | POWER SUPPLY | PS | - 5 Volts |
| 21 | $\mathrm{V}_{\mathrm{cc}}$ | POWER SUPPLY | PS | +5 Volts |
| 40 | $V_{\text {D }}$ | POWER SUPPLY | PS | + 12 Volts |
| 20 | $\mathrm{V}_{\text {ss }}$ | GROUND | GND | Ground |
| 23 | $\overline{\mathrm{MR}}$ | MASTER RESET | 1 | The Control and Status Registers and other controls are cleared when this input is low. |
| $\begin{array}{r} 8- \\ 15 \end{array}$ | $\frac{\overline{\text { DALO- }}}{\frac{\text { DAL }}{}}$ | $\overline{\text { DATA ACCESS LINES }}$ | 1/0 | Eight-bit bi-directional bus used for transfer of data, control status, and address information. |
| 17 | $\overline{\text { ID7 }}$ | $\overline{\text { SELECT CODE }}$ | 1 | Five input pins which when hard-wired assign the |
| 22 | ID6 |  | 1 | device a unique identification code used to select |
| 24 | $\overline{\text { ID }}$ |  | I | the device when addressing and used as an |
| 25 | $\overline{\text { D } 4}$ |  | 1 | identification when responding to interrupts. |
| 26 | $\overline{\text { IV3 }}$ |  | 1 |  |
| 3 | $\overline{\text { CS }}$ | CHIP SELECT | 1 | The low logic transition of $\overline{\mathrm{CS}}$ identifies a valid address on the DAL bus during Read and Write operations. |
| 39 | $\overline{\mathrm{RE}}$ | READ ENABLE | 1 | This input, when low, gates the contents of the addressed register from a selected ASTRO onto the DAL bus. |
| 4 | $\overline{W E}$ | WRITE ENABLE | 1 | This input, when low, gates the contents of the DAL bus into the addressed register of a selected ASTRO. |
| 7 | $\overline{\text { INTR }}$ | INTERRUPT | 0 | This open drain output, to facilitate WIRE-ORing, goes low when any interrupt conditions occur. |
| 2 | $\overline{\text { IACKI }}$ | INTERRUPT ACKNOWLEDGE IN | 1 | When the Controller (determining the interrupting ASTRO) makes this input low, the ASTRO places its ID code on the DAL bus and sets reply low if it is interrupting, otherwise it makes IACKO a low. |
| 5 | $\overline{\text { IACKO }}$ | INTERRUPT ACKNOWLEDGE OUT | 0 | This output goes low in response to a low $\overline{\text { IACKI }}$ if the ASTRO is not the interrupting device. |
| 6 | $\overline{\text { RPLY }}$ | $\overline{\text { REPLY }}$ | 0 | This open drain output, to facilitate WIRE-ORing, goes low when the ASTRO is responding to being selected by an address on the DAL bus or in affirming that it is the interrupting source. |


| Pin No. | Symbol | Pin Name | 1/0 | Function |
| :---: | :---: | :---: | :---: | :---: |
| 30 | R1 | CLOCK RATES | 1 | These four inputs accept four different local |
| 31 | R2 |  | 1 | data rate Transmit and Receive clocks. The input on |
| 32 | R3 |  | 1 | R4 may be divided down into a 32X clock from a |
| 33 | R4 |  | 1 | 32X, 64X, 128X, or 256X clock input. The clock used in the ASTRO is selected by bits $0-2$ of Control Register 2. |
| 37 | BA | TRANSMITTED DATA | 0 | This output is the transmitted serial data from the ASTRO. This output is held in a Marking condition when the transmitter section is not enabled. |
| 27 | BB | RECEIVED DATA | 1 | This input receives serial data into the ASTRO. |
| 38 | $\overline{C A}$ | REQUEST TO SEND | 0 | This output is enabled by bit 1 of Control Register 1 and remains in a low state during transmitted data from the ASTRO. |
| 36 | $\overline{C B}$ | CLEAR TO SEND | 1 | This input, when low, enables the transmitter section of the ASTRO. |
| 28 | $\bar{C}$ | $\overline{\text { DATA SET READY }}$ | 1 | This input generates an interrupt when going ON or OFF while the Data Terminal Ready signal is ON. It appears as bit 6 in the Status Register. |
| 16 | $\overline{C D}$ | $\overline{\text { DATA TERMINAL }}$ | 0 | This output is generated by bit 0 in Control Register 1 and indicates Controller readiness. |
| 18 | $\overline{C E}$ | $\overline{\text { RING INDICATOR }}$ | 1 | This input from the Data Set generates an interrupt when made low with Data Terminal Ready in the OFF condition. |
| 29 | $\overline{C F}$ | $\overline{\text { CARRIER DETECTOR }}$ | 1 | This input from the Data Set generates an interrupt when going ON or OFF if Data Terminal Ready is ON. It appears as bit 5 in the Status Register. |
| 35 | $\overline{D B}$ | $\begin{aligned} & \overline{\text { TRANSMITTER }} \\ & \text { TIMING } \end{aligned}$ | 1 | This input is the Transmitter 1X Data Rate Clock. Its use is selected by bits 0-2 of Control Register 2. The transmitted data changes on the negative transition of this signal. |
| 34 | $\overline{\mathrm{DD}}$ | $\overline{\text { RECEIVER TIMING }}$ | 1 | This input is the Receiver 1X Data Rate Clock. Its use is selected by bits $0-2$ of Control Register 2. The Received Data is sampled by the ASTRO on the positive transition of this signal. |
| 19 | $\overline{\text { MISC }}$ | $\overline{\text { MISCELLANEOUS }}$ | 0 | This output is controlled by bits 4 and 5 of Control Register 1 and is used as an extra programmable signal. |

## Device Programming

The two 8-bit Control Registers of the ASTRO determine the operative conditions of the ASTRO chip.

## Control Register 1

| BIT | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYNC/ASYNC | ASYNC | ASYNC (trans. EnABLIED) | ASYNC | ASYNC | SYNC/ASYNC | SYNC/ASYNC | SYCC/ASYMC |
| $\begin{aligned} & 0-\text { LOop } \\ & 1-\text { Nop } \\ & 1 \text { Nopk } \\ & \text { NOOE } \end{aligned}$ |  | $0-1 / 1 / 202$ STOP BIT <br> 1 - STITEGESTIOP BIT <br> Asyv (ttans. disabled) |  SYNC (CR12 $=1$ ) 0 - DEE Sthipping |  |  |  |  |
|  | $\begin{aligned} & 0-\operatorname{TRANSMITER} \\ & \text { NON TRANSE. } \end{aligned}$ <br> Non trans. | $\begin{aligned} & 0-\frac{\text { MISC OUT }=1}{\text { MISC OUT }}=0 \end{aligned}$ |  | SYNC |  |  |  |
|  | 1 - Transmite | SYNC (CR16=0) |  | O- RECEVER PAAITY |  |  |  |
|  |  |  | $0-$ MISE 0 OUT $=1$ | 1 - RECEVVE PARTY |  |  |  |

## Bit 0

Controls the Data Terminal Ready output on Pin 16 to control the CD circuit of the Data Set. A logic 1 enables the Carrier and Data Set Ready interrupts. A logic 0 enables only the telephone line Ring interrupt. The $\overline{\text { TTR }}$ output is inverted from the state of CR10.

## Bit 1

Controls the Request to Send output on Pin 38 to control the CA circuit of the Data Set. The $\overline{\text { RTS }}$ output is inverted from the state of CR11. A logic 1 combined with a low logic Clear to Send input enables the Transmitter and allows TBMT interrupts to be generated. A logic 0 disables the Transmitter and turns off the external Request to Send signal. Any character in the Transmitter Register will be completely transmitted before the Transmitter is turned off. The Request to Send output may be used for other functions such as Make Busy on 103 Data Sets.

## Bit 2

A logic 1 enables the ASTRO to receive data into the Receiver Buffer, update Receiver Status Bits 1,2,3, and 4, and to generate Data Received interrupts. A logic 0 disables the Receiver and clears the Receiver Status bits.

## Bit 3

## Asynchronous Mode

A logic 1 enables check of parity on received characters and generation of parity for transmitted characters.

## Synchronous Mode

A logic 1 bit enables check of parity on received characters only. Note: Transmitter parity enable is controlled by CR15.

## Bit 4

## Asynchronous Mode

A logic 1 enables the Automatic Echo mode when the receiver section is enabled. In this mode the clocked regenerated data is presented to the Transmitter Data output in place of normal transmission through the Transmitter Register. This serial method of echoing does not present any abnormal restrictions on the transmit speed of the terminal. Only the first character of a Break condition of all zeroes (null character) is echoed when a Line Break condition is detected. For all subsequent null characters, with logic zero Stop bits, a steady Marking condition is transmitted until normal character reception resumes. Echoing does not start until a character has been received and the Transmitter is idle. The Transmitter does not have to be enabled during the Echo mode.

## Synchronous Mode

A logic 1, with the Receiver enabled does not allow assembled Receiver data matching the DLE register contents to be transferred to the Receiver Buffer; also, parity checking is disabled.
When the Receiver is not enabled this bit controls the Miscellaneous output on Pin 19, which may be used for New Sync on a 201 Data Set. When operating with a 32 X clock and a disabled Receiver, a logic 1 on this bit also causes the Receiver timing to synchronize on Mark-To-Space transitions.

## Bit 5

## Asynchronous Mode

A logic 1, with the Transmitter enabled, causes a single Stop bit to be transmitted. A logic 0 causes transmission of 2 stop bits for character lengths of 6,7 , or 8 bits and one-and-a-half Stop bits for a character length of 5 bits.
With the Transmitter disabled this bit controls the Miscellaneous output on Pin 19, which may be used for Make Busy on 103 Data Sets, Secondary Transmit on 202 Data Sets, or dialing on CBS Data Couplers.

## Synchronous Mode

A logic 1 combined with a logic 0 on Bit 6 of Control Register 1 enables Transmit parity; if CR15=0 or CR16=1 no parity is generated. When set to a logic 1 with Bit 6 also a logic 1 , the contents of the DLE register are transmitted prior to the next character loaded in the Transmitter Buffer as part of the Transmitter Transparent mode.

## Bit 6

## Asynchronous Mode

A logic 1 holds the Transmitted Data output in a Spacing (Logic 0 ) condition, starting at the end of any current transmitted character, when the Transmitter is enabled. Normal Transmitter timing continues so that this Break condition can be timed out after the loading of new characters into the Transmitter Buffer.

## Synchronous Mode

A logic 1 conditions the Transmitter to a transparent transmission which implies that idle transmitter time will be filled by DLE-SYN character transmission and a DLE character can be forced ahead of any character in the Transmitter Buffer (Bit 5 above). When forcing DLE transmission, Bit 5 should be set to a logic 1 prior to loading the Transmitter Buffer, otherwise the character in the latter register may be transferred to the Transmitter Register prior to sending the DLE character.

## Bit 7

A logic 0 configures the ASTRO into an Internal Data and Control Loop mode and disables the Ring interrupt. In this diagnostic mode the following loops are connected internally:
a. The Transmit Data is connected to the Receive Data with the BA pin held in a Mark condition and the input to the BB pin disregarded.
b. With a 1X clock selected, the Transmitter Clock also becomes the Receive Clock.
c. The Data Terminal Ready (DTR) Control bit is connected to the Data Set Ready (DSR) input, with the Data Terminal Ready (DSR) output pin held in an OFF condition (logic high), and the DSR input pin is disregarded.
d. The Request to Send Control bit is connected to the Clear To Send (CTS) and Carrier Detector (CF) inputs, with the Request To Send (RTS) output pin held in an OFF condition (logic high), and the CTS and Carrier Detector input pins are disregarded.
e. The Miscellaneous pin is held in an OFF (logic high) condition.

A logic 1 on Bit 7 enables the Ring interrupt and returns the ASTRO to the normal full duplex configuration.

## Control Register 2

Control Register 2, unlike Control Register 1, cannot be changed at any time. This register should be changed only while both the receiver and transmitter sections of the ASTRO are in the idle state.

| $\begin{array}{lll}\text { BIT } & 7 & 6\end{array}$ | 5 | 4 | 3 | 210 |
| :---: | :---: | :---: | :---: | :---: |
| SYNC/ASYNC <br> Character lengit select $\begin{aligned} & 00=8 \text { BITS } \\ & 01=7 \text { BITS } \\ & 10=6 \text { BITS } \\ & 11=5 \text { BITS } \end{aligned}$ | $\begin{aligned} & \text { MODE SELECT } \\ & 0 \text { - ASYNCHRONOUS } \\ & \text { MODE } \\ & 1-\text { SYNCHRONOUS } \\ & \text { MODE } \end{aligned}$ | $\begin{aligned} & \frac{\text { SYNC/ASYNC }}{0-\text { EVEN PARITY }} \\ & \text { SELEC } \\ & 1 \text { - ODD PARITY } \\ & \text { SELECT } \end{aligned}$ | ASYNC <br> 0 - RECEIVER CLK = RATE 1 <br> 1 - RECEIVER CLOCK DETERMINED BY BITS 2-0 <br> SYNC (CR16 = 0 ) <br> 0 - NO SYN STRIP <br> 1-SYN STRIP <br> SYNC (CR16=1) <br> O - NO DLE-SYN STAIP <br> 1 - DLE-SYN STRIP | SYNC/ASYNC <br> CLOCK SELECT <br> 000-1X CLOCK <br> 001 - RATE 1 CLOCK <br> 010 - RATE 2 CLOCK <br> 011 - RATE 3 CLOCK <br> 100 - RATE 4 CLOCK <br> 101 - RATE 4 CLOCK $\div 2$ <br> 110-RATE 4 CLOCK $\div 4$ <br> 111 - RATE 4 CLOCK $\div 8$ |

## Bits 0-2

These bits select the Tranmit and Receive clocks.

| Bits | Clock Source |  |
| :---: | :---: | :---: |
| 210 | Tx | Rx |
| 000 | 1X Clock (Pin 35) | 1X Clock (Pin 34) |
| 001 | Rate 132 Xc | 30) |
| 010 | Rate 2 32X clocm | 31) |
| 011 | Rate 3 32X clocm | 32) |
| 100 | Rate 4 32X cloc | 33) |
| 101 | Rate 4 32X cloc | 33) $(\div 2){ }^{*} \dagger$ |
| 110 | Rate 4 32X c | 33) $(\div 4){ }^{*+}$ |
| 111 | Rate 4 32X clo | 33) $(\div 8){ }^{*+}$ |

## NOTES:

*Rx clock is modified by bit 3 in the asynchronous mode.
tRate 4 is internally dividable so that the required 32 X clock may be derived from an applied $64 \mathrm{X}, 128 \mathrm{X}$, or 256 X clock which may be available.

## Bits 3

## Asynchronous Mode

A logic 0 selects the Rate 132 X clock input (Pin 30) as the Receiver clock rate and a logic 1 selects the same clock rate for the Receiver as selected by Bits 2-0 for the Transmitter. This bit must be a logic 1 for the 1X clock selection by Bits 2-0.

## Synchronous Mode

A logic 1 causes alI DLE-SYN combination characters in the Transparent mode when DLE strip (CR14) is a logic 1, or all SYN characters in the Non-transparent mode to be stripped out and no Data Received interrupt to be generated. The SYN Detect status bit is set with reception of the next assembled character as is transferred to the Receiver Buffer.

## Bit 4

A logic 1 selects odd parity and a logic 0 selects even parity, when parity is enabled by CR13 and/or CR15.

## Bit 5

A logic 1 selects the Synchronous Character mode. A logic 0 selects the Asynchronous Character mode.

## Bits 6-7

These bits select the full character length (including parity, if selected) as shown above. When parity is enabled it must be considered as a bit when making character length selection ( 5 bits plus parity $=6$ bits).

## Status Register

The data contained in the Status Register define Receiver and Transmitter data conditions and status of the Data Set.

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - Data Set Change | - Data Set Ready (DSR) | - Carrier Detector | - Framing Error <br> - Syn Detect | - DLE Detect <br> - Parity Error | - Overrun Error | $\begin{aligned} & \text { - Data } \\ & \text { Received } \\ & \text { (DR) } \end{aligned}$ | - Transmitter Buffer Empty (TBMT) |

## Bit 0

A logic 1 indicates that the Transmitter Buffer may be loaded with new data. It is set to a logic 1 when the contents of the Transmitter Buffer is transferred to the Transmitter Register. It is cleared when the Transmitter Buffer is loaded from the DAL bus, or when the Transmitter is disabled.

## Bit 1

A logic 1 indicates that an entire character has been received and transferred into the Receiver Buffer. It is cleared when the Receiver Buffer is read onto the DAL bus, or the Receiver is disabled.

## Bit 2

A logic 1 indicates an Overrun error which occurs if the previous character in the Receiver Buffer has not been read and Data Received is not reset, at the time a new character is to be transferred to the Receiver Buffer. This bit is cleared when no Overrun condition is detected (the next character transfer time) or when the Receiver is disabled.

## Bit 3

When the DLE Strip is enabled (CR14) the Receiver parity check is disabled and this bit is set to a logic 1 if the previous character to the presently assembled character matched the contents of the DLE register; otherwise it is cleared. The DLE DET remains for one character time and is reset on the next character transfer or on a Status Register Read. If DLE Strip is not enabled this bit is set to a logic 1 when the Receiver is enabled, Receiver parity (CR13) is also enabled, and the last received character has a Parity error. A logic 0 on this bit indicates correct parity. This bit is cleared in both modes when the Receiver is disabled.

## Bit 4

## Asynchronous Mode

A logic 1 indicates that the received data did not have a valid stop bit, while the Receiver was enabled, which indicates a Framing error. This bit is set to a logic 0 if the stop bit (logic 1) was detected.

## Synchronous Mode

A logic 1 indicates that the contents of the Receiver Register matches the contents of the SYN Register. The condition of this bit remains for a full character assembly time. If SYN strip (CR23) is enabled this status bit is updated with the character received after the SYN character.
In both modes the bit is cleared when the Receiver is disabled.

## Bit 5

This bit is the logic complement of the $\overline{\text { Carrier Detector input on Pin } 29 .}$

## Bit 6

This bit is the logic complement of the $\overline{\text { Data Set Ready }}$ input on Pin 28. With 202-type Data Sets it can be used for Secondary Receive.

## Bit 7

This bit is set to a logic 1 whenever there is a change in state of the Data Set Ready or Carrier Detector inputs while Data Terminal Ready (CR10) is a logic 1 or the Ring Indicator is turned ON, with DTR a logic 0 . This bit is cleared when the Status Register is read onto the DAL bus.


Flow Chart Receiver Operations



MAXIMUM GUARANTEED RATINGS*
Operating Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +18.0 V
Negative Voltage on any Pin, with respect to ground. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -0.3 V
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
ELECTRICAL CHARACTERISTICS
$\left(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$, unless otherwise noted)

| Parameter |  | Min | Typ. | Max. | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. Characteristics |  |  |  |  |  |  |
| INPUT VOLTAGE LEVELS |  |  |  |  |  |  |
| Low Level, $\mathrm{V}_{12}$ |  |  |  | 0.8 | V |  |
| High Level, $V_{I H}$ OUTPUT VOLTAGE LEVELS |  | 2.4 |  |  | V |  |
|  |  |  |  |  |  |  |
| Low Level, $\mathrm{V}_{\mathrm{OL}}$ |  |  | 0.4 |  | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{ma}$ |
| High Le | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  |  |  | $\mathrm{I}_{\mathrm{OH}}=100 \mu \mathrm{a}$ |
| INPUT LEAKAGE |  |  |  |  |  |  |
| Data Bus |  |  | 5.0 | 10.0 | $\mu \mathrm{a}$ | $0 \leq V_{1 N} \leq 5 v$ |
| All othe |  |  | 5.0 | 10.0 | $\mu \mathrm{a}$ | $V_{\text {IN }}=+12 v$ |
| POWER SUPPLY CURRENT |  |  |  |  |  |  |
| $\mathrm{I}_{\mathrm{cc}}$ |  |  |  | 80.0 | ma |  |
| $I_{\text {D }}$ |  |  |  | 10.0 | ma |  |
| $\mathrm{I}_{\text {B }}$ |  |  |  | 1.0 | ma |  |
| A.C. Characteristics |  |  |  |  |  | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| CLOCK-RCP, TCP |  |  |  |  |  |  |
| frequen |  |  | 1.0 |  | MHz |  |
| DAL Bus |  |  |  |  |  |  |
| $\mathrm{T}_{\text {AS }}$ | Address Set-Up Time | 0 |  |  | ns |  |
| $\mathrm{T}_{\text {AH }}$ | Address Hold Time | 150 |  |  | ns |  |
| $\mathrm{T}_{\text {ARL }}$ | Address to RPLY Delay |  |  | 400 | ns |  |
| $\mathrm{T}_{\text {cs }}$ | CS Width | 250 |  |  | ns |  |
| $\mathrm{T}_{\text {CSRLF }}$ | CS to Reply OFF Relay | 0 |  | 250 | ns | $\mathrm{R}_{\mathrm{L}}=2.7 \mathrm{~K} \Omega$ |
| Read |  |  |  |  |  |  |
| $\mathrm{T}_{\text {ARE }}$ | Address and RE Spacing | 250 |  |  | ns |  |
| $\mathrm{T}_{\text {RECSH }}$ | RE and CS Overlap | 20 |  |  | ns |  |
| $\mathrm{T}_{\text {RECS }}$ | $\overline{\mathrm{RE}}$ to $\overline{\mathrm{CS}}$ Spacing | 250 |  |  | ns |  |
| $\mathrm{T}_{\text {RED }}$ | $\overline{\mathrm{RE}}$ to Data Out Delay |  |  | 180 | ns | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pf}$ |
| Write |  |  |  |  |  |  |
| $\mathrm{T}_{\text {AWE }}$ | Address to WE Spacing | 250 |  |  | ns |  |
| $\mathrm{T}_{\text {wecsh }}$ | WE and CS Overlap | 20 |  |  | ns |  |
| $\mathrm{T}_{\mathrm{WE}}$ | WE Width | 200 |  | 1000 | ns |  |
| $\mathrm{T}_{\text {DS }}$ | Data Set-Up Time | 150 |  |  | ns |  |
| $\mathrm{T}_{\text {DH }}$ | Data Hold Time | 100 |  |  | ns |  |
| $\mathrm{T}_{\text {wecs }}$ | WE to CS Spacing | 250 |  |  | ns |  |
| Interrupt |  |  |  |  |  |  |
| $\mathrm{T}_{\text {csı }}$ | $\overline{C S}$ to $\overline{\text { IACKI }}$ Delay | 0 |  |  | ns |  |
| TCSRE | $\overline{C S}$ to RE Delay | 250 |  |  | ns |  |
| $\mathrm{T}_{\text {csreh }}$ | $\overline{\mathrm{CS}}$ and RE Overlap | 20 |  |  | ns |  |
| $\mathrm{T}_{\text {RECS }}$ | $\overline{\mathrm{RE}}$ to CS Spacing | 250 |  |  | ns |  |
| $\mathrm{T}_{\text {PI }}$ | IACKI Pulse Width | 200 |  |  | ns |  |
| $\mathrm{T}_{\text {IAD }}$ | IACKI to Valid ID Code Delay |  |  | 250 | ns | See Note 1. |
| $\mathrm{T}_{\text {RED }}$ | RE OFF to DAL Open Delay |  |  | 180 | ns |  |
| $\mathrm{T}_{\text {IARL }}$ | $\overline{\text { IACKI }}$ to $\overline{R P L Y}$ Delay |  |  | 250 | ns | See Note 1. |
| $\mathrm{T}_{\text {cSRLF }}$ | $\overline{C S}$ to RPLY OFF Delay | 0 |  | 250 | ns | $\mathrm{R}_{\mathrm{L}}=2.7 \mathrm{~K} \Omega$ |
| $\mathrm{T}_{11}$ | IACKI to IACKO Delay |  |  | 200 | ns |  |
| $\mathrm{T}_{\text {REI }}$ | $\overline{\text { RE OFF to IACKO OFF Delay }}$ |  |  | 250 | ns |  |



Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

## Universal Asynchronous Receiver/Transmitter UART

## FEATURES

$\square$ Compatible with TR1863 timingHigh accuracy 32X clock mode: 48.4375\% Receiver Distortion Immunity and improved RDA/ROR operation (COM 8018 only)High Speed Operation-62.5K baud, 200ns strobesSingle +5V Power SupplyDirect TTL Compatibility-no interfacing circuits requiredInput pull-up options: COM 8018 has low current pull-up resistors; COM 1863 has no pull up resistorsFull or Half Duplex Operation-can receive and transmit simultaneously at different baud ratesFully Double Buffered-eliminates need for precise external timingImproved Start Bit Verification-decreases error rate46.875\% Receiver Distortion ImmunityFully Programmable-data word length; parity mode; number of stop bits: one, one and one-half, or twoMaster Reset-Resets all status outputs and Receiver Buffer RegisterThree State Outputs-bus structure orientedLow Power-minimum power requirementsInput Protected-eliminates handling problemsCeramic or Plastic DIP Package-easy board insertionBaud Rates available from SMC's COM 8046, COM 8116, COM 8126, COM 8136, COM 8146 baud rate generators

## GENERAL DESCRIPTION

The Universal Asynchronous Receiver/Transmitter is an MOS/LSI monolithic circuit that performs all the receiving and transmitting functions associated with asynchronous data communications. This circuit is fabricated using SMC's patented COPLAMOS® technology and employs depletion mode loads, allowing operation from a single +5 V supply. The duplex mode, baud rate, data word length, parity mode, and number of stop bits are independently programmable through the use of external controls. There may be $5,6,7$, or 8 data bits, odd/even or no parity, and 1 or 2 stop bits or 1.5 stop bits when utilizing a 5 -bit code. These programmable features provide the user with the ability to interface with all asynchronous peripherals.

[^4]PIN CONFIGURATION

| VDD | 1 | 40 | T TCP |
| :---: | :---: | :---: | :---: |
| *HIACC | 2 | 39 | $\square \mathrm{POE}$ |
| Gnd | 3 | 38 | NDB1 |
| $\overline{R D E}$ | 4 | 37 | ] NDB 2 |
| RD8 | 5 | 36 | ] NSB |
| RD7 ${ }^{\text {a }}$ | 6 | 35 | 7 NPB |
| RD6 | 7 | 34 | CS |
| RD5 | 8 | 33 | T TD8 |
| RD4 | 9 | 32 | ] TD7 |
| RD3 | 10 | 31 | $\square$ TD6 |
| RD2 | 11 | 30 | TD5 |
| RD1 | 12 | 29 | $\square$ TD4 |
| RPE | 13 | 28 | TD3 |
| RFE | 14 | 27 | $\square$ TD2 |
| ROR | 15 | 26 | $\square$ TD1 |
| SWE | 16 | 25 | TSO |
| RCP | 17 | 24 | $\square$ TEOC |
| $\overline{\text { RDAR }}$ | 18 | 23 | $\bigcirc$ TDS |
| RDA | 19 | 22 | ] твмт |
| RSI | 20 | 21 | M MR |

PACKAGE: 40-Pin D.I.P.

At start-up the power is turned on, a clock whose frequency is 16 or 32 times the desired baud rate is applied, and master reset is pulsed. Under these conditions TBMT, TEOC, and TSO are all at a high level (the line is marking).
When TBMT and TEOC are high, the control bits may be set. After this has been done the data bits may be set. Normally, the control bits are strobed into the transmitter prior to the data bits. However, as long as minimum pulse width specifications are not violated, TDS and CS may occur simultaneously. Once the data strobe (TDS) has been pulsed, the TBMT signal goes low, indicating that the data bits buffer register is full and unavailable to receive new data.
If the transmitter shift register is transmitting previously loaded data the TBMT signal remains low. If the transmitter shift register is empty, or when it is through transmitting the previous character, the data in the buffer register is loaded immediately into the transmitter shift register and data transmission
commences. TEOC goes low, TSO goes Iow (the start bit), and TBMT goes high indicating that the data in the data bits buffer register has been loaded into the transmitter shift register and that the data bits buffer register is available to be loaded with new data.
If new data is loaded into the data bits buffer register at this time, TBMT goes low and remains in this state until the present transmission is completed. One full character time is available for loading the next character with no loss in speed of transmission. This is an advantage of double buffering.
Data transmission proceeds in an orderly manner: start bit, data bits, parity bit (if selected), and the stop bit(s). When the last stop bit has been on the line for one bit time TEOC goes high. If TBMT is low, transmission begins immediately. If TBMT is high the transmitter is completely at rest and, if desired, new control bits may be loaded prior to the next data transmission.


## DESCRIPTION OF OPERATION — RECEIVER

At start-up the power is turned on, a clock whose frequency is 16 or 32 times the desired baud rate is applied and master reset is pulsed. The data available (RDA) signal is now low. There is one set of control bits for both the receiver and transmitter.

Data reception begins when the serial input line transitions for mark (high) to space (low). If the RSI line remains spacing for $15 / 32$ to $17 / 32$ bit times (in the 16X mode, $\mathrm{HIACC}=0$ ) or $31 / 64$ to
$33 / 64$ bit times (in the 32 X mode, HIACC $=1$ ), a genuine start bit is verified. Should the line return to a marking condition prior to a $1 / 2$ bit time, the start bit verification process begins again. A mark to space transition must occur in order to initiate start bit verification. Once a start bit has been verified, data reception proceeds in an orderly manner: start bit verified and received, data bits received, parity bit received (if selected) and the stop bit(s) received.

If the received parity bit is incorrect, the parity error flip-flop of the status word buffer register is set high, indicating a parity error. However, if the no parity mode is selected, the parity error flipflop is unconditionally held low, inhibiting a parity error indication. If a stop bit is not received, the framing error flip-flop is set high, indicating a framing error.
On the negative RCP edge preceding the stop-bit center sample, internal logic looks at the data available (RDA) signal. If, at this instant, the RDA signal is high, or the $\overline{\operatorname{RDAR}}$ signal is low, the
receiver assumes that the previously received character has not been read out and the over-run flip-flop is set high. The only way the receiver is aware that data has been read out is by having the data available reset low.

Subsequently the RDA output goes high indicating that all outputs are available to be examined. The receiver shift register is now available to begin receiving the next character. Due to the double buffered receiver, a full character time is available to remove the received character.


## DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 1 | VDD | Power Supply | +5 volt Supply |
| 2 | HIACC | High Accuracy Mode | Enables 32 X clock and improved RDA/ROR operation. See NOTE on high accuracy mode. |
| 3 | GND | Ground | Ground |
| 4 | RDE | Received Data Enable | A low-level input enables the outputs (RD8-RD1) of the receiver buffer register. |
| 5-12 | RD8-RD1 | Receiver Data Outputs | These are the eight 3 -state data outputs enabled by $\overline{\mathrm{RDE}}$. Unused data output lines, as selected by NDB1 and NDB2, have a low-level output, and received characters are right justified, i.e. the LSB always appears on the RD1 output. |
| 13 | RPE | Receiver Parity Error | This 3-state output (enabled by $\overline{S W E}$ ) is at a high-level if the received character parity bit does not agree with the selected parity. |
| 14 | RFE | Receiver Framing Error | This 3-state output (enabled by $\overline{\text { SWE }}$ ) is at a high-level if the received character has no valid stop bit. |

DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | SYMBOL | NAME | FUNCTION |
| :--- | :--- | :--- | :--- |
| 15 | ROR | $\begin{array}{l}\text { Receiver Over } \\ \text { Run }\end{array}$ | $\begin{array}{l}\text { This 3-state output (enabled by SWE) is at a high-level if } \\ \text { the previously received character is not read (RDA output } \\ \text { reset not completed) before the present character is } \\ \text { transferred into the receiver buffer register. }\end{array}$ |
| 16 | SWE | $\begin{array}{l}\text { Status Word } \\ \text { Enable }\end{array}$ | $\begin{array}{l}\text { A low-level input enables the outputs (RPE, RFE, ROR, }\end{array}$ |
| RDA, and TBMT) of the status word buffer register. |  |  |  |$\}$| Receiver Clock |
| :--- |

DESCRIPTION OF PIN FUNCTION

| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 36 | NSB | Number of Stop Bits | This input selects the number of stop bits. A low-level input selects 1 stop bit; a high-level input selects 2 stop bits. Selection of two stop bits when programming a 5 data bit word generates 1.5 stop bits. |
| 37-38 | NDB2, NDB1 | Number of Data Bits/Character | These 2 inputs are internally decoded to select either 5, 6, 7, or 8 data bits/character as per the following truth table: |
| 39 | POE | Odd/Even Parity Select | The logic level on this input, in conjunction with the NPB input, determines the parity mode for both the receiver and transmitter, as per the following truth table:$\begin{array}{ccl} \text { NPB } & \text { POE } & \text { MODE } \\ L & L & \text { odd parity } \\ L & H & \text { even parity } \\ H & X & \text { no parity } \\ & & X=\text { don't care } \\ \hline \end{array}$ |
|  |  |  |  |
| 40 | TCP | Transmitter Clock | This input is a clock whose frequency is 16 times (16X) or 32 times (32X) the desired transmitter baud rate. |

TRANSMITTER TIMING 8 BIT, PARITY, 2 STOP BITS


RECEIVER TIMING8 BIT, PARITY, 2 STOP BITS


TRANSMITTER START-UP


START BIT DETECT AND VERIFY


RECEIVER TIMING DETAIL


## MAXIMUM GUARANTEED RATINGS*



Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that at clamp circuit be used.

ELECTRICAL CHARACTERISTICS ( $\mathrm{T}_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS INPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, VIL |  |  | 0.8 | V |  |
| High-level, VIH | 2.0 |  | 0.8 | V |  |
| OUTPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, Vol |  |  | 0.4 | V | $\mathrm{lOL}=1.6 \mathrm{~mA}$ |
| High-level, VoH | 2.4 |  |  | V | $\mathrm{IOH}=-100 \mu \mathrm{~A}$ |
| INPUT CURRENT |  |  |  |  |  |
| Low-level, lic |  |  | 300 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{GND}, \mathrm{COM} 8018$ only |
| INPUT LEAKAGE |  |  | $\pm 10$ | $\mu \mathrm{A}$ | COM 1863 only |
| OUTPUT CURRENT |  |  |  |  | $\overline{\mathrm{SWF}}=\overline{\mathrm{RDF}}=\mathrm{V}_{\text {IH }} 0<\mathrm{V}_{\text {/UI }}<+5 \mathrm{~V}$ |
| Leakage, lıo Short circuit, los** |  |  | $\begin{aligned} & \pm 10 \\ & 40 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \text { SWE }=\text { RDE }=\mathrm{V}_{\text {IH }}, 0 \leq \text { VOUT } \leq+5 \mathrm{~V} \\ & \text { VOUT } \end{aligned}$ |
| INPUT CAPACITANCE |  |  |  |  |  |
| OUTPUT CAPACITANCE All outputs, Cout |  | 10 | 20 | pf | $\overline{\mathrm{SWE}}=\overline{\mathrm{RDE}}=\mathrm{V}_{\mathrm{IH}}$ |
| POWER SUPPLY CURRENT |  |  | 25 |  |  |
| A.C. CHARACTERISTICS |  |  | 25 | mA | All outputs $=\mathrm{VOH}$, All inputs $=\mathrm{VDD}$ $T_{A}=+25^{\circ} \mathrm{C}$, See Timing Diagrams |
| CLOCK FREQUENCY | DC |  | 1.0 | MHz | RCP, TCP |
| PULSE WIDTH |  |  |  |  |  |
| Clock | 0.45 |  |  | $\mu \mathrm{s}$ | RCP, TCP |
| Master reset | 500 |  |  | ns | MR |
| Control strobe | 200 |  |  | ns | CS |
| Transmitter data strobe | 200 |  |  | ns | TDS |
| Receiver data available reset | 200 |  |  | ns | RDAR |
| INPUT SET-UP TIME |  |  |  |  |  |
| Data bits | 0 |  |  | ns | TD1-TD8 |
| Control bits | 0 |  |  | ns | NPB, NSB, NDB2, NDB1, POE |
| INPUT HOLD TIME |  |  |  |  |  |
| Data bits | 0 |  |  | ns | TD1-TD8 |
| Control bits | 0 |  |  | ns | NPB, NSB, NDB2, NDB1, POE |
| ENABLE TO OUTPUT DELAY |  |  |  |  | Load $=20 \mathrm{pf}+1$ TTL input |
| Receive data enable |  |  | 250 | ns | RDE: TPD1, TPDO |
| Status word enable |  |  | 250 | ns | SWE: TPD1, TPDO |
| OUTPUT DISABLE DELAY |  |  | 250 | ns | RDE, $\overline{\text { SWE }}$ |

**Not more than one output should be shorted at a time.

NOTES: 1 . If the transmitter is inactive (TEOC and TBMT are at a high-level) the start bit will appear on the TSO line within $11 / 2$ clock period (TCP) after the trailing edge of TDS.
2. The start bit (mark to space transition) will always be detected within one RCP clock period, guaranteeing a maximum start bit slippage of $\pm 1 / 32$ or $\pm 1 / 64$ of a bit time.
3. The 3-state output has 3 states: 1) low impedance to VDD 2) low impedance to GND 3) high impedance OFF $\cong$ 10 M ohms The "OFF" state is controlled by the SWE and RDE inputs.


- Input information (Data/Control) need only be valid during the last TPW, min time of the input strobes (TDS, CS).


## OUTPUT TIMING DIAGRAM

$\overline{R D E}, \overline{S W E}$

OUTPUTS (RD1-RD8, RDA, RPE, ROR, RFE, TBMT)


NOTE: Waveform drawings not to scale for clarity.

## ADDITIONAL TIMING INFORMATION

## $\overline{\operatorname{RDAR}}$



NOTES ON COM 8018 AND COM 1863 HIGH-ACCURACY AND IMPROVED RDA/ROR MODE
The HIACC mode is enabled by applying a logic "one" to pin 2. If this pin is left unconnected, or connected to GND, -12 V , or a logic "zero," the HIACC mode is disabled. The HIACC input has an internal pull-down resistor
When the HIACC mode is selected, the TX and RX halves both operate on 32 X instead of 16 X clocks. Also, RDA is notched during the one half receiver clock cycle preceding the stop bit center sample when RD1-RD8 and ROR are changing.
Whether or not the HIACC mode is selected, RDA must be low and $\overline{\text { RDAR }}$ must have returned high to avoid setting ROR. If RDAR is held low past the stop-bit center sample, RDA will go high after RDAR returns high.
The maximum current HIACC will supply if connected to -13.2 V is 3.5 mA .

TIMING DIAGRAMS



Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser, of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

# Universal Asynchronous Receiver/Transmitter 

 UART
## FEATURES

Direct TTL Compatibility - no interfacing circuits requiredFull or Half Duplex Operation - can receive and transmit simultaneously at different baud ratesFully Double Buffered—eliminates need for precise external timingStart Bit Verification—decreases error rateFully Programmable-data word length, parity mode, number of stop bits; one, one and one-half, or twoHigh Speed Operation - 40K baud, 200ns strobesMaster Reset-Resets all status outputsTri-State Outputs—bus structure orientedLow Power-minimum power requirementsInput Protected-eliminates handling problemsCeramic or Plastic Dip Package - easy board insertion
## GENERAL DESCRIPTION

The Universal Asynchronous Receiver/Transmitter is an MOS/LSI monolothic circuit that performs all the receiving and transmitting functions associated with asynchronous data communications. This circuit is fabricated using SMC's P-channel low voltage oxidenitride technology. The duplex mode, baud rate, data word length, parity mode, and number of stop bits are independently programmable through the use of external controls. There may be $5,6,7$ or 8 data bits, odd/even or no parity, and 1, or 2 stop bits or 1.5 stop bits when utilizing a 5 -bit code from the COM 2017 or COM2017/H. The UART can operate in either the full or half duplex mode. These programmable features provide the user with the ability to interface with all asynchronous peripherals.


## DESCRIPTION OF OPERATION - TRANSMITTER

At start-up the power is turned on, a clock whose frequency is 16 times the desired baud rate is applied and master reset is pulsed. Under these conditions TBMT, TEOC, and TSO are all at a high level (the line is marking).
When TBMT and TEOC are high, the control bits may be set. After this has been done the data bits may be set. Normally, the control bits are strobed into the transmitter prior to the data bits. However, as long as minimum pulse width specifications are not violated, TDS and CS may occur simultaneously. Once the date strobe (TDS) has been pulsed the TBMT signal goes low, indicating that the data bits buffer register is full and unavailable to receive new data.

If the transmitter shift register is transmitting previously loaded data the TBMT signal remains low. If the transmitter shift register is empty, or when it is through transmitting the previous character, the data in the buffer register is loaded immediately into the transmitter shift register and data transmission
commences. TSO goes low (the start bit), TEOC goes low, the TBMT goes high indicating that the data in the data bits buffer register has been loaded into the transmitter shift register and that the data bits buffer register is available to be loaded with new data.
If new data is loaded into the data bits buffer register at this time, TBMT goes lowand remains in this state until the present transmission is completed. One full character time is available for loading the next character with no loss in speed of transmission. This is an advantage of double buffering.
Data transmission proceeds in an orderly manner: start bit, data bits, parity bit (if selected), and the stop bit(s). When the last stop bit has been on the line for one bit time TEOC goes high. If TBMT is low, transmission begins immediately. If TBMT is high the transmitter is completely at rest and, if desired, new control bits may be loaded prior to the next data transmission.

TRANSMITTER BLOCK DIAGRAM


## DESCRIPTION OF OPERATION-RECEIVER

At start-up the power is turned on, a clock whose frequency is 16 times the desired baud rate is applied and master reset is pulsed. The data available (RDA) signal is now low. There is one set of control bits for both the receiver and transmitter.
Data reception begins when the serial input line transitions from mark (high) to space (low). If the RSI line remains spacing for a $1 / 2$ bit time, a genuine start bit is verified. Should the line return to a mark-
ing condition prior to a $1 / 2$ bit time, the start bit verification process begins again. A mark to space transition must occur in order to initiate start bit verification. Once a start bit has been verified, data reception proceeds in an orderly manner: start bit verified and received, data bits received, parity bit received (if selected) and the stop bit(s) received. If the transmitted parity bit does not agree with the received parity bit, the parity error flip-flop of the
status word buffer register is set high, indicating a parity error. However, if the no parity mode is selected, the parity error flip-flop is unconditionally held low, inhibiting a parity error indication. If a stop bit is not received, due to an improperly framed character, the framing error flip-flop is set high, indicating a framing error.
Once a full character has been received internal logic looks at the data available (RDA) signal. If, at this instant, the RDA signal is high the receiver assumes that the previously received character has
not been read out and the over-run flip-flop is set high. The only way the receiver is aware that data has been read out is by having the data available reset low.
At this time the RDA output goes high indicating that all outputs are available to be examined. The receiver shift register is now available to begin receiving the next character. Due to the double buffered receiver, a full character time is available to remove the received character.


## DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | SYMBOL | NAME | FUNCTION |
| :--- | :--- | :--- | :--- |
| $\mathbf{1}$ | Vcc | Power Supply | +5 volt Supply |
| $\mathbf{2}$ | VDD | Power Supply | -12 volt Supply |
| 3 | GND | Ground | Ground |
| 4 | $\overline{\text { RDE }}$ | Received Data <br> Enable | A low-level input enables the outputs (RD8-RD1) of the <br> receiver buffer register. |
| $5-12$ | RD8-RD1 | Receiver Data <br> Outputs | These are the 8 tri-state data outputs enabled by $\overline{R D E}$ <br> Unused data output lines, as selected by NDB1 and NDB2, <br> have a low-level output, and received characters are right <br> justified, i.e. the LSB always appears on the RD1 output. |
| 13 | RPE | Receiver Parity <br> Error | This tri-state output (enabled by $\overline{\text { SWE) is at a high-level if }}$ <br> the received character parity bit does not agree with the <br> selected parity. |
| 14 | RFE | Receiver Framing <br> Error | This tri-state output (enabled by $\overline{\text { SWE) is at a high-level if }}$the received character has no valid stop bit. |


| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 15 | ROR | Receiver Over Run | This tri-state output (enabled by $\overline{\text { SWE }}$ ) is at a high-level if the previously received character is not read (RDA output not reset) before the present character is transferred into the receiver buffer register. |
| 16 | $\overline{\text { SWE }}$ | Status Word Enable | A low-level input enables the outputs (RPE, RFE, ROR, RDA, and TBMT) of the status word buffer register. |
| 17 | RCP | Receiver Clock | This input is a clock whose frequency is 16 times (16X) the desired receiver baud rate. |
| 18 | $\overline{\text { RDAR }}$ | Receiver Data Available Reset | A low-level input resets the RDA output to a low-level. |
| 19 | RDA | Receiver Data Available | This tri-state output (enabled by $\overline{\mathrm{SWE}}$ ) is at a high-level when an entire character has been received and transferred into the receiver buffer register. |
| 20 | RSI | Receiver Serial Input | This input accepts the serial bit input stream. A high-level (mark) to low-level (space) transition is required to initiate data reception. |
| 21 | MR | Master Reset | This input should be pulsed to a high-level after power turn-on. This sets TSO, TEOC, and TBMT to a high-level and resets RDA, RPE, RFE and ROR to a low-level. |
| 22 | TBMT | Transmitter Buffer Empty | This tri-state output (enabled by $\overline{\mathrm{SWE}}$ ) is at a high-level when the transmitter buffer register may be loaded with new data. |
| 23 | $\overline{\text { TDS }}$ | Transmitter Data Strobe | A low-level input strobe enters the data bits into the transmitter buffer register. |
| 24 | TEOC | Transmitter End of Character | This output appears as a high-level each time afull character is transmitted. It remains at this level until the start of transmission of the next character or for one-half of a TCP period in the case of continuous transmission. |
| 25 | TSO | Transmitter Serial Output | This output serially provides the entire transmitted character. TSO remains at a high-level when no data is being transmitted. |
| 26-33 | TD1-TD8 | Transmitter Data Inputs | There are 8 data input lines (strobed by $\overline{T D S}$ ) available. Unused data input lines, as selected by NDB1 and NDB2, may be in either logic state. The LSB should always be placed on TD1. |
| 34 | CS | Control Strobe | A high-level input enters the control bits (NDB1, NDB2, NSB, POE and NPB) into the control bits holding register. This line may be strobed or hard wired to a high-level. |
| 35 | NPB | No Parity Bit | A high-level input eliminates the parity bit from being transmitted; the stop bit(s) immediately follow the last data bit. In addition, the receiver requires the stop bit(s) to follow immediately after the last data bit. Also, the RPE output is forced to a low-level. See pin 39, POE. |


| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 36 | NSB | Number of Stop Bits | This input selects the number of stop bits. A low-level input selects 1 stop bit; a high-level input selects 2 stop bits. Selection of 2 stop bits when programming a 5 data bit word generates 1.5 stop bits from the COM 2017 or COM 2017/H. |
| 37-38 | $\begin{aligned} & \text { NDB2, } \\ & \text { NDB1 } \end{aligned}$ | Number of Data Bits/Character | These 2 inputs are internally decoded to select either 5, 6, 7, or 8 data bits/character as per the following truth table: |
| 39 | POE | Odd/Even Parity Select | The logic level on this input, in conjunction with the NPB input, determines the parity mode for both the receiver and transmitter, as per the following truth table: |
|  |  |  | NPB POE MODE <br> $L$ L odd parity <br> L $H$ even parity <br> $H$ $X$ no parity <br>   $X=$ don't care |
| 40 | TCP | Transmitter Clock | This input is a clock whose frequency is 16 times (16X) the desired transmitter baud rate. |



Upon data transmission initiation, or when not transmitting at $100 \%$ line utilization, the start bit will be placed on the TSO line at the high to low transition of the TCP clock following the trailing edge of TDS.

RECEIVER TIMING-8 BIT, PARITY, 2 STOP BITS


START BIT DETECT/VERIFY
RCP

RSI


If the RSI tine remains spacing for a $1 / 2$ bit time, a genuine start bit is verified. Should the line return to a marking condition prior to a $1 / 2$ bit time, the start bit verification process begins again.

## MAXIMUM GUARANTEED RATINGS*

Operating Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, Vcc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +0.3 C
Negative Voltage on any Pin, Vcc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -25 C
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition abovethose indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS ( $\mathrm{T}_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=-12 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS <br> INPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, VIL | Vod |  | 0.8 | V |  |
| High-level, $\mathrm{V}_{1 H}$ | Vcc-1.5 |  | Vcc | V |  |
| OUTPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, Vol |  | 0.2 | 0.4 | V | $1 \mathrm{LL}=1.6 \mathrm{~mA}$ |
| High-level, VOH | 2.4 | 4.0 |  | V | $\mathrm{IOH}=100 \mu \mathrm{~A}$ |
| INPUT CURRENT |  |  |  |  |  |
| Low-level, IIL |  |  | 1.6 | mA | see note 4 |
| OUTPUT CURRENT |  |  |  |  |  |
| Leakage, ILo |  |  | -1 | $\mu \mathrm{A}$ | $\overline{\text { SWE }}=\overline{\mathrm{RDE}}=\mathrm{VIH}^{\prime}, 0 \leq \mathrm{Vout} \leq+5 \mathrm{~V}$ |
| Short circuit, los** |  |  | 10 | mA | Vout $=0 \mathrm{~V}$ |
| INPUT CAPACITANCE |  |  |  |  |  |
| All inputs, CIN |  | 5 | 10 | pf | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{cc}}, \mathrm{f}=1 \mathrm{MHz}$ |
| OUTPUT CAPACITANCE |  |  |  |  |  |
| All outputs, Cout |  | 10 | 20 | pf | $\overline{\mathrm{SWE}}=\overline{\mathrm{RDE}}=\mathrm{V}_{1}, \mathrm{f}=1 \mathrm{MHz}$ |
| POWER SUPPLY CURRENT |  |  |  |  |  |
| $\mathrm{ICO}$ |  |  | $28$ | $\mathrm{mA}$ | All outputs $=\mathrm{VoH}$, All inputs $=\mathrm{Vcc}$ |
| Iod |  |  | $28$ | $\mathrm{mA}$ |  |
| A.C. CHARACTERISTICS CLOCK FREQUENCY |  |  |  |  | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ |
| (COM2502, COM2017) <br> (COM2502H, COM2017H) | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \end{aligned}$ |  | $\begin{aligned} & 400 \\ & 640 \end{aligned}$ | $\begin{aligned} & \mathrm{KHz} \\ & \mathrm{KHz} \end{aligned}$ | RCP, TCP RCP, TCP |
| PULSE WIDTH |  |  |  |  |  |
| Clock | 1 |  |  | $\mu \mathrm{s}$ | RCP, TCP |
| Master reset | 500 |  |  | ns | MR |
| Control strobe | 200 |  |  | ns | CS |
| Transmitter data strobe | 200 |  |  | ns | TDS |
| Receiver data available reset | 200 |  |  | ns | RDAR |
| INPUT SET-UP TIME |  |  |  |  |  |
| Data bits | $\geq 0$ |  |  | ns | TD1-TD8 |
| Control bits | $\geq 0$ |  |  | ns | NPB, NSB, NDB2, NDB1, POE |
| INPUT HOLD TIME |  |  |  |  |  |
| Data bits | $\geq 0$ |  |  | ns | TD1-TD8 |
| Control bits | $\geq 0$ |  |  | ns | NPB, NSB, NDB2, NDB1, POE |
| STROBE TO OUTPUT DELAY |  |  |  |  | Load $=20 \mathrm{pf}+1$ TTL input |
| Receive data enable |  |  | 350 | ns | RDE: TPD1, TPDO |
| Status word enable |  |  | 350 | ns | SWE: TPD1, TPDo |
| OUTPUT DISABLE DELAY |  |  | 350 | ns | RDE, $\overline{\text { SWE }}$ |

**Not more than one output should be shorted at a time.

NOTES: 1 . If the transmitter is inactive (TEOC and TBMT are at a high-level) the start bit will appear on the TSO line within one clock period (TCP) after the trailing edge of TDS.
2. The start bit (mark to space transition) will always be detected within one clock period of RCP, guaranteeing a maximum start bit slippage of $1 / 16$ th of a bit time.
3. The tri-state output has 3 states: 1 ) lowimpedance to Vcc $\quad$ 2) lowimpedance to GND 3 )high impedance $O F F \cong$ 10M ohms. The "OFF" state is controlled by the SWE and RDE inputs.
4. Under steady state conditions no current flows for TTL or MOS interfacing. (COM 2502 or COM 2502/H)

## DATA/CONTROL TIMING DIAGRAM


*Input information (Data/Control) need only be valid during the last TPW, min time of the input strobes (TDS, CS).

## OUTPUT TIMING DIAGRAM

$\overline{R D E}, \overline{S W E}$

OUTPUTS (RD1-RD8, RDA,
RPE, ROR, RFE, TBMT)


NOTE: Waveform drawings not to scale for clarity.



FLOW CHART-RECEIVER


Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

# RS-449 <br> Programmable Communications Interface 

## FEATURES

PIN CONFIGURATIONRS-449 compatible inputs and outputsMaskable Interrupts for RS-449 inputsSynchronous and Asynchronous Full Duplex or Half Duplex OperationsRe-programmable ROM on-chip baud rate generatorSynchronous Mode Capabilities
-Selectable 5 to 8-Bit Characters
-Selectable 1 or 2 SYNC Characters

- Internal or External CharacterSynchronization
- Transparent or Non-Transparent Mode
-Transparent mode DLE stuffing (Tx) and detection (Rx)
- Automatic SYNC or DLE-SYNC Insertion
-SYNC, DLE and DLE-SYNC stripping
-Odd, Even, or No Parity
- Local or remote maintenance loop back mode

Asynchronous Mode Capabilities
-Selectable 5 to 8 -Bit Characters plus parity
-3 Selectable Clock Rates (1X, 16X, 64X the Baud Rate)

- Line Break Detection and Generation
$-1,1 \frac{1}{2}$, or 2 -Stop Bit Detection and Generation
-False Start Bit Detection
-Odd, Even, or No Parity
- Parity, Overrun, and framing error detect
- Local or remote maintenance loop back mode
- Automatic serial echo mode (echoplex)Baud Rates
-DC to 1.0M Baud (Synchronous)
—DC to 1.0M Baud (1X, Asynchronous)


## GENERAL DESCRIPTION

The COM 2449 is an MOS/LSI device fabricated using SMC's patented COPLAMOS ${ }^{\text {© }}$ technology. It is equivalent to the COM 2661 with the additional features required to create the interface to an RS-449 compatible modem. Six new outputs are added to implement the RS-449 signals sent to the Data Communications Equipment (DCE) and five new signals are added to receive the RS-449 status signals from the DCE. A second status register and an output register have been added to allow a processor full control of the additional I/O pins. The COM 2449 contains a baud rate generator which can be programmed to either accept an external clock or to generate internal transmit or receive clocks. Sixteen different baud rates can be selected under program control when operating in the internal clock mode. Each version of the COM $2449(-1,-2,-3)$ has a different set of baud rates. Custom baud rates can be ROM reprogrammed to accommodate different baud rates
and different starting frequencies.
The COM 2449 is a Universal Synchronous/ Asynchronous Receiver/Transmitter (USART) designed for microcomputer system data communications. The USART is used as a peripheral and is programmed by the processor to communicate in commonly used asynchronous and synchronous serial data transmission techniques including IBM Bi-Sync. The USART receives serial data streams and converts them into parallel data characters for the processor. While receiving serial data, the USART will also accept data characters from the processor in parallel format, convert them to serial format and transmit. The USART will signal the processor when it has completely received or transmitted a character and requires service. Complete USART status including data format errors and control signals is available to the processor at any time.


## COM 2449 ORGANIZATION

The COM 2449 is organized into 6 major sections. Communication between each section is achieved via an internal data and control bus. The data bus buffer allows a processor access to all internal registers on the COM 2449. The COM 2449 is a COM 2661 with 5 new inputs (readable by the processor from STATUS REGISTER 2) and 6 new outputs (written by the processor via the OUTPUT REGISTER). Each of the 5 new inputs can cause an interrupt condition on the COM 2449. The ability to enable these conditions for interrupt handling is provided. Table 1 outlines the differences between the COM 2661 and the COM 2449. It should be noted that the COM 2449 can be viewed as a general purpose communications interface device with general purpose $1 / O$ pins to allow setting output controls and interrogation of input status. This additional I/O capability, although added to allow RS-449 compatibility, can ease the interface to any communications discipline.

## Operation Control

This functional block stores configuration and operation commands from the processor and generates appropriate signals to various internal sections to control the overall device operation. It contains read and write circuits to permit communications with a processor via the data bus and contains Mode Registers 1 and 2, the Command Register, the two Status Registers, and the Output Register. Details of register addressing and protocol are presented in the COM 2449 programming section of this specification.

## Timing

The COM 2449 contains a Baud Rate Generator (BRG) which is programmable to accept external transmit or receive clocks or to divide an external clock to perform data communications. The unit can generate 16 commonly used baud rates, any one of which can be selected for full duplex operation. Tables 2a, b, and cillustrate all available baud rates.

## Receiver

The Receiver accepts serial data on the RxD pin, converts this serial input to parallel format, checks for bits or characters that are unique to the communication technique and stores the "assembled" character in the receive data holding register until read by the processor.

## Transmitter

The Transmitter accepts parallel data from the processor, converts it to a serial bit stream, inserts the appropriate characters or bits (based on the communication technique) and outputs a composite serial stream of data on the TxD output pin.

## Modem Control

The modem control provides three output signals and accepts three input signals used for "handshaking" and status indication between the COM 2449 and a modem. Five signals to and from the modem control are given names that are in accordance with the RS-449 specification. The signals, however, have an identical function to the corresponding COM 2661 RS-232 compatible signals and this correspondence is shown in Table 1.

## SYN/DLE Control

This section contains control circuitry and three 8-bit registers storing the SYN1, SYN2, and DLE characters provided by the processor. These registers are used in the synchronous mode of operation to provide the characters required for synchronization, idle fill and data transparency.

## DESCRIPTION OF PIN FUNCTIONS

TABLE 3-PROCESSOR RELATED SIGNALS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & 1,2,5,6 \\ & 7,8,9,10 \end{aligned}$ | Data | D7-D0 | Bidirectional; 8 bit, three state data bus used to transfer commands, data and status between the COM 2449 and a processor. D0 is the least significant bit; D7 is the most significant bit. |
| 14,17,20 | Address | A2, A1, A0 | Input; Address lines used to select COM 2449 registers. |
| 16 | Chip Enable | $\overline{\mathrm{CE}}$ | Input; when this signal is low, the operation specified by the R/W, A2, A1 and A0 will be performed. When this input is high, D7-0 are in the high impedance state. |
| 21 | Read/Write | $\bar{R} / \mathrm{W}$ | Input; Processor read/write direction control. This signal defines the direction of the data bus D7-0 when the COM 2449 is selected. D7-0 drives out (read) when this signal is low and accepts data input when this signal is high. The input only has meaning when the CE input is active. |
| 22 | Receiver Ready | $\overline{\mathrm{RxRDY}}$ | Output; This signal is the complement of Status Register 1, bit 1 (SR11). When low, it indicates that the Receive Data Holding Register (RHR) has a character ready for input to the processor. It goes high when the RHR is read by the processor, and also when the receiver is disabled. It is an open drain output which can be used as an interrupt to the processor. |
| 23 | Transmitter Ready | $\overline{T X R D Y}$ | Output; This signal is the complement of Status Register 1, bit 0 (SR10). When low, it indicates that the Transmit Data Holding Register (THR) is ready to accept a data character from the processor. It goes high when the data character is loaded. This output is valid only when the transmitter is enabled. It is an open drain output which can be used as an interrupt to the processor. |
| 25 | Transmitter empty/data set change | $\begin{aligned} & \overline{\text { TXEMT/ }} \\ & \overline{\text { DSCHG }} \end{aligned}$ | Output; This signal is the complement of Status Register 1, bit 2 (SR12). When Iow, it indicates that the transmitter has completed serialization of the last character loaded by the processor, or that a change of state of the $\overline{\mathrm{DM}}$ or $\overline{\mathrm{RR}}$ inputs has occurred. This signal also goes low if the $\overline{\mathrm{SI}}, \overline{\mathrm{SB}}, \overline{\mathrm{SQ}}, \mathrm{TM}$ or $\overline{\mathrm{IC}}$ experience a change of state if the corresponding input is enable for interrupt. Interrupt enable bits are located in the 3 most significant bits of Status Register 2 (SR2). This output goes high when Status Register 1 is read by the processor, if the TxEMT condition does not exist. Otherwise, the THR must be loaded by the processor for this line to go high. It is an open drain output which can be used as an interrupt to the processor. |
| 28 | Reset | RESET | Input; A high on this input performs a master reset on the COM 2449. This signal asynchronously terminates any device activity and clears the Mode, Command and Status registers. The device assumes the idle state and remains there until initialized with the appropriate control words. |
| 33 | Supply Voltage | Vcc | +5 volt supply. |
| 4 | Ground | GND | Ground. |

## Interface Signals

The COM 2449 interface signals can be grouped into two types: the processor-related signals (shown in Table 3) which interface the COM 2449 to the processor, and the device-related signals (shown in Table 4), which are used to interface to the communications equipment.

## TABLE 4-DEVICE RELATED SIGNALS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :--- |
| 3 | Receive Data | RxD | Input: Serial data to the receiver. "Mark" is high, "space" is low. |
| 11 | Incoming Call | $\overline{\mathrm{IC}}$ | Input: This general purpose signal can be used for "incoming call" status from the <br> DCE. Its complement appears in Status Register 2 bit 0 (SR20). When this input is <br> enabled for interrupt via Status/Register 2 bit 5 (SR25), a change in its state will <br> cause a low output on TxEMT/DSCHG. |
| 12 | Test Mode | $\overline{\mathrm{TM}}$ | Input: This general purpose signal can be used for "test mode" status from the DCE. <br> Its complement appears in Status Register 2 bit 1 (SR21). When this input is enabled <br> for interrupt via Status Register 2, bit 6 (SR26) a change in its state will cause a low <br> output on TxEMT/DSCHG. |
| 13 | Signal Quality | $\overline{\mathrm{SQ}}$ | Input: This general purpose signal can be used for "signal quality" status from the DCE. <br> Its complement appears in Status Register 2 bit 2 (SR22). When this input is enabled <br> for interrupt via Status Register 2 bit 7 (SR27) a change in its state will cause a low out- <br> put on TxEMT/DSCHG. |

TABLE 4-DEVICE RELATED SIGNALS (Cont'd)

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 15 | Transmitter Clock/External Sync | $\begin{array}{r} \overline{\mathrm{TXC}} / 2 \\ \text { XSYNC } \end{array}$ | Input or Output: If the external transmitter clock is programmed, this input controls the rate at which the character is transmitted. Its frequency is $1 X, 16 \mathrm{X}$, or 64 X the baud rate as programmed by mode Register 1. The transmitted data changes on the falling edge of the clock. If the internal transmitter clock is programmed, this pin can be a 1X/16X clock output or an external jam synchronization input. |
| 18 | Standby Indicator | $\overline{\mathrm{S}}$ | Input: This general purpose signal can be used for "standby indicator" status from the DCE. Its complement appears in Status Register 2 bit 3 (SR23). When this input is enabled for interrupt via Status Register 2 bit 7 (SR27), a change in its state will cause a low output on TXEMT/DSCHG. |
| 19 | Signalling Rate Indicator | $\overline{\text { si }}$ | Input: This general purpose signal can be used for "signalling rate indicator" status from the DCE. Its complement appears in Status Register 2 bit 4 (SR24). When this input is enabled for interrupt via Status Register 2 bit 7 (SR27), a change in its state will cause a low output on TXEMT/DSCHG. |
| 24 | Clear to Send | $\overline{\text { CS }}$ | Input: This signal must be low in order for the transmitter to function. If it goes high during transmission, the character in the Transmit Shift Register will be transmitted before termination. |
| 26 | Transmit Data | TxD | Output: Serial data from the transmitter. "Mark" is high, "Space" is low. This signal is held in the "Mark" condition when the transmitter is disabled. |
| 27 | Baud Rate Clock | BRCLK | Input: Clock input to the internal baud rate generator (See Tables 2a, b, and c); not required if the external receiver and transmitter clocks are used. |
| 29 | Data Mode | $\overline{\text { DM }}$ | Input: This general purpose signal can be used for Data Mode, Data Set Ready or Ring Indicator condition. Its complement appears as Status Register 1 bit 7 (SR17). DM causes a low output on TXEMT/DSCHG when its state changes if CR2 or CRO=1. |
| 30 | Request to Send | $\overline{\text { RS }}$ | Output: This general purpose signal is the complement of the Command Register bit 5 (CR5). It is normally used to indicate Request to Send. If the Transmit Shift Register is not empty when CR5 is reset ( 1 to 0 ), then RS will go high on TXC time after the last serial bit is transmitted. |
| 31 | Terminal Ready | $\overline{T R}$ | Output: This general purpose signal is the complement of the Command Register bit 1 (CR1). It is normally used to indicate Terminal Ready. |
| 32 | Receive Clock/ Break Detect | $\begin{aligned} & \overline{\mathrm{RXC} /} \\ & \text { BKDET } \end{aligned}$ | Input or Output: If the external receiver clock is programmed, this input controls the rate at which the character is to be received. Its frequency is $1 \mathrm{X}, 16 \mathrm{X}$, or 64 X the Baud rate as programmed by Mode Register 1. Data are sampled on the rising edge of the clock. If internal receiver clock is programmed, this pin can be a $1 \mathrm{X} / 16 \mathrm{X}$ clock or a break detect output. |
| 34 | Receiver Ready | $\overline{\mathrm{RR}}$ | Input: This signal must be low in order for the receiver to function. The complement appears in Status Register 1 bit 6 (SR16). $\overline{\text { RR }}$ causes a low output on TxEMT/DSCHG when its state changes if CR 2 or $\mathrm{CR} 0=1$. If RR goes high while receiving, the RxC is internally inhibited. |
| 35 | New Signal | $\overline{\mathrm{NS}}$ | Output: This signal is used to tell the DCE that a new line signal at the DTE has occurred. This output will go to its low active state when the Output Register, bit 0 (OR0) is set to a logic 1 . This output will go to its high inactive state when the Output Register bit 0 (ORO) is set to a logic 0 and the RR input goes high. |
| 36 | Local Loopback | LI | Output: This general purpose signal can be used to inform the DCE of a "local loopback" test condition. It is the complement of Output Register bit 1 (OR1) which has direct control over the state of this output. |
| 37 | Remote Loopback | $\overline{\text { RL }}$ | Output: This general purpose signal can be used to inform the DCE of a "remote loopback" test condition. It is the complement of Output Register bit 2 (OR2) which has direct control over the state of this output. |
| 38 | Select Standby | $\overline{\text { SS }}$ | Output: This general purpose signal can be used to select the normal or standby communication facilities of the DCE. It is the complement of Output Register bit 3 (OR3) which has direct control over the state of this output. |
| 39 | Select Frequency/ Signal Rate Select | $\overline{\text { SF/SR }}$ | Output: This general purpose signal can be used as a combined "Select Frequency" and "Signal Rate Select". It is the complement of Output Register bit 4 (OR4) which has direct control over the state of this output. |
| 40 | Terminal in Service | $\overline{\text { s }}$ | Output: This general purpose signal can be used to inform the DCE of a "Terminal in Service" condition. It is the complement of Output Register bit 5 (OR5) which has direct control over the state of this output. |

Table 1 COM 2449 vs. COM 2661

| NEW INPUTS |  | NEW OUTPUTS |  | 1/O SIGNAL NAME EQUIVALENTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Name | Symbol | Name | COM 2 | OM 2661 |
| IC | incoming call | NS | new signal | DM | DSR |
| $\overline{\text { SQ }}$ | signal quality | $\overline{\text { IS }}$ | terminal in service | RR | DCD |
| $\overline{\mathrm{TM}}$ | test mode | $\overline{\text { SF/SR }}$ | select frequency/ signal rate select | CS | CTS |
| $\overline{\text { ST }}$ | signaling rate indicator | $\overline{\text { LI }}$ | local loopback | TR | DTR |
| $\overline{\overline{S B}}$ | standby select | $\overline{\mathrm{RL}}$ | remote loopback | RS | RTS |
|  |  | $\overline{\text { SS }}$ | standby select |  |  |

Table 2b BAUD RATE GENERATOR CHARACTERISTICS $2449-2($ BRCLK $=4.9152 \mathrm{MHz})$

| MR23-20 | BAUD <br> RATE | ACTUAL <br> FREQUENCY <br> 16X CLOCK | PERCENT <br> ERROR | DIVISOR |
| :---: | :---: | :---: | :---: | :---: |
| 0000 | 45.5 | 0.7279 kHz | 0.005 | 6752 |
| 0001 | 50 | 0.8 | - | 6144 |
| 0010 | 75 | 1.2 | - | 4096 |
| 0011 | 110 | 1.7598 | -0.01 | 2793 |
| 0100 | 134.5 | 2.152 | - | 2284 |
| 0101 | 150 | 2.4 | - | 2048 |
| 0110 | 300 | 4.8 | - | 1024 |
| 0111 | 600 | 9.6 | - | 512 |
| 1000 | 1200 | 19.2 | - | 256 |
| 1001 | 1800 | 28.7438 | -0.19 | 171 |
| 1010 | 2000 | 31.9168 | -0.26 | 154 |
| 1011 | 2400 | 38.4 | - | 128 |
| 1100 | 4800 | 76.8 | - | 64 |
| 1101 | 9600 | 153.6 | - | 32 |
| 1110 | 19200 | 307.2 | - | 16 |
| 1111 | 38400 | 614.4 | - | 8 |

Table 2a BAUD RATE GENERATOR CHARACTERISTICS 2449-1 $($ BRCLK $=4.9152 \mathrm{MHz})$

| MR23-20 | BAUD <br> RATE | ACTUAL <br> FREQUENCY <br> 16X CLOCK | PERCENT <br> ERROR | DIVISOR |
| :---: | :---: | :---: | :---: | :---: |
| 0000 | 50 | 0.8 kHz | - | 6144 |
| 0001 | 75 | 1.2 | - | 4096 |
| 0010 | 110 | 1.7598 | -0.01 | 2793 |
| 0011 | 134.5 | 2.152 | - | 2284 |
| 0100 | 150 | 2.4 | - | 2048 |
| 0101 | 200 | 3.2 | - | 1536 |
| 0110 | 300 | 4.8 | - | 1024 |
| 0111 | 600 | 9.6 | - | 512 |
| 1000 | 1050 | 16.8329 | 0.196 | 292 |
| 1001 | 1200 | 19.2 | - | 256 |
| 1010 | 1800 | 28.7438 | -0.19 | 171 |
| 1011 | 2000 | 31.9168 | -0.26 | 154 |
| 1100 | 2400 | 38.4 | - | 128 |
| 1101 | 4800 | 76.8 | - | 64 |
| 1110 | 9600 | 153.6 | - | 32 |
| 1111 | 19200 | 307.2 | - | 16 |

Table 2c BAUD RATE CHARACTERISTICS $2449-3$ (BRCLK $=5.0688 \mathrm{MHz}$ )

| MR23-20 | BAUD <br> RATE | ACTUAL <br> FREQUENCY <br> 16XCLOCK | PERCENT <br> ERROR | DIVISOR |
| :---: | :---: | :---: | :---: | :---: |
| 0000 | 50 | 0.8 kHz | - | 6336 |
| 0001 | 75 | 1.2 | - | 4224 |
| 0010 | 110 | 1.76 | - | 2880 |
| 0011 | 134.5 | 2.1523 | 0.016 | 2355 |
| 0100 | 150 | 2.4 | - | 2112 |
| 0101 | 300 | 4.8 | - | 1056 |
| 0110 | 600 | 9.6 | - | 528 |
| 0111 | 1200 | 19.2 | - | 264 |
| 1000 | 1800 | 28.8 | - | 176 |
| 1001 | 2000 | 32.081 | -253 | 158 |
| 1010 | 2400 | 38.4 | - | 132 |
| 1011 | 3600 | 57.6 | - | 88 |
| 1100 | 4800 | 76.8 | - | 66 |
| 1101 | 7200 | 115.2 | 3.125 | 44 |
| 1110 | 9600 | 153.6 |  | 16 |
| 1111 | 19200 | 316.8 |  | - |

NOTE:
16 X clock is used in asynchronous mode. In synchronous mode, clock multiplier is 1 X and BRG can be used only for TxC.

## COM 2449 OPERATION

The functional operation of the COM 2449 is programmed by a set of control words supplied by the processor. These control words specify items such as synchronous or asynchronous mode, baud rate, number of bits per character, etc. The programming procedure is described in the COM 2449 Programming section of this data sheet.
After programming, the COM 2449 is ready to perform the desired communications functions. The receiver performs serial to parallel conversion of data received from a modem or equivalent device. The transmitter converts parallel data received from the processor to a serial bit stream. These actions are accomplished within the framework specified by the control words.

## Receiver

The COM 2449 is conditioned to receive data when the $\overline{R R}$ input is low and the RxEN bit in the command register is true. In the asynchronous mode, the receiver looks for a high to low (mark to space) transition of the start bit on the RxD input line. If a transition is detected, the state of the $R \times D$ line is sampled again after a delay of one-half of a bit time. If RxD is now high, the search for a valid start bit is begun again. If RxD is still low, a valid start bit is assumed and the receiver continues to sample the input line at one bit time intervals until the proper number of data bits, the parity bit, and one stop bit have been assembled. The data is then transferred to the

## COM 2449 INITIALIZATION FLOW CHART



Receive Data Holding Register, the RxRDY bit in the status register is set, and the RxRDY output is asserted. If the character length is less than 8 bits, the high order unused bits in the Holding Register are set to zero. The Parity Error, Framing Error, and Overrun Error status bits are strobed into the status register on the positive going edge of R×C corresponding to the received character boundary. If the stop bit is present, the receiver will immediately begin its search for the next start bit. If the stop bit is absent (framing error), the receiver will interpret a space as a start bit if it persists into the next bit time interval. If a break condition is detected ( RxD is low for the entire character as well as the stop bit), only one character consisting of all zeros (with the Framing error status bit set) will be transferred to the Holding Register. The RxD input must return to a high condition before a search for the next start bit begins.
Pin 25 can be programmed to be a break detect output by appropriate setting of MR27-MR24. If so, a detected break will cause that pin to go high. When RxD returns to mark for one RxC time, pin 25 will go low. Refer to the break detection timing diagram.
When the COM 2449 is initialized into the synchronous mode, the receiver first enters the hunt mode on a 0 to 1 transition of RXEN (CR2). In this mode, as data is shifted into the Receiver Shift Register a bit at a time, the contents of the register are compared to the contents of the SYN1 register. If the two are not equal, the next bit is shifted in and the comparison is repeated. When the two registers match, the hunt mode is terminated and character assembly begins. If the single SYN operation is programmed, the SYN DETECT status bit is set. If double SYN operation is programmed, the first character assembled after SYN1 must be SYN2 in order for the SYN DETECT bit to be set. Otherwise, the COM 2449 returns to the hunt mode. (Note that the sequence SYN1-SYN1SYN2 will not achieve synchronization). When synchronization has been achieved, the COM 2449 continues to assemble characters and transfers them to the Holding Register. The RxRDY status bit is set and the RxRDY output is asserted each time a character is assembled and transferred to the Holding Register. The Overrun error (OE) and Parity error (PE) status bits are set as appropriate. Further receipt of the proper SYN sequence sets the SYN DETECT status bit. If the SYN stripping mode is commanded, SYN characters are not transferred to the Holding Register. Note that the SYN characters used to establish initial synchronization are not transferred to the Holding Register in any case.
External jam synchronization can be achieved via pin 9 by appropriate setting of MR27-MR24. When pin 9 is an XSYNC input, the internal SYN1, SYN1-SYN2, and DLESYN1 detection is disabled. Each positive going signal on XSYNC will cause the receiver to establish synchronization on the rising edge of the next RxC pulse. Character assembly will start with the RxD input at this edge. XSYNC may be lowered on the next rising edge of RxC. This external synchronization will cause the SYN DETECT status bit to be set until the status register is read. Refer to XSYNC timing diagram:

## Transmitter

The COM 2449 is conditioned to transmit data when the CS input is low and the TXEN command register bit is set. The COM 2449 indicates to the processor that it can accept a character for transmission by setting the TXRDY status bit and asserting the TXRDY output. When the processor writes a character into the Transmit Data Holding Register, the TXRDY status bit is reset and the TXRDY output is returned to a high (false) state. Data is transferred from the Holding Register to the Transmit

Shift Register when it is idle or has completed transmission of the previous character. The TxRDY conditions are then asserted again. Thus, one full character time of buffering is provided.
In the asynchronous mode, the transmitter automatically sends a start bit followed by the programmed number of data bits, the least significant bit being sent first. It then appends an optional odd or even parity bit and the programmed number of stop bits. If, following transmission of the data bits, a new character is not available in the Transmit Holding Register, the TxD output remains in the marking (high) condition and the TXEMT/DSCHG output and its corresponding status bit are asserted. Transmission resumes when the processor loads a new character into the Holding Register. The transmitter can be forced to output a continuous low (BREAK) condition by setting the Send Break command bit high.
In the synchronous mode, when the COM 2449 is initially conditioned to transmit, the TXD output remains high and the TxRDY condition is asserted until the first character to be transmitted (usually a SYN character) is loaded by the processor. Subsequent to this, a continuous stream of characters is transmitted. No extra bits (other than parity, if commanded) are generated by the COM 2449 unless the processor fails to send a new character to the COM 2449 by the time the transmitter has completed sending the previous character. Since synchronous communication does not allow gaps between characters, the COM 2449 asserts TXEMT and automatically "fills" the gap by transmitting SYN1s, SYN1-SYN2 doublets, or DLE-SYN1 doublets, depending on the state of MR16 and MR17. Normal transmission of the message resumes when a new character is available in the Transmit Data Holding Register. If the SEND DLE bit in the command register is true, the DLE character is automatically transmitted prior to transmission of the message character in the transmit holding register.

## COM 2449 PROGRAMMING

Prior to initiating data communications, the COM 2449 operational mode must be programmed by performing write operations to the mode and command registers. In addition, if synchronous operation is programmed, the appropriate SYN/DLE registers must be loaded. The COM 2449 can be reconfigured at any time during program execution. A flow chart of the initialization process appears in Figure 1.
The internal registers of the COM 2449 are accessed by applying specific signals to the $\overline{C E}, \bar{R} / W, A 2, A 1$ and $A 0$ inputs. The conditions necessary to address each register are shown in Table 5.

TABLE 5-COM 2449 REGISTER ADDRESSING

| CE | A2 | A1 | AO | $\overline{\text { R/W }}$ | FUNCTION |
| :--- | :---: | :---: | :---: | :---: | :--- |
| 1 | X | X | X | X | Tri-st ate data bus |
| 0 | 0 | 0 | 0 | 0 | Read receive holding register |
| 0 | 0 | 0 | 0 | 1 | Write transmit holding register |
| 0 | 0 | 0 | 1 | 0 | Read status register 1 |
| 0 | 0 | 0 | 1 | 1 | Write SYN1/SYN2/DLE registers |
| 0 | 0 | 1 | 0 | 0 | Read mode registers 1 and 2 |
| 0 | 0 | 1 | 0 | 1 | Write mode registers 1 and 2 |
| 0 | 0 | 1 | 1 | 0 | Read command register |
| 0 | 0 | 1 | 1 | 1 | Write command register |
| 0 | 1 | 0 | 0 | 0 | Read output register |
| 0 | 1 | 0 | 0 | 1 | Write output register |
| 0 | 1 | 0 | 1 | 0 | Read status register 2 |
|  |  |  |  |  | Write status register 2 |

NOTE
See $A C$ Characteristics section for timing requirements.

The SYN1, SYN2, and DLE registers are accessed by performing write operations with the conditions $\mathrm{A} 2=0$, $A 1=0, A 0=1$, and $A / W=1$. The first operation loads the SYN1 register. The next loads the SYN2 register, and the third loads the DLE register. Reading or loading the mode registers is done in a similar manner. The first write (or read) operation addresses Mode Register 1, and a subsequent operation addresses Mode Register 2. If more than the required number of accesses are made, the internal sequencer recycles to point at the first register. The pointers are reset to SYN1 Register and

Mode Register 1 by a RESET input or by performing a "Read Command Register" operation, but are unaffected by any other read or write operation.
The COM 2449 register formats are summarized in Tables 6, 7, 8, 9, 10 and 11. Mode Registers 1 and 2 define the general operational characteristics of the COM 2449, while the Command Register controls the operation within this basic framework. The COM 2661 indicates its status in the two Status Registers. The status registers are cleared when a RESET input is applied.

## MODE REGISTER 1 (MR1)

Table 6 illustrates Mode Register 1. Bits MR11 and MR10 select the communication format and Baud rate multiplier. 00 specifies synchronous mode and 1 X multiplier. 1X, 16X, and 64X multipliers are programmable for asynchronous format. However, the multiplier in asynchronous format applies only if the external clock input option is selected by MR24 or MR25.
MR13 and MR12 select a character length of 5, 6, 7, or 8 bits. The character length does not include the parity bit, if programmed, and does not include the start and stop bits in asynchronous mode.
MR14 controls parity generation. If enabled, a parity bit is added to the transmitted character and the receiver performs a parity check on incoming data. MR15 selects odd or even parity when parity is enabled by MR14.
In asynchronous mode, MR17 and MR16 select character
framing of $1,1.5$, or 2 stop bits (if 1 X baud rate is programmed, 1.5 , stop bits defaults to 1 stop bits on transmit). In synchronous mode, MR17 controls the number of SYN characters used to establish synchronization and for character fill when the transmitter is idle. SYN1 alone is used if MR17 $=1$, and SYN1-SYN2 is used when MR17 $=0$. If the transparent mode is specified by MR16, DLE-SYN1 is used for character fill and SYN Detect, but the normal synchronization sequence is used. When transmitting, a DLE character in the transmit holding register will cause a second DLE character to be transmitted. This DLE stuffing eliminates the software DLE compare and stuff on each transparent mode data character. If the send DLE command (CR3) is active when a DLE is loaded into THR, only one additional DLE will be transmitted. Also DLE stripping and DLE Detect (with MR14 $=0$ ) are enabled.

TABLE 6-MODE REGISTER 1 (MR1)

| MR17 MR16 | MR15 | MR14 | MR13 MR12 | MR11 MR10 |
| :---: | :---: | :---: | :---: | :---: |
| Syne/Async | Parlty Type | Parity Control | Character Length | Mode and Baud Rate Factor |
| ASYNCH: STOP BIT LENGTH $00=$ INVALID <br> $01=1$ STOP BIT <br> $10=11 / 2$ STOP BITS <br> $11=2$ STOP BITS | $\begin{aligned} & 0=O D D \\ & 1=E V E N \end{aligned}$ | $\begin{aligned} & 0=\text { DISABLED } \\ & 1=\text { ENABLED } \end{aligned}$ | $\begin{aligned} & 00=5 \text { BITS } \\ & 01=6 \text { BITS } \\ & 10=7 \text { BITS } \\ & 11=8 \text { BITS } \end{aligned}$ | $00=$ SYNCHRONOUS 1 X RATE <br> 01=ASYNCHRONOUS $1 \times$ RATE <br> $10=$ ASYNCHRONOUS 16 X RATE <br> $11=$ ASYNCHRONOUS 64X RATE |
| SYNCH: NUMBER SYNCH: TRANS- <br> OF SYN CHAR <br> PARENCY CONTROL <br> $0=$ DOUBLE SYN $0=$ NORMAL <br> $1=$ SINGLE SYN $1=$ TRANSPARENT |  |  |  | . |

NOTE Baud rate factor in asynchronous applies only if external clock is selected. Factor is 15 X if
internal clock is selected. Mode must be selected (MR11, MR10) in any case.

## MODE REGISTER 2 (MR2)

Table 7 illustrates mode register 2 (MR23, MR22, MR21 and MR20 control the frequency of the internal baud rate generator (BRG). Sixteen rates are selectable for each COM 2449 version ( $(-1,-2,-3$ ). Version 1 and 2 specify a 4.9152 MHz TTL input at BRCLK (pin 20); version 3 specifies a 5.0688 MHz input which is identical to the

COM 2651 and COM 2661-3. MR23-20 are don't cares if external clocks are selected (MR25-24=0). The individual rates are given in table $2 \mathrm{a}, \mathrm{b}$ and c .
MR24-MR27 select the receive and transmit clock source (either the BRG or an external input) and the function at pins 9 and 25 . Refer to table 7.

TABLE 7-MODE REGISTER 2 (MR2)

|  | MR-27-MR24 |  |  |  |  |  |  |  |  |  | MR23-MR20 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TxC | RxC | Pin 9 | Pin 25 |  | TxC | RxC | Pin 9 | Pin 25 | Mode | Baud Rate Selection |
| 0000 | E | E | TxC | RxC | 1000 | E | E | XSYNC ${ }^{1}$ | RxC/TxC | sync |  |
| 0001 | E | - I | TxC | 1 X | 1001 | E | I | TxC | BKDET | async |  |
| 0010 | 1 | $E$ | 1 X | RxC | 1010 | 1 | E | XSYNC' | RxC | sync |  |
| 0011 | 1 | I | 1X | 1X | 1011 | 1 | I | 1X | BKDET | async | See baud rates in table 2 |
| 0100 | E | E | TxC | RxC | 1100 | E | E | XSYNC ${ }^{1}$ | RxC/TxC | sync |  |
| 0101 | E | 1 | TxC | 16X | 1101 | E | I | TxC | BKDET | async |  |
| 0110 | 1 | E | 16X | RxC | 1110 | 1 | E | XSYNC | RxC | sync |  |
| 0111 | 1 | I | 16X | 16X | 1111 | 1 | 1 | 16X | BKDET | async |  |
| TES <br> When | is pro | med | YNC | , SYN1, | N1-SY | and D | SYN | ction is |  |  | E=External clock <br> I=Internal clock (BRG) <br> 1 X and 16 X are clock outputs |

Table 8 illustrates the Command Register. Bits CRO (TXEN) and CR2 (RxEN) enable or disable the transmitter and receiver respectively. A 0 to 1 transition of CR2 forces start bit search (async mode) or hunt mode (sync mode) on the second RxC rising edge. Disabling the receiver causes RxRDY to go high (inactive). If the transmitter is disabled, it will complete the transmission of the character in the Transmit Shift Register (if any) prior to terminating operation. The TxD output will then remain in the marking state (high while the TxRDY and TxEMT will go high (inactive). If the receiver is disabled, it will terminate operation immediately. Any character being assembled will be neglected. Bits CR1 (TR) and CR5 (RS) control the TR and RS outputs. Data at the outputs are the logical complement of the register data.
In asynchronous mode, setting CR3 will force and hold the TxD output low (spacing condition) at the end of the current transmitted character. Normal operation resumes when CR3 is cleared. The TxD line will go high for at least one bit time before beginning transmission of the next character in the Transmit Data Holding Register. In synchronous mode, setting CR3 causes the transmission of the DLE register contents prior to sending the character in the Transmit Data Holding Register. Since this is a one time command, CR3 does not have to be reset by software. CR3 should be set when entering and exiting transparent mode and for all DLE- non-DLE character sequences.
Setting CR4 causes the error flags in the Status Register 1 (SR13, SR14, and SR15) to be cleared. This is a one time command. There is no internal latch for this bit. When CR5 (RS) is set, the $\overline{R S}$ pin is forced low and the transmit serial logic is enabled. A 1 to 0 transition of CR5 will cause $\overline{\mathrm{RS}}$ to go high (inactive) one TxC time after the last serial bit has been transmitted (if the transmit shift register was not empty).
The COM 2449 can operate in one of four sub-modes within each major mode (synchronous or asynchronous). The operational sub-mode is determined by CR7 and CR6. CR7-CR6 $=00$ is the normal mode, with the transmitter and receiver operating independently in accordance with the Mode and Status Register instructions.
In asynchronous mode, CR7-CR6 $=01$ places the COM 2449 in the Automatic Echo mode. Clocked, regenerated received data are automatically directed to the TxD line while normal receiver operation continues. The receiver must be enabled (CR2=1), but the transmitter need not be enabled. Processor to receiver communications continue normally, but the processor to transmitter link is disabled. Only the first character of a break condition is echoed. The TxD output will go high until the next valid start is detected. The following conditions are true while in Automatic Echo mode:

1. Data assembled by the receiver are automatically
placed in the Transmit Holding Register and retransmitted by the transmitter on the TXD output.
2. The transmitter is clocked by the receive clock.
3. $\overline{\text { TxRDY output }=1 \text {. }}$
4. The TxEMT/DSCHG pin will reflect only the data set change condition.
5. The TXEN command (CRO) is ignored.

In synchronous mode, CR7-CR6 $=01$ places the COM 2449 in the Automatic SYN/DLE Stripping mode. The exact action taken depends on the setting of bits MR17 and MR16:

1. In the non-transparent, single SYN mode (MR17MR16=10), characters in the data stream matching SYN1 are not transferred to the Receive Data Holding Register (RHR).
2. In the non-transparent, double SYN mode (MR17MR16=00), characters in the data stream matching SYN1, or SYN2 if immediately preceded by SYN1, are not transferred to the RHR.
3. In transparent mode (MR16 $=1$ ), characters in the data stream matching DLE, or SYN1 if immediately preceded by DLE, are not transferred to the RHR. However, only the first DLE of a DLE-DLE pair is stripped.

Note that Automatic Stripping mode does not affect the setting of the DLE Detect and SYN Detect status bits (SR13 and SR15).
Two diagnostic sub-modes can also be configured. In Local Loop Back mode (CR7-CR6=10), the following loops are connected internally:

1. The transmitter output is connected to the receiver input.
2. $\overline{\mathrm{TR}}$ is connected to $\overline{\mathrm{RR}}$ and $\overline{\mathrm{RS}}$ is connected to $\overline{\mathrm{CS}}$.
3. The receiver is clocked by the transmit clock.
4. The TR, $\overline{R S}$ and $T x D$ outputs are held high.
5. The $\overline{C S}, \overline{R R}, \overline{D M}$ and RxD inputs are ignored.

Additional requirements to operate in the Local Loop Back mode are that CR0 (TxEN), CR1 (TR), and CR5 (RS) must be set to 1. CR2 (RxEN) is ignored by the COM 2449.
The second diagnostic mode is the Remote Loop Back mode (CR7-CR6=11). In this mode:

1. Data assembled by the receiver is automatically placed in the Transmit Holding Register and retransmitted by the transmitter on the TxD output.
2. The transmitter is clocked by the receive clock.
3. No data are sent to the local processor, but the error status conditions (PE, OE, FE) are set.
4. The RxRDY, TxRDY, and TxEMT/DSCHG outputs are held high.
5. CR1 (TxEN) is ignored.
6. All other signals operate normally.

| CR7 ${ }^{\text {c/ }}$ CR6 | CR5 | CR4 | CR3 | CR2 | CR1 | CRO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operating Mode | Request to Send | Reset Error | Sync/Async | Recelve Control (RXEN) | Terminal Ready | Transmit Control (TXEN) |
| $00=$ NORMAL OPERATION $01=$ ASYNCH: AUTOMATIC ECHO MODE SYNCH: SYN AND/OR DLE STRIPPING MODE <br> $10=$ LOCAL LOOP BACK REMOTE LOOP BACK | $0=$ FORCE $\overline{\text { RS }}$ OUTPUT HIGH ONE CLOCK time AFTER TxSR SERIALization 1=FORCE $\overline{\text { SS }}$ OUTPUT LOW | $\begin{aligned} & 0=\text { NORMAL } \\ & 1=\text { RESET } \\ & \text { ERROR FLAG } \\ & \text { IN STATUS } \\ & \text { (FE, OE, } \\ & \\ & \text { PE/DLE DETECT) } \end{aligned}$ | ASYNCH: <br> FORCE BREAK <br> $0=$ NORMAL <br> 1=FORCE <br> BREAK <br> SYNCH: <br> SEND DLE <br> $0=$ NORMAL <br> $1=$ SEND DLE | $\begin{aligned} & 0=\text { DISABLE } \\ & 1=\text { ENABLE } \end{aligned}$ | $0=$ FORCE $\overline{T R}$ OUTPUT HIGH 1=FORCE $\overline{T R}$ OUTPUT LOW | $\begin{aligned} & 0=\text { DISABLE } \\ & 1=\text { ENABLE } \end{aligned}$ |

## STATUS REGISTER 1 (SR1)

The data contained in the Status Register 1 (as shown in Table 9) indicate receiver and transmitter conditions and modem/data set status.
SR10 is the Transmitter Ready (TxRDY) status bit. It, and its corresponding output, are valid only when the transmitter is enabled. If equal to 0 , it indicates that the Transmit Data Holding Register has been loaded by the processor and the data has not been transferred to the Transmit Shift Register. If set equal to 1, it indicates that the Holding Register is ready to accept data from the processor. This bit is initially set when the Transmitter is enabled by CRO, unless a character has previously been loaded into the Holding Register. It is not set when the Automatic Echo or Remote Loop Back modes are programmed. When this bit is set, the TxRDY output pin is low. In the Automatic Echo and Remote Loop Back modes, the output is held high.
SR11, the Receiver Ready (RxRDY) status bit, indicates the condition of the Receive Data Holding Register. If set, it indicates that a character has been loaded into the Holding Register from the Receive Shift Register and is ready to be read by the processor. If equal to zero, there is no new character in the Holding Register. This bit is cleared when the processor reads the Receive Data Holding Register or when the receiver is disabled by CR2. When set, the RxRDY output is low.
The TxEMT/DSCHG bit, SR12, when set, indicates a change of state of the DM or RR inputs (when CR2 or $\mathrm{CRO}=1$ ), the $\overline{\mathrm{ST}}, \overline{\mathrm{SB}}, \overline{\mathrm{SQ}}, \overline{\mathrm{TM}}$ or $\overline{T C}$ inputs (when SR25, SR26, or SR27=1) or that the Transmit Shift Register has completed transmission of a character and no new character has been loaded into the Transmit Data Holding Register. Note that in synchronous mode this bit will be set even though the appropriate "fill", character is transmitted. TxEMT will not go active until at least one character has been transmitted. It is cleared by loading the Transmit Data Holding Register. The DSCHG condition is enabled when $\operatorname{TxEN}=1$ or $\mathrm{RxEN}=1$.

It is cleared when status register 1 is read by the processor. If status register 1 is read twice and SR12 $=1$ while SR16 and SR17 remain unchanged, then a TXEMT condition exists. When SR12 is set, the TxEMT/DSCHG output is low.
SR13, when set, indicates a received parity error when parity is enabled by MR14. In synchronous transparent mode (MR16=1), with parity disabled, it indicates that a character matching the DLE Register has been received, and the present character is neither SYN1 nor DLE. This bit is cleared when the next character following the above sequence is loaded into the Receive Data Holding Register, when the receiver is disabled, or by a reset error command, CR4.
The Overrun Error status bit, SR14, indicates that the previous character loaded into the Receive Holding Register was not read by the processor at the time a new received character was transferred into it. This bit is cleared when the receiver is disabled and by the Reset Error command, CR4.
In asynchronous mode, bit SR15 signifies that the received character was not framed by a stop bit, i.e., only the first stop bit is checked. If the RHR contains all 0 's when SR15 = 1 , a break condition is present. In synchronous non-transparent mode (MR16 $=0$ ), it indicates receipt of the SYN1 character in single SYN mode or the SYN1-SYN2 pair in double SYN mode. In synchronous transparent mode (MR16=1), this bit is set upon detection of the initial synchronizing characters (SYN1 or SYN1-SYN2) and, after synchronization has been achieved, when a DLE-SYN1 pair is received. The bit is reset when the receiver is disabled, when the Reset Error command is given in asynchronous mode, or when Status Register 1 is read by the processor in the synchronous mode.
SR16 and SR17 reflect the conditions of the $\overline{\mathrm{RR}}$ and $\overline{\mathrm{DM}}$ inputs respectively. A low input sets the corresponding status bit and a high input clears it.

| SR17 | SR16 | SR15 | SR14 | SR13 | SR12 | SR11 | SR10 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Data Mode | Receiver Ready | FE/SYN Detect | Overrun | PE/DLE Detect | TxEMT/DSCHG | RxRDY | TxRDY |
| $\begin{gathered} 0=\overline{\mathrm{DM}} \text { INPUT } \\ \text { IS HIGH } \\ 1=\overline{\mathrm{DM}} \text { INPUT } \\ \text { IS LOW } \end{gathered}$ | $\begin{aligned} 0=\overline{R R} \text { INPUT } \\ \text { IS HIGH } \\ 1=\overline{R R} \text { INPUT } \\ \text { IS LOW } \end{aligned}$ | ASYNCH: <br> $0=$ NORMAL <br> 1=FRAMING <br> ERROR <br> SYNCH: <br> $0=$ NORMAL <br> $1=$ SYN CHAR <br> detected | $\begin{aligned} 0 & =\text { NORMAL } \\ 1 & =\text { OVERRUUN } \\ & \text { ERROR } \end{aligned}$ | ASYNCH: <br> $0=$ NORMAL <br> 1=PARITY <br> ERROR <br> SYNCH: <br> $0=$ NORMAL <br> $1=$ PARITY <br> ERROR OR <br> DLE CHAR <br> RECEIVED | $\begin{aligned} & 0=\text { NORMAL } \\ & 1=\text { CHANGE } \\ & \text { IN DSR OR } \\ & \hline \text { DCD, OR } \\ & \text { TRANSMIT } \end{aligned}$ <br> SHIFT REGIS- <br> TER IS <br> EMPTY | $0=$ RECEIVE <br> HOLDING REG EMPTY <br> 1 = RECEIVE <br> HOLDING REG has Data | $0=$ TRANSMIT <br> HOLDING <br> REG BUSY <br> 1=TRANSMIT <br> HOLDING <br> REG EMPTY |

TABLE 9-STATUS REGISTER 1 (SR1)

## STATUS REGISTER 2 (SR2)

The Data contained in the 5 least significant bits (SR20 to SR24) reflect the conditions of the IC, $\overline{T M}, \overline{S Q}, \overline{S B}$ and SI inputs respectively. A low input sets the corresponding status bit high and a high input clears the corresponding status bit low. These 5 bits or read only. The three most significant bits (SR25 to SR27) allow interrupts to be enabled on the 5 inputs reflected in SR20 to SR24.
Setting SR25 enables an interrupt to occur when the IC
input signal experiences a change of state. Setting SR26 enables an interrupt to occur when the TM input signal experiences a change of state. Setting SR27 enables an interrupt to occur when the SQ, $\overline{\text { SI, or }}$ SB input signals experience a change of state. All interrupts enabled in these 3 bits will be reflected in the DSCHG/TxEMT output signal and its corresponding status bit (SR12). These 3 bits can be read as well as written according to Table5. Table 10 illustrates bit assignments of Status Register 2.

| SR27 <br> Interrupt Enable 1 | SR26 Interrupt Enable 2 | SR25 Interrupt Enable 3 | SR24 Signal Rate Indication | SR23 Standby Indicator | SR22 <br> Signal Quality | SR21 <br> Test <br> Mode | $\begin{gathered} \text { SR20 } \\ \text { Incoming } \\ \text { Call } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1=INTERRUPT ON SQ, SI, SB STATE CHANGE | $1=$ INTERRUPT ON TM STATE CHANGE | $\begin{aligned} & 1=\text { INTERRUPT } \\ & \text { ON IC STATE } \\ & \text { CHANGE } \end{aligned}$ | $\begin{aligned} & 0=\overline{S I} \text { INPUT } \\ & \text { IS HIGH } \\ & 1==\overline{S I} \text { INPUT } \\ & \text { IS LOW } \end{aligned}$ | $\begin{aligned} & 0= \overline{S B} \text { INPUT } \\ & \text { IS HIGH } \\ & 1= \overline{S B} \text { INPUT } \\ & \text { IS LOW } \end{aligned}$ | $\begin{aligned} & 0=\overline{\text { SQ INPUT }} \\ & \text { IS HIGH } \\ & 1==\text { SQ INPUT } \\ & \text { IS LOW } \end{aligned}$ | $\begin{gathered} 0=\overline{T M} \text { INPUT } \\ \text { IS HIGH } \\ 1=\overline{T M} \text { INPUT } \\ \text { IS LOW } \end{gathered}$ | $\begin{aligned} & 0= \bar{C} \text { INPUT } \\ & \text { IS HIGH } \\ & 1= \bar{C} \text { INPUT } \\ & \text { IS LOW } \end{aligned}$ |

## OUTPUT REGISTER (OR)

This 6 bit read write register (OR5-ORO) controls the 6 new output signals added to the COM2449. OR5-1 directly control the state of the $\overline{\mathrm{I}}, \overline{\mathrm{SF}} / \mathrm{SR}, \overline{\mathrm{SS}}, \overline{\mathrm{RL}}$, and LL respectively.

ORO when set to a logic 1 will cause the $\overline{N S}$ output to become low. When ORO is set to a logic 0 the NS output will not change until the RR input goes high.
Table 11 illustrates bit positions of the Output Register.

| OR7 | OR6 | OR5 | OR4 | OR3 | OR2 | OR1 | ORO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Terminal In service | Select <br> Frequency/ <br> Signal rate <br> select | Select Standby | Remote Loopback | Local Loopback | New Signal |
| DON'T CARE | DON'T CARE | $0=\bar{S}$ OUTPUT GOES HIGH $1=\bar{S}$ OUTPUT GOES LOW | $\begin{gathered} 0=\overline{\mathrm{SF} / \mathrm{SR} \text { OUTPUT }} \\ \quad \mathrm{HIGH} \\ 1=\overline{\mathrm{SF} / \mathrm{SR} \text { OUTPUT }} \\ \text { LOW } \end{gathered}$ | $\begin{gathered} 0=\overline{\text { SS OUTPUT }} \\ \text { HIGH } \\ 1=\overline{\text { SS OUTPUT }} \\ \text { LOW } \end{gathered}$ | $0=\overline{\text { RL }}$ OUTPUT <br> GOES HIGH <br> $1=\overline{\text { RL }}$ OUTPUT <br> GOES LOW | $0=\overline{\text { LI OUTPUT }}$ GOES HIGH $1=\overline{\mathrm{RL}}$ OUTPUT goes Low | $0=\overline{\text { NS }}$ OUTPUT GOES HIGH ONLY WHEN $\overline{\mathrm{RR}}$ INPUT GOES HIGH $1=\overline{N S}$ OUTPUT GOES Low |

TABLE 11-OUTPUT REGISTER (OR)

## шш"॥ЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛЛ





## MAXIMUM GUARANTEED RATINGS*

Operating Temperature Range $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range ..................................................................................... . . $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec.) . ................................................................................... $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +18.0 V

*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. For example, the bench power supply programmed to deliver +12 volts may have large voltage transients when the AC power is switched on and off. If this possibility exists it is suggested that a clamp circuit be used.

DC ELECTRICAL CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$

|  | PARAMETER | MIN | TYP | MAX | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & V_{I L} \\ & V_{I H} \end{aligned}$ | Input voltage Low High | 2.0 |  | 0.8 | V |  |
| $\begin{aligned} & V_{\text {OL }} \\ & V_{\text {OH }} \end{aligned}$ | Output voltage Low High | 2.4 |  | 0.4 | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=2.2 \mathrm{~mA} \\ & \mathrm{IOH}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{IL}}$ | Input leakage current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=0$ to 5.5 V |
| $\begin{aligned} & \mathrm{I}_{\mathrm{LH}} \\ & \mathrm{I}_{\mathrm{LL}} \\ & \hline \end{aligned}$ | Output leakage current Data bus high Data bus low |  |  | $\begin{aligned} & 10 \\ & 10 \\ & \hline \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ | $\begin{aligned} & V_{0}=4.0 \mathrm{~V} \\ & V_{0}=0.45 \mathrm{~V} \end{aligned}$ |
| Icc | Power supply current |  |  | 150 | mA |  |
| $\mathrm{C}_{\mathrm{IN}}$ Cout $\mathrm{C}_{1 / 0}$ | Capacitance Input Output Input/Output |  |  | 20 <br> 20 <br> 20 | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\mathrm{fc}=1 \mathrm{MHz}$ <br> Unmeasured pins tied to ground |

AC ELECTRICAL CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$

|  | PARAMETER | MIN | TYP | MAX | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & t_{\text {tes }} \\ & t_{\text {l }} \end{aligned}$ | Pulse width Reset Chip enable | $\begin{aligned} & 1000 \\ & 250 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |  |
| $t_{\text {AS }}$ <br> $t_{\text {AH }}$ <br> tcs <br> tch <br> tos <br> $\mathrm{t}_{\mathrm{DH}}$ <br> $t_{\text {fxs }}$ <br> $\mathrm{t}_{\mathrm{BXH}}$ | Setup and hold time Address setup Address hold R/W control setup $\overline{\mathrm{R}} / \mathrm{W}$ control hold Data setup for write Data hold for write Rx data setup Rx data hold | $\begin{gathered} 10 \\ 10 \\ 10 \\ 10 \\ 150 \\ 0 \\ 300 \\ 350 \end{gathered}$ |  |  | ns ns ns ns ns ns ns ns |  |
| $\begin{aligned} & t_{\mathrm{DD}} \\ & \mathrm{t}_{\mathrm{DF}} \\ & \mathrm{t}_{\mathrm{CED}} \end{aligned}$ | Data delay time for read Data bus floating time for read $\overline{\mathrm{CE}}$ to $\overline{\mathrm{CE}}$ delay | 600 |  | $\begin{aligned} & 200 \\ & 100 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \\ & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \end{aligned}$ |
| $f_{\text {farg }}$ <br> $f_{\text {brg }}$ <br> $f_{\mathbf{R}, T^{1}}$ | ```Input clock frequency Baud rate generator (2449-1, -2) Baud rate generator (2449-3) \(\overline{\mathrm{TxC}}\) or \(\overline{\mathrm{RxC}}\)``` | $\begin{aligned} & 1.0 \\ & 1.0 \\ & d c \\ & \hline \end{aligned}$ | $\begin{aligned} & 4.9152 \\ & 5.0688 \end{aligned}$ | $\begin{gathered} 4.9202 \\ 5.0738 \\ 1.0 \\ \hline \end{gathered}$ | MHz <br> MHz <br> MHz |  |
| $t_{B R H}$ <br> $t_{B R H}$ <br> $t_{B R L}$ <br> $t_{\text {BRL }}$ <br> $t_{\text {RTH }}$ <br> $t_{\text {R/TL }}$ | Clock width <br> Baud rate high <br> (2449-1, -2$)$ <br> Baud rate high <br> (2449-3) <br> Baud rate low <br> (2449-1, -2$)$ <br> Baud rate low <br> (2449-3) <br> $\frac{T \times C}{}$ or $\overline{\text { RxC }}$ high <br> TXC or $\mathrm{R} \mathrm{\times C}$ low | $\begin{aligned} & 75 \\ & 70 \\ & 75 \\ & 70 \\ & 480 \\ & 480 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ | $f_{\text {BRG }}=4.915 \mathrm{MHz}$; measured fagG $=5.0688 \mathrm{MHz}$; measured $\underset{f_{\mathrm{BRG}}}{ }=4.915 \mathrm{MHz}$ at measured at $V_{\mathrm{VL}}$ $f_{\text {GRG }}=5.0688 \mathrm{MHz}$; measured at $\mathrm{V}_{\mathrm{IL}}$ |
| $\begin{aligned} & t_{\mathrm{TXD}} \\ & t_{\mathrm{T} C} \end{aligned}$ | TxD delay from falling edge of TxC <br> Skew between TxD changing and falling edge of TxC output |  | 0 | 650 | ns ns | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \\ & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \end{aligned}$ |

## NOTE:

1. $f_{\mathrm{R}, \tau}$ and $\mathrm{t}_{\mathrm{R}, \pi \mathrm{L}}$ shown all modes except Local Loopback. For Local Loopback mode $\mathrm{f}_{\mathrm{R} / \mathrm{T}}=0.7 \mathrm{MHz}$ and $\mathrm{t}_{\mathrm{R} / \mathrm{L}}=700 \mathrm{~ns} \mathrm{~min}$.
 devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

# Universal Synchronous Receiver/Transmitter USRT 

## FEATURES

STR, BSC-Bi-sync and interleaved bi-sync modes of operationFully Programmable - data word length, parity mode, receiver sync character, transmitter sync characterFull or Half Duplex Operation - can receive and transmit simultaneously at different baud ratesFully Double Buffered-eliminates need for precise external timingDirectly TTL Compatible-no interface components requiredTri-State Data Outputs - bus structure orientedIBM Compatible-internally generated SCR and SCT signalsHigh Speed Operation - 250K baud, 200ns strobesLow Power-300mWInput Protected-eliminates handling problemsDip Package-easy board insertion
## APPLICATIONS

Bi-Sync CommunicationsCassette I/OFloppy Disk I/O
## GENERAL DESCRIPTION

The Universal Synchronous Receiver/Transmitter is an MOS/LSI monolithic circuit that performs all the receiving and transmitting functions associated with synchronous (STR, BSC, Bi-sync, and interleaved bi-sync) data communications. This circuit is fabricated using SMC's P -channel low voltage oxide-nitride technology, allowing all inputs and outputs to be directly TTL compatible. The duplex mode, baud rate, data word length, parity mode, receiver sync character, and transmitter sync character are independently programmable through the use of external controls. The USR/T is fully double buffered and internally generates the sync character received and sync character transmitted signals. These programmable features provide the user with the ability to interface with all synchronous peripherals.


| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 1 | Vcc | Power Supply | +5 volt Supply |
| 2 | TBMT | Transmitter Buffer Empty | This output is at a high-level when the transmitter data buffer register may be loaded with new data. |
| 3 | TSO | Transmitter Serial Output | This output serially provides the entire transmitted character. This character is extracted from the transmitter data buffer register provided that a TDS pulse occurs during the presently transmitted character. If TDS is not pulsed, the next transmitted character will be extracted from the transmitter sync register. |
| 4 | GND | Ground | Ground |
| 5 | SCT | Sync Character Transmitted | This output is set high when the character loaded into the transmitter shift register is extracted from the transmitter sync register, indicating that the TDS was not pulsed during the previously transmitted character. This output is reset low when the character to be transmitted is extracted from the transmitter data buffer register. This can only occur if TDS is pulsed. |
| 6 | Vod | Power Supply | -12 volt Supply |
| 7-14 | DB1-DB8 | Data Bus Inputs | This 8 bit bus inputs information into the receiver sync register under control of the RSS strobe, into the transmitter sync register under control of the TSS strobe, and into the transmitter data buffer register under control of the TDS strobe. The strobes operate independently of each other. Unused bus inputs may be in either logic state. The LSB should always be placed on DB1. |
| 15 | RR | Receiver Reset | This input should be pulsed to a high-level after power turn-on. This resets the RDA, SCR, ROR, and RPE outputs to a low-level. The transition of the RR input from a highlevel to a low-level sets the receiver into the search mode (bit phase). In the search mode the serially received data bit stream is examined on a bit by bit basis until async character is found. A sync character is found, by definition, when the contents of the receiver sync register and the receiver shift register are identical. When this occurs the SCR output is set high. This character is then loaded into the receiver buffer register and the receiver is set into the character mode. In this mode each character received is loaded into the receiver buffer register. |
| 16 | RPE | Receiver Parity Error | This output is a high-level if the received character parity bit does not agree with the selected parity. |

## DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 17 | SCR | Sync Character Received | This output is set high each time the character loaded into the receiver buffer register is identical to the character in the receiver sync register. This output is reset low the next time the receiver buffer register is loaded with a character which is not a sync character. |
| 18 | TSS | Transmitter Sync Strobe | A high-level input strobe loads the character on the DB1DB8 lines into the transmitter sync register. |
| 19 | TCP | Transmitter Clock | The positive going edge of this clock shifts data out of the transmitter shift register, at a baud rate equal to the TCP clock frequency. |
| 20 | TDS | Transmitter Data Buffer Strobe | A high-level input strobe loads the character on the DB1DB8 lines into the transmitter data buffer register. |
| 21 | RSS | Receiver Sync Strobe | A high-level input strobe loads the character on the DB1DB8 lines into the receiver sync register. |
| 22 | RSI | Receiver Serial Input | This input accepts the serial bit input stream. |
| 23 | RCP | Receiver Clock | The negative-going edge of this clock shifts data into the receiver shift register, at a baud rate equal to the RCP clock frequency. |
| 24 | RDAR | Receiver Data Available Reset | A high-level input resets the RDA output to a low-level. |
| 25 | RDE | Received Data Enable | A high-level input enables the outputs (RD8-RD1) of the receiver buffer register |
| 26 | RDA | Receiver Data Available | This output is at a high-level when an entire character has been received and transferred into the receiver buffer register. |
| 27 | ROR | Receiver OverRun | This output is at a high-level if the previously received character is not read (RDA not reset) before the present character is transferred into the receiver buffer register. |
| 28-35 | RD8-RD1 | Receiver Data Output | These are the 8 tri-state data outputs enabled by RDE. Unused data output lines, as selected by NDB1 and NDB2, have a low level output, and received characters are right justified, i.e. the LSB always appears on the RD1 output. |
| 36,38 | NDB2, NDB1 | Number of Data Bits | These 2 inputs are internally decoded to select either 5,6,7, or 8 data bits/character as per the following truth table: |
|  |  |  | NDB2 NDB1 data bits/character <br> L L 5 <br> L $H$ 6 <br> $H$ $L$ 7 <br> $H$ $H$ 8 |


| PIN NO. SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: |
| 37 | NPB | No Parity Bit |
| 39 | CS | A high-level input eliminates the parity bit from being <br> transmitted. In addition, it is necessary that the received <br> character contain no parity bit. Also, the RPE output is <br> forced to a low-level. See pin 40, POE. |
| 40 | POE | Control Strobe <br> A high-level input enters the control bits (NDB1, NDB2, <br> POE, and NPB) into the control bits register. This line may <br> be strobed or hard wired to a high-level. |

## ADDITIONAL TIMING INFORMATION (Typical Propagation Delays)



## MAXIMUM GUARANTEED RATINGS*


*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{Vcc}=+5 \mathrm{~V} \pm 5 \%, \mathrm{VDD}=-12 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min | Typ | Max | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS |  |  |  |  |  |
| INPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, VIL | Vdo |  | 0.8 | V |  |
| High-level, $\mathrm{V}_{1}$ | Vcc-1.5 |  | Vcc | V |  |
| OUTPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, Vol |  | 0.2 | 0.4 | v | $\mathrm{IOL}=1.6 \mathrm{~mA}$ |
| High-level, Vor | 2.4 | 4.0 |  | V | $\mathrm{IOH}=-100 \mu \mathrm{~A}$ |
| INPUT CURRENT |  |  |  |  |  |
| Low-level, Ill |  |  | 1.6 | mA | see note 1 |
| OUTPUT CURRENT |  |  |  |  |  |
| Leakage, lıo |  |  | -1 | $\mu \mathrm{A}$ | RDE $=\mathrm{V}_{\text {IL }}, \mathrm{O} \leq$ Vout $\leq+5 \mathrm{~V}$ |
| Short circuit, los** |  |  | 10 | mA . | Vout $=0 \mathrm{~V}$ |
| INPUT CAPACITANCE |  |  |  |  |  |
| All inputs, Cin |  | 5 | 10 | pf | $\mathrm{V}_{1 \mathrm{~N}}=\mathrm{Vcc}_{\text {c }} \mathrm{f}=1 \mathrm{MHz}$ |
| OUTPUT CAPACITANCE |  |  |  |  |  |
| All outputs, Cout |  | 10 | 20 | pf | $\mathrm{R}_{\mathrm{DE}}=\mathrm{V}_{\mathrm{IL}, \mathrm{f}} \mathrm{f}=1 \mathrm{MHz}$ |
| POWER SUPPLY CURRENT |  |  |  |  |  |
| Icc IDD |  |  | $\begin{aligned} & 28 \\ & 28 \end{aligned}$ | $\left.\begin{array}{l} \mathrm{mA} \\ \mathrm{~mA} \end{array}\right\}$ | All outputs $=\mathrm{VOH}$ |
| A.C. CHARACTERISTICS |  |  |  |  | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ |
| CLOCK FREQUENCY | DC |  | 250 | KHz | RCP, TCP |
| PULSE WIDTH |  |  |  |  |  |
| Clock | 1 |  |  | $\mu \mathrm{s}$ | RCP, TCP |
| Receiver reset | 1 |  |  | $\mu \mathrm{s}$ |  |
| Control strobe | 200 |  |  | ns | CS |
| Transmitter data strobe | 200 |  |  | ns | TDS |
| Transmitter sync strobe | 200 |  |  | ns | TSS |
| Receiver sync strobe Receiver data available | 200 |  |  | ns | RSS |
|  | 200 |  |  | ns | RDAR |
| INPUT SET-UP TIME |  |  |  |  |  |
| Data bits | $>0$ |  |  | ns | DB1-DB8 |
| Control bits | $>0$ |  |  | ns | NPB, NDB2, NDB1, POE |
| INPUT HOLD TIME $>0$ - |  |  |  |  |  |
| Data bits | $>0$ |  |  | ns | DB1-DB8 |
| Control bits | $>0$ |  |  | ns | NPB, NDB2, NDB1, POE |
| STROBE TO OUTPUT DELAY Receive data enable |  | 180 | 250 | ns | Load $=20 \mathrm{pf}+1$ TTL input <br> RDE: TPD1, TPDO |
| OUTPUT DISABLE DELAY |  | 100 | 250 | ns | RDE |

[^5]NOTES:

1. Under steady state condition no current flows for TTL or MOS interfacing. A switching current of 1.6 mA maximum flows during a transition of the input.
2. The three-state output has 3 states:
1) low impedance to Vcc
2) low impedance to GND
3) high impedance $O F F \cong 10 \mathrm{M}$ ohms

The OFF state is controlled by the RDE input.

## DESCRIPTION OF OPERATION -RECEIVER/TRANSMITTER

The input clock frequency for the receiver is set at the desired receiver baud rate and the desired receiver sync character (synchronous idle character) is loaded into the receiver sync register. When the Receiver Reset input transitions from a highlevel to a low-level the receiver is set into the search mode (bit phase). In the search mode the serially received data bit stream is examined on a bit by bit basis until a sync character is found. A sync character is found, by definition, when the contents of the receiver sync register and the receiver shift register are identical. When this occurs the Sync Character Received output is set high. This character is then loaded into the receiver buffer register and the receiver is set into the character mode. In this mode each character received is loaded into the receiver buffer register. The receiver provides flags for Receiver Data Available, Receiver Over Run, Receiver Parity Error, and Sync Character Received. Full double buffering eliminates the need for precise external timing by allowing one full character time for received data to be read out.
The input clock frequency for the transmitter is set
at the desired baud rate and the desired transmitter sync character is loaded into the transmitter sync register. Internal logic decides if the character to be transmitted out of the transmitter shift register is extracted from the transmitter data register or the transmitter sync register. The next character transmitted is extracted from the transmitter data register provided that a Transmitter Data Strobe pulse occurs during the presently transmitted character. If the Transmitter Data Strobe is not pulsed, the next transmitted character is extracted from the transmitter sync register and the Sync Character Transmitted output is set to a high level. Full double buffering eliminates the need for precise external timing by allowing one full character time to load the next character to be transmitted.
There may be 5, 6, 7, or 8 data bits and odd/even or no parity bit. All inputs and outputs are directly TTL compatible. Tri-state data output levels are provided for the bus structure oriented signals. Input strobe widths of 200 ns , output propagation delays of 250 ns , and receiver/transmitter rates of 250 K baud are achieved.

## FLOW CHART - TRANSMITTER



## FLOW CHART-RECEIVER




NOTE 1
The transmitter shift register is loaded with the next character at the positive clock transition corresponding to the leading edge of the last bit of the current character on the TSO output. TBMT is set high approximately two microseconds after this clock transition. If it is desired that the next character be extracted from the transmitter data register the leading edge of the TDS should occur at least one microsecond prior to this clock transition.

NOTE 2
In order to avoid an ROR indication the leading edge of the RDAR pulse should occur at least one microsecond prior to the negative clock transition corresponding to the center of the first bit after the last data bit on the RSI input.

## NOTE 3

The ROR, RPE, SCR and RD1RD8 outputs are set to their correct levels approximately two microseconds after the negative clock transition corresponding to the center of the first bit after the last data bit on the RSI input. The RDA output is set high at the next negative clock transition.
The solid waveforms correspond to a control register setting of 5 data bits and a parity bit. The dashed waveforms are for a setting of 6 data bits and no parity bit.

Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

# Programmable Communication Interface PCI 

## FEATURES

Synchronous and Asynchronous Full Duplex or Half Duplex OperationsRe-programmable ROM on-chip baud rate generatorSynchronous Mode Capabilities-Selectable 5 to 8-Bit Characters

- Selectable 1 or 2 SYNC Characters
- Internal Character Synchronization
- Transparent or Non-Transparent Mode
- Automatic SYNC or DLE-SYNC Insertion
- SYNC or DLE Stripping
- Odd, Even, or No Parity
- Local or remote maintenance loop back modeAsynchronous Mode Capabilities
-Selectable 5 to 8-Bit Characters
-3 Selectable Clock Rates (1X, 16X, 64X the Baud Rate)
- Line Break Detection and Generation
$-1,1 / 2$, or 2 -Stop Bit Detection and Generation
- False Start Bit Detection
- Odd, Even, or No Parity
- Parity, Overrun, and framing error detect
- Local or remote maintenance loop back mode
- Automatic serial echo mode

Baud Rates
-DC to 1.0M Baud (Synchronous)
—DC to 1.0M Baud (1X, Asynchronous)
-DC to 62.5 K Baud (16X, Asynchronous)
-DC to 15.625 K Baud ( 64 X , Asynchronous)
$\square$ Double Buffering of Data

PIN CONFIGURATION

$\square$ Internal or External Baud Rate Clock -16 Internal Rates:50 to 19,200 BaudSingle +5 volt Power SupplyTTL CompatibleNo System Clock Required
Compatible with 2651, INS2651

## GENERAL DESCRIPTION

The COM 2651 is an MOS/LSI device fabricated using SMC's patented COPLAMOS® technology that meets the majority of asynchronous and synchronous data communication requirements, by interfacing parallel digital systems to asynchronous and synchronous data communication channels while requiring a minimum of processor overhead. The COM 2651 contains a baud rate generator which can be programmed to either accept an external clock or to generate internal transmit or receive clocks. Sixteen different baud rates can be selected under program control when operating in the internal clock mode. The on-chip baud rate generator can be ROM reprogrammed to accommodate different baud rates and different starting frequencies.
The COM 2651 is a Universal Synchronous/

Asynchronous Receiver/Transmitter (USART) designed for microcomputer system data communications. The USART is used as a peripheral and is programmed by the processor to communicate in commonly used asynchronous and synchronous serial data transmission techniques including IBM Bi-Sync. The USART receives serial data streams and converts them into parallel data characters for the processor. While receiving serial data, the USART will also accept data characters from the processor in parallel format, convert them to serial format and transmit. The USART will signal the processor when it has completely received or transmitted a character and requires service. Complete USART status including data format errors and control signals is available to the processor at any time.


## COM 2651 ORGANIZATION

The COM 2651 is organized into 6 major sections. Communication between each section is achieved via an internal data and control bus. The data bus buffer allows a processor access to all internal registers on the COM 2651.

## Operation Control

This functional block stores configuration and operation commands from the processor and generates appropriate signals to various internal sections to control the overall device operation. It contains read and write circuits to permit communications with a processor via the data bus and contains Mode Registers 1 and 2, the Command Register, and the Status Register. Details of register addressing and protocol are presented in the COM 2651 programming section of this specification.

## Timing

The COM 2651 contains a Baud Rate Generator (BRG) which is programmable to accept external transmit or receive clocks or to divide an external clock to perform data communications. The unit can generate 16 commonly used baud rates, any one of which can be selected for full duplex operation. Table 6 illustrates all available baud rates.

## Receiver

The Receiver accepts serial data on the RxD pin, converts this serial input to parallel format, checks for bits or characters that are unique to the communication
technique and stores the "assembled" character in the receive data holding register until read by the processor.

## Transmitter

The Transmitter accepts parallel data from the processor, converts it to a serial bit stream, inserts the appropriate characters or bits (based on the communication technique) and outputs a composite serial stream of data on the TxD output pin.

## Modem Control

The modem control provides three output signals and accepts three input signals used for "handshaking" and status indication between the COM 2651 and a modem.

## SYN/DLE Control

This section contains control circuitry and three 8-bit registers storing the SYN1, SYN2, and DLE characters provided by the processor. These registers are used in the synchronous mode of operation to provide the characters required for synchronization, idle fill and data transparency.

## Interface Signals

The COM 2651 interface signals can be grouped into two types: the processor-related signals (shown in Table2) which interface the COM 2651 to the processor, and the devicerelated signals (shown in Table 3), which are used to interface to the communications equipment.

TABLE 2-PROCESSOR RELATED SIGNALS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & 1,2,5,6 \\ & 7,8,27,28 \end{aligned}$ | Data | D7-D0 | Bidirectional; 8 bit, three state data bus used to transfer commands, data and status between the COM 2651 and a processor. D $\emptyset$ is the least significant bit; D7 is the most significant bit. |
| 10,12 | Address | A1, A $\square$ | Input; Address lines used to select COM 2651 registers. |
| 11 | Chip Enable | $\overline{C E}$ | Input; when this signal is low, the operation specified by the $\bar{R} / W, A 1$ and $A 0$ will be performed. When this input is high, D7- $\emptyset$ are in the high impedance state. |
| 13 | Read/Write | $\overline{\mathrm{R}}$ W | Input; Processor read/write direction control. This signal defines the direction of the data bus D7-Ø when the COM 2651 is selected. D7-D drives out (read) when this signal is low and accepts data input when this signal is high. The input only has meaning when the chip enable input is active. |
| 14 | Receiver Ready | $\overline{\mathrm{RxRDY}}$ | Output; This signal is the complement of Status Register bit 1 (SR1). When low, it indicates that the Receive Data Holding Register (RHR) has a character ready for input to the processor. It goes high when the RHR is read by the processor, and also when the receiver is disabled. It is an open drain output which can be used as an interrupt to the processor. |
| 15 | Transmitter Ready | $\overline{T \times R D Y}$ | Output; This signal is the complement of Status Register bit 0(SRO). When Iow, it indicates that the Transmit Data Holding Register (THR) is ready to accept a data character from the processor. It goes high when the data character is loaded. This output is valid only when the transmitter is enabled. It is an open drain output which can be used as an interrupt to the processor. |
| 18 | Transmitter empty/data set change | $\frac{\overline{T \times E M T}}{\mathrm{DSCHG}}$ | Output; This signal is the complement of Status Register bit 2 (SR2). When low, it indicates that the transmitter has completed serialization of the last character loaded by the processor, or that a change of state of the $\overline{\mathrm{DSR}}$ or $\overline{\mathrm{DCD}}$ inputs has occurred. This output goes high when the Status Register is read by the processor, if the TxEMT condition does not exist. Otherwise, the THR must be loaded by the processor for this line to go high. It is an open drain output which can be used as an interrupt to the processor. |
| 21 | Reset | Reset | Input; A high on this input performs a master reset on the COM 2651. This signal asynchronously terminates any device activity and clears the Mode, Command and Status registers. The device assumes the idle state and remains there until initialized with the appropriate control words. |
| 26 | Supply Voltage | $V_{C C}$ | +5 volts supply. |
| 4 | Ground | GND | Ground. |

## TABLE 3-DEVICE RELATED SIGNALS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 3 | Receive Data | RxD | Input; Serial data to the receiver. "Mark" is high "space" is low. |
| 9 | Transmitter Clock | $\overline{T x C}$ | Input or Output; If the external transmitter clock is programmed, this input controls the rate at which the character is transmitted. Its frequency is $1 \mathrm{X}, 16 \mathrm{X}$ or 64 X , the Baud rate as programmed by Mode Register 1. The transmitted data changes on the falling edge of the clock. If the internal transmitter clock is programmed, this pin becomes an output at 1 X the programmed Baud rate. |
| 16 | Data Carrier Detect | $\overline{D C D}$ | Input; This signal must be low in order for the receiver to function. The complement appears in the Status Register bit 6 (SR6). When this input changes state a low output on TxEMT/DSCHG occurs. |
| 17 | Clear to Send | $\overline{\text { CTS }}$ | Input; This signal must be low in order for the transmitter to function. If it goes high during transmission, the character in the Transmit Shift Register will be transmitted before termination. |
| 19 | Transmit Data | TxD | Output; Serial data from the transmitter. "Mark" is high, "Space" is low. This signal is held in the "Mark" condition when the transmitter is disabled. |
| 20 | Baud Rate Clock | BRCLK | Input; The standard device requires a 5.0688 MHz clock to the internal Baud rate generator allowing for Baud rate shown in Table6. The reprogrammable ROM on chip allows for user specificed Baud rates and input frequency. Consult the factory for details. This input is not required if external receive and transmit clocks are used. |
| 22 | Data Set Ready | $\overline{\text { DSR }}$ | Input; This general purpose signal can be used for Data Set Ready or Ring Indicator condition. Its complement appears as Status Register bit 7 (SR7). When this input changes state, a low output on TxEMT/DSCHG occurs. |
| 23 | Request to Send | $\overline{\text { RTS }}$ | Output; This general purpose signal is the complement of the Command Register bit 5 (CR5). It is normally used to indicate Request to Send. |

TABLE 3-DEVICE RELATED SIGNALS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :--- |
| 24 | Data Terminal | $\overline{\text { DTR }}$ | Output; This general purpose signal is the complement of the Command Register <br> bit 1 (CR1). It is normally used to indicate Data Terminal Ready. |
| 25 | Receive Clock | $\overline{R x C}$ | Input or Output; If the external receiver clock is programmed, this input controls the <br> rate at which the character is to be received. Its frequency is 1X, 16X, or 64X the Baud <br> rate, as programmed by Mode Register 1. Data are sampled on the rising edge of the <br> clock. If internal receiver clock is programmed, this pin becomes an output at 1X the <br> programmed Baud rate. |

## COM 2651 OPERATION

The functional operation of the COM 2651 is programmed by a set of control words supplied by the processor. These control words specify items such as synchronous or asynchronous mode, baud rate, number of bits per character, etc. The programming procedure is described in the COM 2651 Programming section of this data sheet.
After programming, the COM 2651 is ready to perform the desired communications functions. The receiver performs serial to parallel conversion of data received from a modem or equivalent device. The transmitter converts parallel data received from the processor to a serial bit stream. These actions are accomplished within the framework specificed by the control words.

## Receiver

The COM 2651 is conditioned to receive data when the $\overline{D C D}$ input is low and the RxEN bit in the command register is true. In the asynchronous mode, the receiver looks for a high to low transition on the RxD input line indicating the start bit. If a transition is detected, the state of the RxD line is sampled again after a delay of one-half of a bit time. If RxD is now high, the search for a valid start bit is begun again. If RxD is still low, a valid start bit is assumed and the receiver continues to sample the input line at one bit time intervals until the proper number of data bits, the parity bit, and the stop bit(s) have been assembled. The data is then transferred to the Receive Data Holding Register, the RxRDY bit in the status register is set, and the RXRDY output is asserted. If the character length is less than 8 bits, the high order unused bits in the Holding Register are set to zero. The Parity Error, Framing Error, and Overrun Error status bits are strobed into the status register on the positive going edge of RxC corresponding to the received character boundary. If a break condition is detected ( RxD is low for the entire character as well as the stop bit[s]), only one character consisting of all zeros (with the Framing error status bit set) will be transferred to the Holding Register. The RxD input must return to a high condition before a search for the next start bit begins.
When the COM 2651 is initialized into the synchronous mode, the receiver first enters the hunt mode on a 0 to 1 transition of RxEN (CR2). In this mode, as data is shifted into the Reciver Shift Register a bit at a time, the contents of the register are compared to the contents of the SYN1 register. If the two are not equal, the next bit is shifted in and the comparison is repeated. When the two registers match, the hunt mode is terminated and character assembly begins. If the single SYN operation is programmed, the SYN DETECT status bit is set. If double SYN operation is programmed, the first character assembled after SYN1 must be SYN2 in order for the SYN DETECT bit to be set. Otherwise, the COM 2651 returns
to the hunt mode. (Note that the sequence SYN1-SYN1SYN2 will not achieve synchronization). When synchronization has been achieved, the COM 2651 continues to assemble characters and transfers them to the Holding Register. The RxRDY status bit is set and the RxRDY output is asserted each time a character is assembled and transferred to the Holding Register. The Overrun error (OE) and Parity error (PE) status bits are set as appropriate. Further receipt of the proper SYN sequence sets the SYN DETECT status bit. If the SYN stripping mode is commanded, SYN characters are not transferred to the Holding Register. Note that the SYN characters used to establish initial synchronization are not transferred to the Holding Register in any case.

## Transmitter

The COM 2651 is conditioned to transmit data when the CTS input is low and the TxEN command register bit is set. The COM 2651 indicates to the processor that it can accept a character for transmission by setting the TxRDY status bit and asserting the TxRDY output. When the processor writes a character into the Transmit Data Holding Register, the TxRDY status bit is reset and the TxRDY output is returned to a high (false) state. Data is transferred from the Holding Register to the Transmit Shift Register when it is idle or has completed transmission of the previous character. The TxRDY conditions are then asserted again. Thus, one full character time of buffering is provided.
In the asynchronous mode, the transmitter automatically sends a start bit followed by the programmed number of data bits, the least significant bit being sent first. It then appends an optional odd or even parity bit and the programmed number of stop bits. If, following transmission of the data bits, a new character is not available in the Transmit Holding Register, the TxD output remains in the marking (high) condition and the TXEMT/DSCHG output and its corresponding status bit are asserted. Transmission resumes when the processor loads a new character into the Holding Register. The transmitter can be forced to output a continuous low (BREAK) condition by setting the Send Break command bit high.
In the synchronous mode, when the COM 2651 is initially conditioned to transmit, the TxD output remains high and the TxRDY condition is asserted until the first character to be transmitted (usually a SYN character) is loaded by the processor. Subsequent to this, a continuous stream of characters is transmitted. No extra bits (other than parity, if commanded) are generated by theCOM 2651 unless the processor fails to send a new character to the COM 2651 by the time the transmitter has completed sending the previous character. Since synchronous communication does not allow gaps between characters, the COM 2651
asserts TxEMT and automatically "fills" the gap by transmitting SYN1s, SYN1-SYN2 doublets, or DLE-SYN1 doublets, depending on the state of MR16 and MR17. Normal transmission of the message resumes when anew character is available in the Transmit Data Holding Register. If the SEND DLE bit in the command register is true, the DLE character is automatically transmitted prior to transmission of the message character in the transmit holding register.

## COM 2651 PROGRAMMING

Prior to initiating data communications, the COM 2651 operational mode must be programmed by performing write operations to the mode and command registers. In addition, if synchronous operation is programmed, the appropriate SYN/DLE registers must be loaded. The COM 2651 can be reconfigured at any time during program execution. However, if the change has an effect on the reception of a character the receiver should be disabled. Alternatively if the change is made $11 / 2 \mathrm{RxC}$ periods after RxRDY goes active it will affect the next character assembly. A flowchart of the initialization process appears in Figure 1.
The internal registers of the COM 2651 are accessed by applying specific signals to the $\overline{C E}, \overline{\mathrm{R}} / \mathrm{W}, \mathrm{A} 1$ and A 0 inputs. The conditions necessary to address each register are shown in Table 4.
The SYN1, SYN2, and DLE registers are accessed by performing write operations with the conditions $\mathrm{A} 1=0$, $\mathrm{A} 0=1$, and $\overline{\mathrm{R}} / \mathrm{W}=1$. The first operation loads the SYN1 register. The next loads the SYN2 register, and the third loads the DLE register. Reading or loading the mode registers is done in a similar manner. The first write (or read) operation addresses Mode Register 1, and a subsequent operation addresses Mode Register 2. If more than the required number of accesses are made, the internal sequencer recycles to point at the first register. The pointers are reset to SYN1 Register and Mode Register 1 by a RESET input or by performing a "Read Command Register" operation, but are unaffected by any other read or write operation.
The COM 2651 register formats are summarized in Tables 5, 6, 7 and 8 . Mode Registers 1 and 2 define the general operational characteristics of the COM 2651, while the Command Register controls the operation within this basic framework. The COM 2651 indicates its status in the Status Register. These registers are cleared when a RESET input is applied.

COM 2651 INITIALIZATION FLOW CHART


Figure 1

| $\overline{\mathbf{C E}}$ | $\mathbf{A 1}$ | $\mathbf{A 0}$ | $\overline{\mathbf{R}} / \mathbf{W}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :--- |
| 1 | X | X | X | Tri-state data bus |
| 0 | 0 | 0 | 0 | Read receive holding register |
| 0 | 0 | 0 | 1 | Write transmit holding register |
| 0 | 0 | 1 | 0 | Read status register |
| 0 | 0 | 1 | 1 | Write SYN1/SYN2/DLE registers |
| 0 | 1 | 0 | 0 | Read mode registers 1 and 2 |
| 0 | 1 | 0 | 1 | Write mode registers 1 and 2 |
| 0 | 1 | 1 | 0 | Read command register |
| 0 | 1 | 1 | 1 | Write command register |

NOTE
See AC Characteristics section for timing requirements.
Table 4-COM 2651 REGISTER ADDRESSING

## MODE REGISTER 1 (MR1)

Table 5 illustrates Mode Register 1. Bits MR11 and MR10 select the communication format and Baud rate multiplier. 00 specifies synchronous mode and 1 X multiplier. 1X, 16X, and 64X multipliers are programmable for asynchronous format. However, the multiplier in asynchronous format applies only if the external clock input option is selected by MR24 or MR25.
MR13 and MR12 select a character length of $5,6,7$, or 8 bits. The character length does not include the parity bit, if programmed, and does not include the start and stop bits in asynchronous mode.
MR14 controls parity generation. If enabled, a parity bit is added to the transmitted character and the receiver
performs a parity check on incoming data. MR15 selects odd or even parity when parity is enabled by MR14.
In asychronous mode, MR17 and MR16 select character framing of $1,1.5$, or 2 stop bits. (if 1 X baud rate is programmed, 1.5 , stop bits defaults to 1 stop bits on transmit). In synchronous mode, MR17 controls the number of SYN characters used to establish synchronization and for character fill when the transmitter is idle. SYN1 alone is used if MR17=1, and SYN1-SYN2 is used when MR17 $=0$. If the transparent mode is specified by MR16, DLE-SYN1 is used for character fill and SYN Detect, but the normal synchronization sequence is used. Also DLE stripping and DLE Detect (with MR14=0) are enabled.

| MR17 | MR16 | MR15 | MR14 | MR13 | MR12 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Sync/Async | ParIty Type | Parlty Control | Character Length | MR11 |  |
| ASYNCH: STOP BIT LENGTH <br> 00=INVALID <br> $01=1$ STOP BIT <br> $10=11 / 2$ STOP BITS <br> $11=2$ STOP BITS | $0=$ ODD | $0=$ DISABLED |  | $00=5$ BITS |  |

NOTE Baud rate factor in asynchronous applies only if external clock is selected. Factor is 16 X if
internal clock is selected. Mode must be selected (MR11, MR10) in any case.
TABLE 5-MODE REGISTER 1 (MR1)

## MODE REGISTER 2 (MR2)

Table 6 illustrates Mode Register 2. MR23, MR22, MR21, and MR20 control the frequency of the internal Baud rate generator (BRG). Sixteen rates are selectable. When driven by a 5.0688 MHz input at the BRCLK input (pin 20), the BRG output has zero error except at 134.5, 2000, and 19,200 Baud, which have errors of $+0.016 \%+0.253 \%$, and $+3.125 \%$ respectively.
MR25 and MR24 select either the BRG or the external
inputs $\overline{\mathrm{TXC}}$ and $\overline{\mathrm{RXC}}$ as the clock source for the transmitter and receiver, respectively. If the BRG clock is selected, the Baud rate factor in asynchronous mode is 16X regardless of the factor selected by MR11 and MR10. In addition, the corresponding clock pin provides an output at 1X the Baud rate. Custom Baud rates other than the ones provided by the standard part are available. Contact the factory for details.

| MR27 |  | MR26 | MR25 | MR24 | MR23-MR20 |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Transmitter Clock | Receiver Clock | Code | Baud Rate | Theoretical Frequency 16X Clock | Actual Frequency 16X Clock | Percent Error | Divisor |
| NOT USED |  |  | $\begin{aligned} & 0=\text { EXTERNAL } \\ & 1=\text { INTERNAL } \end{aligned}$ | $\begin{aligned} & 0=\text { EXTERNAL } \\ & 1=\text { INTERNAL } \end{aligned}$ | 0000 | 50 | 0.8 KHz | 0.8 KHz | - | 6336 |
|  |  |  | 0001 |  | 75 | 1.2 | 1.2 | - | 4224 |
|  |  |  | 0010 |  | 110 | 1.76 | 1.76 | - | 2880 |
|  |  |  | 0011 |  | 134.5 | 2.152 | 2.1523 | 0.016 | 2355 |
|  |  |  | 0100 |  | 150 | 2.4 | 2,4 | - | 2112 |
|  |  |  | 0101 |  | 300 | 4.8 | 4.8 | - | 1056 |
|  |  |  | 0110 |  | 600 | 9.6 | 9.6 | - | 528 |
|  |  |  | 0111 |  | 1200 | 19.2 | 19.2 | - | 264 |
|  |  |  | 1000 |  | 1800 | 28.8 | 28.8 | - | 176 |
|  |  |  | 1001 |  | 2000 | 32.0 | 32.081 | 0.253 | 158 |
|  |  |  | 1010 |  | 2400 | 38.4 | 38.4 | - | 132 |
|  |  |  | 1011 |  | 3600 | 57.6 | 57.6 | - | 88 |
|  |  |  | 1100 |  | 4800 | 76.8 | 76.8 | - | 66 |
|  |  |  | 1101 |  | 7200 | 115.2 | 115.2 | - | 44 |
|  |  |  | 1110 |  | 9600 | 153.6 | 153.6 | - | 33 |
|  |  |  | 1111 |  | 19200* | 307.2 | 316.8 | 3.125 | 16 |

NOTE *Error at 19200 can be reduced to zero by using crystal frequency 4.9152 MHz 16 X clock is used in asynchronous mode. In synchronous mode, clock multiplier is 1 X . Baud rates are valid for crystal frequency $=5.0688 \mathrm{MHz}$

Table 7 illustrates the Command Register. BitsCRO (TxEN) and CR2 (RxEN) enable or disable the transmitter and receiver respectively. A 0 to 1 transition of CR2 forces start bit search (async mode) or hunt mode (sync mode) on the second RxC rising edge. Disabling the receiver causes RxRDP to go high (inactive). If the transmitter is disabled, it will complete the transmission of the character in the Transmit Shift Register (if any) prior to terminating operation. The TxD output will then remain in the marking state (high) while the TxRDY and TxEMT will go high (inactive). If the receiver is disabled, it will terminate operation immediately. Any character being assembled will be neglected.
In asynchronous mode, setting CR3 will force and hold the TxD output low (spacing condition) at the end of the current transmitted character. Normal operation resumes when CR3 is cleared. The TxD line will go high for at least one bit time before beginning transmission of the next character in the Transmit Data Holding Register. In synchronous mode, setting CR3 causes the transmission of the DLE register contents prior to sending the character in the Transmit Data Holding Register. CR3 should be reset in response to the next TxRDY.
Setting CR4 causes the error flags in the Status Register (SR3, SR4, and SR5) to be cleared. This is a one time command. There is no internal latch for this bit.
The COM 2651 can operate in one of four sub-modes within each major mode (synchronous or asynchronous). The operational sub-mode is determined by CR7 and CR6. CR7-CR6=00 is the normal mode, with the transmitter and receiver operating independently in accordance with the Mode and Status Register instructions.
In asynchronous mode, CR7-CR6=01 places the COM 2651 in the Automatic Echo mode. Clocked, regenerated received data is automatically directed to the TxD line while normal receiver operation continues. The receiver must be enabled (CR2=1), but the transmitter need not be enabled. Processor to receiver communications continues normally, but the processor to transmitter link is disabled. Only the first character of a break condition is echoed. The TxD output will go high until the next valid start is detected. The following conditions are true while in Automatic Echo mode:

1. Data assembled by the receiver are automatically placed in the Transmit Holding Register and retransmitted by the transmitter on the TxD output.
2. The transmitter is clocked by the receive clock.
3. TxRDYoutput $=1$.
4. The TXEMT/DSCHG pin will reflect only the data set change condition.
5. The TXEN command (CRO) is ignored.

In synchronous mode, CR7-CR6 $=01$ places the COM 2651 in the Automatic SYN/DLE Stripping mode. The exact action taken depends on the setting of bits MR17 and MR16:

1. In the non-transparent, single SYN mode (MR17MR16=10), characters in the data stream matching SYN1 are not transferred to the Receive Data Holding Register (RHR).
2. In the non-transparent, double SYN mode (MR17MR16=00), characters in the data stream matching, SYN1, or SYN2 if immediately preceded by SYN1, are not transferred to the RHR. However, only the first SYN1 of an SYN1-SYN1 pair is stripped.
3. In transparent mode (MR16=1), characters in the data stream matching DLE, or SYN1 if immediately preceded by DLE, are not transferred to the RHR. However, only the first DLE of a DLE-DLE pair is stripped.
Note that Automatic Stripping mode does not affect the setting of the DLE Detect and SYN Detect status bits (SR3 and SR5).
Two diagnostic sub-modes can also be configured. In Local Loop Back mode (CR7-CR6=10), the following loops are connected internally:
4. The transmitter output is connected to the receiver input.
5. $\overline{\mathrm{DTR}}$ is connected to $\overline{\mathrm{DCD}}$ and $\overline{\mathrm{RTS}}$ is connected to CTS.
6. The receiver is clocked by the transmit clock.
7. The $\overline{D T R}, \overline{R T S}$ and TxD outputs are held high.
8. The $\overline{\mathrm{CTS}}, \overline{\mathrm{DCD}}, \overline{\mathrm{DSR}}$ and RxD inputs are ignored.

Additional requirements to operate in the Local Loop Back mode are that CR0 (TxEN), CR1 (DTR), and CR5 (RTS) must be set to 1. CR2 (RxEN) is ignored by the COM 2651.
The second diagnostic mode is the Remote Loop Back mode (CR7-CR6=11). In this mode:

1. Data assembled by the receiver is automatically placed in the Transmit Holding Register and retransmitted by the transmitter on the TxD output.
2. The transmitter is clocked by the receive clock.
3. No data are sent to the local processor, but the error status conditions (PE, OE, FE) are set.
4. The $\overline{R x R D Y}, \overline{T x R D Y}$, and TxEMT/DSCHG outputs are held high.
5. CRO (TXEN) is ignored.
6. All other signals operate normally.

| CR7 7 CR6 | CR5 | CR4 | CR3 | CR2 | CR1 | CRO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operating Mode | Request to Send | Reset Error | Sync/Async | Receive Control (RxEN) | Data Terminal Ready | Transmit Control (TxEN) |
| $00=$ NORMAL OPERATION $01=$ ASYNCH: AUTOMATIC ECHO MODE <br> SYNCH: SYN AND/OR DLE STRIPPING MODE $10=$ LOCAL LOOP BACK <br> $11=$ REMOTE LOOP BACK | $0=$ FORCE $\overline{\text { RTS }}$ OUTPUT HIGH 1 =FORCE $\overline{\text { RTS }}$ OUTPUT LOW | $\begin{aligned} & 0=\text { NORMAL } \\ & 1=\text { RESET } \\ & \text { ERROR FLAG } \\ & \text { IN STATUS } \\ & \text { (FE, OE, } \\ & \text { PE/DLE DETECT) } \end{aligned}$ | ASYNCH: <br> FORCE BREAK <br> $0=$ NORMAL <br> $1=$ FORCE <br> BREAK <br> SYNCH: <br> SEND DLE <br> $0=$ NORMAL <br> $1=$ SEND DLE | $\begin{aligned} & 0=\text { DISABLE } \\ & 1=\text { ENABLE } \end{aligned}$ | $0=$ FORCE $\overline{\text { DTR }}$ OUTPUT HIGH 1 =FORCE DTR OUTPUT LOW | $\begin{aligned} & 0=\text { DISABLE } \\ & 1=\text { ENABLE } \end{aligned}$ |

## STATUS REGISTER (SR)

The data contained in the Status Register (as shown in Table 8) indicate receiver and transmitter conditions and modem/data set status.
SRO is the Transmitter Ready (TxRDY) status bit. It, and its corresponding output, are valid only when the transmitter is enabled. If equal to 0 , it indicates that the Transmit Data Holding Register has been loaded by the processor and the data has not been transferred to the Transmit Shift Register. If set equal to 1, it indicates that the Holding Register is ready to accept data from the processor. This bit is initially set when the Transmitter is enabled by CRO, unless a character has previously been loaded into the Holding Register. It is not set when the Automatic Echo or Remote Loop Back modes are programmed. When this bit is set, the TxRDY output pin is low. In the Automatic Echo and Remote Loop Back modes, the output is held high.
SR1, the Receiver Ready (RxRDY) status bit, indicates the condition of the Receive DataHolding Register. Ifset, it indicates that a character has been loaded into the Holding Register from the Receive Shift Register and is ready to be read by the processor. If equal to zero. there is no new character in the Holding Register. This bit is cleared when the processor reads the Receive Data Holding Register or when the receiver is disabled by CR2. When set, the RxRDY output is low.
The TxEMT/DSCHG bit, SR2, when set, indicates either a change of state of the $\overline{D S R}$ or $\overline{D C D}$ inputs or that the Transmit Shift Register has completed transmission of a character and no new character has been loaded into the Transmit Data Holding Register. Note that in synchronous mode this bit will be set even though the appropriate "fill" character is transmitted. TxEMT will not go active until at least one character has been transmitted. It is cleared by loading the Transmit Data Hold-
ing Register. The DSCHG condition is enabled when TxEN = 1 or RxEN = 1. It is cleared when the Status Register is read by the processor. When SR2 is set, the TxEMT/ DSCHG output is low.
SR3, when set, indicates a received parity error when parity is enabled by MR14. In synchronous transparent mode (MR16=1), with parity disabled, it indicates that a character matching the DLE Register has been received. However, only the first DLE of two successive DLEs will set SR3. This bit is cleared when the receiver is disabled and by the Reset Error command, CR4.
The Overrun Error status bit, SR4, indicates that the previous character loaded into the Receive Holding Register was not read by the processor at the time a new received character was transferred into it. This bit is cleared when the receiver is disabled and by the Reset Error command, CR4.
In asynchronous mode, bit SR5 signifies that the received character was not framed by the programmed number of stop bits. (if 1.5 stop bits are programmed, only the first stop bit is checked.) If the RHR contains all 0 's when SR5 $=1$, a break condition is present. In synchronous non-transparent mode (MR16=0), it indicates receipt of the SYN1 character in single SYN mode or the SYN1-SYN2 pair in double SYN mode. In synchronous transparent mode (MR16=1), this bit is set upon detection of the initial synchronizing characters (SYN1 or SYN1-SYN2) and, after synchronization has been achieved, when a DLE-SYN1 pair is received. The bit is reset when the receiver is disabled, when the Reset Error command is given in asynchronous mode, or when the Status Register is read by the processor in the synchronous mode.
SR6 and SR7 reflect the conditions of the $\overline{D C D}$ and $\overline{D S R}$ inputs respectively. A low input sets the corresponding status bit and a high input clears it.

| SR7 | SR6 | SR5 | SR4 | SR3 | SR2 | SR1 | SRO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Data Set Ready | Data Carrier Detect | FE/SYN Detect | Overrun | PE/DLE Detect | TxEMT/DSCHG | RxRDY | TxRDY |
| $\begin{aligned} 0= & \overline{\text { DSR INPUT }} \\ & \text { IS HIGH } \\ 1= & \overline{\text { DSR INPUT }} \\ & \text { IS LOW } \end{aligned}$ | $\begin{aligned} 0 & =\overline{\text { DCD INPUT }} \\ & \text { IS HIGH } \\ 1= & \overline{\text { DCD INPUT }} \\ & \text { IS LOW } \end{aligned}$ | ASYNCH: <br> $0=$ NORMAL <br> $1=$ FRAMING ERROR <br> SYNCH: <br> $0=$ NORMAL <br> $1=$ SYN CHAR DETECTED | $0=$ NORMAL <br> 1 = OVERRUN ERROR | ASYNCH: <br> $0=$ NORMAL <br> $1=$ PARITY <br> ERROR <br> SYNCH: $0=\text { NORMAL }$ <br> $1=$ PARITY <br> ERROR <br> OR <br> DLECHAR <br> RECEIVED | $\begin{aligned} & 0=\text { NORMAL } \\ & 1=\text { CHANGE } \\ & \text { IN } \overline{D S R} \text { OR } \\ & \overline{\text { DCD, OR }} \\ & \text { TRANSMIT } \\ & \text { SHIFT REGIS- } \\ & \text { TER IS } \\ & \text { EMPTY } \end{aligned}$ | $\begin{aligned} & 0=\text { RECEIVE } \\ & \text { HOLDING REG } \\ & \text { EMPTY } \\ & 1=\text { RECEIVE } \\ & \text { HOLDING REG } \\ & \text { HAS DATA } \end{aligned}$ | $0=$ TRANSMIT <br> HOLDING <br> REG BUSY <br> $1=$ TRANSMIT <br> HOLDING <br> REG EMPTY |

TABLE 8-STATUS REGISTER (SR)

TXRDY, TXEMT (Shown for 5-bit characters, no parity, 2 stop bits [in asynchronous mode])



NOTES
$A=$ Start bit
B = Stop bit 1
$C=$ Stop bit 2
$\mathrm{D}=\mathrm{TXD}$ marking condition
TXEMT goes low at the beginning of the last data bit, or, if parity is enabled, at the beginning of the parity bit.

RxRDY (Shown for 5-bit characters, no parity, 2 stop bits [in asynchronous mode])



READ AND WRITE


## MAXIMUM GUARANTEED RATINGS*

Operating Temperature Range .................................................................................. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

Lead Temperature (soldering, 10 sec.) ................................................................................... $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground . ................................................................. +18.0 V
Negative Voltage on any Pin, with respect to ground ........................................................................ -0.3 V
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

NOTE: When powering this device from laboratory or system power supplies, it it important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. For example, the bench power supply programmed to deliver +12 volts may have large voltage transients when the AC power is switched on and off. If this possibility exists it is suggested that a clamp circuit be used.

DC ELECTRICAL CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V} \pm 5 \%$

|  | PARAMETER | MIN | TYP | MAX | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & V_{I L} \\ & V_{I H} \end{aligned}$ | Input voltage Low High | 2.0 |  | 0.8 | V |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL}} \\ & \mathrm{~V}_{\mathrm{OH}} \end{aligned}$ | Output voltage Low High | 2.4 |  | 0.4 | V | $\begin{array}{r} l_{\mathrm{OL}}=1.6 \mathrm{~mA} \\ \mathrm{l}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ \hline \end{array}$ |
| IIL | Input leakage current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V |
| $\begin{aligned} & \mathrm{I}_{\mathrm{LH}} \\ & \mathrm{I}_{\mathrm{LL}} \\ & \hline \end{aligned}$ | Output leakage current Data bus high Data bus Iow |  |  | $\begin{array}{r} 10 \\ 10 \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ | $\begin{gathered} V_{0}=4.0 \mathrm{~V} \\ V_{0}=0.45 \mathrm{~V} \end{gathered}$ |
| $\mathrm{I}_{\mathrm{cc}}$ | Power supply current |  |  | 150 | mA |  |
| $\mathrm{C}_{\text {IN }}$ <br> Cout <br> $\mathrm{C}_{10}$ | Capacitance Input <br> Output Input/Output |  |  | $\begin{aligned} & 20 \\ & 20 \\ & 20 \end{aligned}$ | pF <br> pF <br> pF | $\mathrm{fc}=1 \mathrm{MHz}$ <br> Unmeasured pins tied to ground |

AC ELECTRICAL CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$

|  | PARAMETER | MIN | TYP | MAX | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{RES}}$ $t_{C E}$ | Pulse width Reset Chip enable | $\begin{gathered} 1000 \\ 300 \\ \hline \end{gathered}$ |  |  | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \\ & \hline \end{aligned}$ |  |
| $t_{A S}$ <br> $\mathrm{t}_{\mathrm{AH}}$ <br> tcs <br> $\mathrm{t}_{\mathrm{CH}}$ <br> tos <br> $t_{D H}$ <br> $t_{\text {rxs }}$ <br> $\mathrm{t}_{\mathrm{RXH}}$ | Setup and hold time Address setup Address hold $\overline{\mathrm{R}} / \mathrm{W}$ control setup $\overline{\mathrm{R}} / \mathrm{W}$ control hold Data setup for write Data hold for write Rx data setup Rx data hold | $\begin{gathered} 20 \\ 20 \\ 20 \\ 20 \\ 225 \\ 0 \\ 300 \\ 350 \end{gathered}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ |  |
| $\begin{aligned} & t_{\mathrm{DD}} \\ & \mathrm{t}_{\mathrm{DF}} \\ & \mathrm{t}_{\mathrm{CED}} \\ & \hline \end{aligned}$ | Data delay time for read Data bus floating time for read $\overline{\mathrm{CE}}$ to $\overline{\mathrm{CE}}$ delay | 700 |  | $\begin{aligned} & 250 \\ & 150 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} \\ & \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} \end{aligned}$ |
|  | Input clock frequency Baud rate generator TxC or RxC | $\begin{aligned} & 1.0 \\ & \mathrm{dc} \end{aligned}$ | 5.0688 | $\begin{gathered} 5.0738 \\ 1.0 \end{gathered}$ | $\begin{aligned} & \mathrm{MHz} \\ & \mathrm{MHz} \\ & \hline \end{aligned}$ |  |
| $t_{\text {BRH }}$ <br> $t_{\text {BRL }}$ <br> ${ }_{t_{\mathrm{R} / \mathrm{TH}_{\mathrm{L}}}}$ | Clock width Baud rate high Baud rate low $\overline{T \times C}$ or $\overline{R \times C}$ high $\overline{T \times C}$ or $\overline{R \times C}$ low | $\begin{array}{r} 70 \\ 70 \\ 500 \\ 500 \\ \hline \end{array}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \hline \end{aligned}$ | $\begin{aligned} & f_{\mathrm{BRG}}=5.0688 \mathrm{MHz} \\ & f_{\mathrm{BRG}}=5.0688 \mathrm{MHz} \end{aligned}$ |
| $t_{\text {TXD }}$ $t_{\text {tics }}$ | TxD delay from falling edge of TxC <br> Skew between TxD changing and falling edge of TxC output |  | 0 | 650 | ns <br> ns | $\begin{aligned} & C_{L}=100 \mathrm{pF} \\ & C_{L}=100 \mathrm{pF} \end{aligned}$ |

## NOTE:

1. $f_{R, T}$ and $t_{R, T L}$ shown for all modes except Local Loopback. For Local Loopback mode
$\mathrm{f}_{\mathrm{Q}, \tau}=0.7 \mathrm{MHz}$ and $\mathrm{t}_{\mathrm{R}, \mathrm{TL}_{\mathrm{L}}}=700 \mathrm{~ns} \mathrm{~min}$.

## TYPICAL APPLICATIONS



## STANDARD MICROSYSTEMS

 assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.
# Enhanced Programmable Communication Interface EPCI 

## FEATURES

Synchronous and Asynchronous Full Duplex or Half Duplex Operations$\square$ Re-programmable ROM on-chip baud rate generator
$\square$ Synchronous Mode Capabilities
-Selectable 5 to 8-Bit Characters

- Selectable 1 or 2 SYNC Characters
- Internal or External Character Synchronization
-Transparent or Non-Transparent Mode
- Transparent mode DLE stuffing (Tx) and detection ( Rx )
-Automatic SYNC or DLE-SYNC Insertion
-SYNC, DLE and DLE-SYNC stripping
-Odd, Even, or No Parity
- Local or remote maintenance loop back mode
$\square$ Asynchronous Mode Capabilities
-Selectable 5 to 8 -Bit Characters plus parity
- 3 Selectable Clock Rates (1X, 16X, 64X the Baud Rate)
- Line Break Detection and Generation
- $1,11 / 2$, or 2-Stop Bit Detection and Generation
-False Start Bit Detection
- Odd, Even, or No Parity
- Parity, Overrun, and framing error detect
- Local or remote maintenance loop back mode
-Automatic serial echo mode (echoplex)


## $\square$ Baud Rates

-DC to 1.0 M Baud (Synchronous)
-DC to 1.0M Baud (1X, Asynchronous)
-DC to 62.5 K Baud (16X, Asynchronous)
-DC to 15.625 K Baud ( 64 X , Asynchronous)

PIN CONFIGURATION


Double Buffering of DataRxC and TxC pins are short circuit protectedInternal or External Baud Rate Clock3 baud rate sets (2661-1, -2, -3)16 internal rates for each versionSingle +5 volt Power SupplyTTL CompatibleNo System Clock RequiredCompatible with EPCI 2661

The COM 2661 is an MOS/LSI device fabricated using SMC's patented COPLAMOS ${ }^{\circledR}$ technology. It is an enhanced pin and register compatible version of the COM 2651 that meets the majority of asynchronous and synchronous data communication requirements, by interfacing parallel digital systems to asynchronous and synchronous data communication channels while requiring a minimum of processor overhead. The COM2661 contains a baud rate generator which can be programmed to either accept an external clock or to generate internal transmit or receive clocks. Sixteen different baud rates can be selected under program control when operating in the internal clock mode. Each version of the COM 2661 ( -1 , $-2,-3$ ) has a different set of baud rates. Custom baud rates can be ROM reprogrammed to accommodate different baud rates and different starting frequencies.

The COM 2661 is a Universal Synchronous/ Asynchronous Receiver/Transmitter (USART) designed for microcomputer system data communications. The USART is used as a peripheral and is programmed by the processor to communicate in commonly used asynchronous and synchronous serial data transmission techniques including IBM Bi-Sync. The USART receives serial data streams and converts them into parallel data characters for the processor. While receiving serial data, the USART will also accept data characters from the processor in parallel format, convert them to serial format and transmit. The USART will signal the processor when it has completely received or transmitted a character and requires service. Complete USART status including data format errors and control signals is available to the processor at any time.


## COM 2661 ORGANIZATION

The COM 2661 is organized into 6 major sections. Communication between each section is achieved via an internal data and control bus. The data bus buffer allows a processor access to all internal registers on the COM 2661. The differences between the COM 2661 and COM 2651 are outlined in table 1.

## Operation Control

This functional block stores configuration and operation commands from the processor and generates appropriate signals to various internal sections to control the overall device operation. It contains read and write circuits to permit communications with a processor via the data bus and contains Mode Registers 1 and 2, the Command Register, and the Status Register. Details of register addressing and protocol are presented in the COM 2661 programming section of this specification.

## Timing

The COM 2661 contains a Baud Rate Generator (BRG) which is programmable to accept external transmit or receive clocks or to divide an external clock to perform data communications. The unit can generate 16 commonly used baud rates, any one of which can be selected for full duplex operation. Tables 2a, b, and c illustrate all available baud rates.

## Receiver

The Receiver accepts serial data on the RxD pin, converts this serial input to paraliel format, checks for bits
or characters that are unique to the communication technique and stores the "assembled" character in the receive data holding register until read by the processor.

## Transmitter

The Transmitter accepts parallel data from the processor, converts it to a serial bit stream, inserts the appropriate characters or bits (based on the communication technique) and outputs a composite serial stream of data on the TxD output pin.

## Modem Control

The modem control provides three output signals and accepts three input signals used for "handshaking" and status indication between the COM 2661 and a modem.

## SYN/DLE Control

This section contains control circuitry and three 8-bit registers storing the SYN1, SYN2, and DLE characters provided by the processor. These registers are used in the synchronous mode of operation to provide the characters required for synchronization, idle fill and data transparency.

## Interface Signals

The COM 2661 interface signals can be grouped into two types: the processor-related signals (shown in Table 3) which interface the COM 2661 to the processor, and the device-related signals (shown in Table 4), which are used to interface to the communications equipment.

TABLE 3-PROCESSOR RELATED SIGNALS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & 1,2,5,6, \\ & 7,8,27,28 \end{aligned}$ | Data | D7-D0 | Bidirectional; 8 bit, three state data bus used to transfer commands, data and status between the COM 2661 and a processor. D0 is the least significant bit; D7 is the most significant bit. |
| 10, 12 | Address | A1, AD | Input; Address lines used to select COM 2661 registers. |
| 11 | Chip Enable | $\overline{C E}$ | Input; when this signal is low, the operation specified by the $\overline{\mathrm{A}} / \mathrm{W}, \mathrm{A} 1$ and $A 0$ will be performed. When this input is high, D7- $\emptyset$ are in the high impedance state. |
| 13 | Read/Write | F/W | Input; Processor read/write direction control. This signal defines the direction of the data bus D7-0 when the COM 2661 is selected. D7-ø drives out (read) when this signal is low and accepts data input when this signal is high. The input only has meaning when the CE input is active. |
| 14 | Receiver Ready | RXRDY | Output; This signal is the complement of Status Register bit 1 (SR1). When low, it indicates that the Receive Data Holding Register (RHR) has a character ready for input to the processor. It goes high when the RHR is read by the processor, and also when the receiver is disabled. It is an open drain output which can be used as an interrupt to the processor. |
| 15 | Transmitter Ready | TXRDY | Output; This signal is the complement of Status Register bit 0 (SRO). When low, it indicates that the Transmit Data Holding Register (THR) is ready to accept a data character from the processor. It goes high when the data character is loaded. This outpu is valid only when the transmitter is enabled. It is an open drain output which can be used as an interrupt to the processor. |
| 18 | Transmitter empty/data set change | $\begin{aligned} & \text { TXEMT/ } \\ & \text { DSCHG } \end{aligned}$ | Output; This signal is the complement of Status Register bit 2 (SR2). When low, it indicates that the transmitter has completed serialization of the last character loaded by the processor, or that a change of state of the DSR or DCD inputs has occurred. This output goes high when the Status Register is read by the processor, if the TXEMT condition does not exist. Otherwise, the THR must be loaded by the processor for this line to go high. It is an open drain output which can be used as an interrupt to the processor. |
| 21 | Reset | Reset | Input; A high on this input performs a master reset on the COM 2661. This signal asynchronously terminates any device activity and clears the Mode, Command and Status registers. The device assumes the idle state and remains there until initialized with the appropriate control words. |
| 26 | Supply Voltage | $V_{c c}$ | +5 volts supply. |
| 4 | Ground | GND | Ground. |

TABLE 4-DEVICE RELATED SIGNALS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 3 | Receive Date | RxD | Input; Serial data to the receiver. "Mark" is high "space" is low. |
| 9 | Transmitter Clock/External Sync | $\begin{gathered} \overline{\mathrm{TXC}} / \\ \text { XSYNC } \end{gathered}$ | Input or Output; If the external transmitter clock is programmed, this input controls the rate at which the character is transmitted. Its frequency is $1 X, 16 \mathrm{X}$ or 64 X , the Baud rate as programmed by Mode Register 1. The transmitted data changes on the falling edge of the clock. If the internal transmitter clock is programmed, this pin can be a 1X/16X clock output or an external jam synchronization input. |
| 16 | Data Carrier Detect | $\overline{\mathrm{DCD}}$ | Input; This signal must be low in order for the receiver to function. The complement appears in the Status Register bit 6 (SR6). $\overline{\mathrm{DCD}}$ causes a low output on TxEMT/DSCHG when its state changes if $C R 2$ or $C R O=1$. If $\overline{D C D}$ goes high while receiving, the $R \times C$ is internally inhibited. |
| 17 | Clear to Send | $\overline{\text { CTS }}$ | Input; This signal must be low in order for the transmitter to function. If it goes high during transmission, the character in the Transmit Shift Register will be transmitted before termination. |
| 19 | Transmit Data | TxD | Output; Serial data from the transmitter. "Mark" is high, "Space" is low. This signal is held in the "Mark" condition when the transmitter is disabled. |
| 20 | Baud Rate Clock | BRCLK | Input; Clock input to the internal baud rate generator (See Tables 2a, b and c); not required if the external receiver and transmitter clocks are used. |
| 22 | Data Set Ready | $\overline{\text { DSR }}$ | Input; This general purpose signal can be used for Data Set Ready or Ring Indicator condition. Its complement appears as Status Register bit 7 (SR7). DSR causes a low output on TXEMT/DSCHG when its state changes if CR2 or CRO $=1$. |
| 23 | Request to Send | $\overline{\text { RTS }}$ | Output; This general purpose signal is the complement of the Command Register bit 5 (CR5). It is normally used to indicate Request to Send. If the Transmit Shift Register is not empty when CR5 is reset ( 1 to 0 ), then RTS will go high on TXC time after the last serial bit is transmitted. |
| 24 | Data Terminal Ready | $\overline{\text { DTR }}$ | Output; This general purpose signal is the complement of the Command Register bit 1 (CR1). It is normally used to indicate Data Terminal Ready. |
| 25 | Receive Clock/ Break Detect | $\begin{aligned} & \mathrm{RXC/} \\ & \text { BKDET } \end{aligned}$ | Input or Output; If the external receiver clock is programmed, this input controls the rate at which the character is to be received. Its frequency is $1 \mathrm{X}, 16 \mathrm{X}$, or 64 X the Baud rate, as programmed by Mode Register 1. Data are sampled on the rising edge of the clock. If internal receiver clock is programmed, this pin can be a $1 \mathrm{X} / 16 \mathrm{X}$ clock or a break detect output. |


| feature |  | EPCI | PC |  |
| :---: | :---: | :---: | :---: | :---: |
| 1. MR2 Bit 6.7 |  | Control pin 9, 25 | Not used |  |
| 2. DLE detect-SR3 |  | $\begin{aligned} & \text { SR3 }=0 \text { for DLE-DLE, } \\ & \text { DLE-SYNC1 } \end{aligned}$ | SR3 $=1$ for DLE-DLE. DLE-SYNC1 |  |
| 3. Reset ol SR3, DLE detect |  | Second character after DLE: or receiver disable, or CR4 = 1 | Receiver disable, or$C R 4=1$ |  |
| 4. Send DLE-CR3 |  | One time command | Reset via CR3 on next TxRDY |  |
| 5. DLE stuffing in transparent mode |  | Automatic DLE stuffing when DLE is loaded except if CR3 $=1$ | None |  |
| 6. SYNC1 stripping in double sync non-transparent mode |  | All SYNC1 | First SYNC1 of pair |  |
| 7. Baud rate versions |  | Three | One |  |
| 8. Terminate ASYNC transmission (drop RTS) |  | Reset CR5 in response to TXRDY changing from 0 to 1 | Reset CRO when TxEMT goes from 1 to 0 . Then reset CR5 when TXEMT goes from 0 to 1 |  |
| 9. Break detect |  | Pin $25{ }^{\prime}$ | FE and null character |  |
| 10. Stop bit searched |  | One | Two |  |
| 11. External jam sync |  | Pin $9{ }^{\text {a }}$ | No |  |
| 12. Data bus timing |  | Improved over 2651 | - |  |
| 13. Data bus dr |  | Sink 2.2 mA Source $400 \mu \mathrm{~A}$ | Sink 1.6 mA Source $100 \mu \mathrm{~A}$ |  |
| NOTES <br> 1. Internal BRG used for AxC . <br> 2. Internal BRG used for TxC. |  |  |  |  |
| Table 2a BAUD RATE GENERATOR CHARACTERISTICS 2661-1 $($ BRCLK $=4.9152 \mathrm{MHz})$ |  |  |  |  |
| MR23-20 | BAUD RATE | ACTUAL FREQUENCY $16 X C L O C K$ | PERCENT ERROR | DIVISOR |
| 0000 | 50 | 0.8 kHz | - | 6144 |
| 0001. | 75 | ${ }^{1.2}$ | -0.01 | 4096 |
| 0010 0011 | 110 1345 | 1.7598 <br> 2.152 | -0.01 | 2793 2284 |
| 0011 0100 | 134.5 <br> 150 <br> 80 | 2.152 2.4 | - | 2284 |
| 0101 | 200 | 3.2 | - | 1536 |
| 0110 | 300 | 4.8 | - | 1024 |
| 0111 | 600 | 9.6 | - | 512 |
| 1000 | 1050 | 16.8329 | 0.196 | 292 |
| 1001 | 1200 | 19.2 | - | 256 |
| 1010 | 1800 | 28.7438 | -0.19 | 171 |
| 1011 | 2000 | 31.9168 | -0.26 | 154 |
| 1100 | 2400 | 38.4 | - | 128 |
| 1101 | 4800 | 76.8 | - | 64 |
| 1110 1111 | 9600 19200 | 153.6 307.2 | - | 32 16 |

Table 2b BAUD RATE GENERATOR CHARACTERISTICS
2661-2 (BRCLK $=4.9152 \mathrm{MHz})$

| MR23-20 | BAUD RATE | ACTUAL frequency 16 XCLOCK | PERCENT ERROR | DIVISOR |
| :---: | :---: | :---: | :---: | :---: |
| 0000 | 45.5 | 0.7279 kHz | 0.005 | 6752 |
| 0001 | 50 | 0.8 | - | 6144 |
| 0010 | 75 | 1.2 | $-$ | 4096 |
| 0011 | 110 | 1.7598 | -0.01 | 2793 |
| 0100 | 134.5 | 2.152 | - | 2284 |
| 0101 | 150 | 2.4 | - | 2048 |
| 0110 | 300 | 4.8 | - | 1024 |
| 0111 | 600 | 9.6 | - | 512 |
| 1000 | 1200 | 19.2 | - | 256 |
| 1001 | 1800 | 28.7438 | -0.19 | 171 |
| 1010 | 2000 | 31.9168 | -0.26 | 154 |
| 1011 | 2400 | 38.4 | - | 128 |
| 1100 | 4800 | 76.8 | - | 64 |
| 1101 | 9600 | 153.6 | - | 32 |
| 1110 | 19200 | 307.2 | - | 16 |
| 1111 | 38400 | 614.4 | - | 8 |

Table 2c BAUD RATE CHARACTERISTICS
$2661-3$ (BRCLK $=5.0688 \mathrm{MHz}$ )

| MR23-20 | BAUD RATE | Actual FREQUENCY 16X CLOCK | PERCENT ERROR | DIVISOR |
| :---: | :---: | :---: | :---: | :---: |
| 0000 | 50 | 0.8 kHz | - | 6336 |
| 0001 | 75 | 1.2 | - | 4224 |
| 0010 | 110 | 1.76 | - | 2880 |
| 0011 | 134.5 | 2.1523 | 0.016 | 2355 |
| 0100 | 150 | 2.4 | - | 2112 |
| 0101 | 300 | 48 | - | 1056 |
| 0110 | 600 | 9.6 | - | 528 |
| 0111 | 1200 | 19.2 | - | 264 |
| 1000 | 1800 | 28.8 | - | 176 |
| 1001 | 2000 | 32.081 | 0.253 | 158 |
| 1010 | 2400 | 38.4 | - | 132 |
| 1011 | 3600 | 57.6 | - | 88 |
| 1100 | 4800 | 76.8 | - | 66 |
| 1101 | 7200 | 115.2 | - | 44 |
| 1110 | 9600 | 153.6 | - | 33 |
| 1111 | 19200 | 316.8 | 3.125 | 16 |

NOTE: BRG can be used only for $7 \times C$

## COM 2661 OPERATION

The functional operation of the COM 2661 is programmed by a set of control words supplied by the processor. These control words specify items such as synchronous or asynchronous mode, baud rate, number of bits per character, etc. The programming procedure is described in the COM 2661 Programming section of this data sheet.
After programming, the COM 2661 is ready to perform the desired communications functions. The receiver performs serial to parallel conversion of data received from a modem or equivalent device. The transmitter converts parallel data received from the processor to a serial bit stream. These actions are accomplished within the framework specified by the control words.

## Receiver

The COM 2661 is conditioned to receive data when the $\overline{D C D}$ input is low and the RxEN bit in the command register is true. In the asynchronous mode, the receiver looks for a high to low (mark to space) transition of the start bit on the RxD input line. If a transition is detected, the state of the RxD line is sampled again after a delay of one-half of a bit time. If RxD is now high, the search for a valid start bit is begun again. If $R \times D$ is still low, a valid start bit is assumed and the receiver continues to sample the input line at one bit time intervals until the proper number of data bits, the parity bit, and one stop bit have been assembled. The data is then transferred to the Receive Data Holding Register, the RxRDY bit in the status register is set, and the RxRDY output is asserted. If the character length is less than 8 bits, the high order unused bits in the Holding Register are set to zero. The Parity Error, Framing Error, and Overrun Error status
bits are strobed into the status register on the positive going edge of $\overline{\mathrm{RxC}}$ corresponding to the received character boundary. If the stop bit is present, the receiver will immediately begin its search for the next start bit. If the stop bit is absent (framing error), the receiver will interpret a space as a start bit if it persists into the next bit time interval. If a break condition is detected ( $R \times D$ is low for the entire character as well as the stop bit), only one character consisting of all zeros (with the Framing error status bit set) will be transferred to the Holding Register. The RxD input must return to a high condition before a search for the next start bit begins.
Pin 25 can be programmed to be a break detect output by appropriate setting of MR27-MR24. If so, a detected break will cause that pin to go high. When RxD returns to mark for one RxC time, pin 25 will go low. Refer to the break detection timing diagram.
When the COM 2661 is initialized into the synchronous mode, the receiver first enters the hunt mode on a 0 to 1 transition of RxEN (CR2). In this mode, as data is shifted into the Receiver Shift Register a bit at a time, the contents of the register are compared to the contents of the SYN1 register. If the two are not equal, the next bit is shifted in and the comparison is repeated. When the two registers match, the hunt mode is terminated and character assembly begins. If the single SYN operation is programmed, the SYN DETECT status bit is set. If double SYN operation is programmed, the first character assembled after SYN1 must be SYN2 in order for the SYN DETECT bit to be set. Otherwise, the COM 2661 returns to the hunt mode. (Note that the sequence SYN1-SYN1-

SYN2 will not achieve synchronization). When synchronization has been achieved, the COM 2661 continues to assemble characters and transfers them to the Holding Register. The RxRDY status bit is set and the RxRDY output is asserted each time a character is assembled and transferred to the Holding Register. The Overrun error (OE) and Parity error (PE) status bits are set as appropriate. Further receipt of the proper SYN sequence sets the SYN DETECT status bit. If the SYN stripping mode is commanded, SYN characters are not transferred to the Holding Register. Note that the SYN characters used to establish initial synchronization are not transferred to the Holding Register in any case.
External jam synchronization can be achieved via pin 9 by appropriate setting of MR27-MR24. When pin 9 is an XSYNC input, the internal SYN1, SYN1-SYN2, and DLESYN1 detection is disabled. Each positive going signal on XSYNC will cause the receiver to establish synchronization on the rising edge of the next RxC pulse. Character assembly will start with the RxD input at this edge. XSYNC may be lowered on the next rising edge of RxC. This external synchronization will cause the SYN DETECT status bit to be set until the status register is read. Refer to XSYNC timing diagram.

## Transmitter

The COM 2661 is conditioned to transmit data when the CTS input is low and the TXEN command register bit is set. The COM 2661 indicates to the processor that it can accept a character for transmission by setting the TxRDY status bit and asserting the TxRDY output. When the processor writes a character into the Transmit Data Holding Register, the TxRDY status bit is reset and the TXRDY output is returned to a high (false) state. Data is transferred from the Holding Register to the Transmit Shift Register when it is idle or has completed transmission of the previous character. The TxRDY conditions are then asserted again. Thus, one full character time of buffering is provided.
In the asynchronous mode, the transmitter automatically sends a start bit followed by the programmed number of data bits, the least significant bit being sent first. It then appends an optional odd or even parity bit and the programmed number of stop bits. If, following transmission of the data bits, a new character is not available in the Transmit Holding Register, the TXD output remains in the marking (high) condition and the TXEMT/DSCHG output and its corresponding status bit are asserted. Transmission resumes when the processor loads a new character into the Holding Register. The transmitter can be forced to output a continuous low (BREAK) condition by setting the Send Break command bit high.
In the synchronous mode, when the COM 2661 is initially conditioned to transmit, the TxD output remains high and the TXRDY condition is asserted until the first character to be transmitted (usually a SYN character) is loaded by the processor. Subsequent to this, a continuous stream of characters is transmitted. No extra bits (other than parity, if commanded) are generated by the COM 2661 unless the processor fails to send a new character to the COM 2661 by the time the transmitter has completed sending the previous character. Since synchronous communication does not allow gaps between characters, the COM 2661 asserts TxEMT and automatically "fills" the gap by transmitting SYN1s, SYN1-SYN2 doublets, or DLE-SYN1 doublets, depending on the state of MR16 and MR17. Normal transmission of the message resumes when a new character is available in the Transmit Data Holding Register. If the SEND DLE bit in the command register is true, the DLE character is automatically transmitted prior to transmission of the message character in the transmit holding register.

## COM 2661 PROGRAMMING

Prior to initiating data communications, the COM 2661 operational mode must be programmed by performing write operations to the mode and command registers. In addition, if synchronous operation is programmed, the appropriate SYN/DLE registers must be loaded. The COM 2661 can be reconfigured at any time during program execution. A flow chart of the initialization process appears in Figure 1.
The internal registers of the COM 2661 are accessed by applying specific signals to the $\overline{C E}, \bar{R} / W, A 1$ and $A 0$ inputs. The conditions necessary to address each register are shown in Table 5.
The SYN1, SYN2, and DLE registers are accessed by performing write operations with the conditions $A 1=0$, $\mathrm{A} 0=1$, and $\overline{\mathrm{R}} / \mathrm{W}=1$. The first operation loads the SYN1 register. The next loads the SYN2 register, and the third loads the DLE register. Reading or loading the mode registers is done in a similar manner. The first write (or read) operation addresses Mode Register 1, and a subsequent operation addresses Mode Register 2. If more

## COM 2661 INITIALIZATION FLOW CHART



Figure 1
than the required number of accesses are made, the internal sequencer recycles to point at the first register. The pointers are reset to SYN1 Register and Mode Register 1 by a RESET input or by performing a "Read Command Register" operation, but are unaffected by any other read or write operation.
The COM 2661 register formats are summarized in Tables 6, 7, 8 and 9. Mode Registers 1 and 2 define the general operational characteristics of the COM 2661, while the Command Register controls the operation within this basic framework. The COM 2661 indicates its status in the Status Register. These registers are cleared when a RESET input is applied.

| $\overline{\mathbf{C E}}$ | $\mathbf{A 1}$ | $\mathbf{A O}$ | $\overline{\mathbf{R}} / \mathbf{W}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :--- |
| 1 | X | X | X | Tri-state data bus |
| 0 | 0 | 0 | 0 | Read receive holding register |
| 0 | 0 | 0 | 1 | Write transmit holding register |
| 0 | 0 | 1 | 0 | Read status register |
| 0 | 0 | 1 | 1 | Write SYN1/SYN2/DLE registers |
| 0 | 1 | 0 | 0 | Read mode registers 1 and 2 |
| 0 | 1 | 0 | 1 | Write mode registers 1 and 2 |
| 0 | 1 | 1 | 0 | Read command register |
| 0 | 1 | 1 | 1 | Write command register |

NOTE
See AC Characteristics section for timing requirements.
Table 5-COM 2661 REGISTER ADDRESSING

## MODE REGISTER 1 (MR1)

Table 6 illustrates Mode Register 1. Bits MR11 and MR10 select the communication format and Baud rate multiplier. 00 specifies synchronous mode and 1X multiplier. $1 \mathrm{X}, 16 \mathrm{X}$, and 64 X multipliers are programmable for asynchronous format. However, the multiplier in asynchronous format applies only if the external clock input option is selected by MR24 or MR25.

MR13 and MR12 select a character length of $5,6,7$, or 8 bits. The character length does not include the parity bit, if programmed, and does not include the start and stop bits in asynchronous mode.

MR14 controls parity generation. If enabled, a parity bit is added to the transmitted character and the receiver performs a parity check on incoming data. MR15 selects odd or even parity when parity is enabled by MR14.

In asynchronous mode, MR17 and MR16 select character framing of $1,1.5$, or 2 stop bits (if 1 X baud rate is programmed, 1.5 , stop bits defaults to 1 stop bits on transmit). In synchronous mode, MR17 controls the number of SYN characters used to establish synchronization and for character fill when the transmitter is idle. SYN1 alone is used if MR17=1, and SYN1-SYN2 is used when $\mathrm{MR17}=0$. If the transparent mode is specified by MR16, DLE-SYN1 is used for character fill and SYN Detect, but the normal synchronization sequence is used. When transmitting, a DLE character in the transmit holding register will cause a second DLE character to be transmitted. This DLE stuffing eliminates the software DLE compare and stuff on each transparent mode data character. If the send DLE command (CR3) is active when a DLE is loaded into THR, only one additional DLE will be transmitted. Also DLE stripping and DLE Detect (with $\mathrm{MR14}=0$ ) are enabled.

| M817 | MR16 | MR15 | MR14 | MR13 MR12 | MR11 MR10 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Sync/Async |  | Parity Type | P arity Control | Character Length | Mode and Baud Rate Factor |
| ASYNCH: STOP BI $00=$ INVALID $01=1$ STOP BIT $10=1 \frac{1}{2}$ STOP BITS $11=2$ STOP BITS | T LENGTH | $\begin{aligned} & 0=\text { ODD } \\ & 1=\text { EVEN } \end{aligned}$ | $\begin{aligned} & 0=\text { DISABLED } \\ & 1=\text { ENABLED } \end{aligned}$ | $\begin{aligned} & 00=5 \mathrm{BITS} \\ & 01=6 \mathrm{BITS} \\ & 10=7 \mathrm{BITS} \\ & 11=8 \mathrm{BITS} \end{aligned}$ | $00=$ SYNCHRONOUS $1 \times$ RATE <br> $01=A S Y N C H R O N O U S 1 X$ RATE <br> 10=ASYNCHRONOUS 16X RATE <br> 11=ASYNCHRONOUS 64X RATE |
| SYNCH: NUMBER OF SYN CHAR $\begin{aligned} & 0=\text { DOUBLE SYN } \\ & 1=\text { SINGLE SYN } \end{aligned}$ | SYNCH: TRANSPARENCYCONTROL $\begin{aligned} & 0=\text { NORMAL } \\ & 1=\text { TRANSPARENT } \end{aligned}$ |  |  |  |  |

NOTE Baud rate factor in asynchronous applies only if external clock is selected. Factor is 16 X if internal clock is selected. Mode must be selected (MR11, MR10) in any case.

TABLE 6-MODE REGISTER 1 (MR1)

## MODE REGISTER 2 (MR2)

Table 7 illustrates mode register 2 (MR23, MR22, MR21 and MR20 control the frequency of the internal baud rate generator (BRG). Sixteen rates are selectable for each COM 2661 version ( $-1,-2,-3$ ). Version 1 and 2 specify a 4.9152 MHz TTL input at BRCLK (pin 20); version 3 specifies a 5.0688 MHz input which is identical to the

COM 2651. MR23-20 are don't cares if external clocks are selected (MR25-24 = 0). The individual rates are given in table $2 \mathrm{a}, \mathrm{b}$ and c .
MR24-MR27 select the receive and transmit clock source (either the BRG or an external input) and the function at pins 9 and 25 . Refer to table 7.

| MR-27-MR24 |  |  |  |  |  |  |  |  |  |  | MR23-MR20 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TxC | RxC | Pin 9 | Pin 25 |  | TxC | RxC | Pin 9 | Pin 25 | Mode | Baud Rate Selection |
| 0000 | E | E | TxC | RxC | 1000 | E | E | XSYNC ${ }^{1}$ | RxC/TxC | sync |  |
| 0001 | E | 1 | TxC | 1X | 1001 | E | 1 | TxC | BKDET | async |  |
| 0010 | 1 | E | 1X | RxC | 1010 | 1 | E | XSYNC ${ }^{\prime}$ | RxC | sync |  |
| 0011 | 1 | 1 | 1X | 1X | 1011 | 1 | 1 | 1X | BKDET | async | See baud rates in table 2 |
| 0100 | E | E | TxC | RxC | 1100 | E | E | XSYNC ${ }^{1}$ | RxC/TxC | sync |  |
| 0101 | E | 1 | TxC | 16X | 1101 | E | 1 | TxC | BKDET | async |  |
| 0110 | 1 | E | 16X | RxC | 1110 | 1 | E | XSYNC ${ }^{\prime}$ | RxC | sync |  |
| 0111 | 1 | 1 | 16X | 16X | 1111 | 1 | 1 | 16X | BKDET | async |  |

NOTES

1. When pin 9 is programmed as XSYNC input, SYN1, SYN1-SYN2, and DLE-SYN1 detection is disabled.

TABLE 7-MODE REGISTER 2 (MR2)

## COMMAND REGISTER (CR)

Table 8 illustrates the Command Register. Bits CRO (TxEN) and CR2 (RxEN) enable or disable the transmitter and receiver respectively. A 0 to 1 transition of CR2 forces start bit search (async mode) or hunt mode (sync mode) on the second RxC rising edge. Disabling the receiver causes RxRDY to go high (inactive). If the transmitter is disabled, it will complete the transmission of the character in the Transmit Shift Register (if any) prior to terminating operation. The TxD output will then remain in the marking state (high while the TxRDY and TxEMT will go high (inactive). If the receiver is disabled, it will terminate operation immediately. Any character being assembled will be neglected. Bits CR1 (DTR) and CR5 (RTS) control the DTR and RTS outputs. Data at the outputs are the logical complement of the register data.
In asynchronous mode, setting CR3 will force and hold the TxD output low (spacing condition) at the end of the current transmitted character. Normal operation resumes when CR3 is cleared. The TxD line will go high for at least one bit time before beginning transmission of the next character in the Transmit Data Holding Register. In synchronous mode, setting CR3 causes the transmission of the DLE register contents prior to sending the character in the Transmit Data Holding Register. Since this is a one time command, CR3 does not have to be reset by software. CR3 should be set when entering and exiting transparent mode and for all DLE- non-DLE character sequences.
Setting CR4 causes the error flags in the Status Register (SR3, SR4, and SR5) to be cleared. This is a one time command. There is no internal latch for this bit. When CR5 (RTS) is set, the $\overline{\text { RTS }}$ pin is forced low and the transmit serial logic is enabled. A 1 to 0 transition of CR5 will cause $\overline{\mathrm{RTS}}$ to go high (inactive) one TxC time after the last serial bit has been transmitted (if the transmit shift register was not empty).
The COM 2661 can operate in one of four sub-modes within each major mode (synchronous or asynchronous). The operational sub-mode is determined by CR7 and CR6. CR7-CR6 $=00$ is the normal mode, with the transmitter and receiver operating independently in accordance with the Mode and Status Register instructions.
In asynchronous mode, CR7-CR6=01 places the COM 2661 in the Automatic Echo mode. Clocked, regenerated received data are automatically directed to the TxD line while normal receiver operation continues. The receiver must be enabled (CR2=1), but the transmitter need not be enabled. Processor to receiver communications continue normally, but the processor to transmitter link is disabled. Only the first character of a break condition is echoed. The TxD output will go high until the next valid start is detected. The following conditions are true while in Automatic Echo mode:

1. Data assembled by the receiver are automatically
placed in the Transmit Holding Register and retransmitted by the transmitter on the TxD output.
2. The transmitter is clocked by the receive clock.
3. TxRDY output $=1$.
4. The TXEMT/DSCHG pin will reflect only the data set change condition.
5. The TxEN command (CRO) is ignored.

In synchronous mode, CR7-CR6=01 places the COM 2661 in the Automatic SYN/DLE Stripping mode. The exact action taken depends on the setting of bits MR17 and MR16:

1. In the non-transparent, single SYN mode (MR17MR16=10), characters in the data stream matching SYN1 are not transferred to the Receive Data Holding Register (RHR).
2. In the non-transparent, double SYN mode (MR17MR16=00), characters in the data stream matching SYN1, or SYN2 if immediately preceded by SYN1, are not transferred to the RHR.
3. In transparent mode (MR16=1), characters in the data stream matching DLE, or SYN1 if immediately preceded by DLE, are not transferred to the RHR. However, only the first DLE of a DLE-DLE pair is stripped.
Note that Automatic Stripping mode does not affect the setting of the DLE Detect and SYN Detect status bits (SR3 and SR5).
Two diagnostic sub-modes can also be configured. In Local Loop Back mode (CR7-CR6=10), the following loops are connected internally:
4. The transmitter output is connected to the receiver input.
5. $\overline{\mathrm{DTR}}$ is connected to $\overline{\mathrm{DCD}}$ and $\overline{\mathrm{RTS}}$ is connected to CTS.
6. The receiver is clocked by the transmit clock.
7. The DTR, $\overline{R T S}$ and TxD outputs are held high.
8. The $\overline{C T S}, \overline{D C D}, \overline{D S R}$ and RxD inputs are ignored.

Additional requirements to operate in the Local Loop Back mode are that CR0 (TxEN), CR1 (DTR), and CR5 (RTS) must be set to 1. CR2 (RxEN) is ignored by the COM 2661.
The second diagnostic mode is the Remote Loop Back mode (CR7-CR6=11). In this mode:

1. Data assembled by the receiver is automatically placed in the Transmit Holding Register and retransmitted by the transmitter on the TxD output.
2. The transmitter is clocked by the receive clock.
3. No data are sent to the local processor, but the error status conditions (PE, OE, FE) are set.
4. The RxRDY, TxRDY, and TxEMT/DSCHG outputs are held high.
5. CR1 (TXEN) is ignored.
6. All other signals operate normally.

| CR7 CR6 | CR5 | CR4 | CR3 | CR2 | CR1 | CRO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operating Mode | Request to Send | Reset Error | Sync/Async | Receive Control (RxEN) | Data Terminal Ready | Transmit Control (TxEN) |
| 00 - NORMAL OPERATION <br> 01 = ASYNCH: AUTOMATIC ECHO MODE <br> SYNCH: SYN AND/OR DLE STRIPPING MODE $10=$ LOCAL LOOP BACK 11 = REMOTE LOOP BACK | 0 FORCE $\overline{\text { RTS }}$ OUTPUT HIGH ONE CLOCK time after TxSR SERIALization <br> 1 FORCE $\overline{\text { RTS }}$. OUTPUT LOW | $0=$ NORMAL <br> 1 =RESET <br> ERROR FLAG <br> in Status <br> (FE, OE, <br> PE/DLE DETECT) | ASYNCH: <br> FORCE BREAK <br> $0=$ NORMAL <br> 1 =FORCE <br> BREAK <br> SYNCH: <br> SEND DLE <br> $0=$ NORMAL <br> 1 =SEND DLE | $\begin{aligned} & 0=\text { DISABLE } \\ & 1=\text { ENABLE } \end{aligned}$ | $0=$ FORCE $\overline{\text { DTR }}$ OUTPUT HIGH 1 =FORCE DTR OUTPUT LOW | $\begin{aligned} & 0=\text { DISABLE } \\ & 1=\text { ENABLE } \end{aligned}$ |

## STATUS REGISTER (SR)

The data contained in the Status Register (as shown in Table 9) indicate receiver and transmitter conditions and modem/data set status.
SRO is the Transmitter Ready (TxRDY) status bit. It, and its corresponding output, are valid only when the transmitter is enabled. If equal to 0 , it indicates that the Transmit Data Holding Register has been loaded by the processor and the data has not been transferred to the Transmit Shift Register. If set equal to 1, it indicates that the Holding Register is ready to accept data from the processor. This bit is initially set when the Transmitter is enabled by CRO, unless a character has previously been loaded into the Holding Register. It is not set when the Automatic Echo or Remote Loop Back modes are programmed. When this bit is set, the TxRDY output pin is low. In the Automatic Echo and Remote Loop Back modes, the output is held high.
SR1, the Receiver Ready (RxRDY) status bit, indicates the condition of the Receive Data Holding Register. If set, it indicates that a character has been loaded into the Holding Register from the Receive Shift Register and is ready to be read by the processor. If equal to zero, there is no new character in the Holding Register. This bit is cleared when the processor reads the Receive Data Holding Register or when the receiver is disabled by CR2. When set, the RxRDY output is low.
The TxEMT/DSCHG bit, SR2, when set, indicates either a change of state of the $\overline{\mathrm{DSR}}$ or $\overline{\mathrm{DCD}}$ inputs (when CR2 or CRO $=1$ ) or that the Transmit Shift Register has completed transmission of a character and no new character has been loaded into the Transmit Data Holding Register. Note that in synchronous mode this bit will be set even though the appropriate "fill" character is transmitted. TxEMT will not go active until at least one character has been transmitted. It is cleared by loading the Transmit Data Holding Register. The DSCHG condition is enabled when $\operatorname{TxEN}=1$ or $\operatorname{RxEN}=1$. It is cleared when the status
register is read by the processor. If the status register is read twice and $S R 2=1$ while SR6 and SR7 remain unchanged, then a TxEMT condition exists. When SR2 is set, the TxEMT/DSCHG output is low.
SR3, when set, indicates a received parity error when parity is enabled by MR14. In synchronous transparent mode (MR16 $=1$ ), with parity disabled, it indicates that a character matching the DLE Register has been received, and the present character is neither SYN1 nor DLE. This bit is cleared when the next character following the above sequence is loaded into the Receive Data Holding Register, when the receiver is disabled, or by a reset error command, CR4.
The Overrun Error status bit, SR4, indicates that the previous character loaded into the Receive Holding Register was not read by the processor at the time a new received character was transferred into it. This bit is cleared when the receiver is disabled and by the Reset Error command, CR4.
In asynchronous mode, bit SR5 signifies that the received character was not framed by a stop bit, i.e., only the first stop bit is checked. If the RHR contains all 0 's when SR5 $=1$, a break condition is present. In synchronous non-transparent mode (MR16 $=0$ ), it indicates receipt of the SYN1 character in single SYN mode or the SYN1-SYN2 pair in double SYN mode. In synchronous transparent mode (MR16=1), this bit is set upon detection of the initial synchronizing characters (SYN1 or SYN1-SYN2) and, after synchronization has been achieved, when a DLE-SYN1 pair is received. The bit is reset when the receiver is disabled, when the Reset Error command is given in asynchronous mode, or when the Status Register is read by the processor in the synchronous mode.
SR6 and SR7 reflect the conditions of the $\overline{\mathrm{DCD}}$ and $\overline{\mathrm{DSR}}$ inputs respectively. A low input sets the corresponding status bit and a high input clears it.

| SR7 | SR6 | SR5 | SR4 | SR3 | SR2 | SR1 | SRO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Data Set Ready | Data Carrler Detect | FE/SYN Detect | Overrun | PE/DLE Detect | TXEMT/DSCHG | RxRDY | TxRDY |
| $\begin{aligned} & 0= \overline{\text { DSR INPUT }} \\ & \text { ISHIGH } \\ & 1= \overline{\text { OSR INPUT }} \\ & \text { ISLOW } \end{aligned}$ | $\begin{aligned} 0 & =\overline{\mathrm{DCD} ~ I N P U T} \\ & \text { IS HIGH } \\ 1= & \overline{\text { DCD INPUT }} \\ & \text { IS LOW } \end{aligned}$ | ASYNCH: <br> $0=$ NORMAL <br> $1=$ FRAMING <br> ERROR <br> SYNCH: $\begin{aligned} 0= & \text { NORMAL } \\ 1= & \text { SYN CHAR } \\ & \text { DETECTED } \end{aligned}$ | $0=$ NORMAL <br> 1 = OVERRUN ERROR | ASYNCH: <br> $0=$ NORMAL <br> $1=$ PARITY <br> ERROR <br> SYNCH: <br> $0=$ NORMAL <br> $1=$ PARITY <br> ERROR <br> OR <br> DLE CHAR <br> RECEIVED | $\begin{aligned} & 0=\text { NORMAL } \\ & 1=\text { CHANGE } \end{aligned}$ <br> IN $\overline{D S R}$ OR <br> $\overline{D C D}, O R$ <br> TRANSMIT <br> SHIFT REGIS- <br> TER IS <br> EMPTY | $0=$ RECEIVE <br> HOLDING REG EMPTY <br> 1=RECEIVE <br> HOLDING REG HAS DATA | $\begin{aligned} & 0=\text { TRANSMIT } \\ & \text { HOLDING } \\ & \text { REG BUSY } \\ & 1=\text { TRANSMIT } \\ & \text { HOLDING } \\ & \text { REG EMPTY } \end{aligned}$ |

TABLE 9-STATUS REGISTER (SR)

TxRDY, TxEMT (Shown for 5-bit characters, no parity, 2 stop bits [in asynchronous mode])


RXRDY (Shown for 5-bit characters, no parity, 2 stop bits [in asynchronous mode])


NOTES
$A=$ Start bit
$B=$ Stop bit 1
$C=$ Stop bit 2
$\mathrm{D}=\mathrm{Tx}$ D marking condition


Operating Temperature Range ................................................................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$

Positive Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +18.0 V
Negative Voltage on any Pin, with respect to ground ...................................................................... -0.3 V
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
NOTE: When powering this device from laboratory or system power supplies, it it important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. For example, the bench power supply programmed to deliver +12 volts may have large voltage transients when the AC power is switched on and off. If this possibility exists it is suggested that a clamp circuit be used.

DC ELECTRICAL CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$

|  | PARAMETER | MIN | TYP | MAX | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & V_{L L} \\ & V_{1 H} \end{aligned}$ | Input voltage Low High | 2.0 |  | 0.8 | V |  |
| $\begin{aligned} & V_{\text {OL }} \\ & V_{\text {OH }} \end{aligned}$ | Output voltage Low High | 2.4 |  | 0.4 | V | $\begin{aligned} \mathrm{loL} & =2.2 \mathrm{~mA} \\ \mathrm{IOH}_{\mathrm{OH}} & =-400 \mu \mathrm{~A} \end{aligned}$ |
| $1 / 2$ | Input leakage current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.5 V |
| $\begin{aligned} & \mathrm{I}_{\mathrm{LH}} \\ & \mathrm{ILL}^{2} \end{aligned}$ | Output leakage current Data bus high Data bus low |  |  | $\begin{array}{r} 10 \\ 10 \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{gathered} V_{0}=4.0 \mathrm{~V} \\ V_{0}=0.45 \mathrm{~V} \\ \hline \end{gathered}$ |
| Icc | Power supply current |  |  | 150 | mA |  |
| $\begin{aligned} & \mathrm{C}_{10} \\ & \mathrm{C}_{\text {Out }} \\ & \mathrm{C}_{10} \\ & \hline \end{aligned}$ | Capacitance Input Output Input/Output |  |  | $\begin{aligned} & 20 \\ & 20 \\ & 20 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\mathrm{fc}=1 \mathrm{MHz}$ <br> Unmeasured pins tied to ground |

AC ELECTRICAL CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$

|  | PARAMETER | MIN | TYP | MAX | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{t}_{\text {RES }} \\ & \mathrm{t}_{\mathrm{CE}} \\ & \hline \end{aligned}$ | Pulse width Reset Chip enable | $\begin{aligned} & 1000 \\ & 250 \end{aligned}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |  |
| $t_{A S}$ <br> $t_{\text {AH }}$ <br> tcs <br> $\mathrm{tch}_{\mathrm{CH}}$ <br> tos <br> $t_{D H}$ <br> $\mathrm{t}_{\mathrm{RXS}}$ <br> $\mathrm{t}_{\mathrm{RXH}}$ | Setup and hold time <br> Address setup Address hold $\overline{\bar{B}} / \mathrm{W}$ control setup $\overline{\mathrm{A}} / \mathrm{W}$ control hold Data setup for write Data hold for write Rx data setup Rx data hold | $\begin{gathered} 10 \\ 10 \\ 10 \\ 10 \\ 150 \\ 0 \\ 300 \\ 350 \\ \hline \end{gathered}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ |  |
| tod tbF tced | Data delay time for read Data bus floating time for read $\overline{\mathrm{CE}}$ to $\overline{\mathrm{CE}}$ delay | 600 |  | $\begin{aligned} & 200 \\ & 100 \end{aligned}$ | ns <br> ns ns | $\begin{aligned} & C_{\mathrm{L}}=150 \mathrm{pF} \\ & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \end{aligned}$ |
| $f_{B R G}$ <br> $f_{B R G}$ <br> $f_{\mathrm{R}} \mathrm{r}^{\prime}$ | Input clock frequency <br> Baud rate generator (2661-1, -2) <br> Baud rate generator $\frac{(2661-3)}{T \times C}$ | $\begin{aligned} & 1.0 \\ & 1.0 \\ & \text { dc } \end{aligned}$ | $\begin{aligned} & 4.9152 \\ & 5.0688 \end{aligned}$ | $\begin{gathered} 4.9202 \\ 5.0738 \\ 1.0 \\ \hline \end{gathered}$ | MHz <br> MHz <br> MHz |  |
| $t_{\text {brh }}$ <br> Іван <br> tarl <br> $t_{\text {BRL }}$ <br> $t_{\mathrm{RTH}}$ | Clock width <br> Baud rate high (2661-1, -2) <br> Baud rate high (2661-3) <br> Baud rate low (2661-1, -2) <br> Baud rate low $\qquad$ (2661-3) <br> $\overline{\mathrm{TXC}}$ or $\overline{\mathrm{RXC}}$ high T×C or $\overline{\mathrm{RxC}}$ low | $\begin{aligned} & 75 \\ & 70 \\ & 75 \\ & 70 \\ & \\ & 480 \\ & 480 \\ & \hline \end{aligned}$ |  |  | ns ns ns ns ns ns | $\begin{gathered} f_{\mathrm{BRG}}=4.915 \mathrm{MHz} ; \text { measured } \\ \text { at } \mathrm{V}_{\mathrm{HH}} \\ \mathrm{f}_{\mathrm{BRG}}=5.0688 \mathrm{MHz} ; \text { measured } \\ \text { at } \mathrm{V}_{\mathrm{H}} \text {, } \\ \mathrm{f}_{\mathrm{BRG}}=4.915 \mathrm{MHz} ; \text { measured } \\ \text { at } V_{\mathrm{IL}} \\ \mathrm{f}_{\mathrm{BRG}}=5.0688 \mathrm{MHz} \text {; measured } \\ \text { at } \mathrm{V}_{\mathrm{IL}} \end{gathered}$ |
| tixo $\mathrm{t}_{\text {tics }}$ | TxD delay from falling edge of TxC <br> Skew between TxD changing and falling edge of TXC output |  | 0 | 650 | ns ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |

## NOTE:

1. $f_{R} r$ and $t_{R ~ f L}$ shown all modes except Local Loopback. For Local Loopback mode $\mathrm{f}_{\mathrm{R} T}=0.7 \mathrm{MHz}$ and $\mathrm{t}_{\mathrm{R} \mathrm{TL}}=700 \mathrm{~ns} \mathrm{~min}$.


# Multi-Protocol Universal Synchronous Receiver/Transmitter USYNR/T 

## FEATURES

Selectable Protocol-Bit or Byte orientedDirect TTL CompatibilityThree-state Input/Output BUSProcessor Compatible-8 or 16 bitHigh Speed Operation-1.5 M Baud-typicalFully Double Buffered—Data, Status, and Control RegistersFull or Half Duplex Operation-independent Transmitter and Receiver Clocks
—individually selectable data length for Receiver and TransmitterMaster Reset-resets all Data, Status, and Control RegistersMaintenance Select-built-in self checking
PIN CONFIGURATION


BIT ORIENTED PROTOCOLS-SDLC, HDLC, ADCCP
$\square$ Automatic bit stuffing and stripping
$\square$ Automatic frame character detection and generation
$\square$ Valid message protection-a valid received message is protected from overrun
$\square$ Residue Handling-for messages which terminate with a partial data byte, the number of valid data bits is available

## SELECTABLE OPTIONS:

$\square$ Variable Length Data-1 to 8 bit bytes

- Error Checking-CRC (CRC16, CCITT-0, or CCITT-1) -None
$\square$ Primary or Secondary Station Address Mode
$\square$ All Parties Address-APA
$\square$ Extendable Address Field-to any number of bytes $\square$ Extendable Control Field-to 2 bytes $\square$ Idle Mode-idle FLAG characters or MARK the line $\square$ Point to Point, Multi-drop, or Loop Configuration

BYTE ORIENTED PROTOCOLS-BiSync, DDCMP $\square$ Automatic detection and generation of SYNC characters

SELECTABLE OPTIONS:
$\square$ Variable Length Data-1 to 8 bit bytes
$\square$ Variable SYNC character-5,6,7, or 8 bits

- Error Checking-CRC (CRC16, CCITT-0, or CCITT-1) —VRC (odd/even parity) -None
Strip Sync-deletion of leading SYNC characters after synchronization
$\square$ Idle Mode-idle SYNC characters or MARK the line


## APPLICATIONS

Remote Data ConcentractorsCommunication Test EquipmentComputer to Computer LinksHard Disk Data Handler
## General Description

The COM 5025 is a COPLAMOS ${ }^{\circledR} n$ channel silicon gate MOS/LSI device that meets the majority of synchronous communications requirements, by interfacing parallel digital systems to synchronous serial data communication channels while requiring a minimum of controller overhead.

The COM 5025 is well suited for applications such as computer to modem interfaces, computer to computer serial links and in terminal applications. Since higher level decisions and responses are made or initiated by the controller, some degree of intelligence in each controller of the device is necessary.

Newly emerging protocols such as SDLC, HDLC, and ADCCP will be able to utilize the COM 5025 with a high degree of efficiency as zero insertion for transmission and zero deletion for reception are done automatically. These protocols will be referred to as Bit Oriented Protocols (BOP). Any differences between them will be discussed in their respective sections. Conventional synchronous protocols that are control character oriented such as BISYNC can also utilize this device. Control Character oriented protocols will be referred to as CCP protocols. Other types of protocols that operate on a byte or character count basis can also utilize the COM 5025 with a high degree of efficiency in most cases. These protocols, such as DDCMP will also be referred to as CCP protocols.

The COM 5025 is designed to operate in a synchronous communications system where some external source is expected to provide the necessary received serial data, and all clock signals properly synchronized according to EIA standard RS334. The external controller of the chip will provide the necessary control signals, intelligence in interpreting control signals from the device and data to be transmitted in accord with RS334.

The receiver and transmitter are as symmetrical as possible without loss of efficiency. The controller of the device will be responsible for all higher level decisions and interpretation of some fields within message frames. The degree to which this occurs is dependent on the protocol being implemented. The receiver and transmitter logic operate as two totally independent sections with a minimum of common logic.

## References:

| 1. ANSI-American National Standards Institute | 3. EIA-Electronic Industries Association |
| :--- | :---: |
| X353, XS34/589 | TR30, RS334 |
| 202-466-2299 | $202-659-2200$ |
| 2. CCITT-Consultative Committee for International | 4. IBM |
| Telephone and Telegraph | General Information Brochure, GA27-3093 |
| X.25 | Loop Interface-OEM Information, GA27-3098 |
| 202-632-1007 | System Journal-Vol. 15, No. 1, 1976; G321-0044 |

## Terminology

| Term | Definition | Term | Definition |
| :--- | :--- | :--- | :--- |
| BOP | Bit Oriented Protocols: SDLC, HDLC, ADCCP | GA | 01111111 (0 (LSB) followed by 7-1's) |
| CCP | Control Character Protocols: BiSync, DDCMP | LSB | First transmitted bit, First received bit |
| TDB | Transmitter Data Buffer | MSB | Last transmitted bit, Last received bit |
| RDB | Receiver Data Buffer | RDP | Receiver Data Path |
| TDSR | Transmitter Data Shift Register | TDP | Transmitter Data Path |
| FLAG | 01111110 | LM | Loop Mode |
| ABORT | 11111111 (7 or more contiguous 1's) |  |  |

BLOCK DIAGRAM


## Description of Pin Functions

| Pin No. | Symbol | Name | I/O | Function |
| :---: | :---: | :---: | :---: | :---: |
| 1 | Vod | Power Supply | PS | + 12 volt Power Supply. |
| 2 | RCP | Receiver Clock | 1 | The positive-going edge of this clock shifts data into the receiver shift register. |
| 3 | RSI | Receiver Serial Input | 1 | This input accepts the serial bit input stream. |
| 4 | SFR | Sync/Flag Received | 0 | This output is set high, for 1 clock time of the RCP, each time a sync or flag character is received. |
| 5 | RXACT | Receiver Active | 0 | This output is asserted when the RDP presents the first data character of the message to the controller. In the BOP mode the first data character is the first non-flag character (address byte). In the CCP mode: 1. if strip-sync is set; the first non-sync character is the first data character 2 . if strip-sync is not set; the first data character is the character following the second sync. In the BOP mode the trailing (next) FLAG resets RXACT. In the CCP mode RXACT is never reset, it can be cleared via RXENA. |
| 6 | RDA | Receiver Data Available | 0 | This output is set high when the RDP has assembled an entire character and transferred it into the\|RDB. This output is reset by reading the RDB. |
| 7 | RSA | Receiver Status Available | 0 | This output is set high: 1. CCP-in the event of receiver over run (ROR) or parity error (if selected), 2. BOP-in the event of ROR, CRC error (if selected) receiving REOM or RAB/GA. This output is reset by reading the receiver status register or dropping of RXENA. |
| 8 | RXENA | Receiver Enable | 1 | A high level input allows the processing of RSI data. A low level disables the RDP and resets RDA, RSA and RXACT. |
| 9 | GND | Ground | GND | Ground |
| 10 | DBø8 | Data Bus | I/O | Bidirectional Data Bus. |
| 11 | DB99 | Data Bus | 1/0 | Bidirectional Data Bus. |
| 12 | DB1б | Data Bus | 1/0 | Bidirectional Data Bus. |
| 13 | DB11 | Data Bus | 1/0 | Bidirectional Data Bus. Wire "OR" with DBøø-DBø7 |
| 14 | DB12 | Data Bus | 1/0 | Bidirectional Data Bus. For 8 bit data bus |
| 15 | DB13 | Data Bus | 1/0 | Bidirectional Data Bus. |
| 16 | DB14 | Data Bus | $1 / 0$ | Bidirectional Data Bus. |
| 17 | DB15 | Data Bus | 1/0 | Bidirectional Data Bus. |
| 18 | W/R | Write/Read | 1 | Controls direction of data port. W/R=1, Write. W/R=0, Read. |
| 19 | A2 | Address 2 | 1 | Address input-MSB. |
| 20 | A1 | Address 1 | 1 | Address input. |
| 21 | A 1 | Address 0 | 1 | Address input-LSB. |
| 22 | BYTE OP | Byte Operation | 1 | If asserted, byte operation (data port is 8 bits wide) is selected. If $B Y T E O P=0$, data port is 16 bits wide. |
| 23 | DPENA | Data Port Enable | 1 | Strobe for data port. After address, byte op, W/R and data are set-up DPENA may be strobed. If reading the port, DPENA may reset (depending on register selected by address) RDA or RSA. If writing into the port, DPENA may reset (depending on register selected by address) TBMT. |
| 24 | DB07 | Data Bus | 1/0 | Bidirectional Data Bus-MSB. |
| 25 | DBØ6 | Data Bus | 1/0 | Bidirectional Data Bus. |
| 26 | DBø5 | Data Bus | 1/0 | Bidirectional Data Bus. |
| 27 | DBø4 | Data Bus | 1/0 | Bidirectional Data Bus. |
| 28 | DBø3 | Data Bus | 1/0 | Bidirectional Data Bus. |
| 29 | DBg2 | Data Bus | 1/0 | Bidirectional Data Bus. |
| 30 | DB¢1 | Data Bus | 1/0 | Bidirectional Data Bus. |
| 31 | DBØø | Data Bus | 1/0 | Bidirectional Data Bus-LSB. |
| 32 | Vcc | Power Supply | PS | + 5 volt Power Supply. |
| 33 | MR | Master Reset | 1 | This input should be pulsed high after power turn on. This will: clear all flags, and status conditions, set TBMT $=1$, TSO $=1$ and place the device in the primary BOP mode with 8 bit TX/RX data length, CRC CCITT initialized to all 1 's. |
| 34 | TXACT | Transmitter Active | 0 | This output indicates the status of the TDP. TXACT will go high after asserting TXENA and TSOM coinsidently with the first TSO bit. This output will reset one half clock after the byte during which TXENA is dropped. |
| 35 | TBMT | Transmitter Buffer Empty | 0 | This output is at a high level when the TDB or the TX Status and Control Register may be loaded with the new data. TBMT $=0$ on any write access to TDB or TX Status and Control Register. TBMT returns high when the TDSR is loaded. |
| 36 | TSA | Transmitter Status Available | 0 | TERR bit, indicating transmitter underflow. Reset by MR or assertion of TSOM. |
| 37 | TXENA | Transmitter Enable | 1 | A high level input allows the processing of transmitter data. |
| 38 | TSO | Transmitter Serial Output | 0 | This output is the transmitted character. |
| 39 | TCP | Transmitter Clock | 1 | The positive going edge of this clock shifts data out of the transmitter shift register. |
| 40 | MSEL | Maintenance Select | 1 | Internally RSI becomes TSO and RCP becomes TCP. Externally RSI is disabled and TSO=1. |

# Register Bit Assignment Chart 1 and 2 


＊Note：Product manufactured before 1Q79 may not have this feature．

## Register Bit Assignment Chart 1

| REGISTER | DP07 | DPø6 | DP65 | DP94 | DPø3 | DPø2 | DP\%1 | DP9\% |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Receiver Data Buffer | RD7 | RD6 | RD5 | RD4 | RD3 | RD2 | RD1 | RDØ |
| (Read OnlyRight JustifiedUnused Bits=0) | MSB |  |  |  |  |  |  | LSB |
| ```Transmitter Data Register (Read/Write- Unused Inputs=X)``` | TD7 MSB | TD6 | TD5 | TD4 | TD3 | TD2 | TD1 | $\begin{aligned} & \text { TDØ } \\ & \text { LSB } \end{aligned}$ |
| Sync/Secondary <br> Address <br> (Read/Write- <br> Right JustifiedUnused Inputs=X) | SSA7 MSB | SSA6 | SSA5 | SSA4 | SSA3 | SSA2 | SSA1 | $\begin{aligned} & \text { SSAø } \\ & \text { LSB } \end{aligned}$ |

## Register Bit Assignment Chart 2

| REGISTER | DP15 | DP14 | DP13 | DP12 | DP11 | DP10 | DP99 | DPø8 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Receiver Status (Read Only) | ERR CHK | C | B | A | ROR | RAB/GA | REOM | RSOM |
| TX Status and Control (Read/Write) | TERR (Read Only) | ) 0 | 0 | 0 | TXGA | TXAB | TEOM | TSOM |
| Mode Control (Read/Write) | *APA | PROTOCOL | STRIP SYNC/ LOOP | SEC ADD | IDLE | Z | Y | $x$ |
| Data Length Select (Read/Write) | TXDL3 | TXDL2 | TXDL1 | EXADD | EXCON | RXDL3 | RXDL2 | RXDL1 |

* Note: Product manufactured before 1Q79 may not have this feature.


## Register Address Selection

| 1) BYTE $\mathrm{OP}=0$, data port 16 bits wide |  |  |
| :---: | :---: | :---: |
| A2 | A 1 | $\mathrm{~A} \varnothing$ |
| 0 | 0 | X |
| 0 | 1 | X |
| 1 | 0 | X |
| 1 | 1 | X |

$X=$ don't care
2) $\mathrm{BYTE} \mathrm{OP}=1$, data port 8 bits wide

| A2 | A1 | A $\varnothing$ |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 0 | 1 |
| 0 | 1 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 0 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |
| 1 | 1 | 1 |

## Register

Receiver Data Buffer
Receiver Status Register
Transmitter Data Buffer
Transmitter Status and Control Register
SYNC/Address Register
Mode Control Register
Data Length Select Register

BOP TRANSMITTER OPERATION


## CCP TRANSMITTER OPERATION




Nori $-1-7$ ene

BOP RECEIVER TIMING


BOP TRANSMITTER OPERATION


## AC TIMING DIAGRAMS



RCP


Resets: RDP-RDA, RSA,
RXACT, receiver into search mode (for FLAG)

Note: Unless otherwise specified all times are maximum.

Data Port Timing

MAXIMUM GUARANTEED RATINGS*
Operating Temperature Range ..... $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range ..... $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec .) ..... $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground ..... $+18.0 \mathrm{~V}$
Negative Voltage on any Pin, with respect to ground ..... $-0.3 \mathrm{~V}$
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only andfunctional operation of the device at these or at any other condition above those indicated in the operationalsections of this specification is not implied.

NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. For example, the bench power supply programmed to deliver +12 volts may have large voltage transients when the AC power is switched on and off. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{VcC}=+5 \mathrm{~V} \pm 5 \%, V D D=+12 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. Characteristics |  |  |  |  |  |
| INPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low Level, VIL |  |  | 0.8 | V |  |
| High Level, $\mathrm{V}_{\text {IH }}$ | 2.0 |  | Vcc | V |  |
| OUTPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low Level, Vol |  |  | 0.4 | V | $1 \mathrm{l}=1.6 \mathrm{ma}$ |
| High Level, V он | 2.4 |  |  |  | $\mathrm{IOH}^{2}=40 \mu \mathrm{a}$ |
| INPUT LEAKAGE |  |  |  |  |  |
| Data Bus |  | 5.0 | 50.0 | $\mu \mathrm{a}$ | $0 \leqslant V_{\text {I }} \leqslant 5 \mathrm{v}$, DPENA $=0$ or $W / R=1$ |
| All others |  |  |  | $\mu \mathrm{a}$ | $V_{\text {IN }}=+5 v$ |
| INPUT CAPACITANCE |  |  |  |  |  |
| Data Bus, Cin |  |  |  | pf |  |
| Address Bus, Cin |  |  |  | pf |  |
| Clock, Cin |  |  |  | pf |  |
| All other, Cin |  |  |  | pf |  |
| POWER SUPPLY CURRENT |  |  |  |  |  |
| Icc |  |  | 70 | ma |  |
| lod |  |  | 90 | ma |  |
| A.C. Characteristics |  |  |  |  | TA $=25^{\circ} \mathrm{C}$ |
| CLOCK-RCP, TCP |  |  |  |  |  |
| frequency | DC |  | 1.5 | MHz |  |
| PWH | 325 |  |  | ns |  |
| PWL | 325 |  |  | ns |  |
| $\mathrm{tr}_{\mathrm{r}} \mathrm{t}_{\mathrm{t}}$ |  | 10 |  | ns |  |
| DPENA, Twdpena | 250 |  | $50 \mu \mathrm{~s}$ | ns |  |
| Set-up Time, TAs | 0 |  |  | ns |  |
| Byte Op, W/R |  |  |  |  |  |
| $A_{2}, A_{1}, A_{0}$ |  |  |  |  |  |
| Hold Time, Tah | 0 | 1 |  | ns |  |
| Byte Op, WIR, |  |  |  |  |  |
| A2, $A_{1}, A_{0}$ DATA BUS ACCESS, TDPA |  |  | 150 | ns |  |
| DATA BUS DISABLE DELAY, Tdpd |  |  | 100 | ns |  |
| DATA BUS SET-UP TIME, Tobs | 0 |  |  | ns |  |
| DATA BUS HOLD TIME, Tdвh | 100 |  |  | ns |  |
| MASTER RESET, MR | 350 |  |  | ns |  |



Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

# Dual 32 Bit CRC SDLC Generator/Checker CRC-32 

## FEATURES

SDLC 32 bit CRCCOM 5025 USYNRT CompanionData Rate- 2 MHz typicalAll Inputs and Outputs are TTL CompatibleSingle +5 Volt SupplyCOPLAMOS® N -Channel MOS Technology
## GENERAL DESCRIPTION

SMC's COM 8004 is a dual 32-bit CRC Generator/ Checker for use with SDLC protocols. It is a companion device to SMC's COM 5025 USYNRT. It operates at bit rates from DC to 2.0 MHz from a single $+5 v$ supply and is housed in a 20 lead $\times 0.3$ inch DIP. All inputs and outputs are TTL compatible with full noise immunity.
The COM 8004 is comprised of two independent halves, and each half may be operated in the check or generate mode. The polynominal used in computations is:
$X^{32}+X^{26}+X^{23}+X^{22}+X^{16}+X^{12}+X^{11}+X^{10}+X^{8}+X^{7}+X^{5}+$ $X^{4}+X^{2}+X+1$.
The CRC register is initialized to all ones and the result is inverted before being appended to the message. The expected remainder is:
$X^{31}+X^{30}+X^{26}+X^{25}+X^{24}+X^{18}+X^{15}+X^{14}+X^{12}+X^{11}+X^{10}+$ $X^{8}+X^{6}+X^{5}+X^{4}+X^{3}+X+1$.
Each half has a nine-bit serial data shift register. Data moves on the positive edge of the clock, and all clocked inputs are designed for zero-hold-time (e.g. 7474). A "clock out" pin provides gated clocks to the accompanying USYNRT (COM 5025).
In the generate mode, computation is initiatedupon detection of a flag character in the serial bit stream. CRC computation proceeds upon the serial data until a second flag is detected. CLK OUT to the SDLC transmitter is then halted, and the 32-bit CRC is passed out; CLK OUT is then resumed, and the flag character is passed out. Nonsignificant zeros are automatically stripped and stuffed, and shared flags are supported. If the data between flags is less than two full bytes, the CRC is discarded and the serial data stream remains unaltered.
In the check mode, computation is similarly initiated upon detection of a flag. Detection of a second flag causes the conditional setting of the error flag. A separate reset pin is provided for the error flag. No error is flagged on messages of less than two full bytes between flags. Detection of an abort character ( 7 consecutive ones) in either mode causes computation to be reset and a search for an opening flag resumed.

PIN CONFIGURATION

| MRA 10 | 20 Vcc |
| :---: | :---: |
| CLKINA 2 ¢ | 19 EFLGRB |
| Clkouta 3 d | 18 EFLGB |
| SERINA 4 d | 17 MODEB |
| SEROUTA 5 d | 16 ENAB |
| ENAA 6 [ | 15 SEROUTB |
| MODEA 7 [ | 14 SERINB |
| EFLGA 8 [ | 13 CLKOUTB |
| EflGRA 9 [ | 12 CLKINB |
| GND 10 | 11 MRB |

PACKAGE: 20 pin D.I.P.


## DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 1 | MASTER RESET-A | MRA | MRA presets the CRC calculation in Section A of the COM 8004 to all ones and forces the "pipeline" ( 8 shift register bits and the output flip-flop) to a logic "1" (Mark). The COM 8004 will only exit the reset state when MRA has been released and all 8 bits of a FLAG (01111110) have been received. |
| 2 | CLOCKINPUT-A | CLKINA | Baud Rate Clock for Section A. |
| 3 | CLOCK OUTPUT-A | CKLOUTA | Clock output from Section A. This is used to provide the clock for the USYNRT. CLKOUTA will normally track CLKINA. In the generate mode, when the last flag bit has been shifted into the shift register of the COM 8004, CLKOUTA will be held high until the CRC check character has been sent out. After the last bit of the CRC character is transmitted, CLKOUTA will resume tracking CLKINA. |
| 4 | SERIAL INPUT-A | SERINA | Serial input to the COM 8004 Section A. For transmission, SERINA is connected to the transmitter serial output of the USYNRT. For receiving, SERINA is connected to the received data output of the modem. |
| 5 | SERIAL OUTPUT-A | SEROUTA | Serial output from Section A of the COM 8004. For transmission, SEROUTA is connected to the transmit data input of the modem. For receiving, SEROUTA may be connected to the serial data input of the USYNRT. |
| 6 | ENABLE-A | ENAA | When ENAA is low, section A of the COM 8004 will pass data from SERINA to SEROUTA after a nine bit delay without alteration and without checking or generating CRC. If ENAA is high, CRC generation or checking will be enabled. ENAA is gated into the COM 8004 by the rising edge of CLKINA. |
| 7 | MODE SELECT-A | MODEA | MODEA determines whether Section A of the COM 8004 is in the receive (CRC check) Mode or transmit (CRC generate) Mode. Logic "1" selects CRC check. Logic " 0 " selects CRC generate. |
| 8 | ERROR FLAG-A | EFLGA | EFLGA will go high if, when in the CRC check mode, section A of the COM 8004 has detected an error. EFLGA can only be reset by a MASTER RESET (MRA) or by ERROR FLAGRESET (EFLGRA). |
| 9 | ERROR FLAG RESET-A | EFLGRA | A logic " 1 " on EFLGRA will reset EFLGA. If EFLGRA is kept at a logic " 1 ," it will inhibit the setting of EFLGA. |
| 10 | GROUND | GND | Ground. |
| 11 | MASTER RESET-B | MRB | Master reset for Section B. See MRA for description. |
| 12 | CLOCK IN-B | CLKINB | Clock input for Section B. See CLKINA for description. |
| 13 | CLOCK OUT-B | CLKOUTB | Clock output for Section B. See CLKOUTA for description. |
| 14 | SERIAL INPUT-B | SERINB | Serial input for Section B. See SERINA for description. |
| 15 | SERIAL OUTPUT-B | SEROUTB | Serial output for Section B. See SEROUTA for description. |
| 16 | ENABLE-B | ENAB | CRC enable for Section B. See ENAA for description. |
| 17 | MODE SELECT-B | MODEB | Mode select for Section B. See MODEA for description. |
| 18 | ERROR FLAG-B | EFLGB | Error Flag for Section B. See EFLGA for description. |
| 19 | ERROR FLAG RESET-B | EFLGRB | Error flag reset for Section B. See EFLGRA for description. |
| 20 | POWER SUPPLY | Vcc | +5 volt power supply input. |

The COM 8004 has 3 modes of operation, as selected by the ENABLE and MODE SELECT inputs. They are:

| $\frac{\text { ENABLE }}{0}$ |  | MODE SELECT |
| :---: | :---: | :--- |
|  |  | CRC Disabled. Data is <br> shifted from SERIN to <br> SEROUT with no compu- <br> tation performed. Serial <br> delay is 9 bit times. |
| 0 | 1 | Same as above. |
| 1 | 0 | CRC generation mode. |
| 1 | 1 | CRC check mode. |

In the CRC generation and check modes, calculations begin upon receipt of the first data character after an opening FLAG. "Stuffed zeroes" are stripped for the purpose of the CRC calculation. CRC calculation will continue until either a MASTER RESET occurs, ENABLE is brought to logic zero, an ABORT character is received, or a closing FLAG is received.

## CRC Generation

Upon detection of a closing FLAG character, CLKOUT is left high (stopping USYNRT activity), and the CRC accumulation is shifted out by CLKIN. CLKOUT then resumes clocking, and the FLAG (which has been stored in the shift register) is shifted out. The CRC check data is inverted before this data is transmitted. Zero-stuffing is performed on the inverted CRC check data.
During the time CKLOUT is forced high and CRC check data is being shifted out, data on SERIN will be ignored. If an ABORT character is received, CRC calculation will cease after the last " 1 " bit of the ABORT character is shifted into the shift register. Data will pass through the COM 8004 without effect until a FLAG is received.

## CRC Check (Reception)

When the last bit of a closing flag enters the shift register, ERRCHK will go high on the following positive CLKIN transition if a CRC error is detected.

## Operation Notes

Note 1: The minimum message size is sixteen significant bits following an opening flag. A stuffed zero is not considered a significant bit. If the message is less than 16 bits, the data will pass through the COM 8004 without being affected.
If the sixteenth received bit is the fifth consecutive one, but is not followed by a stuffed zero before a FLAG, the COM 8004 will detect the FLAG but the minimum message will not have occurred. CRC calculation will begin anew after this FLAG is detected.


Note 2: If the seventeenth bit of a message followed by a FLAG is the fifth consecutive one, but the stuffed zero is missing, the following will occur:
A) CRC Generate Mode: The last "one" bit, bit 17, will not be calculated into the CRC, but will appear at the serial output. The first bit of the CRC character will be forced to a zero, therefore looking like a stuffed zero.
B) CRC Check Mode: The last "one" bit, bit 17 , will not be calculated into the CRC.


Note 3: If a stuffed zero is missing in the middle or end of a message, the reaction will depend on the next bit. If it is a one, a FLAG or ABORT may be detected. If an ABORT is detected, the message and the CRC checking is aborted. If a FLAG is detected, a CRC error will be detected.
If the missing zero is followed by a zero, the CRC computation will continue, but the zero bit will be stripped, causing a CRC error.

## MAXIMUM GUARANTEED RATINGS*

> Operating Temperature Range $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

> Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+325^{\circ} \mathrm{C}$
> Positive Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0 V
> Negative Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 0.3 C
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{cc}}=+5$ Volts $\pm 5 \%$, unless otherwise noted)

| PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DC CHARACTERISTICS |  |  |  |  |  |  |
| Input Voltage Levels Low Level High Level | $\begin{aligned} & V_{\text {IL }} \\ & V_{I H} \end{aligned}$ | 2.0 |  | 0.8 | $\begin{aligned} & V \\ & V \end{aligned}$ |  |
| Output Voltage Levels Low Level High Level | Vol <br> Voh | 2.4 |  | 0.4 | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \\ & \mathrm{IOH}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \end{aligned}$ |
| Input Capacitance | $\mathrm{CIN}_{\text {IN }}$ |  | 10 | 25 | pf |  |
| Power Supply Current | Icc |  |  | 100 | mA |  |
| AC CHARACTERISTICS |  |  |  |  |  | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Clock Frequency | fin |  |  | 2 | MHz |  |
| Clock Pulse Width - High | tclek | 350 |  |  | ns | Figure 1 |
| Input Set-Up Time | toc | 100 |  |  | ns | Figure 1 |
| Input Hold Time | $t C D$ | 0 |  |  | ns | Figure 1 |
| Master Reset Pulse Width | tpw | 250 |  |  | ns | Figure 2 |
| Reset Delay | $\mathrm{t}_{\text {MR }}$ |  |  | 250 | ns | Figure 2 |
| Error Flag Delay | $\mathrm{t}_{\mathrm{F}}$ D |  |  | 300 | ns | Figure 3 |
| Error Flag Reset Delay | $t_{\text {fr }}$ |  |  | 100 | ns | Figure 4 |
| ERRST Pulse Width | tew | 100 |  |  | ns | Figure 4 |
| Clock Propagation Delay | $t_{\text {PD }}$ |  |  | 150 | ns | Figure 5 |
| SEROUT Propagation Delay | tso |  |  | 150 | ns | Figure 5 |

Figure 1


Figure 2


Figure 3


Figure 4

CRC ERR


Figure 5


## Universal Asynchronous Receiver/Transmitter UART <br> Pin Configuration

## FEATURES

Single +5 V Power SupplyDirect TTL Compatibility - no interfacing circuits requiredFull or Half Duplex Operation - can receive and transmit simultaneously at different baud ratesFully Double Buffered—eliminates need for precise external timingStart Bit Verification—decreases error rateFully Programmable - data word length; parity mode; number of stop bits: one, one and one-half, or twoHigh Speed Operation - 40K baud, 200ns strobesMaster Reset - Resets all status outputsTri-State Outputs - bus structure orientedLow Power-minimum power requirementsInput Protected-eliminates handling problemsCeramic or Plastic Dip Package-easy board insertionCompatible with COM 2017, COM 2502Compatible with COM 8116, COM 8126, COM 8136, COM 8146, COM 8046 Baud Rate Generators
## GENERAL DESCRIPTION

The Universal Asynchronous Receiver/Transmitter is an MOS/LSI monolothic circuit that performs all the receiving and transmitting functions associated with asynchronous data communications. This circuit is fabricated using SMC's patented COPLAMOS® technology and employs depletion mode loads, allowing operation from a single +5 V supply. The duplex mode, baud rate, data word length, parity mode, and number of stop bits are independently programmable through the use of external controls. There may be $5,6,7$ or 8 data bits, odd/even or no parity, and 1, or 2 stop bits. In addition the COM 8017 will provide 1.5 stop bits when programmed for 5 data bits and 2 stop bits. The UART can operate in either the full or half duplex mode. These programmable features provide the user with the ability to interface with all asynchronous peripherals.
VCC
NC
Gnd
RDE


## DESCRIPTION OF OPERATION - TRANSMITTER

At start-up the power is turned on, a clock whose frequency is 16 times the desired baud rate is applied and master reset is pulsed. Under these conditions TBMT, TEOC, and TSO are all at a high level (the line is marking).
When TBMT and TEOC are high, the control bits may be set. After this has been done the data bits may be set. Normally, the control bits are strobed into the transmitter prior to the data bits. However, as long as minimum pulse width specifications are not violated, TDS and CS may occur simultaneously. Once the date strobe (TDS) has been pulsed the TBMT signal goes low, indicating that the data bits buffer register is full and unavailable to receive new data.
If the transmitter shift register is transmitting previously loaded data the TBMT signal remains low. If the transmitter shift register is empty, or when it is through transmitting the previous character, the data in the buffer register is loaded immediately into the transmitter shift register and data transmission
commences. TSO goes low (the start bit), TEOC goes low, the TBMT goes high indicating that the data in the data bits buffer register has been loaded into the transmitter shift register and that the data bits buffer register is available to be loaded with new data.
If new data is loaded into the data bits buffer register at this time, TBMT goes lowand remains in this state until the present transmission is completed. One full character time is available for loading the next character with no loss in speed of transmission. This is an advantage of double buffering.
Data transmission proceeds in an orderly manner: start bit, data bits, parity bit (if selected), and the stop bit(s). When the last stop bit has been on the line for one bit time TEOC goes high. If TBMT is low, transmission begins immediately. If TBMT is high the transmitter is completely at rest and, if desired, new control bits may be loaded prior to the next data transmission.

## TRANSMITTER BLOCK DIAGRAM



## DESCRIPTION OF OPERATION - RECEIVER

At start-up the power is turned on, a clock whose frequency is 16 times the desired baud rate is applied and master reset is pulsed. The data available (RDA) signal is now low. There is one set of control bits for both the receiver and transmitter.
Data reception begins when the serial input line transitions from mark (high) to space (low). If the RSI line remains spacing for a $1 / 2$ bittime, a genuine start bit is verified. Should the line return to a mark-
ing condition prior to a $1 / 2$ bit time, the start bit verification process begins again. A mark to space transition must occur in order to initiate start bit verification. Once a start bit has been verified, data reception proceeds in an orderly manner: start bit verified and received, data bits received, parity bit received (if selected) and the stop bit(s) received.
If the transmitted parity bit does not agree with the received parity bit, the parity error flip-flop of the
status word buffer register is set high, indicating a parity error. However, if the no parity mode is selected, the parity error flip-flop is unconditionally held low, inhibiting a parity error indication. If a stop bit is not received, due to an improperly framed character, the framing error flip-flop is set high, indicating a framing error.
Once a full character has been received internal logic looks at the data available (RDA) signal. If, at this instant, the RDA signal is high the receiver assumes that the previously received character has
not been read out and the over-run flip-flop is set high. The only way the receiver is aware that data has been read out is by having the data available reset low.
At this time the RDA output goes high indicating that all outputs are available to be examined. The receiver shift register is now available to begin receiving the next character. Due to the double buffered receiver, a full character time is available to remove the received character.


## DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 1 | Vcc | Power Supply | +5 volt Supply |
| 2 | NC | No Connection | No Connection |
| 3 | GND | Ground | Ground |
| 4 | $\overline{\mathrm{RDE}}$ | Received Data Enable | A low-level input enables the outputs (RD8-RD1) of the receiver buffer register. |
| 5-12 | RD8-RD1 | Receiver Data Outputs | These are the 8 tri-state data outputs enabled by $\overline{\operatorname{RDE}}$. Unused data output lines, as selected by NDB1 and NDB2, have a low-level output, and received characters are right justified, i.e. the LSB always appears on the RD1 output. |
| 13 | RPE | Receiver Parity Error | This tri-state output (enabled by $\overline{\text { SWE }}$ ) is at a high-level if the received character parity bit does not agree with the selected parity. |
| 14 | RFE | Receiver Framing Error | This tri-state output (enabled by $\overline{\mathrm{SWE}}$ ) is at a high-level if the received character has no valid stop bit. |


| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 15 | ROR | Receiver Over Run | This tri-state output (enabled by $\overline{\text { SWE }}$ ) is at a high-level if the previously received character is not read (RDA output not reset) before the present character is transferred into the receiver buffer register. |
| 16 | $\overline{\text { SWE }}$ | Status Word Enable | A low-level input enables the outputs (RPE, RFE, ROR, RDA, and TBMT) of the status word buffer register. |
| 17 | RCP | Receiver Clock | This input is a clock whose frequency is 16 times (16X) the desired receiver baud rate. |
| 18 | $\overline{\text { RDAR }}$ | Receiver Data Available Reset | A low-level input resets the RDA output to a low-level. |
| 19 | RDA | Receiver Data Available | This tri-state output (enabled by $\overline{\text { SWE }}$ ) is at a high-level when an entire character has been received and transferred into the receiver buffer register. |
| 20 | RSI | Receiver Serial Input | This input accepts the serial bit input stream. A high-level (mark) to low-level (space) transition is required to initiate data reception. |
| 21 | MR | Master Reset | This input should be pulsed to a high-level after power turn-on. This sets TSO, TEOC, and TBMT to a high-level and resets RDA, RPE, RFE and ROR to a low-level. |
| 22 | TBMT | Transmitter Buffer Empty | This tri-state output (enabled by $\overline{\text { SWE }}$ ) is at a high-level when the transmitter buffer register may be loaded with new data. |
| 23 | $\overline{\text { TDS }}$ | Transmitter Data Strobe | A low-level input strobe enters the data bits into the transmitter buffer register. |
| 24 | TEOC | Transmitter End of Character | This output appears as a high-level each time a full character is transmitted. It remains at this level until the start of transmission of the next character or for one-half of a TCP period in the case of continuous transmission. |
| 25 | TSO | Transmitter Serial Output | This output serially provides the entire transmitted character. TSO remains at a high-level when no data is being transmitted. |
| 26-33 | TD1-TD8 | Transmitter Data Inputs | There are 8 data input lines (strobed by $\overline{T D S}$ ) available. Unused data input lines, as selected by NDB1 and NDB2, may be in either logic state. The LSB should always be placed on TD1. |
| 34 | CS | Control Strobe | A high-level input enters the control bits (NDB1, NDB2, NSB, POE and NPB) into the control bits holding register. This line may be strobed or hard wired to a high-level. |
| 35 | NPB | No Parity Bit | A high-level input eliminates the parity bit from being transmitted; the stop bit(s) immediately follow the last data bit. In addition, the receiver requires the stop bit(s) to follow immediately after the last data bit. Also, the RPE output is forced to a low-level. See pin 39, POE. |


| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 36 | NSB | Number of Stop Bits | This input selects the number of stop bits. A low-level input selects 1 stop bit; a high-level input selects 2 stop bits. Selection of 2 stop bits when programming a 5 data bit word generates 1.5 stop bits from the COM 8017 or COM 8017/H. |
| 37-38 | NDB2, NDB1 | Number of Data Bits/Character | These 2 inputs are internally decoded to select either $5,6,7$, or 8 data bits/character as per the following truth table: |
| 39 | POE | Odd/Even Parity Select | The logic level on this input, in conjunction with the NPB input, determines the parity mode for both the receiver and transmitter, as per the following truth table: |
|  |  |  | NPB POE MODE <br> L L odd parity <br> L H even parity <br> H X no parity <br>   $X=$ don't care |
| 40 | TCP | Transmitter Clock | This input is a clock whose frequency is 16 times (16X) the desired transmitter baud rate. |



Upon data transmission initiation, or when not transmitting at 100\% line utilization, the start bit will be placed on the TSO line at the high to low transition of the TCP clock following the trailing edge of TDS.

## RECEIVER TIMING-8 BIT, PARITY, 2 STOP BITS


" The RDA line was previously reset ( $R O R=$ low-level).

## START BIT DETECT/VERIFY



If the RSI line remains spacing for a $1 / 2$ bit time, a genuine start bit is verified. Should the line return to a marking condition prior to a $1 / 2$ bit time. the start bit veritication process begins again.

## MAXIMUM GUARANTEED RATINGS*

> Operating Temperature Range
> Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
> NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that at clamp circuit be used.

ELECTRICAL CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V} C \mathrm{C}=+5 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS INPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, VIL | 0 |  | 0.8 | V |  |
| High-level, $\mathrm{V}_{1 H}$ | 2.0 |  | Vcc | V |  |
| OUTPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, Vol |  |  | 0.4 | V | $\mathrm{loL}=1.6 \mathrm{~mA}$ |
| High-level, VOH | 2.4 |  |  | V | $\mathrm{IOH}=-100 \mu \mathrm{~A}$ |
| INPUT CURRENT |  |  |  |  |  |
| Low-level, IIL |  |  | 300 | $\mu \mathrm{A}$ | $V_{\text {IN }}=G_{N D}$ |
| OUTPUT CURRENT |  |  |  |  |  |
| Leakage, ILo |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\overline{\text { SWE }}=\overline{\mathrm{RDE}}=\mathrm{V}_{\text {IH }}, 0 \leq$ Vout $\leq+5 \mathrm{~V}$ |
| Short circuit, los** |  |  | 30 | mA | VOUT $=0 \mathrm{~V}$ |
| INPUT CAPACITANCE All inputs, Cin |  | 5 | 10 | pf |  |
| OUTPUT CAPACITANCE All outputs, Cout |  | 10 | 20 | pf | $\overline{S W E}=\overline{R D E}=V_{1 H}$ |
| POWER SUPPLY CURRENT Icc |  |  | 25 | mA | All outputs $=\mathrm{VOH}$, All inputs $=\mathrm{VCC}$ |
| A.C. CHARACTERISTICS |  |  |  |  | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ |
| $\text { COM8502, COM } 8017$ | DC |  | 640 | KHz | RCP, TCP |
| PULSE WIDTH |  |  |  |  |  |
| Clock | 0.7 |  |  | $\mu \mathrm{s}$ | RCP, TCP |
| Master reset | 500 |  |  | ns | MR |
| Control strobe | 200 |  |  | ns | CS |
| Transmitter data strobe | 200 |  |  | ns | TDSAR |
| INPUT SET-UP TIME | 200 |  |  | Hs | RDAR |
| Data bits | $\geq 0$ |  |  | ns | TD1-TD8 |
| Control bits | $\geq 0$ |  |  | ns | NPB, NSB, NDB2, NDB1, POE |
| INPUT HOLD TIME |  |  |  |  |  |
| Data bits | $\geq 0$ |  |  | ns | TD1-TD8 |
| Control bits | $\geq 0$ |  |  | ns | NPB, NSB, NDB2, NDB1, POE |
| STROBE TO OUTPUT DELAY |  |  |  |  | Load $=20 \mathrm{pf}+1$ TTL input |
| Receive data enable |  |  | 350 | ns | RDE: TPD1, TPDo |
| Status word enable |  |  | 350 | ns | SWE: TPD1, TPDO |
| OUTPUT DISABLE DELAY |  |  | 350 | ns | RDE, $\overline{\text { SWE }}$ |

**Not more than one output should be shorted at a time.

NOTES: 1 . If the transmitter is inactive (TEOC and TBMT are at a high-level) the start bit will appear on the TSO line within one clock period (TCP) after the trailing edge of TDS.
2. The start bit (mark to space transition) will always be detected within one clock period of RCP, guaranteeing a maximum start bit slippage of $1 / 16$ th of a bit time.
3. The tri-state output has 3 states: 1) low impedance to $\operatorname{Vcc} 2$ ) low impedance to GND 3) high impedance OFF $\cong$ 10M ohms The "OFF" state is controlled by the SWE and RDE inputs.

## DATACONTROL TIMING DIAGRAM

$\overline{T D S}$

DATA INPUTS
$\mathrm{tr}=\mathrm{tf}=20 \mathrm{~ns}$
TsET-UP $\geq 0$ THOLD $\geq 0$

cs

CONTROL INPUTS

*Input information (Data/Control) need only be valid during the last TPW, min time of the input strobes (TDS, CS).


NOTE: Waveform drawings not to scale for clarity.



Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

## Universal Synchronous/Asynchronous Receiver/Transmitter USART <br> PIN CONFIGURATION

$\square$ Asynchronous or Synchronous Operation

- Asynchronous:

5-8 Bit Characters
Clock Rate-1, 16 or $64 \times$ Baud Rate
Break Character Generation
$1,11 / 2$ or 2 Stop Bits
False Start Bit Detection
Automatic Break Detect and Handling
-Synchronous:
5-8 Bit Characters
Internal or External Character Synchronization
Automatic Sync Insertion
Single or Double Sync Characters
Programmable Sync Character(s)
$\square$ Baud Rate - Synchronous - DC to 64 K Baud
-Asynchronous-DC to 19.2K BaudBaud Rates available from SMC's COM 8116, COM 8126, COM 8136, COM 8146, and COM 8046Full Duplex, Double Buffered Transmitter and ReceiverOdd parity, even parity or no parity bitParity, Overrun and Framing Error FlagsModem Interface Controlled by Processor
All Inputs and Outputs are TTL Compatible

## GENERAL DESCRIPTION

The COM 8251A is an MOS/LSI device fabricated using SMC's patented COPLAMOS® technology that meets the majority of asynchronous and synchronous data communication requirements by interfacing parallel digital systems to asynchronous and synchronous data communication channels while requiring a minimum of processor overhead. The COM 8251A is an enhanced version of the 8251.
The COM 8251A is a Universal Synchronous/ Asynchronous Receiver/Transmitter (USART) designed for microcomputer system data communications. The USART is used as a peripheral and is programmed by the processor to communicate in commonly used asychronous and synchronous serial data transmission techniques including IBM $\mathrm{Bi}-\mathrm{Sync}$. The USART receives serial data streams and converts them into parallel data characters for the processor. While receiving serial data, the USART will also accept data characters from the processor in parallel format, convert them to serial format and transmit. The USART will signal the processor when it has completely received or transmitted a character and requires service. Complete USART status, including data format errors and control signals such as TXE and SYNDET, is available to the processor at any time.

$\square$ Compatable with Intel 8251A, NEC $\mu$ PD8251A
$\square$ Single +5 Volt SupplySeparate Receive and Transmit TTL ClocksEnhanced version of 8251
$\square 28$ Pin Plastic or Ceramic DIP Package
$\square$ COPLAMOS® ${ }^{\text {® }}$-Channel MOS Technology

BLOCK DIAGRAM


| PIN NO. | SYMBOL | NAME | INPUT/ OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 1,2,27, \\ & 28,5-8 \end{aligned}$ | $\begin{aligned} & \mathrm{D} 2, \mathrm{D} 3, \mathrm{DO} \\ & \mathrm{D} 1, \mathrm{D} 4-\mathrm{D} 7 \end{aligned}$ | DATA BUS | 1/O | An 8-bit, 3-state bi-directional DATA BUS used to interface the COM 8251A to the processor data bus. Data is transmitted or received by the bus in response to input/output or Read/Write instructions from the processor. The DATA BUS also transfers Control words, Command words, and Status. |
| 3 | RxD | RECEIVER DATA | 1 | This input receives serial data into the USART. |
| 4 | GND | GROUND | GND | Ground |
| 9 | $\overline{T x C}$ | $\begin{aligned} & \text { TRANSMITTER } \\ & \text { CLOCK } \end{aligned}$ | I | The TRANSMITTER CLOCK controls the serial character transmission rate. In the Asynchronous mode, the $\overline{T x C}$ frequency is a multiple of the actual Baud Rate. Two bits of the ModeInstruction select the multiple to be 1X, 16X, or 64X the Baud Rate. In the Synchronous mode, the TxC frequency is automatically selected to equal the actual Baud Rate. <br> Note that for both Synchronous and Asynchronous modes, serial data is shifted out of theUSART by the falling edge of TXC. |
| 10 | $\overline{W R}$ | WRITE DATA | 1 | A "zero" on this input instructs the COM 8251A to accept the data or control word which the processor is writing out to the USART via the DATA BUS. |
| 11 | $\overline{\mathrm{CS}}$ | $\overline{\text { CHIP SELECT }}$ | 1 | A "zero" on this input enables the USART for reading and writing to the processor. When $\overline{C S}$ is high, the DATA BUS is in the float state and RD and WR will have no effect on the chip. |
| 12 | C/D | CONTROL/ $\overline{\text { DATA }}$ | 1 | The Control/Data input, in conjunction with the $\overline{W R}$ and $\overline{R D}$ inputs, informs the USART to accept or provide either a data character, control word or status information via the DATA BUS. $0=$ Data; $1=$ Control/Status |
| 13 | $\overline{\mathrm{RD}}$ | $\overline{\text { READ DATA }}$ | 1 | A "zero" on this input instructs the COM 8251A to place the data or status information onto the DATA BUS for the processor to read. |
| 14 | RxRDY | RECEIVER READY | 0 | The RECEIVER READY output indicates that the Receiver Buffer is ready with an "assembled" character for input to the processor. For polled operation, the processor can check RxRDY using a Status Read or RxRDY can be connected to the processor interrupt structure. Note that reading the character to the processor automatically resets RxRDY. |
| 15 | TxRDY | TRANSMITTER READY | 0 | TRANSMITTER READY signals the processor that the transmitter is ready to accept a data character. TxRDY can be used as an interrupt or may be tested through the Status information polled operaton. TxRDY is automatically reset by the leading edge of WR when a data character is loaded from the processor. |
| 16 | SYNDET/ BRKDET | SYNC DETECT/ BREAK DETECT | I/O | The SYNDET feature is only used in the Synchronous mode. The USART may be programmed through the Mode Instruction to operate in either the internal or external Sync mode and SYNDET then functions as an output or input respectively. In the internal SYNC mode, the SYNDET output will go to a "one" when the COM 8251A has located the SYNC character in the Receive mode. If double SYNC character (bi-sync) operation has been programmed, SYNDET will go to "one" in the middle of the last bit of the second contiguously detected SYNC character. SYNDET is automatically reset to "zero" upon a Status Read or RESET. In the external SYNC mode, a "zero" to "one" transition on the SYNDET input is sampled during the negative half cycle of $\overline{\mathrm{RxC}}$ and will cause the COM 8251A to start assembling data character on the next rising edge of $\overline{R \times C}$. The length of the SYNDET input should be at least one $\overline{R X C}$ period, but may be removed once the COM 8251A is in SYNC. When external SYNC DETECT is programmed, the internal SYNC DETECT is disabled. |


| PIN NO. | SYMBOL | NAME | INPUT/ OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} 16 \\ \text { (cont.) } \end{gathered}$ |  |  |  | The SYNDET/BRKDET pin is used in both Synchronous and Asynchronous modes. When in SYNC mode the features for the SYNDET pin described above apply. When in Asynchronous mode, the BREAK DETECT output will go high when an all zero word of the programmed length is received. This word consists of: start bit, data bit, parity bitand one stop bit.Reset only occurs of: start bit, data bit, parity bit andone stop bit. Reset only occurs when Rx Data returns to a logic one state or upon chip RESET. The state of BREAK DETECT can also be read as a status bit. |
| 17 | $\overline{\text { CTS }}$ | CLEAR TO SEND | 1 | A "zero" on the CLEAR TO SEND input enables the USART to transmit serial data if the TxEN bit in the Command Instruction register is enabled (one). <br> If either a TXEN off or $\overline{C T S}$ off condition occurs while the Tx is in operation, the Tx will transmit all the datain the USART written prior to the Tx Disable command before shutting down. |
| 18 | TxE | TRANSMITTER EMPTY | 0 | The TRANSMITTER EMPTY output signals the processor that the USART has no further characters to transmit. TXE is automatically reset upon receiving a datacharacterfrom en er a trans- sor. mission and request the processor to "turn the line around". The TXEN bit in the command instruction does not effect TXE. In the Synchronous mode, a "one" on this output indicates that a SYNC character or characters are about to be automatically transmitted as "fillers" because the next data character has not been loaded; an underflow condition. If the USART is operating in the two SYNC character mode, both SYNC characters will be transmitted before the message can resume. TXE does not go low when the SYNC characters are being shifted out. TXE goes low upon the processor writing a character to the USART. |
| 19 | TxD | TRANSMItTER DATA | o | This output is the transmitted serial data from the USART. When a transmission is concluded the TXD line will always return to the marking state unless SBRK is programmed. |
| 20 | CLK | CLOCK PULSE | 1 | The CLK input provides for internal device timing. External inputs and outputs are not referenced to CLK, but the CLK frequency must be greater than 30 times the RECEIVER or TRANSMITTER CLOCKS in the 1X mode and greater than 4.5 times for the 16X and 64X modes. |
| 21 | RESET | RESET | 1 | A "one" on this input forces the USART into the "idle" mode where it will remain until reinitialized with a new set of control words. RESET causes: RxRDY = TxRDY = TxEmpty=SYNDET/ $\mathrm{BRKDET}=0 ; \mathrm{TXD}=\overline{\mathrm{DTR}}=\overline{\mathrm{RST}}=1$. Minimum RESET pulse width is 6 ter, CLK must be running during RESET. |
| 22 | $\overline{\text { DSR }}$ | $\overline{\text { DATA SET READY }}$ | 1 | The DATA SET READY input can be tested by the processor via Status information. The DSR input is normally used to test Modem Data Set Ready condition. |
| 23 | $\overline{\text { RTS }}$ | $\overline{\text { REQUEST TO SEND }}$ | 0 | The REQUEST TO SEND output is controlled via the Command word. The RTS output is normally used to drive the Modem Request to Send line. |
| 24 | $\overline{\text { DTR }}$ | DATA TERMINAL READY | 0 | The DATA TERMINAL READY output is controlled via the Command word. The DTR output is normally used to drive Modem Data Terminal Ready or Rate Select lines. |
| 25 | $\overline{\mathrm{RxC}}$ | RECEIVER CLOCK | 1 | The RECEIVER CLOCK is the rate at which the incoming character is received. In the Asynchronous mode, the $\overline{R x C}$ frequency may be 1, 16 or 64 times the actual Baud Rate but in the Synchronous mode the $\overline{\mathrm{RxC}}$ frequency must equal the Baud Rate. Two bits in the mode instruction select Asynchronous at 1X, 16X or 64X or Synchronous operation at 1X the Baud Rate. Data is sampled into the USART on the rising edge of $\overline{\mathrm{RxC}}$. |
| 26 | Vco | Vcc SUPPLY VOLTAGE | PS | +5 volt supply |

## Transmission-

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

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

## Receive-

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

## DESCRIPTION OF OPERATION-SYNCHRONOUS

## Transmission-

As in Asynchronous transmission, the TXD output remains "high" (marking) until the USART receives the first character (usually a SYNC character) from the processor. After a Command Instruction has set TxEN and after Clear to Send (CTS) goes low, the first character is serially transmitted. Data is shifted out on the falling edge of TXC at the same rate as TxC.

Once transmission has started, Synchronous Data Protocols require that the serial data stream at TxD continue at the TXC rate or SYNC will be lost. If a data character is not provided by the processor before the USART Transmit Buffer becomes empty, the SYNC character(s) loaded directly following the Mode Instruction will be automatically inserted in the TxD data stream. The SYNC character(s) are inserted to fill the line and maintain synchronization until the new data characters are available for transmission. If the USART becomes empty, and must send the SYNC character(s), the TxEMPTY output is raised to signal the processor that the Transmitter Buffer is empty and SYNC characters are being transmitted. TxEMPTY is automatically reset by the next character from the processor.

## Receive-

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

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

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

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

The processor may command the receiver to enter the HUNT mode with a Command Instruction which sets Enter HUNT (EH) if synchronization is lost. Under this condition the Rx register will be cleared to all "ones".

## OPERATION AND PROGRAMMING

The microprocessor program controlling the COM 8251A performs these tasks:

- Outputs control codes
- Inputs status
- Outputs data to be transmitted
- Inputs data which has been received

Control codes determine the mode in which the COM 8251A will operate and are used to set or reset control signals output by the COM 8251A.
The Status register contents will be read by the program monitoring this device's operation in order to determine error conditions, when and how to read data, write data or output control codes. Program logic may be based on reading status bit levels, or control signals may be used to request interrupts.

## INITIALIZING THE COM 8251A

Figure 1. Control Word Sequences for Initialization


ASYNCHRONOUS OPERATION


SYNCHRONOUS OPERATION

The COM 8251A may be initialized following a system RESET or prior to starting a new seral I/O sequence. The USART must be RESET (external or internal) following power up and subsequently may be reset at any time following completion of one activity and preceding a new set of operations. Following a reset, the COM 8251A enters an idle state in which it can neither transmit nor receive data.
The COM 8251A is initialized with two, three or four control words from the processor. Figure 1 shows the sequence of control words needed to initialize the COM 8251A, for synchronous or for asynchronous operation. Note that in asynchronous operation a mode control is output to the device followed by a command. For synchronous operation, the mode control is followed by one or two SYNC characters, and then a command.
Only a single address is set aside for mode control bytes, command bytes and SYNC character bytes. For this to be possible, logic internal to the chip directs control information to its proper destination based on the sequence in which it is received. Following a RESET (external or internal), the first control code output is interpreted as a mode control. If the mode control specifies synchronous operation, then the next one or two bytes (as determined by the
mode byte) output as control codes will be interpreted as SYNC characters. For either asynchronous or synchronous operation, the next byte output as a control code is interpreted as a command. All subsequent bytes output as control codes are interpreted as commands. There are two ways in which control logic may return to anticipating a mode control input; following a RESET input or following an internal reset command. A reset operation (internal via IR or external via RESET) will cause the USART to interpret the next "control write", which should immediately follow the reset, as a Mode Instruction.
After receiving the control words the USART is ready to communicate. TXRDY is raised to signal the processor that the USART is ready to receive a character for transmission. Concurrently, the USART is ready to receive serial data.

| $\mathrm{C} / \overline{\mathrm{D}}$ | $\overline{\mathrm{RD}}$ | $\overline{\mathrm{WR}}$ | $\overline{\mathrm{CS}}$ |  |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 1 | 0 | USART $\rightarrow$ Data Bus |
| 0 | 1 | 0 | 0 | Data Bus $\rightarrow$ USART |
| 1 | 0 | 1 | 0 | Status $\rightarrow$ Data Bus |
| 1 | 1 | 0 | 0 | Data Bus $\rightarrow$ Control |
| X | X | X | 1 | Data Bus $\rightarrow$ 3-State |
| X | 1 | 1 | 0 |  |

## MODE CONTROL CODES

The COM 8251A interprets mode control codes as illustrated in Figures 2 and 3.
Control code bits 0 and 1 determine whether synchronous or asynchronous operation is specified. A non-zero value in bits 0 and 1 specifies asynchronous operation and defines the relationship between data transfer baud rate and receiver or transmitter clock rate. Asynchronous serial data may be received or transmitted on every clock pulse, on every 16 th clock pulse, or on every 64th clock pulse, as programmed. A zero in both bits 0 and 1 defines the mode of operation as synchronous.
For synchronous and asynchronous modes, control bits 2 and 3 determine the number of data bits which will be present in each data character. In the case of a programmed character length of less than 8 bits, the least significant DATA BUS unused bits are "don't care" when writing data to the USART and will be "zeros" when reading data. Rx data will be right justified onto DO and the LSB for Tx data is DO .
For synchronous and asynchronous modes, bits 4 and 5
determine whether there will be a parity bit in each character, and if so, whether odd or even parity will be adopted. Thus in synchronous mode a character will consist of five, six, seven or eight data bits, plus an optional parity bit. In asynchronous mode, the data unit will consist of five, six, seven or eight data bits, an optional parity bit, a preceeding start bit, plus $1,1 \frac{1}{2}$ or 2 trailing stop bits. Interpretation of subsequent bits differs for synchronous or asynchronous modes.

Control code bits 6 and 7 in asynchronous modedetermine how many stop bits will trail each data unit. $11 / 2$ stop bits can only be specified with a 16X or 64X baud rate factor. In these two cases, the half stop bit will be equivanlent to 8 or 32 clock pulses, respectively.
In synchronous mode, control bits 6 and 7 determine how character synchronization will be achieved. When SYNDET is an output, internal synchronization is specified; one or two SYNC characters, as specified by control bit 7 , must be detected at the head of a data stream in order to establish synchronization.

## COMMAND WORDS

Command words are used to initiate specific functions within the COM 8251A such as, "reset all error flags" or "start searching for sync". Consequently, Command Words may be issued by the processor to the COM 8251A at any time during the execution of a program in which
specific functions are to be initialized within the communication circuit.
Figure 4 shows the format for the Command Word.

Figure 4. COM 8251A Control Command


Figure 2. Synchronous Mode Control Code.


Figure 3. Asynchronous Mode Control Code.


Bit 0 of the Command Word is the Transmit Enable bit (TXEN). Data transmission for the COM 8251A cannot take place unless TXEN is set (assuming CTS $=0$ ) in the command register. The TX Disable command is prevented from halting transmission by the Tx Enable logic until all data previously written has been transmitted. Figure 5 defines the way in which TxEN, TxE and TxRDY combines to control transmitter operations.
Bit 1 is the $\overline{\text { Data Terminal Ready ( } \overline{\mathrm{DTR}} \text { ) bit. When the } \overline{\mathrm{DTR}} \text {. } n \text {. }}$ command bit is set, the DTR output connection is active (low). DTR is used to advise a modem that the dataterminal is prepared to accept or transmit data.

Bit 2 is the Receiver Enable Command bit ( $R \times E$ ). RxE is used to enable the RxRDY output signal. RxE, when zero, prevents the RxRDY signal from being generated to notify the processor that a complete character is framed in the Receive Character Buffer. It does not inhibit the assembly of data characters at the input, however. Consequently, if communication circuits are active, characters will be assembled by the receiver and transferred to the Receiver Buffer. If RxE is disabled, the overrun error (OE) will probably be set; to insure proper operation, the overrun error is usually reset with the same command that enables RxE.

| Operation of the Transmitter Section as a Function of TxE, TxRDY and TxEN |  |  |  |
| :---: | :---: | :---: | :---: |
| TXEN | TXE | TXRDY |  |
| 1 | 1 | 1 | Transmit Output Register and Transmit Character Buffer empty. <br> TxD continues to mark if COM 8251A is in the asynchronous mode. <br> TxD will send SYNC pattern if COM 8251A is in the Synchronous <br> Mode. Data can be entered into Buffer. |
| 1 | 0 | 1 | Transmit Output Register is shifting a character. Transmit Character <br> Buffer is available to receive a new byte from the processor. |
| 1 | 1 | 0 | Transmit Register has finished sending. A new character is waiting <br> for transmission. This is a transient condition. |
| 1 | 0 | 0 | Transmit Register is currently sending and an additional character <br> is stored in the Transmit Character Buffer for transmission. |
| 0 | $0 / 1$ | $0 / 1$ | Transmitter is disabled. |

Bit 3 is the Send Break Command bit (SBRK). WhenSBRK is set, the transmitter output (TxD) is interrupted and a continuous binary " 0 " level, (spacing) is applied to the TxD output signal. The break will continue until a subsequent Command Word is sent to theCOM8251A to removeSBRK.
Bit 4 is the Error Reset bit (ER). When a Command Word is transferred with the ER bit set, all three error flags (PE, OE, FE) in the Status Register are reset. Error Reset occurs when the Command Word is loaded into the COM 8251A. No latch is provided in the Command Register to save the ER command bit.
Bit 5, the Request To Send Command bit ( $\overline{\mathrm{RTS}}$ ), sets a latch to reflect the RTS signal level. The output of this lattch is created independently of other signals in the COM 8251A. As a result, data transfers may be made by the processor to the Transmit Register, and data may be actively transmitted to the communication line through TxD regardless of the status of $\overline{\text { RTS }}$.
Bit 6, the Internal Reset (IR), causes the COM 8251A to
return to the Idle mode. All functions within the COM 8251A cease and no new operation can be resumed until the circuit is reinitialized. If the operating mode is to be altered during the execution of a processor program, the COM 8251A must first be reset. Either the RESET input can be activated, or the Internal Reset Command can be sent to the COM 8251A. Internal Reset is a momentary function performed only when the command is issued.
Bit 7 is the Enter Hunt command bit (EH). The Enter Hunt mode command is only effective for the COM 8251A when it is operating in the Synchronous mode. EH causes the receiver to stop assembling characters at the R×D input, clear the Rx register to all "ones", and start searching for the prescribed sync pattern. Once the "Enter Hunt" mode has been initiated, the search for the sync pattern will continue indefinitely until EH is reset when a subsequent Command Word is sent, when the IR command is sent to the COM 8251A, or when SYNC characters are recognized. Parity is not checked in the EH mode.

## STATUS REGISTER

The Status Register maintains information about the current operational status of the COM 8251A. Status can be read at any time, however, the status update will be inhibited during status read. Figure 6 shows the format of the Status Register.
TxRDY signals the processor that the Transmit Character Buffer is empty and that the COM 8251A can accept a new character for transmission. The TxRDY status bit is not
totally equivalent to the TxRDY output pin, the relationship is as follows:

TxRDY (status bit) $=$ Tx Character Buffer Empty TxRDY (pin 15) $=$ Tx Character Buffer Empty • CTS • TxEN
RxRDY signals the processor that a completed character is holding in the Receive Character Buffer Register for transfer to the processor.

Figure 6. The COM 8251A Status Register


TxE signals the processor that the Transmit Register is empty.
PE is the Parity Error signal indicating to the CPU that the character stored in the Receive Character Buffer was received with an incorrect number of binary "1" bits. PE does not inhibit USART operation. PE is reset by the ER bit. OE is the receiver Overrun Error. OE is set whenever a byte stored in the Receiver Character Register is overwritten with a new byte before being transferred to the processor. OE does not inhibit USART operation. OE is reset by the ER bit.
FE (Async only) is the character framing error which indicates that the asynchronous mode byte stored in the Receiver Character Buffer was received with incorrect bit format ("0" stop bit), as specified by the current mode. FE does not inhibit USART operaton. FE is reset by the ER bit.

SYNDET is the synchronous mode status bit associated with internal or external sync detection.
DSR is the status bit set by the external $\overline{\text { Data Set Ready }}$ signal to indicate that the communication Data Set is operational.
All status bits are set by the functions described for them. SYNDET is reset whenever the processor reads the Status Register. OE, FE, PE are reset by the error reset command or the internal reset command or the RESET input. OE, FE, or PE being set does not inhibit USART operation.
Many of the bits in the status register are copies of external pins. This dual status arrangement allows the USART to be used in both Polled and Interrupt driven environments. Status update can have a maximum delay of 16 tcy periods.

## Note:

1. While operating the receiver it is important to realize that the RxE bit of the Command Instruction only inhibits the assertion of RxRDY; it does not inhibit the actual reception of characters. As the receiver is constantly running, it is possible for it to contain extraneous data when it is enabled. To avoid problems this data should be read from the USART and discarded. This read should be done immediately following the setting of the RxE bit in the asynchronous mode, and following the setting of EH in the synchronous mode. It is not necessary to wait for RxRDY before executing the dummy read.
2. ER should be performed whenever R×E of EH are programmed. $E R$ resets all error flags, even if $R x E=0$.
3. The USART may provide faulty RxRDY for the first read after power-on or for the first read after the receiver is re-enabled by a command instruction (RxE). A dummy read is recommended to clear faulty RxRDY. This is not the case for the first read after hardware or software reset after the device opration has been established.
4. Internal Sync Detect is disabled when External Sync Detect is programmed. An External Sync Detect Status is provided through an internal flip-flop which clears itself, assuming the External Sync Detect assertion has removed, upon a status read. As long as External Sync Detect is asserted, External Sync Detect Status will remain high.

## MAXIMUM GUARANTEED RATINGS*



ELECTRICAL CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| SYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :--- | :--- | :--- | :--- |

## D.C. Characteristics

| VIL | Input Low Voltage |
| :--- | :--- |
| VIH | Input High Voltage |
| VoL | Output Low Voltage |
| VoH | Output High Voltage |
| IofL | Output Float Leakage |
| ILL | Input Leakage |
| Icc | Power Supply Current |


| -0.3 | 0.8 | V |  |
| :---: | :---: | :---: | :---: |
| 2.0 | Vcc | V |  |
|  | 0.45 | V | $\mathrm{loL}=2.2 \mathrm{~mA}$ |
| 2.4 |  | V | $\mathrm{l} \mathrm{H}=-400 \mu \mathrm{~A}$ |
|  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {out }}=\mathrm{V}_{\text {cc }}$ TO 0.45V |
|  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {cc }}$ TO 0.45 V |
|  | 100 | mA | All Outputs $=\mathrm{High}$ |

## Capacitance

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{cc}}=\mathrm{GND}$

| $\mathrm{C}_{1 \mathrm{~N}}$ | Input Capacitance |
| :--- | :--- |
| $\mathrm{C}_{1 / 0}$ | I/O Capacitance |


| 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| :--- | :--- | :--- | :--- |
| 20 | pF | Unmeasured pins returned to GND |

A.C. Characteristics

Bus Parameters (Note 1)

## Read Cycle:

| $t_{\text {AR }}$ | Address Stable Before $\overline{\operatorname{READ}}$ ( $\overline{C S}, \mathrm{C} / \overline{\mathrm{D}}$ ) |
| :---: | :---: |
| $\mathrm{t}_{\text {RA }}$ | Address Hold Time for $\overline{\text { READ }}$ ( $\overline{C S}, C / \bar{D}$ ) |
| $t_{\text {Rr }}$ | $\overline{\text { READ Pulse Width }}$ |
| thd | Data Delay from READ |
| tbr | $\widehat{R E A D}$ to Data Floating |


| 0 |  | ns |
| ---: | ---: | ---: |
| 0 |  | ns |
| 250 |  | ns |
|  | 200 | ns |
| 10 | 100 | ns |

## Write Cycle:

| taw | Address Stable Before WRITE | 0 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| twa | Address Hold Time for WRITE | 0 |  | ns |  |
| tww | WRITE Pulse Width | 250 |  | ns |  |
| tow | Data Set Up Time for WRITE | 150 |  | ns |  |
| two | Data Hold Time for WRITE | 0 |  | ns |  |
| tev | Recovery Time Between WRITES | 6 |  | tcr | Note 4 |
| Other Timings: |  |  |  |  |  |
| tor | Clock Period | . 320 | 1.35 | $\mu \mathrm{s}$ | Notes 5, 6 |
| $t_{\text {d }}$ | Clock High Pulse Width | 120 | tcr -90 | ns |  |
| $t_{\text {¢ }}$ | Clock Low Pulse Width | 90 |  | ns |  |


| SYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {f }}, t_{F}$ | Clock Rise and Fall Time | 5 | 20 | ns |  |
| totx | TxD Delay from Falling Edge of $\overline{T x C}$ |  | 1 | $\mu \mathrm{s}$ |  |
| $t_{\text {sfx }}$ | Rx Data Set-Up Time to Sampling Pulse | 2 |  | $\mu \mathrm{s}$ |  |
| $t_{\text {HRx }}$ | Rx Data Hold Time to Sampling Pulse | 2 |  | $\mu s$ |  |
| $\mathrm{ftx}^{\text {x }}$ | ```Transmitter Input Clock Frequency 1X Baud Rate 16X Baud Rate 64X Baud Rate``` | $\begin{aligned} & D C \\ & D C \\ & D C \end{aligned}$ | $\begin{array}{r} 64 \\ 310 \\ 615 \end{array}$ | $\begin{aligned} & \mathrm{kHz} \\ & \mathrm{kHz} \\ & \mathrm{kHz} \end{aligned}$ |  |
| ttpw | Transmitter Input Clock Width 1X Baud Rate 16X and 64X Baud Rate | $\begin{array}{r} 12 \\ 1 \end{array}$ |  | $\begin{aligned} & \text { toy } \\ & \text { tcy } \end{aligned}$ |  |
| ttpd | $\begin{array}{\|l} \text { Transmitter Input Clock Pulse Delay } \\ 1 \times \text { Baud Rate } \\ 16 \mathrm{X} \text { and } 64 \mathrm{X} \text { Baud Rate } \end{array}$ | $\begin{array}{r} 15 \\ 3 \end{array}$ |  | tcy <br> tor |  |
| $\mathrm{ffx}_{\text {f }}$ | $\begin{gathered} \text { Receiver Input Clock Frequency } \\ 1 \times \text { Baud Rate } \\ 16 X \text { Baud Rate } \\ 64 \mathrm{X} \text { Baud Rate } \end{gathered}$ | $\begin{aligned} & \text { DC } \\ & \text { DC } \\ & \text { DC } \end{aligned}$ | $\begin{array}{r} 64 \\ 310 \\ 615 \end{array}$ | $\begin{aligned} & \mathrm{kHz} \\ & \mathrm{kHz} \\ & \mathrm{kHz} \end{aligned}$ |  |
| traw | Receiver Input Clock Pulse Width 1X Baud Rate 16X and 64X Baud Rate | $\begin{array}{r} 12 \\ 1 \end{array}$ |  | $\begin{aligned} & \text { tcy } \\ & \text { tor } \end{aligned}$ |  |
| trpo | Receiver Input Clock Pulse Delay 1X Baud Rate 16X and 64X Baud Rate | $\begin{array}{r} 15 \\ 3 \end{array}$ |  | $\begin{aligned} & \text { tcy } \\ & \text { tcr } \end{aligned}$ |  |
| $t_{\text {Tx }}$ RDY | TxRDY Pin Delay from Center of last Bit |  | 8 | tcy | Note 7 |
| ttxady clear | TxRDY! from Leading Edge of $\overline{W R}$ |  | 150 | ns | Note 7 |
| $t_{\text {RxRDY }}$ | RxRDY Pin Delay from Center of last Bit |  | 24 | tcy | Note 7 |
| $t_{\text {fx }}$ moy clear | RxRDY \from Leading Edge of $\overline{\mathrm{RD}}$ |  | 150 | ns | Note 7 |
| tis | Internal SYNDET Delay from Rising Edge of RxC |  | 24 | tcr | Note 7 |
| tes | External SYNDET Set-Up Time Before Falling Edge of RxC |  | 16 | tcr | Note 7 |
| $t_{\text {txempty }}$ | TxEMPTY Delay from Center of Data Bit |  | 20 | tcr | Note 7 |
| twc | Control Delay from Rising Edge of WRITE (TxEn, DTR, $\overline{R T S})$ |  | 8 | tor | Note 7 |
| tcr | Control to READSet-Up Time ( $\overline{\mathrm{DSR}}, \overline{\mathrm{CTS}})$ |  | 20 | tcr | Note 7 |

NOTES: 1. $A C$ timings measured $\mathrm{VOH}_{\mathrm{OH}}=2.0, \mathrm{VOL}_{\mathrm{O}}=0.8$, and with load circuit of Figure 1.
2. Chip Select (CS) and Command/Data (C/D) are considered as Addresses.
3. Assumes that Address is valid before Rol.
4. This recovery time is for RESET and Mode Initialization. Write Data is allowed only when TXRDY $=1$. Recovery Time between Writes for Asynchronous Mode is 8 tcr and for Synchronous Mode is 16 tor.
5. The TXC and RXC frequencies have the following limitations with respect to CLK.

For $1 \times$ Baud Rate, frx or $\mathrm{frx} \leq 1 /(30 \mathrm{tcy})$
For 16 X and 64 X Baud Rate, $\mathrm{ftx}_{\mathrm{x}}$ or $\mathrm{f}_{\mathrm{R}} \leq 1 /(4.5 \mathrm{tcy})$
6. Reset Pulse Width $=6$ tcr minimum; System Clock must be running during RESET.
7. Status update can have a maximum delay of 28 clock periods from the event affecting the status.


Figure 1.
test load circuit


## WAVEFORMS

## System Clock Input



Transmitter Clock \& Data


Receiver Clock \& Data


Write Data Cycle (CPU $\rightarrow$ USART)


Read Data Cycle (CPU $\leftarrow$ USART)


Write Control or Output Port Cycle (CPU $\rightarrow$ USART)


NOTE =1: $T_{\text {WC }}$ INCLUdes the response timing of a control byte.

Read Control or Input Port (CPU $\leftarrow$ USART)


NOTE \#1: $T_{C R}$ INCLUDES THE EFFECT OF CTS ON THE TXENBL CIRCUITRY.

Transmitter Control \& Flag Timing (ASYNC Mode)


Receiver Control \& Flag Timing (ASYNC Mode)


Transmitter Control \& Flag Timing (SYNC Mode)


EXAMPLE FORMAT - 5 BIT CHARACTER WITH PARITY. 2 SYNC CHARACTERS.

Receiver Control \& Flag Timing (SYNC Mode)


NOTE :1: INTERNAL SYNC. 2 SYNC CHARACTERS, 5 BITS, WITH PARITY NOTE =2: EXTERNAL SYNC, 5 BITS, WITHPARITY


Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

## Baud Rate Generator

All Baud Rate Generators are programmable dividers capable of providing 16 output frequencles* for UARTs or USARTs from either an on-chip crystal oscillator or an external frequency input. "' T " versions utilize an external frequency input only. Dual Baud Rate Generators provide two out-
*except as noted
put frequencies simultaneously for full duplex communications.
Baud Rate Generators providing all standard baud rates from various popular crystal frequencies are available. In addition the baud rate generator may be custom mask programmed for other divisors.

| Part Number | Description | Features | Power Supplies | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| COM 5016 | Dual Baud Rate Generator | On-chip oscillator or external frequency input | +6, +12 | 18 DIP | 167-168 |
| COM 5016T ${ }^{(3)}$ | Dual Baud Rate Generator | External frequency input | +5, +12 | 18 DIP | 167-168 |
| COM 5026 | Single Baud Rate Generator | On-chip oscillator or external frequency input | +5, +12 | 14 DIP | 169-170 |
| COM 5026T ${ }^{(3)}$ | Single Baud Rate Generator | External frequency input | +5, +12 | 14 DIP | 169-170 |
| COM 5036 | Dual Baud Rate Generator | COM 5016 with additional output of input frequency $\div 4$ | +5, +12 | 18 DIP | 171-172 |
| COM 5036T ${ }^{(3)}$ | Dual Baud Rate Generator | COM 5016T with additional output of input frequency $\div 4$ | +5, +12 | 18 DIP | 171-172 |
| COM 5046 | Single Baud Rate Generator | COM 5026 with additional output of input frequency $\div 4$ | +5, +12 | 14 DIP | 173-174 |
| COM 5046T ${ }^{(3)}$ | Single Baud Rate Generator | COM 5026T with additional output of input frequency $\div 4$ | +5, +12 | 14 DIP | 173-174 |
| COM 8046 | Single Baud Rate Generator | 32 baud rates; IX, 16X, 32X clock outputs; single +5 volt supply | +5 | 16 DIP | 179-180 |
| COM 8046T ${ }^{(3)}$ | Single Baud Rate Generator | COM 8046 with external frequency input only | +5 | 16 DIP | 179-180 |
| COM 8116 | Dual Baud Rate Generator | Single +5 volt version of COM 5016 | +5 | 18 DIP | 181-182 |
| COM $8116 \mathrm{~T}^{(3)}$ | Dual Baud Rate Generator | Single +5 volt version of COM 5016T | +5 | 18 DIP | 181-182 |
| COM 8126 | Single Baud Rate Generator | Single +5 volt version of COM 5026 | 45 | 14 DIP | 183-184 |
| COM $8126^{(3)}$ | Single Baud Rate Generator | Single +5 volt version of COM 5026T | $+5$ | 14 DIP | 183-184 |
| COM 8136 | Dual Baud Rate Generator | Single +5 volt version of COM 5036 | +5 | 18 DIP. | 185-186 |
| COM 81361 ${ }^{(3)}$ | Dual Baud Rate Generator | Single +5 volt version of COM 5036T | +5 | 18 DIP | 185-186 |
| COM 8146 | Single Baud Rate Generator | Single +5 volt version of COM 5048 | +5 | 14 DIP | 187-188 |
| COM $8146 \mathrm{~T}^{(3)}$ | Single Baud Rate Generator | Single +5 volt version of COM 5046T | $+5$ | 14 DIP | 187-188 |

[^6]
## Dual Baud Rate Generator Programmable Divider

## FEATURES

$\square$ On chip crystal oscillator or external frequency inputChoice of $2 \times 16$ output frequencies16 asynchronous/synchronous baud ratesDirect UART/USRT/ASTRO/USYNRT compatibilityFull duplex communication capabilityTTL, MOS compatibility

PIN CONFIGURATION


## BLOCK DIAGRAM



## General Description

The Standard Microsystems COM 5016 Dual Baud Rate Generator/Programmable Divider is an N-channel COPLAMOS ${ }^{\circledR}$ MOS/LSI device which, from a single crystal (on-chip oscillator) or input frequency is capable of generating 32 externally selectable frequencies.

The COM 5016 is specifically dedicated to generating the full spectrum of 16 asynchronous/synchronous data communication frequencies as shown in Table 1 . One of the sixteen output frequencies is externally selected by four address inputs, on each of the independent dividers, as shown in Table 1.

Internal re-programmable ROM allows the generation of other frequencies from other crystal frequencies or input frequencies. The four address inputs on each divider section may be strobe ( 150 ns ) or DC loaded. As the COM 5016 is a dual baud rate generator, full duplex (independent receive and transmit frequencies) operation is possible.

The COM 5016 is basically a programmable 15 -stage feedback shift register capable of dividing any modulo up to $\left(2^{15}-1\right)$.

By using one of the frequency outputs it is possible to generate additional divisions of the master clock frequency by cascading COM 5016's. The frequency output is fed into the XTAL/EXT input on a subsequent device. In this way one crystal or input frequency may be used to generate numerous output frequencies.

The COM 5016 can be driven by either an external crystal or TTL logic level inputs: COM 5016T is driven by TTL logic level inputs only.

## Description of Pin Functions

| Pin No. | Symbol | Name | Function |
| :---: | :---: | :---: | :---: |
| 1 | XTAL/EXT1 | Crystal or External Input 1 | This input is either one pin of the crystal package or one polarity of the external input. |
| 2 | $V_{c c}$ | Power Supply | +5 volt supply |
| 3 | $\mathrm{f}_{\mathrm{R}}$ | Receiver Output Frequency | This output runs at a frequency selected by the Receiver divisor select data bits. |
| 4-7 | $\mathrm{R}_{\mathrm{A}}, \mathrm{R}_{\mathrm{B}}, \mathrm{R}_{\mathrm{C}}, \mathrm{R}_{\mathrm{D}}$ | Receiver-Divisor Select Data Bits | The logic level on these inputs, as shown in Table 1, selects the receiver output frequency, $f_{R}$. |
| 8 | STR | Strobe-Receiver | A high level input strobe loads the receiver data ( $R_{A}, R_{B}, R_{C}, R_{D}$ ) into the receiver divisor select register. This input may be strobed or hard-wired to a high level. |
| 9 | $V_{D D}$ | Power Supply | + 12 volt supply |
| 10 | NC | No Connection |  |
| 11 | GND | Ground | Ground |
| 12 | STT | StrobeTransmitter | A high level input strobe loads the transmitter data ( $T_{A}, T_{B}, T_{C}, T_{D}$ ) into the transmitter divisor select register. This input may be strobed or hard-wired to a high level. |
| 13-16 | $\mathrm{T}_{\mathrm{D}}, \mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{B}}, \mathrm{T}_{\mathrm{A}}$ | TransmitterDivisor Select Data Bits | The logic level on these inputs, as shown in Table 1, selects the transmitter output frequency, $\mathrm{f}_{\mathrm{T}}$. |
| 17 | $\mathbf{f}_{T}$ | Transmitter Output Frequency | This output runs at a frequency selected by the Transmitter divisor select data bits. |
| 18 | XTAL/EXT2 | Crystal or External Input 2 | This input is either the other pin of the crystal package or the other polarity of the external input. |

For electrical characteristics, see page 175.

## Baud Rate Generator

Programmable Divider

## FEATURES

On chip crystal oscillator or external frequency inputChoice of 16 output frequencies16 asynchronous/synchronous baud ratesDirect UART/USRT/ASTRO/USYNRT compatibilityTTL, MOS compatibilityPIN CONFIGURATION


BLOCK DIAGRAM


## GENERAL DESCRIPTION

The Standard Microsystems COM 5026 Baud Rate Generator/Programmable Divider is an N-channel COPLAMOS MOS/LSI device which, from a single crystal (on-chip oscillator) or input frequency is capable of generating 16 externally selectable frequencies.

The COM 5026 is specifically dedicated to generating the full spectrum of 16 asynchronous/synchronous data communication frequencies as shown in Table 1. One of the sixteen output frequencies is externally selected by four address inputs, as shown in Table 1.

Internal re-programmable ROM allows the generation of other frequencies from other crystal frequencies or input frequencies. The four address inputs may be strobe (150ns) or DC loaded.

The COM 5026 is basically a programmable 15 -stage feedback shift register capable of dividing any modulo up to ( $2^{15}-1$ ).
By using the frequency output, it is possible to generate additional divisions of the master clock frequency by cascading COM 5026's. The frequency output is fed into the XTAL/EXT input on a subsequent device. In this way one crystal or input frequency may be used to generate numerous output frequencies.

The COM 5026 can be driven by either an external crystal or TTL logic level inputs; COM 5026T is driven by TTL logic level inputs only.

## Description of Pin Functions

| Pin No. | Symbol | Name | Function |
| :---: | :---: | :---: | :---: |
| 1 | XTAL/EXT1 | Crystal or External Input 1 | This input is either one pin of the crystal package or one polarity of the external input. |
| 2 | XTALEXT2 | Crystal or External Input 2 | This input is either the other pin of the crystal package or the other polarity of the external input. |
| 3 | Vcc | Power Supply | +5 volt Supply |
| 4,6,8 | NC | No Connection |  |
| 5 | GND | Ground | Ground |
| 7 | Vod | Power Supply | + 12 volt Supply |
| 9 | ST | Strobe | A high-level strobe loads the Input Address ( $A_{A}, A_{B}, A c, A_{D}$ ) into the Input Address register. This input may be strobed or hard wired to a high-level, |
| 10-13 | $A d, A c, A B, A A$ | Input Address | The logic level on these inputs. as shown in Table 1, selects the output frequency. |
| 14 | fout | Output Frequency | This output runs at a frequency as selected by the Input Address. |

For electrical characteristics, see page 175.

## Dual Baud Rate Generator Programmable Divider

## FEATURES

$\square$ On chip crystal oscillator or external frequency input
Choice of $2 \times 16$ output frequencies16 asynchronous/synchronous baud ratesDirect UART/USRT/ASTRO/USYNRT compatibilityFull duplex communication capabilityHigh frequency reference outputTTL, MOS compatibility

PIN CONFIGURATION

| XTAL/EXT1 1 | $\left\{\begin{array}{l} 18 \mathrm{XTAL} / \mathrm{EXT} 2 \\ 17 \mathrm{f}_{\mathrm{T}} \\ 16 \mathrm{~T}_{\wedge} \\ 15 \mathrm{~T}_{\mathrm{B}} \\ 14 \mathrm{~T}_{\mathrm{C}} \\ 13 \mathrm{~T}_{\mathrm{D}} \\ 12 \mathrm{STT} \\ 11 \mathrm{GND} \\ 10 \mathrm{fx} / 4 \end{array}\right.$ |
| :---: | :---: |

BLOCK DIAGRAM


## General Description

The Standard Microsystems COM 5036 Dual Baud Rate Generator/Programmable Divider is an N-channel COPLAMOS ${ }^{\circledR}$ MOS/LSI device which, from a single crystal (on-chip oscillator) or input frequency is capable of generating 32 externally selectable frequencies.

The COM 5036 is specifically dedicated to generating the full spectrum of 16 asynchronous/synchronous data communication frequencies as shown in Table 1. One of the sixteen output frequencies is externally selected by four address inputs, on each of the independent dividers, as shown in Table 1.

Internal re-programmable ROM allows the generation of other frequencies from other crystal frequencies or input frequencies. The four address inputs on each divider section may be strobe ( 150 ns ) or DC loaded. As the COM 5036 is a dual baud rate generator, full duplex (independent receive and transmit frequencies) operation is possible.

The COM 5036 is basically a programmable 15 -stage feedback shift register capable of dividing any modulo up to $\left(2^{15}-1\right)$.

By using one of the frequency outputs it is possible to generate additional divisions of the master clock frequency by cascading COM 5036's. The frequency output is fed into the XTAL/EXT input on a subsequent device. In this way one crystal or input frequency may be used to generate numerous output frequencies.

The COM 5036 can be driven by either an external crystal or TTL logic level inputs; COM 5036T is driven by TTL logic level inputs only.

The COM 5036 provides a high frequency reference output at one-quarter (1/4) the XTAL/EXT input frequency.

## Description of Pin Functions

| Pin No. | Symbol | Name | Function |
| :---: | :---: | :---: | :---: |
| 1 | XTAL/EXT1 | Crystal or External Input 1 | This input is either one pin of the crystal package or one polarity of the external input. |
| 2 | V | Power Supply | + 5 volt supply |
| 3 | $\mathrm{f}_{\mathrm{R}}$ | Receiver Output Frequency | This output runs at a frequency selected by the Receiver divisor select data bits. |
| 4-7 | $\mathrm{R}_{\mathrm{A}}, \mathrm{R}_{3}, \mathrm{R}_{\mathrm{C}}, \mathrm{R}_{\mathrm{D}}$ | Receiver-Divisor Select Data Bits | The logic level on these inputs, as shown in Table 1, selects the receiver output frequency, $f_{R}$. |
| 8 | STR | Strobe-Receiver | A high level input strobe loads the receiver data ( $R_{A}, R_{B}, R_{C}, R_{D}$ ) into the receiver divisor select register. This input may be strobed or hard-wired to a high level. |
| 9 | $V_{D D}$ | Power Supply | + 12 volt supply |
| 10 | $\mathrm{f}_{\mathrm{x}} / 4$ | $\mathrm{f}_{\mathrm{x}} / 4$ | $1 / 4$ crystal/clock frequency reference output. |
| 11 | GND | Ground | Ground |
| 12 | STT | StrobeTransmitter | A high level input strobe loads the transmitter data ( $T_{A}, T_{B}, T_{C}, T_{D}$ ) into the transmitter divisor select register. This input may be strobed or hard-wired to a high level. |
| 13-16 | $\mathrm{T}_{\mathrm{D}}, \mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{B}}, \mathrm{T}_{\mathrm{A}}$ | TransmitterDivider Select Data Bits | The logic level on these inputs, as shown in Table 1, selects the transmitter output frequency, $f_{T}$. |
| 17 | $\mathrm{f}_{\mathrm{T}}$ | Transmitter Output Frequency | This output runs at a frequency selected by the Transmitter divisor select data bits. |
| 18 | XTAL/EXT2 | Crystal or External Input 2 | This input is either the other pin of the crystal package or the other polarity of the external input. |

For electrical characteristics, see page 175.

## Baud Rate Generator <br> Programmable Divider

## FEATURES

On chip crystal oscillator or external frequency inputChoice of 16 output frequencies16 asynchronous/synchronous baud ratesDirect UART/USRT/ASTRO/USYNRT compatibilityHigh frequency reference outputTTL, MOS compatibilityPIN CONFIGURATION


## BLOCK DIAGRAM



## GENERAL DESCRIPTION

The Standard Microsystems COM 5046 Baud Rate Generator/Programmable Divider is an N-channel COPLAMOS ${ }^{\circledR}$ MOS/LSI device which, from a single crystal (on-chip oscillator) or input frequency is capable of generating 16 externally selectable frequencies.

The COM 5046 is specifically dedicated to generating the full spectrum of 16 asynchronous/synchronous data communication frequencies as shown in Table 1. One of the sixteen output frequencies is externally selected by four address inputs; as shown in Table 1.

Internal re-programmable ROM allows the generation of other frequencies from other crystal frequencies or input frequencies. The four address inputs may be strobe (150ns) or DC loaded.

The COM 5046 is basically a programmable 15 -stage feedback shift register capable of dividing any modulo up to $\left(2^{15}-1\right)$.

By using the frequency output, it is possible to generate additional divisions of the master clock frequency by cascading COM 5046's. The frequency output is fed into the XTAL/EXT input on a subsequent device. In this way one crystal or input frequency may be used to generate numerous output frequencies.

The COM 5046 can be driven by either an external crystal or TTL logic level inputs; COM 5046T is driven by TTL logic level inputs only.

The COM 5046 provides a high frequency reference output at one-quarter (1/4) the XTAL/EXT input frequency.

## Description of Pin Functions

| Pin No. | Symbol | Name | Function |
| :---: | :---: | :---: | :---: |
| 1 | XTAL/EXT1 | Crystal or External Input 1 | This input is either one pin of the crystal package or one polarity of the external input. |
| 2 | XTAL/EXT2 | Crystal or External Input 2 | This input is either the other pin of the crystal package or the other polarity of the external input. |
| 3 | Vcc | Power Supply | +5 volt Supply. |
| 4,6 | NC | No Connection |  |
| 5 | GND | Ground | Ground |
| 7 | Vod | Power Supply | + 12 volt Supply. |
| 8 | $\mathrm{f}_{\mathrm{X} / 4}$ | Reference Frequency | High frequency reference output @ (1/4) fin |
| 9 | ST | Strobe | A high-level strobe loads the Input Address ( $A_{A}, A_{B}, A c, A D$ ) into the Input Address register. This input may be strobed or hard wired to a high-level, |
| 10-13 | Ad, $A c, A B, A_{A}$ | Input Address | The logic level on these inputs. as shown in Table 1, selects the output frequency. |
| 14 | fout | Output Frequency | This output runs at a frequency as selected by the Input Address. |

For electrical characteristics, see page 175.

## ELECTRICAL CHARACTERISTICS COM5016, COM5016T, COM5026, COM5026T, COM5036, COM5036T, COM5046, COM5046T <br> MAXIMUM GUARANTEED RATINGS*

```
Operating Temperature Range
    \(.0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\)
    Storage Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . \(55^{\circ} \mathrm{C}\) to \(+150^{\circ} \mathrm{C}\)
    Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . \(325^{\circ} \mathrm{C}\)
    Positive Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 . 18.0 V
    Negative Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -0.3 V
```

*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{Vcc}=+5 \mathrm{~V} \pm 5 \%, \mathrm{VDD}=+12 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS <br> INPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, VII |  |  | 0.8 | V | excluding XTAL inputs |
| High-level, VIH | 2.0 |  | Vcc | V |  |
| OUTPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, Vol |  |  | 0.4 | V | $\mathrm{lot}=1.6 \mathrm{ma}$ |
|  |  |  | 0.5 | V | $1 \mathrm{ol}=3.2 \mathrm{ma}$ |
| High-level, VOH INPUT CURRENT | $\mathrm{Vcc}-1.5$ | 4.0 |  | V | $1 \mathrm{lH}=100 \mu \mathrm{~A}$ |
| Low-level, ItL |  |  | 0.3 | mA | VIN $=$ GND, excluding XTAL inputs |
| INPUT CAPACITANCE |  |  |  |  |  |
| All inputs, Cin |  | 5 | 10 | pf | VIN $=$ GND, excluding XTAL inputs |
| EXT INPUT LOAD |  | 8 | 10 |  | Series 7400 unit loads |
| POWER SUPPLY CURRENT |  |  |  |  |  |
| Icc |  | 28 | 45 | mA |  |
| 100 |  | 12 | 22 | mA |  |
| A.C. CHARACTERISTICS |  |  |  |  | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ |
| CLOCK FREQUENCY |  | 5.0688 |  | MHz | XTAL, EXT |
| PULSE WIDTH |  |  |  |  |  |
| Clock |  |  |  |  | 50\% Duty Cycle $\pm 5 \%$ |
| Strobe | 150 |  | DC | ns | See Note 1. |
| INPUT SET-UP TIME |  |  |  |  |  |
| Address | 50 |  |  | ns | See Note 1. |
| INPUT HOLD TIME |  |  |  |  |  |
| Address | 50 |  |  | ns |  |
| STROBE TO NEW FREQUENCY DELAY |  |  | 3.5 | $\mu \mathrm{s}$ | $=1 / f_{\text {IN }}(18)$ |

Note 1: Input set-up time can be decreased to $\geqslant 0$ ns by increasing the minimum strobe width by 50 ns to a total of 200 ns .




For ROM re-programming SMC has a computer program available whereby the customer need only supply the input frequency and the desired output frequencies. The ROM programming is automatically generated.

Crystal Specifications
User must specify termination (pin, wire, other)
Prefer: HC-18/U or HC-25/U
Frequency - 5.0688 MHz , AT cut
Temperature range $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Series resistance $<50 \Omega$
Series Resonant
Overall tolerance $\pm .01 \%$
or as required

Crystal manufacturers (Partial List) Northern Engineering Laboratories
357 Beloit Street
Burlington, Wisconsin 53105
(414) 763-3591

Bulova Frequency Control Products
61-20 Woodside Avenue
Woodside, New York 11377
(212) 335-6000

CTS Knights Inc.
101 East Church Street
Sandwich, Illinois 60548
(815) 786-8411

Crystek Crystals Corporation
1000 Crystal Drive
Fort Myers, Florida 33901
(813) 936-2109

## APPLICATIONS INFORMATION

Charge pump techniques using the +5 volt power supply can be used to generate the +12 volt power supply required. The +12 volt power supply of figure 1 will supply the 22 milli-amps that is typically required.


Figure 1
VOLTAGE CHARGE PUMP SUPPLY FOR +12v SUPPLY


## Baud Rate Generator Output Frequency Options






## Baud Rate Generator

## Programmable Divider

## FEATURES

On chip crystal oscillator or external frequency input
$\square$ Single +5 v power supply
Choice of 32 output frequencies32 asynchronous/synchronous baud ratesDirect UART/USRT/ASTRO/USYNRT compatibilityRe-programmable ROM via CLASP® technology allows generation of other frequencies
TTL, MOS compatible
1X Clock via fo/16 outputCrystal frequency output via fx and $\mathrm{fx} / 4$ outputs
$\square$ Output disable via FENA

PIN CONFIGURATION


BLOCK DIAGRAM


## General Description

The Standard Microsystems COM 8046 is an enhanced version of the COM 5046 Baud Rate Generator. It is fabricated using SMC's patented COPLAMOS ${ }^{\circledR}$ and CLASP ${ }^{\circledR}$ technologies and employs depletion mode loads, allowing operation from a single +5 v supply.
The standard COM 8046 is specifically dedicated to generating the full spectrum of 16 asynchronous/ synchronous data communication frequencies for 1X, 16X and 32X UART/USRT/ASTRO/USYNRT devices.
The COM 8046 features an internal crystal oscillator which may be used to provide the master reference frequency. Alternatively, an external reference may be supplied by applying complementary TTL level signals to pins 1 and 2. Parts suitable for use only with an external TTL reference are marked COM 8046T. TTL outputs used to drive the COM 8046 or COM 8046T should not be used to drive other TTL inputs, as noise immunity may be compromised due to excessive loading.
The reference frequency ( fx ) is used to provide two high frequency outputs: one at fx and the other at $f x / 4$. The fx/4 output will drive one standard 7400 load, while the fx output will drive two 74LS loads.

The output of the oscillator/buffer is applied to the divider for generation of the output frequency $f_{0}$. The divider is capable of dividing by any integer from 6
to $2^{19}+1$, inclusive. If the divisor is even, the output will be square; otherwise the output will be high longer than it is low by one fx clock period. The output of the divider is also divided internally by 16 and made available at the $\mathrm{f}_{\mathrm{O}} / 16$ output pin. The $\mathrm{f}_{0} / 16$ output will drive one and the $f_{0}$ output will drive two standard 7400 TTL loads. Both the $f_{0}$ and $f_{0} / 16$ outputs can be disabled by supplying a low logic level to the FENA input pin. Note that the FENA input has an internal pull-up which will cause the pin to rise to approximately $\mathrm{V}_{\mathrm{CC}}$ if left unconnected.

The divisor ROM contains 32 divisors, each 19 bits wide, and is fabricated using SMC's unique CLASP ${ }^{\text {® }}$ technology. This process permits reduction of turn-around-time for ROM patterns.
The five divisor select bits are held in an externally strobed data latch. The strobe input is level sensitive: while the strobe is high, data is passed directly through to the ROM. Initiation of a new frequency is effected within $3.5 \mu \mathrm{~s}$ of a change in any of the five divisor select bits; strobe activity is not required. This feature may be disabled through a CLASP ${ }^{8}$ programming option causing new frequency initiation to be delayed until the end of the current $f_{0}$ half-cycle All five data inputs have pull-ups identical to that of the FENA input, while the strobe input has no pull-up.

## Description of Pin Functions

| Pin No. | Symbol | Name | Function |
| :---: | :---: | :---: | :---: |
| 1 | XTAL/EXT1 | Crystal or External Input 1 | This input is either one pin of the crystal package or one polarity of the external input. |
| 2 | XTAL/EXT2 | Crystal or External Input 2 | This input is either the other pin of the crystal package or the other polarity of the external input. |
| 3 | $\mathrm{V}_{\mathrm{cc}}$ | Power Supply | +5 volt supply |
| 4 | $f_{x}$ | $\mathrm{f}_{\mathrm{x}}$ | Crystal/clock frequency reference output |
| 5 | GND | Ground | Ground |
| 6 | $\mathrm{f}_{0} / 16$ | $\mathrm{f}_{\mathrm{O}} / 16$ | 1X clock output |
| 7 | FENA | Enable | A low level at this input causes the $f_{0}$ and $f_{0} / 16$ outputs to be held high. An open or a high level at the FENA input enables the $\mathrm{f}_{\mathrm{O}}$ and $\mathrm{f}_{\mathrm{O}} / 16$ outputs. |
| 8 | E | E | Most significant divisor select data bit. An open at this input is equivalent to a logic high. |
| 9 | NC | NC | No connection |
| 10 | $\mathrm{f}_{\mathrm{x}} / 4$ | $\mathrm{f}_{\mathrm{x}} / 4$ | $1 / 4$ crystal/clock frequency reference output. |
| 11 | ST | Strobe | Divisor select data strobe. Data is sampled when this input is high, preserved when this input is low. |
| 12-15 | D, C,B,A | D,C,B,A | Divisor select data bits. $A=$ LSB. An open circuit at these inputs is equivalent to a logic high. |
| 16 | $\mathrm{f}_{\mathrm{O}}$ | $\mathrm{f}_{0}$ | 16X clock output |

For electrical characteristics, see page 189.

## Dual Baud Rate Generator Programmable Divider

## FEATURES

On chip crystal oscillator or external frequency input
Single $+5 v$ power supplyChoice of $2 \times 16$ output frequencies16 asynchronous/synchronous baud ratesDirect UART/USRT/ASTRO/USYNRT compatibilityFull duplex communication capabilityRe-programmable ROM via CLASP ${ }^{\circledR}$
technology allows generation of other frequenciesTTL, MOS compatibilityCompatible with COM 5016

PIN CONFIGURATION


BLOCK DIAGRAM


## General Description

The Standard Microsystem's COM 8116 is an enhanced version of the COM 5016 Dual Baud Rate Generator. It is fabricated using SMC's patented COPLAMOS ${ }^{\circledR}$ and CLASP ${ }^{\circledR}$ technologies and employs depletion mode loads, allowing operation from a single $+5 v$ supply.

The standard COM 8116 is specifically dedicated to generating the full spectrum of 16 asynchronous/ synchronous data communication frequencies for 16X UART/USRT devices. A large number of the frequencies available are also useful for 1 X and 32 X ASTRO/USYNRT devices.

The COM 8116 features an internal crystal oscillator which may be used to provide the master reference frequency. Alternatively, an external reference may be supplied by applying complementary TTL level signals to pins 1 and 18. Parts suitable for use only with an external TTL reference are marked COM 8116T. TTL outputs used to drive the COM 8116 or COM 8116 T XTAL/EXT inputs should not be used to drive
other TTL inputs, as noise immunity may be compromised due to excessive loading.
The output of the oscillator/buffer is applied to the dividers for generation of the output frequencies $f_{T}, f_{R}$. The dividers are capable of dividing by any integer from 6 to $2^{19}+1$, inclusive. If the divisor is even, the output will be square; otherwise the output will be high longer than it is low by one fx clock period.
Each of the two divisor ROMs contains 16 divisors, each 19 bits wide, and is fabricated using SMC's unique CLASP ${ }^{\circledR}$ technology allowing up to 32 different divisors on custom parts. This process permits reduction of turn-around time for ROM patterns. Each group of four divisor select bits is held in an externally strobed data latch. The strobe input is level sensitive: while the strobe is high, data is passed directly through to the ROM. Initiation of a new frequency is effected within $3.5 \mu \mathrm{~s}$ of a change in any of the four divisor select bits (strobe activity is not required). The divisor select inputs have pull-up resistors; the strobe inputs do not.

## Description of Pin Functions

| Pin No. | Symbol | Name | Function |
| :---: | :---: | :---: | :---: |
| 1 | XTAL/EXT1 | Crystal or External Input 1 | This input is either one pin of the crystal package or one polarity of the external input. |
| 2 | V | Power Supply | + 5 volt supply |
| 3 | $\mathrm{f}_{\mathrm{R}}$ | Receiver Output Frequency | This output runs at a frequency selected by the Receiver divisor select data bits. |
| 4-7 | $\mathrm{R}_{\mathrm{A}}, \mathrm{R}_{\mathrm{B}}, \mathrm{R}_{\mathrm{C}}, \mathrm{R}_{\mathrm{D}}$ | Receiver-Divisor Select Data Bits | The logic level on these inputs, as shown in Table 1, selects the receiver output frequency, $f_{R}$. |
| 8 | STR | Strobe-Receiver | A high level input strobe loads the receiver data ( $\mathbf{R}_{A}, R_{B}, R_{C}, R_{D}$ ) into the receiver divisor select register. This input may be strobed or hard-wired to a high level. |
| 9 | NC | No Connection |  |
| 10 | NC | No Connection |  |
| 11 | GND | Ground | Ground |
| 12 | STT | StrobeTransmitter | A high level input strobe loads the transmitter data ( $T_{A}, T_{B}, T_{C}, T_{D}$ ) into the transmitter divisor select register. This input may be strobed or hard-wired to a high level. |
| 13-16 | $T_{D}, T_{C}, T_{B}, T_{A}$ | TransmitterDivisor Select Data Bits | The logic level on these inputs, as shown in Table 1, selects the transmitter output frequency, $\mathrm{f}_{\mathrm{T}}$. |
| 17 | $\mathrm{f}_{\mathrm{T}}$ | Transmitter Output Frequency | This output runs at a frequency selected by the Transmitter divisor select data bits. |
| 18 | XTAL/EXT2 | Crystal or External Input 2 | This input is either the other pin of the crystal package or the other polarity of the external input. |

For electrical characteristics, see page 189.

## Baud Rate Generator

## Programmable Divider

## FEATURES

On chip crystal oscillator or external frequency inputSingle +5 v power supplyChoice of 16 output frequencies16 asynchronous/synchronous baud ratesDirect UART/USRT/ASTRO/USYNRT compatibilityRe-programmable ROM via CLASP ${ }^{\circledR}$ technology allows generation of other frequenciesTTL, MOS compatibilityCompatible with COM 5026PIN CONFIGURATION


## BLOCK DIAGRAM



## General Description

The Standard Microsystem's COM 8126 is an enhanced version of the COM 5026 Baud Rate Generator. It is fabricated using SMC's patented COPLAMOS ${ }^{\circledR}$ and CLASP ${ }^{\circledR}$ technologies and employs depletion mode loads, allowing operation from a single $+5 v$ supply.
The standard COM 8126 is specifically dedicated to generating the full spectrum of 16 asynchronous/ synchronous data communication frequencies for 16X UART/USRT devices. A large number of the frequencies available are also useful for 1 X and 32 X ASTRO/USYNRT devices.

The COM 8126 features an internal crystal oscillator which may be used to provide the master reference frequency. Alternatively, an external reference may be supplied by applying complementary TTL level signals to pins 1 and 2. Parts suitable for use only with an external TTL reference are marked COM 8126T. TTL outputs used to drive the COM 8126 or COM 8126T XTAL/EXT inputs should not be used to drive other TTL inputs, as noise immunity may be com-
promised due to excessive loading.
The output of the oscillator/buffer is applied to the divider for generation of the output frequency. The divider is capable of dividing by any integer from 6 to $2^{19}+1$, inclusive. If the divisor is even, the output will be square; otherwise the output will be high longer than it is low by one fx clock period.

The divisor ROM contains 16 divisors, each 19 bits wide, and is fabricated using SMC's unique CLASP ${ }^{\text {® }}$ technology. This process permits reduction of turnaround time for ROM patterns. The four divisor select bits are held in an externally strobed data latch. The strobe input is level sensitive: while the strobe is high, data is passed directly through to the ROM. Initiation of a new frequency is effected within $3.5 \mu \mathrm{~s}$ of a change in any of the four divisor select bits (strobe activity is not required). This feature may be disabled through a CLASP ${ }^{\circledR}$ programming option causing new frequency initiation to be delayed until the end of the current $f_{\text {OUT }}$ half-cycle. The divisor select inputs have pull-up resistors; the strobe input does not.

## Description of Pin Functions

| Pin No. | Symbol | Name | Function |
| :---: | :---: | :---: | :---: |
| 1 | XTAL/EXT1 | Crystal or External Input 1 | This input is either one pin of the crystal package or one polarity of the external input. |
| 2 | XTAL/EXT2 | Crystal or External Input 2 | This input is either the other pin of the crystal package or the other polarity of the external input. |
| 3 | $V_{c c}$ | Power Supply | +5 volt supply |
| 4,6,7,8 | NC | No Connection |  |
| 5 | GND | Ground | Ground |
| 9 | ST | Strobe | A high level strobe loads the input data (A, B, C, D) into the input divisor select register. This input may be strobed or hard-wired to a high level. |
| 10-13 | D,C, B, A | Divisor Select Data Bits | The logic level on these inputs as shown in Table 1, selects the output frequency. |
| 14 | $\mathrm{f}_{\text {OUT }}$ | Output Frequency | This output runs at a frequency selected by the divisor select data bits. |

For electrical characteristics, see page 189.

## Dual Baud Rate Generator <br> Programmable Divider

## FEATURES

On chip crystal oscillator or external frequency input
Single $+5 v$ power supply
Choice of $2 \times 16$ output frequencies16 asynchronous/synchronous baud rates
Direct UART/USRT/ASTRO/USYNRT compatibilityFull duplex communication capability
High frequency reference outputRe-programmable ROM via CLASP® ${ }^{\circledR}$ technology allows generation of other frequencies
TTL, MOS compatibility
Compatible with COM 5036

PIN CONFIGURATION

|  | $\left\{\begin{array}{l} 18 \text { XTAL/EXT2 } \\ 17 \mathrm{f}_{\mathrm{T}} \\ 16 \mathrm{~T}_{\Lambda} \\ 15 \mathrm{~T}_{\mathrm{B}} \\ 14 \mathrm{~T}_{\mathrm{C}} \\ 13 \mathrm{~T}_{\mathrm{D}} \\ 12 \mathrm{STT} \\ 11 \mathrm{GND} \\ 10 \mathrm{fx} / 4 \end{array}\right.$ |
| :---: | :---: |

BLOCK DIAGRAM


## General Description

The Standard Microsystem's COM 8136 is an enhanced version of the COM 5036 Dual Baud Rate Generator. It is fabricated using SMC's patented COPLAMOS ${ }^{\circledR}$ and CLASP ${ }^{\circledR}$ technologies and employs depletion mode loads, allowing operation from a single $+5 v$ supply.
The standard COM 8136 is specifically dedicated to generating the full spectrum of 16 asynchronous/ synchronous data communication frequencies for 16X UART/USRT devices. A large number of the frequencies available are also useful for 1X and 32X ASTRO/USYNRT devices.
The COM 8136 features an internal crystal oscillator which may be used to provide the master reference frequency. Alternatively, an external reference may be supplied by applying complementary TTL level signals to pins 1 and 18. Parts suitable for use only with an external TTL reference are marked COM 8136T. TTL outputs used to drive the COM 8136 or COM 8136T XTAL/EXT inputs should not be used to drive other TTL inputs, as noise immunity may be compromised due to excessive loading.

The output of the oscillator/buffer is applied to the dividers for generation of the output frequencies $f_{T}, f_{R}$. The dividers are capable of dividing by any integer from 6 to $2^{19}+1$, inclusive. If the divisor is even, the output will be square; otherwise the output will be high longer than it is low by one $f x$ clock period.
The reference frequency ( fx ) is used to provide a high frequency output at $\mathrm{fx} / 4$.
Each of the two divisor ROMs contains 16 divisors, each 19 bits wide, and is fabricated using SMC's unique CLASP ${ }^{\circledR}$ technology allowing up to 32 different divisors on custom parts. This process permits reduction of turn-around time for ROM patterns. Each group of four divisor select bits is held in an externally strobed data latch. The strobe input is level sensitive: while the strobe is high, data is passed directly through to the ROM. Initiation of a new frequency is effected within $3.5 \mu \mathrm{~s}$ of a change in any of the four divisor select bits (strobe activity is not required). The divisor select inputs have pull-up resistors; the strobe inputs do not.

## Description of Pin Functions

| Pin No. | Symbol | Name | Function |
| :---: | :---: | :---: | :---: |
| 1 | XTAL/EXT1 | Crystal or External Input 1 | This input is either one pin of the crystal package or one polarity of the external input. |
| 2 | $V_{C C}$ | Power Supply | + 5 volt supply |
| 3 | $\mathrm{f}_{\mathrm{R}}$ | Receiver Output Frequency | This output runs at a frequency selected by the Receiver divisor select data bits. |
| 4-7 | $\mathrm{R}_{\mathrm{A}}, \mathrm{R}_{\mathrm{B}}, \mathrm{R}_{\mathrm{C}}, \mathrm{R}_{\mathrm{D}}$ | Receiver-Divisor Select Data Bits | The logic level on these inputs, as shown in Table 1, selects the receiver output frequency, $f_{R}$. |
| 8 | STR | Strobe-Receiver | A high level input strobe loads the receiver data ( $R_{A}, R_{B}, R_{C}, R_{D}$ ) into the receiver divisor select register. This input may be strobed or hard-wired to a high level. |
| 9 | NC | No Connection |  |
| 10 | $\mathrm{f}_{\mathrm{x}} / 4$ | $\mathrm{f}_{\mathrm{x}} / 4$ | 1/4 crystal/clock frequency reference output. |
| 11 | GND | Ground | Ground |
| 12 | STT | StrobeTransmitter | A high level input strobe loads the transmitter data ( $T_{A}, T_{B}, T_{C}, T_{D}$ ) into the transmitter divisor select register. This input may be strobed or hard-wired to a high level. |
| 13-16 | $\mathrm{T}_{\mathrm{D}}, \mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{B}}, \mathrm{T}_{\mathrm{A}}$ | TransmitterDivider <br> Select Data Bits | The logic level on these inputs, as shown in Table 1, selects the transmitter output frequency, $\mathrm{f}_{\mathrm{T}}$. |
| 17 | $\mathrm{f}_{T}$ | Transmitter Output Frequency | This output runs at a frequency selected by the Transmitter divisor select data bits. |
| 18 | XTAL/EXT2 | Crystal or External Input 2 | This input is either the other pin of the crystal package or the other polarity of the external input. |

For electrical characteristics, see page 189.

## Baud Rate Generator <br> Programmable Divider

## FEATURES

$\square$ On chip crystal oscillator or external frequency inputSingle +5 v power supplyChoice of 16 output frequencies16 asynchronous/synchronous baud ratesDirect UART/USRT/ASTRO/USYNRT compatibilityHigh frequency reference outputRe-programmable ROM via CLASP® technology allows generation of other frequencies
TTL, MOS compatibility
$\square$ Compatible with COM 5046

PIN CONFIGURATION


## BLOCK DIAGRAM



## General Description

The Standard Microsystem's COM 8146 is an enhanced version of the COM 5046 Baud Rate Generator. It is fabricated using SMC's patented COPLAMOS ${ }^{\circledR}$ and CLASP ${ }^{\circledR}$ technologies and employs depletion mode loads, allowing operation from a single $+5 v$ supply.
The standard COM 8146 is specifically dedicated to generating the full spectrum of 16 asynchronous/ synchronous data communication frequencies for 16X UART/USRT devices. A large number of the frequencies available are also useful for 1 X and 32 X ASTRO/USYNRT devices.
The COM 8146 features an internal crystal oscillator which may be used to provide the master reference frequency. Alternatively, an external reference may be supplied by applying complementary TTL level signals to pins 1 and 2. Parts suitable for use only with an external TTL reference are marked COM 8146T. TTL outputs used to drive the COM 8146 or COM $8146 T$ XTAL/EXT inputs should not be used to drive other TTL inputs, as noise immunity may be compromised due to excessive loading.

The output of the oscillator/buffer is applied to the divider for generation of the output frequency. The divider is capable of dividing by any integer from 6 to $2^{19}+1$, inclusive. If the divisor is even, the output will be square; otherwise the output will be high longer than it is low by one fx clock period.
The reference frequency ( fx ) is used to provide a high frequency output at $f x / 4$.
The divisor ROM contains 16 divisors, each 19 bits wide, and is fabricated using SMC's unique CLASP ${ }^{\circledR}$ technology. This process permits reduction of turnaround time for ROM patterns. The four divisor select bits are held in an externally strobed data latch. The strobe input is level sensitive: while the strobe is high, data is passed directly through to the ROM. Initiation of a new frequency is effected within $3.5 \mu \mathrm{~s}$ of a change in any of the four divisor select bits (strobe activity is not required). This feature may be disabled through a CLASP ${ }^{\circledR}$ programming option causing new frequency initiation to be delayed until the end of the current fout half-cycle. The divisor select inputs have pull-up resistors; the strobe input does not.

## Description of Pin Functions

| Pin No. | Symbol | Name | Function |
| :---: | :---: | :---: | :---: |
| 1 | XTAL/EXT1 | Crystal or External Input 1 | This input is either one pin of the crystal package or one polarity of the external input. |
| 2 | XTAL/EXT2 | Crystal or External Input 2 | This input is either the other pin of the crystal package or the other polarity of the external input. |
| 3 | $\mathrm{V}_{\mathrm{cc}}$ | Power Supply | + 5 volt supply |
| 4,6,7 | NC | No Connection |  |
| 5 | GND | Ground | Ground |
| 8 | $\mathrm{f}_{\mathrm{x}} / 4$ | $\mathrm{f}_{\mathrm{x}} / 4$ | 1/4 crystal/clock frequency reference output. |
| 9 | ST | Strobe | A high level strobe loads the input data ( $A, B, C, D$ ) into the input divisor select register. This input may be strobed or hard-wired to a high level. |
| 10-13 | D, C,B,A | Divisor Select Data Bits | The logic level on these inputs as shown in Table 1, selects the output frequency. |
| 14 | fout | Output Frequency | This output runs at a frequency selected by the divisor select data bits. |

For electrical characteristics, see page 189.

## ELECTRICAL CHARACTERISTICS COM8046, COM8046T, COM8116, COM8116T, COM8126, COM8126T, COM8136, COM8136T, COM8146, COM8146T <br> MAXIMUM GUARANTEED RATINGS


$+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin. with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0 V
Negative Voltage on any Pin. with respect to ground . ................................................................. . 0.3 V
Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.
ELECTRICAL CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{VcC}=+5 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS |  |  |  |  |  |
| INPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, VIL |  |  | 0.8 | V |  |
| High-level, $\mathrm{V}_{\text {IH }}$ | 2.0 |  |  | V | excluding XTAL inputs |
| OUTPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, Vo |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$, for $\mathrm{f}_{\mathrm{X}} / 4, \mathrm{f}_{\mathrm{O}} / 16$ |
|  |  |  | 0.4 | $V$ | $\mathrm{l}_{\mathrm{OL}}=3.2 \mathrm{~mA}$, for $\mathrm{f}_{\mathrm{O}}, \mathrm{f}_{\mathrm{R}}, \mathrm{f}_{\mathrm{T}}$ |
|  |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=0.8 \mathrm{~mA}$, for $\mathrm{f}_{\mathrm{X}}$ |
| High-level, $\mathrm{V}_{\text {OH }}$ | 3.5 |  |  | V | $\mathrm{I}_{\text {он }}=-100 \mu \mathrm{~A}$; for $\mathrm{f}_{\mathrm{x}}, \mathrm{I}_{\text {он }}=-50 \mu \mathrm{~A}$ |
| INPUT CURRENT |  |  |  |  |  |
| INPUT CAPACITANCE All inputs, $\mathrm{C}_{\text {IN }}$ |  | 5 | 10 | pF | $V_{1 H}=G N D$, excluding XTAL inputs |
|  |  |  |  |  |  |
| POWER SUPPLY CURRENT Icc |  |  | 50 | mA |  |
| A.C. CHARACTERISTICS |  |  |  |  | $\mathrm{T}_{\wedge}=+25^{\circ} \mathrm{C}$ |
| CLOCK FREQUENCY, fin | 0.01 |  | 7.0 | MHz | XTAL/EXT, 50\% Duty Cycle $\pm 5 \%$ COM 8046, COM 8126, COM 8146 |
|  | 0.01 |  | 5.1 | MHz | XTAL/EXT, $50 \%$ Duty Cycle $\pm 5 \%$ COM 8116, COM 8136 |
| STROBE PULSE WIDTH, tpw INPUT SET-UP TIME tos | 150 |  | DC | ns |  |
|  | 200 |  |  | ns |  |
| $\underset{\substack{\text { In } \\ \text { toh }}}{\text { HOUT }}$ HOLD TIME | 50 |  |  | ns |  |
| STROBE TO NEW FREQUENCY DELAY |  |  | 3.5 | $\mu \mathrm{S}$ | @ $\mathrm{f}_{\mathrm{x}}=5.0 \mathrm{MHz}$ |




For ROM re-programming SMC has a computer program available whereby the customer need only supply the input frequency and the desired output frequencies.

The ROM programming is automatically generated.

Crystal Specifications
User must specify termination (pin, wire, other)
Prefer: HC-18/U or HC-25/U
Frequency - 5.0688 MHz , AT cut
Temperature range $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Series resistance $<50 \Omega$
Series Resonant
Overall tolerance $\pm .01 \%$ or as required

## Crystal manufacturers (Partial List) Northern Engineering Laboratories 357 Beloit Street Burlington, Wisconsin 53105 (414) 763-3591 <br> Bulova Frequency Control Products <br> 61-20 Woodside Avenue Woodside, New York 11377 (212) 335-6000 CTS Knights Inc. 101 East Church Street Sandwich, Illinois 60548 (815) 786-8411 Crystek Crystals Corporation 1000 Crystal Drive <br> Fort Myers, Florida 33901

## COM 8046 COM 8046T

Table 2
REFERENCE FREQUENCY $=5.068800 \mathrm{MHz}$

| Divisor Select EDCBA | Desired Baud Rate | Clock Factor | Desired Frequency (KHz) | Divisor | Actual Baud Rate | Actual Frequency (KHz) | Deviation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00000 | 50.00 | 32 X | 1.60000 | 3168 | 50.00 | 1.600000 | 0.0000\% |
| 00001 | 75.00 | 32 X | 2.40000 | 2112 | 75.00 | 2.400000 | 0.0000\% |
| 00010 | 110.00 | 32 X | 3.52000 | 1440 | 110.00 | 3.520000 | 0.0000\% |
| 00011 | 134.50 | 32 X | 4.30400 | 1177 | 134.58 | 4.306542 | 0.0591\% |
| 00100 | 150.00 | 32 X | 4.80000 | 1056 | 150.00 | 4.800000 | 0.0000\% |
| 00101 | 200.00 | 32X | 6.40000 | 792 | 200.00 | 6.400000 | 0.0000\% |
| 00110 | 300.00 | 32X | 9.60000 | 528 | 300.00 | 9.600000 | 0.0000\% |
| 00111 | 600.00 | 32 X | 19.20000 | 264 | 600.00 | 19.200000 | 0.0000\% |
| 01000 | 1200.00 | 32 X | 38.40000 | 132 | 1200.00 | 38.400000 | 0.0000\% |
| 01001 | 1800.00 | 32 X | 57.60000 | 88 | 1800.00 | 57.600000 | 0.0000\% |
| 01010 | 2400.00 | 32X | 76.80000 | 66 | 2400.00 | 76.800000 | 0.0000\% |
| 01011 | 3600.00 | 32 X | 115.20000 | 44 | 3600.00 | 115.200000 | 0.0000\% |
| 01100 | 4800.00 | 32X | 153.60000 | 33 | 4800.00 | 153.600000 | 0.0000\% |
| 01101 | 7200.00 | 32X | 230.40000 | 22 | 7200.00 | 230.400000 | 0.0000\% |
| 01110 | 9600.00 | 32X | 307.20000 | 16 | 9900.00 | 316.800000 | 3.1250\% |
| 01111 | 19200.00 | 32 X | 614.40000 | 8 | 19800.00 | 633.600000 | 3.1250\% |
| 10000 | 50.00 | 16X | 0.80000 | 6336 | 50.00 | 0.800000 | 0.0000\% |
| 10001 | 75.00 | 16X | 1.20000 | 4224 | 75.00 | 1.200000 | 0.0000\% |
| 10010 | 110.00 | 16X | 1.76000 | 2880 | 110.00 | 1.760000 | 0.0000\% |
| 10011 | 134.50 | 16X | 2.15200 | 2355 | 134.52 | 2.152357 | 0.0166\% |
| 10100 | 150.00 | 16X | 2.40000 | 2112 | 150.00 | 2.400000 | 0.0000\% |
| 10101 | 300.00 | 16X | 4.80000 | 1056 | 300.00 | 4.800000 | 0.0000\% |
| 10110 | 600.00 | 16X | 9.60000 | 528 | 600.00 | 9.600000 | 0.0000\% |
| 10111 | 1200.00 | 16X | 19.20000 | 264 | 1200.00 | 19.200000 | 0.0000\% |
| 11000 | 1800.00 | 16X | 28.80000 | 176 | 1800.00 | 28.800000 | 0.0000\% |
| 11001 | 2000.00 | 16X | 32.00000 | 158 | 2005.06 | 32.081013 | 0.2532\% |
| 11010 | 2400.00 | 16X | 38.40000 | 132 | 2400.00 | 38.400000 | 0.0000\% |
| 11011 | 3600.00 | 16X | 57.60000 | 88 | 3600.00 | 57.600000 | 0.0000\% |
| 11100 | 4800.00 | 16X | 76.80000 | 66 | 4800.00 | 76.800000 | 0.0000\% |
| 11101 | 7200.00 | 16X | 115.20000 | 44 | 7200.00 | 115.200000 | 0.0000\% |
| 11110 | 9600.00 | 16X | 153.60000 | 33 | 9600.00 | 153.600000 | 0.0000\% |
| 11111 | 19200.00 | 16X | 307.20000 | 16 | 19800.00 | 316.800000 | 3.1250\% |

# COM 8116 COM $8116 T$ COM 8136 COM 8136T COM 8126 COM 8126T COM 8146 COM $8146 T$ 

Table 1
REFERENCE FREQUENCY $=5.068800 \mathrm{MHZ}$ (STANDARD PART)

| Divisior <br> Select DCBA | Desired Baud Rate | Clock <br> Factor | Desired Frequency (KHz) | Divisor | Actual Baud Rate | Actual Frequency (KHz) | Deviation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0000 | 50.00 | 16X | 0.80000 | 6336 | 50.00 | 0.800000 | 0.0000\% |
| 0001 | 75.00 | 16X | 1.20000 | 4224 | 75.00 | 1.200000 | 0.0000\% |
| 0010 | 110.00 | 16X | 1.76000 | 2880 | 110.00 | 1.760000 | 0.0000\% |
| 0011 | 134.50 | 16X | 2.15200 | 2355 | 134.52 | 2.152357 | 0.0166\% |
| 0100 | 150.00 | 16X | 2.40000 | 2112 | 150.00 | 2.400000 | 0.0000\% |
| 0101 | 300.00 | 16X | 4.80000 | 1056 | 300.00 | 4.800000 | 0.0000\% |
| 0110 | 600.00 | 16X | 9.60000 | 528 | 600.00 | 9.600000 | 0.0000\% |
| 0111 | 1200.00 | 16X | 19.20000 | 264 | 1200.00 | 19.200000 | 0.0000\% |
| 1000 | 1800.00 | 16X | 28.80000 | 176 | 1800.00 | 28.800000 | 0.0000\% |
| 1001 | 2000.00 | 16X | 32.00000 | 158 | 2005.06 | 32.081013 | 0.2532\% |
| 1010 | 2400.00 | 16X | 38.40000 | 132 | 2400.00 | 38.400000 | 0.0000\% |
| 1011 | 3600.00 | 16X | 57.60000 | 88 | 3600.00 | 57.600000 | 0.0000\% |
| 1100 | 4800.00 | 16X | 76.80000 | 66 | 4800.00 | 76.800000 | 0.0000\% |
| 1101 | 7200.00 | 16X | 115.20000 | 44 | 7200.00 | 115.200000 | 0.0000\% |
| 1110 | 9600.00 | 16X | 153.60000 | 33 | 9600.00 | 153.600000 | 0.0000\% |
| 1111 | 19200.00 | 16X | 307.20000 | 16 | 19800.00 | 316.800000 | 3.1250\% |

Table 2
REFERENCE FREQUENCY $=4.915200 \mathrm{MHz}$
(COM81_--5)

| $\begin{aligned} & \text { Divisor } \\ & \text { Select } \\ & \text { DCBA } \end{aligned}$ | Desired Baud Rate | Clock <br> Factor | Desired Frequency (KHz) | Divisor | Actual Baud Rate | Actual Frequency (KHz) | Deviation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0000 | 50.00 | 16X | 0.80000 | 6144 | 50.00 | 0.800000 | 0.0000\% |
| 0001 | 75.00 | 16X | 1.20000 | 4096 | 75.00 | 1.200000 | 0.0000\% |
| 0010 | 110.00 | 16X | 1.76000 | 2793 | 109.93 | 1.758983 | 0.0100\% |
| 0011 | 134.50 | 16X | 2.15200 | 2284 | 134.50 | 2.152000 | 0.0000\% |
| 0100 | 150.00 | 16X | 2.40000 | 2048 | 150.00 | 2.400000 | 0.0000\% |
| 0101 | 300.00 | 16X | 4.80000 | 1024 | 300.00 | 4.800000 | 0.0000\% |
| 0110 | 600.00 | 16X | 9.60000 | 512 | 600.00 | 9.600000 | 0.0000\% |
| 0111 | 1200.00 | 16X | 19.20000 | 256 | 1200.00 | 19.200000 | 0.0000\% |
| 1000 | 1800.00 | 16X | 28.80000 | 171 | 1796.49 | 28.743859 | 0.1949\% |
| 1001 | 2000.00 | 16X | 32.00000 | 154 | 1994.81 | 31.916883 | 0.2597\% |
| 1010 | 2400.00 | 16X | 38.40000 | 128 | 2400.00 | 32.000000 | 0.0000\% |
| 1011 | 3600.00 | 16X | 57.60000 | 85 | 3614.11 | 57.825882 | 0.3921\% |
| 1100 | 4800.00 | 16X | 76.80000 | 64 | 4800.00 | 76.800000 | 0.0000\% |
| 1101 | 7200.00 | 16x | 115.20000 | 43 | 7144.19 | 114.306976 | 0.7751\% |
| 1110 | 9600.00 | 16X | 153.60000 | 32 | 9600.00 | 153.600000 | 0.0000\% |
| 1111 | 19200.00 | 16X | 307.20000 | 16 | 19200.00 | 307.200000 | 0.0000\% |



Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.
(amumil CRT Display

## timing controllers

| Part Nrumber | Description | Features | Display Format | Max Clock | Power Supplies | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CRT 5027 | provides all of the timing and control for interlaced and non-interlaced CRT display |  | programmable | 4 MHz | +6,+12 | 40 DIP | 197-204 |
| CRT 5037 |  | balanced beam fnterlace | programmable | 4 MHz | +5, +12 | 40 DIP | 197-204 |
| CRT 5047 ${ }^{(3)}$ |  | fixed format | $\begin{aligned} & 80 \text { column } \\ & 24 \text { row } \end{aligned}$ | 4 MHz | $+5,+12$ | 40 DIP | 205-206 |
| CRT 5057 |  | line-lock | programmable | 4 MHz | $+5,+12$ | 40 DIP | 197-204 |
| CRT 9007 | CRT video processor and controller | sequential or rowtable driven memory | programmable | 4 MHz | +5 | 40 DIP | 207-226 |
| CRT 96364A/B | complete CRT processor | on-chip cursor and write control | $\begin{aligned} & 64 \text { column } \\ & 16 \text { row } \\ & \hline \end{aligned}$ | 1.6 MHz | +5 | 28 DIP | 227-234 |

## VDACTM DISPLAY CONTROLLERS

| Part Number | Description | Display | Attributes | Max Clock | Power Supply | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CRT 8002H ${ }^{(2,2,3)}$ | Provides complete display and attributes control for alphanumertc and graphics display. Consists of $7 \times 11 \times 128$ character generator, video shift register, latches, graphics and attributes circuits. | $7 \times 11$ dot matrix. wide graphics, thin graphics, on-chip cursor | reverse video <br> blank <br> blink <br> underline <br> strike-thru | 25 MHz | +5 | 28 DIP | 247-254 |
| CRT 8002A ${ }^{(23)}$ |  |  |  | 20 MHz |  |  | 235-244 |
| CRT 80023 ${ }^{(2,3)}$ |  |  |  | 15 MHz |  |  | 235-244 |
| CRT 80020 ${ }^{(2,3)}$ |  |  |  | 10 MHz |  |  | 235-244 |

## CHARACTER GENFRATORS

| Part ITamber | Description | Max Frequency | Power 8upply | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CRT 7004A (3,4) | $7 \times 11 \times 128$ character generator, latches, video shift register | 20 MHz | $+5$ | 24 DIP | 255-260 |
| CRT 7004B (3,4) |  | 15 MHz |  |  |  |
| CRT 7004C (3,4) |  | 10 MHz |  |  |  |

## ROW BUFFWR

| Part ITumber | Description | $\begin{gathered} \text { Max } \\ \text { Row Length } \end{gathered}$ | Power Supply | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CRT 9006-83 | 8 bit wide serial cascadable single row buffer memory for CRT or printer | 83 characters | +5 | 24 DIP | 261-266 |
| CRT 9006-135 |  | 135 characters |  |  |  |
| CRT 9212 | 8 bit wide serial cascadable double row buffer memory for CRT or printer | 135 characters | $+5$ | 28 DIP | 267-272 |

## VIDFO ATTRIBUTFS CONTROL工FRS

| Part Number | Description | Display | Attributes | Max <br> Clock | Powar Supply | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CRT 8021 | Provides attributes and graphics control for CRT VIdeo displays | Alphanumeric, wide graphics, thingraphics, on-chip cursor | Reverse video, blank, blink, underline, strike-thru | 20 MHz | +5 | 28 DIP | 273-280 |
| CRT 9021B | Provides attributes and graphics control for CRT video displays | Alphanumeric, wide graphics, thin graphics, on-chip cursor, double height, double width | Reverse video, blank, blink, underline, intensity | 28.5 MHz | +5 | 28 DIP | 281-292 |

(1) For future release
(3) May be custom mask programmed
(2) Also available as CRT 8002A,B,C-001 Katakana
(4) Also available as CRT 7004A,B,C-003 5X7 dot matrix

## FEATURES

$\square$ Fully Programmable Display Format Characters per data row (1-200)
Data rows per frame (1-64)
Raster scans per data row (1-16)
$\square$ Programmable Monitor Sync Format
Raster Scans/Frame (256-1023)
"Front Porch"
Sync Width
"Back Porch"
Interlace/Non-Interlace
Vertical Blanking
$\square$ Lock Line Input (CRT 5057)Direct Outputs to CRT Monitor Horizontal Sync
Vertical Sync
Composite Sync (CRT 5027, CRT 5037)

## Blanking

Cursor coincidence
$\square$ Programmed via:
Processor data bus
External PROM
Mask Option ROMStandard or Non-Standard CRT Monitor Compatible
Refresh Rate: $60 \mathrm{~Hz}, 50 \mathrm{~Hz}, \ldots$
Scrolling
Single Line
Multi-LineCursor Position RegistersCharacter Format: $5 \times 7,7 \times 9, \ldots$
Programmable Vertical Data Positioning
Balanced Beam Current Interlace (CRT 5037)
Graphics Compatible

PIN CONFIGURATION

$\square$ Split-Screen Applications Horizontal
VerticalTTL CompatibilityUUS Oriented High Speed Operation
$\square$ COPLAMOS* N-Channel Silicon Gate Technology
Compatible with CRT 8002 VDAC ${ }^{\text {M }}$Compatible with CRT 7004

## GENERAL DESCRIPTION

The CRT Video Timer and Controller Chip (VTAC) ${ }^{\text { }}$ is a user programmable 40-pin COPLAMOS® nchannel MOS/LSI device containing the logic functions required to generate all the timing signals for the presentation and formatting of interlaced and non-interlaced video data on a standard or non-standard CRT monitor.

With the exception of the dot counter, which may be clocked at a video frequency above 25 MHz and therefore not recommended for MOS implementation, all frame formatting, such as horizontal, vertical, and composite sync, characters per data row, data rows per frame, and raster scans per data row and per frame are totally user programmable. The data row counter has been designed to facilitate scrolling.

Programming is effected by loading seven 8 bit control registers directly off an 8 bit bidirectional data bus. Four register address lines and a chip select line provide complete microprocessor compatibility for program controlled set up. The device can be "self loaded" via an external PROM tied on the data bus as described in the OPERATION section. Formatting can also be programmed by a single mask option.

In addition to the seven control registers two additional registers are provided to store the cursor character and data row addresses for generation of the cursor video signal. The contents of these two registers can also be read out onto the bus for update by the program.

Three versions of the VTAC ${ }^{\circledR}$ are available. The CRT 5027 provides non-interlaced operation with an even or odd number of scan lines per data row, or interlaced operation with an even number of scan lines per data row. The CRT 5037 may be programmed for an odd or even number of scan lines per data row in both interlaced and non-interlaced modes. Programming the CRT 5037 for an odd number of scan lines per data row eliminates character distortion caused by the uneven beam current normally associated with odd field/even field interlacing of alphanumeric displays.

The CRT 5057 provides the ability to lock a CRT's vertical refresh rate, as controlled by the VTAC's® vertical sync pulse, to the 50 Hz or 60 Hz line frequency thereby eliminating the so called "swim" phenomenon. This is particularly well suited for European system requirements. The line frequency waveform, processed to conform to the VTAC's ${ }^{\circledR}$ specified logic levels, is applied to the line lock input. The VTAC® will inhibit generation of vertical sync until a zero to one transition on this input is detected. The vertical sync pulse is then initiated within one scan line after this transition rises above the logic threshold of the VTAC. ${ }^{(®)}$

To provide the pin required for the line lock input, the composite sync output is not provided in the CRT 5057.

## Description of Pin Functions



## Operation

The design philosophy employed was to allow the device to interface effectively with either a microprocessor based or hardwire logic system. The device is programmed by the user in one of two ways; via the processor data bus as part of the system initialization routine, or during power up via a PROM tied on the data bus and addressed directly by the Row Select outputs of the chip. (See figure 4). Seven 8 bit words are required to fully program the chip. Bit assignments for these words are shown in Table 1. The information contained in these seven words consists of the following:

Horizontal Formatting:
Characters/Data Row

Horizontal Sync Delay
Horizontal Sync Width

Horizontal Line Count
Skew Bits

Vertical Formatting: Interlaced/Non-interlaced

Scans/Frame 8 bits assigned, defined according to the following equations: Let $X=$ value of 8 assigned bits.

1) in interlaced mode-scans/frame $=2 X+513$. Therefore for 525 scans, program $X=6(00000110)$. Vertical sync will occur precisely every 262.5 scans, thereby producing two interlaced fields.
Range $=513$ to 1023 scans/frame, odd counts only.
2) in non-interlaced mode-scans/frame $=2 X+256$. Therefore for 262 scans, program $X=3$ (00000011).
Range $=256$ to 766 scans/frame, even counts only.
In either mode, vertical sync width is fixed at three horizontal scans ( $\equiv 3 \mathrm{H}$ ).
Vertical Data Start

Data Rows/Frame
Last Data Row

Scans/Data Row
A 3 bit code providing 8 mask programmable character lengths from 20 to 132. The standard device will be masked for the following character lengths; 20, 32, $40,64,72,80,96$, and 132.
3 bits assigned providing up to 8 character times for generation of "front porch".
4 bits assigned providing up to 15 character times for generation of horizontal sync width.

8 bits assigned providing up to 256 character times for total horizontal formatting.
A 2 bit code providing from a 0 to 2 character skew (delay) between the horizontal address counter and the blank and sync (horizontal, vertical, composite) signals to allow for retiming of video data prior to generation of composite video signal. The Cursor Video signal is also skewed as a function of this code.

This bit provides for data presentation with odd/even field formatting for interlaced systems. It modifies the vertical timing counters as described below. A logic 1 establishes the interlace mode.

8 bits defining the number of raster scans from the leading edge of vertical sync until the start of display data. At this raster scan the data row counter is set to the data row address at the top of the page.
6 bits assigned providing up to 64 data rows per frame.
6 bits to allow up or down scrolling via a preload defining the count of the last displayed data row.

4 bits assigned providing up to 16 scan lines per data row.

## Additional Features

## Device Initialization:

Under microprocessor control-The device can be reset under system or program control by presenting a $1 \varnothing 1 \varnothing$ address on A3- $\varnothing$. The device will remain reset at the top of the even field page until a start command is executed by presenting a $111 \varnothing$ address on $A 3-\emptyset$.

Via "Self Loading"-In a non-processor environment, the self loading sequence is effected by presenting and holding the 1111 address on A3•Ø, and is initiated by the receipt of the strobe pulse (DS). The 1111 address should be maintained long enough to insure that all seven registers have been loaded (in most applications under one millisecond). The timing sequence will begin one line scan after the 1111 address is removed. In processor based systems, self loading is initiated by presenting the $\varnothing 111$ address to the device. Self loading is terminated by presenting the start command to the device which also initiates the timing chain.

Scrolling—In addition to the Register 6 storage of the last displayed data row a "scroll" command (address 1ø11) presented to the device will increment the first displayed data row count to facilitate up scrolling in certain applications.

## Control Registers Programming Chart

Horizontal Line Count: Characters/Data Row:

Horizontal Sync Delay: Horizontal Sync Width:

Skew Bits

Scans/Frame

Vertical Data Start:

Data Rows/Frame:
Last Data Row:

Mode:
Scans/Data Row:

Total Characters/Line $=\mathrm{N}+1, \mathrm{~N}=0$ to $255(\mathrm{DBO}=\mathrm{LSB})$
DB2 DB1 DB0

| 0 | 0 | 0 | $=20$ |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | $=32$ |
| 0 | 1 | 0 | $=40$ |
| 0 | 1 | 1 | $=64$ |
| 1 | 0 | 0 | $=72$ |
| 1 | 0 | 1 | $=80$ |
| 1 | 1 | 0 | $=96$ |
| 1 | 1 | 1 | $=132$ |

$=N$, from 1 to 7 character times $(D B 0=L S B)(N=0$ Disallowed $)$
$=N$, from 1 to 15 character times (DB3 = LSB) $(N=0$ Disallowed) Sync/Blank Delay Cursor Delay
DB7 DB6
(Character Times)

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

0
1 0
1 1 2 -
8 bits assigned, defined according to the following equations:
Let $X=$ value of 8 assigned bits. (DB0 $=$ LSB)

1) in interlaced mode-scans/frame $=2 X+513$. Therefore for 525 scans, program $X=6$ (00000110). Vertical sync will occur precisely every 262.5 scans, thereby producing two interlaced fields.
Range $=513$ to 1023 scans/frame, odd counts only.
2) in non-interlaced mode-scans/frame $=2 X+256$. Therefore for 262 scans, program $X=3$ (00000011).
Range $=256$ to 766 scans/frame, even counts only.
In either mode, vertical sync width is fixed at three horizontal scans $(=3 \mathrm{H})$.
$N=$ number of raster lines delay after leading edge of vertical sync of vertical start position. $(\mathrm{DB} 0=\mathrm{LSB})$
Number of data rows $=N+1, N=0$ to 63 (DBO $=$ LSB)
$\mathrm{N}=$ Address of last dsplayed data row, $\mathrm{N}=0$ to 63, ie; for 24 data rows, program $\mathrm{N}=23$. ( $\mathrm{DBO}=\mathrm{LSB}$ )
Register, 1, DB7 = 1 establishes Interlace.

## Interlace Mode

CRT 5027: Scans per Data Row $=N+1$ where $N=$ programmed number of scans/data rows. $\mathrm{N}=0$ to 15 . Scans per data row must be even counts only. CRT 5037, CRT 5057: Scans per data Row $=N+2 . N=0$ to 14, odd or even counts.

## Non-Interlace Mode

CRT 5027, CRT 5037, CRT 5057: Scans per Data Row $=$ N + 1, odd or even count. $\mathrm{N}=0$ to 15 .


## Register Selects/Command Codes

| A3 | A2 | A1 | A $\varnothing$ | Select/Command |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | Load Control Register $\emptyset$ |
| 0 | 0 | 0 | 1 | Load Control Register 1 |
| 0 | 0 | 1 | 0 | Load Control Register 2 <br> 0 0 |
| 0 | 1 | 1 | Load Control Register 3 |  |
| 0 | 1 | 0 | 0 | Load Control Register 4 |
| 0 | 1 | 0 | 1 | Load Control Register 5 <br> 0 1 |
| 1 | 0 | Load Control Register 6 |  |  |
| 0 | 1 | 1 | 1 | Processor Initiated Self Load |
|  |  |  |  | Read Cursor Line Address |
| 1 | 0 | 0 | 0 | Read Cursor Character Address |
| 1 | 0 | 0 | 1 |  |
| 1 | 0 | 1 | 0 |  |
| 1 | 0 | 1 | 1 |  |

$10 \quad 0 \quad$ Load Cursor Character Address*
$110 \quad 1$ Load Cursor Line Address*
1110

1111
Non-Processor Self Load

## Description

I

See Table 1

Command from processor instructing VTAC ${ }^{\text {e }}$ to enter Self Load Mode (via external PROM)

Resets timing chain to top left of page. Reset is latched on chip by $\overline{\mathrm{DS}}$ and counters are held until released by start command.
Increments address of first displayed data row on page. ie; prior to receipt of scroll command-top line $=0$, bottom line $=23$. After receipt of Scroll Command-top line = 1, bottom line $=0$.

Receipt of this command after a Reset or Processor Self Load command will release the timing chain approximately one scan line later. In applications requiring synchronous operation of more than one CRT 5027 the dot counter carry should be held low during the $\overline{\mathrm{DS}}$ for this command.
Device will begin self load via PROM when $\overline{\mathrm{DS}}$ goes low. The 1111 command should be maintained on A3-ø long enough to guarantee self load. (Scan counter should cycle through at least once). Self load is automatically terminated and timing chain initiated when the all " 1 's" condition is removed, independent of DS. For synchronous operation of more than one VTAC ${ }^{\text {® }}$, the Dot Counter Carry should be held low when the command is removed.
*NOTE: During Self-Load, the Cursor Character Address Register (REG 7) and the Cursor Row Address
Register (REG 8) are enabled during states $\emptyset 111$ and $1 \varnothing \varnothing \emptyset$ of the R3-R $\emptyset$ Scan Counter outputs respectively. Therefore, Cursor data in the PROM should be stored at these addresses.

## TABLE 1



AC timing diagrams

*R $\varnothing$ - 3 and $D R \emptyset-5$ may change prior to the falling edge of H sync


MAXIMUM GUARANTEED RATINGS


Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transientṣ on the AC power line may appear on the DC output. For example, the bench power supply programmed to deliver +12 volts may have large voltage transients when the $A C$ power is switched on and off. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{VCC}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%$, unless otherwise noted)


## Restrictions

1. Only one pin is available for strobing data into the device via the data bus. The cursor $X$ and $Y$ coordinates are therefore loaded into the chip by presenting one set of addresses and outputed by presenting a different set of addresses. Therefore the standard WRITE and READ control signals from most microprocessors must be "NORed" externally to present a single strobe $(\overline{\mathrm{DS}})$ signal to the device.
2. In interlaced mode the total number of character slots assigned to the horizontal scan must be even to insure that vertical sync occurs precisely between horizontal sync pulses.


## Start-up, CRT 5027

When employing microprocessor controlled loading of the CRT 5027's registers, the following sequence of instructions is necessary:

| ADDRESS |  |  |  | COMMAND |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 1 | 0 | Start Timing Chain |
| 1 | 0 | 1 | 0 | Reset |
| 0 | 0 | 0 | 0 | Load Register 0 |
|  |  |  |  | - |
|  |  |  |  | - |
| 0 | 1 | 1 | 0 | Load Register 6 |
| 1 | 1 | 1 | 0 | Start Timing Chain |

The sequence of START RESET LOAD START is necessary to insure proper initialization of the registers.
This sequence is not required if register loading is via either of the Self Load modes. This sequence is optional with the CRT 5037 or CRT 5057. tions; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

# Preprogrammed CRT Video Timer and Controller VTAC ${ }^{\text {® }}$ 

## FEATURES

Preprogrammed (Mask-Programmed) Display Format 80 Characters Per Data Row 24 Data Rows Per Frame 9 Scan Lines Per Data RowPreprogrammed Monitor Sync Format 262 Scan Lines Per Frame 6 Character Times for Horizontal Front Porch 8 Character Times for Horizontal Sync Width 6 Character Times for Horizontal Back Porch 16 Scan Lines for Vertical Front Porch 3 Scan Lines for Vertical Sync Width 27 Scan Lines for Vertical Back Porch Non-Interlace 15.720 KHz Horizontal Scan Rate 60 Hz Frame Refresh Rate$\square$ Fixed Character Rate 1.572 MHz Character Rate ( $636.13 \mathrm{~ns} /$ Character) 11.004 MHz Dot Rate ( $90.88 \mathrm{~ns} /$ Dot) for 7 Dot Wide Character Block
$\square$ Character Format
$5 \times 7$ Character in a $7 \times 9$ Block
$\square$ Compatible with CRT 8002B-003 VDAC ${ }^{\text {rw }}$
$\square$ Compatible with CRT 7004B-003
$\square$ May be mask-programmed with other display formats

## GENERAL DESCRIPTION

The two chip combination of SMC's CRT 5047 and CRT 8002B-003 effectively provide all of the video electronics for a CRT terminal. This chip set along with a $\mu \mathrm{C}$ form the basis for a minimum chip count CRT terminal.
The CRT 5047 Video Timer and Controller is a special version of the CRT 5037 VTAC® which has been ROMprogrammed with a fixed format. It is especially effective for low-cost CRT terminals using an $80 \times 24$ display format with a $5 \times 7$ character matrix. The use of a fixed ROM program in the CRT 5047 eliminates the software overhead normally required to specify the display parameters and simplifies terminal software design.
The Cursor Character Address Register and the Cursor Row Address Register are the only two registers acces-
sible by the processor. The CRT 5047 is easily initialized by the following sequence of commands:

Reset Load Control Register 6 Start Timing Chain
The parameters of the CRT 5047 have been selected to be compatible with most CRT monitors. The horizontal timing is programmed so that when the two character skew delay of the CRT $8002 \mathrm{VDAC}^{\text {ru }}$ is taken into account, the effective timing is: Horizontal Front Porch - four characters, and Horizontal Back Porch-eight characters.
Figure 1 shows the contents of the internal CRT 5047 registers. Other mask-programmed versions of the CRT 5037 are available. Consult SMC for more information.

## VTAC® WORK SHEET

 (No. of Horiz. Scan Lines):7
3. H CHARACTER BLOCK (Step $1+$ Desired Horiz. Spacing = No. in Dots): ..... 7
4. V CHARACTER BLOCK (Step $2+$ Desired Vertical Spacing = No. in Horiz. Scan Lines): ..... 9
5. VERTICAL FRAME (REFRESH) RATE (Freq. in Hz ): ..... 60
6. DESIRED NO. OF DATA ROWS: ..... 24
7. TOTAL NO. OF ACTIVE "VIDEO DISPLAY" SCAN LINES (Step $4 \times$
Step $6=$ No. in Horiz. Scan Lines): ..... 216
8. VERT. SYNC DELAY (No. in Horiz.
Scan Lines): ..... 16
9. VERT. SYNC (No. in Horiz. Scan Lines; $\left.\mathrm{T}=190.8 \mu \mathrm{~s}^{*}\right)$ : ..... 3
10. VERT. SCAN DELAY (No. in Horiz. Scan Lines; $T=\underline{1.718} \mathrm{~ms}^{*}$ ): ..... 27
11. TOTAL VERTICAL FRAME (Add steps 7 thru $10=$ No. in Horiz. Scan Lines):

262
12. HORIZONTAL SCAN LINE RATE (Step $5 \times$ Step $11=$ Freq. in KHz ): ..... 15.720
13. DESIRED NO. OF CHARACTERS ..... 80
14. HORIZ. SYNC DELAY (No. in Character Time Units; $\left.T=3.817 \mu \mathrm{~s}^{\star \star}\right)$ : ..... 6
15. HORIZ. SYNC (No. in Character Time Units; $\left.T=\underline{5.090} \mu \mathrm{~s}^{* *}\right)$ : ..... 8
16. HORIZ. SCAN DELAY (No. in CharacterTime Units; $T=\underline{3.817} \mu \mathrm{~s}^{* *}$ ):6
17. TOTAL CHARACTER TIME UNITS IN (1) HORIZ. SCAN LINE (Add Steps 13 thru 16): ..... 100
18. CHARACTER RATE (Step $12 \times$ Step 17 $=$ Freq. in MHz ): ..... 1.572
19. CLOCK (DOT) RATE (Step $3 \times$ Step 18 $=$ Freq. in MHz): ..... 11.004


# CRT Video Processor and Controller <br> VPAC ${ }^{\text {™ }}$ 

## FEATURES

Fully Programmable Display Format Characters per Data Row (8-240)Data Rows per Frame (2-256)
Raster Scans per Data Row (1-32)
$\square$ Programmable Monitor Sync Format
Raster Scans/Frame (4-2048)
Front Porch - Horizontal (Negative or Positive)
-Vertical
Sync Width - Horizontal (1-128 Character Times)

- Vertical (2-256 Scan Lines)

Back Porch-Horizontal

- VerticalDirect Outputs to CRT Monitor
Horizontal Sync
Vertical Sync
Composite Sync
Composite Blanking
Cursor CoincidenceBinary Addressing of Video MemoryRow-Table Driven or Sequential Video Addressing ModesProgrammable Status Row Position and Address RegistersBidirectional Partial or Full Page Smooth ScrollAttribute Assemble ModeDouble Height Data Row ModeDouble Width Data Row ModeProgrammable DMA Burst ModeConfigurable with a Variety of Memory Contention
ArrangementsLight Pen Register
Cursor Horizontal and Vertical Position Registers
Maskable Processor Interrupt Line
Internal Status Register
Three-state Video Memory Address Bus
Partial or Full Page Blank CapabilityTwo Interlace Modes: Enhanced Video and Alternate
Scan Line

PIN CONFIGURATION

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

Ability to Delay Cursor and Blanking with respect to Active Video Programmable for Horizontal Split Screen Applications Graphics Compatible 1 Ability to Externally Sync each Raster Line, each Field Single +5 Volt Power SupplyTTL Compatible on All Inputs and Outputs
VT-100 Compatible
RS-170 Interlaced Composite Sync Available

The CRT 9007 VPAC $^{\text {™ }}$ is a next generation video processor/ controller-an MOS LSI integrated circuit which supports either sequential or row-table driven memory addressing modes. As indicated by the features above, the VPAC ${ }^{\text {™ }}$ provides the user with a wide range of programmable features permitting low cost implementation of high performance CRT systems. Its 14 address lines can directly address up to 16 K of video memory. This is equivalent to eight pages of an 80 character by 24 line CRT display. Smooth or jump scroll operations may be performed anywhere within the addressable memory. In addition, status rows can be defined anywhere on the screen.
In the sequential video addressing mode, a Table Start Register points to the address of the first character of the first data row on the screen. It can be easily changed to produce a scrolling effect on the screen. By using this register in conjunction with two auxiliary address registers and two sequential break registers, a screen roll can be produced with a stable status row held at either the first or last data row position.

In the row-table driven video addressing mode, each row in the video display is designated by its own address. This provides the user with greater flexibility than sequential addressing since the rows of characters are linked by pointers instead of residing in sequential memory locations. Operations such as data row insertion, deletion, and replication are easily accomplished by manipulating pointers instead of entire lines. The row table itself can be stored in memory in a linked list or in a contiguous format. The VPAC ${ }^{\text {TM }}$ works with a variety of memory contention schemes including operation with a Single Row Buffer such as the CRT 9006, a Double Row Buffer such as the CRT 9212, or no buffer at all, in which case character addresses are output during each displayable scan line.
User accessable internal registers provide such features as light pen, interrupt enabling, cursor addressing, and VPAC ${ }^{\text {™ }}$ status. Ten of these registers are used for screen formatting with the ability to define over 200 characters per data row and up to 256 data rows per frame. These 10 registers contain the "vital screen parameters".


FIGURE 1: CRT 9007 BLOCK DIAGRAM

## DESCRIPTION OF PIN FUNCTIONS

PROCESSOR INTERFACE:

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| $\begin{gathered} 7,5,4,2,39 \\ 37,10,9,8,6 \\ 3,1,38,36 \end{gathered}$ | $\begin{aligned} & \text { Video Address } \\ & 13-0 \end{aligned}$ | VA13-VA0 | These 14 signals are the binary address presented to the video memory by the CRT 9007. The function depends on the particular CRT 9007 mode of operation. VA13-6 are outputs only. VA5-0 are bidirectional. <br> -Double Row Buffer Configuration: <br> VA13-0 are active outputs for the DMA operations and are in their high impedance state at all other times. <br> -Single Row Buffer Configuration: <br> VA13-0 are active outputs during the first scan line of each data row and are in their high impedance state at all other times. <br> -Repetitive Memory Addressing Configuration: <br> VA13-0 are active outputs at all times except during horizontal and vertical retrace at which time they are in their high impedance state. <br> If row table addressing is used for either single row buffer or repetitive memory addressing modes, VA13-0 are active outputs during the horizontal retrace at each data row boundary to allow the CRT 9007 to retrieve the row table address. For processor read/write operations VA5-0 are inputs that select the appropriate internal register. |
| $\begin{aligned} & 16,17,18,19, \\ & 20,22,23,24 \end{aligned}$ | Video Data 7-0 | VD7-VD0 | Bidirectional video data bus: during processor Read/write operations data is transferred via VD7-VD0 when chip strobe ( $\overline{\mathrm{CS}}$ ) is active. These lines are in their high impedance state when CS is inactive. During CRT 9007 DMA operations, data from video memory is input via VD7-VDO when a new row table address is being retrieved or when the attribute latch is being updated in the attribute assemble mode. VD7-VD0 are outputs when the external row buffer is updated with a new attribute in the attribute assemble mode. |
| 25 | Chip strobe | $\overline{\mathrm{CS}}$ | Input; this signal when active low, allows the processor to read or write internal CRT 9007 registers. When reading from an internal CRT 9007 register, the chip strobe (CS) enables the output drivers. When writing to an internal CRT 9007 register, the trailing edge of this signal latches the incoming data. Figure 2 shows all processor read/write timing. |
| 26 | Reset | $\overline{\text { RST }}$ | Input; this active low signal puts the CRT 9007 into a known, inactive state and insures that the horizontal sync (HS) output is inactive. Activating this input has the same effect as a RESET command. After initialization, a START command causes normal CRT 9007 operation. See processor addressable registers section, Register 16 for the reset state definition. |
| 27 | Interrupt | INT | Output; an interrupt to the processor from the CRT 9007 occurs when this signal is active high. The interrupt returns to its inactive low state when the status register is read. |

CRT INTERFACE:

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 11 | Visible Line Time | VLT | Output; this signal is active high during all visible scan lines and during the horizontal trace times at vertical retrace. This signal can be used to gate the character clock (CCLK) when supplying data to a character generator from a single or double row buffer. |
| 12 | Vertical Sync | $\overline{\mathrm{VS}}$ | Open drain output; this signal determines the vertical position of displayed text by initiating a vertical retrace. Its position and pulse width are user programmable. The open drain allows the vertical frame rate to be synchronized to the line frequency when using monitors with DC coupled vertical amplifiers. If the $\overline{\mathrm{VS}}$ output is pulled active low externally before the CRT 9007 itself initiates a vertical sync, the CRT 9007 will start its own vertical sync at the next leading edge of horizontal sync ( $\overline{\mathrm{HS}}$ ). |
| 13 | Horizontal Sync | $\overline{\mathrm{HS}}$ | Open drain output; this signal determines the horizontal position of displayed text by initiating a horizontal retrace. Its position and pulse width are user programmable. During hardware and software reset, this signal is inactive high. The open drain allows the horizontal scan rate to be synchronized to an external source. If the HS output is pulled low externally before the CRT 9007 itself initiates a horizontal sync, the CRT 9007 will start its own horizontal sync on the next character clock (CCLK). |
| 14 | Character Clock | $\overline{\text { CCLK }}$ | Input; this signal defines the character rate of the screen and is used by the CRT 9007 for all internal timing. A minimum high voltage of 4.3 V must be maintained for proper chip operation. |
| 15 | Data Row Boundary | $\overline{\mathrm{DRB}}$ | Output; this signal is active low for one full scan line (from VLT trailing edge to VLT trailing edge) at the top scan line of each new data row. This signal can be used to swap buffers in the double row buffer mode. It indicates the particular horizontal retrace time that the CRT 9007 outputs addresses (VA13-VA0) for single row buffer operation. |
| 34 | Cursor | CURS | Output; this signal marks the cursor position on the screen as specified by the horizontal and vertical cursor registers. The signal is active for one character time at the particular character position for all scan lines within the data row. For double height or width characters, this signal is active for 2 consecutive $\overline{\text { CCLK's in every scan line within the data row. For double }}$ height characters, this signal can be programmed to be active at the proper position for 2 consecutive data rows. <br> CURS is also used to signal either a double height or double width data row by becoming active during the horizontal retrace (CBLANK active) prior to a double height or double width scan line. The time of activation and deactivation is a function of the addressing mode, buffer configuration and the scan line number. See section of Double height/width for details. |
| 35 | Composite Blank | CBLANK | Output. This signal when active high, indicates that a retrace (either horizontal or vertical) will be performed. The signal remains active for the entire retrace interval as programmed. It is used to blank the video to a CRT. |

USER SELECTABLE PINS: (see Tables 4 and 5)

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 28, 29, 30, 31 | Scan Line 3Scan Line 0 | SL3-SL0 | Output; these 4 signals are the direct scan line counter outputs, in binary form, that indicate to the character generator the current scan line. These signals continue to be updated during the vertical retrace interval. SL3 and SL0 are the most and least significant bits respectively. |
| 28 | Direct Memory Access Request | DMAR | Output; this signal is the DMA request issued by the CRT 9007. It will only become active if the acknowledge (ACK) input is inactive. It remains active high throughout the entire DMA operation. |
| 28 | Vertical Blank | VBLANK | Output; this signal is active high only during the vertical retrace period. |
| 29 | Write Buffer Enable | WBEN | Output; this active high signal is used to gate the clock feeding the write buffer in a double row buffer configuration. |
| 29 or 32 | Composite Sync | $\overline{\text { CSYNC }}$ | Output; this signal provides a true RS-170 composite sync waveform with equalization pulses and vertical serrations in both interlace and noninterlace formats. Figure 3 illustrates the CSYNC output in both interlaced and noninterlaced formats. |
| 30 | Scan Line Gate | $\overline{\text { SLG }}$ | Output; this active low signal is used as a clock gate. It captures the correct 5 or $6 \overline{\mathrm{CCLK}}$ 's and, in conjunction with SLD (pin 31), allows scan line information to be loaded serially into an external shift register. |
| 31 | Scan Line Data | SLD | Output; this signal allows one to load an external shift register with the current scan line count. The count is presented least significant to most significant bit during the 5 or 6 CCLK's framed by SLG. With this form of scan line representation, it is possible to define up to 32 scan lines per data row. <br> The external shift register must be at least 5 bits in length. Even though 6 shifts can occur one should only use the 5 last bits shifted to define the scan line count. The extra shift occurs in interlace or double height character mode to allow the scan line count to be adjusted to its proper value. Figures 4 and 5 illustrate the serial scan line timing. |
| 32 | Light Pen Strobe | LPSTB | Input; this signal strobes the current row/column position into the light pen register at its positive transition. |
| 33 | Acknowledge | ACK | Input; this active high signal acknowledges a DMA request. It indicates that the processor bus has entered its high impedance state and the CRT 9007 may access video memory. It is not recommended to deactivate this signal during a CRT 9007 DMA cycle because the CRT 9007 will not shut down in a predictable amount of time. |
| 33 | Three State Control | TSC | Input; this signal, when active low, places VA13-VA0 in their high impedance state. |

## Single Row Buffer Operation

The CRT 9007 configured with a CRT 9006 Single Row Buffer is shown in figure 6. The use of the CRT 9006 Single Row Buffer requires that the buffer be loaded at the video painting rate during the top scan line of each data row. However, after the CRT 9006 is loaded, the CRT 9007 address lines enter their high impedance state for the remaining N 1 scan lines of the data row, thereby permitting full proces-
sor access to memory during these scan lines. The percentage of total memory cycles available to the processor is approximately $[(\mathrm{N}-1) / \mathrm{N}] \times 100$ where N is the total number of scan lines per data row. For a typical system with 12 scan lines per data row this percentage is $92 \%$. Figure 7 illustrates typical timing for the CRT 9007 used with the CRT 9006 Single Row Buffer.


FIGURE 6: CRT 9007 CONFIGURATION WITH SINGLE ROW BUFFER


FIGURE 7: CRT 9007 SINGLE ROW BUFFER TIMING (32 CHARACTERS PER DATA ROW)

## Double Row Buffer Operation

Figure 8 shows the CRT 9007 used in conjunction with a CRT 9212 Double Row Buffer. The Double Row Buffer has a read buffer which is read at the painting rate of the CRT during each scan line in the data row. While the read buffer is being read and supplying data to the character generator for the current displayed data row, the write buffer is being loaded with the next data row to be displayed. This arrangement allows for relaxed write timing to the write buffer as it may be filled in the time it takes for N scan lines on the CRT to be painted where $N$ is the number of scan lines per data row. Used in this configuration, the CRT 9007 takes advantage of the relaxed write buffer timing by stealing memory cycles from the processor to fill the write buffer (Direct memory access operation). The CRT 9007 sends the DMAR (DMA request) signal, awaits an ACK (acknowledge) signal and then drives out on VA13-VA0 the address at which the next video data resides. The CRT 9007 then activates the WBEN (write buffer enable) signal to write the data into the buffer. If for example there are 80 characters per data row, the CRT 9007 performs 80 DMA operations. The user has the ability to program the number of DMA cycles performed during each DMAR-ACK sequence, as well as
the delay between each DMAR-ACK sequence, via the DMA CONTROL REGISTER (RA). If 8 DMA operations are performed for each ACK received, 10 such DMAR-ACK sequences must be performed to completely fill the write buffer. The programmed delay allows the user to evenly distribute the DMA operations so as not to hold up the processor for an excessive length of time. This feature also permits other DMA devices to be used and allows the processor to respond to real time events. In addition, the user has the ability to disable the CRT 9007 DMA mechanism. Figure 9 illustrates typical timing for the CRT 9007 used with the CRT 9212 Double Row Buffer.
Since the CRT 9212 Double Row Buffer has separate inputs for read and write clocks (RCLK, $\overline{\text { WCLK }}$ ), it is possible to display proportional character widths (variable number of dots per character) by reading out the buffer at a character clock rate determined by the particular character. The writing of the buffer can be clocked from a different and constant character clock. Figure 10 illustrates the CRT 9007 used with two double row buffers and a CRT 9021 Video Attributes Controller chip to provide proportional character display.


FIGURE 8: CRT 9007 CONFIGURATION WITH DOUBLE ROW BUFFER


FIGURE 9: CRT 9007 DOUBLE ROW BUFFER TIMING (32 CHARACTERS PER DATA ROW)


FIGURE 10: CRT 9007 CONFIGURATION FOR PROPORTIONAL CHARACTER DISPLAY

## Repetitive Memory Addressing Operation

In this operation mode, the CRT 9007 will repeat the sequence of video addresses for every scan line of every data row. The CRT 9007 address bus will enter its high impedance state during all horizontal retrace intervals (except the retrace interval at a data row boundary if the CRT 9007 is configured in a row driven addressing mode). This arrangement allows for such low end contention schemes as retrace intervention (the processor is only allowed access to video memory during retrace intervals)
and processor priority (the processor has an unlimited access to video memory). A high end contention scheme can be employed which uses a double speed memory such that in a single character period both the processor and the CRT 9007 are permitted access to video memory at predetermined time slots. Figure 11 illustrates the CRT 9007 configured with a double speed memory. Typical timing for this mode is illustrated in figure 12.


FIGURE 11: CRT 9007 CONFIGURATION WITH DOUBLE SPEED MEMORY


## Attribute Assemble Operation

This configuration allows the user to retain an 8 bit wide video memory in which attributes occupy memory locations but not positions on the CRT. This mode assumes that every other display position in video memory contains an attribute. During one clock cycle, attribute data is latched into the CRT 9007; during the next clock cycle a character location is addressed. The attribute data is driven out along with a WBEN signal allowing the character plus its associated attribute to be written simultaneously to two 8 bit double row buffers. Figure 13 illustrates the memory organization used for the Attribute Assemble mode. The first entry in each data row must begin with an attribute.
Figure 14 shows the CRT 9007 configured in the Attribute Assemble mode used with two CRT 9212 Double Row Buffers and $8,16 \mathrm{Kx1}$ dynamic RAMS. This mode, since it retains an 8 bit wide memory while providing all the advantages of a 16 bit wide memory, lends itself to some cost effective designs using dynamic RAMS. The CRT 9007 will refresh dynamic RAMS because twice the number of the programmed characters per data row are accessed sequentially for each data row.* Figure 15 illustrates typical timing of the CRT 9007 used in the Attribute Assemble mode.

Memory Address (typ) Memory Data (8 bits)

| ODOO | Attribute 0 |
| :---: | :---: |
| OD01 | Character 0 |
| 0D02 | Attribute 1 |
| 0D03 | Character 1 |
| $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | 0 0 0 |
| 2 N | Attribute N |
| $2 N+1$ | Character N |

Figure 13: Attribute Assemble Memory Organization
*Note: For 50 Hz operation there usually is about 3 milliseconds extra vertical blanking where refreshing might fail. In this situation the CRT 9007 can be programmed with about 5 more "dummy" data rows while extending the vertical blank signal. This allows the CRT 9007 to start addressing video memory much earlier within the vertical blanking interval and hence provide refresh to the dynamic RAMS. When displaying double height or double width data rows, only half as many sequential locations are accessed each data row and dynamic RAM refresh might fail.


FIGURE 14: CRT 9007 CONFIGURATION FOR ATTRIBUTE ASSEMBLE MODE

## Smooth Scroll Operation

Smooth scroll requires that all or a portion of the screen move up or down an integral number of scan lines at a time. 2 user programmable registers allow one to define the "start data row" and the "end data row" for the smooth scroll operation. A SMOOTH SCROLL OFFSET REGISTER (R17), when used in conjunction with a CRT 9007 vertically timed interrupt, allows the user to synchronize the update of the offset register to the vertical frame rate. The offset register causes the scan line counter outputs of the CRT 9007 to start at the programmed offset value rather than zero for
the data row that starts the smooth scroll interval. To allow complete flexibility in smooth scroll direction and rate, one can update the offset register in the positive as well as negative direction and can also offset any number of scan lines each frame. Since a smooth scroll can momentarily result in a partial data row consisting of one scan line, the loading of the write buffer under DMA operations for the start and end data row of the smooth scroll operation is forced to occur in one scan line. This condition overrides the programmable DMA CONTROL REGISTER (RA).


## ADDRESSING MODES

## Row Table Addressing

In this addressing mode, each data row in video memory is designated by its own starting address. This provides greater flexibility with respect to screen operations than with other addressing schemes used by previous CRT controllers. The row table, which is a list of starting addresses for each data row, can be configured in one of 2 ways. The choice of row table format is highly dependent upon the particular application and the programmer's preference since each format allows full utilization of the CRT 9007 features.

## Contiguous Row Table Format

In this format, the TABLE START REGISTER (RC and RD) points to the address where the row table begins. The contents of the first 2 locations define the starting address of the first data row. These 2 bytes define a 14 bit address where the first byte is the low order 8 bits and the second byte is the high order 6 bits. The 2 most significant bits of the second byte define double height/width characteristics to the current data row. The contents of the third and fourth locations define the address where the second data row begins. Figure 16 illustrates the contiguous row table organization in video memory.

## Linked List Row Table Format

In this format the TABLE START REGISTER (RC and RD) points to the memory location which starts the entire addressing sequence into operation. The first byte read is the lower 8 bits and the second byte read is the upper 6 bits of the next data row's start address. The 2 most significant bits of the second byte define double height/width characteristics for the data row about to be read. The third, fourth, fifth, etc., bytes read are the first, second, third, etc., characters of the current data row. Figure 17 illustrates the linked list row table organization in video memory.


## Sequential Addressing

In this addressing mode, characters on the display screen are located in successive memory locations. The TABLE START REGISTER (RC and RD) points to the address of the first character of the first data row on the screen. In this mode the TABLE START REGISTER does not point to the start of a table but the start of the screen. As each character
is read by the CRT 9007 for display refresh, the internal video address register is incremented by one to access the next character.
For more versatile systems operation in the sequential addressing mode, SEQUENTIAL BREAK REGISTER 1 (R10) and SEQUENTIAL BREAK REGISTER 2 (R12) may be used to define the data rows at which two additional
sequential display areas begin. Note that DATA ROW END REGISTER (R12) is defined as SEQUENTIAL BREAK REGISTER 2 (R12) for the sequential addressing mode only. The starting addresses for these two additional display areas are defined by AUXILIARY ADDRESS REGISTER 1 (RE and RF) and AUXILIARY ADDRESS REGISTER 2 (R13 and R14). When the raster begins painting a data row equal to the number programmed in one of the sequential break registers, the CRT 9007 addresses the video memory sequentially starting with the address specified by the corresponding auxiliary address register. Figure 18 illustrates a display with 80 characters per data row having sequential breaks at data rows 3 and 6 .
Using the sequential addressing mode with 2 breaks, it is possible to roll a portion of the screen and keep the rest of the screen stable. Double height/width characteristics can be attached to the 2 sequentially addressed screens defined by SEQUENTIAL BREAK REGISTERS 1 and 2 by using the 2 most significant bits of AUXILIARY ADDRESS REGISTERS 1 and 2. See the description of these 2 registers for their bit definition.

TABLE START REGISTER = 1000
AUXILIARY ADDRESS REGISTER $1=2000$
AUXILIARY ADDRESS REGISTER $2=0800$
SEQUENTIAL BREAK REGISTER $1=3$
SEQUENTIAL BREAK REGISTER $2=6$

| Data Row | Address range |  |
| :---: | :---: | :---: |
| 0 | 1000 to 104 F |  |
| 1 | 1050 to 109 F |  |
| 2 | 10 A 0 to 10 FF |  |
| 3 | 2000 to 204F | (Break 1) |
| 4 | 2050 to 209F |  |
| 5 | 20 A 0 to 20EF |  |
| 6 | 0800 to 084F | (Break 2) |
| 7 | 0850 to 089F |  |
| 8 | $08 A 0$ to 08EF |  |
|  | 0 | 0 |
|  | 0 |  |

Figure 18: Sequential Addressing Example With Two Breaks

## Double Height/Width Operation

When double height/width characters ( $2 \mathrm{XH} / 2 \mathrm{XW}$ ) are displayed, the following will occur:

1. the CRT 9007 will address half as many characters for each data row by incrementing its address every other character clock.
2. the high speed video shift register supplying serial video to the CRT must shift out dots at half frequency.
3. For double height, the scan line counter outputs (SL.3SLO or SLG, SLD) are incremented every other scan line.
The CRT 9007 is informed of the double height or double width display modes via the 2 most significant bits of the row table address or the 2 most significant bits of the AUXILIARY ADDRESS registers depending on the selected addressing mode. In any case, once the information is obtained by the CRT 9007, it must initiate the 3 tasks listed above. Tasks 1 and 3 are performed as appropriate and task 2 is performed using the CURS output of the CRT 9007 during CBLANK (horizontal retrace) to signal the external logic that a change in the dot shift frequency is required. The exact time of activation and deactivation of the CURS signal during horizontal retrace is a function of addressing mode, operation mode and actual scan line number to be painted. Tables 1 and 2 show the cursor activation and deactivation times as a function of the buffer configuration and addressing mode for the top scan line of a new data row. Tables 1 and 2 assume a cursor skew of zero. A cursor skew will effect the cursor position during trace as well as retrace time. For all subsequent scan lines, the CURS signal is activated 3 CCLK's after VLT trailing edge and stays active for exactly 1 CCLK assuming no cursor skew. When the cursor is placed on a double height or double width data row, it will become active for 2 CCLK's to allow the cursor to be displayed as double width. If the cursor position is programmed to reside

| OPERATIONMODE | ADDRESSING MODE |  |
| :---: | :---: | :---: |
|  | Row Driven (linked list or contiguous) | Sequentia! |
| Repetitive Memory Addressing | 1 CCLK after high byte of row table read | $\begin{array}{\|l\|} \hline 1 \text { CCLK after TSC } \\ \text { leading edge } \end{array}$ |
| Single row buffer | 1 CCLK after high byte of row table read | 1 CCLK after TSC leading edge |
| Double row buffer | 1 CCLK after high byte of row table read | 1 CCLK after ACK leading edge |

Table 1: Double Height/Width CURS activation for top scan line of new data row.
in the top half of a double height data row, it may become active for all scan lines in both the current and next data row to allow the cursor to be displayed as double height.
For row driven addressing, a particular data row or pair of data rows can appear in one of the following ways as a function of the two most significant bits of the row table address (bits 15 and 14).
-Single height, single width (Row table address bits 15, $14=00$ ). The CRT 9007 will display the particular data row as single height, single width.
-Single height, double width (Row table address bits 15, $14=01$ ). The CRT 9007 will display the particular data row as single height double width by accessing half as many characters as appear in a single width data row. The CURS signal becomes active during horizontal retrace in the manner described previously.
—Double height, double width top half (Row table address bits $15,14=10$ ). In addition to providing the special timing associated with single height double width data rows, the scan line counter is started from zero and incremented every other scan line until N scan lines are painted ( N is the number of scan lines per single height data row). In this way, new dot information appears every other scan line and the top half of the data row appears in N scan lines.
—Double Height, Double Width Bottom Half (Row table address bits $15,14=11$ )-Same as Double Height, Double Width Top except the scan line counter is started from $\mathrm{N} / 2$ (or ( $\mathrm{N}-1$ )/2 if N is odd), and incremented every other scan line until N scan lines are painted. In single row buffer operation, a double height bottom data row can never stand alone and is assumed to follow a double height top data row.


Table 2: Double Height/Width CURS deactivation for top scan line of new data row.

## PROCESSOR ADDRESSABLE REGISTERS

All CRT 9007 registers are selected by specifying the address on VA5-0 and asserting CS. All 14 bit registers are written or read as two consecutive 8 bit registers addressed low byte first. Only the VERTICAL CURSOR REGISTER and the HORIZONTAL CURSOR REGISTER are read/write registers with 2 different addresses for read or write operations. The register address assigned to each register represents the actual address in hexadecimal form that must appear on VA5-0. Figure 2 illustrates all processor to CRT 9007 register timing. Tables 3a, 3b, and 3c summarize all register bits and provide register addresses.

## HORIZONTAL TIMING REGISTERS

The following 4 registers define the horizontal timing parameters. Figure 19 relates the horizontal timing to these registers.

## CHARACTERS PER HORIZONTAL PERIOD (RO)

This 8 bit write only register, programmed in units of character times, represents the total number of characters in the horizontal period (trace plus retrace time). This register is programmed with the binary number N where N is the total characters in the horizontal period. The horizontal period should not be programmed for less than 12 characters.

## CHARACTERS PER DATA ROW (R1)

This 8 bit write only register, programmed in units of char-
acter times, represents the number of displayable characters during the horizontal trace interval. The difference R0 minus R1 represents the number of character times reserved for horizontal retrace. This register is programmed with the binary number ( $\mathrm{N}-1$ ) where N is the displayable characters per data row.

## HORIZONTAL DELAY (R2)

This 8 bit write only register, programmed in units of character times, represents the time between the leading edge of horizontal sync and leading edge of VLT. This register is programmed with N where N represents the time of horizontal delay. By programming this time greater than the horizontal blank interval, one can obtain negative front porch (horizontal sync begins before the horizontal blank interval).

## HORIZONTAL SYNC WIDTH (R3)

This 8 bit write only register defines the horizontal sync width in units of character times. The start of the sync pulse is defined by the HORIZONTAL DELAY REGISTER and the end is independent of the start of the active display time. This register is programmed with N where N is the horizontal sync width. However this register must be programmed less than or equal to $[(\mathrm{A} / 2)-1]$ where $A$ is the programmed contents of REGISTER 0 rounded to the smallest even integer.

## VERTICAL TIMING REGISTERS

The following 5 registers define the vertical timing parameters. Figure 20 relates the vertical timing to these registers.

## VERTICAL SYNC WIDTH (R4)

This 8 bit write only register defines the vertical sync width in units of horizontal periods. The start of this signal is defined by the delay register (R5) and the end is independent of the start of the active display time. This register is programmed with $N$ where $N$ is the vertical SYNC width.

## VERTICAL DELAY (R5)

This 8 bit write only register, programmed in units of horizontal periods, represents the time between the leading edge of vertical sync and the leading edge of the first VLT after the vertical retrace interval. This register is programmed with ( $\mathrm{N}-1$ ) where N represents the time of the vertical delay.

## VISIBLE DATA ROWS PER FRAME (R7)

This 8 bit write only register defines the number of data rows
displayed on the screen. This register is programmed with ( $\mathrm{N}-1$ ) where N is the number of data rows displayed.

## SCAN LINES PER DATA ROW (R8)

The 5 LSBs of this write only register define the number of scan lines per data row. These 5 bits are programmed with $(\mathrm{N}-1)$ where N is the number of scan lines per data row. When programming for scan lines per data row greater than 16, only the serial scan line pin option (SLD, SLG) can be used.

## SCAN LINES PER VERTICAL PERIOD (R8; R9)

Registers R9 and the 3 most significant bits of R8 define the number of scan lines for the entire frame. R8 contains the 3 most significant bits of the 11 bit programmed value and R9 contains the 8 least significant bits of the 11 bit programmed value. The 11 bits are programmed with $N$ where $N$ is the number of scan lines per frame. In the 2 interlace modes, the programmed value represents the number of scan lines per field.


FIGURE 19: CRT 9007 HORIZONTAL TIMING


FIGURE 20: CRT 9007 VERTICAL TIMING

## PIN CONFIGURATION/SKEW BITS REGISTER (R6)

This 8 bit write only register is used to select certain pin configurations and to skew (delay) the cursor and the blank signals independently with respect to the video signal sent to the monitor. The bits take on the following definition:

## Bit 7, 6 (Pin Configuration)

These 2 bits, as illustrated in tables 4 and 5 , define all pinout configurations as a function of double row buffer mode and non double row buffer mode. (The buffer mode is defined in the CONTROL REGISTER bits 3,2 , and 1.) The attribute assemble mode is assumed to be a double row buffer mode and obeys table 4.
Bits 5, 4, 3 (Cursor skew)
These three bits define the number of character clocks the cursor signal is skewed (delayed) from the VLT signal. The

| REGISTER R6 BITS |  |  |  |  |  |  |  |  | CRT 9007 PIN NUMBER |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 28 | 29 | 30 | 31 | 32 | 33 |  |  |  |  |  |  |
| 0 | 1 | DMAR | WBEN | $\overline{\text { SLG }}$ SLD | CSYNC | ACK |  |  |  |  |  |  |  |
| 1 | 1 | DMAR | WBEN | SLG SLD | LPSTB | ACK |  |  |  |  |  |  |  |
| 0 | 0 | NOT PERMITTED |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 0 | NOT PERMITTED |  |  |  |  |  |  |  |  |  |  |  |

Table 4: Pin configuration for double row buffer and attribute assemble modes.

VLT signal is active for all characters within a data row and a non skewed cursor will always become active within the active VLT time at the designated position. The cursor can be skewed from 0 to 5 character clocks (Bits 5,4 and 3 programmed from 000 to 101, bit 5 is the most significant bit; bit 3 is the least significant bit). For double height/width data rows, the cursor signal appearing during horizontal retrace is also skewed as programmed.
Bits 2, 1, 0 (Blank skew)
These three bits define the number of character clocks the horizontal blank component of the CBLANK signal is skewed (delayed) from the VLT signal. The edges of VLT will line up exactly with the edges of the horizontal component of the CBLANK signal if no skew is programmed. The CBLANK can be skewed from 0 to 5 character clocks (Bits 2, 1 and 0 programmed from 000 to 101, bit 2 is the most significant bit; bit 0 is the least significant bit).

| REGISTER 6 | BITS | CRT 9007 PIN NUMBER |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 28 | 29 | 30 | 31 | 32 | 33 |
| 0 | 0 | SL3 | SL2 | SL1 | SLO | CSYNC | TSC |
| 1 | 0 | SL3 | SL2 | SL1 | SLO | LPSTB | TSC |
| 1 | 1 | VBLANK | CSYNC | SLG SLD | LPSTB | TSC |  |
| 0 | 1 | NOT PERMITTED |  |  |  |  |  |

Table 5: Pin configuration for Single Row Buffer and Repetitive Memory Addressing Modes.

## DMA CONTROL REGISTER (RA)

This 8 bit write only register allows the user to set up a DMA burst count and delay as well as disable the DMA mechanism of the CRT 9007. The register bits have the following definition:

## Bit 7 (DMA Disable)

A logic one will immediately force the CRT 9007 DMA request to the inactive level and the CRT 9007 address bus (VA13VAO) will enter its high impedance state. After enabling the DMA mechanism by setting this bit to a logic zero, a start command must be issued (see START COMMAND, R15).
Bits 6, 5, 4 (DMA Burst Delay)
These 3 bits define the number of clock delays ( $\overline{\mathrm{CCLK}}$ ) between successive DMAR-ACK sequences. Bit 6 is the most and bit 4 is the least significant bit respectively. When programmed with a number $N$, the CRT 9007 will delay for $4(N+1)$ clock cycles before initiating another DMA request. If 111 is programmed, however, this will result in a zero delay allowing all characters to be retrieved from video RAM in one DMA burst regardless of the value programmed for the DMA burst count.
Bits 3, 2, 1, 0 (DMA Burst Count)

These 4 bits define the number of DMA operations in one DMAR-ACK sequence. Bit 3 is the most and bit 0 is the least significant bit respectively. When programmed with a number N , the CRT 9007 will produce 4 (iv +1) DMA cycles before relinquishing the bus. When programmed with 0000, the minimum DMA Burst will occur $(4 \times 1=4)$ and when programmed with 1111 the maximum DMA Burst will occur $(4 \times 16=64)$. When bits 6,5 , and 4 are programmed with 111, no DMA delay will occur and the Burst count will equal the number of programmed characters per data row as specified in R1. Refer to figures 9 and 15 which illustrate a DMA burst of 16 and a DMA delay of 8 for double row buffer and attribute assemble modes respectively. For single row buffer operation, no DMA delay is permitted and bits 6, 5, 4 must be programmed with 000 .

## CONTROL REGISTER (RB)

This 7 bit write only register controls certain frame operations as well as specifying the operation mode used. Internal to the CRT 9007, this register is double buffered. Changes in the register are reflected into the CRT 9007 at a particular time during vertical retrace. This allows the user to update the CONTROL REGISTER at any time without running the risk of destroying the frame or field currently being painted.

The bits take on the following definition: Bit 6 ( $\mathrm{PB} / \overline{\mathrm{SS}}$ )
$=0$; The smooth scroll mechanism is enabled permitting the SMOOTH SCROLL OFFSET REGISTER (R17) to be loaded in the scan line counter (SL30 or SLG, SLD signals) allowing for a scroll on the screen of a predetermined number of scan lines per frame or field. The starting and ending of the smooth scroll operation is defined by the DATA ROW START REGISTER (R11) and DATA ROW END REGISTER (R12) respectively.
$=1$; The page blank mechanism is enabled. The CBLANK signal is made active high for a continuous period of time starting and ending at the data row defined by the DATA ROW STARTREGISTER (R11) and DATA ROW END REGISTER (R12) respectively.
Bits 5, 4 (Interlace)-these 2 bits define one of 3 displayed modes as illustrated in figure 21
= 00; Non interlaced display
= 10; Enhanced video interlace. This display mode will produce an interlaced frame with the same dot information painted in adjacent odd/even scan lines.
= 11; Normal video interlace. This display mode will produce an interlaced frame with odd scan lines of characters displayed in odd fields and even scan lines displayed in even fields. This mode can be used to allow the screen to show twice as many data rows at half the height since it effectively doubles the character density on the screen.
$=01$; This combination is not permitted.
Bits 3, 2, 1 (Operation modes): These 3 bits define the various buffer configuration modes as follows:
= 000; (Repetitive memory addressing) -In this mode the address information (VA13-VA0) appears during every visible scan line and the address bus enters its high impedance state during all retrace intervals. When using a row driven addressing mode (linked list or contiguous), the address bus is in the high impedance state for all retrace intervals except the horizontal retrace interval prior to the top scan line of a new data row. This period can be distinguished from other retrace intervals because the $\overline{\mathrm{DR}} \bar{B}$ (data row boundary) signal is active.
= 001; (Double row buffer) - In this mode, the CRT 9007 will address a particular data row from video memory one data row prior to the time when it is displayed on the CRT. During vertical retrace, the first data row is retrieved and loaded into the double row buffer. At the next data row boundary (in this case at the end of vertical retrace), the first data row feeds the character generator while the second data
row is retrieved from video memory. The address bus will enter its high impedance state in accordance with the DMA mechanism for address bus arbitration.
$=100$; (Single row buffer)—In this mode, during the first scan line of each data row, the CRT 9007 will address video memory, load the buffer and feed the character generator at the painting rate of the CRT. If the CRT 9007 is used in a row driven addressing mode, it will drive the address bus during the retrace period prior to the first scan line of each data row in order to retrieve the row table address. It will automatically enter the high impedance state at the end of the first visible scan line of each data row. If the CRT 9007 is used in a sequential addressing mode, it will drive the address bus only during the visible line time of the first scan line of each data row.
$=111$; (Attribute assemble)-In the attribute assemble mode, character data and attribute data are shared in consecutive alternating byte locations in memory. When the CRT 9007 reads an attribute byte, it loads it into its internal attribute latch. During the next memory access, a character byte is fetched. At this time the CRT 9007 isolates its bus from the main system bus and outputs the previously latched attribute. A WBEN signal is produced during every character byte fetch to allow the character and its associated attribute to be simultaneously latched into two double row buffers. This mode assumes that there exists twice as many byte locations as there are displayable character positions on the CRT. The first byte of every data row is assumed to be an attribute.
All other combinations of the CONTROL REGISTER bits 3, 2, 1 are not permitted.
Bit $0(\overline{2 X C} / 1 \times C)$ : This bit allows for either single or double height cursor display when the cursor is placed within a double height data row as follows:
$=1$; (Single height cursor)-The CURS signal will appear during every scan line for single height data rows and will appear only during the top half or bottom half of a double height data row depending upon where the VERTICAL CURSOR REGISTER (R18, R38) defines the CURSOR data row.
$=0$; (Double height cursor) -If the VERTICAL CURSOR REGISTER (R18, R38) places the cursor in the top half of a double height data row, the CURS signal will appear during every scan line of the top half (the current data row) and the bottom half (the next data row) of the double height data row. If the cursor is placed in the bottom half of a double height data row or if it is placed in a single height data row, the CURS signal will only appear during the one particular data row.


FIGURE 21: CRT 9007 INTERLACE MODES

## TABLE START REGISTER (RC AND RD)

This 16 bit write only register contains a 14 bit address which is used in a variety of ways depending on the addressing mode chosen; the 2 remaining bits define the addressing mode. Register $C$ contains the lower 8 bits of the 14 bit address. The 6 least significant bits of register D contain the upper 6 bits of the 14 bit address. The 2 most significant bits of register $D$ define four addressing modes as follows:

Register D bits 7, 6:
= 00; (Sequential addressing mode) -The CRT 9007 will address video memory in a sequential fashion starting with the 14 bit address contained in REGISTER D bits 5-0 and REGISTER C bits 7-0. One break is allowed in the sequential addressing scheme as defined by SEQUENTIAL BREAK REGISTER 1 (R10) and AUXILIARY ADDRESS REGISTER 1 (RE and RF).
= 01; (Sequential roll addressing mode) - The CRT 9007 will address video memory in a sequential fashion starting with the 14 bit address contained in REGISTER D bits 5-0 and REGISTER C bits 7-0. SEQUENTIAL BREAK REGISTER 1 and AUXILIARY ADDRESS REGISTER 1 can be used to cause one sequential break as described in the sequential addressing mode. A second break in the sequential addressing can be defined by SEQUENTIAL BREAK REGISTER 2 (R12) and AUXILIARY ADDRESS REGISTER 2 (R13 and R14) permitting up to 3 separate sequentially addressed screens to be painted.
= 10; (Contiguous row table mode) —The CRT 9007 will address video memory according to the contiguous row table format. The 14 address bits contained in REGISTER D bits 5-0 and REGISTER C bits $7-0$ define an address that points to the beginning of the contiguous row table.
$=11$; (Linked list row table mode) -The CRT 9007 will address video memory according to the linked list row table format. The 14 address bits contained in REGISTER D bits 5-0 and REGISTER C bits 7-0 define the address at which the second row table entry and the first data row reside.

AUXILIARY ADDRESS REGISTER 1 (RE and RF)
This 16 bit write only register contains a 14 bit address. The 6 least significant bits of REGISTER F contain the upper order 6 bits of the 14 bit address and REGISTER E contains the 8 lower order bits of the 14 bit address. When the current data row equals the value programmed in SEQUENTIAL BREAK REGISTER 1 (R10) the remainder of the screen is addressed sequentially starting at the 14 bit address specified in this register. This sequential break overrides any row driven addressing mode used prior to the sequential break.

The 2 most significant bits of REGISTER $F$ allow one to attach double height and/or double width characteristics to every data row in this sequentially addressed area in the following way:

For Double row buffer or attribute assemble mode REGISTER F Bits 7, 6
$=00$; single height single width
$=01$; single height double width
$=10$; even data rows are double height double width top half odd data rows are double height double width bottom half
$=11$; odd data rows are double height double width top half even data rows are double height double width bottom half

For Single row buffer or repetitive memory addressing mode REGISTER F Bits 7, 6
$=00$; single height single width
$=01$; single height double width
$=10$; odd data rows are double height double width top half even data rows are double height double width bottom half
$=11$; even data rows are double height double width top half
odd data rows are double height double width bottom half

## SEQUENTIAL BREAK REGISTER 1 (R10)

This 8 bit write only register defines the data row number in which a new sequential video address begins as specified by AUXILIARY ADDRESS REGISTER 1 (RE and RF). To disable the use of this break, the register should be loaded with a data row count greater than the number of displayable data rows on the screen.

## DATA ROW START REGISTER (R11)

This 8 bit write only register defines the first data row number at which a page blank or smooth scroll operation will begin. Bit 6 of the CONTROL REGISTER determines if a page blank or smooth scroll operation will occur.

## DATA ROW END/SEQUENTIAL BREAK REGISTER 2 (R12)

This 8 bit write only register has a dual function depending on the addressing mode used. For row driven addressing (contiguous or linked list as specified by the 2 most significant bits of the TABLE START REGISTER) this register
defines the data row number which ends either a page blank or smooth scroll operation. The row numerically one less than the row defined by this register is the last data row on which the page blank or smooth scroll will occur. To use the page blank feature to blank a portion of the screen that includes the last displayed data row, this register must be programmed to zero. For sequential addressing, this register can cause a break in the sequential addressing at the data row number specified and a new sequential addressing sequence begins at the address contained in AUXILIARY ADDRESS REGISTER 2.

## AUXILIARY ADDRESS REGISTER 2 (R13 and R14)

This 16 bit write only register contains a 14 bit address. The 6 least significant bits of REGISTER 14 contain the upper order 6 bits of the 14 bit address and REGISTER 13 contains the 8 lower order bits of the 14 bit address. In the row driven addressing mode, this register is automatically loaded by the CRT 9007 with the current table address. The two most significant bits of REGISTER 14 specify one of four combinations of row attributes (for example double height
double width) on a row by row basis. Refer to the section entitled Double Height/Double Width operation for the meaning of these 2 bits. In the sequential addressing mode, this register can be loaded by the processor with a 14 bit address and a 2 bit row attributes field. The bit positions are identical for the row driven addressing mode. When the current data row equals the value programmed in DATAROW END/SEQUENTIAL BREAK REGISTER 2 (R12), the remainder of the screen is addressed sequentially starting at the location specified by the programmed 14 bit address. The 2 most significant bits of register 14 allow one to attach double height and or double width characteristics to every data row in this sequentially addressed area. The bit definitions take on the same meaning as the 2 most significant bits of AUXILIARY ADDRESS REGISTER 1 and affect the display in an identical manner.

## START COMMAND (R15)

After all vital screen parameters are loaded, a START command can be initiated by addressing this dummy register location within the CRT 9007. A START command must be issued after the DMA mechanism is enabled (DMA CONTROL REGISTER bit 7).

## RESET COMMAND (R16)

The CRT 9007 can be reset via software by addressing this dummy location. Activation of the RST input pin or initiating this software command will effect the CRT 9007 in an identical manner. The reset state of the CRT 9007 is defined as follows:

| CRT 9007 outputs | Reset state |
| :--- | :--- |
| VA13-0 | High impedance |
| VD7-0 | High impedance |
| HS | High |
| VS | High |
| CBLANK | High |
| CUS | Low |
| VLT | High |
| DRB | Low |
| INT | Low |
| Pin 28 | Low |
| Pin 29 | Low |
| Pin 30 | Low |
| Pin 31 | Low |

## SMOOTH SCROLL OFFSET REGISTER (R17)

This register is loaded with the scan line offset number to allow a smooth scroll operation to occur. The offset register causes the scan line counter output of the CRT 9007 to start at the programmed value rather than zero for the data row that starts the smooth scroll interval. The start is specified in the DATA ROW START REGISTER (R11). Typically, this register is updated every frame and it ranges from zero (no offset) to a maximum of the programmed scan lines per data row (maximum offset). For example, if 12 scan lines per data row are programmed (scan line 0 to scan line 11) an offset of zero will cause an unscrolled display. An offset of one will cause a display starting at scan line 1 and ending at scan line 11 (eleven scan lines total). An offset of eleven will cause a display starting at scan line eleven.
The next scan line will be zero, starting the subsequent data row. To allow smooth scroll of double height rows, the programmed range of the register is from zero to twice the programmed scan lines per data row. Whenever the offset register if greater than the programmed scan lines per data row, bit 7 of the register must be set to a logic 1 (offset overflow). It must be set to a logic zero at all other times. The 6 bit offset value occupies bits 6 through 1. Bit 0 must always be programmed with a logic zero. By setting the offset overflow (bit 7) to a logic 1, it is possible to have the bottom half
of a double height data row stand alone in Single Row Buffer Mode by programming the scrolled data row as double height top half and loading R17 with the proper value.

## VERTICAL CURSOR REGISTER (R18 or R38)

This 8 bit read/write register specifies the data row in which the cursor appears. To write into this register it is addressed as R18 and to read from this register it is addressed as R38.

## HORIZONTAL CURSOR REGISTER (R19 or R39)

This 8 bit read/write register specifies the character position in which the cursor appears. To write into this register it is addressed as R19 and to read from this register it is addressed as R39.
It should be noted that the vertical and horizontal cursor is programmed in an $\mathrm{X}-\mathrm{Y}$ format with respect to the screen and not dependant upon a particular location in video memory. The cursor will remain stationary during all-scroll operations.

## INTERRUPT ENABLE REGISTER (R1A)

This 3 bit write only register allows each of the three CRT 9007 interrupt conditions to be individually enabled or disabled according to the following definition:
Bit 6 (Vertical retrace interrupt)-This bit, when set to a logic one, will cause the CRT 9007 to activate the INT signal when a vertical retrace (i.e., the start of the vertical blanking interval) begins.
Bit 5 (Light pen interrupt)-This bit, when set to a logic one, will cause the CRT 9007 to activate the INT signal when the LIGHT PEN REGISTER (R3B, R3C) captures an X-Y coordinate. This interrupt, which occurs at the beginning of vertical retrace, reflects the occurrence of a LPSTB input on the frame or field just painted. This interrupt need not be enabled when other CRT 9007 interrupt conditions are enabled since the STATUS REGISTER (R3A) will flag the occurance of a light pen update and servicing can be done off of other interrupts.
Bit 0 (Frame timer) - This bit, when set to a logic one, allows the CRT 9007 to activate the INT signal once every frame or field at a time when a potential smooth scroll update may occur. In this way the user can use the frame timer interrupt as both a real time clock and can service smooth scroll updates and other frame oriented operations by using the appropriate status bits. This interrupt will occur after the last row table entry is read by the CRT 9007. In single row buffer operation, this will occur one data row before the start of vertical retrace. In double row buffer operation, this will occur two data rows before the start of vertical retrace.

## STATUS REGISTER (R3A)

This 5 bit register flags the various conditions that can potentially cause an interrupt regardless of whether the corresponding condition is enabled for interrupt. In this way some or all of the conditions can be reported to the processor via the STATUS REGISTER. If some of the conditions are enabled for interrupt, the processor, in response to an interrupt, simply has to read the STATUS REGISTER to determine the cause of the interrupt. The bit definition of the STATUS REGISTER is as follows:
Bit 7 (Interrupt Pending)—This bit will set when any other status bit, having its corresponding interrupt enabled, experiences a 0 to 1 transition. In this manner, when the processor services a potential CRT 9007 interrupt, it only has to test the interrupt pending bit to determine if the CRT 9007 caused the interrupt. If it did, the individual bits can then be tested to determine the details of the CRT 9007 interrupt. Any noninterruptable status change (corresponding interrupt enable bit reset to a logic 0 ) will not be reflected in the interrupt pending bit and must be polled by
the processor in order to provide service. The interrupt pending bit is reset when the status register is read. All other bits except Light Pen Update are reset to a logic 0 at the end of the vertical retrace interval. The light pen update bit is reset to a logic 0 when the HORIZONTAL LIGHT PEN REGISTER is read.
Bit 6 (Vertical Retrace)-A logic 1 indicates that a vertical retrace interval has begun.
Bit 5 (Light Pen Update)-A logic 1 indicates that a new coordinate has been strobed into the LIGHT PEN REGISTER. It is reset to a logic zero when the HORIZONTAL LIGHT PENREGISTER is read. The light pen coordinates may have to be modified via software depending on light pen characteristics.
Bit 2 (odd/even)—For a normal video interlaced display, this bit is a logic 1 when the field about be painted is an odd field and is a logic zero when the field about be painted is an even field.

Bit 0 (Frame timer occurred)-This bit becomes a logic 1 either one or two data rows before the start of vertical retrace. Since this bit is set when the CRT has finished reading the row table for the frame or field just painted, it permits row table manipulation to start at the earliest possible time.
VERTICAL LIGHT PEN REGISTER (R3B)
This 8 bit read only register contains the vertical coordinate captured at the time the CRT 9007 received a light pen strobe signal (LPSTB).

## HORIZONTAL LIGHT PEN REGISTER (R3C)

This 8 bit read only register contains the horizontal coordinate captured at the time the CRT 9007 received a light pen strobe signal. When a coordinate is captured, the appropriate status bit is set and further transitions on LPSTB are ignored until this register is read. The reading of this register will reset the light pen status bit in the STATUS REGISTER. The captured coordinate may have to be modified in software to allow for light pen response.



## MAXIMUM GUARANTEED RATINGS*


*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

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

| PARAMETER | MIN | TYP | MAX | UNITS | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  Input voltage <br>  Low <br> $V_{\text {LI }}$ How <br> $\mathrm{V}_{1{ }_{1 H 1}}$ High <br> $\mathrm{V}_{\mathrm{HH2}}$ High | $\begin{aligned} & 2.0 \\ & 4.3 \end{aligned}$ |  | 0.8 | $\begin{aligned} & V \\ & V \\ & V \end{aligned}$ | all inputs except $\overline{C C L K}$ CCLK input |
|  Output voltage <br> $\mathrm{V}_{\mathrm{ol}}$ Low <br> $\mathrm{V}_{\text {OH }}$ High | 2.4 |  | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & I_{\mathrm{OL}}=1.6 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=40 \mu \mathrm{~A} \end{aligned}$ |
|  |  |  | $\begin{aligned} & 10 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \leqslant V_{I N} \leqslant V_{\text {cc }} ; \text { excluding } \overline{\operatorname{CCLK}} \\ & 0 \leqslant V_{I N} \leqslant V_{\text {Cc }} ; \text { for } \overline{\text { CCLK }} \end{aligned}$ |
|  |  | $\begin{aligned} & 10 \\ & 25 \end{aligned}$ |  | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | all inputs except $\overline{\mathrm{CCLK}}$ CCLK input |
| $\mathrm{I}_{\text {cc }} \quad$ Power supply current |  | 100 |  | mA |  |

AC ELECTRICAL CHARACTERISTICS ${ }^{3} T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$

| PARAMETER | MIN | TYP | MAX | UNITS | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  Clock <br> clock period <br> $t_{c Y}$ <br> $t_{\text {cKL }}$ <br> clock low <br> $t_{\text {cKH }}$ clock high <br> clock rise time <br> $t_{\text {CKR }}$  <br> $t_{\text {cKF }}$ clock fall time | $\begin{array}{r} 250 \\ 90 \\ 130 \end{array}$ |  | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ | measured from $10 \%$ to $90 \%$ points <br> measured from $90 \%$ to $10 \%$ <br> points |
|  | 50 0 |  | 125 <br> 125 <br> 150 <br> 100 <br> 500 <br> 185 <br> 185 <br> 185 <br> 185 <br> 185 <br> 185 | ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns <br> ns | measured to the 2.3 V or 0.5 V level on VA13-VAO <br> valid for loading auxiliary address register 2 or the attribute latch $c_{L}=50 \mathrm{pF}$ |
| $t_{\text {AS }}$ Processor Read/write ${ }^{2}$ <br> $t_{\text {th }}$  <br> $t_{\text {tow }}$  <br> $t_{\text {Pos }}$  <br> $t_{\text {toH }}$  <br> $t_{\text {PoA }}$  <br> $t_{\text {POH }}$  <br> $t_{\text {lRR }}$  | $\begin{gathered} 110 \\ 0 \\ 165 \\ 100 \\ 0 \\ 10 \end{gathered}$ |  | $\begin{array}{r} 140 \\ 50 \\ 400 \\ \hline \end{array}$ | ns ns ns ns ns ns ns ns |  |
|   <br> $\mathrm{t}_{\text {ATS }}$ Miscellaneous timing <br> $\mathrm{t}_{\mathrm{RW}}$  |  |  | $\begin{aligned} & 125 \\ & 4 t_{\mathrm{cr}} \end{aligned}$ | ns ns | measured from the 0.4 V level of ACK or TSC falling edge measured from the 0.4 V level falling edge to 0.4 V level rising edge |

## NOTE:

1. Timing measured from the 1.5 V level of the rising edge of $\overline{\mathrm{CCLK}}$ to the 2.4 V (high) or 0.4 V (low) voltage level of the output unless otherwise noted.
2. Reference points are 2.4 V high and 0.4 V low.
3. Loading on all outputs is 30 pF except where noted.


FIGURE 22: CRT 9007 TIMING PARAMETERS: OUTPUT SIGNALS


FIGURE 2: CRT 9007 PROCESSOR READ AND WRITE TIMING PARAMETERS


* $t_{\text {ats }}$ is controlled directly from ACK or $\overline{T S} \bar{C}$ or from the particular $\overline{C C L K}$ that ends a DMA burst cycle.

FIGURE 23: CRT 9007 MISCELLANEOUS TIMING PARAMETERS


Table 3a: CRT 9007 Screen Format Registers


Table 3b: Control and Memory Address Registers


Table 3c: Cursor, Light Pen, Offset, and Status Registers devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes

# CRT Controller 

## FEATURES

$\square$ Single $+5 v$ power supply16 line $\times 64$ character displayOn chip sync oscillatorComplete cursor controlAutomatic scrollingErase functions built inPerforms character entry during horizontal sync Internal blinking cursorPage linking logic built in
LS-TTL compatible
Compatible with CRT 8002, CRT 7004

## GENERAL DESCRIPTION

The CRT 96364 A/B is a CRT Controller which controls all of the functions associated with a 16 line x 64 character video display. Functions include CRT refresh, character entry, and cursor management.
The CRT $96364 \mathrm{~A} / \mathrm{B}$ contains an internal oscillator which produces the composite sync output. The CRT 96364 B generates a 60 Hz vertical sync while the CRT 96364 A generates a 50 Hz vertical sync.

PIN CONFIGURATION


Standard functions such as ERASE PAGE, ERASE LINE, and ERASE TO END OF LINE make the CRT 96364 A/B easy to interface to any computer or microprocessor, or to use as a stand-alone video processor.

The CRT 96364A/B requires only $+5 v$ power at less than 100 mA . It is manufactured in COPLAMOS ${ }^{\circledR}$ N channel silicon gate technology.


DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 1 | Crystal in Crystal out | $\begin{aligned} & \text { X } \\ & \text { X1 } \end{aligned}$ | Pin one is the sync clock input. It may be driven directly from a TTL gate or from a parallel mode crystal connected between pins one and two. When a crystal is used, a $10 \mathrm{M} \Omega$ resistor should be connected in parallel. For standard 60 Hz line operation, a 1.018 MHz frequency source or crystal is required (with the CRT 96364 B ). For 50 Hz line operation, the CRT 96364 A requires a 1.008 MHz crystal. |
| 3 | Page Select | PS | PS provides automatic page selection when two pages of memory are used. A "zero" output indicates selection of page 1; a logic "one" indicates page 2. |
| 4-8 | Memory Address | A9-A5 | Upper order memory address lines; A6-A9 determine which lines of text are being refreshed or written. A5 along with AØ-A4 determine the character position. |
| 9 | Character Clock | DCC | Character clock input. Addresses are changed on the trailing edge of DCC. |
| 10 | Dot Clock Enable | DCE | A logic zero from DCE is used to inhibit oscillation of the dot clock for retrace blanking. |
| 11-13 | Row Address | RØ-R2 | Character Generator row addresses. Blanks are generated by forcing Rø-R2 to " 000 ". During character entry, R2 gates data into memory to control the erase function. Row addressing follows the sequence 0-1-2-3-4-5-6-7-0-0-0-0-increment text line-0-1-2-etc. |
| 14 | Ground | GND | Ground |
| 15 | Cursor | CRV | Cursor video output. Indicates cursor location by a 2 Hz blinking underline. |
| 16 | Data Strobe | $\overline{\mathrm{DS}}$ | The rising edge of $\overline{D S}$ strobes the appropriate $C \emptyset-C 2$ control word into the CRT 96364A/B. |
| 17 | Write | W | A positive going signal which indicates that the CRT 96364A/B is allowing a memory write. W is approximately $4 \mu \mathrm{~s}$, and occurs during $H$ sync. Memory address lines are latched at the cursor address during W . |
| 18-22 | Memory Address | AØ-A4 | Lower order memory addresses. A $\emptyset$-A4 plus A5 (pin 8) determine the character position. |
| 23-25 | Command Inputs | Cø-C2 | Command inputs are strobed into the CRT $96364 \mathrm{~A} / \mathrm{B}$ by $\overline{\mathrm{DS}}$. Functions are as follows: <br> and cursor position is incremented <br> * In order to suppress non-displayed characters |
| 26 | Composite Sync | CSYN | Positive logic composite sync output. Horizontal sync is generated during VSYNC and VSYNC time. A vertical sync output may be generated by logically "ANDing" CSYN and DCE. |
| 27 | End of Page | $\overline{\text { EOP }}$ | This output is used to increment an external page counter when using more than one page of memory. |
| 28 | Power Supply | $\mathrm{V}_{\mathrm{cc}}$ | +5 volt supply. |

## OPERATION

The CRT $96364 \mathrm{~A} / \mathrm{B}$ provides all of the control functions required by a CRT display with a minimum of external circuitry.
The cursor and erase commands may be decoded from the data bus by a low cost $256 \times 4$ PROM. The CRT 96364A/B then provides the necessary cursor movement and gates the memory for writing or erasing. Erase is controlled by providing a write signal to RAM, and
gating "zeros" to the RAM input bus. Use of an external PROM allows user selection of control words.
The RAM write command, " $W$ ", is generated during horizontal retrace. At this time, the RAM address is set to the cursor address. Immediately following the write command, the RAM addresses revert to refresh addressing and the cursor is shifted one character.

## CURSOR

The cursor location is indicated by an alternating high on pin 15 (CRV) at row 7, and a low on pin 15 with Rø-R2 forced low at rows 0-6. These alternate at a 2 Hz rate. If CRV is used to
force the display on, the result will be a blink of the cursor character position alternating with an underline at a 2 Hz rate.

## CHARACTER ENTRY

When a Normal Character code (C2, C1, Cø =1, 1, 1) and a Data Strobe are received, the write command will be generated during horizontal retrace. If, at the end of the horizontal retrace, the cursor is at the last position on a line, a car-
riage return and line feed will automatically occur. When the cursor is at the last position of the last line, a carriage return and up-scroll will automatically occur.

## EXTRA FUNCTIONS

By using the fourth bit of the decoder PROM as a write enable signal, and properly programming the PROM, the additional commands of Home Cursor, Return Cursor, and Roll Screen may be generated. This is done by inhibiting the

W signal to the page memory and inputting the control codes, respectively, of Page Erase and Home Cursor, Erase to end of line and Return Cursor, and Line Feed.

## SCROLLING

Scrolling of the screen text will occur under any of the following characteristics:

1. Inputting a line feed command when the cursor is at the bottom line of the screen.
2. Inputting a character when the cursor is at the bottom right hand side of the screen. Scrolling will result in the entire top line of the
screen being erased and all of the remaining lines shifting up. Alternatively, a Roll (defined as all of the lines shifting up with the previous top line reappearing at the bottom of the screen) may be performed by inhibiting the write signal to the page memory as described in "Extra Functions."

MAXIMUM GUARANTEED RATINGS
Operating Temperature Range
$.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range $55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec . $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +7.0 V
Negative Voltage on any Pin, with respect to ground
-0.3V
Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS ( $T_{A}=0$ C to $70^{\circ} \mathrm{C} . \mathrm{V}_{C C}=+5 \mathrm{~V}=5^{\circ}$. unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS <br> INPUT VOLTAGE LEVELS (except DCC) <br> Low-level, $\mathrm{V}_{11}$ <br> High-level, $\mathrm{V}_{1 H}$ | 2.2 |  | 0.65 | $\begin{aligned} & V \\ & V \end{aligned}$ | excluding DCC excluding DCC |
| input voltage levels-dCc Low-level, $\mathrm{V}_{\text {II }}$ High-level, $\mathrm{V}_{1 H}$ | 3.5 |  | 0.65 | V |  |
| OUTPUT VOLTAGE LEVELS (DCE Only) Low-level, $\mathrm{V}_{\mathrm{OL}}$ High-level, $\mathrm{V}_{\text {OH }}$ | 2.2 |  | 0.4 | $V$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=1.9 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \end{aligned}$ |
| OUTPUT VOLTAGE LEVELS (except DCE) Low-level, Vo High-level, Vor | 2.2 |  | 0.4 | $\begin{aligned} & V \\ & V \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=0.36 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \end{aligned}$ |
| INPUT CURRENT Low-level, II: |  |  | 10 | $\mu \mathrm{A}$ | $0 \leq \mathrm{V}_{\text {IN }} \leq+5 \mathrm{~V}$ |
| INPUT CAPACITANCE All inputs, Cin (except DCE) $\mathrm{C}_{\text {IN }}$ (DCC Only) |  | $\begin{gathered} 5 \\ 25 \end{gathered}$ |  | $\mathrm{pF}$ | $\begin{aligned} & V_{I N}=G N D \\ & V_{I N}=G N D \end{aligned}$ |
| POWER SUPPLY CURRENT Icc |  | 100 | 120 | mA |  |

AC CHARACTERISTICS

| PARAMETERS | SYMBOL | VALUES |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | TYP. | MAX. |  |
| Frequency of control clock DCC | $\mathrm{f}_{\mathrm{DCC}}$ |  | 1.6 |  | MHz |
| Crystal Frequency CRT 96364A <br> CRT 96364B | $\begin{aligned} & f_{x} \\ & f_{x} \end{aligned}$ |  | $\begin{aligned} & 1.008 \\ & 1.018 \end{aligned}$ |  | $\begin{aligned} & \mathrm{MHz} \\ & \mathrm{MHz} \end{aligned}$ |
| DCC pulse width | $\mathrm{t}_{\mathrm{ccc}}$ | 200 |  |  | ns |
| Rise and fall times | $\begin{aligned} & t_{r} \\ & t_{f} \end{aligned}$ |  | 20 | 40 | ns |
| Refresh memory address access time | $\mathrm{t}_{\mathrm{CA}}$ |  | 200 | 250 | ns |
| Character memory address access time | $\mathrm{t}_{\mathrm{CRO}}$ |  | 200 | 250 | ns |
| PS access time (read) | $\mathrm{t}_{\text {CPS }}$ |  | 300 | 1000 | ns |
| CRV access time | $\mathrm{t}_{\mathrm{CRV}}$ |  | 200 | 250 | ns |
| DCE access time (high to low) | $\mathrm{t}_{\text {DCE }}$ |  | 100 |  | ns |
| SYNC period | $\mathrm{t}_{\text {PS }}$ |  | 64 |  | $\mu \mathrm{s}$ |
| SYNC pulse width | $t_{\text {wp }}$ |  | 4 |  | $\mu \mathrm{s}$ |
| DCE access time (low to high level) | $\mathrm{t}_{\mathrm{sC}}$ |  | 11 |  | $\mu \mathrm{s}$ |
| EOP access time (high to low level) | $\mathrm{t}_{\mathrm{sp}}$ |  | 1 | 1.5 | $\mu \mathrm{s}$ |
| W access time (low to high) | $t_{\text {sw }}$ |  | 500 | 1000 | ns |
| W pulse width | $t_{\text {pw }}$ |  | 4 |  | $\mu \mathrm{s}$ |
| EOP pulse width | teop |  | 10 | $\underline{4}$ | $\mu \mathrm{s}$ |
| Address to rising edge of DCE delay | $\mathrm{t}_{\text {AD }}$ | 0 |  | 2.1 | $\mu \mathrm{s}$ |
| Falling edge of DCE to Address delay | $\mathrm{t}_{\mathrm{DA}}$ | 0 |  | 1 | $\mu \mathrm{s}$ |
| Row to rising edge of DCE delay | $\mathrm{t}_{\text {RD }}$ | 0 |  | 2.1 | $\mu \mathrm{s}$ |
| Falling edge of DCE to row delay | $\mathrm{t}_{\mathrm{DR}}$ | 0 |  | 1 | $\mu \mathrm{s}$ |
| PS to rising edge of DCE delay | $\mathrm{t}_{\text {PSO }}$ | 0 |  |  | $\mu \mathrm{s}$ |

## LINE TIMING



SYNC TIMING


FRAME TIMING


DATA INPUT TIMING
Asynchronous Operation

|  |  | Value |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT |
| DS Pulse Width | $t_{\text {pw }}$ | 0.5 |  |  | $\mu \mathrm{s}$ |
| Cø-C2 Set Up Time | tcos | 1 |  |  | $\mu \mathrm{s}$ |
| Cø-C2 Hold Time | tosc | 90 |  |  | $\mu \mathrm{s}$ |
| Minimum Strobe Period (Operation Execution Time) | tos |  |  |  |  |
| FUNCTION |  | C1 | Cø |  |  |
| Page Erase \& Cursor Home |  | 0 | 0 | 132 | ms |
| Erase to End of Line \& Return Cursor |  | 0 | 1 | 4.2 | ms |
| Line Feed (Cursor Down) |  | 1 | 0 | 130* | $\mu \mathrm{s}$ |
| No Operation |  | 1 | 1 | 80 | $\mu \mathrm{s}$ |
| Cursor Left |  | 0 | 0 | 80 | $\mu \mathrm{s}$ |
| Erasure of Cursor Line |  | 0 | 1 | 8.3 | ms |
| Cursor Up |  | 1 | 0 | 80 | $\mu \mathrm{s}$ |
| Normal Character |  | 1 | 1 | 130* | $\mu \mathrm{s}$ |

*Will increase to 8.3 ms when text scroll occurs. See "Scrolling" for conditions.
Synchronous Operation

|  |  | Value |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT |
| DS Pulse Width | $\mathrm{t}_{\mathrm{p} w}$ | 0.5 |  |  | $\mu \mathrm{s}$ |
| C0-C2 Set-Up Time | tcos | 1 |  |  | $\mu \mathrm{S}$ |
| C0-C2 Hold Time | tose | 16 |  |  | $\mu \mathrm{s}$ |
| DS Set Up Time | tsos | 1 |  |  | $\mu \mathrm{S}$ |
| Minimum Strobe Period (Operation Execution Time) | tos |  |  |  |  |
| FUNCTION |  | C1 | Cø |  |  |
| Page Erase \& Cursor Home |  | 0 | 0 | 132 | ms |
| Erase to End of Line \& Return Cursor |  | 0 | 1 | 4.2 | ms |
| Line Feed (Cursor Down) | (4) | 1 | 0 | 64* | $\mu \mathrm{s}$ |
| No Operation | 篤䍊 | 1 | 1 | 64 | $\mu \mathrm{s}$ |
| Cursor Left |  | 0 | 0 | 64 | $\mu \mathrm{s}$ |
| Erasure of Cursor Line |  | 0 | 1 | 8.3 | ms |
| Cursor Up |  | 1 | 0 | 64 | $\mu \mathrm{S}$ |
| Normal Character |  | 1 | 1 | 64* | $\mu \mathrm{s}$ |

*Will increase to 8.3 ms when text scroll occurs. See "Scrolling" for conditions.


MULTIPLE PAGE DISPLAY
When linking two or more pages, the EOP and PS signals may be used to allow a "moving window" text display. PS (Page Select) indicates the end of page location. If a scroll has occurred, PS will show the transition from the end of line 15 of page $P$ and the beginning of line 0 of page $P+1$.


To properly maintain the memory address when displaying more than two pages, EOP pulses low at the point in time when page $P$ is scrolled completely off the screen. At this time, PS will remain low for the entire frame since page $P+1$ is now the only displayed page.
The circuit at the right will allow scrolling through 4 pages of memory.


## TYPICAL SYSTEM APPLICATION


 information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor at any time in order to improve design and supply the best product possible.

# CRT Video Display Attributes Controller Video Generator VDAC $^{\text {™ }}$ 

## FEATURES

On chip character generator (mask programmable) 128 Characters (alphanumeric and graphic) $7 \times 11$ Dot matrix blockOn chip video shift registerMaximum shift register frequency
CRT 8002A 20 MHz
CRT $8002 \mathrm{~B} \quad 15 \mathrm{MHz}$
CRT $8002 \mathrm{C} \quad 10 \mathrm{MHz}$
Access time 400 nsOn chip horizontal and vertical retrace video blankingNo descender circuitry requiredFour modes of operation (intermixable)
Internal character generator (ROM)
Wide graphics
Thin graphics
External inputs (fonts/dot graphics)On chip attribute logic-character, field Reverse video Character blank Character blink Underline Strike-thru
Four on chip cursor modes
Underline
Blinking underline
Reverse video Blinking reverse videoProgrammable character blink rate
$\square$ Programmable cursor blink rate

PIN CONFIGURATION

$\square$ SubscriptableExpandable character set
External fonts
Alphanumeric and graphic
RAM, ROM, and PROMOn chip address bufferOn chip attribute buffer+5 volt operationTTL compatibleMOS N -channel silicon-gate COPLAMOS ${ }^{\circledR}$ processCLASP ${ }^{\circledR}$ technology-ROM and optionsCompatible with CRT 5027 VTAC®

The SMC CRT 8002 Video Display Attributes Controller (VDAC) is an N -channel COPLAMOS ${ }^{\circledR}$ MOS/LSI device which utilizes CLASP® technology. It contains a 7X11X128 character generator ROM, a wide graphics mode, a thin graphics mode, an external input mode, character address/data latch, field and/or character attribute logic, attribute latch, four cursor modes, two programmable blink rates, and a high speed video shift register. The CRT 8002 VDAC is a companion chip to SMC's CRT 5027 VTAC®. Together these two chips comprise the circuitry required for the display portion of a CRT video terminal.
The CRT 8002 video output may be connected directly to a CRT monitor video input. The CRT 5027 blanking output can be connected directly to the CRT 8002 retrace blank input to provide both horizontal and vertical retrace blanking of the video output.
Four cursor modes are available on the CRT 8002. They are: underline, blinking underline, reverse video block, and blinking reverse video block. Any one of these can be mask programmed as the cursor function. There is a separate cursor blink rate which can be mask programmed to provide a 15 Hz to 2 Hz blink rate.

The CRT 8002 attributes include: reverse video, character blank, blink, underline, and strike-thru. The character blink rate is mask programmable from 7.5 Hz to 1.0 Hz and has a duty cycle of $75 / 25$. The underline and strike-thru are similar but independently controlled functions and can be mask programmed to any number of raster lines at any position in the character block. These attributes are available in all modes.
In the wide graphic mode the CRT 8002 produces a graphic entity the size of the character block. The graphic entity contains 8 parts, each of which is associated with one bit of a graphic byte, thereby providing for 256 unique graphic symbols. Thus, the CRT 8002 can produce either an alphanumeric symbol or a graphic entity depending on the mode selected. The mode can be changed on a per character basis.
The thin graphic mode enables the user to create single line drawings and forms.
The external mode enables the user to extend the onchip ROM character set and/or the on-chip graphics capabilities by inserting external symbols. These external symbols can come from either RAM, ROM or PROM.
Operating Temperature Range . ............................................................................ $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range .................................................................................. . . . $55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0 V
Negative Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 0.3 C
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS ( $\mathrm{T}_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{Vcc}=+5 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS |  |  |  |  |  |
| INPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, $\mathrm{V}_{\text {IL }}$ |  |  | 0.8 | V | excluding VDC |
| High-level, $\mathrm{V}_{1 \mathrm{H}}$ | 2.0 |  |  | V | excluding VDC |
| INPUT VOLTAGE LEVELS-CLOCK |  |  |  |  |  |
| Low-level, $\mathrm{V}_{\text {ii }}$ |  |  | 0.8 | V |  |
| High-level, $\mathrm{V}_{1 \mathrm{H}}$ | 4.3 |  |  | V | See Figure 6 |
| OUTPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, $\mathrm{V}_{\mathrm{O}}$ |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{LL}}=0.4 \mathrm{~mA}, 74 \mathrm{LSXX}$ load |
| High-level, $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-20 \mu \mathrm{~A}$ |
| INPUT CURRENT |  |  |  |  |  |
| Leakage, $\mathrm{I}_{\mathrm{L}}$ (Except CLOCK) |  |  | 10 | $\mu \mathrm{A}$ | $0 \leq V_{\text {IN }} \leq \mathrm{V}_{\text {cc }}$ |
| Leakage, IL (CLOCK Only) |  |  | 50 | $\mu \mathrm{A}$ | $0 \leq V_{\text {IN }} \leq \mathrm{V}_{\text {cc }}$ |
| INPUT CAPACITANCE |  |  |  |  |  |
| Data |  |  |  |  |  |
| LD/SH |  | 20 |  | pF | @ 1 MHz |
| CLOCK |  | 25 |  | pF | @ 1 MHz |
|  |  |  |  |  |  |
| A.C. CHARACTERISTICS |  |  |  |  |  |
| See Figure 6, 7 |  |  |  |  |  |


| SYMBOL | PARAMETER | CRT 8002A |  | CRT 8002B |  | CRT 8002C |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| VDC | Video Dot Clock Frequency | 1.0 | 20 | 1.0 | 15 | 1.0 | 10 | MHz |
| $\mathrm{PW}_{\mathrm{H}}$ | VDC-High Time | 15.0 |  | 23 |  | 40 |  | ns |
| PW ${ }_{\text {L }}$ | VDC-Low Time | 15.0 |  | 23 |  | 40 |  | ns |
| $\mathrm{t}_{\mathrm{Cr}}$ | LD/ $\overline{\mathrm{SH}}$ cycle time | 400 |  | 533 |  | 800 |  | ns |
| $\mathrm{t}_{\mathrm{r} .} \mathrm{t}_{\mathrm{f}}$ | Rise, fall time |  | 10 |  | 10 |  | 10 | ns |
| $\mathrm{t}_{\text {SEI-UP }}$ | Input set-up time | $\geq 0$ |  | $\geq 0$ |  | $\geq 0$ |  | ns |
| $\mathrm{t}_{\text {HoLD }}$ | Input hold time | 15 |  | 15 |  | 15 |  | ns |
| $t_{\text {PDI, }} \mathrm{t}_{\text {PDO }}$ | Output propagation delay | 15 | 50 | 15 | 65 | 15 | 100 | ns |
| $\mathrm{t}_{1}$ | LD/ $\overline{\text { SH }}$ set-up time | 10 |  | 15 |  | 20 |  | ns |
| $\mathrm{t}_{2}$ | LD/ $\overline{S H}$ hold time | 5 |  | 5 |  | 5 |  | ns |




| PIN NO. | SYMBOL | NAME | $\begin{aligned} & \text { INPUT/ } \\ & \text { OUTPUT } \end{aligned}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| 1 | VIDEO | Video Output | 0 | The video output contains the dot stream for the selected row of the alphanumeric, wide graphic, thin graphic, or external character after processing by the attribute logic, and the retrace blank and cursor inputs. <br> In the alphanumeric mode, the characters are ROM programmed into the 77 dots, ( $7 \times 11$ ) allocated for each of the 128 characters. See figure 5 . The top row (RØ) and rows R12 to R15 are normally all zeros as is column C7. Thus, the character is defined in the box bounded by R1 to R11 and Cø to C6. When a row of the ROM, via the attribute logic, is parallel loaded into the 8-bit shift-register, the first bit serially shifted out is C7 (A zero; or a one in REVID). It is followed by C6, C5, through Cø. <br> The timing of the Load/ $\overline{\text { Shift }}$ pulse will determine the number of additional ( -- , zero to $N$ ) backfill zeros (or ones if in REVID) shifted out. See figure 4. When the next Load/ Shift pulse appears the next character's row of the ROM, via the attribute logic, is parallel loaded into the shift register and the cycle repeats. |
| 2 | LD/SH | Load/Shift | I | The 8 bit shift-register parallel-in load or serial-out shift modes are established by the Load/Shift input. When low, this input enables the shift register for serial shifting with each Video Dot Clock pulse. When high, the shift register parallel (broadside) data inputs are enabled and synchronous loading occurs on the next Video Dot Clock pulse. During parallel loading, serial data flow is inhibited. The Address/Data inputs (A $\emptyset-A 7$ ) are latched on the negative transition of the Load/Shift input. See timing diagram, figure 7. |
| 3 | VDC | Video Dot Clock | I | Frequency at which video is shifted. |
| 4-11 | A 0 -A7 | Address/Data | 1 | In the Alphanumeric Mode the 7 bits on inputs (A $\emptyset-A 6$ ) are internally decoded to address one of the 128 available characters ( $A 7=X$ ). In the External Mode, A $\emptyset$-A7 is used to insert an 8 bit word from a user defined external ROM, PROM or RAM into the on-chip Attribute logic. In the wide Graphic Modes A $\emptyset$-A7 is used to define one of 256 graphic entities. In the thin Graphic Mode AØ-A2 is used to define the 3 line segments. |
| 12 | $V_{c c}$ | Power Supply | PS | +5 volt power supply |
| 13,14,15,16 | R2,R3,R1,R̆̈ | Row Address | 1 | These 4 binary inputs define the row address in the current character block. |
| 17 | GND | Ground | GND | Ground |
| 18 | ATTBE | Attribute Enable | 1 | A positive level on this input enables data from the Reverse Video, Character |

A positive level on this input enables data from the Reverse Video, Character
Blank, Underline, Strike-Thru, Blink, Mode Select $\emptyset$, and Mode Select 1 inputs to be strobed into the on-chip attribute latch at the negative transition of the Load/Shift pulse. The latch loading is disabled when this input is low. The latched attributes will remain fixed until this input becomes high again. To facilitate attribute latching on a character by character basis, tie ATTBE high. See timing diagram, figure 7 .
When this input is high and RETBL $=0$, the parallel inputs to the shift register are forced high (SRØ-SR7), providing a solid line segment throughout the character block. The operation of strike-thru is modified by Reverse Video (see table 1). In addition, an on-chip ROM programmable decoder is available to decode the line count on which strike-thru is to be placed as well as to program the strike-thru to be 1 to N raster lines high. Actually, the strike-thru decoder (mask programmable) logic allows the strike-thru to be any number or arrangement of horizontal lines in the character block. The standard strikethru will be a double line on rows R5 and R6.
When this input is high and RETBL $=0$, the parallel inputs to the shift register are forced high (SR@-SR7), providing a solid line segment throughout the character block. The operation of underline is modified by Reverse Video (see table 1). In addition, an on-chip ROM programmable decoder is available to decode the line count on which underline is to be placed as well as to program the underline to be 1 to N raster lines high. Actually, the underline decoder (mask programmable) logic allows the underline to be any number or arrangement of horizontal lines in the character block. The standard underline will be a single line on R11.
When this input is low and RETBL $=0$, data into the Attribute Logic is presented directly to the shift register parallel inputs. When reverse video is high data into the Attribute Logic is inverted and then presented to the shift register parallel inputs. This operation reverses the data and field video. See table 1. When this input is high, the parallel inputs to the shift register are all set low, providing a blank character line segment. Character blank will override blink. The operation of Character Blank is modified by the Reverse Video input. See table 1.
This input is used as the clock input for the two on-chip mask programmable blink rate dividers. The cursor blink rate ( $50 / 50$ duty cycle) will be twice the character blink rate ( $75 / 25$ duty cycle). The divisors can be programmed from $\div 4$ to $\div 30$ for the cursor ( $\div 8$ to $\div 60$ for the character).
When this input is high and RETBL $=0$ and CHABL $=0$, the character will blink at the programmed character blink rate. Blinking is accomplished by blanking the character block with the internal Character Blink clock. The standard character blink rate is 1.875 Hz .
These 2 inputs define the four modes of operation of the CRT 8002 as follows: Alphanumeric Mode - In this mode addresses A $\varnothing$-A6 ( $A 7=X$ ) are internally decoded to address 1 of the 128 available ROM characters. The addressed character along with the decoded row will define a 7 bit output from the ROM to be loaded into the shift register via the attribute logic.
Thin Graphics Mode - In this mode Aø-A2 (A3-A7 $=X$ ) will be loaded into the thin graphic logic along with the row addresses. This logic will define the segments of a graphic entity as defined in figure 2 . The top of the entity will begin on row 0000 and will end on a mask programmable row.

| PIN NO. | SYMBOL | NAME | INPUT/ OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} 25 \\ 26 \\ \text { (cont.) } \end{gathered}$ |  |  |  | External Mode - In this mode the inputs Ag-A7 go directly from the character latch into the shift register via the attribute logic. Thus the user may define external character fonts or graphic entities in an external PROM. ROM or RAM. See figure 3. <br> Wide Graphics Mode-In this mode the inputs A $\emptyset-A 7$ will define a graphic entity as described in figure 1 . Each line of the graphic entity is determined by the wide graphic logic in conjunction with the row inputs Rø to R3. In this mode each segment of the entity is defined by one of the bits of the 8 bit word. Therefore, the 8 bits can define any 1 of the 256 possible graphic entities. These entities can butt up against each other to form a contiguous pattern or can be interspaced with alphanumeric characters. Each of the entities occupies the space of 1 character block and thus requires 1 byte of memory. <br> These 4 modes can be intermixed on a per character basis. |
| 27 | CURSOR | Cursor | 1 | When this input is enabled 1 of the 4 pre-programmed cursor modes will be activated. The cursor mode is on-chip mask programmable. The standard cursor will be a blinking (at 3.75 Hz ) reverse video block. The 4 cursor modes are: Underline-In this mode an underline ( 1 to N raster lines) at the programmed underline position occurs. <br> Blinking Underline-In this mode the underline blinks at the cursor rate. Reverse Video Block-In this mode the Character Block is set to reverse video. <br> Blinking Reverse Video Block-In this mode the Character Block is set to reverse video at the cursor blink rate. The Character Block will alternate between normal video and reverse video. The cursor functions are listed in table 1. |
| 28 | RETBL | Retrace Blank | 1 | When this input is latched high, the shift register parallel inputs are unconditionally cleared to all zeros and loaded into the shift register on the next Load/Shift pulse. This blanks the video, independent of all attributes, during horizontal and vertical retrace time. |


| ROM CHARACTER BLOCK FORMAT |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  | Rows | R3 | R2 | R1 | Rø |
| （ALL ZEROS）$\longrightarrow 0$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | Rø | 0 | 0 | 0 | 0 |
|  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R1 | 0 | 0 | 0 | 1 |
| $\underset{(7 \times 11 \mathrm{RITS}}{77})\left\{\begin{array}{l} 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \end{array}\right.$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R2 | 0 | 0 | 1 | 0 |
|  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R3 | 0 | 0 | 1 | 1 |
|  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R4 | 0 | 1 | 0 | 0 |
|  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R5 | 0 | 1 | 0 | 1 |
|  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R6 | 0 | 1 | 1 | 0 |
|  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R7 | 0 | 1 | 1 | 1 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R8 | 1 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R9 | 1 | 0 | 0 | 1 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R1ø | 1 | 0 | 1 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R11 | 1 | 0 | 1 | 1 |
| （ALL ZEROS）$\{$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R12 | 1 | 1 | 0 | 0 |
|  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R13 | 1 | 1 | 0 | 1 |
|  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R14 | 1 | 1 | 1 | 0 |
|  | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  | R15 | 1 | 1 | 1 | 1 |

＊C7 C6 C5 C4 C3 C2 C1 Cø
＊COLUMN 7 IS ALL ZEROS（REVID $=0$ ） COLUMN 7 IS SHIFTED OUT FIRST

EXTENDED ZEROS（BACK FILL） FOR INTERCHARACTER SPAC－ ING（NUMBER CONTROLLED BY LD／SH，VDC TIMING）

|  |  | 0000 | 001 | 010 | 0011 | 100 | 0101 | 0110 | 111 | 1000 | 001 | 1010 | 011 | 100 | 1701 | 1110 | 111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | C6．．．C0 | C6．．．C0 | C6．．．c0 | C6．．．C0 | C6．．．C0 | C6．．．C0 | C6．．．C0 | C6．．．C0 | C6．．．C0 | C6．．．C0 | C6．．．C0 | C6．．．C0 | C6．．．C0 | C6．．．C0 | C6．．．co | C6．．．c0 |
| 000 | R1 | 明踄噩 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 001 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 010 | Rt |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 011 | R1 |  |  |  | 祸潞 |  |  |  |  |  |  |  |  |  |  |  |  |
| 100 | R1 |  |  |  |  |  |  | 8明踄品 |  |  |  |  |  |  |  |  |  |
| 101 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 110 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 111 | R1 |  |  |  |  |  |  |  | 别㗊㗊 |  | 聐㗊㗊品 |  |  |  |  |  |  |

CONSULT FACTORY FOR CUSTOM FONT AND OPTION PROGRAMMING FORMS．

FIGURE 1
WIDE GRAPHICS MODE

-ON CHIP ROM PROGRAMMABLE TO 2, 3, OR 4 LINE MULTIPLES . CAN BE PROGRAMMED FROM 1 TH


MS $\emptyset=\varnothing$ MS1 $=\varnothing$

$B F=$ back fill

FIGURE 2 THIN GRAPHICS MODE

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

- THE INSIDE SEGMENT IS MASK PROGRAMMABLE

TO ROW 0000

* LENGTH DETERMINED by Ld/SR, vDC timing
$\mathrm{C} 7 \mathrm{C} 6 \mathrm{C} 5 \mathrm{C} 4 \mathrm{C} 3 \mathrm{C} 2 \mathrm{C} 1 \mathrm{C} \varnothing \mathrm{BF} \mathrm{BF} \ldots$


NOTE: When $A 1=" 1$ ", the underline row/rows are deleted. When A $1=$ " 0 ", the underline, if selected, will appear.
$\mathrm{BF}=$ back fill

FIGURE 3
EXTERNAL MODE
MS $\varnothing=1$ MS1=ø


$$
\mathrm{BF}=\text { back fill }
$$

FIGURE 4 TYPICAL VIDEO OUTPUT


## CRT Video Display-Controller Video Generator VDAC'"



## ATTRIBUTES

## Underline

Underline will be a single horizontal line at row R11
Cursor
Cursor will be a blinking reverse video block, blinking at 3.75 Hz

Blink Rate
The character blink rate will be 1.875 Hz
Strike-Thru
$z$ The strike-thru will be a double line at rows R5 and R6

## CRT Video Display－Controller Video Generator VDAC＂

| $A 6 . A^{4}$ |  | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | C6．．．c0 | C6．．．co | C6．．． | C6．．．co | c6．．．co | C6．．．co | C6．．．co | c6． | c6．．．co | c6． | c6．．．co | C6． | c6．．．co | c6．．．co | C6．．．c0 | 6. |
| 000 | R11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 001 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 010 | R11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11 | R11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 100 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 101 | R1 R11 |  |  |  |  |  |  |  |  | ｜ | ｜ | 踄啧品 |  |  |  |  |  |
| 110 | R11 <br> R11 <br> 18 |  |  |  |  |  |  |  |  | ＂ |  |  |  |  |  |  |  |
| 111 | 21 811 |  |  |  | 㗊品品㗊品 |  |  |  |  | 踄品品品品 |  | 踄品品品品 | 蹑㗊㗊品 | 啧詔㗊 |  |  |  |



## ATTRIBUTES

## Underline

Underline will be a single horizontal line at R8

## Cursor

Cursor will be a blinking reverse video block，blinking at 3.75 Hz

## Blink Rate

The character blink rate is 1.875 Hz
Strike－Thru
The strike－thru will be a single horizontal line at R4

## CRT Video Display-Controller Video Generator VDAC"

|  |  | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | C6...co | C6...co | C6...co | C6...co | C6...c0 | C6...co | C6...c0 | C6...co | C6...co | C6...c0 | C6...c0 | C6...c0 | C6...CO | C6...c0 | C6...c0 | C6... CO |
| 000 | R1 <br> R11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 001 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 010 | R1 R11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 011 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 100 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 101 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 110 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 111 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



## ATTRIBUTES

Underline
Underline will be a single horizontal line at R12

## Cursor

Cursor will be a reverse video block

## Blink Rate

The character blink rate is 1.875 Hz

## Strike-Thru

The strike-thru will be a double line at rows R5 and R6

## CRT 8002－011 （ASCII） CODING INFORMATION

## CRT Video Display－Controller Video Generator VDAC ${ }^{\text {＂}}$

|  |  | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 101 | 1110 | 1111 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | C6．．．co | C6．．．c0 | C6．．． C 0 | C6．．．c0 | C6．．．co | c6．．．c0 | C6．．．C0 | C6．．．c0 | C6．．．c0 | C6．．．co | C6．．．c0 | C6．．．c0 | C6．．．C0 | C6．．．C0 | C6．．．C0 | C6．．．c0 |  |
| 000 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 001 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 010 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 011 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 100 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 101 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 㗊㗊㗊品 |  |
| 110 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 111 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



## ATTRIBUTES

## Underline

Underline will be a single horizontal line at R11

## Cursor

Cursor will be a blinking reverse video block， blinking at 3.75 Hz

## Blink Rate

The character blink rate is 1.875 Hz

## Strike－Thru

The strike－thru will be a double line at rows R5 and R6

# CRT Video Display Attributes Controller Video Generator VDAC ${ }^{\text {M }}$ 

## FEATURES

On chip character generator (mask programmable) 128 Characters (alphanumeric and graphic) $7 \times 11$ Dot matrix blockOn chip video shift register Maximum shift register frequency 25 MHzROM Access time 310 nsOn chip horizontal and vertical retrace video blankingNo descender circuitry requiredFour modes of operation (intermixable)Internal character generator (ROM)
Wide graphics
Thin graphics External inputs (fonts/dot graphics)
On chip attribute logic—character, field Reverse video Character blank Character blink Underline Strike-thruOn chip cursorProgrammable character blink rateProgrammable cursor blink rateSubscriptableExpandable character set External fonts Alphanumeric and graphic RAM, ROM, and PROM

## PIN CONFIGURATION



## General Description

The SMC CRT 8002 H Video Display Attributes Controller (VDAC) is an n -channel COPLAMOS ${ }^{\text {© MOS/LSI de- }}$ vice. It contains a 7X11X128 character generator ROM, a wide graphics mode, a thin graphics mode, an external input mode, character address/data latch, field and/or character attribute logic, attribute latch, four cursor modes, two programmable blink rates, and a high speed video shift register. The CRT 8002 H VDAC is a companion chip to SMC's CRT 5027/37 VTAC®. Together these two chips comprise the circuitry required for the display portion of a CRT video terminal.
The CRT 8002 H video output may be connected directly to a CRT monitor video input. The CRT 5027/37 blanking output can be connected directly to the CRT 8002 H retrace blank input to provide both horizontal and vertical retrace blanking of the video output.
The CRT 8002 H attributes include: reverse video, character blank, blink, underline, and strike-thru. The character blink rate is mask programmable from 7.5 Hz to 1.0 Hz and has a duty cycle of $75 / 25$. The underline
and strike-thru are similar but independently controlled functions and can be mask programmed to any number of raster lines at any position in the character block. These attributes are available in all modes.
In the wide graphic mode the CRT 8002 H produces a graphic entity the size of the character block. The graphic entity contains 8 parts, each of which is associated with one bit of a graphic byte, thereby providing for 256 unique graphic symbols. Thus, the CRT 8002 H can produce either an alphanumeric symbol or a graphic entity depending on the mode selected. The mode can be changed on a per character basis.
The thin graphic mode enables the user to create single line drawings and forms.
The external mode enables the user to extend the onchip ROM character set and/or the on-chip graphics capabilities by inserting external symbols. These external symbols can come from either RAM, ROM or PROM.

## MAXIMUM GUARANTEED RATINGS

> Operating Temperature Range $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
> Storage Temperature Range ................................................................................ $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
> Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+325^{\circ} \mathrm{C}$
> Positive Voltage on any Pin, with respect to ground +8.0 V
> Negative Voltage on any Pin, with respect to ground
> *Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
> NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{VcC}=+5 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS <br> INPUT VOLTAGE LEVELS Low-level, $\mathrm{V}_{\text {IL }}$ High-level, $\mathrm{V}_{\mathrm{IH}}$ | 2.0 |  | 0.8 | $\begin{aligned} & V \\ & V \end{aligned}$ | excluding VDC excluding VDC |
| infut voltage levels-clock Low-level, $\mathrm{V}_{\text {IL }}$ High-level, $\mathrm{V}_{\mathrm{IH}}$ | 4.3 |  | 0.8 | $V$ | See Figure 6 |
| OUTPUT VOLTAGE LEVELS Low-level, $\mathrm{V}_{\mathrm{OL}}$ High-level, $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | 0.4 | $\begin{aligned} & V \\ & V \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=0.4 \mathrm{~mA}, 74 \mathrm{LSXX} \text { load } \\ & \mathrm{I}_{\mathrm{OH}}=-20 \mu \mathrm{~A} \end{aligned}$ |
| INPUT CURRENT <br> Leakage, $I_{L}$ (Except CLOCK) <br> Leakage, IL (CLOCK Only) |  |  | $\begin{aligned} & 10 \\ & 50 \end{aligned}$ | ${ }_{\mu \mathrm{A}}^{\mu \mathrm{A}}$ | $\begin{aligned} & 0 \leq V_{1 N} \leq V_{c c} \\ & 0 \leq V_{\mathbb{I N}} \leq V_{c c} \end{aligned}$ |
| INPUT CAPACITANCE Data LD/SH CLOCK |  | 10 20 25 |  | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | @ 1 MHz <br> @ 1 MHz <br> @ 1 MHz |
| POWER SUPPLY CURRENT $I_{c c}$ |  | 100 |  | mA |  |
| A.C. CHARACTERISTICS See Figure 6,7 |  |  |  |  |  |


| SYMBOL | PARAMETER | MIN. | MAX. | UNITS |
| :---: | :---: | :---: | :---: | :---: |
| VDC | Video Dot Clock Frequency | 1.0 | 25 | MHz |
| $\mathrm{PW}_{\mathrm{H}}$ | VDC-High Time | 11.0 |  | ns |
| PW | VDC-Low Time | 11.0 |  | ns |
| tcr | LD/SH cycle time | 310 |  | ns |
| $t_{r}, t_{1}$ | Rise, fall time |  | 9 | ns |
| $t_{\text {SET-UP }}$ | Input set-up time | $\geq 0$ |  | ns |
| thold | Input hold time | 15 |  | ns |
| $\mathrm{t}_{\text {PDI, }} \mathrm{tPDO}$ | Output propagation delay | 15 | 27 | ns |
| $\mathrm{t}_{1}$ | LD/SH set-up time | 5 |  | ns |
| $t_{2}$ | LD/SH hold time | 5 |  | ns |




AC TIMING DIAGRAM

# DESCRIPTION OF PIN FUNCTIONS 



## FUNCTION

The video output contains the dot stream for the selected row of the alphanumeric, wide graphic, thin graphic, or external character after processing by the attribute logic, and the retrace blank and cursor inputs. In the alphanumeric mode, the characters are ROM programmed into the 77 dots, ( $7 \times 11$ ) allocated for each of the 128 characters. See figure 5 . The top row (Rø) and rows R12 to R15 are normally all zeros as is column C7. Thus, the character is defined in the box bounded by R1 to R11 and C $\emptyset$ to C6. When a row of the ROM, via the attribute logic, is parallel loaded into the 8-bit shift-register, the first bit serially shifted out is C7 (A zero; or a one in REVID). It is followed by C6, C5, through Cø.
The timing of the Load/ $\overline{\text { Shift }}$ pulse will determine the number of additional ( - , zero to $N$ ) backfill zeros (or ones if in REVID) shifted out. See figure 4. When the next Load/Shift pulse appears the next character's row of the ROM, via the attribute logic, is parallel loaded into the shift register and the cycle repeats.
The 8 bit shift-register parallel-in load or serial-out shift modes are established by the Load/Shift input. When low, this input enables the shift register for serial shifting with each Video Dot Clock pulse. When high, the shift register parallel (broadside) data inputs are enabled and synchronous loading occurs on the next Video Dot Clock pulse. During parallel loading, serial data flow is inhibited. The Address/Data inputs (AØ-A7) are latched on the negative transition of the Load/Shift input. See timing diagram, figure 7.
Frequency at which video is shifted.
In the Alphanumeric Mode the 7 bits on inputs (A $\varnothing$-A6) are internally decoded to address one of the 128 available characters ( $\mathrm{A} 7=\mathrm{X}$ ). In the External Mode, A $\emptyset-\mathrm{A} 7$ is used to insert an 8 bit word from a user defined external ROM, PROM or RAM into the on-chip Attribute logic. In the wide Graphic Modes A $\varnothing$-A7 is used to define one of 256 graphic entities. In the thin Graphic Mode $A \emptyset$-A2 is used to define the 3 line segments.
+5 volt power supply
These 4 binary inputs define the row address in the current character block. Ground
A positive level on this input enables data from the Reverse Video, Character Blank, Underline, Strike-Thru, Blink, Mode Select $\emptyset$, and Mode Select 1 inputs to be strobed into the on-chip attribute latch at the negative transition of the Load/Shift pulse. The latch loading is disabled when this input is low. The latched attributes will remain fixed until this input becomes high again. To facilitate attribute latching on a character by character basis, tie ATTBE high. See timing diagram, figure 7.
When this input is high and RETBL $=0$, the parallel inputs to the shift register are forced high (SR $\varnothing$-SR7), providing a solid line segment throughout the character block. The operation of strike-thru is modified by Reverse Video (see table 1). In addition, an on-chip ROM programmable decoder is available to decode the line count on which strike-thru is to be placed as well as to program the strike-thru to be 1 to N raster lines high. Actually, the strike-thru decoder (mask programmable) logic allows the strike-thru to be any number or arrangement of horizontal lines in the character block. The standard strikethru will be a double line on rows R5 and R6.
When this input is high and RETBL $=0$, the parallel inputs to the shift register are forced high (SRØ-SR7), providing a solid line segment throughout the character block. The operation of underline is modified by Reverse Video (see table 1). In addition, an on-chip ROM programmable decoder is available to decode the line count on which underline is to be placed as well as to program the underline to be 1 to N raster lines high. Actually, the underline decoder (mask programmable) logic allows the underline to be any number or arrangement of horizontal lines in the character block. The standard underline will be a single line on R11.
When this input is low and RETBL $=0$, data into the Attribute Logic is presented directly to the shift register parallel inputs. When reverse video is high data into the Attribute Logic is inverted and then presented to the shift register parallel inputs. This operation reverses the data and field video. See table 1. When this input is high, the parallel inputs to the shift register are all set low, providing a blank character line segment. Character blank will override blink. The operation of Character Blank is modified by the Reverse Video input. See table 1.
This input is used as the clock input for the two on-chíp mask programmable blink rate dividers. The cursor blink rate ( $50 / 50$ duty cycle) will be twice the character blink rate ( $75 / 25$ duty cycle). The divisors can be programmed from $\div 4$ to $\div 30$ for the cursor $(\div 8$ to $\div 60$ for the character).
When this input is high and RETBL $=0$ and CHABL $=0$, the character will blink at the programmed character blink rate. Blinking is accomplished by blanking the character block with the internal Character Blink clock. The standard character blink rate is 1.875 Hz .
These 2 inputs define the four modes of operation of the CRT 8002 as follows: Alphanumeric Mode- In this mode addresses $A \emptyset-A 6(A 7=X)$ are internally decoded to address 1 of the 128 available ROM characters. The addressed character along with the decoded row will define a 7 bit output from the ROM to be loaded into the shift register via the attribute logic.
Thin Graphics Mode - In this mode $A \emptyset-A 2$ ( $A 3-A 7=X$ ) will be loaded into the thin graphic logic along with the row addresses. This logic will define the segments of a graphic entity as defined in figure 2. The top of the entity will begin on row 0000 and will end on a mask programmable row.

| PIN NO. | SYMBOL | NAME | INPUT/ OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} 25 \\ 26 \\ \text { (cont.) } \end{gathered}$ |  |  |  | External Mode - In this mode the inputs $A \emptyset-A 7$ go directly from the character latch into the shift register via the attribute logic. Thus the user may define external character fonts or graphic entities in an external PROM, ROM or RAM. See figure 3. <br> Wide Graphics Mode - In this mode the inputs AØ-A7 will define a graphic entity as described in figure 1. Each line of the graphic entity is determined by the wide graphic logic in conjunction with the row inputs R $\emptyset$ to R3. In this mode each segment of the entity is defined by one of the bits of the 8 bit word. Therefore, the 8 bits can define any 1 of the 256 possible graphic entities. These entities can butt up against each other to form a contiguous pattern or can be interspaced with alphanumeric characters. Each of the entities occupies the space of 1 character block and thus requires 1 byte of memory. <br> These 4 modes can be intermixed on a per character basis. |
| 27 | CURSOR | Cursor | I | When this input is enabled 1 of the 4 pre-programmed cursor modes will be activated. The cursor mode is on-chip mask programmable. The standard cursor will be a blinking (at 3.75 Hz ) reverse video block. The 4 cursor modes are: Underline-In this mode an underline ( 1 to N raster lines) at the programmed underline position occurs. <br> Blinking Underline-In this mode the underline blinks at the cursor rate. Reverse Video Block-In this mode the Character Block is set to reverse video. <br> Blinking Reverse Video Block-In this mode the Character Block is set to reverse video at the cursor blink rate. The Character Block will alternate between normal video and reverse video. <br> The cursor functions are listed in table 1. |
| 28 | RETBL | Retrace Blank | I | When this input is latched high, the shift register parallel inputs are unconditionally cleared to all zeros and loaded into the shift register on the next Load/Shift pulse. This blanks the video, independent of all attributes, during horizontal and vertical retrace time. |

TABLE 1

| CURSOR | RETBL | REVID | CHABL | UNDL ${ }^{*}$ |  | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | 1 | X | X | X | "0" | S.R. All |
| 0 | 0 | 0 | 0 | 0 | D | (S.R.) All |
| 0 | 0 | 0 | 0 | 1 | "1" | (S.R.)* |
|  |  |  |  |  | D | (S.R.) All others |
| 0 | 0 | 0 | 1 | X | " 0 " | (S.R.) All |
| 0 | 0 | 1 | 0 | 0 | $\overline{\mathrm{D}}$ | (S.R.) All |
| 0 | 0 | 1 | 0 | 1 | " 0 " | (S.R.)* |
|  |  |  |  |  | $\overline{\mathrm{D}}$ | (S.R.) All others |
| 0 | 0 | 1 | 1 | X | "1" | (S.R.) All |
| Underline* | 0 | 0 | 0 | X | "1" | (S.R.) ${ }^{*}$ |
|  |  |  |  |  | D, | (S.R.) All others |
| Underline* | 0 | 0 | 1 | X | "1" | (S.R.)* |
|  |  |  |  |  | "0" | (S.R.) All others |
| Underline* | 0 | 1 | 0 | X | " 0 " | (S.R.)* |
| Underline* | 0 | 1 | 1 | X | "0" | (S.R.)** All others |
|  |  |  |  |  | "1" | (S.R.) All others |
| Blinking** Underline* | 0 | 0 | 0 | X | "1" | (S.R.)* Blinking |
|  |  |  |  |  | D | (S.R.) All others |
| Blinking** Underline* | 0 | 0 | 1 | X | "1" | (S.R.)* Blinking |
|  |  |  |  |  | "0" | (S.R.) All others |
| Blinking** Underline* | 0 | 1 | 0 | X | "0" | (S.R.)* Blinking |
|  |  |  |  |  | D | (S.R.) All others |
| Blinking** Underline* | 0 | 1 | 1 | X | "0" | (S.R.)* Blinking |
|  |  |  |  |  | "1" | (S.R.) All others |
| REVID Black | 0 | 0 | 0 | 0 | D | (S.R.) All |
| REVID Block | 0 | 0 | 0 | 1 | "0] | (S.R.)* |
|  |  |  |  |  | D | (S.R.) All others |
| REVID Block | 0 | 0 | 1 | X | "1" | (S.R.) All |
| REVID Block | 0 | 0 | 0 | 1 | " 0 " | (S.R.)* |
|  |  |  |  |  | $\overline{\text { D }}$ | (S.R.) All others |
| REVID Block | 0 | 1 | 0 | 0 | D | (S.R.) All |
| REVID Block | 0 | 1 | 0 | 1 | "1" | (S.R.)* |
|  |  |  |  |  | D | (S.R.) All others |
| REVID Block | 0 | 1 | 1 | X | "0" | (S.R.) All |
| Blink** REVID Block | 0 | 0 | 0 | 0 | $\left\{\begin{array}{l} \text { Alternate Normal Video/REVID } \\ \text { At Cursor Blink Rate } \end{array}\right.$ |  |
| Blink** REVID Block | 0 | 0 | 0 | 1 |  |  |
| Blink** REVID Block | 0 | 0 | 1 | X |  |  |
| Blink** REVID Block | 0 | 1 | 0 | 0 |  |  |
| Blink** REVID Block | 0 | 1 | 0 | 1 |  |  |
| Blink** REVID Block | 0 | 1 | 1 | X |  |  |

*At Selected Row Decode **At Cursor Blink Rate
Note: If Character is Blinking at Character Rate, Cursor will change it to Cursor Blink Rate.

ROM CHARACTER BLOCK FORMAT

| （ALL ZEROS）$\longrightarrow 0$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | $R \emptyset$ | 0 | 0 | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| （0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R1 | 0 | 0 | 0 | 1 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R2 | 0 | 0 | 1 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R3 | 0 | 0 | 1 | 1 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R4 | 0 | 1 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R5 | 0 | 1 | 0 | 1 |
| 77 BITS $(7 \times 11 \mathrm{ROM})$$\quad\left\{\begin{array}{l}0 \\ 0\end{array}\right.$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R6 | 0 | 1 | 1 | 0 |
| x11ROM） 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R7 | 0 | 1 | 1 | 1 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R8 | 1 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R9 | 1 | 0 | 0 | 1 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R1ø | 1 | 0 | 1 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － |  | R11 | 1 | 0 | 1 | 1 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R12 | 1 | 1 | 0 | 0 |
| （ALIEROS） 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － |  | R13 | 1 | 1 | 0 | 1 |
| （ALL ZEROS）$\left\{\begin{array}{l}0 \\ 0\end{array}\right.$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | － | － | R14 | 1 | 1 | 1 | 0 |
| 0 |  | 0 | 0 | 0 | 0 | 0 | 0 | － |  | R15 | 1 | 1 | 1 | 1 |
| ＊C7 | C6 | C5 | C4 | C3 | C2 | C1 | Cø |  |  |  |  |  |  |  |
| ＊COLUMN 7 IS ALL Z COLUMN 7 IS SHIFT | ROS | （RE | $\text { EVID }=$ IRST | ＝0） |  |  |  |  |  |  |  |  |  |  |


|  |  | 0000 | 0001 | 0010 | 0011 | 0100 | 10 | 0110 | 111 | 1000 | 1001 | 1010 | 1011 | 100 | 1101 | 1110 | 111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | C6．．． C 0 | C6．．．c0 | C6．．．c0 | C6．．．c0 | C6．．．c0 | C6．．．co | C6．．．C0 | C6．．．C0 | C6．．．c0 | C6．．．C0 | C6．．．c0 | C6．．．C0 | C6．．．C0 | C6．．．C0 | C6．．．c0 | C6．．．c0 |
| 000 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 001 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 010 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 踄吅品品 |  |
| 011 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 100 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  | 时品㗊踛 |  |  |
| 101 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 110 | R11 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 111 | R1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

CONSULT FACTORY FOR CUSTOM FONT AND OPTION PROGRAMMING FORMS．

FIGURE 1
WIDE GRAPHICS MODE
MS $\varnothing=\varnothing$ MS1 = $\varnothing$

$\therefore$ ON CHIP ROM PROGRAMMABLE TO 2,3, OR 4 LINE MULTIPLES $\because$ CAN BE PROGRAMMED FROM 1 TO 7 BITS

-     - LENGTH DETERMINED BY LD/SH, VDC TIMING


$B F=$ back fill

FIGURE 2
THIN GRAPHICS MODE



NOTE: When $A 1=$ " 1 ", the underline row/rows are deleted. When $A 1=$ " 0 '", the underline, if selected, will appear.
$\mathrm{BF}=$ back fill

FIGURE 3 EXTERNAL MODE MS $\varnothing=1$ MS1=ø

|  | C7 | C6 | C5 | C4 | C3 | C2 | C1 | C0 | BF | BF | $\cdots$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R $\varnothing-R 15 ~$ | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A 0 | A7 | A7 | $\cdots$ |

$$
B F=\text { back fill }
$$



## Dot Matrix Character Generator

128 Characters of $7 \times 11$ Bits

## FEATURES

On chip character generator (mask programmable) 128 Characters $7 \times 11$ Dot matrix blockOn chip video shift register Maximum shift register frequency| CRT 7004A | 20 MHz |
| :--- | :--- |
| CRT 7004 B | 15 MHz |
| CRT 7004 C | 10 MHz |
| Access time | 400 ns |No descender circuitry requiredOn chip cursorOn chip character address bufferOn chip line address bufferSingle +5 volt power supplyTTL compatibleMOS N-channel silicon-gate COPLAMOS ${ }^{\ominus}$ processCLASP ${ }^{\odot}$ technology - ROMCompatible with CRT 5027 VTAC®Enhanced version of CG5004L-1

## PIN CONFIGURATION



PACKAGE: 24-Pin D.I.P.

## GENERAL DESCRIPTION

SMC's CRT 7004 is a high speed character generator with a high speed video shift register designed to display 128 characters in a $7 \times 11$ dot matrix. The CRT 7004 is an enhanced, pin for pin compatible, version of SMC's CG5004L-1. It is fabricated using SMC's patented COPLAMOS® and CLASP ${ }^{\oplus}$ technologies and employs depletion mode loads, allowing operation from a single +5 v supply. This process permits reduction of turn-around time for ROM patterns. The CRT 7004 is a companion chip to SMC's CRT 5027 VTAC ${ }^{\oplus}$. Together these two chips comprise the circuitry required for the display portion of a CRT video terminal.

FUNCTIONAL BLOCK DIAGRAM


## MAXIMUM GUARANTEED RATINGS*

Operating Temperature Range .............................................................................. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0 V
Negative Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -0.3 V
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{Vcc}=+5 \mathrm{~V} \pm 5 \%$, unless otherwise noted)


| SYMBOL | PARAMETER | CRT 7004A |  | CRT 7004B |  | CRT 7004C |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. |  |
| VDC | Video Dot Clock Frequency | 1.0 | 20 | 1.0 | 15 | 1.0 | 10 | MHz |
| $\mathrm{PW}_{\mathrm{H}}$ | VDC - High Time | 13.5 |  | 21 |  | 36 |  | ns |
| PW ${ }_{\text {L }}$ | VDC - Low Time | 13.5 |  | 21 |  | 36 |  | ns |
| $t_{c r} A S$ | Address strobe to PE high | 400 |  | 533 |  | 800 |  | ns |
| $t_{c r} \mathrm{LS}$ | Line strobe to PE high | 1.0 |  | 1.0 |  | 1.0 |  | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\text {f }}$ | Rise, fall time |  | 10 |  | 10 |  | 10 | ns |
| $\mathrm{t}_{1}$ | PE set-up time | 5 |  | 20 |  | 20 |  | ns |
| $\mathrm{t}_{2}$ | PE hold time | 15 |  | 15 |  | 15 |  | ns |
| $A S_{\text {PW }}$ | Address strobe pulse width | 50 |  | 50 |  | 50 |  | ns |
| LS ${ }_{\text {PW }}$ | Line strobe pulse width | 50 |  | 50 |  | 50 |  | ns |
| $\mathrm{t}_{\text {SEt-UP }}$ | Input set-up time | $\geq 0$ |  | $\geq 0$ |  | $\geq 0$ |  | ns |
| $t_{\text {Hold }}$ | Input hold time | 15 |  | 15 |  | 15 |  | ns |
| $\mathrm{t}_{\text {pd }}, \mathrm{t}_{\text {pdo }}$ | Output propagation delay |  | 45 |  | 60 |  | 90 | ns |

DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 1 | NC | No Connection |  |
| 2 | SO | Serial Output | The output of the dynamic shift register is clocked out on this pin. The serial input to this shift register is internally grounded; thus zeros are shifted in while data is shifted out. |
| 3 | $\mathrm{V}_{\mathrm{cc}}$ | Power Supply | +5 volt supply |
| 4 | LS | Line Strobe | A positive pulse on this input enters data from the L.1, L2, L4, L8 lines into the line address holding register. The LS input may be left open, in which case it is pulled up to $V_{c c}$ by an internal resistor. Data on the L1 to L8 inputs is then entered directly into the register without any latching action. |
| 5 | PRST | Preset | A high level on this input forces the last stage of the shift register and the serial output to a logic high. |
| 6,8,9,10 | $\begin{aligned} & \mathrm{L} 1, \mathrm{~L} 2, \\ & \mathrm{L4}, \mathrm{LB} \end{aligned}$ | Line Address | A binary number $N$, on these four inputs address the $N$ th line of the character font for $N=1-11$. If lines $0,12,13$, 14 or 15 are addressed, the parallel inputs to the shift register are all forced low. |
| 7 | CLR | Clear | A high level on this input forces the last stage of the shift register and the serial output to a logic low and will be latched (for a character time) by PE. Clear overrides preset. |
| 11-17 | A1-A7 | Character Address | The seven-bit word on these inputs is decoded internally to address one of the 128 available characters. |
| 18 | LCI | Lower Case Inhibit | A high level on this input transforms the address of a lower case character into that of the equivalent upper case character. This is internally achieved by forcing A6 low whenever A7 and LCl are high. |
| 19 | AS | Address Strobe | A positive pulse on this input enters data from the A1-A7, LCI and CUR inputs into the holding register. The AS input may be left open, in which case it is pulled up to $V_{c c}$ by an internal resistor. The data on the A1-A7, LCI and CUR inputs is then entered directly into the register without any latching action. |
| 20 | CUR | Cursor* | A high level on this input causes the cursor pattern to be superimposed on the pattern of the character addressed, i.e., the two patterns are OR-ed to generate the parallel inputs to the shift register. The standard cursor is presented as a double underscore on rows 10 and 11. |
| 21 | CLK | Clock | Frequency at which video (SO) is shifted. |
| 22 | NC | No Connection |  |
| 23 | PE | Parallel Enable | A high level on this input loads the word at the output of the ROM into the shift register. The PE input must then be brought low again to allow the shift register to clock out this word. |
| 24 | GND | Ground | Ground |



AC TIMING DIAGRAM



$\qquad$ $\mathrm{CH}\left[\begin{array}{c}\text { oin } \\ 2\end{array}\right.$ $\int_{3}^{\mathrm{CH}} \ldots$ ${ }_{4}^{C+}$ $\qquad$ $\sqrt{\mathrm{CH}}$ | CH |
| :--- |
| 5 |


A1-A7,

PRESET $\qquad$
Clear $\qquad$
SO VIDEO 7 DOT FIELD


SOVIDEO
8 OOT FILLD
 BF = Back Fill

## TYPICAL VIDEO OUTPUT



## NOTE

The differences between the CRT 7004 and CG5004L-1 are detailed below:

## CG5004L-1

1. If both the Preset and Clear inputs are brought high simultaneously the Serial Output is disabled and may be wire-ORed.
2. All Inputs $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-1.5 \mathrm{v}$
3. $\mathrm{SO}_{\mathrm{OL}}=0.4 \mathrm{v} @ \mathrm{I}_{\mathrm{OL}}=0.2 \mathrm{~mA}$
4. Shift Register is static
5. Clear-directly forces the output low; when released, the output is determined by the state of the shift register output.
6. General Timing Differences-See Timing Diagram

CRT 7004

1. Clear overrides Preset, no output disable is possible.
2. All inputs (except CLK) $\mathrm{V}_{\mathrm{IH}}=2.0 \mathrm{v}$, min. $C L K V_{I H}=4.3 \mathrm{v}, \mathrm{min}$.
3. $\mathrm{SO} \mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{v} @ \mathrm{I}_{\mathrm{OL}}=0.4 \mathrm{~mA} 74 \mathrm{LSXX}$ Ioad
4. Shift Register is dynamic
5. Clear directly forces the output low and will be latched (for a character time) by PE.
6. General Timing Differences-See Timing Diagram

CRT 7004-003
(5 X 7 ASCII)
CODING INFORMATION

## Dot Matrix Character Generator

|  | ${ }^{\circ 00}$ ame |  | - ${ }^{\text {an }}$ |  |  | "1) | " ${ }^{\text {m }}$ " |  |  |  |  | $\cdots$ | " ${ }^{\text {m }}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | mome | ${ }^{\text {a }}$ | \% | as | \% | \% | \% | mom | , | ${ }_{\text {a }}^{0}$ | \% | amem | \% | , | , |
| ${ }^{\circ}$ | + | 4 | \# | - | : | $=$ | : | + |  | $\stackrel{+}{*}$ | T. |  | \# |  |  |
| ${ }^{\circ \prime}$ | $\sqrt{2}=$ |  | * | $\pm$ | $4$ | $54$ | $41$ | $14$ | $4$ | $\sqrt{*}$ | $=3$ |  | $0$ | $12$ | . |
| \%om |  |  | \% | \% |  | \% |  |  |  | \% | \% |  |  |  |  |
| o. | W: | We | \% | \% | $4$ |  |  | W |  |  |  |  | = |  |  |
|  |  |  | $1$ | in | $4=$ |  |  |  |  |  |  |  |  | 1 | . |
|  | 2 | $3$ | $2$ |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | $\cdots$ |  |  |  |  | : | : | T | : |  | 7 |  |  |
|  |  |  |  |  |  |  |  |  |  | Meme |  |  |  |  | \# |

The Cursor for the CRT 7004-003 is presented as a double underscore on Rows 8 and 9 .

CRT 9006-135

# Single Row Buffer SRB 

## FEATURES:

Low Cost Solution to CRT Memory Contention ProblemProvides Enhanced Processor Throughput for CRT Display SystemsProvides 8 Bit Wide Variable Length Serial MemoryPermits Active Video on All Scan Lines of Data RowDynamically Variable Number of Characters per Data Row ...64, 80, 132, ... up to a Maximum of 135Cascadable for Data Rows Greater than 135 CharactersStackable for Invisible Attributes or Character Widths of Greater than 8 BitsThree-State Outputs4MHz Typical Read/Write Data RateStatic OperationCompatible with SMC CRT 5037, CRT 9007, and other CRT Controllers24 Pin Dual In Line Package+5 Volt Only Power SupplyTTL Compatible Inputs and OutputsAvailable in 135 Byte Maximum Length (CRT 9006-135) or 83 Byte Maximum Length (CRT 9006-83)PIN CONFIGURATION


## APPLICATIONS:

CRT Data Row BufferBlock-Oriented BufferPrinter BufferSynchronous Communications BufferFloppy Disk Sector Buffer

## GENERAL DESCRIPTION

The SMC Single Row Buffer (SRB) provides a low cost solution to memory contention between the system processor and CRT controller in video display systems.
The SRB is a RAM-based buffer which is loaded with character data from system memory during the first scan line of each data row. While data is being written into the RAM it is also being output through the multiplexer onto the Data Ouput
(DOUT) Lines. During subsequent scan lines in the data row, the system will disable Write Enable (WREN) and cause data to be read out from the internal RAM for CRT screen refresh, thereby releasing the system memory for processor access for the remaining $\mathrm{N}-1$ scan lines where N is the number of scan lines per data row. The SRB enhances processor throughput and permits a flicker-free display of data.


DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 1-4 | DATA OUTPUTS | DOUT3-DOUT0 | Data Outputs from the internal output latch. |
| 5 | CLOCK | CLK | Character clock. The negative-going edge of CLK clocks the latches. When CKEN (pin 8) is high, CLK will increment the address counter. |
| 6 | WRITE ENABLE | WREN | When WREN is low, data from the input latch is transferred directly to the output latch and simultaneously written into sequential locations in the RAM. |
| 7 | CLEAR COUNTER | CLRCNT | A negative transition on CLRCNT clears the RAM address counter. $\overline{\text { CLRCNT }}$ is normally asserted low near the beginning of each scan line. |
| 8 | CLOCK ENABLE | CKEN | When CKEN is high, CLK will clock the address counter. The combination of CKEN high and WREN low will allow the writing of data into the RAM. |
| 9-12 | DATA INPUTS | DIN0-DIN3 | Data Inputs from system memory. |
| 13 | POWER SUPPLY | $\mathrm{V}_{\mathrm{cc}}$ | +5 Volt supply. |
| 14-17 | DATA INPUTS | DIN4-DIN7 | Data Inputs from system memory. |
| 18 | OVERFLOW FLAG | OF | This output goes high when the RAM address counter reaches its maximum count. If cascaded operation of multiple CRT 9006's is desired for more than 135 bytes, OF may be used to drive the CKEN input of the second row buffer chip. |
| 19 | OUTPUT ENABLE | $\overline{O E}$ | When $\overline{O E}$ is low, the data outputs DOUT0-DOUT7 are enabled. When $\overline{O E}$ is high, DOUTØ-DOUT7 present a high impedance state. |
| 20-23 | DATA OUTPUTS | DOUT7-DOUT4 | Data Outputs from the internal output latch. |
| 24 | GROUND | GND | Ground. |

## OPERATION

For CRT operation, the Write Enable (WREN) signal is made active for the duration of the top scan line of each data row. Clear Counter (CLRCNT) typically occurs at the beginning of each scan line (HSYNC may be used as input to CLRCNT). Data is continually clocked into the input latch by CLK. When Clock Enable (CKEN) occurs, the data in the input latch (Write Data) is written into the first location of RAM. At the negative-going edge of the next clock, the address counter is incremented, the next input data is latched into the input latch, and the new data is then written into the RAM. Loading the RAM continues until one clock after CKEN goes inactive or until the

RAM has been fully loaded ( 135 bytes). While data is being written into the RAM, it is also being output through the multiplexer onto the Data Output (DOUT) lines. Each byte is loaded into the output latch one clock time later than it is written into the RAM. Output of the data during the first scan line permits the Video Display Controller (such as the CRT 8002) to display video on the first scan line. During subsequent scanlines in the datarow, the system will disable Write Enable (WREN) and cause data to be read out from the internal RAM, thereby freeing the system memory for processor access for the remaining $\mathrm{N}-1$ scan lines where $N$ is the number of scan lines per datarow.

## MAXIMUM GUARANTEED RATINGS*

Operating Temperature Range $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$\qquad$
Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground . ..................................................................... +8.0 V
Negative Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -0.3 V
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \pm 5 \%$, unless otherwise noted)


FIGURE 1: AC CHARACTERISTICS


FIGURE 2: SINGLE ROW BUFFER READ TIMING


FIGURE 3: SINGLE ROW BUFFER WRITE TIMING



FIGURE 2: TYPICAL CRT CONTROLLER CONFIGURATION WITH SINGLE ROW BUFFER

FIGURE 4:
TYPICAL READ TIMING FOR SRB CASCADED CONFIGURATION


Notes: $\mathrm{N}=134$ FOR CRT9006-135
$N=82$ FOR CRT9006-83
EXAMPLE IS FOR $N+3$ CHARACTERS TOTAL
A, B REFER TO DEVICES A\&B IN FIGURE 5

FIGURE 5:
TYPICAL CASCADE OF SINGLE ROW BUFFERS—270 BYTES TOTAL


[^7]
## Double Row Buffer DRB

## FEATURES

$\square$ Low Cost Solution to CRT Memory
Contention ProblemProvides Enhanced Processor Throughput for CRT Display SystemsReplaces Shift Registers or Several RAM and Counter IC's in CRT Display SystemPermits Display of One Data Row While Next Data Row is Being LoadedData May be Written into Buffer at Less Than the Video Painting RateDouble Data Row Buffer Permits Second Data Row to be Loaded Anytime during the Display of the Preceding Data Row
$\square$ Permits Active Video on All Scan Lines of Data Row

Dynamically Variable Number of Characters per Data Row-...64, 80, 132,... up to a Maximum of 135

Cascadable for Data Rows Greater than 135 Characters

Stackable for "Invisible Attributes"
or Character Widths of Greater than 8 Bits

$\square$ Three-State OutputsUp to 4 MHz Read/Write Data RateCompatible with SMC CRT 5037, CRT 9007, and other CRT Controllers
$\square 28$ Pin Dual-In-Line Package+5 Volt Only Power SupplyTTL Compatible

## GENERAL DESCRIPTION

The CRT 9212 Double Row Buffer (DRB) provides a low cost solution to memory contention between the system processor and the CRT controller in video display systems.

The CRT 9212 DRB is a RAM-based buffer which provides two rows of buffering. It appears to the system as two octal shift registers of dynamically variable length ( $2-135$ bytes) plus steering logic.

The CRT 9212 permits the loading of one data row
while the previous data row is being displayed. The loading of data may take place during any of the scan line times of the data row. This relaxed time-constraint allows the processor to perform additional processing on the data or service other high priority interrupt conditions (such as a Floppy Disk DMA request) which may occur during a single video scan line. The result is enhanced processor throughput and flicker-free display of data.


FIGURE 2: CRT 9212 DOUBLE ROW BUFFER READ TIMING

DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| $\begin{gathered} 3-0,28, \\ 16-13 \end{gathered}$ | Data inputs | DIN0-DIN7 | DINO-DIN7 are the data inputs from the system memory. |
| 12-9, 7-4 | Data outputs | DOUTODOUT7 | DOUT0-DOUT7 are the data outputs from the CRT 9212 internal data output latch. Valid information will appear on DOUTO-DOUT7 two RCLK periods after the rising edge of REN. This introduces two pipeline delays when supplying data to the character generator. |
| 17 | Read Clock | $\overline{\text { RCLK }}$ | $\overline{\mathrm{R} C L K}$ increments the current "read" address register, clocks data through the "read" buffer and moves data through the internal pipeline at the trailing edge. |
| 18 | Toggle Signal | TOG | TOG alternates the function of each buffer between read and write. TOG normally occurs at every data row boundary. Switching of the buffers occurs when both TOG and CLRCNT are low. |
| 19 | Clear Counter | CLRCNT | Clear Counter clears the current "read" address counter at the next RCLK positive edge. CLRCNT is normally asserted low at the beginning of each horizontal retrace interval. CLRCNT clears the current "write" address counter when the TOG is active. |
| 20 | Read Enable | REN | REN enables the loading of data from the selected "read" buffer into the output latch. Data is loaded when Read Clock is active. |
| 21 | Write Overflow | WOF | WOF high indicates that data is being written into the last memory position (position 135). When WOF is high, further writing into the selected "write" buffer is disabled. WOF may be connected to the WEN1 or WEN2 inputs of a second CRT 9212 for cascaded operation where data row lengths of greater than 135 characters are desired. See figure 4. |
| 22 | Read Overflow | ROF | The Read Overflow output is high when data is being read from the last memory position (position 135). ROF high disables further reading from the selected "read" buffer. ROF may be connected to the REN input of a second CRT 9212 for cascaded operation where data row lengths of greater than 135 characters are desired. DOUTO-7 will switch into a high impedance state at the second positive transition of RCLK after ROF goes high. See figure 4. |
| 24, 25 | Write Enable | WEN1. WEN 2 | WEN allows input data to be written into the selected "write" buffer during WCLK active. Both WEN1 and WEN 2 must be high to enable writing. WEN1 has an internal pullup resistor allowing it to assume a high if pin 24 is left open. |
| 26 | Output Enable | $\overline{O E}$ | When the OE input is low, the data outputs DOUTO-DOUT7 are enabled. When OE is high, DOUTO-DOUT7 present a high impedance state. OE has an internal pulldown resistor allowing it to assume a low if pin 26 is left open. |
| 27 | Write Clock | WCLK | WCLK clocks input data into the selected "write" buffer and increments the current "write" address register when WEN1 and WEN2 are high. |
| 8 | Power Supply | $V_{c c}$ | +5 Volt supply |
| 23 | Ground | GND | Ground |

## OPERATION

Figure 1 illustrates the internal architecture of the CRT 9212. It contains 135 bytes of RAM in each of its two buffers. In normal operation, data is written into the input latch on the positive-going edge of Write Clock (WCLK). When both Write Enable (WEN1, WEN 2) signals go high, the next WCLK causes data from the input latch to be written into the selected buffer ( 1 or 2 ) and the associated address counter to be incremented by one. Loading of the selected RAM buffer continues until WEN goes inactive of until the buffer has been fully loaded. At the next data row boundary, the Toggle Signal (TOG) will go low. When Clear Counter (CLRCNT) goes low, the next Read Clock ( $\overline{\mathrm{RCLK}}$ ) will begin to reset both buffer address counters to zero, switching the buffer just loaded from a "write buffer" to a "read buffer", permitting the next row of data to be written into the other buffer. Data from the current "read" buffer is read out of the buffer and to the output latch whenever Read Enable (REN) is high during a Read Clock ( $\overline{\mathrm{RCLK}}$ ). Each read-out from
the buffer RAM causes the "read" address counter to be incremented. REN is normally high during the entire visible line time of each scan line of the data row. CLRCNT resets the present "read" address counter. The negative edge of CLRCNT is detected by the CRT 9212 and the internal "read" address counter is cleared independent of the CLRCNT pulse width. The CLRCNT input may be tied to the REN input for proper operation.

Figures 2 and 3 illustrate the functional timing for reading and writing the CRT 9212. It is possible to cascade two or more CRT 9212's to allow for data storage greater than 135 bytes by employing the read overflow (ROF) and write overflow (WOF) outputs. Figure 4 illustrates two CRT 9212's cascaded together.
The CRT 9212 is compatible with the CRT 9007 video processor and controller (VPAC ${ }^{\text {M }}$ ) and the CRT 8002 video display attributes controller (VDAC ${ }^{\text {rM }}$ ). A typical video configuration employing the three parts is illustrated in figure 5.
Operating Temperature Range $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+325^{\circ} \mathrm{C}$

Negative Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 0.3 l .
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

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


| PARAMETER | MIN | TYP | MAX | UNITS | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DC CHARACTERISTICS INPUT VOLTAGE LEVELS Low Level $\mathrm{V}_{1}$ High Level $V_{1+1}$ High Level VHz $_{\text {H2 }}$ | $\begin{array}{r} 2.0 \\ 4.2 \\ \hline \end{array}$ |  | 0.8 | $\begin{aligned} & v \\ & v \\ & v \\ & \hline \end{aligned}$ | excluding $\overline{R C L K} ;$ WCLK RCLK, WCLK |
| OUTPUT VOLTAGE LEVELS <br> Low Level $\mathrm{V}_{0}$ <br> High Level $\mathrm{V}_{\text {OH }}$ | 2.4 |  | 0.4 | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ |  |
| INPUT LEAKAGE CURRENT High Leakage $\mathrm{I}_{\mathrm{L}+\mathrm{H}}$ Low Leakage $I_{\mathrm{LL}}$, High Leakage $\mathrm{I}_{\mathrm{LH} 2}$ Low Leakage $\mathrm{I}_{\text {L2 }}$ |  |  | $\begin{array}{r} 10 \\ 10 \\ 400 \\ 400 \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \mu \mathrm{~A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ | excluding $\overline{O E}$ excluding WEN1 WEN1 OE |
| INPUT CAPACITANCE $\mathrm{C}_{\mathrm{N} 1}$ <br> $\mathrm{C}_{\mathrm{NW}_{2}}$ |  | $\begin{aligned} & 10 \\ & 15 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | excluding RCLK, WCLK RCLK, WCLK |
| POWER SUPPLY CURRENT $\mathrm{I}_{\mathrm{cc}}$ |  | 100 |  | mA |  |

AC CHARACTERISTICS ${ }^{1}$

| $\mathrm{t}_{\text {crw }}$ | 300 |  |  | ns | Write clock period |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CYR}}$ | 300 |  |  | ns | Read clock period |
| $\mathrm{t}_{\text {ckH }}$ | 247 |  | DC | ns |  |
| $\mathrm{t}_{\mathrm{CKL}}$ | 33 |  |  | ns |  |
| $\mathrm{t}_{\text {ckR }}$ |  |  | 10 | ns | measured from 10\% to 90\% points |
| $\mathrm{t}_{\text {CKF }}$ |  |  | 10 | ns | measured from $90 \%$ to $10 \%$ points |
| $\mathrm{t}_{\mathrm{Ds}}$ | 50 |  |  | ns | referenced to WCLK |
| $\mathrm{t}_{\mathrm{DH}}$ | 0 |  |  | ns | referenced to WCLK |
| $\mathrm{t}_{\text {EN: }}{ }^{2}$ | 0 |  |  | ns |  |
| $\mathrm{t}_{\text {EN2 }}{ }^{2}$ | 100 |  |  | ns |  |
| $\mathrm{t}_{\text {ENH }}{ }^{2}$ | 0 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{Dv}}$ |  |  | 175 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$; referenced from RCLK |
| $\mathrm{t}_{\text {DOFF }}$ |  |  | 175 | ns |  |
| $\mathrm{t}_{\text {DON }}$ |  |  | 175 | ns |  |
| $\mathrm{t}_{0}{ }^{3}$ |  |  | 175 | ns | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{cs}}$ | 100 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{CH}}$ | 0 |  |  | ns |  |
| $t_{\text {wT }}$ |  | $1 t_{\text {cru }}$ |  |  |  |

1 - Reference points for all AC parameters are 2.4 V high and 0.4 V low.
2 - For REN, referenced from RCLK; for WEN1 or WEN2 referenced to WCLK.
3 - For ROF, referenced from RCLK; for WOF referenced from WCLK.
4 - At least 1 WCLK rising edge must occur between CLRCNT or TOG (whichever occurs last) and WEN ( = WEN1-WEN2).


FIGURE 5: CRT 9212 CONFIGURED WITH THE CRT 9007 VPAC AND THE CRT 8002 VDAC $^{\text {M }}$



FIGURE 3: CRT 9212 DOUBLE ROW BUFFER WRITE TIMING


FIGURE 4: CRT 9212 CASCADED CONFIGURATION FOR DATA ROW LENGTHS UP TO 270 CHARACTERS

# CRT Video Attributes Controller Video Generator VAC 

## FEATURES

ON CHIP VIDEO SHIFT REGISTERMaximum shift register frequency -20 MHz
Maximum character clock rate -2.5 MHzON CHIP HORIZONTAL AND VERTICAL RETRACE VIDEO BLANKING
ON CHIP GRAPHICS GENERATIONON CHIP ATTRIBUTE LOGIC-CHARACTER, FIELD
Reverse video
Character blank
Character blink
Underline
Strike-thruON CHIP BLINKING CURSORON CHIP DATA BUFFERON CHIP ATTRIBUTE BUFFER+5 VOLT OPERATIONTTL COMPATIBLE
$\square$
MOS N-CHANNEL SILICON-GATE COPLAMOS® PROCESS

PIN CONFIGURATION


## GENERAL DESCRIPTION

The SMC CRT 8021 Video Attributes Controller (VAC) is an $n$-channel COPLAMOS ${ }^{\circledR}$ MOS/LSI device. It contains wide and thin graphics logic, attributes logic, a data latch, field and character attribute latch, a blinking cursor, and a high speed video shift register. The CRT 8021 VAC is a companion to SMC's CRT $5027 / 37$ VTAC ${ }^{\circledR}$ or CRT 9007 VPAC. The CRT 8021 and a character ROM combined with either a CRT 5027/37 or a CRT 9007 comprises the major circuitry required for the display portion of a CRT video terminal.

The CRT 8021 video output may be connected directly to a CRT monitor video input. The CRT 5027/37 or CRT 9007 blanking output can be connected directly to the CRT 8021 retrace blank input to provide both horizontal and vertical retrace blanking of the video output.
A blinking cursor is available on the CRT 8021. There is a separate cursor blink rate which is twice the character blink rate and has a duty cycle of 50/50.
The CRT 8021 attributes include: reverse video, character blank, blink, underline, and strike-thru. The character blink rate has a duty cycle of $75 / 25$. The underline and
strike-thru are similar but independently controlled functions. These attributes are available in all modes.

The thin graphic mode enables the user to create single line drawings and forms.
In the wide graphic mode the CRT 8021 produces a graphic entity the size of the character block. The graphic entity contains 8 parts, each of which is associated with one bit of a graphic byte, thereby providing 256 unique graphic symbols. Thus, the CRT 8021 can produce either alphanumeric symbols or various graphic entities depending on the mode selected. The mode can be changed on a per character basis.

The CRT 8021 is available in two versions. The CRT 8021 provides an eight-part graphic entity which fills the character block. The CRT 8021 is designed for seven dot wide, nine or eleven dot high characters in nine by twelve or ten by twelve character blocks.
The CRT 8021-003 provides a six part graphic entity for five by seven or five by nine characters in character blocks of up to seven by ten dots.



AC TIMING DIAGRAM

## MAXIMUM GUARANTEED RATINGS*


#### Abstract

Operating Temperature Range $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ Storage Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+325^{\circ} \mathrm{C}$ Positive Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0 V Negative Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-0.3 V$ *Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied. NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.


ELECTRICAL CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS <br> INPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, VIL |  |  | 0.8 | V | excluding VDC |
| High-level, $\mathrm{V}_{\mathrm{IH}}$ | 2.0 |  |  | V | excluding VDC |
| INPUT VOLTAGE LEVELS-CLOCK |  |  |  |  |  |
| Low-level, $\mathrm{V}_{\text {IL }}$ |  |  | 0.8 | V |  |
| High-level, $\mathrm{V}_{1 H}$ | 4.3 |  |  | V | See Figure 7 |
| OUTPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, Vol |  |  | 0.4 | V | $\mathrm{l}_{\mathrm{OL}}=0.4 \mathrm{~mA}, 74 \mathrm{LSXX}$ load |
| High-level, $\mathrm{V}_{\text {OH }}$ | 2.4 |  |  | V | $\mathrm{IOH}=-20 \mu \mathrm{~A}$ |
| INPUT CURRENT |  |  |  |  |  |
| Leakage, IL (Except CLOCK) |  |  | 10 | $\mu \mathrm{A}$ | $0 \leq V_{\text {IN }} \leq V_{C C}$ |
| Leakage, IL (CLOCK Only) |  |  | 50 | $\mu \mathrm{A}$ | $0 \leq V_{\text {IN }} \leq V_{\text {cc }}$ |
| INPUT CAPACITANCE |  |  |  |  |  |
| Data |  | 10 |  | pF | @ 1 MHz |
| LD/ $\overline{\text { SH }}$ |  | 20 |  | pF | @ 1 MHz |
| CLOCK |  | 25 |  | pF | @ 1 MHz |
| POWER SUPPLY CURRENT Icc |  | 100 |  | mA |  |
| A.C. CHARACTERISTICS <br> See Figure 6, 7 |  |  |  |  |  |


| SYMBOL | PARAMETER | CRT 8021 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. |  |
| VDC | Video Dot Clock Frequency | 1.0 | 20 | MHz |
| $\mathrm{PW}_{\mathrm{H}}$ | VDC-High Time | 15.0 |  | ns |
| PW ${ }_{\text {L }}$ | VDC - Low Time | 15.0 |  | ns |
| $\mathrm{t}_{\mathrm{c}} \mathrm{r}$ | LD/ $\overline{\mathrm{SH}}$ cycle time | 400 |  | ns |
| $t_{\text {r }}, \mathrm{t}_{\mathrm{f}}$ | Rise, fall time |  | 10 | ns |
| $t_{\text {SET-UP }}$ | Input set-up time | $\geq 0$ |  | ns |
| $\mathrm{t}_{\text {Hold }}$ | Input hold time | 15 |  | ns |
| $\mathrm{t}_{\text {PDI }}, \mathrm{t}_{\text {PDO }}$ | Output propagation delay | 15 | 50 | ns |
| $t_{1}$ | LD/ $\overline{\mathrm{SH}}$ set-up time | 10 |  | ns |
| $\mathrm{t}_{2}$ | LD/ $\overline{\mathrm{SH}}$ hold time | 5 |  | ns |

# DESCRIPTION OF PIN FUNCTIONS 

| PIN NO. | SYMBOL | NAME | INPUT/ OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| 1 | VIDEO | Video Output | 0 | The video output contains the dot stream for the selected row of the wide graphic, thin graphic, or external character after processing by the attribute logic, and the retrace blank and cursor inputs. <br> The timing of the Load/ $\overline{\text { Shift }}$ pulse will determine the number of additional $(--$, zero to $N$ ) backfill zeros (or ones if in REVID) shifted out. See figure 4. <br> When the next Load/Shift pulse appears the next character via the attribute logic, is paraliel loaded into the shift register and the cycle repeats. |
| 2 | LD/ $\overline{\mathrm{SH}}$ | Load/Shift | 1 | The 8 bit shift-register parallel-in load or serial-out shift modes are established by the Load/Shift input. When low, this input enables the shift register for serial shifting with each Video Dot Clock pulse. When high, the shift register parallel (broadside) data inputs are enabled and synchronous loading occurs on the next Video Dot Clock pulse. During parallel loading, serial data flow is inhibited. The Address/Data inputs (AD-A7) are latched on the negative transition of the Load/Shift input. See timing diagram, figure 1. |
| 3 | VDC | Video Dot Clock | I | Frequency at which video is shifted. |
| 4-11 | A0-A7 | Address/Data | 1 | In the External Mode, A0-A7 is used to insert an 8 bit word from a user defined external ROM, PROM or RAM into the on-chip Attribute logic. In the wide Graphic Mode A $\emptyset-A 7$ is used to define one of 256 graphic entities. In the thin Graphic Mode A $\emptyset-A 2$ is used to define the 3 line segments. |
| 12 | V cc | Power Supply | PS | +5 volt power supply. |
| 13, 14, 15, 16 | R2, R3, R1, Rø | Row Address | 1 | These 4 binary inputs define the row address in the current character block. |
| 17 | GND | Ground | GND | Ground |
| 18 | ATTBE | Attribute Enable | 1 | A positive level on this input enables data from the Reverse Video, Character Blank, Underline, Strike-Thru, Blink, Mode Select $\emptyset$, and Mode Select 1 inputs to be strobed into the on-chip attribute latch at the negative transition of the Load/Shift pulse. The latch loading is disabled when this input is low. The latched attributes will remain fixed until this input becomes high again. To facilitate attribute latching on a character by character basis, tie ATTBE high. See timing diagram, figure 1. |
| 19 | STKRU | Strike-Thru | 1 | When this input is high and RETBL $=0$, the parallel inputs to the shift register are forced high (SR0-SR7), providing a solid line segment throughout the character block. The operation of strike-thru is modified by Reverse Video (see table 1). The strike-thru is a double line on rows R5 and R6 for the CRT 8021 and a single line on row R4 for the CRT 8021-003. |
| 20 | UNDLN | Underline | 1 | When this input is high and RETBL $=0$, the parallel inputs to the shift register are forced high (SR0-SR7), providing a solid line segment throughout the character block. The operation of underline is modified by Reverse Video (see table 1). The underline is a single line of R11 for the CRT 8021 and a single line on R8 for the CRT 8021-003. |
| 21 | REVID | Reverse Video | 1 | When this input is low and RETBL $=0$, data into the Attribute Logic is presented directly to the shift register parallel inputs. When reverse video is high data into the Attribute Logic is inverted and then presented to the shift register parallel inputs. This operation reverses the data and field video. See table 1. |
| 22 | CHABL | Character Blank | 1 | When this input is high, the parallel inputs to the shift register are all set low, providing a blank character line segment. Character blank will override blink. The operation of Character Blank is modified by the Reverse Video input. See table 1. |
| 23 | $V$ SYNC | V SYNC | 1 | This input is used as the clock input for the two on-chip blink rate dividers. The cursor blink rate ( $50 / 50$ duty cycle) will be twice the character blink rate (75/25 duty cycle). |
| 24 | BLINK | Blink | 1 | When this input is high and RETBL $=0$ and $\mathrm{CHABL}=0$, the character will blink at the character blink rate. Blinking is accomplished by blanking the character block with the internal Character Blink clock. The character blink rate is 1.875 Hz when V SYNC $=60 \mathrm{~Hz}$. |
| $\begin{aligned} & 25 \\ & 26 \end{aligned}$ | MS1 MS $\emptyset$ | Mode Select 1 Mode Select $\emptyset$ | $1$ | These 2 inputs define the three modes of operation of the CRT 8002 as follows: <br> Thin Graphics Mode - In this mode A0-A2, (A3-A7 $=X$ ) will be loaded into the thin graphic logic along with the row addresses. This logic will define the segments of a graphic entity as defined in figure 6. <br> Character Mode - In this mode the inputs A0-A7 go directly from the character latch into the shift register via the attribute logic. Thus the user may define external character fonts or graphic entities in an external PROM, ROM or RAM. See figure 3. <br> Wide Graphics Mode-In this mode the inputs A0-A7 will define a graphic entity as described in figure 5 . Each line of the graphic entity is determined by the wide graphic logic in conjunction with the row inputs Rø to R3. In this mode each segment of the entity is defined by one of the bits of the 8 bit word. Therefore, the 8 bits can define any 1 of the 256 possible graphic entities. These entities can butt up against each other to form a contiguous pattern or can be interspaced with alphanumeric characters. Each of the entities occupies the space of 1 character block and thus requires 1 byte of memory. <br> These 3 modes can be intermixed on a per character basis. |
|  | MS1 | MS0 M | DE |  |
|  | 1 0 0 | Thin Graphics Character Mode Wide Graphics |  |  |
| 27 | CURSOR | Cursor | 1 | When this input is enabled the cursor will be activated. The cursor will be a blinking(at 3.75 Hz when V SYNC $=60 \mathrm{~Hz}$ ) reverse video block. In this mode the Character Block is set to reverse video at the cursor blink rate. The Character Block will alternate between normal video and reverse video. |
| 28 | RETBL | Retrace Blank | 1 | When this input is latched high, the shift register parallel inputs are unconditionally cleared to all zeros and loaded into the shift register on the next Load/Shift pulse. This blanks the video, independent of all attributes, during horizontal and vertical retracetime. |

TABLE 1

| CURSOR | RETBL | REVID | CHABL | UNDLN* |  | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | 1 | X | X | X | "0" | (S.R.) All |
| 0 | 0 | 0 | 0 | 0 | D | (S.R.) All |
| 0 | 0 | 0 | 0 | 1 | "1" | (S.R.)* |
|  |  |  |  |  | D | (S.R.) All others |
| 0 | 0 | 0 | 1 | $X$ | " 0 " | (S.R.) All |
| 0 | 0 | 1 | 0 | 0 | $\overline{\text { D }}$ | (S.R.) All |
| 0 | 0 | 1 | 0 | 1 | $\stackrel{0}{\prime \prime}$ | (S.R.)* <br> (S.R.) All others |
| 0 | 0 | 1 | 1 | $x$ | "1" | (S.R.) All |
| Blink** REVID Block | 0 | 0 | 0 | 0 | [ |  |
| Blink** REVID Block | 0 | 0 | 0 | 1 | $\left\{\begin{array}{l}\text { Alternate Normal Video/REVID } \\ \text { At Cursor Blink Rate }\end{array}\right.$ |  |
| Blink** REVID Block | 0 | 0 | 1 | $X$ |  |  |
| Blink** REVID Block | 0 | 1 | 0 | 0 |  |  |
| Blink** REVID Block | 0 | 1 | 0 | 1 |  |  |
| Blink** REVID Block | 0 | 1 | 1 | X |  |  |

*At Selected Row Decode **At Cursor Blink Rate
Note: If Character is Blinking at Character Rate, Cursor will change it to Cursor Blink Rate

FIGURE 2
TYPICAL CHARACTER MODE BLOCK FORMATS


Note: Dotted line shows typical character display area.

FIGURE 3
CHARACTER MODE MS $0=1$ MS1 $=0$

|  | C7 | C6 | C5 | C4 | C3 | C 2 | C1 | C 0 | BF | BF | ... |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RD-R15 | A7 | A6 | A5 | A4 | A3 | A2 | A1 | AØ | A7 | A7 | $\ldots$ |

$B F=$ back fill

FIGURE 4. TYPICAL VIDEO OUTPUT-CHARACTER MODE


FIGURE 5 WIDE GRAPHICS MODE

MS0 $=0$ MS1 $=0$

*ON CHIP ROM PROGRAMMABLE TO 2, 3, OR 4 LINE MULTIPLES *-CAN BE PROGRAMMED FROM 1 TO 7 BITS


CRT 8021


CRT 8021-003


FIGURE 6
THIN GRAPHICS MODE MS0 = 0 MS1 = 1

CRT 8021


CRT 8021-003

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

- THE INSIDE SEGMENT IS MASK PROGRAMMABLE
* LENGTH DETERMINED BY LD/SH, VDC TIMING


## FIGURE 7



FIGURE 8
TYPICAL CRT 8021 CONFIGURATION FOR COMBINED CHARACTER AND GRAPHICS MODES



FIGURE 9. CRT 8021 TYPICAL $\mu$ P CONFIGURATION (CHARACTER MODE ONLY)

# CRT Video Attributes Controller VAC 

## FEATURES

On chip video shift register ( 28.5 MHz max.)On chip attributes logic Reverse video Character blank Character blink Underline Full/half intensityFour modes of operationWide graphics
Thin graphics
Character mode without underline Character mode with underlineOn Chip logic for double height/double width characters
$\square$ Accepts scan line information in parallel or serial formatFour cursor modes dynamically selectable via 2 input pins

Underline
Blinking underline
Reverse video
Blinking reverse videoProgrammable character blink rate
$\square$ Programmable cursor blink rate

PIN CONFIGURATION


On chip data and attribute latches+5 volt operation
TTL compatible
MOS n-Channel silicon gate COPLAMOS® process
Compatible with CRT 5037 VTAC ${ }^{\circledR}$; CRT 9007 VPAC ${ }^{\text {™ }}$

## GENERAL DESCRIPTION

The SMC CRT 9021 Video Attributes Controller (VAC) is an n-channel COPLAMOS MOS/LSI device containing Graphics logic, attributes logic, data and attributes latches, cursor control, and a high speed video shift register. The CRT 9021, a character generator ROM and a CRT controller such as the CRT 9007 provide all of the major circuitry for the display portion of a CRT video terminal.
The CRT 9021 serial video output may be connected directly to a CRT monitor's video input. The maximum video shift register frequency of 28.5 MHz allows for CRT displays of up to 132 characters per data row.

The CRT 9021 attributes include: reverse video, underline, character blank, character blink, and full/ half intensity selection. In addition, when used in conjunction with the CRT 9007 VPAC, ${ }^{\text {TM }}$, the CRT 9021 will provide double height or double width characters.

Four programmable cursor modes are provided on the CRT 9021. They are: underline, blinking under-
line, reverse video character block, and blinking reverse video character block. When used in the serial scan line input mode, the cursor mode may be selected via two input pins. When used in the parallel scan line input mode, the cursor mode is a mask program option and is fixed at the time of manufacture.

Two graphics modes are provided. In the wide graphics mode, the CRT 9021 produces a graphic entity the size of the character block. The graphic entity contains eight parts, each of which is associated with one bit of the input byte, thereby providing 256 unique graphic symbols. The thin graphics mode enables the user to create thin line drawings and forms.

In both graphics modes, continuous horizontal and vertical lines may be drawn. Additional flexibility is provided by allowing the mask programming of the placement and dimensions of the blocks or lines within a character block. In the thin graphics mode, mask programming allows serrated horizontal or vertical lines.


FIGURE 1: CRT 9021 BLOCK DIAGRAM

## DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| $\begin{gathered} 1,28,27,26, \\ 25,24,23, \\ 22 \end{gathered}$ | Data | D7-D0 | In the character mode, the data on these inputs is passed through the Attributes logic into the 8 bit high speed video shift register. The binary information on D7 will be the first bit output after the LD/SH input goes low. <br> In the thin or wide graphics mode these 8 inputs will individually control the on/off condition of the particular portion of the character block or line drawing. Figures 2 and 3 illustrate the wide and thin graphics modes respectively and their relationships to D7-D0 |
| $\begin{aligned} & 2 \\ & 3 \end{aligned}$ | Mode Select 0 Mode Select 1 | $\begin{aligned} & \hline \text { MS0 } \\ & \text { MS1 } \end{aligned}$ | These 2 inputs define the four modes of operation of the CRT 9021 as follows: <br> MS1, MS0 $=00$; Wide graphics mode <br> $=10$; Thin graphics mode <br> = 01; Character mode without underline <br> = 11; Character mode with underline <br> See section entitled Display Modes for details. |
| 4 | Reverse Video | REVID | When this input and Retrace Blank (RETBL) are both low, data from the Attributes and Graphics logic is presented directly to the video shift register. When this input is high and RETBL is low, the Attribute and Graphics logic will invert the data before presenting it to the video shift register. |
| 5 | Character blank | CHABL | When this input is high, the parallel inputs to the video shift register are all set low (or high depending on the state of REVID) thus providing a constant video level for the entire length of the character block. |
| 6 | Blink | BLINK | When this input is high and both the RETBL and CHABL inputs are low, the character will blink at the programmed character blink rate. Blinking is accomplished by causing the video to go to the background level during the "off" portion of the Character Blink cycle. This video level may be either the white or black level depending on state of REVID. The duty cycle for the character blink is $75 / 25$ (on/ off). This input is ignored if it coincides with the CURSOR input and the cursor is formatted to blink. |
| 7 | Intensity In | INTIN | The INTIN input along with the INTOUT output provides a user controlled general purpose attribute. Data input to INTIN will appear at INTOUT with the same delay as that from any other attribute input to the serial video output (VIDEO). By using an external mixing circuit, it is possible to raise or lower the voltage level of the video output to produce such attributes as "half intensity" or "intensity". |

DESCRIPTION OF PIN FUNCTIONS CONT'D
$\left.\begin{array}{|c|l|c|l|}\hline \text { PIN NO. } & \text { NAME } & \text { SYMBOL } & \text { FUNCTION } \\ \hline 8 & \text { Supply Voltage } & \text { +5V } & \text { +5 volt power supply } \\ \hline 9 & \begin{array}{l}\text { Attribute } \\ \text { Enable }\end{array} & \text { ATTEN } & \begin{array}{l}\text { When this input is high, the internal attribute latch is updated at the positive going } \\ \text { edge of the LD/SH input with data appearing on the REVID, CHABL, MS1, MS0, } \\ \text { BLINK and INTIN inputs. By selectively bringing this input high, the user will }\end{array} \\ \text { update the attribute only at specific character times; all subsequent characters } \\ \text { will carry with them the attributes last updated thus allowing "field" or "embed- } \\ \text { ded" attributes. When using a wide video memory where attribute bits are } \\ \text { attached to every character, the internal attribute latch may be updated at each } \\ \text { character by tieing this input high (thus allowing for "invisible" attributes). }\end{array}\right\}$

## ATTRIBUTES FUNCTION

| Retrace Blank | -The RETBL input causes the VIDEO to go to the zero (black) level regardless of the state of all other inputs. |  | grammed to blink (not controlled by the BLINK input), the video alternates from normal to reverse video at |
| :---: | :---: | :---: | :---: |
| Reverse Video | -The REVID input causes inverted data to be loaded into the video shift register. |  | $50 \%$ duty cycle. The cursor blink rate always overrides the character blink rate when they both appear at the |
| Character Blank | -The CHABL input forces the video to go to the current background level as defined by Reverse Video. | Intensity (Half Intensity) | same character position. <br> -The INTIN input and the INTOUT output allow an intensity (or half |
| Underline | $-\mathrm{MS} 1, \mathrm{MS0}=1,1$ forces the video to go to the inverse of the background level for the scan line(s) programmed for underline. |  | intensity) attribute to be carried through the pipeline of the CRT 9021 An external mixer can be used to combine VIDEO and INTOUT to cre |
| Blink | -The BLINK input will cause characters to blink by forcing the video to the background level $25 \%$ of the time and allowing the normal video for $75 \%$ of the time. When the cursor is pro- | Table 1 illustra attributes as a SOR and RET | ate the desired video level. See figure 8. <br> effect of the REVID, CHABL, UNDLN on of the cursor format and the CURouts. |

TABLE 1: CRT 9021 ATTRIBUTE COMBINATIONS

| CURSOR FORMAT | CRT 9021 INPUTS |  |  |  |  | VIDEO SHIFT REGISTER LOADED WITH: |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RETBL | CURSOR | REVID | CHABL | UNDLN |  |  |
| X | 1 | X | X | X | X | all zero's |  |
|  | 0 | 0 | 0 | 0 | 0 | data |  |
|  | 0 | 0 | 0 | 0 | 1 | One's for selected scan line(s); Data for all other scan lines. |  |
|  | 0 | 0 | 0 | 1 | X | All zero's |  |
|  | 0 | 0 | 1 | 0 | 0 | data |  |
|  | 0 | 0 | 1 | 0 | 1 | Zero's for selected scan line(s); data for all other scan lines. |  |
|  | 0 | 0 | 1 | 1 | $X$ | One's for all scan lines. |  |
|  | 0 | 1 | 0 | 0 | X | One's for selected scan line(s) for cursor; data for all other scan lines. |  |
| UN | 0 | 1 | 0 | 1 | $\mathrm{X}^{1}$ | One's for selected scan line(s) for cursor; zero's for all other scan lines. |  |
| NDERLINE | 0 | 1 | 1 | 0 | X | Zero's for selected scan line(s) for cursor; Data for all other scan lines. |  |
|  | 0 | 1 | 1 | 1 | ${ }^{1}$ | Zero's for selected scan line(s) for cursor; one's for all other scan lines. |  |
|  | 0 | 1 | 0 | 0 | X | One's for selected scan line(s) blinking; Data for all other scan lines. |  |
| BLINKING ${ }^{3}$ | 0 | 1 | 0 | 1 | X ${ }^{1}$ | One's for selected scan line(s) blinking; zero's for all other scan lines. |  |
| UNDERLINE ${ }^{2}$ | 0 | 1 | 1 | 0 | X | Zero's for selected scan line(s) blinking; Data for all other scan lines. |  |
|  | 0 | 1 | 1 | 1 | $\mathrm{X}^{\prime}$ | Zero's for selected scan line(s) blinking; one's for all other scan lines. |  |
|  | 0 | 1 | 0 | 0 | 0 | Data for all scan lines. |  |
|  | 0 | 1 | 0 | 0 | 1 | Zero's for selected scan line(s) for underline; data for all other scan lines. |  |
| REVIDBLOCK | 0 | 1 | 0 | 1 | $X$ | One's for all scan lines. |  |
| Revidblock | 0 | 1 | 1 | 0 | 0 | Data for all scan lines |  |
|  | 0 | 1 | 1 | 0 | 1 | One's for selected scan line(s) for underline; data for all other scan lines. |  |
|  | 0 | 1 | 1 | 1 | X | Zero's for all scan lines. |  |
| BLINKING ${ }^{3}$ REVID BLOCK | 0 | 1 | 0 | 0 | 0 | On <br> $\overline{\text { Data }}$ for all scan lines. | Off <br> Data for all scan lines. |
|  | 0 | 1 | 0 | 0 | 1 | Zero's for selected scan line(s) for underline; Data for all other scan lines. | One's for selected scan line(s) for underline; Data for all other scan lines. |
|  | 0 | 1 | 0 | 1 | X | One's for all scan lines. | Zero's for all scan lines. |
|  | 0 | 1 | 1 | 0 | 0 | Data for all scan lines. | Data for all scan lines. |
|  | 0 | 1 | 1 | 0 | 1 | One's for selected scan line(s); Data for all other scan lines. | Zero's for selected scan line(s); Data for all other scan lines. |
|  | 0 | 1 | 1 | 1 | X | Zero's for all scan lines. | One's for all scan lines. |

[^8]
## DISPLAY MODES

Inputs MS1 and MS0 select one of four display modes. All attributes except underline operate independent of the display mode used. Figures 8 a and 8 b illustrate a typical CRT 9021 configuration which operates in all display modes for both the parallel and serial scan line modes respectively. MS1, MS0 = 00 $\begin{aligned} & \text { - Wide Graphics Mode. } \\ & \text { In this display mode, inputs D7-D0 }\end{aligned}$ In this display mode, inputs D7-D0
define a graphics entity as illustrated in figure 2. Note that individual bits in D7-D0 will illuminate particular portions of the character block. Table 2 shows all programming ranges possible when defining the wide graphic boundaries. No underline is possible in this display mode.
MS1, MSO = 10

MS1, MSO = 01

MS1,MS0 = 11
the character block. Table 3 shows all programming ranges possible when defining the thin graphics boundaries. No underline is possible in this display mode.
-Character Mode Without Underline. In this display mode, inputs D7-D0 go directly from the input latch to the video shift register via the Attributes and Graphics logic. This mode requires either a bit mapped system RAM ( 1 bit in RAM equals 1 pixal on the CRT) or an external character generator as shown in figures 8 a and 8 b .
-Character Mode With Underline. Same operation as MS1, MS0 $=01$ with the underline attribute appearing on the scan line(s) mask programmed.

SL3-SL0 ROW \# C7 C6 C5 C4 C3 C2 C1 C0 BF BF o o o


FIGURE 2: WIDE GRAPHICS MODE FOR STANDARD CRT 9021


FIGURE 3: THIN GRAPHICS MODE FOR STANDARD CRT 9021

## BACKFILL

Backfill is a mechanism that allows a character width of Method B greater than 8 dots and provides dot information (usually blanks) for all dot positions beyond 8 . The character width is defined by the period of the LD/SH input. For the character modes, backfill is added to the tail end of the character by two methods which are mask programmable.
Method A - The backfill (BF) dots will be the same as the dot displayed in position C7.

- The backfill (BF) dots will be the same as the dot displayed in position C 0 .

For the wide graphics mode, the backfill dots will always be the same as the dot displayed in position C0 (method B) with no programmable option.

## CURSOR FORMATS

Four cursor formats are possible with the CRT 9021. If the parallel scan line input mode is used, one of four cursor formats may be selected as a mask programmed option. If the serial scan line input mode is used, the cursor format is selected via input pins 16 and 17 (SL3/BKC, SL2/BLC). See Table 5. The four cursor modes are as follows:

Underline $\quad$ - The cursor will appear as an underline. The position and width of the cursor underline is mask programmed.
Blinking Underline - The cursor will appear as an underline. The underline will alternate between normal and reverse video at the mask programmed cursor blink rate.
Reverse Video Block

Blinking Reverse Video Block
cell will be displayed in reverse video).
-The cursor will appear as a reverse video block and the entire block (character plus background) will alternate between normal and reverse video at the masked programmed cursor blink rate.

| Scan Line <br> Input Mode | Pin 17 | Pin 16 | Cursor Function |
| :---: | :---: | :---: | :---: |
|  | 0 | 0 | Underline <br> Serial1 <br> 1 |
| Parallel | X | X | Reverse Video Block <br> Blinking Underline <br> Blinking Reverse <br> Video Block |
|  | X | Mask programmable <br> Only |  |

TABLE 5: CURSOR FORMATS

## DOUBLE WIDTH MODE

In order to display double width characters, video must be shifted out at half frequency and the video shift register must receive new information (parallel load) every other $\overline{\mathrm{LD}} / \mathrm{SH}$ input pulse. In order to divide the video dot clock (VDC) and the $\overline{L D} / S H$ pulse internally at the proper time, the cursor input should be pulsed during RETBL prior to the scan line to be displayed as double width. The CURSOR input must remain low for a minimum of $1 \overline{\mathrm{LD}} / \mathrm{SH}$ period from the leading edge of RETBL. The CURSOR input can stay high for the entire RETBL time but should not extend into active video. If it does, a cursor will be displayed. It is assumed that the CRT con-
troller knows when a particular scan line should be double width and it should activate the CURSOR in the manner just described. Double height/double width characters can also be displayed if the scan line count is incremented by the CRT controller every other scan line. With respect to the CRT 9021, no distinction between double width and double height display is necessary. Figure 4 illustrated timing for both single and double width modes. The CRT 9007, which supports double height double width characters, will produce the CURSOR signal as required by the CRT 9021 with no additional hardware.

## SCAN LINE INPUT MODES

Scan line information can be introduced into the CRT 9021 in parallel format or serial format. Table 6 illustrates the pin definition as a function of the scan line input mode. The CRT 9021 will automatically recognize the proper scan line mode by observing the activity on pin 18. In parallel mode, this input will be stable for at least 1 scan line and in serial mode this input will remain low for about 5 or $6 \overline{\mathrm{LD} / S H}$ periods. If pin 18 goes active low for less than seven but more than two continuous $\overline{\mathrm{LD}} / \mathrm{SH}$ periods during the last scan line that has an active low on the VSYNC input, the serial mode will be locked in for the next field. The parallel scan line input
mode will be selected for the next field if the following two conditions occur during VSYNC low time. First, at least one positive transition must occur on pin 18 and second, pin 18 must be low for seven or more $\overline{L D} / \mathrm{SH}$ periods. Refer to figure 7 for timing details.

| Scan Line <br> Input Mode | CRT 9021 Pin Number |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | 19 | 18 | 17 | 16 |
| Serial | SLD | SLG | BLC | BKC |
| Parallel | SL0 | SL1 | SL2 | SL3 |

TABLE 6: PIN DEFINITION FOR PARALLEL AND SERIAL SCAN LINE MODES

## PROGRAM OPTIONS

The CRT 9021 has a variety of mask programmed options. Tables 2 and 3 illustrate the range of these options for the wide and thin graphics modes respectively. Table 4 illus-
trates the range of the miscellaneous mask programmed options. In addition, Tables 2, 3 and 4 show the mask programmed options for the standard CRT 9021.


FIGURE 4: CRT 9021 FUNCTIONAL I/O TIMING

## SECTION V

## MAXIMUM GUARANTEED RATINGS*


*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.


| PARAMETER | MIN | TYP | MAX | UNIT | COMMENTS ${ }^{\text {sech }}$ cition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DC CHARACTERISTICS INPUT VOLTAGE LEVELS <br> Low Level $\mathrm{V}_{11}$ <br> High Level $V_{1+1}$ <br> High Level $\mathrm{V}_{1+2}$ | $\begin{aligned} & 2.0 \\ & 4.3 \\ & \hline \end{aligned}$ |  | 0.8 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ | All inputs except VDC, $\overline{\mathrm{LD}} / \mathrm{SH}$ For VDC, $\overline{\mathrm{LD}} / \mathrm{SH}$ input |
| OUTPUT VOLTAGE LEVELS Low Level $V_{o L}$ High Level $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | 0.4 | $\begin{aligned} & V \\ & V \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=0.4 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=100 \mu \mathrm{~A} \end{aligned}$ |
| INPUT LEAKAGE CURRENT <br> Leakage $\mathrm{I}_{\mathrm{L}}$ <br> Leakage $\mathrm{I}_{12}$ |  |  | $\begin{array}{r} 10 \\ 50 \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ | $0 \leqslant \mathrm{~V}_{1 \mathrm{~N}}<\mathrm{V}_{\mathrm{cc}}$; excluding VDC, $\overline{\mathrm{LD}} / \mathrm{SH}$ $0 \leqslant V_{1 N} \leqslant V_{c c}$; for VDC LD/SH |
| INPUT CAPACITANCE $\mathrm{C}_{\text {IN1 }}$ $\mathrm{C}_{\mathrm{IN2} 2}$ $\mathrm{C}_{\mathrm{IN} 3}$ |  | $\begin{aligned} & 10 \\ & 20 \\ & 25 \\ & \hline \end{aligned}$ |  | pf pf pf | Excluding VDC, $\overline{\mathrm{LD}} / \mathrm{SH}$ <br> For LD/SH <br> For VDC |
| POWER SUPPLY CURRENT $I_{c c}$ |  | 50 |  | mA |  |

AC CHARACTERISTICS

| PARAMETER | MIN | TYP | MAX | UNIT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VDC <br> $1 / t_{\text {cri }} \mathrm{VDC}$ frequency $t_{\text {ckL }}$ VDC low $\mathrm{t}_{\mathrm{cKH}}$ VDC high $\mathrm{t}_{\mathrm{CKA}} \mathrm{VDC}$ rise time $\mathrm{t}_{\mathrm{CKF}}$ VDC fall time | $\begin{aligned} & 1.0 \\ & 10 \\ & 10 \end{aligned}$ |  | $\begin{aligned} & 28.5 \\ & \\ & 7.5 \\ & 7.5 \\ & \hline \end{aligned}$ | $\begin{gathered} \mathrm{MHZ} \\ \mathrm{~ns} \\ \mathrm{~ns} \\ \mathrm{~ns} \\ \mathrm{~ns} \\ \hline \end{gathered}$ | Measured from $10 \%$ to $90 \%$ points Measured from $90 \%$ to $10 \%$ points |
| $\begin{gathered} \hline \overline{\mathrm{LD}} / \mathrm{SH} \\ \mathrm{t}_{\mathrm{cr} 2} \\ \mathrm{t}_{\mathrm{s} 1} \\ \mathbf{t}_{\mathrm{H} 1} \\ \hline \end{gathered}$ | $\begin{gathered} 315 \\ 7 \\ 0 \\ \hline \end{gathered}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ |  |
| $\qquad$ | $\begin{gathered} 35 \\ 0 \\ \hline \end{gathered}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |  |
| MISCELLANEOUS TIMING $t_{\text {PD }}$ $t_{\text {w }}$ | $\mathrm{t}_{\mathrm{cr} 2}$ |  | 35 | ns | $c_{L}=15 \mathrm{pf}$ |



FIGURE 5: CRT 9021 INPUT/OUTPUT TIMING


FIGURE 6: SERIAL SCAN LINE MODE TIMING


TABLE 2
WIDE GRAPHICS MASK PROGRAMMING OPTIONS

| OPTION | CHOICES | STANDARD CRT 9021 |
| :---: | :---: | :--- |
| Height of graphic block* | any scan lines(s) | R0, R1, R2 |
| D7 and D3 | any scan line(s) | R3, R4, R5 |
| D6 and D2 | any scan line(s) | R6, R7, R8 |
| D5 and D1 | any scan line(s) | R9, R10, R11, R12, R13, R14, R15 |
| D4 and D0 | any number of dots 0 to 8 | C7, C6, C5, C4 |
| Width of D7, D6, D5, D4** | any number of dots 0 to 8 | C3, C2, C1, C0, BF |
| Width of D3, D2, D1, D0** |  |  |

* Any graphic block pair can be removed by programming for zero scan lines.
** Total number of dots for both must be equal to the total dots per character with no overlap.

TABLE 3
THIN GRAPHICS MASK PROGRAMMING OPTIONS

| OPTION | CHOICES | STANDARD CRT 9021 |
| :---: | :---: | :---: |
| Backfill | C1 or C0 | C0 |
| Horizontal portion for |  |  |
| $\begin{aligned} & \text { D2 and D3 } \\ & \text { D4 } \\ & \text { D5 } \\ & \hline \end{aligned}$ | any scan line(s) R0-R15 any scan line(s) R0-R15 any scan line(s) R0-R15 | $\begin{aligned} & \hline \text { R5 } \\ & \text { R0 } \\ & \text { R11 } \\ & \hline \end{aligned}$ |
| Blanked dots for serrated horizontal lines |  |  |
| $\begin{aligned} & \text { D2 } \\ & \text { D3 } \\ & \text { D4 } \\ & \text { D5 } \\ & \hline \end{aligned}$ | any $\operatorname{dot}(\mathrm{s}) \mathrm{C} 7-\mathrm{CO}, \mathrm{BF}$ any dot(s) C7-C0, BF any $\operatorname{dot}(\mathrm{s}) \mathrm{C} 7-\mathrm{CO}, \mathrm{BF}$ any $\operatorname{dot}(\mathrm{s}) \mathrm{C} 7-\mathrm{CO}, \mathrm{BF}$ | none none none none |
| Vertical position for |  |  |
| $\begin{aligned} & \text { D0 and D1 } \\ & \text { D6' } \\ & \text { D7' } \end{aligned}$ | any dot(s) $\mathrm{C} 7-\mathrm{CO}, \mathrm{BF}$ any $\operatorname{dot}(\mathrm{s}) \mathrm{C} 6-\mathrm{C0}, \mathrm{BF}$ any $\operatorname{dot}(\mathrm{s}) \mathrm{C} 7-\mathrm{CO}$ | $\begin{aligned} & \mathrm{C} 3 \\ & \mathrm{BF} \\ & \mathrm{C} 7 \end{aligned}$ |
| Vertical length for |  |  |
| $\begin{aligned} & \text { D0 } \\ & \text { D1 } \\ & \text { D6 } \\ & \text { D7 } \end{aligned}$ | any scan line(s) <br> all scan lines not used by D0 no choice; always R0-R15 no choice; always R0-R15 | R0 to R5 <br> R6 to R15 <br> R0 to R15 <br> R0 to R15 |

1-D7 must always come before D6 with no overlap; otherwise D6 is lost.

TABLE 4
MISCELLANEOUS MASK PROGRAMMING OPTIONS

| OPTION | CHOICES | STANDARD CRT 9021 |
| :---: | :---: | :---: |
| Backfill in character mode | C7 to C0 | C7 |
| Character blink rate <br> (division of $\overline{\text { VSYNC frequency) }}$ | 8 to 60 even numbers <br> $(7.5 \mathrm{~Hz} \text { to } 1 \mathrm{~Hz})^{\prime}$ | $(1.875 \mathrm{~Hz})^{1}$ |
| Cursor blink rate ${ }^{2}$ | Twice the character <br> blink rate | 16 |
| character underline position $^{\text {cursor underline }{ }^{3}}$ | any scan line(s) R0-R15 | R11 |
| cursor format ${ }^{4}$ | any scan line(s) R0-R15 |  |
| underline <br> Blinking underline <br> Reverse video block <br> Blinking reverse video block | not applicable |  |

[^9]


FIGURE 8b: CRT 9021 SYSTEM CONFIGURATION IN
SERIAL SCAN LINE MODE

## Microprocessor Peripheral

## дииum ROM

| Part Number | Description | Access Time | Powar 8upply | Package | Page |
| :--- | :--- | :---: | :---: | :---: | :---: |
| ROM 4732(3) | 32 K ROM; 32,768 bits <br> organized 4096x8 | 450 nsec | +5 | 24 DIP | $347-350$ |
| ROM 36000(1)(3) | 64 K ROM; 65,536 bits <br> organized 8192x8 | 250 nsec | +5 | 24 DIP | $351-354$ |

## диициий FLOPPY DISK

| Part Number | Description | Sector/ <br> Format | Density | Data <br> Bus | Side Select Output | Power Supplies | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FDC1761 | Floppy Disk Controller/ Formatter (mini-floppy only) | Soft | Double | Inverted | No | $+5,+12$ | 40 DIP | 295-310 |
| FDC1763 | Floppy Disk Controller/ <br> Formatter (mini-floppy only) | Soft | Double | True | No | $+5,+12$ | 40 DIP | 295-310 |
| FDC1765 | Floppy Disk Controller/ Formatter (mind-floppy only) | Soft | Double | Inverted | Yes | $+5,+12$ | 40 DIP | 295-310 |
| FDC1767 | Floppy Disk Controller/ Formatter (mini-floppy only) | Soft | Double | True | Yes | $+5,+12$ | 40 DIP | 295-310 |
| FDC1791 | Floppy Disk Controller/ Formatter | Soft | Double | Inverted | No | $+5,+12$ | 40 DIP | 311-326 |
| FDC1792 | Floppy Disk Controller/ Formatter | Soft | Single | Inverted | No | $+5,+12$ | 40 DIP | $311-326$ |
| FDC1793 | Floppy Disk Controller/ Formatter | Soft | Double | True | No | $+5,+12$ | 40 DIP | $311-326$ |
| FDC1794 | Floppy Disk Controller/ Formatter | Soft | Single | True | No | $+5,+12$ | 40 DIP | 311-326 |
| FDC1795 | Floppy Disk Controller/ Formatter | Soft | Double | Inverted | Yes | $+5,+12$ | 40 DIP | 311-326 |
| FDCl797 | Floppy Disk Controller/ Formatter | Soft | Double | True | Yes | $+5,+12$ | 40 DIP | 311.326 |
| FDC3400 | Floppy Disk Data Handler | Hard | N/A | True | $\square \mathrm{NA}$ | $+5,-12$ | 40 DIP | $331-338$ |
| FDC9216/B | Floppy Disk Data Separator | Soft/Hard | Double | NA | $\because \mathrm{NA}$ | $+5$ | 8 DIP | 327.330 |

## CASSFTTF/CARTRIDGE

| Part Number | Description | Max <br> Data Rate | Features | Power <br> 8upply | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CCC 3500 | Cassette/Cartridge Data Handler | 250 K bps | Sync byte detection, <br> Read While Write | $+5,-12$ | 40 DIP | $339-346$ |

[^10]
# Floppy Disk Controller/Formatter FDC 

## FEATURES

1 MHZ VERSION OF FDC 179XSOFT SECTOR FORMAT COMPATIBILITYAUTOMATIC TRACK SEEK WITH VERIFICATION$\square$ ACCOMMODATES SINGLE AND DOUBLE DENSITY FORMATS
IBM 3740 Single Density (FM)
IBM System 34 Double Density (MFM)
$\square$ READ MODE
Single/Multiple Sector Read with Automatic Search or Entire Track Read
Selectable 128 Byte or Variable Length Record
$\square$ WRITE MODE
Single/Multiple Sector Write with Automatic Sector Search
Entire Track Write for Diskette InitializationPROGRAMMABLE CONTROLS
Selectable Track to Track Stepping Time
Side Select Compare
$\square$ SYSTEM COMPATIBILITY
Double Buffering of Data 8 Bit Bi-Directional Bus for Data, Control and Status
DMA or Programmed Data Transfers
All Inputs and Outputs are TTL Compatible
On-chip Track and Sector Registers/Comprehensive Status InformationWRITE PRECOMPENSATION (MFM AND FM)SIDE SELECT LOGIC (FDC 1765, FDC 1767)WINDOW EXTENSION (IN MFM)

PIN CONFIGURATION

| NC 1 | 40 | - 12 V |
| :---: | :---: | :---: |
| WE 02 | 39 | INTRQ |
| $\overline{C S} 3$ | 38 | DRQ |
| $\overline{R E}$ C 4 | 37 | $\overline{\text { DDEN }}$ |
| $\mathrm{A}_{1} \mathrm{C} 5$ | 36 | WPRT |
| A 66 | 35 | $\overline{\mathrm{P}}$ |
| DAL O. 7 | 34 | TRÕO |
| DAL $1^{*} 8$ | 33 | $\overline{\text { WF }}$ |
| DAL 2* 9 | 32 | READY |
| DAL 3* 10 | 31 | WD |
| DAL 4* 11 | 30 | WG |
| DAL 5* 12 | 29 | TG43 |
| DAL 6. 13 | 28 | HLD |
| DAL $7^{\circ} 14$ | 27 | RAW READ |
| STEP 15 | 26 | RCLK |
| DIRC 16 | 25 | RG/SSO |
| EARLY 178 | 24 | CLK |
| LATE 18 | 23 | HLT |
| $\overline{\mathrm{MR}} 19$ | 22 | TEST |
| GND [ 20 | 21 | . 5 V |

- INVERTED BUS FOR FDC 1761. FDC 1765 PACKAGE: 40 pin D.I.P.


## GENERAL DESCRIPTION

The FDC 176X is an MOS/LSI device which performs the functions of a Floppy Disk Controller/Formatter in a single chip implementation. The basic FDC 176X chip design has evolved into four specific parts: FDC 1761, FDC 1763, FDC 1765 , and the FDC 1767 . It is a 1 MHz version of the FDC 179X family.
This FDC family performs all the functions necessary to read or write data to a floppy disk drive. $5^{1 / 4 a^{\prime \prime}}$ (minifloppy) drives with single or double density storage capabilities are supported. These n-channel MOS/LSI devices will replace a large amount of discrete logic required for interfacing a host processor to a floppy disk.

The FDC 176X is IBM 3740 compatible in single density mode (FM) and System 34 compatible in double density
mode (MFM). The FDC 176X contains enhanced features necessary to read/write and format a double density diskette. These include address mark detection, FM and MFM encode and decode logic, window extension, and write precompensation.
The FDC 1763 is identical to the FDC 1761 except the DAL lines are TRUE for systems that utilize true data busses.
The FDC 1765 adds side select logic to the FDC 1761. The FDC 1767 adds the side select logic to the FDC 1763.
The processor interface consists of an 8 bit bidirectional bus for data, status, and control word transfers. This family of controllers is configured to operate on a multiplexed bus with other bus-oriented devices.


## DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | NAME | SYMBOL | FUNCTION |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | NO CONNECTION | NC | This pin is internally connected to the substrate bias generator and must be left open. |  |  |  |  |
| 20 | GROUND | $\mathrm{V}_{\mathrm{ss}}$ | Ground |  |  |  |  |
| 21 | POWER SUPPLY | $V_{C c}$ | $+5 \mathrm{~V} \pm 5 \%$ |  |  |  |  |
| 40 | POWER SUPPLY | $V_{D D}$ | $+12 \mathrm{~V} \pm 5 \%$ |  |  |  |  |
| 19 | MASTER RESET | $\overline{\mathrm{MR}}$ | A logic low ( 50 microseconds min.) on this input resets the device and loads HEX 03 into the command register. The Not Ready (Status Bit 7) is reset during MR ACTIVE. When $\overline{M R}$ is brought to a logic high a Restore Command is executed, regardless of the state of the Ready signal from the drive. Also, HEX 01 is loaded into the sector register. |  |  |  |  |
| COMPUTER INTERFACE: |  |  |  |  |  |  |  |
| 2 | WRITE ENABLE | $\overline{W E}$ | A logic low on this input gates data on the DAL into the selected register when $\overline{\mathrm{CS}}$ is low. |  |  |  |  |
| 3 | $\overline{\text { CHIP SELECT }}$ | $\overline{\mathrm{CS}}$ | A logic low on this input selects the chip and the parallel data bus (DAL). |  |  |  |  |
| 4 | $\overline{\text { READ ENABLE }}$ | $\overline{\mathrm{RE}}$ | A logic low on this input controls the placement of data from a selected register on DALø-DAL7 when $\overline{C S}$ is low. |  |  |  |  |
| 5,6 | REGISTER SELECT LINES | A0, A1 | These inputs select the register to receive/transfer data on the DAL lines under RE and WE control: |  |  |  |  |
|  |  |  | $\overline{\mathrm{CS}}$ | A1 | A0 | $\overline{\mathrm{RE}}$ | 产 |
|  |  |  | $\begin{array}{\|l\|} \hline 0 \\ 0 \\ 0 \\ 0 \\ \hline \end{array}$ | 0 0 1 1 1 | 0 <br> 1 <br> 0 <br> 1 | Status Reg Track Reg Sector Reg Data Reg | Command Reg <br> Track Reg <br> Sector Reg <br> Data Reg |
| 7-14 | DATA ACCESS LINES | $\begin{aligned} & \text { DALO- } \\ & \text { DAL7 } \end{aligned}$ | Eight bit Bidirectional bus used for transfer of data, control, and status. This bus is a receiver enabled by WE or a transmitter enabled by RE. The Data Bus is inverted on the FDC 1761, and FDC 1765. Each line will drive 1 standard TTL load. |  |  |  |  |
| 24 | CLOCK | CLK | This input requires a free-running square wave clock for internal timing reference of $1 \mathrm{MHz} \pm 1 \%$ with a $50 \%$ duty cycle. |  |  |  |  |
| 38 | DATA REQUEST | DRQ | This open drain output indicates that the DR contains assembled data in Read operations, or the DR is empty in Write operations. This signal is reset when serviced by the computer through reading or loading the DR in Read or Write operations, respectively. Use a 10 K pull-up resistor to +5 V . |  |  |  |  |
| 39 | INTERRUPT REQUEST | INTRQ | This open drain output is set at the completion or termination of any operation and is reset when a new command is loaded into the command register or the status register is read. Use a 10 K pull-up resistor to +5 V . |  |  |  |  |

## FLOPPY DISK INTERFACE:

| 15 | STEP | STEP | Step and direction motor control. The step output contains a pulse <br> for each step. |
| :---: | :--- | :---: | :--- |
| 16 | DIRECTION | DIRC | Direction Output is active high when stepping in, active low when <br> stepping out. |
| 17 | EARLY | EARLY | Indicates that the write data pulse occurring while Early is active <br> (high) should be shifted early for write precompensation. |
| 18 | LATE | LATE | Indicates that the write data pulse occurring while Late is active <br> (high) should be shifted late for write precompensation. |
| 22 | TEST | TEST | This input is used for testing purposes only and should be tied to <br> +5V or left open by the user unless interfacing to voice coil <br> actuated motors. |
| 23 | HEAD LOAD TIMING | HLT | When a logic high is found on the HLT input the head is assumed <br> to be engaged. |


| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 25 | READ GATE (1761/3) | RG | This output is used for synchronization of external data separators. The output goes high after two bytes of zeroes in single density, or four bytes of either zeroes or ones in double density operation. |
| 25 | SIDE SELECT OUTPUT $(1765,1767)$ | SSO | The logic level of the Side Select Output is directly controlled by the ' $S$ ' flag in Type II or III commands. When $S=1$, SSO is set to a logic 1. When $S=0$, SSO is set to a logic 0 . The SSO is compared with the side information in the sector I.D. field. If they do not compare, status bit 4 (RNF) is set. The side select output is only updated at the beginning of a type II or III command. It is forced to a logic 0 upon a MASTER RESET condition. |
| 26 | READ CLOCK | RCLK | A nominal square-wave clock signal derived from the data stream must be provided to this input. Phasing (i.e. RCLK transitions) relative to RAW READ is important but polarity (RCLK high or low) is not. |
| 27 | RAW READ | $\frac{\overline{\operatorname{RAW}}}{\overline{\operatorname{READ}}}$ | The data input signals directly from the drive. This input shall be a negative pulse for each recorded flux transition. |
| 28 | HEAD LOAD | HLD | The HLD output controls the loading of the Read-Write head against the media. |
| 29 | TRACK GREATER THAN 43 | TG43 | This output informs the drive that the Read/Write head is positioned between tracks 44-76. This output is valid only during Read and Write Commands. |
| 30 | WRITE GATE | WG | This output is made valid before writing is to be performed on the diskette. |
| 31 | WRITE DATA | WD | A 400 ns (MFM) or 1000 ns (FM) pulse per flux transition. WD contains the unique Address marks as well as data and clock in both FM and MFM formats. |
| 32 | READY | READY | This input indicates disk readiness and is sampled for a logic high before Read or Write commands are performed. If Ready is low the Read or Write operation is not performed and an interrupt is generated. Type I operations are performed regardless of the state of Ready. The Ready input appears in inverted format as Status Register bit 7. |
| 33 | $\begin{aligned} & \overline{\text { WRITE FAULT/ }} \\ & \text { VFO ENABLE } \end{aligned}$ | WF/VFOE | This is a bi-directional signal used to signify writing faults at the drive, and to enable the external PLO data separator. When WG $=1$, Pin 33 functions as a $\overline{W F}$ input. If $\overline{W F}=0$, any write command will immediately be terminated. When $W G=0$, Pin 33 functions as a VFOE output. VFOE will go low during a read operation after the head has loaded and settled (HLT=1). On the 1765/7, it will remain low until the last bit of the second CRC byte in the ID field. VFOE will then go high until 8 bytes (MFM) or 4 bytes (FM) before the Address Mark. It will then go active until the last bit of the second CRC byte of the Data Field. On the $1761 / 3$, VFOE will remain low until the end of the Data Field. |
| 34 | TRACK 00 | TR00 | This input informs the FDC176X that the Read/Write head is positioned over Track 00. |
| 35 | INDEX PULSE | $\overline{\mathrm{P}}$ | This input informs the FDC176X when the index hole is encountered on the diskette. |
| 36 | WRITE PROTECT | $\bar{W}$ PRT | This input is sampled whenever a Write Command is received. A logic low terminates the command and sets the Write Protect Status bit. |
| 37 | DOUBLE DENSITY | $\overline{\text { DDEN }}$ | This pin selects either single or double density operation. When $\overline{\mathrm{DDEN}}=0$, double density is selected. When $\overline{\mathrm{DDEN}}=1$, single density is selected. |

The FDC 176X-02 major functional blocks are as follows: Data Shift Register - This 8-bit register assembles serial data from the Read Data input ( $\overline{\text { RAW READ }}$ ) during Read operations and transfers serial data to the Write Data output during Write operations.
Data Register - This 8-bit register is used as a holding register during Disk Read and Write operations. In Disk Read operations the assembled data byte is transferred in parallel to the Data Register from the Data Shift Register. In Disk Write operations information is transferred in parallel from the Data Register to the Data Shift Register.
When executing the Seek command the Data Register holds the address of the desired Track position. This register is loaded from the DAL and gated onto the DAL under processor control.
Sector Register (SR) - This 8-bit register holds the address of the desired sector position. The contents of the register are compared with the recorded sector number in the ID field during disk Read or Write operations. The Sector Register contents can be loaded from or transferred to the DAL. This register should not be loaded when the device is busy.
Command Register (CR) - This 8-bit register holds the command presently being executed. This register should not be loaded when the device is busy unless the new command is a Force Interrupt. The command register can be loaded from the DAL, but not read onto the DAL. Status Register (STR) - This 8-bit register holds device Status information. The meaning of the Status bits is a function of the type of command previously executed.

This register can be read onto the DAL, but not loaded from the DAL.
CRC Logic - This logic is used to check or to generate the 16-bit Cyclic Redundancy Check (CRC). The polynomial is: $G(x)=x^{16}+x^{12}+x^{5}+1$.
Track Register - This 8-bit register holds the track number of the current Read/Write head position. It is incremented by one every time the head stepped in (towards track 76) and decremented by one when the head is stepped out (towards track 00). The contents of the register are compared with the recorded track number in the ID field during disk Read, Write, and Verify operations. The Track Register can be loaded from or transferred to the DAL. This Register should not be loaded when the device is busy.
The CRC includes all information starting with the address mark and up to the CRC characters. The CRC register is preset to ones prior to data being shifted through the circuit.
Arithmetic/Logic Unit (ALU) - The ALU is a serial comparator, incrementer, and decrementer and is used for register modification and comparisons with the disk recorded ID field.
Timing and Control - All computer and Floppy Disk Interface controls are generated through this logic. The internal device timing is generated from an external crystal clock.
AM Detector - The address mark detector detects ID, data and index address marks during ready and write operations.

## OPERATION

The FDC 176X has two modes of operation, according to the state of $\overline{\text { DDEN }}$. When $\overline{\text { DDEN }}=0$, double density (MFM) is assumed. When $\overline{D D E N}=1$, single density (FM) is assumed. In either case the CLK input (Pin 24) is at 1 MHz and stepping rates of $6,12,20$ and 30 ms can be obtained.

## Disk Read Operation

Sector lengths of $128,256,512$ or 1024 are obtainable in either FM or MFM formats. For FM, DDEN should be placed to logical "1." For MFM formats, $\overline{D D E N}$ should be placed to a logical " 0 ." Sector lengths are determined at format time by a special byte in the "ID" field. If this Sector length byte in the ID field is zero, then the sector length is 128 bytes. If 01 , then 256 bytes. If 02 , then 512 bytes. If 03 , then the sector length is 1024 bytes. For the FDC 1765/67 the sector length may be different according to the state of the $b$ flag in the command word. Refer to Table 1; command summary. The number of sectors per track can be from 1 to 255 sectors. The number of tracks is from 0 to 255 tracks.
For read operations, the FDC 176X requires $\overline{\text { RAW READ }}$ Data (Pin 27) signal which is a 400 ns pulse per flux transition and a Read clock (RCLK) signal to indicate flux transition spacings. The RCLK (Pin 26) signal is provided by some drives but if not, it may be derived
externally by Phase lock loops, one shots, or counter techniques. In addition, a Read Gate Signal is provided as an output (Pin 25) on 1761/63 which can be used to inform phase lock loops when to acquire synchronization. When reading from the media in FM, RG is made true when 2 bytes of zeroes are detected. The FDC 176X must find an address mark within the next 10 bytes; otherwise RG is reset and the search for 2 bytes of zeroes begins all over again. If an address mark is found within 10 bytes, RG remains true as long as the FDC 176X is deriving any useful information from the data stream. Similarly for MFM, RG is made active when 4 bytes of " 00 " or "FF" are detected. The FDC 176X must find an address mark within the next 16 bytes, otherwise RG is reset and search resumes.
During read operations ( $W G=0$ ), the $\overline{V F O E}$ (Pin 33) is provided for phase lock loop synchronization. VFOE will go active when:
a) Both HLT and HLD are True
b) Settling Time, if programmed, has expired
c) The 176X is inspecting data off the disk

If WF/VFOE is not used, this pin may be left open, as it has an internal pull up resistor.
On Disk Read operations the Data Request is activated (set high) when an assembled serial input byte is transferred in parallel to the Data Register. This bit
is cleared when the Data Register is read by the processor. If the Data Register is read after one or more characters are lost by having new data transferred into the register prior to processor readout, the Lost Data bit is set in the Status Register. The Read operation continues until the end of sector is reached.

## Disk Write Operation

When writing is to take place on the diskette the Write Gate (WG) output is activated, allowing current to flow into the Read/Write head. As a precaution against erroneous writing the first data byte must be loaded into the Data Register in response to a Data Request from the FDC 176X before the Write Gate signal can be activated. Writing is inhibited when the Write Protect input is a logic low, in which case any Write command is immediately terminated, an interrupt is generated and the Write Protect status bit is set. The Write Fault input, when activated, signifies a writing fault condition detected in disk drive electronics such as failure to detect write current flow when the Write Gate is activated. On detection of this fault the FDC 176X terminates the current command, and sets the Write Fault bit (bit 5) in the Status Word. The Write Fault input should be made inactive when the Write Gate output becomes inactive.
For write operations, the FDC176X provides Write Gate (Pin 30) and Write Data (Pin 31) outputs. Write data consists of a series of 1000 ns pulses in FM ( $\overline{\mathrm{DDEN}}=1$ )
and 400 ns pulses in MFM ( $\overline{\mathrm{DDEN}}=0$ ). Write Data provides the unique address marks in both formats.
Also during write, two additional signals are provided for write precompensation. These are EARLY (Pin 17) and LATE (Pin 18). EARLY is active true when the WD pulse appearing on (Pin 30) is to be written early. LATE is active true when the WD pulse is to be written LATE. If both EARLY and LATE are low when the WD pulse is present, the WD pulse is to be written at nominal. Since write precompensation values vary from disk manufacturer to disk manufacturer, the actual value is determined by several one shots or delay lines which are located external to the FDC 176X. The write precompensation signals EARLY and LATE are valid for the duration of WD in both FM and MFM formats.

On Disk Write operations the Data Request is activated when the Data Register transfers its contents to the Data Shift Register, and requires a new data byte. It is reset when the Data Register is loaded with new data by the processor. If new data is not loaded at the time the next serial byte is required by the Floppy Disk, a byte of zeroes is written on the diskette and the Lost Data bit is set in the Status Register.
At the completion of every command an INTRQ is generated. INTRQ is reset by either reading the status register or by loading the command register with a new command. In addition, INTRQ is generated if a Force Interrupt command condition is met.

## COMMAND WORDS

The FDC 176X will accept eleven commands. Command words should only be loaded in the Command Register when the Busy status bit is off (Status bit 0). The one exception is the Force Interrupt command. Whenever a command is being executed, the Busy status bit is set. When a command is completed, an interrupt is generated and the Busy status bit is reset. The Status Register indicates whether the completed command encountered an error or was fault free. For ease of discussion, commands are divided into four types. Commands and types are summarized in Table 1.

Table 1. Command Summary

|  |  | BITS |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| COMMAND | TYPE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Restore | I | 0 | 0 | 0 | 0 | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| Seek | I | 0 | 0 | 0 | 1 | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| Step | I | 0 | 0 | 1 | u | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| Step In | I | 0 | 1 | 0 | u | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| Step Out | I | 0 | 1 | 1 | u | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| Read Sector | II | 1 | 0 | 0 | m | $\mathrm{~F}_{2}$ | E | $\mathrm{F}_{1}$ | 0 |
| Write Sector | II | 1 | 0 | 1 | m | $\mathrm{~F}_{2}$ | E | $\mathrm{F}_{1}$ | $\mathrm{a}_{0}$ |
| Read Address | III | 1 | 1 | 0 | 0 | 0 | E | $\mathrm{F}_{1}$ | 0 |
| Read Track | III | 1 | 1 | 1 | 0 | 0 | E | $\mathrm{F}_{1}$ | 0 |
| Write Track | III | 1 | 1 | 1 | 1 | 0 | E | $\mathrm{F}_{1}$ | 0 |
| Force Interrupt | IV | 1 | 1 | 0 | 1 | $\mathrm{I}_{3}$ | $\mathrm{I}_{2}$ | $\mathrm{I}_{1}$ | $\mathrm{I}_{0}$ |

## Type I Commands

The Type I Commands are Restore, Seek, Step, Step-In, and Step-Out. Each of the Type I Commands contains a rate field ( $\mathrm{ror}_{1}$ ), which determines the stepping motor rate as defined in Table 2.
The Type I Commands contain a head load flag (h) which determines if the head is to be loaded at the beginning of the command. If $h=1$, the head is loaded at the beginning of the command (HLD output is made active). If $h=0, H L D$ is deactivated. Once the head is loaded, the head will remain engaged until the FDC 176X receives a command that specifically disengages the head. If the FDC 176X is idle (busy=0) for 15 revolutions of the disk, the head will be automatically disengaged (HLD made inactive).
The Type I Commands also contain a verification (V) flag which determines if a verification operation is to take place on the destination track. If $V=1$, a verification is performed, if $V=0$, no verification is performed.
During verification, the head is loaded and after an internal 30 ms delay, the HLT input is sampled. When HLT is active (logic true), the first encountered ID field is read off the disk. The track address of the ID field is then compared to the Track Register; if there is a match and a valid ID CRC, the verification is complete, an interrupt is generated and the Busy status bit is reset. If there is not a match but there is valid ID CRC, an interrupt
is generated, and Seek Error Status bit (Status bit 4) is set and the Busy status bit is reset. If there is a match but not a valid CRC, the CRC error status bit is set (Status bit 3), and the next encountered ID field is read from the disk for the verification operation. If an ID field with a valid CRC cannot be found after five revolutions of the disk, the FDC 176X terminates the operation and sends an interrupt (INTRQ).
The Step, Step-In, and Step-Out commands contain an Update flag ( $u$ ). When $u=1$, the track register is updated by one for each step. When $u=0$, the track register is not updated.
On the FDC 1765/7 devices, the SSO output is not affected during Type 1 commands, and an internal side compare does not take place when the (V) Verify Flag is on.

## Restore (Seek Track 0)

Upon receipt of this command the Track 00 (TROO) input is sampled. if TROO is active low indicating the Read-Write head is positioned over track 0, the Track Register is loaded with zeroes and an interrupt is generated. If TROO is not active low, stepping pulses (pins 15 to 16) at a rate specified by the $r_{1} r_{0}$ field are issued until the TROO input is activated. At this time the Track Register is loaded with zeroes and an interrupt is generated. If the TROO input does not go active low after 255 stepping pulses, the FDC 176X terminates operation, interrupts, and sets the Seek error status bit. A verification operation takes place if the V flag is set. The h bit allows the head to be loaded at the start of command. Note that the Restore command is executed when MR goes from an active to an inactive state.

## Seek

This command assumes that the Track Register contains the track number of the current position of the ReadWrite head and the Data Register contains the desired track number. The FDC 176X will update the Track register and issue stepping pulses in the appropriate direction until the contents of the Track register are equal to the contents of the Data Register (the desired track location). A verification operation takes place if the V flag is on. The $h$ bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command. Note: When using multiple drives, the track register must be updated for the drive selected before seeks are issued.

## Step

Upon receipt of this command, the FDC 176X issues one stepping pulse to the disk drive. The stepping motor direction is the same as in the previous step command. After a delay determined by the $r_{1} r_{0}$ field, a verification takes place if the V flag is on. If the u flag is on, the Track Register is updated. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

## Step-In

Upon receipt of this command, the FDC 176X issues one stepping pulse in the direction towards track 76. If the u flag is on, the Track Register is incremented by one. After a delay determined by the $r_{1} r_{0}$ field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

## Step-Out

Upon receipt of this command, the FDC 176X issues one stepping pulse in the direction towards track 0 . If the u flag is on, the Track Register is decremented by one. After a delay determined by the $r_{1} r_{0}$ field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of command. An interrupt is generated at the completion of the command.

## Head Positioning

The period of each positioning step is specified by the $r$ field in bits 1 and 0 of the command word. After the last directional step an additional 30 milliseconds of head settling time takes place if the Verify flag is set in Type I commands. If TEST $=0$, there is zero settling time. There is also a 30 ms head settling time if the Eflag is set in any Type II or III command.
The rates (shown in Table 2) can be applied to a StepDirection Motor through the device interface.

Step-A $4 \mu \mathrm{~s}$ (MFM) or $8 \mu \mathrm{~s}$ (FM) pulse is provided as an output to the drive. For every step pulse issued, the drive moves one track location in a direction determined by the direction output.
Direction (DIRC) - The Direction signal is active high when stepping in and low when stepping out. The Direction signal is valid $24 \mu$ s before the first stepping pulse is generated.
When a Seek, Step or Restore command is executed an optional verification of Read-Write head position can be performed by setting bit $2(\mathrm{~V}=1)$ in the command word to a logic 1. The verification operation begins at the end of the 30 millisecond settling time after the head is loaded against the media. The track number from the first encountered ID Field is compared against the contents of the Track Register. If the track numbers compare and the ID Field Cyclic Redundancy Check (CRC) is correct, the verify operation is complete and an INTRQ is generated with no errors. The FDC 176X must find an ID field with correct track number and correct CRC within 5 revolutions of the media; otherwise the seek error is set and an INTRQ is generated.

Table 2. Stepping Rates


The Head Load (HLD) output controls the movement of the read/write head against the media. HLD is activated at the beginning of a Type I command if the $h$ flag is set ( $h=1$ ), at the end of the Type I command if the verify flag ( $\mathrm{V}=1$ ), or upon receipt of any Type II or III command. Once HLD is active it remains active until either a Type I command is received with ( $\mathrm{h}=0$ and $\mathrm{V}=0$ ); or if the FDC 176X is in an idle state (non-busy) and 15 index pulses have occurred.
Head Load Timing (HLT) is an input to the FDC 176X which is used for the head engage time. When HLT=1, the FDC 176X assumes the head is completely engaged.

The head engage time is typically 30 to 100 ms depending on drive. The low to high transition on HLD is typically used to fire a one shot. The output of the one shot is then used for HLT and supplied as an input to the FDC 176X.


Head Load Timing
When both HLD and HLT are true, the FDC 176X will then read from or write to the media. The "and" of HLD and HLT appears as a status bit in Type I status.

| TYPE I COMMANDS FLAG SUMMARY |
| :--- |
| $\frac{h=\text { Head Load Flag (Bit 3) }}{h=1, \text { Load head at beginning }}$$h=0$, Unload head at beginning <br> $\frac{V=\text { Verify flag (Bit 2) }}{V=1, \text { Verify on destination track }}$ <br> $V=0$, No verify <br> $\frac{r_{1} r_{0}=\text { Stepping motor rate (Bits 1-0) }}{\text { Refer to Table } 2 \text { for rate summary }}$ <br> $\frac{u=\text { Update flag (Bit 4) }}{u=1, \text { Update Track register }}$ <br> $u=0$, No update |

## EXCEPTIONS

On the FDC 1765/7 devices, the SSO output is not affected during Type 1 commands, and an internal side compare does not take place when the (V) Verify Flag is on.

## Type II Commands

The Type II Commands are the Read Sector and Write Sector commands. Prior to loading the Type ll Command into the Command Register, the system must load the Sector Register with the desired sector number. Upon receipt of the Type II command, the busy status Bit is set. If the $E$ flag $=1$ (this is the normal case) HLD is made active and HLT is sampled until true after a 30 msec delay. If the E flag is 0, HLD is made active and HLT is sampled with no delay until true. The ID field and Data Field format are shown below.
When an ID field is located on the disk, the FDC 176X compares the Track Number on the ID field with the Track Register. If there is not a match, the next encountered ID field is read and a comparison is again made. If there is a match, the Sector Number of the ID field is compared with the Sector Register. If there is not a Sector match, the next encountered ID field is read off the disk and
comparisons again made. If the ID field CRC is correct, the data field is then located and will be either written into, or read from depending upon the command. The FDC 176X must find an ID field with a Track number, Sector number, side number, and CRC within four revolutions of the disk; otherwise, the Record not found status bit is set (Status bit 3 ) and the command is terminated with an interrupt.
Each of the Type II Commands contains an (m) flag which determines if multiple records (sectors) are to be read or written, depending upon the command. If $m=0$, a single sector is read or written and an interrupt is generated at the completion of the command. If $\mathrm{m}=1$, multiple records are read or written with the sector register internally updated so that an address verification can occur on the next record. The FDC 176X will read or write multiple records starting with the sector presently in the sector register. The FDC 176X will continue to read or write multiple records and update the sector register in numerical ascending sequence until the sector register exceeds the number of sectors on the track or until the Force Interrupt command is loaded into the Command Register, which terminates the command and generates an interrupt.
If the Sector Register exceeds the number of sectors on the track, the Record-Not-Found status bit will be set.
The Type II commands also contain side select compare flags. When $\mathrm{C}=0$, no side comparison is made. When $\mathrm{C}=1$, the LSB of the side number is read off the ID Field of the disk and compared with the contents of the ( S ) flag. If the $S$ flag compares with the side number recorded in the ID field, the 176X continues with the ID search. If a comparison is not made within 5 index pulses, the interrupt line is made active and the Record-Not-Found status bit is set.
The Type II and III commands for the FDC 1765/67 contain a side select flag (bit 1). When $U=0$, SSO is updated to 0 . Similarly, $\mathrm{U}=1$ updates SSO to 1 . The chip compares the SSO to the ID field. If they do not compare within 5 revolutions, the interrupt line is made active and the RNF status bit is set.
The FDC 1765/7 READ SECTOR and WRITE SECTOR commands include a ' $b$ ' flag. The ' $b$ ' flag, in conjunction with the sector length byte of the ID Field, allows different byte lengths to be implemented in each sector. For IBM compatibility, the ' $b$ ' flag should be set to a one. The ' s ' flag allows direct control over the SSO Line (Pin 25) and is set or reset at the beginning of the command, dependent upon the value of this flag.

| Sector Length Table (1761/3 only) |  |
| :---: | :---: |
| Sector Length | Number of Bytes |
| Field (hex) | in Sector (decimal) |
| 00 | 128 |
| 01 | 256 |
| 02 | 512 |
| 03 | 1024 |

Field Format

| $\begin{aligned} & \text { GAP } \\ & \text { III } \end{aligned}$ | $\begin{aligned} & \text { ID } \\ & \text { AM } \end{aligned}$ | TRACK NUMBER | SIDE NUMBER | SECTOR NUMBER | SECTOR LENGTH | $\begin{gathered} \hline \text { CRC } \\ 1 \\ \hline \end{gathered}$ | $\begin{gathered} \hline \text { CRC } \\ \hline \end{gathered}$ | $\begin{gathered} \text { GAP } \\ \hline \end{gathered}$ | $\begin{array}{\|c} \hline \text { DATA } \\ \text { AM } \end{array}$ | DATA FIELD | $\begin{gathered} \hline \text { CRC } \\ 1 \\ \hline \end{gathered}$ | $\begin{gathered} \hline \text { CRC } \\ 2 \\ \hline \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ID FIELD |  |  |  |  |  |  |  |  |  | DATA FIELD |  |  |

In MFM only, IDAM and DATA AM are preceded by three bytes of A1 with clock transition between bits 4 and 5 missing.

## Read Sector

Upon receipt of the Read Sector command, the head is loaded, the Busy status bit set, and when an ID field is encountered that has the correct track number, correct sector number, correct side number, and correct CRC, the data field is presented to the computer. The Data Address Mark of the data field must be found within 30 bytes in single density and 43 bytes in double density of the last ID field CRC byte; if not, the Record-NotFound status bit is set and the operation is terminated. When the first character or byte of the data field has been shifted through the DSR, it is transferred to the DR, and DRQ is generated. When the next byte is accumulated in the DSR, it is transferred to the DR and another DRQ is generated. If the Computer has not read the previous contents of the DR before a new character is transferred that character is lost and the Lost Data Status bit is set. This sequence continues until the complete data field has been inputted to the computer. If there is a CRC error at the end of the data field, the CRC error status bit is set, and the command is terminated (even if it is a multiple record command).
At the end of the Read operation, the type of Data Address Mark encountered in the data field is recorded in the Status Register (Bit 5) as shown below:

| STATUS <br> BIT 5 |  |
| :---: | :--- |
| 1 | Deleted Data Mark |
| 0 | Data Mark |

## Write Sector

Upon receipt of the Write Sector command, the head is loaded (HLD active) and the Busy status bit is set. When an ID field is encountered that has the correct track number, correct sector number, correct side number, and correct CRC, a DRQ is generated. The FDC 176X counts off 11 bytes in single density and 22 bytes in double density from the CRC field and the Write Gate (WG) output is made active if the DRQ is serviced (i.e., the DR has been loaded by the computer). If DRQ has not been serviced, the command is terminated and the Lost Data status bit is set. If the DRQ has been serviced, the WG is made active and six bytes of zeros in single density and 12 bytes in double density are then written on the disk. At this time the Data Address Mark is then written on the disk as determined by the $a_{0}$ field of the command as shown below:

| a $_{0}$ | Data Address Mark (Bit 0) |
| :---: | :---: |
| 1 | Deleted Data Mark |
| 0 | Data Mark |

The FDC 176X then writes the data field and generates DRQ's to the computer. If the DRQ is not serviced in time for continuous writing, the Lost Data Status Bit is set and a byte of zeros is written on the disk. The command is not terminated. After the last data byte has been written on the disk, the two-byte CRC is computed internally and written on the disk followed by one byte of logic ones in FM or in MFM. The WG output is then deactivated. For a 1 MHz clock, the INTRQ will set 16 or $24 \mu \mathrm{sec}$ after the last CRC byte is written.


Figure 1. Type II and III Flag Summary

## Type III Commands

There are three Type III Commands:

- READ ADDRESS - Read the next ID field ( 6 bytes) into the FDC.
- READ TRACK-Read all bytes of the entire track, including gaps.
- WRITE TRACK-Write all bytes to the entire track, including gaps.


## Read Address

Upon receipt of the Read Address command, the head is loaded and the Busy Status Bit is set. The next encountered ID field is then read in from the disk, and the six data bytes of the ID field are assembled and transferred to the DR, and a DRQ is generated for each byte. The six bytes of the ID field are shown below:

| TRACK <br> ADDR | SIDE <br> NUMBER | SECTOR <br> ADDRESS | SECTOR <br> LENGTH | CRC <br> 1 | CRC |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 2 | 3 | 4 | 5 | 6 |

Although the CRC characters are transferred to the computer, the FDC176X checks for validity and the CRC
error status bit is set if there is a CRC error. The Track Address of the ID field is written into the sector register. At the end of the operation an interrupt is generated and the Busy Status is reset.

## Read Track

Upon receipt of the Read Track command, the head is loaded and the Busy Status bit is set. Reading starts with the leading edge of the first encountered index pulse and continues until the next index pulse. As each byte is assembled it is transferred to the Data Register and the Data Request is generated for each byte. No CRC checking is performed. Gaps are included in the input data stream. The accumulation of bytes is synchronized to each Address Mark encountered. Upon completion of the command, the interrupt is activated. RG is not activated during the Read Track Command. An internal side compare is not performed during a Read Track.
This command has several characteristics which make it suitable for diagnostic purposes. They are: the Read Gate is not activated during the command; no CRC checking is performed; gap information is included in the data stream; the internal side compare is not per-


Table 3. Control Bytes For Initialization

| DATA PATTERN IN DR (HEX) | FDC 176X INTERPRETATION IN FM (DDEN $=1$ ) | FDC $17 \overline{6 x}$ INTERPRETATION IN MFM (DDEN $=0)$ |
| :---: | :---: | :---: |
| 00 thru F4 F5 F6 F7 F8 thru FB FC FD FE FF | Write 00 thru F4 with CLK $=$ FF <br> Now Allowed <br> Not Allowed <br> Generate 2 CRC bytes <br> Write F8 thru FB, CIk $=$ C7, Preset CRC <br> Write FC with Clk = D7 <br> Write FD with $\mathrm{Clk}=\mathrm{FF}$ <br> Write FE, CIk $=\mathrm{C} 7$, Preset CRC <br> Write FF with Clk = FF | Write 00 thru F4, in MFM <br> Write A1* in MFM, Preset CRC <br> Write C2"* in MFM <br> Generate 2 CRC bytes <br> Write F8 thru FB, in MFM <br> Write FC in MFM <br> Write FD in MFM <br> Write FE in MFM <br> Write FF in MFM |

formed; and the address mark detector is on for the duration of the command. Because the A.M. detector is always on, write splices or noise may cause the chip to look for an A.M. If an address mark does not appear on schedule the Lost Data status flag is set. The ID A.M., ID field, ID CRC bytes, DAM, Data, and Data CRC Bytes for each sector will be correct. The Gap Bytes may be read incorrectly during write-splice time because of synchronization.

## Write Track

Upon receipt of the Write Track command, the head is loaded and the Busy Status bit is set. Writing starts with the leading edge of the first encountered index pulse and continues until the next index pulse, at which time the interrupt is activated. The Data Request is activated immediately upon receiving the command, but writing will not start until after the first byte has been loaded into the Data Register. If the DR has not been loaded by the time the index pulse is encountered the operation is terminated making the device Not Busy, the Lost Data Status Bit is set, and the Interrupt is activated. If a byte is not present in the DR when needed, a byte of zeros is substituted. Address Marks and CRC characters are written on the disk by detecting certain data byte patterns in the outgoing data stream as shown in the table below. The CRC generator is initialized when any data byte from F8 to FE is about to be transferred from the DR to the DSR in FM or by receipt of F5 in MFM.
Disk formatting (initialization) is accomplished by the Write Track command. Each byte for the entire track must be provided for proper formatting. This includes gap as well as data bytes.
The sequence required to format a diskette begins with positioning the Read/Write head at the desired track. Once this has been done, it is necessary to perform a Write Track command to store all the information on a track. The Write Track command uses DRQ to request each byte from the system MPU, starting with the byte at the beginning of the physical Index Pulse and ending with the last gap bytes at the end of the track. Figure 2 illustrates the IBM standard for track formatting.
Normally, each data byte stored on the diskette must be generated by the system MPU and passed into the FDC Data Register. However, there are exceptions to this rule. If a data byte of hex F5 through FE is entered into the Data Register, then the FDC recognizes this as an AM with missing clocks or CRC generation code. Consequently, F5 through FE must not be used in gaps, data fields, or ID fields, as this will disrupt normal operation of the FDC during formatting. Table 3 shows the definition of F5 through FE for disk intialization.

## Type IV Commands

Force Interrupt is the only Type IV command. This command permits the MPU to terminate (abort) any command in progress. Figure 3 tabulates the Type IV command option bits.
The four bits, $\mathrm{I}_{0}-\mathrm{l}_{3}$, are used to select the condition of the interrupt occurrence. Regardless of which bit is set, any command currently being executed is immediately terminated and the Busy status bit is cleared, indicating "Not Busy". Then, when the condition is met, INTRQ goes high, causing the required interrupt.
If $\mathrm{I}_{0}-\mathrm{I}_{3}$ are all " 0 ", no interrupt occurs, but any currently executing command is immediately terminated. If more than one condition is selected, then the interrupt occurs when any of the conditions is met.
To clear the interrupt, it is necessary to read the Status Register or to write the Command Register. An exception, however, is for $\mathrm{I}_{3}=1$ (Immediate Interrupt). For this case, the interrupt is cleared with another Force Interrupt command with $\mathrm{I}_{0}-\mathrm{I}_{3}$ all low.
It is necessary to wait 16 microseconds (double density) or 32 microseconds (single density) before issuing a new command after issuing a force interrupt. Loading a new command sooner than this will nullify the forced interrupt.

## Status Register

The Status Register permits the MPU to monitor a variety of conditions in the FDC. For each command, the individual status bits have their own meaning. When a command is initiated (except for the Force Interrupt command), the Busy status bit is set and the others are cleared or updated. If the Force Interrupt command is entered when another command is in progress, the Busy status bit is cleared, but the others remain unaffected. However, if the Force Interrupt command is initiated when there is not another command in progress, the other status bits are cleared or updated and represent the Type I Command status. Figure 4 illustrates the meaning of the status bits for each command.
The user has the option of reading the status register through program control or using the DRQ line with DMA or interrupt methods. When the Data register is read the DRQ bit in the status register and the DRQ line are automatically reset. A write to the Data register also causes both DRQ's to reset.
The busy bit in the status may be monitored with a user program to determine when a command is complete, in lieu of using the INTRQ line. When using the INTRQ, a busy status check is not recommended because a read of the status register to determine the condition of busy will reset the INTRQ line.
Because of internal sync cycles, certain time delays must be observed when operating under programmed I/O. They are shown in Figure 3A.


| Operation | Next Operation | Delay Req'd. |  |
| :--- | :--- | :---: | :---: |
| Write to <br> Command Reg. | Read Busy Bit <br> (Status Bit 0) | $24 \mu \mathrm{~s}$ | $12 \mu \mathrm{~s}$ |
| Write to <br> Command Reg. | Read Status <br> Bits 1-7 | $56 \mu \mathrm{~s}$ | $28 \mu \mathrm{~s}$ |
| Write Any <br> Register | Read From Diff. <br> Register | 0 | 0 |

Figure 3A. Observed delay during programmed I/O

Figure 4A. Status Register Summary

| COMMAND | STATUS BIT |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ALL TYPE I | Not Ready | Write Protect | Head Loaded | Seek Error | CRC Error | Track 0 | Index | Busy |
| READ SECTOR | Not Ready | 0 | Record Type | Rec not Found | CRC Error | Lost Data | DRQ | Busy |
| WRITE SECTOR | Not Ready | Write Protect | Write Fault | Rec not Found | CRC Error | Lost Data | DRQ | Busy |
| READ ADDRESS | Not Ready | 0 | 0 | Rec not Found | CRC Error | Lost Data | DRQ | Busy |
| READ TRACK | Not Ready | 0 | 0 | 0 | 0 | Lost Data | DRQ | Busy |
| WRITE TRACK | Not Ready | Write Protect | Write Fault | 0 | 0 | Lost Data | DRQ | Busy |

Figure 4B. Status Description for Type I Commands

| BIT | NAME | MEANING |
| :--- | :--- | :--- |
| S7 | NOT READY | This bit when set indicates the drive is not ready. When reset it indicates that the drive is <br> ready. This bit is an inverted copy of the Ready input and logically 'ored' with MR. |
| S6 | PROTECTED | When set, indicates Write Protect is activated. This bit is an inverted copy of WRPT input. |
| S5 | HEAD LOADED | When set, it indicates the head is loaded and engaged. This bit is a logical "and" of HLD <br> and HLT signals. |
| S4 | SEEK ERROR | When set, the desired track was not verified. This bit is reset to 0 when updated. |
| S3 | CRC ERROR | CRC encountered in ID field. |
| S2 | TRACK 00 | When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted copy <br> of the TR00 input. |
| S1 | INDEX | When set, indicates index mark detected from drive. This bit is an inverted copy of the <br> IP input. |
| S0 | BUSY | When set command is in progress. When reset no command is in progress. |

Figure 4C. Status Description for Type II and III Commands

| BIT | NAME | MEANING |
| :--- | :--- | :--- |
| S7 | NOT READY | This bit when set indicates the drive is not ready. When reset, it indicates that the drive <br> is ready. This bit is an inverted copy of the Ready input and 'ored' with MR. The Type II <br> and III Commands will not execute unless the drive is ready. |
| S6 | WRITE PROTECT | On Read Record: Not Used. On Read Track: Not Used. On any Write: It indicates a Write <br> Protect. This bit is reset when updated. |
| S5 | RECORD TYPE/ <br> WRITE FAULT | On Read Record: It indicates the record-type code from data field address mark. <br> 1=Deleted Data Mark. $0=$ Data Mark. On any Write: It indicates a Write Fault. This bit is <br> reset when updated. |
| S4 | RECORD NOT <br> FOUND (RNF) | When set, it indicates that the desired track, sector, or side were not found. This bit is reset <br> when updated. |
| S3 | CRC ERROR | If S4 is set, an error is found in one or more ID fields; otherwise it indicates error in data <br> field. This bit is reset when updated. |
| S2 | LOST DATA | When set, it indicates the computer did not respond to DRQ in one byte time. This bit is <br> reset to zero when updated. |
| S1 | DATA REQUEST | This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Read Operation <br> or the DR is empty on a Write operation. This bit is reset to zero when updated. |
| S0 | BUSY | When set, command is under execution. When reset, no command is under execution. |

Write Data Timing:

| PARAMETER | SYMBOL | MIN. | TYP. | MAX. | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write Data Pulse Width | Twp | 900 | 1000 | 550 | nsec | FM |
|  |  | 300 | 500 | 250 | nsec | - MFM |
| Write Gate to Write Data | Twg |  | 4 |  | $\mu \mathrm{sec}$ | FM |
|  |  |  | 2 |  | $\mu \mathrm{sec}$ | MFM |
| Write data cycle Time | Tbc |  | 4,6, or 8 |  | $\mu \mathrm{sec}$ | $\pm$ CLK Error |
| Early (Late) to Write Data | $\mathrm{T}_{\text {S }}$ | 250 |  |  | nsec | MFM |
| Early (Late) From | Th | 250 |  |  | nsec | MFM |
| Write Data |  |  |  |  |  |  |
| Write Gate off from WD | Twf |  | 4 |  | $\mu \mathrm{sec}$ | FM |
|  |  |  | 2 |  | $\mu \mathrm{sec}$ | MFM |
| WD Valid to Clk | Twdl | 100 |  |  | nsec |  |
| WD Valid after CIk | Twd2 | 100 |  |  | nsec |  |



Operating Temperature Range $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground .................................................................... . . . . . . 15 V
Negative Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -0.3 V
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%$ unless otherwise noted)

| PARAMETER |  | SYMBOL | MIN | TYP | MAX | UNIT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DC CHARACTERISTICS |  |  |  |  |  |  |  |
| Input Voltage Levels |  |  |  |  |  |  |  |
| Low Level, VIL |  |  |  |  | 0.8 | V |  |
| High Level, $\mathrm{V}_{\mathrm{IH}}$ |  |  | 2.6 |  |  | V |  |
| Output Voltage Levels |  |  |  |  |  |  |  |
| Low Level Vol |  |  |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ |
| High Level $\mathrm{V}_{\text {oh }}$ |  |  | 2.8 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=100 \mu \mathrm{~A}$ |
| Output Leakage, ILo |  |  |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {OUT }}=V_{\text {DD }}$ |
| Input Leakage, IIL |  |  |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {DD }}$ |
| Output Capacitance |  |  |  | 5 |  | pf |  |
| Input Capacitance |  |  |  | 10 |  | pf |  |
| Power Dissipation |  |  |  |  | 600 | mW |  |
| AC CHARACTERISTICS |  |  |  |  |  |  |  |
| Processor Read Timing |  |  |  |  |  |  |  |
| Address Setup Time |  | $t_{\text {SEtR }}$ | 50 |  |  | ns | Figure 5 |
| Address Hold Time |  | $t_{\text {HLdr }}$ | 10 |  |  | ns | Figure 5 |
| RE Pulse Width ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) |  | $t_{\text {RE }}$ | 400 |  |  | ns | Figure 5 |
| DRQ Reset Time |  | $t_{\text {dra }}$ |  |  | 500 | ns | Figure 5 |
| INTRQ Reset Time |  | $\mathrm{t}_{\text {IRR }}$ |  | 1000 | 6000 | ns | Figure 5 |
| Data Delay Time ( $\mathrm{C}_{L}=50 \mathrm{pF}$ ) |  | $t_{\text {DACC }}$ |  |  | 350 | ns | Figure 5 |
| Data Hold Time ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) |  | toon | 50 |  | 150 | ns | Figure 5 |
| Microprocessor Write Timing |  |  |  |  |  |  |  |
| Address Setup Time |  | tsetw | 50 |  |  | ns | Figure 6 |
| Address Hold Time |  | thlow | 10 |  |  | ns | Figure 6 |
| WE Pulse Width |  | $\mathrm{t}_{\text {we }}$ | 350 |  |  | ns | Figure 6 |
| DRQ Reset Time |  | $t_{\text {dre }}$ |  |  | 500 | ns | Figure 6 |
| INTRQ Reset Time |  | $\mathrm{t}_{\text {IRR }}$ |  | 1000 | 6000 | ns | Figure 6 |
| Data Setup Time |  | $t_{\text {ds }}$ | 250 |  |  | ns | Figure 6 |
| Data Hold Time |  | $\mathrm{t}_{\mathrm{DH}}$ | 70 |  |  | ns | Figure 6 |
| Disk Input Data Timing |  |  |  |  |  |  |  |
| RAWREAD Pulse Width |  | $t_{\text {pw }}$ | 100 | 200 |  | ns | Figure 7, See Note |
| Clock Setup Time |  | $\mathrm{t}_{\mathrm{d}}$ | 40 |  |  | ns | Figure 7 See Note |
| Clock Hold Time for MFM |  | $t_{\text {cd }}$ | 40 |  |  | ns | Figure 7 |
| Clock Hold Time for FM |  | $\mathrm{t}_{\mathrm{cs}}$ | 40 |  |  | ns | Figure 7 |
| RAWREAD Cycle Time |  | $t_{b c}$ | 3000 |  |  | ns | 3600 at $70^{\circ} \mathrm{C}$, Figure 7 |
| RCLK High Pulse Width | $\underset{\text { MFM }}{\text { M }}$ | $t_{a}$ | 1.6 | 2 |  | $\mu \mathrm{s}$ | Figure 7 |
|  | FM ${ }^{\text {MFM }}$ |  | 1.6 | 2 |  | $\mu \mathrm{S}$ | Figure 7 |
| RCLK Low Pulse Width | FM | $t_{0}$ | 1.6 | 4 |  | $\mu \mathrm{S}$ | Figure Figure 7 |
| RCLK Cycle Time | MFM | $t_{c}$ |  | 4 |  | $\mu \mathrm{s}$ | Figure 7 |
| Miscellaneous Timing 400 隹 |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
| CLK Low Pulse Width |  | $t_{\text {cla }}$ | 460 | 500 | 20000 | ns | Figure 8 |
| CLK High Pulse Width |  | $t_{\text {cD2 }}$ | 460 | 500 | 20000 | ns | Figure 8 |
| STEP Pulse Width | MFM | tstp | 4 |  |  | $\mu \mathrm{s}$ | Figure 8 |
| DIRC Setup Time |  | $t_{\text {IIR }}$ | 8 | 24 |  | $\mu \mathrm{S}$ | Figure 8 Figure 8 |
| MR Pulse Width |  | $\mathrm{t}_{\text {MR }}$ | 50 |  |  | $\mu \mathrm{s}$ | Figure 8 |
| IP Pulse Width |  | $\mathrm{t}_{\text {IP }}$ | 10 |  |  | $\mu \mathrm{S}$ | Figure 8 |
| WF Pulse Width |  | $t_{\text {wf }}$ | 10 |  |  | $\mu \mathrm{s}$ | Figure 8 |
| CLK Cycle Time |  | tcyc |  | 1.0 |  | $\mu \mathrm{s}$ | Figure 8 |

Figure 5.
Microprocessor Read Timing


Figure 6. Microprocessor Write Timing


Figure 7. Disk Input Timing


Note Pulst width on RAW READ ( $\mathrm{P} \mathbf{( 1 )} 27$ ) is normally $10-300$ ns However pulse may be any width it pulse is entirely withn whidow if puise occurs in both windows, Ihen pulse width must be less than 600 ns for MFM at CLK 1 MHz and 12OU ins lor FM at 1 MHz

Figure 8. Miscellaneous Timing


## DISK FORMATS

Disks may be formatted in IBM 3740 or System 34 formats with sector lengths of $128,256,512$, or 1024 bytes.

## IBM 3740 Format

This single-density (FM) format utilizes 128 bytes/ sector. The bytes to be generated by the system MPU for use in the execution of the Write Track command are shown in Figure 9.
IBM System 34 Format
This double-density (MFM) format utilizes 256 bytes/sector. The bytes to be generated by the system MPU for use in the execution of the Write Track command are shown in Figure 10.
Non-IBM Formats
Unique (non-IBM) formats are permissible providing the following restrictions are understood.

- Sector length may only be $128,256,512$, or 1024 bytes.
- Gap sizes must conform to Figure 11.

In addition, the Index Address Mark is not required for operation by the FDC 176X. Gap 1, 3, and 4 lengths can be as short as 2 bytes for FDC 176X operation, however PLL lock up time, motor speed variation, write-splice area, etc. will add more bytes to each gap to achieve proper operation. It is recommended that the appropriate format be used for highest system reliability.


NOTES: 1 . THIS PATTERN MUST BE WRITTEN 26 tIMES PER TRACK.
2. CONTINUE WRITING HEX FF UNTIL FDC COMPLETES SEQUENCE AND GENERATES INTRQ INTERRUPT

Figure 10.
Byte Sequence for IBM System-34 Formatting

| DATA BYTE (hex) | NO. OF BYTES | COMMENTS |
| :---: | :---: | :---: |
| 4E | 807 | $\text { Gap } 5$ |
| 00 | 12] |  |
| F6 | 3 | Writes C2 |
| FC | 1 | Index AM |
| 4E | 507 |  |
| 00 | 12 | -Gap 1 |
| F5 | 3 | Writes A1 |
| FE | 1 | ID AM |
| XX | 1 | Track Number (00-4C) |
| OX | 1 | Side Number (00 or 01) |
| XX | 1 | Sector Number (01-1A) |
| 01 | 1 | Sector Length (256 Bytes) |
| F7 | 1 | Causes 2-Byte CRC to be Written |
| 4E | 227 | -Gap 2 (ID Gap) |
| 00 | 12] |  |
| F5 | 3 | Writes A1 |
| FB | 1 | Data AM |
| 40 | 256 | Data Field |
| F7 | 1 | Causes 2-Byte CRC to be Written |
| 4E | 54 <br> 898 | Part of Gap 3 (Data Gap) |
| 4E | 598 | Gap 4 (Pre Index) |

NOTES: 1. THIS PATTERN MUST BE WRITTEN 26 TIMES PER tRACK.
2. CONTINUE WRITING HEX 4 U UNTL FDC COMPLETES sequence and generates INTRQ INTERRUPT.

| GAP | SINGLE <br> DENSITY <br> (FM) | DOUBLE <br> DENSITY <br> (MFM) | NOTE |
| :---: | :---: | :---: | :---: |
| Gap 1 | 16 bytes FF | 16 bytes 4E | 2 |
| Gap 2 | 11 bytes FF <br> 6 bytes 00 | 22 bytes 4F <br> 12 bytes 00 <br> 3 bytes A1 | 1 |
| Gap 3 | 10 bytes FF <br> 4 bytes 00 | 16 bytes 4E <br> 8 bytes 00 <br> 3 bytes A1 | 2 |
| Gap 4 | 16 bytes FF | 16 bytes 4E | 2 |

NOTES: 1. THESE BYTES COUNTS ARE EXACT.
2. THESE BYTES COUNTS ARE MINIMUM

EXCEPT FOR 3 BYTES A1. WHICH IS EXACT.
Figure 11. Gap Size Limitations

Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

# Floppy Disk Controller/Formatter FDC 

## FEATURES

SOFT SECTOR FORMAT COMPATIBILITYAUTOMATIC TRACK SEEK WITH VERIFICATIONACCOMMODATES SINGLE AND DOUBLE DENSITY FORMATSIBM 3740 Single Density (FM)
IBM System 34 Double Density (MFM)READ MODE
Single/Multiple Sector Read with Automatic Search or Entire Track Read
Selectable 128 Byte or Variable Length RecordWRITE MODE
Single/Multiple Sector Write with Automatic Sector Search
Entire Track Write for Diskette InitializationPROGRAMMABLE CONTROLS
Selectable Track to Track Stepping Time
Side Select Compare
$\square$ SYSTEM COMPATIBILITY
Double Buffering of Data 8 Bit Bi-Directional Bus for Data, Control and Status
DMA or Programmed Data Transfers
All Inputs and Outputs are TTL Compatible
On-chip Track and Sector Registers/Comprehensive Status Information
WRITE PRECOMPENSATION (MFM AND FM)
$\square$ SIDE SELECT LOGIC (FDC 1795, FDC 1797)
$\square$ WINDOW EXTENSION(IN MFM)

PIN CONFIGURATION

| NC | 81 | 40 | $+12 \mathrm{~V}$ |
| :---: | :---: | :---: | :---: |
| $\overline{W E}$ | 2 | 391 | INTRQ |
| $\overline{\mathrm{CS}}$ | 3 | 38 | DRQ |
| $\overline{\mathrm{RE}}$ | 4 | 37 | DDEN.* |
| $\mathrm{A}_{0}$ | 5 | 36 | WPPT |
| A | 06 | 35 | IP |
| DAL ${ }^{*}$ | 7 | 34 | $\overline{\text { TR00 }}$ |
| DAL $1^{*}$ | 8 | 33 | $\overline{W F}$ |
| DAL $2^{*}$ | ¢ 9 | 32 p | READY |
| DAL ${ }^{*}$ | C 10 | 31 | WD |
| DAL 4* | 11 | 30 | WG |
| DAL $5^{*}$ | 12 | 29 | TG43 |
| DAL 6 * | 13 | 28 | HLD |
| DAL7* | O 14 | 27 | RAW READ |
| STEP | 15 | 26 | RCLK |
| DIRC | ¢ 16 | 25 | RG/SSO |
| EARLY | ¢ 17 | 24 | CLK |
| LATE | 18 | 23 | HLT |
|  | 19 | 22 | TEST |
| GND | $\underline{20}$ | 216 | +5V |

-INVERTED BUS FOR FDC 1791, FDC 1792, FDC 1795 *MUST BE LEFT OPEN FOR FDC 1792 and FDC 1794 PACKAGE: 40 pin D.I.P.INCORPORATES ENCODING/DECODING AND ADDRESS MARK CIRCUITRYCOMPATIBLE WITH FD179X-02COPLAMOS® $n$-CHANNEL MOS TECHNOLOGY COMPATIBLE WITH THE FDC 9216 FLOPPY DISK DATA SEPARATOR

## GENERAL DESCRIPTION

The FDC 179X is an MOS/LSI device which performs the functions of a Floppy Disk Controller/Formatter in a single chip implementation. The basic FDC 179X chip design has evolved into six specific parts: FDC 1791, FDC 1792, FDC 1793, FDC 1794, FDC 1795, and the FDC 1797.

This FDC family performs all the functions necessary to read or write data to any type of floppy disk drive. Both $8^{\prime \prime}$ and $51 / 4^{\prime \prime}$ (mini-floppy) drives with single or double density storage capabilities are supported. These n-channel MOS/LSI devices will replace a large amount of discrete logic required for interfacing a host processor to a floppy disk.
The FDC 1791 is IBM 3740 compatible in single density mode (FM) and System 34 compatible in double density mode (MFM). The FDC 1791 contains enhanced features necessary to read/write and format a double
density diskette. These include address mark detection, FM and MFM encode and decode logic, window extension, and write precompensation.
The FDC 1793 is identical to the FDC 1791 except the DAL lines are TRUE for systems that utilize true data busses.
The FDC 1792 operates in the single density mode only. Pin 37 ( $\overline{\text { DDEN }}$ ) of the FDC 1792 must be left open for proper operation. The FDC 1794 is identical to the FDC 1792 except the DAL lines are TRUE for systems that utilize true data busses. The FDC 1795 adds side select logic to the FDC 1791. The FDC 1797 adds the side select logic to the FDC 1793.
The processor interface consists of an 8 bit bidirectional bus for data, status, and control word transfers. This family of controllers is configured to operate on multiplexed bus with other bus-oriented devices.


SYSTEM BLOCK DIAGRAM


## DESCRIPTION OF PIN FUNCTIONS

| PIN NO | NAME | SYMBOL | FUNCTION |
| :---: | :--- | :---: | :--- |
| 1 | NO CONNECTION | NC | This pin is internally connected to the substrate bias generator and <br> must be left open. |
| 20 | GROUND | $V_{S S}$ | Ground |
| 21 | POWER SUPPLY | $V_{C C}$ | +5 V |
| 40 | POWER SUPPLY | $V_{D D}$ | +12 V |
| 19 | $\overline{M A S T E R ~ R E S E T ~}$ | $\overline{M R}$ | A logic low on this input resets the device and loads HEX 03 into <br> the command register. The Not Ready (Status Bit 7 ) is reset during <br> $\overline{M R}$ ACTIVE. When $\overline{M R}$ is brought to a logic high a Restore <br> Command is executed. regardless of the state of the Ready signal <br> from the drive. Also, HEX 01 is loaded into the sector register. |

COMPUTER INTERFACE:

| 2 | WRITE ENABLE | $\overline{W E}$ | A logic low on this input gates data on the DAL into the selected register when $\overline{\mathrm{CS}}$ is low. |
| :---: | :---: | :---: | :---: |
| 3 | $\overline{\text { CHIP SELECT }}$ | $\overline{\mathrm{CS}}$ | A logic low on this input selects the chip and the parallel data bus (DAL). |
| 4 | READ ENABLE | $\overline{\mathrm{RE}}$ | A logic low on this input controls the placement of data from a selected register on DALø-DAL7 when $\overline{\mathrm{CS}}$ is low. |
| 5,6 | REGISTER SELECT LINES | A0, A1 | These inputs select the register to receive/transfer data on the DAL lines under RE and WE control: |
| 7-14 | DATA ACCESS LINES | DALODAL7 | Eight bit Bidirectional bus used for transfer of data, control, and status. This bus is a receiver enabled by WE or a transmitter enabled by $\overline{R E}$. The Data Bus is inverted on the FDC 1791, FDC 1792 and FDC 1795. |
| 24 | CLOCK | CLK | This input requires a free-running square wave clock for internal timing reference, 2 MHz for $8^{\prime \prime}$ drives, 1 MHz for $5^{1 / 4^{\prime \prime}}$ drives. |
| 38 | DATA REQUEST | DRQ | This open drain output indicates that the DR contains assembled data in Read operations, or the DR is empty in Write operations. This signal is reset when serviced by the computer through reading or loading the DR in Read or Write operations, respectively. Use a 10 K pull-up resistor to +5 V . |
| 39 | INTERRUPT REQUEST | INTRQ | This open drain output is set at the completion or termination of any operation and is reset when a new command is loaded into the command register or the status register is read. Use a 10 K pull-up resistor to +5 V . |

FLOPPY DISK INTERFACE:

| 15 | STEP | STEP | Step and direction motor control. The step output contains a pulse <br> for each step. |
| :---: | :--- | :---: | :--- |
| 16 | DIRECTION | DIRC | Direction Output is active high when stepping in, active low when <br> stepping out. |
| 17 | EARLY | LATE | Indicates that the write data pulse occurring while Early is active <br> (high) should be shifted early for write precompensation. |
| 18 | LATE | Indicates that the write data pulse occurring while Late is active <br> (high) should be shifted late for write precompensation. |  |
| 22 | TEST | This input is used for testing purposes only and should be tied to <br> +5V or left open by the user unless interfacing to voice coil <br> actuated motors. |  |
| 23 | HEAD LOAD TIMING | HLT | When a logic high is found on the HLT input the head is assumed <br> to be engaged. |


| PIN NO. | NAME | SYMBOL | FUNCTION |
| :---: | :---: | :---: | :---: |
| 25 | READ GATE (1791/3) | RG | A high level on this output indicates to the data separator circuitry that a field of zeros (or ones) has been encountered, and is used for synchronization. |
| 25 | SIDE SELECT OUTPUT $(1795,1797)$ | SSO | The logic level of the Side Select Output is directly controlled by the 'S' flag in Type II or III commands. When $S=1$, SSO is set to a logic 1. When $\mathrm{S}=0, \mathrm{SSO}$ is set to a logic 0 . The Side Select Output is only updated at the beginning of a Type II or III command. It is forced to a logic 0 upon a MASTER RESET condition. |
| 26 | READ CLOCK | RCLK | A nominal square-wave clock signal derived from the data stream must be provided to this input. Phasing (i.e. RCLK transitions) relative to RAW READ is important but polarity (RCLK high or low) is not. |
| 27 | $\overline{\text { RAW READ }}$ | $\frac{\overline{\text { RAW }}}{\overline{\text { READ }}}$ | The data input signal directly from the drive. This input shall be a negative pulse for each recorded flux transition. |
| 28 | HEAD LOAD | HLD | The HLD output controls the loading of the Read-Write head against the media. |
| 29 | TRACK GREATER THAN 43 | TG43 | This output informs the drive that the Read/Write head is positioned between tracks 44-76. This output is valid only during Read and Write Commands. |
| 30 | WRITE GATE | WG | This output is made valid before writing is to be performed on the diskette. |
| 31 | WRITE DATA | WD | A 250 ns (MFM) or 500 ns (FM) pulse per flux transition. WD contains the unique Address marks as well as data and clock in both FM and MFM formats. |
| 32 | READY | READY | This input indicates disk readiness and is sampled for a logic high before Read or Write commands are performed. If Ready is low the Read or Write operation is not performed and an interrupt is generated. Type I operations are performed regardless of the state of Ready. The Ready input appears in inverted format as Status Register bit 7. |
| 33 | $\begin{aligned} & \hline \text { WRITE FAULT/ } \\ & \hline \text { VFO ENABLE } \end{aligned}$ | WF/VFOE | This is a bi-directional signal used to signify writing faults at the drive, and to enable the external PLO data separator. When $W G=1$, Pin 33 functions as a $\overline{W F}$ input. If $\overline{W F}=0$, any write command will immediately be terminated. When $W G=0$, Pin 33 functions as a VFOE output. VFOE will go low during a read operation after the head has loaded and settled (HLT=1). On the 1795/7, it will remain low until the last bit of the second CRC byte in the ID field. VFOE will then go high until 8 bytes (MFM) or 4 bytes (FM) before the Address Mark. It will then go active until the last bit of the second CRC byte of the Data Field. On the 1791/3, VFOE will remain low until the end of the Data Field. |
| 34 | $\overline{\text { TRACK } 00}$ | TR00 | This input informs the FDC179X that the Read/Write head is positioned over Track 00. |
| 35 | INDEX PULSE | $\stackrel{\rightharpoonup}{P}$ | This input informs the FDC179X when the index hole is encountered on the diskette. |
| 36 | WRITE PROTECT | $\overline{\text { WPRT }}$ | This input is sampled whenever a Write Command is received. A logic low terminates the command and sets the Write Protect Status bit. |
| 37 | DOUBLE DENSITY | $\overline{\text { DDEN }}$ | This pin selects either single or double density operation. When $\overline{D D E N}=0$, double density is selected. When $\overline{\operatorname{DDEN}}=1$, single density is selected. This line must be left open on the 1792/4. |

## FUNCTIONAL DESCRIPTION

The FDC 179X-02 major functional blocks are as follows: Data Shift Register - This 8-bit register assembles serial data from the Read Data input (RAW READ) during Read operations and transfers serial data to the Write Data output during Write operations.
Data Register-This 8 -bit register is used as a holding register during Disk Read and Write operations. In Disk Read operations the assembled data byte is transferred in parallel to the Data Register from the Data Shift Register. In Disk Write operations information is transferred in parallel from the Data Register to the Data Shift Register.
When executing the Seek command the Data Register holds the address of the desired Track position. This register is loaded from the DAL and gated onto the DAL under processor control.
Sector Register (SR) - This 8-bit register holds the address of the desired sector position. The contents of the register are compared with the recorded sector number in the ID field during disk Read or Write operations. The Sector Register contents can be loaded from or transferred to the DAL. This register should not be loaded when the device is busy.
Command Register (CR)—This 8-bit register holds the command presently being executed. This register should not be loaded when the device is busy unless the new command is a Force Interrupt. The command register can be loaded from the DAL, but not read onto the DAL. Status Register (STR) - This 8 -bit register holds device Status information. The meaning of the Status bits is a function of the type of command previously executed.

This register can be read onto the DAL, but not loaded from the DAL.
CRC Logic-This logic is used to check or to generate the 16 -bit Cyclic Redundancy Check (CRC). The polynomial is: $\mathrm{G}(\mathrm{x})=\mathrm{x}^{16}+\mathrm{x}^{12}+\mathrm{x}^{5}+1$.
Track Register-This 8 -bit register holds the track number of the current Read/Write head position. It is incremented by one every time the head stepped in (towards track 76) and decremented by one when the head is stepped out (towards track 00 ). The contents of the register are compared with the recorded track number in the ID field during disk Read, Write, and Verify operations. The Track Register can be loaded from or transferred to the DAL. This Register should not be loaded when the device is busy.
The CRC includes all information starting with the address mark and up to the CRC characters. The CRC register is preset to ones prior to data being shifted through the circuit.
Arithmetic/Logic Unit (ALU) - The ALU is a serial comparator, incrementer, and decrementer and is used for register modification and comparisons with the disk recorded ID field.
Timing and Control-All computer and Floppy Disk Interface controls are generated through this logic. The internal device timing is generated from an external crystal clock.
AM Detector-The address mark detector detects ID, data and index address marks during ready and write operations.

## OPERATION

FDC 1791, FDC 1793, FDC 1795 and FDC 1797 have two modes of operation according to the state of DDEN (Pin 37). When $\overline{\mathrm{DDEN}}=1$, single density is selected. In either case, the CLK input (Pin 24) is at 2 MHz . However, when interfacing with the mini-floppy, the CLK input is set at 1 MHz for both single density and double density. When the clock is at 2 MHz , the stepping rates of $3,6,10$, and 15 ms are obtaınable. When CLK equals 1 MHz these times are doubled.
DDEN must be left open for the FDC 1792 and FDC 1794.

## Disk Read Operation

Sector lengths of $128,256,512$ or 1024 are obtainable in either FM or MFM formats. For FM, DDEN should be placed to logical "1." For MFM formats, DDEN should be placed to a logical " 0 ." Sector lengths are determined at format time by a special byte in the "ID" field. If this Sector length byte in the ID field is zero, then the sector length is 128 bytes. If 01 then 256 bytes. If 02 , then 512 bytes. If 03, then the sector length is 1024 bytes. The number of sectors per track can be from 1 to 255 sectors. The number of tracks is from 0 to 255 tracks. For read operations, the FDC 179X requires RAW READ Data (Pin 27) signal which is a 250 ns pulse per flux transition and a Read clock (RCLK) signal to indicate flux transition spacings. The RCLK (Pin 26) signal is
provided by some drives but if not, it may be derived externally by Phase lock loops, one shots, or counter techniques. In addition, a Read Gate Signal is provided as an output (Pin 25) which can be used to inform phase lock loops when to acquire synchronization. When reading from the media in FM, RG is made true when 2 bytes of zeroes are detected. The FDC179X must find an address mark within the next 10 bytes; otherwise RG is reset and the search for 2 bytes of zeroes begins all over again. If an address mark is found within 10 bytes, RG remains true as long as the FDC179X is deriving any useful information from the data stream. Similarly for MFM, RG is made active when 4 bytes of " 00 " or " $F F$ " are detected. The FDC179X must find an address mark within the next 16 bytes, otherwise RG is reset and search resumes.
During read operations ( $W G=0$ ), the $\overline{\mathrm{VFOE}}$ (Pin 33) is provided for phase lock loop synchronization. VFOE will go active when:
a) Both HLT and HLD are True
b) Settling Time, if programmed, has expired
c) The 179X is inspecting data off the disk

If $\overline{W F} / \overline{\text { VFOE }}$ is not used, leave open or tie to a 10 K resistor to +5 .
On Disk Read operations the Data Request is activated (set high) when an assembled serial input byte is
transferred in parallel to the Data Register. This bit is cleared when the Data Register is read by the processor. If the Data Register is read after one or more characters are lost by having new data transferred into the register prior to processor readout, the Lost Data bit is set in the Status Register. The Read operation continues until the end of sector is reached.

## Disk Write Operation

When writing is to take place on the diskette the Write Gate (WG) output is activated, allowing current to flow into the Read/Write head. As a precaution against erroneous writing the first data byte must be loaded into the Data Register in response to a Data Request from the FDC179X before the Write Gate signal can be activated. Writing is inhibited when the Write Protect input is a logic low, in which case any Write command is immediately terminated, an interrupt is generated and the Write Protect status bit is set. The Write Fault input, when activated, signifies a writing fault condition detected in disk drive electronics such as failure to detect write current flow when the Write Gate is activated. On detection of this fault the FDC179X terminates the current command, and sets the Write Fault bit (bit 5) in the Status Word. The Write Fault input should be made inactive when the Write Gate output becomes inactive.
For write operations, the FDC179X provides Write Gate (Pin 30) and Write Data (Pin 31) outputs. Write data consists of a series of 500 ns pulses in FM ( $\overline{\mathrm{DDEN}}=1$ )
and 250 ns pulses in MFM ( $\overline{\overline{D E N}}=0$ ). Write Data provides the unique address marks in both formats.
Also during write, two additional signals are provided for write precompensation. These are EARLY (Pin 17) and LATE (Pin 18). EARLY is active true when the WD pulse appearing on ( Pin 30 ) is to be written early. LATE is active true when the WD pulse is to be written LATE. If both EARLY and LATE are low when the WD pulse is present, the WD pulse is to be written at nominal. Since write precompensation values vary from disk manufacturer to disk manufacturer, the actual value is determined by several one shots or delay lines which are located external to the FDC179X. The write precompensation signals EARLY and LATE are valid for the duration of WD in both FM and MFM formats.
On Disk Write operations the Data Request is activated when the Data Register transfers its contents to the Data Shift Register, and requires a new data byte. It is reset when the Data Register is loaded with new data by the processor. If new data is not loaded at the time the next serial byte is required by the Floppy Disk, a byte of zeroes is written on the diskette and the Lost Data bit is set in the Status Register.
At the completion of every command an INTRQ is generated. INTRQ is reset by either reading the status register or by loading the command register with a new command. In addition, INTRQ is generated if a Force Interrupt command condition is met.

## COMMAND WORDS

The FDC179X will accept eleven commands. Command words should only be loaded in the Command Register when the Busy status bit is off (Status bit 0). The one exception is the Force Interrupt command. Whenever a command is being executed, the Busy status bit is set. When a command is completed, an interrupt is generated and the Busy status bit is reset. The Status Register indicates whether the completed command encountered an error or was fault free. For ease of discussion, commands are divided into four types. Commands and types are summarized in Table 1.

Table 1. Command Summary

|  |  | BITS |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| COMMAND | TYPE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Restore | I | 0 | 0 | 0 | 0 | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| Seek | I | 0 | 0 | 0 | 1 | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| Step | I | 0 | 0 | 1 | u | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| Step In | I | 0 | 1 | 0 | u | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| Step Out | I | 0 | 1 | 1 | u | h | V | $\mathrm{r}_{1}$ | $\mathrm{r}_{0}$ |
| Read Sector | II | 1 | 0 | 0 | m | $\mathrm{~F}_{2}$ | E | $\mathrm{F}_{1}$ | 0 |
| Write Sector | II | 1 | 0 | 1 | m | $\mathrm{~F}_{2}$ | E | $\mathrm{F}_{1}$ | $\mathrm{a}_{0}$ |
| Read Address | III | 1 | 1 | 0 | 0 | 0 | E | 0 | 0 |
| Read Track | III | 1 | 1 | 1 | 0 | 0 | E | 0 | 0 |
| Write Track | III | 1 | 1 | 1 | 1 | 0 | E | 0 | 0 |
| Force Interrupt | IV | 1 | 1 | 0 | 1 | $\mathrm{I}_{3}$ | $\mathrm{I}_{2}$ | $\mathrm{I}_{1}$ | $\mathrm{I}_{0}$ |

## Type I Commands

The Type I Commands are Restore, Seek, Step, Step-In, and Step-Out. Each of the Type I Commands contains a rate field $\left(r_{0} r_{1}\right)$, which determines the stepping motor rate as defined in Table 2.
The Type I Commands contain a head load flag (h) which determines if the head is to be loaded at the beginning of the command. If $h=1$, the head is loaded at the beginning of the command (HLD output is made active). If $h=0$, HLD is deactivated. Once the head is loaded, the head will remain engaged until the FDC179X receives a command that specifically disengages the head. If the FDC179X is idle (busy=0) for 15 revolutions of the disk, the head will be automatically disengaged (HLD made inactive).
The Type I Commands also contain a verification (V) flag which determines if a verification operation is to take place on the destination track. If $V=1$, a verification is performed, if $V=0$, no verification is performed.
During verification, the head is loaded and after an internal 15 ms delay, the HLT input is sampled. When HLT is active (logic true), the first encountered ID field if read off the disk. The track address of the ID field is then compared to the Track Register; if there is a match and a valid ID CRC, the verification is complete, an interrupt is generated and the Busy status bit is reset. If there is not a match but there is valid ID CRC, an interrupt
is generated, and Seek Error Status bit (Status bit 4) is set and the Busy status bit is reset. If there is a match but not a valid CRC, the CRC error status bit is set (Status bit 3), and the next encountered ID field is read from the disk for the verification operation. If an ID field with a valid CRC cannot be found after four revolutions of the disk, the FDC179X terminates the operation and sends an interrupt (INTRQ).
The Step, Step-In, and Step-Out commands contain an Update flag ( $u$ ). When $u=1$, the track register is updated by one for each step. When $u=0$, the track register is not updated.
On the FDC 1795/7 devices, the SSO output is not affected during Type 1 commands, and an internal side compare does not take place when the (V) Verify Flag is on.

## Restore (Seek Track 0)

Upon receipt of this command the Track 00 (TR00) input is sampled. if TROO is active low indicating the Read-Write head is positioned over track 0 , the Track Register is loaded with zeroes and an interrupt is generated. If TRO0 is not active low, stepping pulses (pins 15 to 16) at a rate specified by the $r_{1} r_{0}$ field are issued until the TROO input is activated. At this time the Track Register is loaded with zeroes and an interrupt is generated. If the TR00 input does not go active low after 255 stepping pulses, the FDC179X terminates operation, interrupts, and sets the Seek error status bit. A verification operation takes place if the V flag is set. The h bit allows the head to be loaded at the start of command. Note that the Restore command is executed when MR goes from an active to an inactive state.

## Seek

This command assumes that the Track Register contains the track number of the current position of the ReadWrite head and the Data Register contains the desired track number. The FDC179X will update the Track register and issue stepping pulses in the appropriate direction until the contents of the Track register are equal to the contents of the Data Register (the desired track location). A verification operation takes place if the V flag is on. The $h$ bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

## Step

Upon receipt of this command, the FDC179X issues one stepping pulse to the disk drive. The stepping motor direction is the same as in the previous step command. After a delay determined by the $r_{1} r_{0}$ field, a verification takes place if the V flag is on. If the u flag is on, the Track Register is updated. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

## Step-In

Upon receipt of this command, the FDC179X issues one stepping pulse in the direction towards track 76. If the u flag is on, the Track Register is incremented by one. After a delay determined by the $r_{1} r_{0}$ field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command.

## Step-Out

Upon receipt of this command, the FDC179X issues one stepping pulse in the direction towards track 0 . If the u flag is on, the Track Register is decremented by one. After a delay determined by the $r_{1} r_{0}$ field, a verification takes place if the V flag is on. The $h$ bit allows the head to be loaded at the start of command. An interrupt is generated at the completion of the command.

## Head Positioning

The period of each positioning step is specified by the $r$ field in bits 1 and 0 of the command word. After the last directional step an additional 15 milliseconds of head settling time takes place if the Verify flag is set in Type I commands. Note that this time doubles to 30 ms for a 1 MHz clock. If $\overline{T E S T}=0$, there is zero settling time. There is also a 15 ms head settling time if the E flag is set in any Type II or III command.
The rates (shown in Table 2) can be applied to a StepDirection Motor through the device interface.
Step-A $2 \mu \mathrm{~s}$ (MFM) or $4 \mu \mathrm{~s}$ (FM) pulse is provided as an output to the drive. For every step pulse issued, the drive moves one track location in a direction determined by the direction output.
Direction (DIRC) - The Direction signal is active high when stepping in and low when stepping out. The Direction signal is valid $12 \mu$ sefore the first stepping pulse is generated.
When a Seek, Step or Restore command is executed an optional verification of Read-Write head position can be performed by setting bit $2(\mathrm{~V}=1)$ in the command word to a logic 1. The verification operation begins at the end of the 15 millisecond settling time after the head is loaded against the media. The track number from the first encountered ID Field is compared against the contents of the Track Register. If the track numbers compare and the ID Field Cyclic Redundancy Check (CRC) is correct, the verify operation is complete and an INTRQ is generated with no errors. The FDC179X must find an ID field with correct track number and correct CRC within 5 revolutions of the media; otherwise the seek error is set and an INTRQ is generated.

Table 2. Stepping Rates


The Head Load (HLD) output controls the movement of the read/write head against the media. HLD is activated at the beginning of a Type I command if the h flag is set $(h=1)$, at the end of the Type I command if the verify flag ( $V=1$ ), or upon receipt of any Type II or III command. Once HLD is active it remains active until either a Type I command is received with ( $\mathrm{h}=0$ and $\mathrm{V}=0$ ); or if the FDC179X is in an idle state (non-busy) and 15 index pulses have occurred.
Head Load Timing (HLT) is an input to the FDC179X which is used for the head engage time. When HLT=1, the FDC179X assumes the head is completely engaged.

The head engage time is typically 30 to 100 ms depending on drive. The low to high transition on HLD is typically used to fire a one shot. The output of the one shot is then used for HLT and supplied as an input to the FDC179X.


Head Load Timing

When both HLD and HLT are true, the FDC179X will then read from or write to the media. The "and" of HLD and HLT appears as a status bit in Type I status.

```
TYPE I COMMANDS FLAG SUMMARY
h=Head Load Flag (Bit 3)
    h=1, Load head at beginning
    h=0, Unload head at beginning
V=Verify flag (Bit 2)
    V=1, Verify on destination track
    V=0, No verify
    \mp@subsup{r}{1}{}\mp@subsup{r}{0}{}=\mathrm{ Stepping motor rate (Bits 1-0)}
    Refer to Table 2 for rate summary
    u=Update flag (Bit 4)
    u=1, Update Track register
    u=0, No update
```


## Type II Commands

The Type II Commands are the Read Sector and Write Sector commands. Prior to loading the Type II Command into the Command Register, the system must load the Sector Register with the desired sector number. Upon receipt of the Type II command, the busy status Bit is set. If the E flag $=1$ (this is the normal case) HLD is made active and HLT is sampled until true after a 15 msec delay. If the E flag is 0, HLD is made active and HLT is sampled with no delay until true. The ID field and Data Field format are shown below.
When an ID field is located on the disk, the FDC179X compares the Track Number on the ID field with the Track Register. If there is not a match, the next encountered ID field is read and a comparison is again made. If there
is a match, the Sector Number of the ID field is compared with the Sector Register. If there is not a Sector match, the next encountered ID field is read off the disk and comparisons again made. If the ID field CRC is correct, the data field is then located and will be either written into, or read from depending upon the command. The FDC179X must find an ID field with a Track number, Sector number, side number, and CRC within four revolutions of the disk; otherwise, the Record not found status bit is set (Status bit 3) and the command is terminated with an interrupt.
Each of the Type II Commands contains an (m) flag which determines if multiple records (sectors) are to be read or written, depending upon the command. If $m=0$, a single sector is read or written and an interrupt is generated at the completion of the command. If $m=1$, multiple records are read or written with the sector register internally updated so that an address verification can occur on the next record. The FDC179X will read or write multiple records starting with the sector presently in the sector register. The FDC179X will continue to read or write multiple records and update the sector register until the sector register exceeds the number of sectors on the track or until the Force Interrupt command is loaded into the Command Register, which terminates the command and generates an interrupt.
If the Sector Register exceeds the number of sectors on the track, the Record-Not-Found status bit will be set.
The Type II commands also contain side select compare flags. When $\mathrm{C}=0$, no side comparison is made. When $\mathrm{C}=1$, the LSB of the side number is read off the ID Field of the disk and compared with the contents of the $(S)$ flag. If the $S$ flag compares with the side number recorded in the ID field, the 179X continues with the ID search. If a comparison is not made within 5 index pulses, the interrupt line is made active and the Record-Not-Found status bit is set.
The FDC 1795/7 READ SECTOR and WRITE SECTOR commands include $a$ ' $b$ ' flag. The ' $b$ ' flag, in conjunction with the sector length byte of the ID Field, allows different byte lengths to be implemented in each sector. For IBM compatability, the 'b' flag should be set to a one. The ' s ' flag allows direct control over the SSO Line (Pin 25) and is set or reset at the beginning of the command, dependent upon the value of this flag.

| Sector Length Table |  |
| :---: | :---: |
| Sector Length | Number of Bytes <br> Field (hex) |
| 00 | in Sector (decimal) |
| 01 | 128 |
| 02 | 256 |
| 03 | 512 |

Field Format

| $\begin{gathered} \text { GAP } \\ \text { III } \end{gathered}$ | $\begin{aligned} & \hline \text { ID } \\ & \text { AM } \\ & \hline \end{aligned}$ | TRACK NUMBER | SIDE NUMBER | SECTOR NUMBER | SECTOR LENGTH | $\begin{gathered} \hline \text { CRC } \\ 1 \end{gathered}$ | $\begin{gathered} \hline \text { CRC } \\ 2 \end{gathered}$ | $\begin{gathered} \text { GAP } \\ \text { II } \end{gathered}$ | $\begin{aligned} & \text { DATA } \\ & \text { AM } \end{aligned}$ | DATA FIELD | $\begin{gathered} \text { CRC } \\ 1 \end{gathered}$ | $\begin{gathered} \hline \text { CRC } \\ 2 \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ID FIELD |  |  |  |  |  |  |  |  |  | DATA FIELD |  |  |

In MFM only, IDAM and DATA AM are preceded by three bytes of A1 with clock transition between bits 4 and 5 missing.

## Read Sector

Upon receipt of the Read Sector command, the head is loaded, the Busy status bit set, and when an ID field is encountered that has the correct track number, correct sector number, correct side number, and correct CRC, the data field is presented to the computer. The Data Address Mark of the data field must be found within 30 bytes in single density and 43 bytes in double density of the last ID field CRC byte; if not, the Record-NotFound status bit is set and the operation is terminated. When the first character or byte of the data field has been shifted through the DSR, it is transferred to the DR, and DRQ is generated. When the next byte is accumulated in the DSR, it is transferred to the DR and another DRQ is generated. If the Computer has not read the previous contents of the DR before a new character is transferred that character is lost and the Lost Data Status bit is set. This sequence continues until the complete data field has been inputted to the computer. If there is a CRC error at the end of the data field, the CRC error status bit is set, and the command is terminated (even if it is a multiple record command).
At the end of the Read operation, the type of Data Address Mark encountered in the data field is recorded in the Status Register (Bit 5) as shown below:
BIT 5
1 Deleted Data Mark
0
Data Mark

## Write Sector

Upon receipt of the Write Sector command, the head is loaded (HLD active) and the Busy status bit is set. When an ID field is encountered that has the correct track number, correct sector number, correct side number, and correct CRC, a DRQ is generated. The FDC179X counts off 11 bytes in single density and 22 bytes in double density from the CRC field and the Write Gate (WG) output is made active if the DRQ is serviced (i.e., the DR has been loaded by the computer). If DRQ has not been serviced, the command is terminated and the Lost Data status bit is set. If the DRQ has been serviced, the WG is made active and six bytes of zeros in single density and 12 bytes in double density are then written on the disk. At this time the Data Address Mark is then written on the disk as determined by the $a_{0}$ field of the command as shown below:

| $a_{0}$ | Data Address Mark (Bit 0) |
| :---: | :---: |
| 1 | Deleted Data Mark |
| 0 | Data Mark |

The FDC179X then writes the data field and generates DRQ's to the computer. If the DRQ is not serviced in time for continuous writing the Lost Data Status Bit is set and a byte of zeros is written on the disk. The command is not terminated. After the last data byte has been written on the disk, the two-byte CRC is computed internally and written on the disk followed by one byte of logic ones in FM or in MFM. The WG output is then deactivated.


Figure 1. Type II and III Flag Summary

## Type III Commands

There are three Type III Commands:

- READ ADDRESS-Read the next ID field (6 bytes) into the FDC.
- READ TRACK-Read all bytes of the entire track, including gaps.
- WRITE TRACK - Write all bytes to the entire track, including gaps.


## Read Address

Upon receipt of the Read Address command, the head is loaded and the Busy Status Bit is set. The next encountered ID field is then read in from the disk, and the six data bytes of the ID field are assembled and transferred to the DR, and a DRQ is generated for each byte. The six bytes of the ID field are shown below:

| TRACK <br> ADDR | SIDE <br> NUMBER | SECTOR <br> ADDRESS | SECTOR <br> LENGTH | CRC <br> 1 | CRC <br> 2 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 2 | 3 | 4 | 5 | 6 |

Although the CRC characters are transferred to the computer, the FDC179X checks for validity and the CRC
error status bit is set if there is a CRC error. The Track Address of the ID field is written into the sector register. At the end of the operation an interrupt is generated and the Busy Status is reset.

## Read Track

Upon receipt of the Read Track command, the head is loaded and the Busy Status bit is set. Reading starts with the leading edge of the first encountered index pulse and continues until the next index pulse. As each byte is assembled it is transferred to the Data Register and the Data Request is generated for each byte. No CRC checking is performed. Gaps are included in the input data stream. The accumulation of bytes is synchronized to each Address Mark encountered. Upon completion of the command, the interrupt is activated. RG is not activated during the Read Track Command. An internal side compare is not performed during a Read Track.

## Write Track

Upon receipt of the Write Track command, the head is loaded and the Busy Status bit is set. Writing starts with the leading edge of the first encountered index pulse and continues until the next index pulse, at which


[^11]Figure 2. IBM Compatible Sector/Track Format
time the interrupt is activated. The Data Request is activated immediately upon receiving the command, but writing will not start until after the first byte has been loaded into the Data Register. If the DR has not been loaded by the time the index pulse is encountered the operation is terminated making the device Not Busy, the Lost Data Status Bit is set, and the Interrupt is activated. If a byte is not present in the DR when needed, a byte of zeros is substituted. Address Marks and CRC characters are written on the disk by detecting certain data byte patterns in the outgoing data stream as shown in the table below. The CRC generator is initialized when any data byte from F8 to FE is about to be transferred from the DR to the DSR in FM or by receipt of F5 in MFM.
Disk formatting (initialization) is accomplished by the Write Track command. Each byte for the entire track must be provided for proper formatting. This includes gap as well as data bytes.
The sequence required to format a diskette begins with positioning the Read/Write head at the desired track. Once this has been done, it is necessary to perform a Write Track command to store all the information on a track. The Write Track command uses DRQ to request each byte from the system MPU, starting with the byte at the beginning of the physical Index Pulse and ending with the last gap bytes at the end of the track. Figure 2 illustrates the IBM standard for track formatting.
Normally, each data byte stored on the diskette must be generated by the system MPU and passed into the FDC Data Register. However, there are exceptions to this rule. If a data byte of hex F5 through FE is entered into the Data Register, then the FDC recognizes this as an AM with missing clocks or CRC generation code. Consequently, F5 through FE must not be used in gaps, data fields, or ID fields, as this will disrupt normal operation of the FDC during formatting.

## Type IV Commands

Force Interrupt is the only Type IV command. This command permits the MPU to terminate (abort) any command in progress. Figure 3 tabulates the Type IV command option bits.
The four bits, $l_{0}-I_{3}$, are used to select the condition of the interrupt occurrence. Regardless of which bit is set, any command currently being executed is immediately terminated and the Busy status bit is cleared, indicating "Not Busy". Then, when the condition is met, INTRQ goes high, causing the required interrupt.
If $\mathrm{I}_{0}-\mathrm{I}_{3}$ are all " 0 ", no interrupt occurs, but any currently executing command is immediately terminated. If more than one condition is selected, then the interrupt occurs when any of the conditions is met.
To clear the interrupt, it is necessary to read the Status Register or to write the Command Register. An exception, however, is for $\mathrm{I}_{3}=1$ (Immediate Interrupt). For this case, the interrupt is cleared with another Force Interrupt command with $\mathrm{I}_{0}-\mathrm{I}_{3}$ all low.

## Status Register

The Status Register permits the MPU to monitor a variety of conditions in the FDC. For each command, the individual status bits have their own meaning. When a command is initiated (except for the Force Interrupt command), the Busy status bit is set and the others are cleared or updated. If the Force Interrupt command is entered when another command is in progress, the Busy status bit is cleared, but the others remain unaffected. However, if the Force Interrupt command is initiated when there is not another command in progress, the other status bits are cleared or updated and represent the Type I Command status. Figure 4 illustrates the meaning of the status bits for each command.

Figure 3. Force Interrupt Command Flags

Figure 4A. Status Register Summary

| COMMAND | STATUS BIT |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ALL TYPE 1 | Not Ready | Write Protect | Head Loaded | Seek Error | CRC Error | Track 0 | Index | Busy |
| READ SECTOR | Not Ready | 0 | Record Type | Rec not Found | CRC Error | Lost Data | DRQ | Busy |
| WRITE SECTOR | Not Ready | Write Protect | Write Fault | Rec not Found | CRC Error | Lost Data | DRQ | Busy |
| READ ADDRESS | Not Ready | 0 | 0 | Rec not Found | CRC Error | Lost Data | DRQ | Busy |
| READ TRACK | Not Ready | 0 | 0 | 0 | 0 | Lost Data | DRQ | Busy |
| WRITE TRACK | Not Ready | Write Protect | Write Fault | 0 | 0 | Lost Data | DRQ | Busy |

Figure 4B. Status Description for Type I Commands

| BIT | NAME | MEANING |
| :--- | :--- | :--- |
| S7 | NOT READY | This bit when set indicates the drive is not ready. When reset it indicates that the drive is <br> ready. This bit is an inverted copy of the Ready input and logically 'ored' with MR. |
| S6 | PROTECTED | When set, indicates Write Protect is activated. This bit is an inverted copy of WRPT input. |$|$| S5 | HEAD LOADED | When set, it indicates the head is loaded and engaged. This bit is a logical "and" of HLD <br> and HLT signals. |
| :--- | :--- | :--- |
| S4 | SEEK ERROR | When set, the desired track was not verified. This bit is reset to 0 when updated. |
| S3 | CRC ERROR | CRC encountered in ID field. |
| S2 | TRACK 00 | When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted copy <br> of the TR00 input. |
| S1 | INDEX | When set, indicates index mark detected from drive. This bit is an inverted copy of the <br> IP input. |
| S0 | BUSY | When set command is in progress. When reset no command is in progress. |

Figure 4C. Status Description for Type II and III Commands

| BIT | NAME | MEANING |
| :--- | :--- | :--- |
| S7 | NOT READY | This bit when set indicates the drive is not ready. When reset, it indicates that the drive <br> is ready. This bit is an inverted copy of the Ready input and 'ored' with MR. The Type II <br> and III Commands will not execute unless the drive is ready. |
| S6 | WRITE PROTECT | On Read Record: Not Used. On Read Track: Not Used. On any Write: It indicates a Write <br> Protect. This bit is reset when updated. |
| S5 | RECORD TYPE/ <br> WRITE FAULT | On Read Record: It indicates the record-type code from data field address mark. <br> 1=Deleted Data Mark. $0=$ Data Mark. On any Write: It indicates a Write Fault. This bit is <br> reset when updated. |
| S4 | RECORD NOT <br> FOUND (RNF) | When set, it indicates that the desired track, sector, or side were not found. This bit is reset <br> when updated. |
| S3 | CRC ERROR | If S4 is set, an error is found in one or more ID fields; otherwise it indicates error in data <br> field. This bit is reset when updated. |
| S2 | LOST DATA | When set, it indicates the computer did not respond to DRQ in one byte time. This bit is <br> reset to zero when updated. |
| S1 | DATA REQUEST | This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Read Operation <br> or the DR is empty on a Write operation. This bit is reset to zero when updated. |
| S0 | BUSY | When set, command is under execution. When reset, no command is under execution. |

Write Data Timing:

| PARAMETER | SYMBOL | MIN. | TYP. | MAX. | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write Data Pulse Width | $\mathrm{T}_{\text {wp }}$ | 450 | 500 | 550 | nsec | FM |
|  |  | 150 | 200 | 250 | nsec | MFM |
| Write Gate to Write Data | Twg |  | 2 |  | $\mu \mathrm{sec}$ | FM |
|  |  |  | 1 |  | $\mu \mathrm{sec}$ | MFM |
| Write data cyle Time | Tbc |  | 2,3 or 4 |  | $\mu \mathrm{sec}$ | $\pm$ CLK Error |
| Early (Late) to Write Data | Ts | 125 |  |  | nsec | MFM |
| Early (Late) From | Th | 125 |  |  | nsec | MFM |
| Write Data |  |  |  |  |  |  |
| Write Gate off from WD | $\mathrm{T}_{\mathrm{wf}}$ |  | 2 |  | $\mu \mathrm{sec}$ | FM |
|  |  |  | 1 |  | $\mu \mathrm{sec}$ | MFM |
| WD Valid to Clk | Twdl | 100 |  |  | nsec | CLK $=1 \mathrm{MHZ}$ |
|  |  | 50 |  |  | nsec | CLK $=2 \mathrm{MHZ}$ |
| WD Valid after Clk | Twd2 | 100 30 |  |  | nsec | CLK $=1 \mathrm{MHZ}$ |
|  |  | 30 |  |  | nsec | CLK $=2 \mathrm{MHZ}$ |

These values are doubled when $C L K=1 \mathrm{MHz}$.


Operating Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +15 V
Negative Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -0.3 V
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the $A C$ power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%$ unless otherwise noted)

| PARAMETER |  | SYMBOL | MIN | TYP | MAX | UNIT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DC CHARACTERISTICS |  |  |  |  |  |  |  |
| Input Voltage Levels |  |  |  |  |  |  |  |
| Low Level, $\mathrm{V}_{\text {IL }}$ |  |  |  |  | 0.8 | V |  |
| High Level, $\mathrm{V}_{\mathbf{I H}}$ |  |  | 2.6 |  |  | V |  |
| Output Voltage Levels |  |  |  |  |  |  |  |
| Low Level Vol. |  |  |  |  | 0.45 | V | $\mathrm{l}_{\mathrm{oL}}=1.6 \mathrm{~mA}$ |
| High Level $\mathrm{V}_{\text {OH }}$ |  |  | 2.8 |  |  | V | $\mathrm{l}_{\text {он }}=100 \mu \mathrm{~A}$ |
| Output Leakage, ILo |  |  |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {out }}=V_{\text {DD }}$ |
| Input Leakage, IIL |  |  |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {DD }}$ |
| Output Capacitance |  |  |  | 5 |  | pf |  |
| Input Capacitance |  |  |  | 10 |  | pf |  |
| Power Dissipation |  |  |  |  | 500 | mW |  |
| AC CHARACTERISTICS |  |  |  |  |  |  |  |
| Processor Read Timing |  |  |  |  |  |  |  |
| Address Setup Time |  | $t_{\text {tetr }}$ | 50 |  |  | ns | Figure 5 |
| Address Hold Time |  | $\mathrm{t}_{\text {HLDR }}$ | 10 |  |  | ns | Figure 5 |
| RE Pulse Width ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) |  | $t_{\text {RE }}$ | 400 |  |  | ns | Figure 5 |
| DRQ Reset Time |  | $t_{\text {dra }}$ |  |  | 500 | ns | Figure 5 |
| INTRQ Reset Time |  | $\mathrm{t}_{\text {IRR }}$ |  | 500* | 3000* | ns | Figure 5 |
| Data Delay Time ( $\mathrm{C}_{L}=50 \mathrm{pF}$ ) |  | toacc |  |  | 350 | ns | Figure 5 |
| Data Hold Time ( $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ) |  | tooh | 50 |  | 150 | ns | Figure 5 |
| Microprocessor Write Timing |  |  |  |  |  |  |  |
| Address Setup Time |  | tsetw | 50 |  |  | ns | Figure 6 |
| Address Hold Time |  | thlow | 10 |  |  | ns | Figure 6 |
| WE Pulse Width |  | twe | 350 |  |  | ns | Figure 6 |
| DRQ Reset Time |  | $t_{\text {dra }}$ |  |  | 500 | ns | Figure 6 |
| INTRQ Reset Time |  | $\mathrm{t}_{\text {IRR }}$ |  | 500* | 3000* | ns | Figure 6 |
| Data Setup Time |  | tos | 250 |  |  | ns | Figure 6 |
| Data Hold Time |  | $t_{\text {DH }}$ | 70 |  |  | ns | Figure 6 |
| Disk Input Data Timing $100 *$ - 200 - |  |  |  |  |  |  |  |
| RAWREAD Pulse Width |  | $t_{\text {pw }}$ | 100* | 200 |  | ns | Figure 7, See Note |
| Clock Setup Time |  | $t_{d}$ | 40 |  |  | ns | Figure 7 See Note |
| Clock Hold Time for MFM |  | $t_{\text {cd }}$ | 40 |  |  | ns | Figure 7 |
| Clock Hold Time for FM |  | $\mathrm{t}_{\text {cs }}$ | 40 |  |  | ns | Figure 7 <br> 1800 |
| RAWREAD Cycle Time |  | $t_{\text {bc }}$ | 1500 |  |  | ns | 1800 at $70^{\circ} \mathrm{C}$, Figure 7 |
| RCLK High Pulse Width | MFM | $t_{a}$ | 0.8 | $1^{*}$ |  | $\mu \mathrm{s}$ | Figure 7 |
|  | FM | $t a$ | 0.8 | 2** |  | $\mu \mathrm{s}$ | Figure 7 |
| RCLK Low Pulse Width | MFM FM | $t_{\text {b }}$ | 0.8 0.8 | $1^{\text {2* }}$ |  | $\mu \mathrm{s}$ | Figure 7 |
|  |  |  |  | ${ }^{\text {2 }}$ |  | $\mu \mathrm{s}$ | Figure 7 |
| RCLK Cycle Time | FM | $t_{\text {c }}$ |  | 4* |  | $\mu \mathrm{s}$ | Figure 7 |
|  |  |  |  |  |  |  |  |
| CLK Low Pulse Width |  | ${ }_{\text {tcD1 }}$ | 230 | 250 | 20000 | ns | Figure 8 |
| CLK High Pulse Width |  | $\mathrm{tcD}^{\text {c }}$ | 200 | 250 | 20000 | ns | Figure 8 |
| STEP Pulse Width | MFM <br> FM | $\mathrm{t}_{\text {StP }}$ | ${ }^{2}{ }^{\text {* }}$ |  |  | $\mu \mathrm{s}$ | Figure 8 |
| DIRC Setup Time |  | $t_{\text {dir }}$ |  | 12 |  | $\mu \mathrm{s}$ | Figure 8 |
| MR Pulse Width |  | $\mathrm{t}_{\text {MR }}$ | 50* |  |  | $\mu \mathrm{s}$ | Figure 8 |
| IP Pulse Width |  | $\mathrm{t}_{\text {IP }}$ | 10* |  |  | $\mu \mathrm{s}$ | Figure 8 |
| WF Pulse Width |  | $t_{\text {wf }}$ | 10* |  |  | $\mu \mathrm{s}$ | Figure 8 |
| CLK Cycle Time |  | tcrc |  | 0.5* |  | $\mu \mathrm{s}$ | Figure 8 |

[^12]Figure 5. Microprocessor Read Timing


Figure 6. Microprocessor Write Timing


Figure 7. Disk Input Timing


Note: Pulse width on RAW READ (Pin 27) is normally $10-300 \mathrm{~ns}$. However, pulse may be any width if pulse is entirely within window. If pulse occurs in both windows. then pulse width must be less than 300 ns for MFM at CLK $=2 \mathrm{MHz}$ and 600 ns for FM at 2 MHz . Times double for 1 MHz .

Figure 8.
Miscellaneous Timing


## DISK FORMATS

Disks may be formatted in IBM 3740 or System 34 formats with sector lengths of $128,256,512$, or 1024 bytes.

## IBM 3740 Format

This single-density (FM) format utilizes 128 bytes/ sector. The bytes to be generated by the system MPU for use in the execution of the Write Track command are shown in Figure 9.

## IBM System 34 Format

This double-density (MFM) format utilizes 256 bytes/sector. The bytes to be generated by the system MPU for use in the execution of the Write Track command are shown in Figure 10.

## Non-IBM Formats

Unique (non-IBM) formats are permissible providing the following restrictions are understood.

- Sector length may only be $128,256,512$, or 1024 bytes.
- Gap sizes must conform to Figure 11.

Figure 10.
Byte Sequence for IBM System-34 Formatting

| DATA BYTE (hex) | NO. OF BYTES | COMMENTS |
| :---: | :---: | :---: |
| 4E | 807 | $\begin{aligned} & \text { Gap } 5 \\ & \text { (Post Index) } \end{aligned}$ |
| 00 | 12J |  |
| F6 | 3 | Writes C2 |
| FC | 1 | Index AM |
| 4E | 507 |  |
| 00 | 12 | -Gap 1 |
| F5 | 3 | Writes A1 |
| FE | 1 | ID AM |
| XX | 1 | Track Number (00-4C) |
| OX | 1 | Side Number ( 00 or 01) |
| XX | 1 | Sector Number (01-1A) |
| 01 | 1 | Sector Length (256 Bytes) |
| F7 | 1 | Causes 2-Byte CRC to be Written |
| 4E |  | -Gap 2 (ID Gap) |
| 00 | 12] |  |
| F5 | 3 | Writes A1 |
| FB | 1 | Data AM |
| 40 | 256 | Data Field |
| F7 | 1 | Causes 2-Byte CRC to be Written |
| 4E | 54 598 | Part of Gap 3 (Data Gap) |
| 4E | 598 | Gap 4 (Pre Index) |

NOTES: 1. THIS PATTERN MUST BE WRITTEN 26 TIMES PER TRACK.
2. CONTINUE WRITING HEX 4E UNTIL FDC COMPLETES SEQUENCE AND GENERATES INTRQ INTERRUPT.

| GAP | SINGLE <br> DENSITY <br> (FM) | DOUBLE <br> DENSITY <br> (MFM) | NOTE |
| :---: | :---: | :---: | :---: |
| Gap 1 | 16 bytes FF | 16 bytes 4E | 2 |
| Gap 2 | 11 bytes FF <br> 6 bytes 00 | 22 bytes 4F <br> 12 bytes 00 <br> 3 bytes A1 | 1 |
| Gap 3 | 10 bytes FF | 16 bytes 4E |  |
|  | 4 bytes 00 | 8 bytes 00 | 2 |
| Gap 4 bytes A1 | 2 |  |  |

NOTES: 1. THESE BYTES COUNTS ARE EXACT.
2. THESE BYTES COUNTS ARE MINIMUM EXCEPT FOR 3 BYTES A1, WHICH IS EXACT.

Figure 11. Gap Size Limitations information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

## Floppy Disk Data Separator

 FDDS
## FEATURES

PERFORMS COMPLETE DATA SEPARATION FUNCTION FOR FLOPPY DISK DRIVESSEPARATES FM OR MFM ENCODED DATA FROM ANY MAGNETIC MEDIAELIMINATES SEVERAL SSI AND MSI DEVICES NORMALLY USED FOR DATA SEPARATIONNO CRITICAL ADJUSTMENTS REQUIREDCOMPATIBLE WITH STANDARD MICROSYSTEMS' FDC 1791, FDC 1793 AND OTHER FLOPPY DISK CONTROLLERS <br> SMALL 8-PIN DUAL-IN-LINE PACKAGE}+5 VOLT ONLY POWER SUPPLYTTL COMPATIBLE INPUTS AND OUTPUTSPIN CONFIGURATION


## GENERAL DESCRIPTION

The Floppy Disk Data Separator provides a low cost solution to the problem of converting a single stream of pulses from a floppy disk drive into separate Clock and Data inputs for a Floppy Disk Controller.
The FDDS consists primarily of a clock divider, a longterm timing corrector, a short-term timing corrector, and reclocking circuitry. Supplied in an 8-pin Dual-In-Line
package to save board real estate, the FDDS operates on +5 volts only and is TTL compatible on all inputs and outputs.
The FDC 9216 is available in two versions; the FDC 9216, which is intended for $51 / 4^{\prime \prime}$ disks and the FDC 9216B for $51 / 4^{\prime \prime}$ and $8^{\prime \prime}$ disks.


FLOPPY DISK DATA SEPARATOR BLOCK DIAGRAM

## DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | NAME | SYMBOL | FUNCTION |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Disk Data | $\overline{\text { DSKD }}$ | Data input signal direct from disk drive. Contains combined clock and data waveform. |  |  |
| 2 | Separated Clock | SEPCLK | Clock sign disk drive | ut from strea | derived from floppy |
| 3 | Reference Clock | REFCLK | Reference | nput |  |
| 4 | Ground | GND | Ground |  |  |
| 5,6 | Clock Divisor | $\begin{aligned} & \text { CDO, } \\ & \text { CD1 } \end{aligned}$ | CDO and internal cla the follow | trol th subm | k divider circuit. The EFCLK according to |
|  |  |  | CD1 0 0 1 1 | $\begin{gathered} \text { CDO } \\ 0 \\ 1 \\ 0 \\ 1 \end{gathered}$ | Divisor 1 2 4 4 8 |
| 7 | $\overline{\text { Separated Data }}$ | $\overline{\text { SEPD }}$ | SEPD is th | output |  |
| 8 | PowerSupply | $V_{D D}$ | +5 volt po |  |  |

FIGURE 1
TYPICAL SYSTEM CONFIGURATION
( $51 / 4^{\prime \prime}$ Drive, Double Density)


## OPERATION

A reference clock (REFCLK) of between 2 and 8 MHz is divided by the FDDS to provide an internal clock. The division ratio is selected by inputs CDO and CD1. The reference clock and division ratio should be chosen per table 1.

The FDDS detects the leading edges of the disk data pulses and adjusts the phase of the internal clock to provide the SEPARATED CLOCK output.

Separate short and long term timing correctors assure accurate clock separation.
The internal clock frequency is nominally 16 times the SEPCLK frequency. Depending on the internal timing correction, the internal clock may be a minimum of 12 times to a maximum of 22 times the SEPCLK frequency.
The reference clock (REFCLK) is divided to provide the internal clock according to pins CD0 and CD1.

TABLE 1:
CLOCK DIVIDER SELECTION TABLE

| DRIVE <br> (8" or $5^{1 / 4}$ ) | DENSITY <br> (DD or SD) | REFCLK <br> MHz | CD1 | CDO | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 8 | DD | 8 | 0 | 0 |  |
| 8 | SD | 8 | 0 | 1 | $\}$ Select either one |
| 8 | SD | 4 | 0 | 0 |  |
| $51 / 4$ | DD | 8 | 0 | 1 | $\}$ Select either one |
| $51 / 4$ | DD | 4 | 0 | 0 |  |
| $51 / 4$ | SD | 8 | 1 | 0 |  |
| $51 / 4$ | SD | 4 | 0 | 1 | $\}$ Selectany one |
| $51 / 4$ | SD | 2 | 0 | 0 |  |



## MAXIMUM GUARANTEED RATINGS*


#### Abstract

Operating Temperature Range $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ Storage Temperature Range .......................................................................... $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Lead Temperature (soldering, 10 sec.) .......................................................................... . . . . $+325^{\circ} \mathrm{C}$ Positive Voltage on any Pin, with respect to ground $+8.0 \mathrm{~V}$ Negative Voltage on any Pin, with respect to ground $-0.3 \mathrm{~V}$ *Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied. NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.


ELECTRICAL CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=+5 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Units | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS input voltage levels Low Level $V_{\mathrm{IL}}$ High Level $\mathrm{V}_{\mathrm{IH}}$ | 2.0 |  | 0.8 | $\begin{aligned} & V \\ & V \end{aligned}$ | PRELIMINARY <br> Nofice This is not a final specification. Some parametric limits are subject to change |
| OUTPUT VOLTAGE LEVELS <br> Low Level Vol <br> High Level $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | 0.4 | $\begin{aligned} & V \\ & V \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \end{aligned}$ |
| INPUT CURRENT Leakage ILL |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{O} \leq \mathrm{V}_{1 N} \leq \mathrm{V}_{\mathrm{DD}}$ |
| INPUT CAPACITANCE All Inputs |  |  | 10 | pF |  |
| POWER SUPPLY CURRENT ID |  |  | 50 | mA |  |
| A.C. CHARACTERISTICS Symbol |  |  |  |  |  |
| $\mathrm{f}_{\mathrm{cy}}$ REFCLK Frequency | 0.2 |  | 4.3 | MHz | FDC 9216 |
| $\mathrm{f}_{\mathrm{cy}}$ R REFCLK Frequency | 0.2 |  | 8.3 | MHz | FDC 9216B |
| tckh REFCLK High Time | 50 |  | 2500 | ns |  |
| tckl REFCLK Low Time | 50 |  | 2500 | ns |  |
| tsdon REFCLK to $\overline{\text { SEPD }}$ "ON" Delay |  | 100 |  | ns |  |
| tsdoff REFCLK to SEPD "OFF"Delay |  | 100 |  | ns |  |
| $\mathrm{t}_{\text {spck }}$ REFCLK to SEPCLK Delay | 100 |  |  | ns |  |
| toll ${ }_{\text {d }}$ DSKD Active Low Time | 0.1 |  | 100 | $\mu \mathrm{s}$ |  |
| toly DSKD Active High Time | 0.2 |  | 100 | $\mu \mathrm{s}$ |  |



# Floppy Disk Hard Sector Data Handler HSDH 

## FEATURES

Hard-Sectored Operation - performs all data operationsSingle or Double Density Operation recording code independentMinifloppy or Standard Floppy compatibleProgrammable Sync ByteInternal Sync Byte Detection and Byte FramingFully Double Buffered
Data Overrun/Underrun DetectionDual Disk Operation - Write on one disk drive while simultaneously reading from anotherTri-State Output Bus for processor compatibilityTTL Compatible Inputs and Outputs

## PIN CONFIGURATION

| RD | 1 | 40 | \% sbs |
| :---: | :---: | :---: | :---: |
| RCK | 2 | 39 | Wws |
| RDRR | 3 | 38 | Wck |
| RDE | 4 | 37 | fris |
| RDR | 5 | 36 | SBD |
| RDL | 6 | 35 | $\square \mathrm{RG}$ |
| RD7 | 7 | 34 | WD7 |
| RD6 | 8 | 33 | [wos |
| RD5 | 9 | 32 | WDS |
| RD4 | 10 | 31 | - WD4 |
| RD3 | 11 | 30 | [ wo3 |
| RD2 | 12 | 29 | W02 |
| RD1 | 13 | 28 | W wor |
| RDO | 14 | 27 | -wos |
| NC | 15 | 26 | $\mathrm{V}_{00}$ |
| NC- | 16 | 25 | F wou |
| NC- | 17 | 24 | $\square \mathrm{gno}$ |
| NCO | 18 | 23 | Wo |
| NCC | 19 | 22 | Wdr |
| $\mathrm{v}_{\mathrm{cc}}$ | 20 | 21 | J NC |

## GENERAL DESCRIPTION

The FDC3400 is an MOS integrated circuit which simplifies the data interface between a processor and a floppy disk drive. During a write operation, the HSDH receives data from the processor and shifts it out bit-serially to the floppy disk data encoding logic. Similarly, during a read operation the HSDH receives a bit-serial stream of read data from the floppy disk data separator, establishes byte synchronization by detecting the sync byte, and transfers data on a byte by byte basis to the processor.
The HSDH detects data overrun and underrun conditions and indicates these conditions on its status lines. A data underrun causes write data to be written onto the disk from a special programmable fill register until new data is entered into the write data buffer or until the write operation is ended.
Separate read and write data registers permit simultaneous read and write operations on two different drives for enhanced system throughput. The HSDH is fully double buffered and all inputs and outputs are TTL compatible.


## DESCRIPTION OF OPERATION

Prior to reading or writing on the disk, the read/write head must be positioned and loaded onto the desired track.

## Write Operation

The Write Clock is set at the desired bit rate (usually 125,250 , or 500 KHz ), and the desired fill byte is written into the Write Fill Register. After the external logic makes the write enable to the drive active, the first byte to be written should be loaded into the Write Data Register. This byte is then loaded into the Write Output Register and shifted out bit serially to the external write encoding logic. The first bit shifted out of each byte is the LSB. Whenever a byte is transferred from the Write Data Register to the Write Output Register, Write Data Request becomes active and requests another byte from the processor. If new data is not loaded into the Write Data Register before the Write Output Register becomes empty, then the Write Output Register is loaded with data from the Write Fill Register and the Write Data Underrun status line is set. WDU is reset the next time WDS is pulsed. At the end of the write operation, the processor should return the external write enable line to an inactive state.

## Read Operation

The Read Clock is set at the desired bit rate (usually 125,250 , or 500 KHz ) and the desired sync byte is loaded into the Sync Byte Register. When the processor wishes to read a sector of data it causes a transition on the Read Gate input to set the read logic into a sync byte search mode. In the search mode the serial read data bit stream is examined on a bit by bit basis until a sync byte is found. A sync byte is found, by definition, when the contents of the Sync Byte Register and the Read Input Register are identical. When this occurs the Sync Byte Detected output is set high. This byte is then loaded into the Read Data Register and the read logic is set into the
byte mode. In this mode each byte read is loaded into the Read Data Register and Read Data Request is made active high for each byte. The processor responds to each Read Data Request by enabling the output bus with Read Data Enable, reading the data byte from the Read Data Register, and resetting Read Data Request by pulsing Read Data Request Reset. If the processor fails to respond to Read Data Request within one byte time, the Read Data Lost status line is set. When the processor has read the required amount of data it may reset Read Gate to an inactive-high level.

## System Operation - Additional Features

Automatic Sector Fill
In some applications, such as the end of a logical file, the system buffer may contain less than a full sector of data. In this case the processor need supply only this data to the FDC3400. The FDC3400 will then underrun, setting the Write Data Underrun Status line and thereby causing the remainder of the sector to fill with bytes taken from the Write Fill Register. This operation continues until the processor returns the disk's write enable signal to an inactive level.

## Byte Search

After byte synchronization has been established during a read operation, the processor may load a different byte into the Sync Byte Register. Whenever that byte occurs in the data being read, the Sync Byte Detected status line will go high. This feature permits the processor to search for the occurence of a specific byte while reading a sector.

## Multiple Byte Synchronization

Some systems use two or more contiguous sync bytes to establish byte synchronization. For these applications, the number of Read Data Requests received while Sync Byte Detected remains active-high may be counted by the processor to establish valid synchronization.

## FLOW DIAGRAM - WRITE DATA




## DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 1 | RD | Read Data | The Read Data input accepts the serial data stream from the floppy disk data separator. |
| 2 | RCK | Read Clock | The negative-going edge of the Read Clock input shifts Read Data into the Read Input Register. |
| 3 | RDRR | Read Data Request Reset | An active-high pulse input on the Read Data Request Reset input resets the RDR output to a low level. |
| 4 | RDE | Read Data Enable | An active-high level on the Read Data Enable line gates the outputs of the Read Data Register onto the Read Data Output lines. |
| 5 | RDR | Read Data Request | The Read Data Request output is made active-high when an assembled byte is transferred from the Read Input Register to the Read Data Register. |
| 6 | RDL | Read Data Lost | The Read Data Lost output is made active-high, if the byte presently in the Read Data Register is not read (RDR not reset) by the processor before the next byte is loaded into the Read Data Register. |
| 7-14 | RD7-RDØ | Read Data Output | When enabled by RDE the tri-state Read Data Output lines present the data in the Read Data Register to the processor. When RDE is inactive-low the RD7-RD $\emptyset$ lines are held at a high-impedance state. |
| 15-19 | NC |  | Not Connected |
| 20 | V cc | Power Supply | + 5 volt supply |
| 21 | NC |  | Not Connected |
| 22 | WDR | Write Data Request | The Write Data Request output is made active-high when the Write Data Register becomes empty and requires a data byte. It is reset to a low level when WDS occurs to load the Write Data Register. If WDR is not serviced by the time the next byte is required by the Write Output Register, the byte stored in the Write Fill Register is written onto the disk and the WDU line is made active high. |
| 23 | WD | Write Data | The Write Data output presents the serial stream of data to the external write data encoder. Each byte is normally provided from the Write Data Register provided that a WDS pulse occurs during the presently written byte. If WDS is not pulsed, the next byte to be written will be extracted from the Write Fill Register. |
| 24 | GND | Ground | Ground |
| 25 | WDU | Write Data Underrun | The Write Data Underrun output is set active-high when the processor fails to respond to the WDR signal within one byte time. When WDU occurs the data written on the disk is extracted from the Write Fill Register. This line is reset when WDS is pulsed. |
| 26 | $V_{\text {DD }}$ | Power Supply | -12 volt supply |
| 27-34 | WD0-WD7 | Write Data Input | The Write Data Input lines present information to the Write Data Register, the Write Fill Register, and the Sync Byte Register under control of their respective strobes. The strobes operate independently of each other. The LSB should always be placed on WDO. |
| 35 | RG | Read Gate | This input should be pulsed to a high-level after power turn on to reset RDR, SBD, and RDL to an inactivelow level. The high-to-low transition of RG sets the read logic into the sync byte search mode. In this mode the serial Read Data stream is examined on a bit by bit basis until a sync byte is found. A sync byte is found by definition when the contents of the Sync Byte Register and the Read Input Register are identical. When this occurs the SBD output is set active-high. The sync byte just read is then transferred into the Read Data Register; RDR is set high, and the read logic is set into the byte mode. In this mode each byte read is transferred into the Read Data Register. |
| 36 | SBD | Sync Byte Detected | The Sync Byte Detected output is set active-high each time the byte loaded into the Read Data Register is identical to the byte in the Sync Byte Register. This output is reset low the next time the Read Data Register is loaded with a byte which is not a sync byte. |

## DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :--- | :--- | :--- |
| 37 | FBS | Fill Byte <br> Strobe | The Fill Byte Strobe is an active-high input strobe which <br> loads the byte on the WDø-WD7 lines into the Write <br> Fill Register. |
| 38 | WCK | Write Clock | Each positive-going edge of this clock shift one bit <br> out of the Write Output Register onto WD. |
| 39 | WDS | Write Data <br> Strobe | The Write Data Strobe is an active-high input strobe <br> which loads the byte on the WDD-WD7 lines into the <br> Write Data Register. |
| 40 | SBS | Sync Byte <br> Strobe | The Sync Byte Strobe is an active-high input strobe <br> which loads the byte on the WDD-WD7 lines into the <br> Sync Byte Register. |

## ADDITIONAL TIMING INFORMATION (Typical Propagation Delays)




## HSDH TIMING DIAGRAM



NOTE 1
The Write Output Register is loaded with the next byte at the positive clock transition corresponding to the leading edge of the last bit of the current byte on the WD output. WDR is set high approximately two microseconds after this clock transition. If it is desired that the next byte be extracted from the Write Data Register the leading edge of the WDS should occur at least one microsecond prior to this clock transition.

NOTE 2
In order to avoid an RDL indication the leading edge of the RDRR pulse should occur at least one microsecond prior to the negative clock transition corresponding to the center of the first bit after the last bit of the previous byte on the RD input.

## NOTE 3

The RDL, SBD and RDO-RD7 output are set to their correct levels approximately two microseconds after the negative clock transition corresponding to the center of the first bit after the last bit of the previous byte on the RD input. The RDR output is set high at the next negative clock transition.

Operating Temperature Range. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Load Temperature (soldering, 10 sec .). $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, Vcc $+0.3 \mathrm{~V}$
Negative Voltage on any Pin, Vcc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -25 V
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{Cc}}=+5 \mathrm{~V} \pm 5 \% \mathrm{~V}_{D D}=-12 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS |  |  |  |  |  |
| input voltage levels Low-level, $\mathrm{V}_{1}$ High-level, $\mathrm{V}_{\mathrm{H}}$ | $\begin{gathered} V_{\text {Do }} \\ V_{c c}-1.5 \end{gathered}$ |  | $\stackrel{0.8}{\text { Vcc }}$ | V |  |
| OUTPUT VOLTAGE LEVELS Low-level, Vo High-level, $\mathrm{Voh}_{\mathrm{oh}}$ | 2.4 | 0.2 4.0 | 0.4 | V | $\begin{aligned} & l_{o x}=1.6 \mathrm{~mA} \\ & l_{\text {OH }}=-100 \mu \mathrm{~A} \end{aligned}$ |
| INPUT CURRENT Low-level, In |  |  | 1.6 | mA | See note 1 |
| OUTPUT CURRENT Leakage, lo Short circuit, los** |  |  | $\begin{aligned} & -1 \\ & 10 \end{aligned}$ | $\mu \mathrm{A}$ mA | $\begin{aligned} & \text { RDE }=V_{\mathrm{IL}}, 0 \leq \mathrm{V}_{\text {out }} \leq+5 \mathrm{~V} \\ & \mathrm{~V}_{\text {out }}=0 \mathrm{~V} \end{aligned}$ |
| INPUT CAPACITANCE All inputs, $\mathrm{C}_{\text {IN }}$ |  | 5 | 10 | pF | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\text {cc }}, \mathrm{f}=1 \mathrm{MHz}$ |
| OUTPUT CAPACITANCE All outputs, Cout |  | 10 | 20 | pF | $\mathrm{RDE}=\mathrm{V}_{\mathrm{L}}, \mathrm{f}=1 \mathrm{MHz}$ |
| POWER SUPPLY CURRENT <br> Icc <br> lod |  |  | 28 28 | $\begin{gathered} \mathrm{mA} \\ \mathrm{~mA} \end{gathered}$ | All outputs $=\mathrm{V}_{\mathrm{OH}}$ |
| A.C. CHARACTERISTICS |  |  |  |  | $\mathrm{T}_{\text {^ }}=+25^{\circ} \mathrm{C}$ |
| CLOCK FREQUENCY | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \end{aligned}$ |  | $\begin{aligned} & 250 \\ & 500 \end{aligned}$ | $\begin{aligned} & \mathrm{KHz} \\ & \mathrm{KHz} \end{aligned}$ | RCK, WCK RCK, WCK, FDC3400-1 |
|  |  |  |  |  |  |
|  | 0.5 |  |  | $\mu \mathrm{S}$ | RCK, WCK, FDC3400-1 |
| Read Gate | 1 |  |  | $\mu \mathrm{S}$ | RG |
| Write Data Strobe | 200 |  |  | ns | WDS |
| Fill Byte Strobe | 200 |  |  | ns | FBS |
| Sync Byte Strobe | 200 |  |  | ns | SBS |
| Read Data Request Reset | 200 |  |  | ns | RDRR |
| INPUT SET-UP TIME Write Data Inputs | 0 |  |  | ns | WDØ-WD7 |
| INPUT HOLD TIME Write Data Inputs | 0 |  |  | ns | WDØ-WD7 |
| STROBE TO OUTPUT DELAY Read Data Enable |  | 180 | 250 | ns | Load $=20$ pf +1 TTL input RDE: Tpor $^{\text {, }}$ Tpro |
| OUTPUT DISABLE DELAY |  | 100 | 250 | ns | RDE |

**Not more than one output should be shorted at a time.
NOTES:

1. Under steady state condition no current flows for TTL or MOS interfacing.

A switching current of 1.6 mA maximum flows during a high to low transition of the input.
2. The tri-state output has 3 states:

1) low-impedance to $V_{c c}$
2) low-impedance to GND
3) high-impedance $O F F \cong 10 \mathrm{M}$ ohms

The OFF state is controlled by the RDE input.


TYPICAL CCC 3500 INTERFACE TO PROCESSOR AND CASSETTE/CARTRIDGE DRIVE

CCC 3500
$\mu$ PC FAMILY

## Cassette/Cartridge Data Handler CCDH

## FEATURES

$\square$ Facilitates Magnetic Tape Cassette or Cartridge to Processor InterfacingPerforms All Data OperationsUp to 250 K bps Data Transfer RateRecording Code IndependentCompatible with Standard and Mini CassettesCompatible with Standard and Mini 3M-type CartridgesRead-While-Write Operation for Write Verification In Dual Gap Head SystemsProgrammable Sync ByteInternal Sync Byte Detection and Byte FramingFully Double BufferedData Overrun/Underrun DetectionTri-State Output Bus for Processor Compatibility
$\square$ TTL Compatible Inputs and Outputs

| PIN CONFIGURATION |  |
| :---: | :---: |
| Ro 1 | 40 Jses |
| RCK ${ }^{2}$ | ${ }^{39}$ ]wos |
| RDRA ${ }^{3}$ | ${ }^{38}$-wck |
| RDEE ${ }^{4}$ | ${ }^{37}{ }^{37}$ Fess |
| RDR ${ }^{5}$ |  |
|  |  |
| R06 | ${ }^{33}$ - wob |
| Ros ${ }^{\text {a }}$ | 32 wos |
| ${ }_{\text {R03 }} \mathrm{RDCO}^{10}{ }^{10}$ | ${ }^{31}{ }^{\text {wod }}$ |
|  |  |
| R01 ${ }_{13}$ | ${ }_{28}^{29}$ W01 |
| R08 ${ }^{14}$ | $\left.{ }_{27}\right]^{\text {wod }}$ |
| NCO 15 | ${ }^{26}$ V $\mathrm{v}_{00}$ |
| NC-16 | ${ }^{25}{ }^{25}$ Owou |
| NCO ${ }_{18}$ | ${ }_{23}^{24}{ }^{\text {\% wo }}$ |
| NC ${ }^{19}$ | ${ }_{22}{ }^{2}$ wor |
| $\mathrm{vccic}_{20}$ | ${ }^{21} \mathrm{P}^{\mathrm{NC}}$ |
| PACKAGE: 40-Pin D.I.P. |  |

## GENERAL DESCRIPTION

The CCC 3500 is an MOS integrated circuit which simplifies the data interface between a processor and a magnetic tape cassette or cartridge drive. During a write operation the CCDH receives data from the processor and shifts it out bit serially to the cassette/cartridge data encoding logic. Similarly during a read operation the CCDH receives a bit-serial stream of read data from the cassette/cartridge data recovery circuit, establishes byte synchronization by detecting the sync byte, and transfers data on a byte by byte basis to the processor. The CCDH detects data overrun and underrun conditions and indicates these conditions on its status lines. A data underrun causes data from a special programmable fill register to be written onto the cassette/ cartridge until new data is entered into the write data buffer or until the write operation is ended.
Separate read and write data registers permit simultaneous read and write operations. Drives with dual gap heads may utilize this read-whilewrite feature for write data verification thereby enhancing system throughput and reliability. The CCDH is fully double buffered and all inputs and outputs are TTL compatible.

## DESCRIPTION OF OPERATION

## Write Operation

After power-on, the Write Clock is set at the desired bit rate and the desired fill byte is written into the Write Fill Register. After the external control logic has caused the tape to come up to operating speed and activated the write enable signal, the first byte to be written should be loaded into the Write Data Register. This byte is then loaded into the Write Output Register and shifted out bit serially to the external write encoding logic. The first bit shifted out of each byte is the LSB. Whenever a byte is transferred from the Write Data Register to the Write Output Register, Write Data Request becomes active and requests another byte from the processor. If new data is not loaded into the Write Data Register before the Write Output Register becomes empty, then the Write Output Register is loaded with data from the Write Fill Register and the Write Data Underrun status line is set. WDU is reset the next time WDS is pulsed. At the end of the write operation, the processor should return the external write enable line to an inactive state.

## Read Operation

After power-on, the desired sync byte is loaded into the Sync Byte Register. After the external control logic has initiated forward motion and the tape has come up to operating speed, the processor produces a positive-to-negative transition on the Read Gate input to set the read logic into the sync byte search mode. In the search mode the serial read data bit stream is examined on a bit by bit basis until a sync byte is found. A sync byte is found, by definition, when the contents of the Sync Byte Register and the Read Input Register are identical. When this occurs the Sync Byte Detected output is set high. This byte is then loaded into the Read Data Register and the read logic is set into the byte mode. In this mode each byte read is loaded into the Read Data Register and Read Data Request is made active high for each byte. The processor responds to
each Read Data Request by enabling the output bus with Read Data Enable, reading the data byte from the Read Data Register, and resetting Read Data Request by pulsing Read Data Request Reset. If the processor fails to respond to Read Data Request within one byte time, the Read Data Lost status line is set. When the processor has read the required amount of data it may reset Read Gate to an inactive-high level and stop tape motion.

## System Operation - Additional Features

## Automatic Block Fill

In some applications, such as the end of a logical file, the system buffer may contain less than a full block of data. In this case the processor need supply only this data to the CCC 3500. The CCC 3500 will then underrun, setting the Write Data Underrun Status line and thereby causing the remainder of the block to fill with bytes taken from the Write Fill Register. This operation continues until the processor returns the drive's write enable signal to an inactive level.

## Byte Search

After byte synchronization has been established during a read operation, the processor may load a different byte into the Sync Byte Register. Whenever that byte occurs in the data being read, the Sync Byte Detected status line will go high. This feature permits the processor to search for the occurrence of a specific byte while reading a block.

## Multiple Byte Synchronization

Some systems use two or more contiguous sync bytes to establish byte synchronization. For these applications, the number of Read Data Requests received while Sync Byte Detected remains active-high may be counted by the processor to establish valid synchronization.

## FLOW DIAGRAM - WRITE DATA



## FLOW DIAGRAM - READ DATA



| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 1 | RD | Read Data | The Read Data input accepts the serial data stream from the cassette/cartridge data recovery circuit. |
| 2 | RCK | Read Clock | The negative-going edge of the Read Clock input shifts Read Data into the Read Input Register. |
| 3 | RDRR | Read Data Request Reset | An active-high pulse input on the Read Data Request Reset input resets the RDR output to a low level. |
| 4 | RDE | Read Data Enable | An active-high level on the Read Data Enable line gates the outputs of the Read Data Register onto the Read Data Output lines. |
| 5 | RDR | Read Data Request | The Read Data Request output is made active-high when an assembled byte is transferred from the Read Input Register to the Read Data Register. |
| 6 | RDL | Read Data Lost | The Read Data Lost output is made active-high, if the byte presently in the Read Data Register is not read (RDR not reset) by the processor before the next byte is loaded into the Read Data Register. |
| 7-14 | RD7-RDØ | Read Data Output | When enabled by RDE the tri-state Read Data Output lines present the data in the Read Data Register to the processor. When RDE is inactive-low the RD7-RD $\emptyset$ lines are held at a high-impedance state. |
| 15-19 | NC |  | Not Connected |
| 20 | Vcc | Power Supply | + 5 volt supply |
| 21 | NC |  | Not Connected |
| 22 | WDR | Write Data Request | The Write Data Request output is made active-high when the Write Data Register becomes empty and requires a data byte. It is reset to a low level when WDS occurs to load the Write Data Register. If WDR is not serviced by the time the next byte is required by the Write Output Register, the byte stored in the Write Fill Register is written onto the cassette/cartridge and the WDU line is made active high. |
| 23 | WD | Write Data | The Write Data output presents the serial stream of data to the external write data encoder. Each byte is normally provided from the Write Data Register provided that a WDS pulse occurs during the presently written byte. If WDS is not pulsed, the next byte to be written will be extracted from the Write Fill Register. |
| 24 | GND | Ground | Ground |
| 25 | WDU | Write Data Underrun | The Write Data Underrun output is set active-high when the processor fails to respond to the WDR signal within one byte time. When WDU occurs the data written on the disk is extracted from the Write Fill Register. This line is reset when WDS is pulsed. |
| 26 | $V_{\text {DD }}$ | Power Supply | -12 volt supply |
| 27-34 | WD0-WD7 | Write Data Input | The Write Data Input lines present information to the Write Data Register, the Write Fill Register, and the Sync Byte Register under control of their respective strobes. The strobes operate independently of each other. The LSB should always be placed on WDØ. |
| 35 | RG | Read Gate | This input should be pulsed to a high-level after power turn on to reset RDR, SBD, and RDL to an inactivelow level. The high-to-low transition of RG sets the read logic into the sync byte search mode. In this mode the serial Read Data stream is examined on a bit by bit basis until a sync byte is found. A sync byte is found by definition when the contents of the Sync Byte Register and the Read Input Register are identical. When this occurs the SBD output is set active-high. The sync byte just read is then transferred into the Read Data Register; RDR is set high, and the read logic is set into the byte mode. In this mode each byte read is transferred into the Read Data Register. |
| 36 | SBD | Sync Byte Detected | The Sync Byte Detected output is set active-high each time the byte loaded into the Read Data Register is identical to the byte in the Sync Byte Register. This output is reset low the next time the Read Data Register is loaded with a byte which is not a sync byte. |

## DESCRIPTION OF PIN FUNCTIONS

| PIN NO. | SYMBOL | NAME | FUNCTION |
| :---: | :--- | :--- | :--- |
| 37 | FBS | Fill Byte <br> Strobe | The Fill Byte Strobe is an active-high input strobe which <br> loads the byte on the WD $\varnothing$-WD7 lines into the Write <br> Fill Register. |
| 38 | WCK | Write Clock | Each positive-going edge of this clock shifts one bit <br> out of the Write Output Register onto WD. |
| 39 | WDS | Write Data <br> Strobe | The Write Data Strobe is an active-high input strobe <br> which loads the byte on the WDD-WD7 lines into the <br> Write Data Register. |
| 40 | SBS | Sync Byte <br> Strobe | The Sync Byte Strobe is an active-high input strobe <br> which lads the byte on the WD $\emptyset$-WD7 lines into the <br> Sync Byte Register. |

## ADDITIONAL TIMING INFORMATION (Typical Propagation Delays)




## MAXIMUM GUARANTEED RATINGS*

Operating Temperature Range $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range. $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Load Temperature (soldering, 10 sec.) $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, Vcc $+0.3 \mathrm{~V}$
Pegative Voltage on any Pin, Vcc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-2.35 V$
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS ( $\mathrm{T}_{\wedge}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{Cc}}=+5 \mathrm{~V} \pm 5 \% \mathrm{~V}_{\mathrm{DD}}=-12 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS |  |  |  |  |  |
| INPUT VOLTAGE LEVELS Low-level, $\mathrm{V}_{12}$ High-level, $\mathrm{V}_{\mathrm{IH}}$ | $\begin{gathered} V_{c c-1} \\ V_{0}-1.5 \end{gathered}$ |  | $\mathrm{V}_{\text {Vc }} \mathbf{0}$ | V |  |
| OUTPUT VOLTAGE LEVELS Low-level, Vo. High-level, $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | 0.2 4.0 | 0.4 | V | $\begin{aligned} & l_{\mathrm{o}}=1.6 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{oH}}=-100 \mu \mathrm{~A} \end{aligned}$ |
| INPUT CURRENT Low-level, it |  |  | 1.6 | mA | See note 1 |
| OUTPUT CURRENT Leakage, lıo Short circuit, los** |  |  | $\begin{aligned} & -1 \\ & 10 \end{aligned}$ | ${ }_{m A}^{\mu A}$ | $\begin{aligned} & \text { RDE }=V_{\text {il }}, 0 \leq V_{\text {out }} \leqslant+5 \mathrm{~V} \\ & \mathrm{~V}_{\text {OUT }}=0 \mathrm{~V} \end{aligned}$ |
| INPUT CAPACITANCE All inputs, Cin |  | 5 | 10 | pF | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{cc}}, \mathrm{f}=1 \mathrm{MHz}$ |
| OUTPUT CAPACITANCE <br> All outputs, Cout |  | 10 | 20 | pF | $\mathrm{RDE}=\mathrm{V}_{\mathrm{u}}, \mathrm{f}=1 \mathrm{MHz}$ |
| POWER SUPPLY CURRENT <br> lec <br> loo |  |  | $\begin{aligned} & 28 \\ & 28 \end{aligned}$ | $\underset{\mathrm{mA}}{\mathrm{~mA}}$ | All outputs $=\mathrm{V}_{\mathrm{OH}}$ |
| A.C. CHARACTERISTICS |  |  |  |  | $\mathrm{T}_{\wedge}=+25^{\circ} \mathrm{C}$ |
| CLOCK FREQUENCY | DC |  | 250 | KHz | RCK, WCK |
| PULSE WIDTH Clock | 1 |  |  | $\mu \mathrm{S}$ | RCK, WCK |
| Read Gate | 1 |  |  | $\mu \mathrm{S}$ | RG |
| Write Data Strobe | 200 |  |  | ns | WDS |
| Fill Byte Strobe | 200 |  |  | ns | FBS |
| Sync Byte Strobe | 200 |  |  | ns | SBS |
| Read Data Request Reset | 200 |  |  | ns | RDRR |
| INPUT SET-UP TIME Write Data Inputs | 0 |  |  | ns | WDØ-WD7 |
| INPUT HOLD TIME Write Data Inputs | 0 |  |  | ns | WDØ-WD7 |
| STROBE TO OUTPUT DELAY Read Data Enable |  | 180 | 250 | ns | $\begin{aligned} & \text { Load }=20 \mathrm{pf}+1 \text { TTL input } \\ & \text { RDE: } T_{P O I}, T_{P D D} \end{aligned}$ |
| OUTPUT DISABLE DELAY |  | 100 | 250 | ns | RDE |

**Not more than one output should be shorted at a time.
NOTES:

1. Under steady state condition no current flows for TTL or MOS interfacing.

A switching current of 1.6 mA maximum flows during a high to low transition of the input.
2. The tri-state output has 3 states:

1) low-impedance to $V_{c c}$
2) Iow-impedance to GND
3) high-impedance $O F F \cong 10 \mathrm{M}$ ohms

The OFF state is controlled by the RDE input.

## CCDH TIMING DIAGRAM



## NOTE 1

The Write Output Register is loaded with the next byte at the positive clock transition corresponding to the leading edge of the last bit of the current byte on the WD output. WDR is set high approximately two microseconds after this clock transition. If it is desired that the next byte be extracted from the Write Data Register the leading edge of the WDS should occur at least one microsecond prior to this clock transition.

NOTE 2
In order to avoid an RDL indication the leading edge of the RDRR pulse should occur at least one microsecond prior to the negative clock transition corresponding to the center of the first bit after the last bit of the previous byte on the RD input.

NOTE 3
The RDL, SBD and RDO-RD7 output are set to their correct levels approximately two microseconds after the negative clock transition corresponding to the center of the first bit after the last bit of the previous byte on the RD input. The RDR output is set high at the next negative clock transition.

TYPICAL CCC 3500 INTERFACE TO PROCESSOR AND CASSETTE/CARTRIDGE DRIVE

STANDARD MICROSYSTEMS CORPORATION

Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

# 4096 X 8-Bit Static Read-Only Memory 32K ROM 

## FEATURES

$4096 \times 8$ OrganizationAll Inputs and Outputs TTL-CompatibleFully Static (No Clocks, No Refresh)Single $+5 v$ Power SupplyMaximum Access Time...450nsMinimum Cycle Time...450nsTypical Power Dissipation...580mWThree-State Outputs for Wire-OR ExpansionIndustry Standard 24 pin DIP Pin OutPin Compatible with TMS 4732, TMS 4700, TMS 2708 and Intel 2316ETwo programmable chip select inputs for Chip Select FlexibilityAutomated Custom Programming-FormatsMediaCOPLAMOS® N -Channel MOS TechnologyPIN CONFIGURATION

| A7 1 - | $\square 24 \mathrm{Vcc}$ |
| :---: | :---: |
| A6 $2 \square$ | $\square 23$ A8 |
| A5 $3 \square$ | $\square 22 \mathrm{~A} 9$ |
| A4 4 - | $\square 21$ CS2 or CS2 |
| A3 $5 \square$ | $\square 20$ CS1 or CS1 |
| A2 6 ¢ | $\square 19$ A10 |
| A1 7 - | $\bigcirc 18$ A11 |
| A0 8 - | -17 Q8 |
| Q1 9 - | 16 Q7 |
| Q2 10 - | $\square 15$ Q6 |
| Q3 11 - | $\square 14$ Q5 |
| GND 12 - | ]13Q4 |

## GENERAL DESCRIPTION

The ROM 4732 is a 32,768 -bit read-only memory organized as 4096 words of 8 -bit length. This makes the ROM4732 ideal for microprocessor based systems. The device is fabricated using N -channel silicon-gate technology for high speed and simple interface with bipolar circuits.
All inputs can be driven directly by Series 74 TTL circuits without the use of any external pull-up resistor. Each output can drive one Series 74 or 74 S load without external resistors. The data outputs are three-state for OR-tieing multiple devices on a common bus, facilitating easy memory expansion. Two chip select controls allow data to be read.

These controls are programmable, providing additional system decode flexibility allowing four 32K ROMs to be OR-tied without external decoding. The data is always available, it is not dependent on external CE clocking.

The ROM 4732 is designed for high-density fixedmemory applications such as logic function generation and microprogramming. Systems utilizing $1024 \times 8$-bit ROMs or $1024 \times 8$-bit EPROMs can expand to the $4096 \times 8$-bit ROM 4732 with changes only to pins 18,19 , and 21. Toupgrade from the 2316 E , simply replace CS2 with A11 on pin 18.

## BLOCK DIAGRAM



Operating Temperature Range $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range.. $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec. ) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground .................................... +7.0 V
Negative Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -0.3 V
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS
( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{cc}}=+5 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CHARACTERISTICS |  |  |  |  |  |
| INPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, $\mathrm{V}_{\text {IL }}$ |  |  | 0.65 | V |  |
| High-level, $\mathrm{V}_{\mathrm{IH}}$ | 2.0 |  |  | V |  |
| OUTPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low-level, Vol |  |  | 0.4 | V | $1 \mathrm{loL}=2.0 \mathrm{~mA}$ |
| High-level, $\mathrm{V}_{\text {он }}$ | 2.4 |  |  | V | $\mathrm{l}_{\text {он }}=-200 \mu \mathrm{~A}$ |
| INPUT CURRENT Low-level, IL |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{ov} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\text {cc }}$ |
| OUTPUT CURRENT lo |  |  | $\pm 10$ | $\mu \mathrm{A}$ | Chip Deselected |
| INPUT CAPACITANCE All inputs, $\mathrm{C}_{\text {In }}$ |  |  | 7 | pF |  |
| OUTPUT CAPACITANCE All Outputs, Cout |  |  | 10 | pF |  |
| POWER SUPPLY CURRENT lce |  |  | 150 | mA |  |
| A.C. CHARACTERISTICS |  |  |  |  | $\begin{aligned} & 1 \text { Series } 74 \text { TTL load, } \\ & \mathrm{CL}=100 \mathrm{pF} \end{aligned}$ |
| Read cycle time, $\mathrm{t}_{\text {c(rd) }}$ | 450 |  |  | ns |  |
| Access time from address, $t_{\text {a }}$ (ad) |  |  | 450 | ns |  |
| Access time from chip select, $t_{a(c s)}$ |  |  | 200 | ns |  |
| Previous output data valid after address change, $\mathrm{t}_{\mathrm{pvx}}$ |  |  | 450 | ns |  |
| Output disable time from chip select, $\mathrm{t}_{\text {pxz }}$ |  |  | 200 | ns |  |

READ CYCLE TIMING


Description of Pin Functions

| PIN NO. | SYMBOL | NAME | INPUT/ OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} 1,2,3,4,5,6 \\ 7,8,18,19,22 \\ 23 \end{gathered}$ | $\begin{gathered} \text { A7, A6, A5, A4, } \\ \text { A3, A2, A1, AØ, } \\ \text { A11, A10, A9, } \\ \text { A8 } \end{gathered}$ | Addresses | I | The 12-bit positive-logic address is decoded on-chip to select one of 4096 words of 8-bit length in the memory array. $A \emptyset$ is the least significant bit and A11 the most significant bit of the word address. The address valid interval determines the device cycle time. |
| $\begin{aligned} & 9,10,11,13 \\ & 14,15,16,17 \end{aligned}$ | $\begin{aligned} & \text { Q1, Q2, Q3, Q4, } \\ & \text { Q5, Q6, Q7, Q8 } \end{aligned}$ | Data Outputs | 0 | The eight outputs must be enabled by both chip select controls before the output word can be read. Data will remain valid until the address is changed or the outputs are disabled (chip deselected). When disabled, the three-state outputs are in a high-impedance state. Q1 is considered the least significant bit, Q8 the most significant bit. The outputs will drive TTL circuits without external components. |
| 12 | GND | Ground | GND | Ground |
| 20,21 | CS1, CS2 | Chip Select | 1 | Each chip select control can be programmed during mask fabrication to be active with either a high or a low level input. When both chip select signals are active, all eight outputs are enabled and the eight-bit addressed word can be read. When either chip select is not active, all eight outputs are in a highimpedance state. |
| 24 | Vcc | Power Supply | PS | +5 volt power supply |

## PROGRAMMING DATA

PROGRAMMING REQUIREMENTS: The ROM 4732 is a fixed program memory in which the programming is performed via computer aided techniques by SMC at the factory during the manufacturing cycle to the specific customer inputs supplied in the punched computer card format below. The device is organized as 40968 -bit words with address locations numbered $\emptyset$ to 4095. The 8 -bit words can be coded as a 2-digit hexadecimal number between $\emptyset \varnothing$ and FF. All data words and addresses in the following format are coded in hexadecimal numbers. In coding, all binary words must be in positive logic before conversion to hexadecimal. Q1 is considered the least significant bit and Q8 the most significant bit. For addresses, A $\emptyset$ is least significant bit and A11 is the most significant bit.
Every card should include the SMC Custom Device Number in the form ROXXXX (4 digit number to be assigned by SMC) in column 75 through 80.
PROGRAMMABLE CHIP SELECTS: The chip select inputs shall be programmed according to the data punched in columns 73 and 74 . Every card should include in column 73 a 1 if the output is to be enabled with a high level at CS2 or a $\emptyset$ (zero) to enable the output with a low level at CS2. The column 74 entry is the same for programming CS1.
PROGRAMMED DATA FORMAT: The format for the cards to be supplied to SMC to specify that data to be programmed is provided below. The card deck for each device consists of 128 cards with each card containing data for 32 memory locations.

## CARD COLUMN

1 to 3

71,72
73
74
75,76
77 to 80

69,70 Checksum. The checksum is the negative of the sum of all8-bit bytes in the record from column 1 to 68 , evaluate modulo 256 (carry from high order bit ignored). (For purposes of calculating the checksum, the value of Column 4 is defined to be zero.) Adding together, modulo 256, all 8-bit bytes from Column 1 to 68 (Column $4=0$ ), then adding the checksum, results inzero.

HEXADECIMAL FORMAT
Hexadecimal address of first word on the card Blank
Data. Each 8-bit memory byte is represented by two ASCII characters to represent a hexadecimal value of ' 00 ' or ' $F F$ '. Blank
One (1) or zero ( $\emptyset$ ) for CS2
One (1) or zero ( $\emptyset$ ) for CS1
RO
XXXX (4 digit number assigned by SMC)

## ALTERNATIVE INPUT MEDIA

In addition to the preferred 80 column "IBM Card," customers may submit their ROM bit patterns on 9 -track $800-\mathrm{BPI}$ mag tape, 8 -channel perforated paper tape, EPROM, ROM, etc. Where one of several nationwide time sharing services is mutually available, arrangements may be made with the factory to communicate the ROM definition data directly through the service computer. Format requirements and other information required to use alternative input media may be obtained through SMC sales personnel.

## ALTERNATIVE DATA FILE FORMATS

In addition to the standard SMC format, it is possible to furnish data to SMC in other formats if prearranged with the factory. Non-standard formats may be acceptable. Contact SMC sales personnel.

## 8192 X 8-Bit Static Read-Only Memory 64K ROM

## FEATURES

8192 X 8 OrganizationAll Inputs and Outputs TTL-CompatibleEdge Activated**Single $+5 \mathrm{~V} \pm 10 \%$ Power SupplyMaximum Access Time...250nsMinimum Cycle Time...375nsLow Power Consumption...220mW max activeLow Standby Power Dissipation... 35 mW typicalThree-State Outputs for Wire-OR ExpansionIndustry Standard 24 Pin DIP Pin OutPin Compatible with MOSTEK MK36000-4On-Chip Address LatchesOutputs drive 2 TTL loads and 100pf$\square$ COPLAMOS® N -Channel MOS Technology

PIN CONFIGURATION


BLOCK DIAGRAM


## GENERAL DESCRIPTION

The ROM 36000 is a new generation N -channel silicon gate MOS Read Only Memory, organized as 8192 words by 8 bits. As a state-of-the-art device, the ROM 36000 incorporates advanced circuit techniques designed to provide maximum circuit density and reliability with the highest possible performance, while maintaining low power dissipation and wide operating margins.
The ROM 36000 utilizes what is fast becoming an industry standard method of device operation. Use of a static storage cell with clocked control periphery allows the circuit to be put into an automatic low power standby mode. This is accomplished by maintaining the chip enable ( $\overline{\mathrm{CE}}$ ) input at a TTL high level. In this mode, power dissipation is reduced to typically 35 mW , as compared to unclocked devices which draw full power continuously. In system operation, a device is selected by the $\overline{\mathrm{CE}}$ input, while all others are in a low power mode, reducing the overall system power. Lower power means reduced power supply cost, less heat to dissipate and an increase in
device and system reliability.
The edge activated chip enable also means greater system flexibility and an increase in system speed. The ROM 36000 features onboard address latches controlled by the CE input. Once the address hold time specification has been met, new address data can be applied in anticipation of the next cycle. Outputs can be wire- 'OR'ed together, and a specific device can be selected by utilizing the $\overline{\mathrm{CE}}$ input with no bus conflict on the outputs. The CE input allows the fastest access times yet available in 5 volt only ROM's and imposes no loss in system operating flexibility over an unclocked device.

Other system oriented features include fully TTL compatible inputs and outputs. The three state outputs, controlled by the CE input, will drive a minimum of 2 standard TTL loads. The ROM 36000 operates from a single +5 volt power supply with a wide $\pm 10 \%$ tolerance, providing the widest operating margins available. The ROM 36000 is packaged in the industry standard 24 pin DIP.

## ABSOLUTE MAXIMUM RATINGS*

Voltage on Any Terminal Relative to Vss ................................................... 0.5 V to +7 V
Operating Temperature $T_{A}$ (Ambient) $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots 0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature-Ceramic (Ambient) ......................................... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Power Dissipation
1 Watt
*Stresses greater than 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 operating sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

PRELIMINARY
Notce, This is not a final specitication Some parametric fimits are subject to change
ELECTRICAL CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=\mathrm{O}^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{Vcc}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted)

| Parameter | Symbol | Min. | Typ. | Max. | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Power Supply Voltage | Vcc | 4.5 | 5.0 | 5.5 | Volts | 6 |
| Input Logic 0 Voltage | VIL | -0.5 |  | 0.8 | Volts |  |
| Input Logic 1 Voltage | $\mathrm{V}_{\text {IH }}$ | 2.0 |  | Vcc | Volts |  |
| DC ELECTRICAL CHARACTERISTICS |  |  |  |  |  |  |
| Vcc Power Supply Current (Active) | Icc1 |  |  | 40 | mA | 1 |
| Vcc Power Supply Current (Standby) | Icc2 |  | 7 |  | mA | 7 |
| Input Leakage Current | li(L) | -10 |  | 10 | $\mu \mathrm{A}$ | 2 |
| Output Leakage Current | lo(L) | -10 |  | 10 | $\mu \mathrm{A}$ | 3 |
| Output Logic "0" Voltage <br> @ Iout $=3.3 \mathrm{~mA}$ | Vol |  |  | 0.4 | Volts |  |
| Output Logic "1" Voltage <br> @ \|out $=-220 \mu \mathrm{~A}$ | VOH | 2.4 |  |  | Volts |  |


| Parameter | Symbol | Min. | Typ. | Max. | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AC ELECTRICAL CHARACTERISTICS |  |  |  |  |  |  |
| Cycle Time | tc | 375 |  |  | ns | 4 |
| $\overline{\text { CE Pulse Width }}$ | tce | 250 |  |  |  | 4 |
| $\overline{\mathrm{CE}}$ Access Time | tac |  |  | 250 | ns | 4 |
| Output Turn Off Delay | toff |  |  | 60 | ns | 4 |
| Address Hold Time Referenced to $\overline{\mathrm{CE}}$ | $t_{\text {AH }}$ | 60 |  |  | ns |  |
| Address Setup Time Referenced to $\overline{\mathrm{CE}}$ | $t_{\text {AS }}$ | 0 |  |  | ns |  |
| CE Precharge Time | $t p$ | 125 |  |  | ns |  |
| CAPACITANCE |  |  |  |  |  |  |
| Input Capacitance | Cl |  | 5 |  | pF | 5 |
| Output Capacitance | CO |  | 7 |  | pF | 5 |
| NOTES: |  |  |  |  |  |  |
| 1. Current is proportional to cycle rate. ICCl is measured at the specified minimum cycle time. <br> 5. Capacitance measured with Boonton Meter or effective capacitance calculated from the equation: $\Delta Q$ |  |  |  |  |  |  |
| 2. V IN $=0 \mathrm{~V}$ to 5.5 V . |  |  |  |  |  |  |
| 3. Device unselected; VOUT $=0 \mathrm{~V}$ to 5.5 V . 6. A minimum $100 \mu \mathrm{~s}$ time delay is required after the application of | 6. A minimum $100 \mu \mathrm{~s}$ time delay is required after the application of $V C C(+5)$ before proper device operation is achieved |  |  |  |  |  |
| 4. Measured with 2 TTL loads and 100 pF , transition times $=20 \mathrm{~ns}$. |  |  |  |  |  |  |

TIMING DIAGRAM


## OPERATION

The ROM 36000 is controlled by the chip enable ( $\overline{\mathrm{CE}}$ ) input. A negative going edge at the $\overline{\mathrm{CE}}$ input will activate the device as well as strobe and latch the inputs into the onchip address registers. At
access time the outputs will become active and contain the data read from the selected location. The outputs will remain latched and active until $\overline{\mathrm{CE}}$ is returned to the inactive state.

## PROGRAMMING

Standard Microsystems Corporation will accept data input in the form of $8 \mathrm{~K}, 16 \mathrm{~K}, 32 \mathrm{~K}$ and 64 K EPROMS and $8 \mathrm{~K}, 16 \mathrm{~K}, 32 \mathrm{~K}$ and 64 K ROMS. If
other programming media is preferable, please consult the factory.

Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently, complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and to supply the best product possible.

STANDARD MICROSYSTEMS
CORPORATION
35 Marcus Blvd., Hauppauge, N.Y. 11787
(516) 273-3100 • TWX-510-227-8898

We keep ahead of our competition so you can keep ahead of yours.

## Hucuu? <br> Printer

## CHARACTER GFNERATOR

| Part ITumber | Description | Bcan | Max Access Time | Power 8upplies | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CG $4103{ }^{(3)}$ | $5 \times 7 \times 64$ | Column | $1.2 \mu \mathrm{sec}$ | $+6,-12$ or $\pm 12$ | 28 DIP | $357-360$ |

## SHIFT REGISTER

| Part Tramber | Description | Feature | $\begin{gathered} \text { Max } \\ \text { Clock Freq. } \end{gathered}$ | $\begin{aligned} & \text { Power } \\ & \text { Supply } \end{aligned}$ | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SR 5015-XX ${ }^{(3)}$ | Quad Statio Shift Register Mask Programmable Length | Load, Recirculate, Shift Controls, | 1 MHz | +6 | 16 DIP | 381-364 |
| SR 5015-80 | Quad 80 Bit Static |  |  |  |  |  |
| SR 5015-81 | Quad 81 Bit Static |  |  |  |  |  |
| SR 6016-133 | Quad 133 Bit Static |  |  |  |  |  |
| SR 6017 | Quad 81 Bit | Shift Left/Shift Right, Recirculate Controls Asynch | 1 MHz | +5 | 16 DIP | 365-368 |
| SR 5018 | Quad 133 Bit | Controls, Asynchronous clear |  |  |  |  |

## CHARACTER GENERATOR 2240-Bit Programmable (ROM) 64 Characters of $5 \times 7$ Bits

## FEATURES

$\square$ Static Operation, no clocks required.2240-Bit Capacity, fully decoded.64 Characters of 35 Bits ( $5 \times 7$ )Column by Column Output-Column ScanTTL CompatibleWired "OR" Capability for memory expansionPower Supplies: $+14 \mathrm{v},-14 \mathrm{v}$ or +12 v , $-12 v$, or $+5 v,-12 v$Eliminates need for $+12 v$ power supplySingle mask custom programming

## APPLICATIONS

Matrix PrintersVertical Scan Alphanumeric DisplaysBillboard and Stock Market Displays$\square$ Strip PrinterLED Matrix Arrays

## PIN CONFIGURATION




## General Description

The CG4100 Series MOS Read Only Memories (ROMs) are designed specifically for dot-matrix character generation where column by column output data is desired. Each ROM contains 2240 bits of programmable storage, organized as 64 characters, each having 5 columns of 7 bits.

The output word appears as a 5 word sequence on each of the output lines. Sequence is controlled by the 5 Column Select lines. By strobing the first select line, the first group of 7 bits (first column) is obtained at the output. By sequentially strobing $\mathrm{C}_{1}$ through $\mathrm{C}_{5}$ the font of the addressed character would be displayed. The character address may remain fixed while the column select changes.

Since only 6 address bits are required in order to decode the 64 stored characters, the seventh bit $\left(A_{7}\right)$ may be used as a chip enable. The chip enable (CE) in conjunction with the single ended open drain output buffers allow for memory expansion through wired "OR" connection.

The CG4100 Series contains an USASCII character font. Custom memory patterns are provided through the use of customer provided encoding sheets, tapes, or card decks.

## MAXIMUM GUARANTEED RATINGS*

| Operating Temperature Range | $-25^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature Range | $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on any Pin, with respect to Vss | +0.3 V to -30 V |

*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

RECOMMENDED OPERATING CONDITIONS $\left(-25^{\circ} \mathrm{C} \leqslant T_{A} \leqslant+85^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Suppy Voltage | Vss |  | 0.0 |  | V |
| Supply Voltage | Vdo | -12.0 | -14.0 | -16.0 | V |
| Supply Voltage | VGg | -24.0 | -28.0 | -29.0 | V |
| Input Voltage, logic "O" Logic "O"= most positive level | $\mathrm{V}_{\mathrm{H}}$ | Vss-1.5 | Vss |  | V |
| Input Voltage, logic " 1 " <br> Logic " l "= most negative; level | VIL |  | Vod | Vss-11 | V |

Note: The design of the CG4100 permits a broad range of operation that allows the user to take advantage of readily available power supplies; e.g. $+5 \mathrm{~V},-12 \mathrm{~V}$. See "Operational Interface-To/From TTL logic" diagram.

ELECTRICAL CHARACTERISTICS $\left(V S S=+14 v, V_{G G}=-14 v, V D D=G\right.$ round, $T_{A}=25^{\circ} C$, unless otherwise noted)

| Parameter | Symbol | Min. | Typ. | Max. | Units | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Output Blank Current | los | - | - | 10 | $\mu \mathrm{a}$ | VoD applied to output see Note 1. |
| Output Dot Current | 100 | 2.5 | - | - | ma | VoD applied to output see Note 1. |
| Input Leakage Current | In | - | - | 10 | $\mu \mathrm{a}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{OV}$ |
| Output Voltage | Vo | - | 2.0 | - | V | $10=0.5 \mathrm{ma}$ |
|  |  | - | 5.0 | - | V | $\mathrm{lo}=2.0 \mathrm{ma}$ |
| Address Access Time | $t_{\text {A }}$ | - | - | 1200 | ns |  |
| Column Select Access Time | tca | - | - | 600 | ns |  |
| Chip Enable Access Time | tce | - | - | 400 | ns |  |
| Power Dissipation |  | - | - | 400 | mw | Output unconnected |

Note 1: An output dot is defined as the ON state of the MOS output transmitter. An output blank is defined as the OFF state.

## Description of Pin Functions

| Pin No. | Symbol | Name | Function |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \hline 1,3,5,7 \\ & 9,11,13 \end{aligned}$ | $\begin{aligned} & \mathrm{O}_{1}, \mathrm{O}_{2}, \mathrm{O}_{3}, \mathrm{O}_{4} \\ & \mathrm{O}_{5}, \mathrm{O}_{6}, \mathrm{O}_{7} \end{aligned}$ | Outputs | 7 Data Outputs |
| 14 | Vod | Vod | Usually connected to Ground |
| 15 | Vgg | VGg | Negative power supply: -14 v or -12 v |
| 16 | A6 | Address | Bit 6 of the character address |
| 17 | Vss | Vss | Positive power supply: +14 v or +12 v or +5 v |
| 18-22 | $\mathrm{C}_{1}-\mathrm{C}_{5}$ | Column Select | Column Select inputs |
| 23-27 | $\mathrm{A}_{5}-\mathrm{A}_{1}$ | Address | Bits 1 through 5 of the character address |
| 28 | $\mathrm{CE}\left(\mathrm{A}_{7}\right)$ | Chip Enable | Chip Enable for memory expansion |


$\mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{t}}<50 \mathrm{~ns}$ for all timing diagram forcing functions.
Al-output waveforms are measured at the output of the 7400 TTL gate.



Pin-for-Pin Equivalent for: TMS 4103 MK2002 S8499.
Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

## Quad Static Shift Register

## FEATURES

$\square$ COPLAMOS ${ }^{\circledR}$ N Channel Silicon Gate Technology
$\square$ Variable Length—Single Mask
Programmable-1 to 134 bits
$\square$ Directly TTL-compatible on all inputs, outputs, and clockClear functionOperation guaranteed from DC to 1.0 MHzRecirculate logic on-chipSingle +5.0 V power supplyLow clock input capacitance16 pin ceramic DIP PackagePin for Pin replacement for AMI S2182, 83. 85

## APPLICATIONS

Memory BufferingUnique Buffering LengthsTerminalsBLOCK DIAGRAM


The SMC SR 5015-XXX is a quad static shift register family fabricated using SMC's COPLAMOS ${ }^{\circledR}$ N channel silicon gate process which provides a higher functional density and speed on a monolithic chip than conventional MOS technology. The COPLAMOS ${ }^{\circledR}$ process provides high speed operation, low power dissipation, low clock input capacitance, and single +5 volt power supply operation.

These shift registers can be driven by either $\mathrm{T}^{2} \mathrm{~L}$ circuits or by MOS circuits and provide driving capability to MOS or $\mathrm{T}^{2} \mathrm{~L}$ circuits. This device consists of four separate static shift registers with independent input and output terminals and logic for loading, recirculating or shifting information. The SR 5015-80, SR 5015-81, and SR $5015-133$ are respectively 80,81 , and 133 bit quad shift registers.

The recirculate control pin is common for registers A, B, and C. Register D has an independent recirculate control pin as well as a recirculate input pin.

A clear pin has been provided that will cause the shift register to be cleared when the pin is at Vcc . A single $\mathrm{T}^{2} \mathrm{~L}$ clock is required for operation.

The transfer of data into the register is accomplished on the low-to-high transition of the clock with the recirculate control low. For long term data storage the clock may be stopped and held in either logic state. Recirculate occurs when the recirculate control is high. Output data appears on the low-to-high transition of the clock pulse.

Bits 81 and 133 are available for flag storage.
This device has been designed to be used in high speed buffer storage systems and small recirculating memories.
Special custom configurations are achieved via single mask programming in lengths of 1 to 134 bits.

## MAXIMUM GUARANTEED RATINGS*

Operating Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec.) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8.0 V
Negative Voltage on any Pin, with respect to ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 0.3 V
*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
ELECTRICAL CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{VcC}=+5 \mathrm{~V} \pm 5 \%$, unless otherwise noted)

| Parameter | Min. | Typ. | Max. | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. CharacteristicsINPUT VOLTAGE LEVELS |  |  |  |  |  |
|  |  |  |  |  |  |
| Low Level, VIL |  |  | 0.8 | V |  |
| High Level, $\mathrm{V}_{\mathbf{I}}$ | Vcc-1.5 |  | Vcc | V |  |
| OUTPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low Level, Vol |  |  | 0.4 | V | $10 L=1.6 \mathrm{ma}$ |
| High Level, Voh | $\mathrm{Vcc}-1.5$ | 4.0 |  | V | $1 \mathrm{OH}=100 \mu \mathrm{a}$ |
| INPUT LEAKAGE CURRENT |  |  | 1.0 | $\mu \mathrm{a}$ | $\mathrm{V}_{\text {IN }}=\mathrm{Vcc}$ |
| CLOCK, CLEAR |  |  | 25 | pf |  |
| All Other |  |  | 10 | pf |  |
| POWER SUPPLY CURRENT |  |  | 80 | ma |  |
| A.C. Characteristics |  |  |  |  | TA $=+25^{\circ} \mathrm{C}$ |
| CLOCK |  |  |  |  |  |
| PWH | 300 |  |  | ns |  |
| PWL | 600 |  |  | ns |  |
| Transition, $\mathrm{tr}, \mathrm{ts}^{\text {f }}$ |  | 0.02 | 1.0 | $\mu \mathrm{S}$ |  |
| Repetition Rate, 1/T | 0 |  | 1.0 | MHz |  |
| $t$ Delay | 300 |  |  | ns |  |
| INPUT DATA |  |  |  |  |  |
| to, set-up | 100 |  |  | ns |  |
| to, hold | 200 |  |  | ns |  |
| PWo | 300 |  |  | ns |  |
| OUTPUT DATA |  |  |  |  |  |
| RECIRCULATE CONTROL |  |  |  |  |  |
| tr, set-up | 200 |  |  | ns |  |
| tre, hold | 300 |  |  | ns |  |
| PWh | 500 |  |  | ns |  |
| CLEAR |  |  |  |  |  |
| PWclear | 20 |  |  | $\mu \mathrm{S}$ |  |

## TIMING DIAGRAMS



## Description of Pin Functions

| Pin No. | Symbol | Name | Function |
| :---: | :---: | :---: | :---: |
| 1 | A | Input A | Input signal which is either high or low depending on what word is to be loaded into shift register. |
| 2 | RECABC | Recirculate $A B C$ | Input signal when high disconnects inputs from registers and connects outputs to inputs, thus recirculating data. Recirculates only A, B, C outputs. |
| 3 | CLR | Clear | Input signal when high forces outputs to a low state immediately and clears all the registers. |
| 4 | B | Input B | Input signal for B register. |
| 5 | O | Output B | Output signal for B register. |
| 6 | GND | GND | Power supply Ground. |
| 7 | Vcc | +5 Volt | 5 volt power supply. |
| $\begin{aligned} & 8 \\ & 9 \end{aligned}$ | Oc CLK | Output C Clock Input | Output signal for C register. Input signal which is normally low and pulses high to shift data into the registers. The data is clocked in on low to high edge of clock. |
| 10 | C | Input C | Input signal for C register. |
| 11 | NC | NC |  |
| 12 | RECD | Recirculate Control D | Input signal which is normally low and, when goes high, disconnects Input D to register and connects Recirculate Input $D$ to register. |
| 13 | D | Input D | Input signal for D register. |
| 14 | Od | Output D | Output signal for D register. |
| 15 | RID | Recirculate Input D | Input signal which is the input to the $D$ register when Recirculate Control $D$ is high: $\mathrm{RECD}=1$. |
| 16 | $\mathrm{OA}_{4}$ | Output A | Output signal for A register. |

Line Buffer for CRT Display . . . 80 Characters per line.


Line Buffer for Matrix Printer . . . 132 Characters per line.


STANDARD MICROSYSTEMS CORPORATION

Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

## Quad Static Shift Right/Shift Left Shift Register Last In First Out Buffer LIFO

## FEATURES

$\square$ COMPLAMOS ${ }^{\circledR}$ N-Channel Silicon
Gate Technology.Quad 81 bit or Quad 133 bitDirectly Compatible with T²L, MOSOperation Guaranteed from DC to 1.0 MHz

Recirculate logic on-chip
Single +5.0 V power supply
Low clock input capacitance
Single phase clock at T² levels
Clear function
16-pin Ceramic DIP Package

## APPLICATIONS

Bi-Directional Printer
Computers-Push Down
Stack-LIFO
$\square$ Buffer data storage-memory buffer
Delay lines-delay line processing
Digital filtering

PIN CONFIGURATION


Telemetry SystemsTerminals
$\square$ Peripheral Equipment

BLOCK DIAGRAM


The SMC SR 5017 and SR 5018 are quad 133 (SR 5017) and quad 81 (SR 5018) bit static shift registers utilizing SMC's COPLAMOS ${ }^{\circledR} \mathrm{N}$ channel silicon gate process. The COPLAMOS ${ }^{\circledR}$ process provides high speed operation, low power dissipation, low clock input capacitance, and requires only a single +5 volt power supply.

These shift registers can be driven by either $\mathrm{T}^{2} \mathrm{~L}$ circuits or by MOS circuits and provide driving capability to MOS to $\mathrm{T}^{2} \mathrm{~L}$ circuits.

This device consists of four separate static shift registers with independent input and output terminals and logic for loading, recirculating or shifting information right or left. This shift left/shift right (L/R Control) control input is common to all registers.

The recirculate control input is common for registers A, B, and C. Register D has an independent recirculate control input as well as a Recirculate Input.

A Clear input has been provided that will cause the shift register to be cleared when the input is at Vcc . A single $\mathrm{T}^{2} \mathrm{~L}$ clock input is required for operation.

The transfer of data into the register is accomplished on the low-to-high transition of the clock with the recirculate control low. For long term data storage the clock may be stopped and held in either logic state. Recirculate occurs when the recirculate control is high. Output data appears on the low-to-high transition of the clock pulse.

Bits 81 or 133 are available for flag storage.


| Parameter | Min. | Typ. | Max. | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D.C. Characteristics |  |  |  |  |  |
| INPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low Level, VIL |  |  | 0.8 | V |  |
| High Level, $\mathrm{V}_{\mathrm{IH}}$ | Vcc-1.5 |  | Vcc | V |  |
| OUTPUT VOLTAGE LEVELS |  |  |  |  |  |
| Low Level, Vol |  |  | 0.4 | V | $\mathrm{loL}=1.6 \mathrm{ma}$ |
| High Level, Vон | Vcc-1.5 | 4.0 |  | V | Іон $=100 \mu$ a |
| INPUT LEAKAGE CURRENT |  |  | 1.0 | $\mu \mathrm{a}$ | $\mathrm{VIN}=\mathrm{Vcc}$ |
| CLOCK, CLEAR |  |  | 25 | pf |  |
| All Other |  |  | 10 | pf |  |
| POWER SUPPLY CURRENT |  |  | 100 | ma |  |
| A.C. Characteristics |  |  |  |  | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ |
| CLOCK |  |  |  |  |  |
| PWH | 300 |  |  | ns |  |
| PWL | 600 |  |  | ns |  |
| Transition, $\mathrm{tr}_{\text {r }} \mathrm{tf}^{\text {f }}$ |  | 0.02 | 1.0 | $\mu \mathrm{S}$ |  |
| Repetition Rate, 1/T | 0 |  | 1.0 | MHz |  |
| ${ }^{\text {t Delay }}$ | 500 |  |  | ns |  |
| INPUT DATA |  |  |  |  |  |
| to, set-up | 150 |  |  | ns |  |
| to, hold | 150 |  |  | ns |  |
| PWo | 300 |  |  | ns |  |
| OUTPUT DATA |  |  |  |  |  |
| RECIRCULATE CONTROL |  |  |  |  |  |
| tr, set-up | 200 |  |  | ns |  |
| tr, hold | 300 |  |  | ns |  |
| PWR | 500 |  |  | ns |  |
| CLEAR |  |  |  |  |  |
| PWclear | 20 |  |  | $\mu \mathrm{S}$ |  |



Description of Pin Functions

| Symbol | Name | Pin | Function |
| :---: | :---: | :---: | :---: |
| D | Input D | 1 | Input signal for D register. |
| RID | Recirculate Input D | 2 | Input signal which is the input to the $D$ register when recirculate control $D$ is high: RECD $=1$. |
| Od | Output D | 3 | Output signal for D register. |
| CLR | Clear | 4 | Input signal when high forces outputs to a low state immediately and clears all the registers. |
| $\mathrm{OA}_{\text {a }}$ | Output A | 5 | Output signal for A register. |
| L/R CON | Shift Left/Shift Right Control | 6 | Input signal which is low for loading data and for shifting right. When L/R CON is high, the register will shift left. |
| A | Input A | 7 | Input signal which is either high or low depending on what word is to be loaded into shift register. |
| CLK | Clock Input | 8 | Input signal which is normally low and pulses high to shift data into the registers. The data is clocked in on low to high edge of clock. |
| Vcc | 5 Volt | 9 | 5 volt power supply. |
| RECABC | Recirculate ABC | 10 | Input signal when high disconnects inputs from registers and connects outputs to inputs, thus recirculating data. Recirculates only A, B, C outputs. |
| $\mathrm{Ob}^{\text {b }}$ | Output B | 11 | Output signal for B register. |
| B | Input B | 12 | Input signal for B register. |
| C | Input C | 13 | Input signal for C register. |
| Oc | Output C | 14 | Output signal for C register. |
| GND | GND | 15 | Ground. |
| RECD | Recirculate Control D | 16 | Input signal which is normally low and, when goes high, disconnects Input $D$ to register and connects RECIRCULATE INPUT D to register. |

## Logic Diagram



## APPLICATION

## Line Buffer for Bidirectional Matrix Printer . . . 80/132 characters per line

 information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

| Part Number | No. of Keys | Modes | Features | Suffix | ndard Fonts Description | Power Supplies | Package | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| KR-2376 XX ${ }^{(3)}$ | 88 | 3 | 2 Key Rollover | ST | ASCII | +5, -12 | 40 DIP | 371.374 |
| KR-3800 XX ${ }^{(3)}$ | 90 | 4 | 2 Key or <br> N Key Rollover | $\begin{aligned} & \text {-ST } \\ & \text {-STD } \\ & \text {-PRO } \end{aligned}$ | ASCII <br> ASCII <br> Binary Sequential | $+5,-12$ | 40 DIP | 375-382 |

[^13]
## Keyboard Encoder Read Only Memory

## FEATURES

Outputs directly compatible with TTL/DTL or MOS logic arrays.External control provided for output polarity selection.External control provided for selection of odd or even parity.Two key roll-over operation.N-key lockout.Programmable coding with a single mask change.Self-contained oscillator circuit.Externally controlled delay network provided to eliminate the effect of contact bounce.One integrated circuit required for complete keyboard assembly.Static charge protection on all input and output terminals.Entire circuit protected by a layer of glass passivation.
## PIN CONFIGURATION



## GENERAL DESCRIPTION

The SMC KR2376-XX is a 2376-bit Read Only Memory with all the logic necessary to encode single pole single throw keyboard closures into a usable 9 -bit code. Data and strobe outputs are directly compatible with TTL/DTL or MOS logic arrays without the use of
any special interface components.
The KR2376-XX is fabricated with low threshold, P-channel technology and contains 2942 P-channel enhancement mode transistors on a single monolithic chip, available in a 40 pin dual-in-line package.

TYPICAL CONNECTION OF KR2376-XX


## MAXIMUM GUARANTEED RATINGS $\dagger$

Operating Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
GND and $V_{G G}$, with respect to $V_{c c}$. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 C to +0.3 V
Logic Input Voltages, with respect to Vcc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . - 20 V to +0.3 V
$\dagger$ Stresses above those listed may cause permanent damage to the device. This is astress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS

( $\mathrm{TA}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{VCC}_{\mathrm{C}}=+5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{GG}}=-12 \mathrm{~V} \pm 1.0 \mathrm{~V}$, unless otherwise noted)

| Characteristics | Min | Typ | Max | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CLOCK | 20 | 50 | 100 | KHz | see fig. 1 footnote (**) for typical R -C values |
| DATA INPUT |  |  |  |  |  |
| Logic "0" Level |  |  | +0.8 | V |  |
| Logic "1" Level | Vcc-1.5 |  |  | V |  |
| Input Capacitance |  |  | 10 | pf |  |
| INPUT CURRENT |  |  |  |  |  |
| *Control, Shift \& Y0 |  |  |  |  |  |
| thru Y10 | 10 | 100 | 140 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=+5.0 \mathrm{~V}$ |
| *Control, Shift \& YO thru Y10 | 5 | 30 | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=$ Ground |
| Data Invert, Parity Invert |  | . 01 | 1 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=-5.0 \mathrm{~V}$ to +5.0 V |
| DATA OUTPUT \& X OUTPUT |  |  |  |  |  |
| Logic "0" Level |  |  | +0.4 | V | lol $=1.6 \mathrm{~mA}$ (see fig. 7) |
| Logic "1" Level | Vcc-1.0 |  |  | V | $1 \mathrm{OH}=100 \mu \mathrm{~A}$ |
| POWER CONSUMPTION |  | 140 | 200 | mW | Nom. Power Supp. Voltages (see fig. 8) |

SWITCH CHARACTERISTICS
Minimum Switch Closure
Contact Closure Resistance between X 1 and Y 1
Contact Open Resistance between X 1 and Y 1
see timing diagram-fig. 2
300 Ohm
$1 \times 10^{7}$
*Inputs with Internal Resistor to VGG

## DESCRIPTION OF OPERATION

The KR2376-XX contains (see Fig. 1), a 2376-bit ROM, 8-stage and 11-stage ring counters, an 11-bit comparator, an oscillator circuit, an externally controllable delay network for eliminating the effect of contact bounce, and TTL/DTL/MOS compatible output drivers.

The ROM portion of the chip is a 264 by 9 -bit memory arranged into three 88 -word by 9 -bit groups. The appropriate levels on the Shift and Control inputs selects one of the three 88 -word groups; the 88 -individual word locations are addressed by the two ring counters. Thus, the ROM
address is formed by combining the Shift and Control Inputs with the two ring counters.

The external outputs of the 8 -stage ring counter and the external inputs to the 11-bit comparator are wired to the keyboard to form an $X-Y$ matrix with the 88-keyboard switches as the crosspoints. In the standby condition, when no key is depressed, the two ring counters are clocked and sequentially address the ROM; the absence of a Strobe Output indicates that the Data Outputs are 'not valid' at this time.

When a key is depressed, a single path is completed between one output of the 8 -stage ring counter ( X 0 thru X7) and one input of the 11-bit comparator (Y0-Y10). After a number of clock cycles, a condition will occur where a level on the selected path to the comparator matches a level on the corresponding comparator input from the 11-stage ring counter. When this occurs, the comparator generates a signal to the clock control and to the Strobe Output (via the delay network). The clock control stops the clocks to the ring counters and the Data Outputs
(B1-B9) stabilize with the selected 9-bit code, indicated by a 'valid' signal on the Strobe Output. The Data Outputs remain stable until the key is released.

As an added feature two inputs are provided for external polarity control of the Data Outputs. Parity Invert (pin 6) provides polarity control of the Parity Output (pin 7) while the Data and Strobe Invert Input (pin 20) provides for polarity control of Data Outputs B1 thru B8 (pins 8 thru 15) and the Strobe Output (pin 16).

## SPECIAL PATTERNS

Since the selected coding of each key is defined during the manufacture of the chip, the coding can be changed to fit any particular application of the keyboard. Up to 264 codes of up to 8 bits (plus one parity bit) can be programmed into the KR2376-XX

ROM covering most popular codes such as ASC11, EBCD1C, Selectric, etc., as well as many specialized codes. The ASC11 code is available as a standard pattern. For special patterns, use Fig. 9.


Fig. 2

POWER SUPPLY CONNECTIONS FOR TTL/DTL OPERATION


POWER SUPPLY CONNECTIONS FOR MOS OPERATION


Fig. 3

OUTPUT DRIVER \& "X" OUTPUT STAGE TO KEYBOARD



Fig. 5

OSCILLATOR FREQUENCY VS. $\mathrm{C}_{2}$


Fig. 6

TYP. OUTPUT
ON RESISTANCE
VS. GATE
BIAS VOLTAGE


Fig. 7

TYP. POWER CONSUMPTION vS. TEMPERATURE


Fig. 8

## CODE ASSIGNMENT CHART <br> KR2376-ST <br> 8 Bit ASCII, odd parity



Fig. 9
$\mathrm{N}=$ Normal Mode
S = Shift Mode
= Output Logic " 1 " (see data B1-88)
Logic " 1 " $=+5.0 \mathrm{~V}$
Logic " 1 " $=$ Ground

## Keyboard Encoder Read Only Memory

## FEATURES

- Data output directly compatible with TTL
- N Key rollover or lockout operation
- Quad mode
- Lockout/rollover selection externally selected as option
- On chip-master/slave oscillator
- All 10 output bits available
- Fully buffered data outputs
- Output enable provided as option
- Data compliment control provided as option
- Pulse or level data ready output signal provided as an option
- Any key down output provided as an option
- Contact bounce circuit provided to eliminate contact bounce
- Static charge protection on all input/outputs
- Pin for Pin replacement for GI AY-5-3600


## GENERAL DESCRIPTION

The SMC Microsystems KR3600-XX is a Keyboard Encoder containing a 3600 bit read only memory and all the logic necessary to encode single pole single throw keyboard closures into a 10 bit code.

The KR3600-XX is fabricated with a low voltage $p$ channel technology and contains the equivalent of 5000 transistors on a monolithic chip in a 40 lead dip ceramic package.

## PIN CONFIGURATION

| Function |  |  |  |
| :---: | :---: | :---: | :---: |
| Option | 1 | 40 | $\mathrm{Xc}_{\mathrm{c}}$ |
| Option See | 2 | 39 | $\mathrm{X}_{1}$ |
| Option "Pin | 3 | 38 | $\mathrm{X}_{2}$ |
| Option $\begin{gathered}\text { Assignment } \\ \text { Chart" }\end{gathered}$ | 4 | 37 | $\mathrm{X}_{3}$ |
| Option | 5 | 36 | $\mathrm{X}_{4}$ |
| Data Output B9 | 6 | 35 | $\mathrm{X}_{5}$ |
| Data Output B8 | 7 | 34 | $\mathrm{X}_{6}$ |
| Data Output B7 | 8 | 33 | $]^{1} X_{7}$ |
| Data Output 86 | 9 | 32 | $]^{X_{8}}$ |
| Data Output B5 | 10 | 31 | Delay Node Input |
| Data Output B4 | 11 | 30 | - $\mathrm{V}_{\mathrm{cc}}$ |
| Data Output B3 | 12 | 29 | 7 Shift Input |
| Data Output B2 | 13 | 28 | ] Control Input |
| Data Output B1 | 14 | 27 | $\mathrm{V}_{G G}$ |
| $V_{00}$ | 15 | 26 | $\square \mathrm{Y}$ g |
| Data Ready | 16 | 25 | $] Y_{8}$ |
| Yo | 17 | 24 | $\square Y_{1}$ |
| $Y_{1}$ | 18 | 23 | $\square Y_{6}$ |
| $Y_{2}$ | 19 | 22 | $\square Y_{5}$ |
| $Y_{3}$ |  |  | $\square Y_{4}$ |
| PACKAGE: $40-\mathrm{Pin}$ D.I.P. |  |  |  |

## BLOCK DIAGRAM


*RI (100K $\Omega$ ). CI ( 450 of) PROVIDES APPROX. SOKHZ CLOCK FREO. * ${ }^{*}$ C2 (300nS DELAY/CPF) R2 SUPPLIED INTE MNALLY.

## DESCRIPTION OF OPERATION

The KR3600 contains a 3600 bit ROM, 9 -stage and 10 -stage ring counters, a 10 bit comparator, timing circuitry, a 90 bit memory to store the location of encoded keys for $n$ key rollover operation, an externally controllable delay network for eliminating the effect of contact bounce, an output data buffer, and TTL/DTL/MOS compatible output drivers.

The ROM portion of the chip is a 360 by 10 bit memory arranged into four 90 -word by 10 -bit groups. The appropriate levels on the Shift and Control Inputs selects one of the four 90 -word groups; the 90 -individual word locations are addressed by the two ring counters. Thus, the ROM address is formed by combining the Shift and Control Inputs with the two ring counters.

The external outputs of the 9 -stage ring counter and the external inputs to the 10 -bit comparator are wired to the keyboard to form an X-Y matrix with the 90-keyboard switches as the crosspoints. In the standby conditions, when no key is depressed, the two ring counters are clocked and sequentially address the ROM, thereby scanning the key switches for key closures.

When a key is depressed, a single path is completed between one output of the 9-stage ring counter (X0 thru X8) and one input of the 10-bit comparator $\left(Y_{0}-Y_{9}\right)$. After a number of clock cycles, a condition will occur where a level on the selected path to the comparator matches a level on the corresponding comparator input from the 10 -stage ring counter.

N KEY ROLLOVER - When a match occurs, and the key has not been encoded, the switch bounce delay network is enabled. If the key is still depressed at the end of the selected delay time, the code for the depressed key is transferred to the output data buffer, the data ready signal appears, a one is stored in the encoded key memory and the scan sequence is resumed. If a match occurs at another key location, the sequence is repeated thus encoding the next key. If the match occurs for an already encoded key, the match is not recognized. The code of the last key encoded remains in the output data buffer.

N KEY LOCKOUT - When a match occurs, the delay network is enabled. If the key is still depressed at the end of the selected delay time, the code for the depressed key is transferred to the output data buffer, the data ready signal appears and the remaining keys are locked out by halting the scan sequence. The scan sequence is resumed upon key release. The output data buffer stores the code of the last key encoded.

SPECIAL PATTERNS - Since the selected coding of each key and all the options are defined during the manufacture of the chip, the coding and options can be changed to fit any particular application of the keyboard. Up to 360 codes of up to 10 bits can be programmed into the KR3600 ROM covering most popular codes such as ASCII, EBCDIC, Selectric, etc., as well as many specialized codes.

CUSTOM CODING INFORMATION
The custom coding information for SMC's 3600 Bit Keyboard Encoder ROM should be transmitted to SMC. The Truth Table should be completed on the format supplied.

## LEGEND

CC $=$ Complement Control
AKO $=$ Any Key Down Output $\mathrm{B} 10=\mathrm{B} 10$ (Data) Output
LO/RO = Lockout/Rollover
$C E=$ Chip Enable
Internal Clock $=$ Self Contained Oscillator External Clock $=$ External Frequency Source


## MAXIMUM GUARANTEED RATINGS*

| Operating Temperature Range | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature Range. | $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Lead Temperature (soldering, 10 sec. ) | $+325^{\circ} \mathrm{C}$ |
| Positive Voltage on any Pin, $\mathrm{V}_{\mathrm{cc}}$ | +0.3 V |
| Negative Voltage on any Pin, $\mathrm{V}_{\mathrm{cc}}$ | -25 V |

*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other condition above those indicated in the operational sections of this specification is not implied.

## ELECTRICAL CHARACTERISTICS

$\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{GG}}=-12 \mathrm{~V} \pm 1.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=\mathrm{GND}$, unless otherwise noted)

| Characteristics | Min | Typ** | Max | Units | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Clock Frequency | 10 | 50 | 100 | KHz | See Block diagram footnote* for typical R-C values |
| External Clock Width | 7 | - | - | $\mu \mathrm{S}$ |  |
| Data \& Clock Input <br> (Shift, Control, <br> Compliment Control, <br> Lockout/Rollover, <br> Chip Enable <br> \& External Clock) <br> Logic "0" Level <br> Logic "1" Level <br> Shift \& Control Input Current |  |  |  |  |  |
|  | $V_{G G}$ | - | +0.8 | V |  |
|  | $V_{C C}-1.5$ | - | $V_{c c}+0.3$ | V |  |
|  | 75 | 150 | 220 | $\mu \mathrm{A}$ | $V_{1 N}=+5 \mathrm{~V}$ |
| $X$ Output ( $X_{0}-X_{8}$ ) <br> Logic " 1 " Output Current |  |  |  |  |  |
|  | $40$ $600$ | $\begin{gathered} 250 \\ 1300 \end{gathered}$ | 500 4000 | ${ }_{\mu}^{\mu} \mathbf{A}$ | $V_{\text {OJT }}=V_{c c}$ (See Note 2) $V_{\text {OJT }}=V_{c c}-1.3 \mathrm{~V}$ |
|  | 900 | 2000 | 6500 | ${ }_{\mu} \mathrm{A}$ | $\mathrm{V}_{\text {Out }}=\mathrm{V}_{\mathrm{cc}}-2.0 \mathrm{~V}$ |
|  | 1500 | 2000 | 14,000 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {our }}=\mathrm{V}_{\text {cc }}-5 \mathrm{~V}$ |
|  | 3000 | 10,000 | 23,000 | $\mu \mathrm{A}$ | $V_{\text {out }}=V_{c c}-10 \mathrm{~V}$ |
| Logic "0' Output Current | 8 | 30 | 60 | $\mu \mathrm{A}$ | $V_{\text {out }}=V_{c c}$ |
|  | 6 | 25 | 50 | $\mu \mathrm{A}$ | $V_{\text {Out }}=\mathrm{V}_{\text {cc }}-1.3 \mathrm{~V}$ |
|  | 5 | 20 | 45 | $\mu \mathrm{A}$ | $V_{\text {OUt }}=V_{\text {cc }}-2.0 \mathrm{~V}$ |
|  | 2 | 10 0.5 | 30 5 | ${ }_{\mu}^{\mu} \mathrm{A}$ | $V_{\text {оנт }}=V_{c c}-5 \mathrm{~V}$ $V_{\text {OנT }}=V_{c c}-10 \mathrm{~V}$ |
| Y Input ( $\mathrm{Y}_{0}-\mathrm{Y}_{9}$ ) |  |  |  |  |  |
| Trip Level | $V_{c c}-5$ | $V_{c c}-3$ | $V_{c c}-2$ | V | Y Input Going Positive (See Note 2) |
| Hysteresis | 0.5 | 0.9 | 1.4 | $V$ | (See Note 1) |
| Selected Y Input Current | 18 | 100 | 170 | $\mu \mathrm{A}$ | $\mathrm{V}_{I N}=\mathrm{V}_{\mathrm{cc}}$ |
|  | 14 | 80 | 150 | $\mu \mathrm{A}$ | $V_{I N}=V_{C c}-1.3 V$ |
|  | 13 | 50 40 | 130 110 | ${ }_{\mu}{ }_{\mu} \mathrm{A}$ | $V_{i N}=V_{c c}-2.0 \mathrm{~V}$ $V_{i N}=V_{c c}-4.0 \mathrm{~V}$ |
| Unselected Y Input Current | 9 | 40 | 80 | $\mu \mathrm{A}$ | V ${ }^{\text {IN }}=\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{cc}}$ |
|  | 7 | 30 | 70 | $\mu \mathrm{A}$ | $V_{1 N}=V_{C C}-1.3 \mathrm{~V}$ |
|  | 6 | 25 | 60 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{cc}}-2.0 \mathrm{~V}$ |
|  | 3 | 15 | 40 | $\mu \mathrm{A}$ | $V_{I N}=V_{c c}-5 V$ |
|  | - | 0.5 | 20 | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{C C}-10 \mathrm{~V}$ |
| Input Capacitance | - | 3 | 10 | pF | at OV (All Inputs) |
| Switch Characteristics |  |  |  |  |  |
| Minimum Switch Closure | - | - | - | - | See Timing Diagram |
| Contact Closure Resistance | - | - | 300 | $\Omega$ | $\mathbf{Z}_{\mathrm{cc}}$ |
|  | $1 \times 10^{7}$ | - | 300 | $\Omega$ | $\mathrm{Z}_{\mathrm{co}}$ |
| Strobe Delay |  |  |  |  |  |
| Trip Level (Pin 31) | $V_{c c}-4$ | $V_{c c}-3$ | $\mathrm{V}_{\mathrm{cc}}-2$ | $V$ |  |
| Hysteresis <br> Quiescent Voltage (Pin 31) | 0.5 -3 | 0.9 -5 | 1.4 -9 | V | (See Note 1) <br> With Internal Switched Resistor |
| Qulescent Voitage (Pin 31) | -3 | -5 | -9 | $V$ | With Internal Switched Resistor |
| Data Output (B1-B10), Any Key Down Output, Data Ready |  |  |  |  |  |
| Logic "0", | - | - | 0.4 | $V$ | $\mathrm{l}_{\mathrm{L}}=1.6 \mathrm{~mA}$ |
| Logic "1" | $\begin{aligned} & V_{c c}-1 \\ & V_{c c}-2 \end{aligned}$ | - | - | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=1.0 \mathrm{~m} \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=2.2 \mathrm{~m} \mathrm{~A} \end{aligned}$ |
| Power |  |  |  |  |  |
| lcc | - | 12 | 25 | $\mathrm{mA}$ | $V_{c c}=+5 \mathrm{~V}$ |
| $I_{G G}$ | - | 12 | 25 | mA | $V_{G G}=-12 V$ |

**Typical values are at $+25^{\circ} \mathrm{C}$ and nominal voltages.
NOTE

1. Hysteresis is defined as the amount of return required to unlatch an input.
2. Precharge of $X$ outputs and $Y$ inputs occurs during each scanned clock cycle.


MINIMUM SWITCH CLOSURE $=$ SWITCH BOUNCE $+\left(90 \times \frac{1}{8}\right)+$ STROBE DELAY + STROBE WIDTH

"Y'" INPUT STAGE FROM KEYBOARD


OUTPUT DRIVER

NOTE: Output driver capable of driving one TTL load with no external resistor. Capable of driving two TTL loads using an external $6.8 \mathrm{~K} \Omega$ resistor to $V_{G G}$
'X' OUTPUT STAGE TO KEYBOARD


STROBE DELAY vs. $\mathrm{C}_{2}$


OSCILLATOR FREQUENCY vs. $\mathrm{C}_{1}$


# KR3600-STD 



Internal oscillator (pins 1, 2,3) Any key down (pin 4) positive output N key rollover only

Pulse data ready signal
Internal resistor to VDD on shift and control pins
KR3600-STD outputs provides ASC 11 bits 1-6 on B1-B6, and bit 7 on B8

## KR 3600-ST

| XY | $\underset{\mathrm{B}-123456789}{\text { Normal }}$ | $\begin{gathered} \text { Shift } \\ \mathrm{B}-123456789 \end{gathered}$ | $\begin{aligned} & \text { Control } \\ & \text { B-123456789 } \end{aligned}$ | $\begin{aligned} & \text { Shift/Control } \\ & \mathrm{B}-123456789 \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| 00 | $\backslash 000001101$ | $\sim 011111101$ | NUL 000000001 | RS 011110001 |
| 01 | $=101111010$ | + 110101001 | GS 101110001 | VT 110100010 |
| 02 | DC3 110010010 | DC3 110010010 | DC3 110010010 | DC3 110010010 |
| 03 | - 101101001 | - 111110101 | CR 101100010 | US 111110010 |
| 04 | BS 000100010 | BS 000100010 | BS 000100010 | BS 000100010 |
| 05 | 0000011001 | 0000011001 | 0000011001 | 0000011001 |
| 06 | - 011101001 | - 011101001 | - 011101001 | - 011101001 |
| 07 | 000000000 | 000000000 | 000000000 | 000000000 |
| 08 | 000000000 | 000000000 | 000000000 | 000000000 |
| 09 | 000000000 | 000000000 | 000000000 | 000000000 |
| 10 | / 111101010 | ? 111111001 | ST 111100001 | US 111110010 |
| 11 | - 011101001 | $>011111010$ | SO 011100010 | RS 011110001 |
| 12 | ? 001101010 | < 001111001 | FF 001100001 | FS 001110010 |
| 13 | m 101101110 | M 101100101 | CR 101100010 | CR 101100010 |
| 14 | n 011101110 | N 011100101 | SO 011100010 | SO 011100010 |
| 15 | b 010001110 | B 010000101 | STX 010000010 | STX 010000010 |
| 16 | $\checkmark 011011110$ | $\checkmark 011010101$ | SYN 011010010 | SYN 011010010 |
| 17 | c 110001101 | C 110000110 | ETX 110000001 | ETX 110000001 |
| 18 | $\times 000111101$ | $\times 000110110$ | CAN 000110001 | CAN 000110001 |
| 19 | z 010111110 | Z 010110101 | SUB 010110010 | SUB 010110010 |
| 20 | LF 010100001 | LF 010100001 | LF 010100001 | LF 010100001 |
| 21 | \001110101 | : 001111110 | FS 001110010 | FS 001110010 |
| 22 | DEL 111111110 | DEL 111111110 | DEL 111111110 | DEL 111111110 |
| 23 | [ 110110110 | ] 101110110 | ESC 110110001 | GS 101110001 |
| 24 | 7111011010 | 7111011010 | 7111011010 | 7111011010 |
| 25 | 8000111010 | 8000111010 | 8000111010 | 8000111010 |
| 26 | 9100111001 | 9100111001 | 9100111001 | 9100111001 |
| 27 | 000000000 | 000000000 | 000000000 | 000000000 |
| 28 | 000000000 | 000000000 | 000000000 | 000000000 |
| 29 | 000000000 | 000000000 | 000000000 | 000000000 |
| 30 | ; 110111010 | : 010111001 | ESC 110110001 | SUB 010110010 |
| 31 | I 001101101 | L 001100110 | FF 001100001 | FF 001100001 |
| 32 | k 110101110 | K 110100101 | VT 110100010 | VT 110100010 |
| 33 | j 010101101 | J 010100110 | LF 010100001 | LF 010100001 |
| 34 | h 000101110 | H 000100101 | BS 000100010 | BS 000100010 |
| 35 | g 111001110 | G 111000101 | BEL 111000010 | BEL 111000010 |
| 36 | f 011001101 | F 011000110 | ACK 011000001 | ACK 011000001 |
| 37 | d 001001110 | D 001000101 | EOT 001000010 | EOT 001000010 |
| 38 | s 110011110 | S 110010101 | DC3 110010010 | DC3 110010010 |
| 39 | a 100001110 | A 100000101 | SOH 100000010 | SOH 100000010 |
| 40 | 000000000 | 000000000 | 000000000 | 000000000 |
| 41 | - 110111101 | + 101111101 | ESC 110110001 | GS 101110001 |
| 42 | GR 101100010 | GR 101100010 | GR 101100010 | GR 101100010 |
| 43 | - 111001001 | " 010001001 | BEL 111000010 | STX 010000010 |
| 44 | 4001011010 | 4001011010 | 4001011010 | 4001011010 |
| 45 | 5101011001 | 5101011001 | 5101011001 | 5101011001 |
| 46 | 6011011001 | 6011011001 | 6011011001 | 6011011001 |
| 47 | 000000000 | 000000000 | 000000000 | 000000000 |
| 48 | 000000000 | 000000000 | 000000000 | 000000000 |
| 49 | 000000000 | 000000000 | 000000000 | 000000000 |
| 50 | p 000011110 | P 000010101 | DEL 000010010 | DEL 000010010 |
| 51 | - 111101101 | - 111100110 | SI 111100001 | SI 111100001 |
| 52 | i 100101101 | I 100100110 | HT 100100001 | HT 100100001 |
| 53 | u 101011110 | U 101010101 | NAK 101010010 | NAK 101010010 |
| 54 | y 100111110 | Y 100110101 | EM 100110010 | EM 100110010 |
| 55 | t 001011101 | T 001010110 | DC4 001010001 | DC4 001010001 |
| 56 | r 010011101 | R 010010110 | DC2 010010001 | DC2 010010001 |
| 57 | e 101001101 | E 101000110 | ENQ 101000001 | ENQ 101000001 |
| 58 | w 111011101 | W 111010110 | ETB $11101000 \uparrow$ | ETB 111010001 |
| 59 | q 100011101 | Q 100010110 | DC1 100010001 | DC1 100010001 |
| 60 | 000000000 | 000000000 | 000000000 | 000000000 |
| 61 | 000000000 | 000000000 | 000000000 | 000000000 |
| 62 | DC2 010010001 | DC2 010010001 | DC2 010010001 | DC2 010010001 |
| 63 | 000000000 | 000000000 | 000000000 | 000000000 |
| 64 | 1100011010 | 1100011010 | 1100011010 | 1100011010 |
| 65 | 2010011010 | 2010011010 | 2010011010 | 2010011010 |
| 66 | 3110011001 | 3110011001 | 3110011001 | 3110011001 |
| 67 | 000000000 | 000000000 | 000000000 | 000000000 |
| 68 | 000000000 | 000000000 | 000000000 | 000000000 |
| 69 | 000000000 | 000000000 | 000000000 | 000000000 |
| 70 | 0000011001 | ) 100101010 | DLE 000010010 | HT 100100001 |
| 71 | 9100111001 | ( 000101001 | EM 100110010 | BS 000100010 |
| 72 | 8000111010 | - 010101010 | CAN 000110001 | LF 010100001 |
| 73 | 7111011010 | \& 011001010 | ETB 111010001 | ACK 011000001 |
| 74 | 6011011001 | $\wedge 011110110$ | SYN 011010010 | RS 011110001 |
| 75 | 5101011001 | \% 101001010 | NAK 101010010 | ENQ 101000001 |
| 76 | 4001011010 | \$ 001001001 | DC4 001010001 | EOT 001000010 |
| 77 | 3110011001 | \# 110001010 | DC3 110010010 | ETX 110000001 |
| 78 79 | 2010011010 1100011010 | @ 000000110 | DC2 010010001 | NUL 000000001 |
| 79 80 | 1100011010 000000000 | 100001001 000000000 | DC1 100010001 | SOH 100000010 |
| 81 | 000000000 | 000000000 | 000000000 | 000000000 |
| 82 | 000000000 | 000000000 | 000000000 | 000000000 |
| 83 | 000000000 | 000000000 | 000000000 | 000000000 |
| 84 | 000000000 | 000000000 | 000000000 | 000000000 |
| 85 | SP 000001010 | SP 000001010 | NUL 000000001 | NUL 000000001 |
| 86 | 000000000 | 000000000 | 000000000 | 000000000 |
| 87 | DC1 100010001 | DC1 100010001 | DC1 100010001 | DC1 100010001 |
| 88 | HT 100100001 | HT 100100001 | HT 100100001 | HT 100100001 |
| 89 | ESC 110110001 | ESC 110110001 | ESC 110110001 | ESC 110110001 |


| XY | Normal | Shift | Control | Shitt/Control |
| :---: | :---: | :---: | :---: | :---: |
| 00 | 000000000 | 001000000 | 010000000 | 011000000 |
| 01 | 000000001 | 001000001 | 010000001 | 011000001 |
| 02 | 000000010 | 001000010 | 010000010 | 011000010 |
| 03 | 000000011 | 001000011 | 010000011 | 011000011 |
| 04 | 000000100 | 001000100 | 010000100 | 011000100 |
| 05 | 000000101 | 001000101 | 010000101 | 011000101 |
| 06 | 000000110 | 001000110 | 010000110 | 011000110 |
| 07 | 000000111 | 001000111 | 010000111 | 011000111 |
| 08 | 000001000 | 001001000 | 010001000 | 011001000 |
| 09 | 000001001 | 001001001 | 010001001 | 011001001 |
| 10 | 000001010 | 001001010 | 010001010 | 011001010 |
| 11 | 000001011 | 001001011 | 010001011 | 011001011 |
| 12 | 000001100 | 001001100 | 010001100 | 011001100 |
| 13 | 000001101 | 001001101 | 010001101 | 011001101 |
| 14 | 000001110 | 0010011110 | 010001110 | 011001110 |
| 15 | 000001111 | 001001111 | 010001111 | 011001111 |
| 16 | 000010000 | 001010000 | 010010000 | 011010000 |
| 17 | 000010001 | 001010001 | 010010001 | 011010001 |
| 18 | 000010010 | 001010010 | 010010010 | 011010010 |
| 19 | 000010011 | 001010011 | 010010011 | 011010011 |
| 20 | 000010100 | 001010100 | 010010100 | 011010100 |
| 21 | 000010101 | 001010101 | 010010101 | 011010101 |
| 22 | 000010110 | 001010110 | 010010110 | 011010110 |
| 23 | 000010111 | 001010111 | 010010111 | 011010111 |
| 24 | 000011000 | 001011000 | 010011000 | 011011000 |
| 25 | 000011001 | 001011001 | 010011001 | 011011001 |
| 26 | 000011010 | 001011010 | 010011010 | 011011010 |
| 27 | 000011011 | 001011011 | 010011011 | 011011011 |
| 28 | 000011100 | 001011100 | 010011100 | 011011100 |
| 29 | 000011101 | 001011101 | 010011101 | 011011101 |
| 30 | 000011110 | 001011110 | 010011110 | 011011110 |
| 31 | 000011111 | 001011111 | 010011111 | 011011111 |
| 32 | 000100000 | 001100000 | 010100000 | 011100000 |
| 33 | 000100001 | 001100001 | 010100001 | 011100001 |
| 34 | 000100010 | 001100010 | 010100010 | 011100010 |
| 35 | 000100011 | 001100011 | 010100011 | 011100011 |
| 36 | 000100100 | 001100100 | 010100100 | 011100100 |
| 37 | 000100101 | 001100101 | 010100101 | 011100101 |
| 38 | 000100110 | 001100110 | 010100110 | 011100110 |
| 39 | 000100111 | 001100111 | 010100111 | 011100111 |
| 40 | 000101000 | 001101000 | 010101000 | 011101000 |
| 41 | 000101001 | 001101001 | 010101001 | 011101001 |
| 42 | 000101010 | 001101010 | 010101010 | 011101010 |
| 43 | 000101011 | 001101011 | 010101011 | 011101011 |
| 44 | 000101100 | 001101100 | 010101100 | 011101100 |
| 45 | 000101101 | 001101101 | 010101101 | 011101101 |
| 46 | 000101110 | 001101110 | 010101110 | 011101110 |
| 47 | 000101111 | 001101111 | 010101111 | 011101111 |
| 48 | 000110000 | 001110000 | 010110000 | 011110000 |
| 49 | 000110001 | 001110001 | 010110001 | 011110001 |
| 50 | 000110010 | 001110010 | 010110010 | 011110010 |
| 51 | 000110011 | 001110011 | 010110011 | 011110011 |
| 52 | 000110100 | 001110100 | 010110100 | 011110100 |
| 53 | 000110101 | 001110101 | 010110101 | 011110101 |
| 54 | 000110110 | 001110110 | 010110110 | 011110110 |
| 55 | 000110111 | 001110111 | 010110111 | 011110111 |
| 56 | 000111000 | 001111000 | 010111000 | 011111000 |
| 57 | 000111001 | 001111001 | 010111001 | 011111001 |
| 58 | 000111010 | 001111010 | 010111010 | 011111010 |
| 59 | 000111011 | 001111011 | 010111011 | 011111011 |
| 60 | 000111100 | 001111100 | 010111100 | 011111100 |
| 61 | 000111101 | 001111101 | 010111101 | 011111101 |
| 62 | 000111110 | 001111110 | 010111110 | 011111110 |
| 63 | 000111111 | 001111111 | 010111111 | 011111111 |
| 64 | 100000000 | 101000000 | 110000000 | 111000000 |
| 65 | 100000001 | 101000001 | 110000001 | 111000001 |
| 66 | 100000010 | 101000010 | 110000010 | 111000010 |
| 67 | 100000011 | 101000011 | 110000011 | 111000011 |
| 68 | 100000100 | 101000100 | 110000100 | 111000100 |
| 69 | 100000101 | 101000101 | 110000101 | 111000101 |
| 70 | 100000110 | 101000110 | 110000110 | 111000110 |
| 71 | 100000111 | 101000111 | 110000111 | 111000111 |
| 72 | 100001000 | 101001000 | 110001000 | 111001000 |
| 73 | 100001001 | 101001001 | 110001001 | 111001001 |
| 74 | 100001010 | 101001010 | 110001010 | 111001010 |
| 75 | 100001011 | 101001011 | 110001011 | 111001011 |
| 76 | 100001100 | 101001100 | 110001100 | 111001100 |
| 77 | 100001101 | 101001101 | 110001101 | 111001101 |
| 78 | 100001110 | 101001110 | 110001110 | 111001110 |
| 79 | 100001111 | 101001111 | 110001111 | 111001111 |
| 80 | 100010000 | 101010000 | 110010000 | 111010000 |
| 81 | 100010001 | 101010001 | 110010001 | 111010001 |
| 82 | 100010010 | 101010010 | 110010010 | 111010010 |
| 83 | 100010011 | 101010011 | 110010011 | 111010011 |
| 84 | 100010100 | 101010100 | 110010100 | 111010100 |
| 85 | 100010101 | 101010101 | 110010101 | 111010101 |
| 86 | 100010110 | 101010110 | 110010110 | 111010110 |
| 87 | 100010111. | 101010111 | 110010111 | 111010111 |
| 88 | 100011000 | 101011000 | 110011000 | 111011000 |
| 89 | 100011001 | 101011001 | 110011001 | 111011001 |

Options:
internal oscillator (pins 1, 2, 3)
Lockout/rollover (pin 4), with internal resistor to VDD Lockout is logic 1

Any key down (pin 5), positive output
Pulse data ready
Internal resistor to VDD on shift \& control pins

## DESCRIPTION

The KR 3600 PRO is a MOS/LSI device intended to simplify the interface of a microprocessor to a keyboard matrix. Like the other KR 3600 parts, the KR 3600 PRO contains all of the logic to de-bounce and encode keyswitch closures, while providing either a 2-key or N -key rollover.

The output of the KR 3600 PRO is a simple binary code which may be converted to a standard information code by a PROM or directly by a microprocessor. This permits a user maximum flexibility of key layout with simple field programming.

The code in the KR 3600 is shown in Table I. The format is simple: output bits $9,8,7,6,5,4$ and 1 are a binary sequence. The count starts at X0, YO and increments through X0Y1, XOY2...X8Y9. Bit 9 is the LSB; bit 1 is the MSB.

Bits 2 and 3 indicate the mode as follows:

Bit 2
Bit 3

| 0 | 0 | Normal |
| :--- | :--- | :--- |
| 0 | 1 | Shift |
| 1 | 0 | Control |
| 1 | 1 | Shift Control |

For maximum ease of use and flexibility, an internal scanning oscillator is used, with pin selection of N-key lockout (also known as 2-key rollover) and N-key rollover. An "any-key-down" output is provided for such uses as repeat oscillator keying.
Figure 1 shows a PROM-encoded 64 key, 4 mode application, using a $256 \times 8$ PROM, and Figure 2 a full 90 key, 4 mode application, utilizing a $512 \times 8$ PROM.
If $N$-key rollover operation is desired, it is recommended that a diode be inserted in series with each switch as shown. This prevents "phantom" key closures from resulting if three or more keys are depressed simultaneously.


Circuit diagrams utilizing SMC products are included as a means of iliustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

## Single Chip 8-Bit Microcomputer

## FEATURES

$\square 2 \mathrm{~K}$ bytes of mask programmable ROM memory64 bytes of scratch pad RAM
$\square 32$ bits (4 ports) TTL compatible I/OProgrammable binary timer interval timer mode pulse width measurement mode event counter modeExternal Interrupt Input
$\square$ Crystal, LC, RC, or external time base options
$\square$ Low Power (275 mW typical)

## GENERAL DESCRIPTION

The MPU3870 is a complete 8 -bit microcomputer on a single MOS integrated circuit. The MPU3870 can execute a set of more than 70 instructions. The MPU3870 features 2K bytes of ROM, 64 bytes of scratch pad RAM, a programmable binary timer, and 32 bits of I/O.

The programmable binary timer operates by itself

PIN CONFIGURATION

in the interval timer mode or in conjunction with the external interrupt input in the pulse width measurement and the event counter modes of operation. Two sources of vectored, prioritized interrupt are provided with the binary timer and the external interrupt input. The user has the option of specifying one of four clock sources: crystal, LC, RC or external clock.



INTERRUPT


MPU 3870
PROGRAMMABLE
REGISTERS, PORTS, AND MEMORY MAP
Figure 2
SCRATCHPAD MEMORY
SCRATCHPAD

| SCRATCHPAD DEC | HEX | OC1 |  |
| :--- | :--- | :--- | :--- |
|  | 0 | 0 | 0 |
|  | 1 | 1 | 1 |

$$
\begin{aligned}
& \text { SCRATCHPAD } \\
& \text { ADDRESS REGISTER }
\end{aligned}
$$




## MPU3870 MAIN MEMORY

There are four address registers used to access main memory. These are the Program Counter (PO), the Stack Register (P), the Data Counter (DC), and the Auxiliary Data Counter (DC1). The Program Counter is used to address instructions or immediate operands. The Stack Register is used to save the contents of the Program Counter during an interrupt or subroutine call. Thus, the Stack Register contains the return address at which processing is to resume upon completion of the subroutine or interrupt routine. The Data Counter is used to address data tables. The register is auto-incrementing. Of the two data counters, only Data Counter (DC), can access the ROM. However, the XDC instruction allows the Data Counter and Auxiliary Data Counter to be exchanged.

## I/O PORTS

The MPU3870 provides four, 8 bit bidirectional Input/Output ports. These are ports $0,1,4,5$. In addition, the Interrupt Control Port is addressed as Port 6 and the binary timer is addressed as Port 7. The programming of Ports 6 and 7 and the bidirectional I/O pin are covered in the 3870 Technical Manual. The schematic of an I/O pin and available output drive options are shown in Figure 4.
An output ready strobe is associated with Port 4. This flag may be used to signal a peripheral device that the MPU3870 has just completed an output of new data to Port 4. The strobe provides a single low pulse shortly after the output operation is completely finished, so either edge may be used to signal the peripheral. STROBE may also be used as an input strobe to Port 4 after completing the input operation.

## MPU3870 CLOCKS

The time base network used with the MPU3870 may be one of the four different types listed below.

Crystal
LC
RC
External Clock

The type of network which is to be used with the MPU3870 is to be specified at the time when mask ROM MPU3870 devices are ordered. The time base specifications for each of the four modes are covered in the 3870 Technical Manual.

## MPU3870 ARCHITECTURE

The basic functional elements of the MPU3870 are shown in Figure 1. A programming model is shown in Figure 2. The user is referred to the 3870 Technical Manual for a thor-
ough discussion of the architecture, instruction set, and other features.

DESCRIPTION OF PIN FUNCTIONS

| PINNO. | NAME | DESCRIPTION | FUNCTION |
| :---: | :---: | :---: | :---: |
| $\begin{gathered} 3-6,19-16 \\ 37-34,22-25 \\ 8-15 \\ 33-26 \\ \hline \end{gathered}$ | $\begin{aligned} & \overline{P 0-0} \overline{P 0-7} \\ & \frac{P 1-\bar{P}}{P 1-P 1-7} \\ & \hline \frac{P 4-0-P 4-7}{P 5-0-P 5-7} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 1 / O \text { Port } 0 \\ & 1 / O \text { Port } 1 \\ & 1 / \mathrm{Port} 4 \\ & 1 / \mathrm{OPort} 5 \\ & \hline \end{aligned}$ | $\overline{\mathrm{P} 0-0}$ through $\overline{\mathrm{P} 0-7}, \overline{\mathrm{P} 1-0}$ through $\overline{\mathrm{P} 1-7}, \overline{\mathrm{P} 4-0}$ through $\overline{\mathrm{P} 4-7}$, and $\overline{\mathrm{P} 5-0}$ through $\overline{\text { P5-7 }}$ are 32 lines which can be individually used as either TTL compatible inputs or as latched outputs. |
| 7 | $\overline{\text { STROBE }}$ | Ready Strobe | $\overline{\text { STROBE }}$ is a ready strobe associated with I/O Port 4. This output pin, which is normally high, provides a single low pulse after valid data is present on the P4-0 through $\mathrm{P} 4-7$ pins during an output instruction. |
| 38 | EXT INT | External Interrupt | EXT INT is the external interrupt input. Its active state is software programmable. This input is also used in conjunction with the timer for pulse width measurement and event counting. |
| 39 | $\overline{\text { RESET }}$ | External Reset | $\overline{R E S E T}$ may be used to externally reset the MK3870. When pulled low the MK3870 will reset. When then allowed to go high the MK3870 will begin program execution at program location $\mathrm{H}^{\circ} 000^{\prime}$. |
| 1,2 | XTL 1, XTL 2 | Time Base | XTL 1 and XTL 2 are the time base inputs to which a crystal, LC network, RC network, or an external single-phase clock may be connected. The time base network must be specified when ordering a mask ROM MK3870. The MK38P70 will operate with any of the four configurations. |
| 21 | TEST | Test Line | TEST is an input, used only in testing the MK3870. For normal circuit functionality this pin may be left unconnected, but it is recommended that TEST be grounded. |
| 40 | $\mathrm{V}_{\text {cc }}$ | Power Supply | +5 volt supply pin |
| 20 | GND | Ground | Ground |

## I/O PIN CONCEPTUAL DIAGRAM WITH OUTPUT BUFFER OPTIONS



| OPERATING VOLTAGES AND TEMPERATURES |  |  |
| :--- | :--- | :--- |
| Dash |  |  |
| Number <br> Suffix | Operating <br> Voltage | Operating <br> Temperature |
| -00 | $+5 \mathrm{~V} \pm 10 \%^{*}$ | T $_{\mathrm{A}}$ |
| -05 | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ |  |
| -10 | $+5 \mathrm{~V} \pm 5 \%^{\circ}$ | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ |
| -15 | $+5 \mathrm{~V} \pm 10 \%^{*}$ | $-40^{\circ} \mathrm{C}-+85^{\circ} \mathrm{C}$ |
|  | $+5 \mathrm{~V} \pm 5 \%^{*}$ | $-40^{\circ} \mathrm{C}-+85^{\circ} \mathrm{C}$ |

See Ordering Information for explanation of part numbers.

## ABSOLUTE MAXIMUM RATINGS*

|  | -00, -05 | -10, -15 |
| :---: | :---: | :---: |
| Temperature Under Bias | $-20^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $-50^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on any Pin With Respect to Ground (Except open drain pins and TEST) | -1.0 V to +7 V | -1.0 V to +7 V |
| Voltage on TEST with Respect to Ground | -1.0 V to +9 V | -1.0 V to +9 V |
| Voltage on Open Drain Pins With Respect to Ground | -1.0 V to +13.5 V | -1.0 V to +13.5 V |
| Power Dissipation | 1.5W | 1.5W |
| Power Dissipation by any one I/O pin | 60 mW | 60 mW |
| Power Dissipation by all I/O pins . | 600 mW | 600 mW |

*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 condition 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.

AC CHARCTERISTICS $T_{A}, V_{C C}$ within specified operating range. I/O power dissipation $\leqslant 100 \mathrm{~mW}$ (Note 2)

| SIGNAL | SYM | PARAMETER | -00, -05 |  | -10, -15 |  | UNIT | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MIN | MAX |  |  |
| $\begin{aligned} & \text { XTL1 } \\ & \text { XTL2 } \end{aligned}$ | $t_{0}$ | Timer Base Period, all clock modes | 250 | 500 | 250 | 500 | ns | $4 \mathrm{MHz}-2 \mathrm{MHz}$ |
|  | $\begin{aligned} & t_{\mathrm{ex}(\mathrm{H})} \\ & \mathrm{t}_{\mathrm{ex}(\mathrm{~L})} \end{aligned}$ | External clock pulse width high External clock pulse width low | $\begin{gathered} 90 \\ 100 \\ \hline \end{gathered}$ | $\begin{aligned} & 400 \\ & 400 \end{aligned}$ | $\begin{array}{r} 100 \\ 110 \\ \hline \end{array}$ | $\begin{aligned} & 390 \\ & 390 \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |  |
| ¢ | t $\Phi$ | Internal $\Phi$ clock | $2 \mathrm{t}_{0}$ |  | $2 \mathrm{t}_{0}$ |  |  |  |
| WRITE | $\mathrm{t}_{\text {w }}$ | Internal WRITE Clock period | $\begin{aligned} & 4 \mathrm{t} \Phi \\ & 6 \mathrm{t} \Phi \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 4 t \Phi \\ & 6 t \Phi \end{aligned}$ |  |  | Short Cycle Long Cycle |
| I/O | $\mathrm{tavo}^{\text {o }}$ | Output delay from internal WRITE clock | 0 | 100 | 0 | 1200 | ns | 50pF plus one TTL load |
|  | $\mathrm{t}_{\text {s/o }}$ | Input setup time to intrenal WRITE clock | 1000 |  | 1200 |  | ns |  |
| $\overline{\text { STROBE }}$ | $\mathrm{t}_{10 \mathrm{O}, \mathrm{s}}$ | Output valid to STROBE delay | $\begin{array}{\|c\|} \hline 3 t \Phi \\ -1000 \\ \hline \end{array}$ | $\begin{gathered} 3+\Phi \\ +250 \\ \hline \end{gathered}$ | $\begin{array}{\|c\|} \hline 31 \Phi \\ -1200 \\ \hline \end{array}$ | $\begin{array}{r} 3 t \Phi \\ +300 \\ \hline \end{array}$ | ns | ```I/O load= 50pF + 1 TTL load``` |
|  | $\mathrm{t}_{\text {st }}$ | STROBE low time | $\begin{gathered} \hline 8 \mathrm{t} \Phi \\ -250 \\ \hline \end{gathered}$ | $\begin{array}{r} 12 t \Phi \\ +250 \\ \hline \end{array}$ | $\begin{gathered} 8 t \Phi \\ -300 \\ \hline \end{gathered}$ | $\begin{array}{r} 121 \Phi \\ +300 \\ \hline \end{array}$ | ns | STROBE load= $50 \mathrm{pF}+3 \mathrm{~T}$ L Loads |
| RESET | $\mathrm{t}_{\text {RH }}$ | RESET hold time, low | $\begin{array}{r} 6 t \Phi \\ +750 \\ \hline \end{array}$ |  | $\begin{array}{\|c\|} \hline 6 t \Phi \\ +1000 \\ \hline \end{array}$ |  | ns |  |
|  | tapOC | RESET hold time, low for power clear | $\begin{array}{\|c\|} \hline \text { power } \\ \text { supply } \\ \text { rise } \\ \text { time } \\ -0.1 \\ \hline \end{array}$ |  | $\begin{array}{\|c} \hline \text { power } \\ \text { supply } \\ \text { rise } \\ \text { time } \\ +15 \\ \hline \end{array}$ |  | ms |  |
| EXT INT | $\mathrm{t}_{\text {EH }}$ | EXT INT hold time in active and inactive state | $\begin{array}{r} 6 t \Phi \\ +750 \\ \hline \end{array}$ |  | $\begin{array}{\|c\|} \hline 6 t \Phi \\ +1000 \\ \hline \end{array}$ |  | ns | To trigger interrupt |
|  |  |  | $2 t \Phi$ |  | $2 t \Phi$ |  | ns | To trigger timer |

DC CHARACTERISTICS $T_{A}, V_{C C}$ within specified operating range I/O power dissipation $\leqslant 100 \mathrm{~mW}$ (Note 2)

| SYM | PARAMETER | -00, -05 |  | -10, -15 |  | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| $\mathrm{V}_{\text {thex }}$ | External Clock input high level | 2.4 | 5.8 | 2.4 | 5.8 | V |  |
| $\mathrm{V}_{\text {ItEX }}$ | External Clock input low level | -. 3 | . 6 | -. 3 | . 6 | V |  |
| $\mathrm{I}_{\text {HEX }}$ | External Clock input high current |  | 100 |  | 130 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IHEX }}=\mathrm{V} 0_{\mathrm{cc}}$ |
| $\mathrm{I}_{\text {LEX }}$ | External Clock input low current |  | -100 |  | -130 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {LEX }}=\mathrm{V}_{\text {Ss }}$ |
| $\mathrm{V}_{\text {IHIO }}$ | Input high level, I/O pins | 2.0 | 5.8 | 2.0 | 5.8 | V | Standard pull-up |
|  |  | 2.0 | 13.2 | 2.0 | 13.2 | V | Open drain (1) |
| $\mathrm{V}_{\text {IHR }}$ | Input high level, $\overline{\text { RESET }}$ | 2.0 | 5.8 | 2.2 | 5.8 | V | Standard pull-up |
|  |  | 2.0 | 13.2 | 2.2 | 13.2 | V | No Pull-up |
| $\mathrm{V}_{\text {HEL }}$ | Input high level, EXT INT | 2.0 | 5.8 | 2.2 | 5.8 | V | Standard pull-up |
|  |  | 2.0 | 13.2 | 2.2 | 13.2 | V | No Pull-up |
| $\mathrm{V}_{11}$ | Input low level | -. 3 | . 8 | -. 3 | . 7 | V | (1) |
| $\mathrm{I}_{1}$ | Input low current, all pins with standard pull-up resistor |  | -1.6 |  | -1.9 | mA | $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |
| $I_{L}$ | Input leakage current, open drain pins, and inputs with no pull-up resistor |  | $\begin{gathered} +10 \\ -5 \\ \hline \end{gathered}$ |  | $\begin{array}{r} +18 \\ -8 \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ | $\begin{aligned} & V_{\text {IN }}=13.2 \mathrm{~V} \\ & V_{\text {IV }}=0.0 \mathrm{~V} \\ & \hline \end{aligned}$ |
| $\mathrm{I}_{\mathrm{OH}}$ | Output high current pins with standard pull-up resistor | $\begin{aligned} & -100 \\ & -30 \end{aligned}$ |  | $\begin{aligned} & -89 \\ & -25 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \mu A \\ & \mu A \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=3.9 \mathrm{~V} \end{aligned}$ |
| $\mathrm{I}_{\text {OHD }}$ | Output high current, direct drive pins | $\begin{aligned} & \hline-100 \\ & -1.5 \end{aligned}$ | -8.5 | $\begin{array}{r} -80 \\ -1.3 \end{array}$ | -11 | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & V_{\text {OH }}=2.4 \mathrm{~V} \\ & V_{\text {OH }}=1.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=0.7 \mathrm{~V} \\ & \hline \end{aligned}$ |
| $\mathrm{I}_{\text {OHS }}$ | STROBE Output High current | -300 |  | -270 |  | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{oL}}=2.4 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{L}}$ | Output low current | 1.8 |  | 1.65 |  | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| $\mathrm{I}_{\text {os }}$ | STROBE Output Low current | 5.0 |  | 4.5 |  | mA | $\mathrm{V}_{\mathrm{oL}}=0.4 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{cc}}$ | Average Power Supply Current |  | 85 |  | 110 | mA | MK3870/20 Outputs Open |

## TIMER AC CHARACTERISTICS

Definitions:
Error = Indicated time value - actual time value
tpsc $=t \Phi \times$ Prescale Value

## Interval Timer Mode:

Single interval error, free running (Note 3) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $\pm 66$. .
Cumulative interval error, free running (Note 3) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 0

Start Timer to stop Timer error (Notes 1, 4) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . + t $\Phi$ to - (tpsc + tФ)
Start Timer to read Timer error (Notes 1, 2) ......................................................................... -5 . $\Phi$ to - (tpsc +7 t $\Phi$ )
Start Timer to interrupt request error (Notes 1,3 ) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -2 2t $\Phi$ to - -8 t $\Phi$
Load Timer to stop Timer error (Note 1) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . + t $\Phi$ to - (tpsc +2 2t $\Phi$ )

Load Timer to interrupt request error (Notes 1,3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . - 2 - $\Phi$ to -9t $\Phi$
Pulse Width Measurement Mode:
Measurement accuracy (Note 4) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . + t . to - (tpsc +2 2t $\Phi$ )
Minimum pulse width of EXT INT pin. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 . 2 .
Event Counter Mode:
Minimum active time of EXT INT pin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 . . .
Minimum inactive time of EXT INT pin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2t .

## Notes:

1. All times which entail loading, starting, or stopping the Timer are referenced from the end of the last machine cycle of the OUT or OUTS instruction.
2. All times which entail reading the Timer are referenced from the end of the last machine cycle of the IN or INS instruction.
3. All times which entail the generation of an interrupt request are referenced from the start of the machine cycle in which the appropriate interrupt request latch is set. Additional time may elapse if the interrupt request occurs during a privileged or multicycle instruction.
4. Error may be cumulative if operation is repetitively performed.


INTERNAL WRITE CLOCK

C. INPUT ON PORT OOR 1

D. OUTPUT ON PORT 0,1

External Clock


Internal $\Phi$ Clock


I/O Port Output

$\overline{\text { RESET }}$


EXT INT


Note: All measurements are referenced to $\mathrm{V}_{\mathrm{IL}}$ max., $\mathrm{V}_{\mathrm{IH}}$ min., $\mathrm{V}_{\mathrm{OL}}$ max., or $\mathrm{V}_{\mathrm{OH}}$ min.

STROBE SOURCE CAPABILITY
(TYPICAL AT $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )


STROBE SINK CAPABILITY (TYPICAL AT $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )


STANDARD I/O PORT SOURCE CAPABILITY (TYPICAL AT $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )


DIRECT DRIVE I/O PORT SOURCE CAPABILITY (TYPICAL AT $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )

output voltage
I/O PORT SINK CAPABILITY
(TYPICAL AT $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )


MAXIMUM OPERATING TEMPERATURE VS. I/O POWER DISSIPATION


## STANDARD MICROSYSTEMS CORPORATIN <br> 35 Marcus Blvd. Havppawge NY 11788 5161273.3100 TWX. 510.227 .8998 <br> We keep ahead of our competition so you can keep ahead of yours

## STANDARD MICROSYSTEMS CORPORATION

## Package Outlines

14, 16, 18, 20 PIN HERMETIC PACKAGE


|  | 14 LEAD |  | 16 LEAD |  | 18 LEAD |  | 20 LEAD |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | DIM | MIN | MAX | MIN | MAX | MIN | MAX | MIN |
| MAX |  |  |  |  |  |  |  |  |
| A | .670 | .760 | .790 | .810 | .885 | .915 | .965 | .995 |
| C |  | .175 |  | .175 |  | .175 |  | .175 |
| D | .015 | .021 | .015 | .021 | .015 | .021 | .015 | .021 |
| F | .048 | .060 | .048 | .060 | .048 | .060 | .048 | .060 |
| G | .090 | .110 | .090 | .110 | .090 | .110 | .090 | .110 |
| J | .008 | .012 | .008 | .012 | .008 | .012 | .008 | .012 |
| K | .100 |  | .100 |  | .100 |  | .100 |  |
| L | .295 | .325 | .295 | .325 | .295 | .325 | .295 | .325 |
| M |  | $10^{\circ}$ |  | $10^{\circ}$ |  | $10^{\circ}$ |  | $10^{\circ}$ |
| N | .025 | .060 | .025 | .060 | .025 | .060 | .025 | .060 |

24, 28, 40 LEAD HERMETIC DIP


|  | 24 LEAD |  | 28 LEAD |  | 40 LEAD |  |
| :--- | ---: | ---: | ---: | ---: | ---: | ---: |
|  | MIN | MAX | MIN | MAX | MIN | MAX |
| A | 1.188 | 1.212 | 1.386 | 1.414 | 1.980 | 2.020 |
| B | .568 | .598 | .568 | .598 | .568 | .598 |
| C | .590 | .610 | .590 | .610 | .590 | .610 |
| D | .070 | .090 | .070 | .090 | .070 | .090 |
| E | .025 | .060 | .025 | .060 | .025 | .060 |
| F | .100 |  | .100 |  | .100 |  |




14 LEAD PLASTIC DIP

16 LEAD PLASTIC DIP


24, 28, 40 PIN PLASTIC DIP


|  | 24 LEAD |  | 28 LEAD |  | 40 LEAD |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX | MIN | MAX |
| A | 1.245 | 1.255 | 1.445 | 1.455 | 2.045 | 2.055 |
| C | .145 | .155 | .145 | .155 | .145 | .155 |
| D | .018 TYP | .018 TYP |  | .018 TYP |  |  |
| F | .060 TYP | .060 TYP |  | .060 TYP |  |  |
| G | .099 | .101 | .099 | .101 | .099 | .101 |
| J | .010 | .014 | .010 | .014 | .010 | .014 |
| K | .120 |  | .120 |  | .120 |  |
| L | .645 | .675 | .645 | .675 | .645 | .675 |
| M | .210 |  | .210 |  | .210 |  |

ALABAMA
EMA
2309 Starmount Circle
Huntsville, AL 35801
(205) 533-6640

ARIZONA
RELCOM Inc.
4314 E . Tonto St.
Phoenix, AZ 85044
(602) 893-1209

ARKANSAS
Nova Marketing Inc.
5728 LBJ Freeway
Suite 400
Dallas, TX 75240
(214) 385-9669

CALIFORNIA
(Southern)
RELCOM Inc. 20335 Ventura Blvd.
Suite 203
Woodland Hills, CA 91364
(213) 340-9143
(Northern)
Costar, Inc.
Suite SW3-175
10080 N. Wolfe Road
Cupertino, CA 95014
(408) 446-9339

COLORADO
WESCOM Mktg.
7985 Vance Drive
Suite 102
Arvada, CO 80003
(303) 422-7619

CONNECTICUT
Orlon Group
27 Meriden Ave.
Southington, CT 06489
(203) 621-8371

DELAWARE
BGR Assoc.
3001D Greentree
Executive Campus
Marlton, NJ 08053
(609) 428-2440

## FLORIDA

"C" Associates 2500 Hollywood Blvd.
Suite 302
Hollywood, FL 33020
(305) 922-5230
(305) 922-8917
"C" Associates 249 Maitland Ave. Suite 305 Altamonte Center Altamonte Springs, FL 32701 (305) 831-1717

## GEORGIA

EMA
6445 Hillandale Drive
Norcross, GA 30092
(404) 449-9430

## IDAHO

SDR ${ }^{2}$ Products \& Sales Co. 14230 N.E. 8th Street Bellevue, WA 98007 (206) 747-9424

## IOWA

Quantum Sales
10800 Normandale Blvd.
Bloomington, MN 55437
(612) 884-4700

## ILLINOIS

METCOM Associates Corp.
Two Talcott Road
Park Ridge, IL 60068
(312) 696-1490

KANSAS
S.W. Wollard Co.

Rural Route IBox 66A
Parker, KS 66072
(913) 898-6552

LOUISIANA
Nova Marketing Inc.
5728 LBJ Freeway
Suite 400
Dallas, TX 75240
(214) 385-9669

MAINE
Mill-Bern Assoc., Inc
120 Cambridge St.
Suite 8
Burlington, MA 01803 (617) 273-1313

## MARYLAND

Robert Electronic Sales 6407 Frederick Avenue Cantonville, MD 21228 (301) 788-2380

MASSACHUSETTS
Mill-Bern Assoc., Inc. 120 Cambridge St. Suite 8
Burlington, MA 01803
(617) 273-1313

MICHIGAN
DETROIT AREA
KRW Sales
P.O. Box 347

Farmington Hills, MI 48024
(313) 476-6090

GRAND RAPIDS
KRW Sales
P.O. Box 163

Grand Rapids, M1 49306
(616) 363-2925

## MINNESOTA

Quantum Sales Inc. 10800 Normandale Boulevard Bloomington, MN 55437
(612) 884-4700

MISSISSIPPI
EMA
2309 Starmount Circle Huntsville, AL 35801 (205) 533-6640

MISSOURI
S.W. Wollard Co.

Rural Route I Box 66A
Parker, KS 66072
(913) 898-6552

MONTANA
SDR ${ }^{2}$ Products \& Sales Co 14230 N.E. 8th Street Bellevue, WA 98007
(206) 747-9427

NEBRASKA
S.W. Wollard Co Rural Route I Box 66A Parker, KS 66072 (913) 898-6552

## NEVADA

RELCOM Inc. 4314 E . Tonto St. Phoenix, AZ 85044 (602) 893-1209

NEW JERSEY
(Northern)
Lorac Sales Electronics 550 Old Country Rd. Room 410
Hicksville, NY 11801
(516) 681-8746
(201) 622-4958
(Southern)
BGR Assoc.
3001D Greentree
Executive Campus
Marlton, NJ 08053
(609) 428-2440

NEW HAMPSHIRE
Mill-Bern Assoc., Inc 120 Cambridge St
Suite 8
Burlington, MA 01803
(617) 273-1313

NEW MEXICO
RELCOM Inc.
4314 E . Tonto St.
Phoenix, AZ 85044
(602) 893-1209

## NEW YORK

Lorac Sales Electronics 550 Old Country Rd.
Room 410
Hicksville, NY 11801
(516) 681-8746
(201) 622-4958
(Upstate)
L-Mar Assoc., Inc.
216 Tilden Drive E. Syracuse, NY 13057 (315) 437-7779

L-Mar Assoc., Inc. 4515 Culver Rd. Rochester, NY 14622 (716) 544-8000

## NORTH CAROLINA

 EMARt. 8 Dogwood Village Jonesboro, TN 37659 (615) 753-8861

NORTH DAKOTA
Quantum Sales
10800 Normandale Blvd. Bloomington, MN 55437 (612) 884-4700

## OHIO

Thompson \& Associates
7221 Taylorsville Rd Dayton, OH 45424
(513) 237-9422

OKLAHOMA
Nova Marketing Inc. 5728 LBJ Freeway Suite 400
Dallas, TX 75240
(214) 385-9669

OREGON
SDR ${ }^{2}$ Products \& Sales Co. 1526 S.E. Claybourne Portland, OR 97202 (206) 747-9424

PENNSYLVANIA
(Eastern)
BRG Assoc.
3001D Greentree
Executive Campus
Mariton, NJ 08053
(609) 428-2440
(Western)
Thompson \& Associates
7221 Taylorsville Rd.
Dayton, OH 45424
(513) 237-9422

RHODE ISLAND
Mill-Bern Assoc., Inc. 120 Cambridge St .
Suite 8
Burlington, MA 01803
(617) 273-1313

SOUTH CAROLINA
EMA
6645 Hillandale Dr.
Norcross, GA 30092
(404) 449-9430

SOUTH DAKOTA
Quantum Sales
10800 Normandale Blvd.
Bloomington, MN 55437
(612) 884-4700

TENNESSEE
(East)
EMA
Rt. 8 Dogwood Village
Jonesboro, TN 37659
(615) 753-8861
(West)
EMA
2309 Starmount Circle
Huntsville, AL 35801
(205) 553-6640

## TEXAS

Nova Marketing Inc.
5728 LBJ Freeway
Suite 400
Dallas, TX 75240
(214) 385-9669
(EI Paso)
RELCOM Inc 4314 E. Tonto St.
Phoenix, AZ 85044
(602) 893-1209

Nova Marketing, Inc 11700 S.W. Freeway
Suite 200
Houston, TX 77031
(713) 933-2636

## UTAH

WESCOM Mktg.
7985 Vance Drive
Suite 102
Arvada, CO 80003
(303) 422-7619

VERMONT
Mill-Bern Assoc., Inc.
120 Cambridge St.
Suite 8
Burlington, MA 01803
(617) 273-1313

VIRGINIA
Robert Electronic Sales 6407 Frederick Avenue Cantonville, MD 21228
(301) 788-2380

TWX: 710-862-1452

AREA SALES
MANAGEMENT OFFICES
EASTERN AREA
35. Marcus Boulevard

Hauppauge. NY 11788
(516) 273-3100

TWX: 510-227-8898
TELEX 221646
WESTERN AREA
Turk Enterprises 2172 Dupont Dr.
trvine, CA 92715
(714) $955-1575$

TWX: 910-595-2635
CENTRAL AREA
Microsystems Sales
16990 Dallas Pkwy
Suite 151
Dallas, TX 75248
(214) $931-5321$

TWX:910-860-9269

## WASHINGTON

SDR ${ }^{2}$ Products \& Sales Co.
14230 N.E. 8th Street
Bellevue, WA 98007
(206) 747-9424

WASHINGTON, D.C.
Robert Electronic Sales
6407 Frederick Avenue
Catonville, MD 21228
(301) 788-2380

TWX: 710-862-1452

## WEST VIRGINIA

Thompson \& Associates
7221 Taylorsville Rd.
Dayton, OH 45424
(513) 237-9422

## WISCONSIN

(East)
Metcom Associates Corp.
237 S. Curtis Rd.
W. Allis, WI 53214
(414) 476-1300
(West)
Quantum Sales
10800 Normandale Blvd.
Bloomington, MN 55437
(612) 884-4700

## WYOMING

SDR ${ }^{2}$ Products \& Sales Co.
14230 N.E. 8th Street
Bellevue, WA 98007
(206) 747-9424

PUERTO RICO
Mill-Bern Assoc., Inc.
G.P.O. Box 4543

San Juan, Puerto Rico 00936
(809) 792-1541

## INTERNATIONAL SALES REPRESENTATIVES AND DISTRIBUTORS

AUSTRALIA
A.J.F. Systems

9 Harker St.
Burwood, Victoria 3125
Australia
(03) 288-4044

TLX: AA 31261
BELGIUM
Auriema, S.A.
Rue Brogniezstraat 172-A
B-1070 Brussels, Belgium
32-2-523-6295
TLX: 84621646
CANADA (OTTAWA)
R.F.Q. Ltd

2249 Carling Ave
Suite 204
Ottowa, Ontario
Canada N2B 7E9
(613) 820-8445
(613) 820-8446

CANADA (TORONTO)
R.F.Q. Ltd.

385 The West Mall
Suite 209
Etobicoke, Ontario
Canada, M9C1E7
(416) 626-1445

TWX: (610) 492-2540

DENMARK
Tage Olsen A/S
Ballerup Byvej 222
275D Ballerup
Denmark
45-2-658111
TLX: 85535293
FINLAND
Havulinna
Instrumentarium OY
F.O. Box 357

Maktelankatu 84
00101 Helsinki 10 90-755-4144 TLX: 124426
FRANCE
Tekelec Airtronic
Cite Des Bruyeres
Rue Carle Vernet
B.P. \#2, 92310 Sevies

33-1-534-7535
TLX: 204552F
GREAT BRITAIN
Manhattan (Skyline) Ltd. Wier Bank
Bray-on-Thames Near Maidenhead Berks, United Kingdom SL62ED
44-628-34281
TLX: 851-847591

HOLLAND
Auriema Nederland BV
Doornakkersweg 26
5642MP Eindhoven Nederland
Tel. 31-40-816565
TLX: 84451992
HONG KONG
Protech
Wah Sing St.
Wah Sing Ind. Bldg.
18F, Flat 1
Kwai Chung, N.T. Kowloon
rel. 12-294721
TLX: 38396 PLTD HX
ISRAEL
Vectronics, Ltd.
69 Gordon Street
P.O. Box 16335 . Tel Aviv

23-4424 TLX: 32396
ITALY
Dott. Ing. Guiseppe
De Mico S.P.A.
Via Vittorio Veneto 8
20060 Cassina De Pecchi
Milano, Italy
02-95-20-551 TLX: 330869

JAPAN
Teijin Advanced Prod. Corp 1-1 Uchisaiwai-Cho
2 Chome, Chiyoda-Ku
Tokyo 100 Japan
506-4670-6 TLX: J23548
SOUTH KOREA
Kortronics Enterprise
Rm. 201-202, 18-Dong, C-Block
\#604-1, Guro-Dong, Guro-Gu
Seoul, Korea
634-5497 TLX: MICROS K28484

## NORWAY

National Elektro A/S:
Trade Division
Ulvenveien 75
P.O. Box 53, Oekern
N. Oslo, 5, Norway

02-644970 TLX: 71265

## SPAIN

Amitron S.A.
Loeches, 6
Madrid 8, Spain
34-1-2485863 TLX: 83145550
SWEDEN
NAXAB
Box 4115
17104 Solna, Sweden
08-98-51-40 TLX: 17912

SWITZERLAND
Datacomp AG
Zurchestr 20
$\mathrm{CH}-8952$ Schileren, Zurich
41-1-7302165 TLX: 854553533
TAIWAN
Multitech Int'I Corp.
977 Min Shen E. Road
Taipei 105 Taiwan R.O.C
02-769-1225 TLX: 23756
WEST GERMANY
Tekelec Airtronic Gmbh
Nussbaumstraße 4
8000 Munchen 2
89-59462t TLX: 05-22241

## DISTRIBUTORS

ARIZONA
Cetec Moltronics
3617 N. 35th Ave.
Phoenix, AZ 85017
(602) 272-7951

Kachina Electronic Dist.
1425 N. 27th Lane
Phoenix, AZ 85009
(602) 269-6201

Kachina Electronic Dist.
1810 W. Grant No. 108
Tucson, AZ 85705
(602) 792-2223

Diplomat/Westates Elec. 18401 North 25th Ave.
Phoenix, AZ 85023
(602) 866-7525

CALIFORNIA
Cetec Moltronics
5610 E. Imperial Hwy.
South Gate, CA 90280
(213) 773-6521
(714) 521•7412

Cetec Moltronics
721 Charcot Ave.
San Jose, CA 95121
(408) 263-7373

Cetec Moltronics
3940 Ruffin Rd.
San Diego, CA 92123
(714) 278-5020

Diplomat Electronics, Inc. 1283 F Mt. View-Alviso Rd Sunnyvale, CA 94086 (408) 734-1900

Diplomat/Westates Elec. 3001 Redhill Ave.
Bidg. 3-108
Costa Mesa, CA 92626
(714) 549-8401

Diplomat/Westates Elec. 20151 Bahama St.
Chatsworth, CA 91311
(213) 341-4411

Diplomat/Westates Elec.
9787 Aero Drive
San Diego, CA 92123
(714) 292-5693

NESCO
7110 Gerald Ave. Van Nuys, CA 91406 (800) 423-2664

Western Micro Sales 10040 Bubb Road
Cupertino, CA 95014 (408) 725-1660

## COLORADO

Bell Industries
Electronic Distributor Div.
8155 W. 48th Ave.
Wheatridge, CO 80033
(303) 424-1985

Diplomat Electronics, Inc. 96 Iverness Dr., East Unit R
Englewood, CO 80112
(303) 740-8300

CONNECTICUT
Diplomat Electronics, Inc. 52 Federal Road
Danbury, CT 06810
(203) 797-9674
J. V. Electronics, Inc.

690 Main Street
East Haven, CT 06512
(203) 469-2321

## FLORIDA

Diplomat Electronics, Inc.
2120 Calumet St.
Clearwater, FL 33515
(813) 443-4514

Diplomat Electronics, Inc.
115 Palm Bay Road
Bldg. 200-Suite 10
Palm Bay, FL 32905
(305) 725-4520

Diplomat Electronics, Inc. 6890 N.W. 20th Ave. Fort Lauderdale, FL 33309 (305) 971-7160

## GEORGIA

Diplomat Electronics, Inc. 6659 Peachtree Ind. Blvd. Suite B
Norcross, GA 30092
(404) 449-4133

ILLINOIS
Diplomat Electronics, Inc. 1071 Judson St.
Bensenville, IL 60106
(312) 595-1000

## Mar-Con

4836 Main Street
Skokie, IL 60076
(312) 675-6450

## MARYLAND

Whitney Distributors, Inc. 6707 Whitestone Road Baltimore, MD 21207 (301) 944-8080

Diplomat Electronics, Inc. 9150 Rumsey Rd., Suite A6 Columbia, MD 21045 (301) 995-1226

## MASSACHUSETTS

Diplomat Electronics, Inc.
559 East Street
Chicopee, MA 01020 (413) 592-9441

Diplomat Electronics, Inc. Kunlholm Drive
Holliston, MA 01746
(617) 429-4120

RC Components
10 Cornell Place
Wilmington, MA 01887
(617) 657-4310

## MICHIGAN

Diplomat Electronics, Inc. 32708 W. Eight Mile Road Farmington, MI 48024
(313) 477-3200

## MINNESOTA

Diplomat Electronics, Inc. 271 Commerce Circle South Fridley, MN 55432
(612) 572-0313

NEW JERSEY
Diplomat Electronics, Inc. 490 South Riverview Dr. Totowa, NJ 07512 (201) 785-1830

Falk-Baker Assoc.
382 Franklin Ave.
Nutley, NJ 07110
(201) 661-2430
(201) 661-2431

NEW MEXICO
Bell Industries
Century Electronic Div.
11728 Linn N.E.
Albuquerque, NM 87123
(505) 292-2700

NEW YORK
Diplomat Electronics
110 Marcus Dr.
Melville, NY 11747
(516) 454-6400

Diplomat Electronics
4610 Wetzel Road Liverpool, NY 13088 (315) 652-5000

Current Components
215 Marcus Blvd.
Hauppauge, NY 11788
(516) 273-2600

## OHIO

Target Electronic Corp.
6230 Cochran Rd.
Solon, OH 44139
(216) 248-7930

Applied Data Management
435 Dayton St.
Cincinnati, OH 45214
(513) 579-8108

OKLAHOMA
Quality Components
9934 E. 21st St.
Tulsa, OK 74129
(918) 664-8812

PENNSYLVANIA
QED Electronics, Inc.
300 North York Road
Hatboro, PA 19040
(215) 674-9600

## TEXAS

Quality Components, Inc. 4257 Kellway Circle P.O. Box 819

Addison, TX 75001
(214) 387-4949

Quality Components, Inc.
6126 Westline
Houston, TX 77036
(713) 772-7100

Quality Components, Inc.
2427 Rutland
Austin, TX 78758
(512) 835-0220

Diplomat Electronics, Inc.
10614 Rockley Road
Houston, TX 77099
(713) 530-1900

Diplomat Electronics, Inc.
4651 Westgrove Drive
Dallas, TX 75248
(214) 931-3404

UTAH
Bell Industries
Electronic Distributor Div.
3639 West 2150 South
Salt Lake City, UT 84120
(801) 972-6969

Diplomat Electronics, Inc.
3007 S.W. Temple
Salt Lake City, UT 84115
(801) 486-4134

## CANADA

Future Electronics Inc.
237 Hymus Blvd.
(Point Claire)
Montreal, Quebec
Canada H9R 5C7
(514) 694-7710

Future Electronics Inc.
4800 Dufferin Street
Downsview, Ontario, M3H5S8
(416) 663-5563

Future Electronics Inc. 3070 Kingsway
Vancouver, B.C. V5R 5J7
(604) 438-5545

Future Electronics Inc.

## STANDARD MICROSYSTEMS CORPORATION

35 Marcus Boulevard, Hauppauge, NY 11788


[^0]:    ${ }^{(3)}$ May be custom mask programmed

[^1]:    (1)For future release
    (3) May be custom mask programmed

[^2]:    (1) For future release
    (3) May be custom mask programmed
    (2) Also available as CRT 8002A,B,C-001 Katakana

    CRT 8002A,B,C-003 5X7 dot matrix
    (4) Also available as CRT $7004 \mathrm{~A}, \mathrm{~B}, \mathrm{C}-0035 \mathrm{X7}$
    dot matrix

[^3]:    WORD COUNTER PRESET TO TRANSMIT COMMAND WORD FIELD

[^4]:    *If pin 2 is taken to a logic 1 the COM 8018 will operate in a high accuracy mode. If pin 2 is connected to -12 V , GND, a valid logic zero, or left unconnected, the high accuracy feature is disabled, and the UART will operate in a 16 X clock mode. Pin 2 is not connected on the COM 1863.

[^5]:    **Not more than one output should be shorted at a time.

[^6]:    (3) May be custom mask programmed

[^7]:    Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor
    devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

[^8]:    1 - if the programmed scan line(s) for cursor and underline coincide, the cursor takes precedence; otherwise both are displayed.
    2-at programmed scan line(s) for underline
    3 - at cursor blink rate
    Note-cursor blink rate overrides character blink rate.

[^9]:    1- Assumes $\overline{\text { VSYNC }}$ input frequency of 60 Hz .
    2 - Valid only if the cursor is formatted to blink.
    3 - Valid only if the cursor is formatted for underline.
    4 - Valid for the parallel scan line mode only.

[^10]:    (1)For future release (3)May be custom mask programmed

[^11]:    'DR=F5 WRITE 3 TIMES MFM ONLY

[^12]:    *: These Values are doubled when CLK=1 MHz.

[^13]:    ${ }^{(3)}$ May be custom mask programmed

