# STARTECH

SEMICONDUCTOR, INC.



890 Saratoga Avenue San Jose, CA 95129 (408) 248-5300 DATA BOOK 1995

# STARTECH Component Data Catalog

Printed September 8, 1994

No part of this document may be copied or reproduced in any form or by means without the prior written consent of STARTECH Semiconductor Inc. The information in this document is subject to change without notice. STARTECH Semiconductor Inc. assumes no responsibility for any errors that may appear in this document and makes no commitment to update or to keep current the information contained in this document. STARTECH Semiconductor Inc. makes no warranty (express, statutory, implied, or by description) regarding the information set forth herein or regarding the freedom of the described device from patent infringement. STARTECH Semiconductor Inc. makes no warranty of merchantability or fitness for any purpose.

STARTECH Semiconductor Inc.'s products are not authorized for use as critical components in the life support devices or systems without the express written approval of the president of STARTECH Semiconductor Inc..

- Life support devices or systems are devices or systems which, (a) are intended for surgical implant
  into the body, or (b) support or sustain life, and whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user.
- A critical component is any component of a life support device or system whose failure to perform
  can be reasonably expected to cause the failure of the life support device or system, or to effect its
  safety or effectiveness.

286/386/486 is a trademark of Intel Corporation.

IBM PC/XT/AT, PS/2 is a trademark of International Business Machines Corporation.

WD is a trademark of Western Digital Corporation.

NS, INS, DS is a trademark of National Semiconductor Corporation.

VL is a trademark of VLSI Technologies Corporation.

CENTRONICS is a trademark of Centronics Data Computer Corporation.

XR is a trademark of Exar Corporation.

TL is trademark of Texas Instrument, Inc.

MC is a trademark of Motorola Semiconductor.

ICS is a trademark of Integrated Circuit Systems, Inc.

AV is a trademark of Avasem Corporation.

SSI is a trademark of Silicon Systems Inc.

MK is a trademark of MicroClock Inc.



#### To our valued customer:

Startech Semiconductor was founded in 1990, with the charter to design, manufacture and market high performance data communication peripheral products in both the commercial and industrial semiconductor markets. Since then, Startech continues to follow that charter and enjoys a rapid growth.

Startech's products are marketed and distributed through a world-class network of representatives and distributors.

At Startech, we are dedicated to keeping your designs competitive with leading edge solutions. All our products are low power, high performance, CMOS ICs. Our commitment to you is to provide you with high quality and reliable ICs.

Ram K. Reddy President

UMI ?

|                                              | FREQUENCY SYNTHESIZERS     |
|----------------------------------------------|----------------------------|
|                                              | LINE DRIVERS / RECEIVERS 2 |
| M. T. C. | UARTS                      |
| <u> </u>                                     | PERIPHERALS                |
|                                              | FUTURE PRODUCTS 5          |
|                                              | PRODUCTS PREVIEW           |
|                                              | APPLICATION NOTES 7        |
|                                              | QUALITY/RELIABILITY        |
|                                              | ORDERING INFORMATION 9     |
|                                              | PACKAGING INFORMATION 10   |

REPRESENTATIVES 11

# - Contents -

| FREQUENCY SYNT   |                       |       |
|------------------|-----------------------|-------|
|                  |                       |       |
| ST49C064         |                       | 1-9   |
|                  |                       |       |
|                  |                       |       |
| ST49C103         |                       | 1-25  |
|                  |                       |       |
| ST49C106         |                       | 1-35  |
| ST49C107         |                       | 1-41  |
|                  |                       |       |
| ST49C155         |                       | 1-61  |
| ST49C158         |                       | 1-71  |
| ST49C214         |                       | 1-79  |
| ST49C418         |                       | 1-91  |
|                  |                       |       |
| DIFFERENTIAL LIN | E DRIVERS             |       |
|                  |                       |       |
| ST34C87          |                       | 2-31  |
|                  |                       |       |
| DIFFERENTIAL LIN | E RECEIVERS           |       |
|                  |                       |       |
| ST34C86          |                       | 2-25  |
|                  |                       |       |
| DIFFERENTIAL LIN | E DRIVERS / RECEIVERS |       |
|                  |                       |       |
|                  |                       |       |
| ST31C32          |                       | 2-37  |
|                  |                       |       |
| UARTS            |                       |       |
|                  |                       |       |
|                  |                       |       |
|                  |                       |       |
|                  |                       |       |
|                  |                       |       |
| ST68C454         |                       | 3-79  |
|                  |                       |       |
| UARTS WITH FIFO  |                       | 0.400 |
|                  |                       |       |
|                  |                       |       |
|                  |                       |       |
|                  |                       |       |
|                  |                       |       |
|                  |                       |       |
|                  |                       |       |
|                  |                       |       |
| ST68C554         |                       | 3-213 |

| UARIS WITH PRINTER      |         |       |
|-------------------------|---------|-------|
| ST16C452AT              |         | 3-269 |
| ST16C452PS              |         | 3-269 |
| ST16C552                |         | 3-295 |
| ST16C553                |         | 3-323 |
|                         |         |       |
| PARALLEL I/O WITH FIFO  |         |       |
| ST78C34                 |         | 4-3   |
| ST78C36                 |         | 6-3   |
| IDE INTERFACE           |         |       |
|                         |         | 4-29  |
| ID INTEREACE            |         |       |
| IR INTERFACE<br>ST84C01 |         | 4-21  |
|                         |         |       |
| SUPER I/O               |         |       |
| ST56CXXX                | <u></u> | 6-15  |
| FLOPPY CONTROLLER       |         |       |
|                         |         | 4-37  |

ST34C86

**DIFFERENTIAL LINE DRIVERS** 

DS34C86/DS34LS86

National Semiconductor Startech Semiconductor DS26C31/DS26LS31 ST26C31

Startech Semiconductor AMD

AM26LS31 ST26C31

**DIFFERENTIAL LINE RECEIVERS** 

National Semiconductor Startech Semiconductor DS26C32/DS26LS32 ST26C32 ST34C87 DS34C87/DS34LS87

AMD Startech Semiconductor AM26LS32 ST26C32

**DIFFERENTIAL LINE RECEIVERS / DRIVERS** 

Motorola Semiconductor Startech Semiconductor MC34050 ST34C50

MC34051 ST34C51

National Semiconductor

**UARTS** 

Startech Semiconductor ST16C450 INS8250A INS82C50A ST16C450 NS16450 ST16C450 NS16C450 ST16C450 NS16550AF ST16C550 NS16C552 ST16C2552

Startech Semiconductor Silicon Systems SSI73M550 ST16C550 SSI73M1550 ST16C1450 / ST16C1550 SSI73M2550 ST16C1451 / ST16C1551

SSI73M2551 ST16C1552 Startech Semiconductor

VLSI Technology, Inc. VL82C50A ST16C450 VL16C450 ST16C450 VL16C550 ST16C550

Western Digital Inc. Startech Semiconductor WD16C450 ST16C450

WD16C550 ST16C550

**Texas Instruments** 

TL16C450 TL16C550A

**Exar Corporation** 

XR16C450 XR16C550

**UARTS WITH PRINTER** 

VLSI Technology, Inc.

VL16C452

VL16C552

Western Digital Inc.

WD16C452

WD16C552

**Texas Instruments** 

TL16C452 TL16C552

**Exar Corporation** 

XR16C452 XR16C552

**VIDEO DOT CLOCK GENERATOR** 

Integrated Circuit Systems, Inc.

ICS2494XXX ICS9064 ICS9154-XX ICS9158

Avasem Corporation

AV9064 AV9103-XX AV9104-XX AV9106 AV9107-XX AV9155-XX

STEREO CLOCK GENERATOR

MicroClock Inc.

MK1418

Startech Semiconductor

ST16C450 ST16C550

Startech Semiconductor

ST16C450 ST16C550

Startech Semiconductor

ST16C452

ST16C552 / ST16C553

Startech Semiconductor

ST16C452

ST16C552 / ST16C553

Startech Semiconductor

ST16C452 ST16C552

Startech Semiconductor

ST16C452 ST16C552

Startech Semiconductor

ST49C214-XX ST49C064 ST49C154-XX

ST49C158

Startech Semiconductor

ST49C064 ST49C103-XX ST49C104-XX ST49C106 ST49C107-XX

ST49C155-XX

Startech Semiconductor

ST49C418

#### **DIFFERENTIAL LINE DRIVERS**

Startech Semiconductor

ST26C31

National Semiconductor DS26C31/DS26LS31

AMD

AM26LS31

National Semiconductor DS34C86/DS34LS86

ST34C86

DIFFERENTIAL LINE RECEIVERS

Startech Semiconductor

ST26C32

National Semiconductor DS26C32/DS26LS32

AMD

AM26LS32

National Semiconductor

Motorola Semiconductor

DS34C87/DS34LS87

ST34C87

**DIFFERENTIAL LINE RECEIVERS / DRIVERS** 

Startech Semiconductor

ST34C50 ST34C51 MC34050

MC34051

**UARTS** 

Startech Semiconductor

ST16C450

National Semiconductor

INS8250A

INS82C50A

NS16450

NS16C450

VLSI Technology, Inc.

VL82C50A

VL16C450

Western Digital Inc.

WD16C450

**Texas Instruments** 

TL16C450

**Exar Corporation** 

XR16C450

Startech Semiconductor

**National Semiconductor** NS16550AF

Silicon Systems SSI73M550

VLSI Technology, Inc. VL16C550

Western Digital Inc. WD16C550

**Texas Instruments** TL16C550A

**Exar Corporation** XR16C550

Silicon Systems SSI73M1550

SSI73M2550

SSI73M2551

National Semiconductor

NS16C552

VLSI Technology, Inc. VL16C452

**Exar Corporation** XR16C452

Western Digital Inc. WD16C452

**Texas Instruments** TL16C452

ST16C550

ST16C1450 ST16C1550

ST16C1451 ST16C1551

ST16C2552

ST16C2552

**UARTS WITH PRINTER** Startech Semiconductor ST16C452AT

ST16C452AT/PS

ST16C452AT/PS

ST16C552/553

VLSI Technology, Inc.

VL16C552

Exar Corporation XR16C552

Western Digital Inc.

WD16C552

Texas Instruments

TL16C552

**VIDEO DOT CLOCK GENERATOR** 

Startech Semiconductor

ST49C064

Avasem Corporation

AV9064

Integrated Circuit Systems, Inc.

ICS9064

Startech Semiconductor

ST49C103-XX ST49C104-XX

ST49C106

ST49C107-XX

ST49C155-XX

**Avasem Corporation** 

AV9103-XX

AV9104-XX

AV9106 AV9107-XX

AV9155-XX

ST49C154-XX

ST49C158

Integrated Circuit Systems, Inc.

ICS9154-XX

ICS9158

Startech Semiconductor

ST49C214-XX

Integrated Circuit Systems, Inc.

ICS2494XXX

STEREO CLOCK GENERATOR

Starech Semiconductor

ST49C418

MicroClock Inc.

MK1418

# Index

| ST49C001 | 1-3  |
|----------|------|
| ST49C064 | 1-9  |
| ST49C101 |      |
| ST49C102 | 1-17 |
| ST49C103 | 1-25 |
| ST49C104 | 1-25 |
| ST49C106 | 1-35 |
| ST49C107 | 1-41 |
| ST49C154 | 1-49 |
| ST49C155 | 1-61 |
| ST49C158 | 1-71 |
| ST49C214 | 1-79 |
| ST49C418 |      |



#### ST49C001

Printed September 2, 1994

#### PREPROGRAMMED HIGH SPEED FREQUENCY SYNTHESIZER

#### **DESCRIPTION**

The ST49C001 is a mask programmable monolithic analog CMOS device, designed to replace existing high frequency crystal/oscillator with single low frequency crystal. The ST49C001 provides high speed and low jitter clock output.

ST49C001 is designed for Magneto-Optical Disk Drive (MODD) appplication.

#### **SOIC Package**

| vcc 1   | 88      | 8 CLOCK |
|---------|---------|---------|
| OE* 2   | 201CF   | 7 CLOCK |
| XTAL1 3 | .49C(   | 6 BCLK  |
| XTAL2 4 | rs<br>S | 5 GND   |

#### **FEATURES**

- Can replace expensive high frequency oscillator.
- Programmable analog phase locked loop
- On board loop filter
- Low power single 3-5V 1.2μ CMOS technology
- 8 pin SOIC package.
- · Crystal oscillator circuit on board

#### Dip Package

| VCC 1   | CP8 ( | 8 CLOCK |
|---------|-------|---------|
| OE* 2   | 301Ci | 7 CLOCK |
| XTAL1 3 | 49C0  | 6 BCLK  |
| XTAL2 4 | ST    | 5 GND   |

#### ORDERING INFORMATION

# ST49C001

#### **BLOCK DIAGRAM**



#### SYMBOL DESCRIPTION

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                                                                    |
|--------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| vcc    | 1   | i           | Analog supply voltage. Single +3 /+5 volts.                                                                                                                                                                                        |
| OE*    | 2*  | I           | Output Enable (Active low). CLOCK1 and BCLK outputs are disabled and forced to low state when this pin is low. CLOCK2 output pin is active when CLOCK1 and BCLK outputs are disabled.                                              |
| XTAL1  | 3   | 1           | Crystal or External Clock input. A crystal can be connected to this pin and XTAL2 pin to generate internal phase locked loop reference clock. For external 16.9344 MHz clock, XTAL2 is left open or used as buffered clock output. |
| XTAL2  | 4   | o           | Crystal output.                                                                                                                                                                                                                    |
| GND    | 5   | 0           | Digital ground.                                                                                                                                                                                                                    |
| BCLK   | 6   | 0           | Buffered reference clock output.                                                                                                                                                                                                   |
| CLOCK1 | 7   | 0           | Preprogrammed 50 MHz clock output.                                                                                                                                                                                                 |
| CLOCK2 | 8   | 0           | Preprogrammed 30 MHz clock output.                                                                                                                                                                                                 |

<sup>\*</sup> Has internal pull-up resistor

#### **EXTERNAL CLOCK CONNECTION**

To minimize the noise pickup , it is recommended to connect  $0.047\mu F$  capacitor to XTAL1, and keep the lead length of the capacitor to XTAL1 to a minimum to reduce noise susceptibility.

#### FREQUENCY SELECT CALCULATION

The ST49C001 contains an analog phase locked loop circuit with digital closed loop dividers and a final output divider to achieve the desired dividing ratios for the clock output.

The accuracy of the frequencies produced by the ST49C001 depends on the input frequency and divider ratios. The formula for calculating the exact output frequency is as follows:

CLOCK1 = (Reference clock) X 2A/B X 1/M CLOCK2 = (Reference clock) X 2A/B X 1/N

where A=5, 6, 7,......128 B=5, 6, 7,......128 M=1, 2,...6 N=1, 2, ...6

| Ref.<br>Frequency | Output<br>Frequencies |
|-------------------|-----------------------|
| 16.934 MHz        | 49.143 MHz            |
|                   | 29.486 MHz            |

## ST49C001

#### **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

#### DC ELECTRICAL CHARACTERISTICS

 $T_{\star}$ =0-70° C, Vcc=3.0 - 5.0 V ± 10% unless otherwise specified.

| Symbol                             | Parameter                | Min | Limits<br>Typ | Max  | Units | Conditions                 |
|------------------------------------|--------------------------|-----|---------------|------|-------|----------------------------|
|                                    | 5.0 Volts operation      |     |               |      |       |                            |
| V <sub>IL</sub>                    | Input low level          |     |               | 0.8  | V     |                            |
| V <sub>II</sub>                    | Input high level         | 2.0 |               |      | V     |                            |
| · V <sub>OL</sub>                  | Output low level         |     |               | 0.4  | V     | I <sub>OL</sub> = 8.0 mA   |
| V <sub>OH</sub>                    | Output high level        | 2.4 |               |      | V     | I <sub>OH</sub> = 8.0 mA   |
| l <sub>IL</sub>                    | Input low current        |     |               | -100 | μΑ    | Pin 2 only                 |
| ļн                                 | Input high current       | 1   |               | 1    | μΑ    | V <sub>IN</sub> =Vcc Pin 2 |
| I <sub>cc</sub>                    | Operating current        |     | 20            | 30   | mA .  | No load.                   |
|                                    |                          |     |               |      |       | CLOCK=50MHz                |
|                                    | 3.0 Volts operation      |     | ·             |      |       | ,                          |
| V <sub>IL</sub>                    | Input low level          |     |               | 0.6  | V     |                            |
| V                                  | Input high level         | 2.0 |               | "."  | v     |                            |
| V <sub>IH</sub><br>V <sub>OL</sub> | Output low level         |     | ŧ             | 0.4  | V     | I <sub>OL</sub> = 2.0 mA   |
| V <sub>OH</sub>                    | Output high level        | 2.4 |               | -    | V     | I <sub>OH</sub> = 2.0 mA   |
| I <sub>IL</sub>                    | Input low current        |     |               | -100 | μА    | Pin 2 only                 |
| I <sub>IH</sub>                    | Input high current       |     | >             | 1    | μΑ    | V <sub>IN</sub> =Vcc Pin 2 |
| I <sub>cc</sub>                    | Operating current        |     | 15            | 20   | mA    | No load.                   |
|                                    | ^ ·                      |     |               |      |       | CLOCK=50MHz                |
| R <sub>in</sub>                    | Input pull-up resistance | 45  | 55            | 70   | kΩ    |                            |

#### **AC ELECTRICAL CHARACTERISTICS**

 $T_A$ =0-70° C, Vcc=3.0 - 5.0 V ± 10% unless otherwise specified.

| Symbol                                               | Parameter                         | Min | Limits<br>Typ | Max        | Units          | Conditions              |
|------------------------------------------------------|-----------------------------------|-----|---------------|------------|----------------|-------------------------|
| <b>T</b> ,                                           | CLOCK rise time                   |     | 1             | 1.5        | ns             | Load=50Ω 0.4V -<br>2.4V |
| 1 <b>T</b> 2                                         | CLOCK fall time                   |     | 1             | 1.5        | ns             | Load=50Ω 2.4V -         |
| T <sub>4,5</sub>                                     | Duty cycle<br>Jitter, absolute    | 45  | 48/52<br>±175 | 55<br>±300 | %              | @ 1.4 Volts             |
| T <sub>4,5</sub><br>T <sub>3</sub><br>T <sub>3</sub> | Jitter, one sigma Input frequency | 12  | 0.5<br>16.9   | 1 20       | ps<br>%<br>MHz |                         |
| T <sub>6</sub>                                       | CLOCK frequency change            |     | 0.008         |            | %              |                         |

# ST49C001

#### TIMING DIAGRAM





#### ST49C064

Printed September 2, 1994

#### PREPROGRAMMED DUAL VIDEO/MEMORY FREQUENCY GENERATOR

#### GENERAL DESCRIPTION

The ST49C064 is a monolithic analog CMOS device designed to generate dual frequency outputs from fifteen possible combinations for video Dot clock frequencies and eight memory clock frequencies for high performance video display systems. The ST49C064 is a mask option programmable device to provide different output frequencies for custom applications. It is designed with  $1.2\mu$  process to achieve 130 MHz speed for high end frequencies.

The ST49C064 is designed to replace existing video clocks generated from individual oscillators, to reduce board space and number of oscillators. To provide high speed and low jitter clock, The ST49C064 utilizes high speed analog CMOS phase locked loop using 14.318 MHz system clock as reference clock (reference clock can be changed to generate optional frequencies from standard programmed device).

The ST49C064 can provide optional clock frequencies, utilizing single layer metal mask option. The programmed clock outputs are selectable via four address lines and address latch enable pin for video Dot clock selection and three address lines for memory clock selection.

#### **FEATURES**

- · Can replace multiple oscillators/crystals
- Pin -to-pin compatible to ICS90C64
- Programmable analog phase locked loop
- High speed (up to 130 MHz output)
- Low power single 5V CMOS technology
- 20 pin dip / SOIC / PLCC packages
- Compatible with Western Digital Imaging Video Graphics Array clock requirements.

#### ORDERING INFORMATION

| Part number     | Package     | Oper | atin | g te | mperati | ure |
|-----------------|-------------|------|------|------|---------|-----|
| ST49C064CP20-xx | Plastic-DIP | 0°   | С    | to   | +70°    | С   |
| ST49C064CF20-xx | SOIC        | 0°   | С    | to   | +70°    | С   |
| ST49C064CJ20-xx | PLCC        | 0°   | С    | to   | +70°    | С   |

#### **SOIC Package**



#### **PLCC Package**



#### **BLOCK DIAGRAM**



#### **SYMBOL DESCRIPTION**

| Symbol | Pin | Signal Type | Pin Description                                                                     |
|--------|-----|-------------|-------------------------------------------------------------------------------------|
| CLK    | 1   | I           | External 14.318 MHz system reference clock input.                                   |
| MA2    | 2*  | 1           | Memory clock Frequency select address 3.                                            |
| EXCLK  | 3*  | 1           | External clock input. For additional clock frequency.                               |
| A1     | 4*  | ı           | Dot clock Frequency select address 2.                                               |
| A0     | 5*  | ı           | Dot clock Frequency select address 1.                                               |
| LEN*   | 6*  | I           | Address latch enable input (active low). To latch selected programmed clock output. |
| A2     | 7*  | 1           | Dot clock Frequency select address 3.                                               |
| A3     | 8*  | I .         | Dot clock Frequency select address 4.                                               |
| ма0    | 9*  | , I         | Memory clock Frequency select address 1.                                            |
| DGND   | 10  | 0           | Digital ground.                                                                     |
| MA1    | 11* | I           | Memory clock Frequency select address 2.                                            |
| MCLK   | 12  | 0           | Programmed memory clock output frequency.                                           |
| N.C.   | 13  |             | No connect.                                                                         |
| MCLKE  | 14* | 1           | MCLK output enable.                                                                 |
| AVCC   | 15  | I           | Analog supply voltage. Single +5 volts.                                             |
| AGND   | 16  | 0           | Analog ground.                                                                      |
| N.C.   | 17  | ·           | No connect.                                                                         |
| DCLKE  | 18* | 1           | DCLK output enable.                                                                 |
| DCLK   | 19  | 0           | Programmed video clock output frequency.                                            |
| DVCC   | 20  | . 1         | Digital supply voltage. Single +5 volts.                                            |

<sup>\*</sup> Have internal pull-up resistors on inputs

#### **GENERAL INFORMATION**

The ST49C064 is programmed to generate 15 different video clock frequencies using the A0-A3 inputs and 8 different memory frequencies using M0-M2 inputs. The address lines A2-A3 can be connected to video controller like Western Digital Imaging VGA controllers. Address lines A0 and A1 are latched with LEN\* pin which is generated from video controllers to select proper Dot clock output. All inputs to the ST49C064 contain internal pull-up resistors including CLK and EXCLK inputs.

The EXCLK is additional input that may be internally connected to the DCLK output. The additional input is useful for supporting modes that require frequencies not provided by the ST49C064.

#### FREQUENCY SELECT CALCULATION

The ST49C064 contains an analog phase locked loop circuit with a digital closed loop divider and a final series divider to achieve desired dividing ratios for clock output.

The accuracy of the frequencies produced by the ST49C064 depends on the input frequency and final output frequency. The formula for calculating the exact output frequency is as follows:

DCLK = (Reference clock) X (A/B.C) MCLK = (Reference clock) X (A/B.C)

where A=1,2,3,......127, B=1,2,3,.....127, and C=1,2,4

For proper output frequency, the ST49C064 can accept reference frequency from 5 - 40 MHz and divider ratio up to 15.

#### MASK OPTIONS

The following mask options are provided for custom applications.

- \* Any frequency can be in any decoding position.
- \* DCLK, can control selection of the internal frequencies.

#### **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

#### DC ELECTRICAL CHARACTERISTICS

 $T_A = 0^{\circ} - 70^{\circ} C$ , Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                          | Parameter                                                                                                                  | Min | Limits<br>Typ | Max                           | Units                            | Conditions                                                                                              |
|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-----|---------------|-------------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------|
| V <sub>IL</sub> V <sub>IH</sub> V <sub>OL</sub> V <sub>OH</sub> I <sub>IL</sub> I <sub>IH</sub> I <sub>CC</sub> | Input low level Input high level Output low level Output high level Input low current Input high current Operating current | 2.0 | 20            | 0.8<br>0.4<br>-350<br>1<br>30 | V<br>V<br>V<br>A<br>A<br>A<br>mA | I <sub>oL</sub> = 8.0 mA<br>I <sub>OH</sub> = 8.0 mA<br>V <sub>IN</sub> =Vcc<br>No load.<br>DCLK=80MHz, |
| R <sub>in</sub>                                                                                                 | Internal pull-up resistance                                                                                                | 15  | 20            | 25                            | kΩ                               | MCLK=40MHz                                                                                              |

# ST49C064

#### **AC ELECTRICAL CHARACTERISTICS**

 $T_{A}$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                   | Parameter                                                                                                                                                                                                  | Min                                  | Limits<br>Typ                    | Max                                              | Units                                                        | Conditions                                                            |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------|--------------------------------------------------|--------------------------------------------------------------|-----------------------------------------------------------------------|
| T, T | Enable pulse width Setup time data to enable Hold time to data enable Rise time Fall time Duty cycle Duty cycle Jitter Input frequency Input clock rise time Input clock fall time Output frequency change | 20<br>20<br>10<br>40<br>45<br>14.318 | 1<br>1<br>48/52<br>48/52<br>±175 | 1.5<br>1.5<br>60<br>55<br>±300<br>32<br>20<br>20 | ns<br>ns<br>ns<br>ns<br>s<br>s<br>%<br>ps<br>MHz<br>ns<br>ns | 0.8V - 2.0V<br>2.0V - 0.8V<br>1.4V switch point<br>Vcc/2 switch point |

1





| \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \                                        | ST49C064-903                                                                                                                                      | ST49C064                                                                                                                                          | ST49C064-907                                                                                                                                                |  |
|------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Video<br>clock<br>address<br>(Hex)                                           | Frequency<br>(MHz)                                                                                                                                | Frequency<br>(MHz)                                                                                                                                | Frequency<br>(MHz)                                                                                                                                          |  |
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>A<br>B<br>C<br>D<br>E<br>F | 30.000<br>77.250<br>EXCLK<br>80.000<br>31.500<br>36.000<br>75.000<br>50.000<br>40.000<br>50.000<br>44.900<br>25.175<br>28.322<br>65.000<br>36.000 | 30.000<br>77.250<br>EXCLK<br>80.000<br>31.500<br>36.000<br>75.000<br>50.000<br>40.000<br>50.000<br>44.900<br>25.175<br>28.322<br>65.000<br>36.000 | 30.250<br>77.250<br>EXCLK<br>80.000<br>31.500<br>35.500<br>75.000<br>72.000<br>40.000<br>50.000<br>32.000<br>44.900<br>25.175<br>28.322<br>65.000<br>36.000 |  |
| Memory<br>clock<br>address<br>(Hex)                                          | Frequency<br>(MHz)                                                                                                                                | Frequency<br>(MHz)                                                                                                                                | Frequency<br>(MHz)                                                                                                                                          |  |
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7                                         | 33.000<br>49.218<br>60.000<br>30.500<br>41.612<br>37.500<br>36.000<br>44.296                                                                      | 41.612<br>37.500<br>49.128<br>44.296                                                                                                              | 65.000<br>49.218<br>60.000<br>62.500<br>41.612<br>37.500<br>55.000<br>44.296                                                                                |  |

Compatible with ICS9064-903 Video Controller WD90C30

AV9064 WD90C30 ICS9064-907 WD90C33

#### .



### ST49C101/102

Printed September 2, 1994

#### PREPROGRAMMED HIGH SPEED FREQUENCY MULTIPLIER

#### DESCRIPTION

The ST49C101/102 is a mask programmable monolithic analog CMOS device, designed to replace existing high frequency crystal/oscillator with single low frequency crystal. The ST49C101/102 provides high speed and low jitter clock output.

ST49C101/102 is designed in a  $1.2\mu$  process to achieve 160 MHz speed for high end frequencies.

#### **SOIC Package**

XTAL1 1 8 8 XTAL2

OE 2 5 7 AVCC

AGND 3 6 DVCC

DGND 4 5 CLOCK

#### Dip Package

| XTAL1 1 |             | 8 XTAL2 |
|---------|-------------|---------|
| OE 2    | иср8        | 7 AVCC  |
| AGND 3  | ST49C101CP8 | 6 DVCC  |
| DGND 4  | ST          | 5 CLOCK |

#### **FEATURES**

- Can replace expensive high frequency oscillator.
- Programmable analog phase locked loop
- Low power single 5V CMOS technology
- 8 pin DIP or SOIC package.
- · Crystal oscillator circuit on board

#### ORDERING INFORMATION

 Part number
 Package
 Operating temperature

 ST49C101CP8
 Plastic-DIP
 0 ° C to +70° C

 ST49C101CF8
 SOIC
 0° C to +70° C

 ST49C102CT8
 TSSOP
 0° C to +70° C

#### **TSSOP Package**



# ST49C101/102

#### **BLOCK DIAGRAM**



#### SYMBOL DESCRIPTION (ST49C101)

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                                                                  |
|--------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XTAL1  | 1   | I           | Crystal or External Clock input. A crystal can be connected to this pin and XTAL2 pin to generate internal phase locked loop reference clock. For external 10.00 MHz clock, XTAL2 is left open or used as buffered clock output. |
| OE     | 2*  | 1 '         | Clock Output Enable (Active high). CLOCK output is three stated when this pin is low.                                                                                                                                            |
| AGND   | 3   | 0           | Analog ground.                                                                                                                                                                                                                   |
| DGND   | 4   | 0           | Digital ground.                                                                                                                                                                                                                  |
| CLOCK  | 5   | 0           | Programmed output clock.                                                                                                                                                                                                         |
| DVCC   | 6   | 1           | Positive supply voltage. Single +5 volts.                                                                                                                                                                                        |
| AVCC   | 7   | ı           | Analog supply voltage. Single +5 volts.                                                                                                                                                                                          |
| XTAL2  | 8   | 0           | Crystal output.                                                                                                                                                                                                                  |

<sup>\*</sup> Has internal pull-up resistor

#### SYMBOL DESCRIPTION (ST49C102)

| Symbol | Pin | Signal Type | Pin Description                                   |
|--------|-----|-------------|---------------------------------------------------|
| DVCC   | 1   | I           | Digital Positive supply voltage. Single +5 volts. |
| сьоск  | 2   | 0           | Pre-programmed output clock.                      |
| EXCLK  | 3   | 1           | External Clock input. Input reference clock.      |
| DGND   | 5   | 0           | Digital ground.                                   |
| AVCC   | 8   | I           | Analog supply voltage. Single +5 volts.           |

#### ST49C101/102

#### **EXTERNAL CLOCK CONNECTION**

To minimize the noise pickup, it is recommended to connect 0.047µF capacitor to XTAL1, and keep the lead length of the capacitor to XTAL1 to a minimum to reduce noise susceptibility.

#### FREQUENCY SELECT CALCULATION

The ST49C101/102 contains an analog phase locked loop circuit with digital closed loop dividers and a final output divider to achieve the desired dividing ratios for the clock output.

The accuracy of the frequencies produced by the ST49C101/102 depends on the input frequency and divider ratios. The formula for calculating the exact output frequency is as follows:

CLOCK = (Reference clock) X 2A/(BXC)

where

A=5, 6, 7,.....128 B=5, 6, 7,.....128 C=1.2.4

For proper output frequency, the ST49C101/102 can accept a reference frequency from 7 - 20 MHz and divider ratio up to 15.

#### Preprogrammed options:

| ST49C101-X  | Factor | Max. Output<br>Frequency |  |  |
|-------------|--------|--------------------------|--|--|
| ST49C101-01 | 12     | 100 MHz                  |  |  |
| ST49C101-02 | 6      | 100 MHz                  |  |  |
| ST49C101-03 | 8      | 160 MHz                  |  |  |
| ST49C101-04 | 4      | 100 MHz                  |  |  |

| ST49C102 | Input<br>Frequency | Output<br>Frequency |
|----------|--------------------|---------------------|
| ST49C102 | 40MHz              | 60MHz               |

#### **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

#### DC ELECTRICAL CHARACTERISTICS

 $T_A=0 - 70^{\circ}$  C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                   | Parameter                              | Min | Limits<br>Typ | Max  | Units                    | Conditions                          |
|--------------------------------------------------------------------------|----------------------------------------|-----|---------------|------|--------------------------|-------------------------------------|
| V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>OL</sub><br>V <sub>OH</sub> | Input low level<br>Input high level    | 2.0 |               | 0.8  | V<br>V                   | ·                                   |
| V <sub>IH</sub>                                                          | Output low level                       | 2.0 |               | 0.5  | V                        | I <sub>oL</sub> = 8.0 mA            |
|                                                                          | Output high level<br>Input low current | 2.8 |               | -100 | V ,                      | I <sub>OH</sub> = 8.0 mA Pin 2 only |
| ו <sub>ונ</sub><br>ו <sub>וн</sub>                                       | Input high current                     |     |               | 1    | μ <b>Α</b><br>μ <b>Α</b> | V <sub>IN</sub> =Vcc Pin 2          |
| I <sub>cc</sub>                                                          | Operating current                      |     | 60            | 80   | mA                       | No load.<br>CLOCK=100MHz            |
| R <sub>IN</sub>                                                          | Input pull-up resistance               | 50  | 75            | 100  | KΩ                       |                                     |

#### **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                       | Parameter                 | Min | Limits<br>Typ | Max  | Units | Conditions              |
|--------------------------------------------------------------|---------------------------|-----|---------------|------|-------|-------------------------|
| , T <sub>1</sub>                                             | CLOCK rise time           |     | 1.5           | 2    | ns    | Load=50Ω 0.5V -<br>2.8V |
| $T_2$                                                        | CLOCK fall time           |     | 1.5           | 2    | ns    | Load=50Ω 2.8V -<br>0.5V |
| T,                                                           | Duty cycle                | 40  | 48/52         | 60   | %     | 1.4V switch point       |
| T <sub>4</sub> T <sub>5</sub> T <sub>3</sub> T <sub>IN</sub> | Duty cycle                | 45  | 48/52         | 55   | . %   | VCC/2 switch point      |
| $T_{\scriptscriptstyle 3}^{\scriptscriptstyle v}$            | Jitter                    |     | ±175          | ±300 | ps    |                         |
| T <sub>IN</sub>                                              | Input reference frequency | 7   | 10            | 20   | MHz   |                         |
| Tout                                                         | Output frequency          |     |               | 160  | MHz   |                         |
| T <sub>6</sub>                                               | CLOCK frequency change    |     | 0.01          |      | %     |                         |

# ST49C101/102

## DC ELECTRICAL CHARACTERISTICS (ST49C101-02 and -04 ONLY)

 $T_{\Delta}$ =0 - 70° C, Vcc=3.0V ± 10% unless otherwise specified.

| Symbol                                                                                                                            | Parameter                                                                                                                                           | Limit<br>Min Typ |          |                               | Units                         | Conditions                                                                                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------|-------------------------------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| V <sub>IL</sub><br>V <sub>OL</sub><br>V <sub>OH</sub><br>I <sub>IL</sub><br>I <sub>IH</sub><br>I <sub>CC</sub><br>R <sub>IN</sub> | Input low level Input high level Output low level Output high level Input low current Input high current Operating current Input pull-up resistance | 2.0<br>2.0<br>50 | 40<br>75 | 0.8<br>0.5<br>-100<br>1<br>60 | V<br>V<br>V<br>μΑ<br>μΑ<br>mA | I <sub>OL</sub> = 4.0 mA<br>I <sub>OH</sub> = 4.0 mA<br>Pin 2 only<br>V <sub>IN</sub> =Vcc Pin 2<br>No load.<br>CLOCK=80 MHz |

## AC ELECTRICAL CHARACTERISTICS (ST49C101-02 and -04 ONLY)

 $T_A=0 - 70^{\circ}$  C, Vcc=3.0V ± 10% unless otherwise specified.

| Symbol                                                         | Parameter                 | Min | Limits<br>Typ | Max  | Units | Conditions              |
|----------------------------------------------------------------|---------------------------|-----|---------------|------|-------|-------------------------|
| Т,                                                             | CLOCK rise time           |     | 1.5           | 2    | ns    | Load=50Ω 0.5V -<br>2.0V |
| T <sub>2</sub>                                                 | CLOCK fall time           |     | 1.5           | 2    | ns    | Load=50Ω 2.0V -<br>0.5V |
| T <sub>5</sub> T <sub>3</sub> T <sub>IN</sub> T <sub>OUT</sub> | Duty cycle                | 45  | 48/52         | 55   | %     | VCC/2 switch point      |
| T <sub>3</sub>                                                 | Jitter                    |     | ±175          | ±300 | ps    |                         |
| T <sub>IN</sub>                                                | Input reference frequency | 7.  | 10            | 20   | MHz   |                         |
| T <sub>OUT</sub>                                               | Output frequency          | 1   |               | 80   | MHz   |                         |
| T <sub>6</sub>                                                 | CLOCK frequency change    |     | 0.01          |      | %     |                         |

## **TIMING DIAGRAM**





# ST49C103 ST49C104

Printed September 2, 1994

### PREPROGRAMMED FREQUENCY GENERATOR

#### DESCRIPTION

The ST49C103 and ST49C104 are mask programmable monolithic analog CMOS devices designed to generate up to 8 single frequency outputs from a single input clock. The ST49C104 will provide eight different output frequencies and the ST49C103 will provide four different output frequencies. They are designed in a  $1.2\mu$  process to achieve 130 MHz speed for high end frequencies.

The ST49C103 and ST49C104 are designed to replace existing video clocks generated from individual oscillators in order to reduce board space and number of oscillators. To provide high speed and low jitter clock, the parts utilize a high speed analog CMOS phase locked loop using 14.318 MHz system clock as the reference clock (note that reference clock can be changed to generate optional frequencies from a standard programmed device). The programmed clock outputs are selectable via three address lines and address latch enable pin. The ST49C104 also includes a power on reset circuit which will cause the select logic to select the frequency at address "000" upon power up. The latch enable pin is also mask programmable to be active high, active low or rising or falling edge sensitive.

#### **FEATURES**

- Can replace up to 8 oscillators/crystals and a multiplexer
- Pin-to-pin compatible to Avasem AV9103/104
- Programmable analog phase locked loop
- Low power single 5V CMOS technology
- 8 or 14 pin DIP or SOIC package.

#### ORDERING INFORMATION

| Package     | Operating temperature                                     |
|-------------|-----------------------------------------------------------|
| Plastic-DIP | 0° C to +70° C                                            |
| SOIC        | . 0° C to +70° C                                          |
| Plastic-DIP | 0° C to +70° C                                            |
| SOIC        | 0° C to +70° C                                            |
| Plastic-DIP | 0 ° C to +70° C                                           |
| SOIC        | 0° C to +70° C                                            |
|             | Plastic-DIP<br>SOIC<br>Plastic-DIP<br>SOIC<br>Plastic-DIP |

## **SOIC Package**

| A1 1    |              | .14 A0  |
|---------|--------------|---------|
| A2 2    | 4            | 13 N.C. |
| LEN 3   | ST49C104CF14 | 12 AVCC |
| AGND 4  | 104          | 11 DVCC |
| DGND 5  | 49C          | 10 сько |
| XTAL1 6 | ST           | 9 CLK2  |
| XTAL2 7 |              | 8 CLK1  |





# ST49C103/104

## **BLOCK DIAGRAM**



## **SYMBOL DESCRIPTION** (ST49C104 14 pin package)

| Symbol | Pin  | Signal Type | Pin Description                                                                                                                                                                                                                   |
|--------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A1     | . 1  | · 1         | Frequency select address input 2.                                                                                                                                                                                                 |
| A2     | 2*   | 1           | Frequency select address input 3.                                                                                                                                                                                                 |
| LEN    | 3*   | 1           | Address latch enable input. To latch selected programmed clock output.                                                                                                                                                            |
| AGND   | 4    | 0           | Analog ground.                                                                                                                                                                                                                    |
| DGND   | 5    | 0           | Digital ground.                                                                                                                                                                                                                   |
| XTAL1  | 6    | I           | Crystal or external clock input. A crystal can be connected to this pin and XTAL2 pin to generate internal phase locked loop reference clock. For external 14.318 MHz clock, XTAL2 is left open or used as buffered clock output. |
| XTAL2  | 7    | 0           | Crystal output.                                                                                                                                                                                                                   |
| CLK1   | 8    | I           | External clock 1 input.                                                                                                                                                                                                           |
| CLK2   | 9    | 1           | External clock 2 input / output select.                                                                                                                                                                                           |
| CLKO   | 10   | 0           | Programmed output clock.                                                                                                                                                                                                          |
| DVCC   | 11   | 1           | Digital supply voltage. Single +5 volts.                                                                                                                                                                                          |
| AVCC   | . 12 | 1 .         | Analog supply voltage. Single +5 volts.                                                                                                                                                                                           |
| N.C.   | 13   |             |                                                                                                                                                                                                                                   |
| A0     | 14   | I           | Frequency select address input 1.                                                                                                                                                                                                 |

<sup>\*</sup> Have internal pull-up resistors on inputs.

# ST49C103/104

## **SYMBOL DESCRIPTION** (ST49C104 8 pin package)

| Symbol | Pin | Signal Type | Pin Description                                                    |
|--------|-----|-------------|--------------------------------------------------------------------|
| A1     | 1   |             | Frequency select address input 2.                                  |
| A2     | 2*  | . 1         | Frequency select address input 3.                                  |
| GND    | 3   | 0           | Digital ground.                                                    |
| EXCLK  | 4   | l           | External clock input. Internal phase locked loop reference clock . |
| CLKO   | 5   | 0           | Programmed output clock.                                           |
| vcc    | 6   | I           | Digital supply voltage. Single +5 volts.                           |
| N.C.   | 7 - |             |                                                                    |
| A0     | 8   | Γ.          | Frequency select address input 1.                                  |

<sup>\*</sup> Has internal pull-up resistor on input

## SYMBOL DESCRIPTION (ST49C103 8pin package)

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                                                                  |  |  |  |  |
|--------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| A1     | 1   | 1.1         | Frequency select address input 2.                                                                                                                                                                                                |  |  |  |  |
| GND    | 2   | 0           | Digital ground.                                                                                                                                                                                                                  |  |  |  |  |
| XTAL1  | 3   | 1.          | Crystal or external clock input. A crystal can be connected to this pin and XTAL2 pin to generate internal phase locked loop reference clock. For external 14.318 MHz clock XTAL2 is left open or used as buffered clock output. |  |  |  |  |
| XTAL2  | 4   | 0           | Crystal output.                                                                                                                                                                                                                  |  |  |  |  |
| CLKO   | 5   | 0           | Programmed output clock.                                                                                                                                                                                                         |  |  |  |  |
| vcc    | 6   | 1           | Digital supply voltage. Single +5 volts.                                                                                                                                                                                         |  |  |  |  |
| N.C.   | 7   |             |                                                                                                                                                                                                                                  |  |  |  |  |
| A0     | 8   | 1           | Frequency select address input 1.                                                                                                                                                                                                |  |  |  |  |

## ST49C103/104

#### **EXTERNAL CLOCK CONNECTION**

To minimize the noise pickup , it is recommended to connect 0.047 $\mu$ F capacitor to XTAL1, and keep the lead length of the capacitor to XTAL1 to a minimum to reduce noise susceptibility.

#### FREQUENCY SELECT CALCULATION

The ST49C104 contains an analog phase locked loop circuit with digital closed loop dividers and a final output multiplexer to achieve the desired dividing ratios for the clock output.

The accuracy of the frequencies produced by the ST49C104 depends on the input frequency and divider ratios. The formula for calculating the exact output frequency is as follows:

CLKO = (Reference clock) X A/(B.C)

where

A=1,2,3,.....127 B=8, 16, 32 ,64 C=1,2,4,8

For proper output frequency, the ST49C104 can accept a reference frequency from 5 - 40 MHz and divider ratio up to 15.

#### MASK OPTIONS

The following mask options are provided for custom applications.

- \* Latch Enable can be edge triggered or level sensitive.
- \* Latch Enable can be active high or active low.
- \* Any frequency can be in any decoding position.
- \* CLK 1 and CLK 2 can be included in decoding table.
- \* CLK2 can control selection of either CLK 1 or the internal frequencies.

| FEATURE                             | ST49C104<br>14-pin | ST49C104<br>8-pin | ST49C103<br>8-pin |
|-------------------------------------|--------------------|-------------------|-------------------|
| <br>  8 output frequencies          | ×                  | X                 |                   |
| 4 output frequencies                |                    |                   | x                 |
| Programmable LEN pin                | X                  | X                 | X                 |
| Clock input only                    |                    | X                 |                   |
| Crystal or clock input              | . X                |                   | X                 |
| CLK1, CLK2 available for output mux | X                  |                   |                   |

| Address latch (LEN) | State                    |
|---------------------|--------------------------|
| ST49C104-1          | Transparent for LEN high |
| ST49C104-2          | Transparent for LEN low  |
| ST49C104-3          | Transparent for LEN low  |

## **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

## DC ELECTRICAL CHARACTERISTICS

 $T_{\Delta}$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                | Parameter                | Limits Min Typ Max |    |      | Units      | Conditions               |  |
|-------------------------------------------------------|--------------------------|--------------------|----|------|------------|--------------------------|--|
| V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>OL</sub> | Input low level          |                    |    | 0.8  | V          |                          |  |
| V <sub>IH</sub>                                       | Input high level         | 2.0                |    |      | V          |                          |  |
| Vol                                                   | Output low level         |                    |    | 0.4  | V          | I <sub>oL</sub> = 8.0 mA |  |
| V <sub>OH.</sub>                                      | Output high level        | 2.4                |    |      | V .        | I <sub>OH</sub> = 8.0 mA |  |
| I <sub>IL</sub>                                       | Input low current        |                    |    | -350 | μΑ         | Except crystal input     |  |
| I <sub>IH</sub>                                       | Input high current       |                    |    | 1    | μΑ         | V <sub>IN</sub> =Vcc     |  |
| l <sub>cc</sub>                                       | Operating current        |                    | 20 | 30   | mA         | No load.<br>DCLK=80MHz   |  |
| R <sub>IN</sub>                                       | Input pull-up resistance | 15                 | 20 | 25   | <b>K</b> Ω |                          |  |

# ST49C103/104

## **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                    | Parameter                                                                                                                                                                                                  | Min                                  | Limits Min Typ Max               |                                                  |                                                         | Conditions                                                            |  |
|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------|--------------------------------------------------|---------------------------------------------------------|-----------------------------------------------------------------------|--|
| $T_{1}$ $T_{2}$ $T_{3}$ $T_{4}$ $T_{5}$ $T_{6}$ $T_{7}$ $T_{7}$ $T_{8}$ $T_{10}$ $T_{11}$ | Enable pulse width Setup time data to enable Hold time to data enable Rise time Fall time Duty cycle Duty cycle Jitter Input frequency Input clock rise time Input clock fall time Output frequency change | 20<br>20<br>10<br>40<br>45<br>14.318 | 1<br>1<br>48/52<br>48/52<br>±175 | 1.5<br>1.5<br>60<br>55<br>±300<br>32<br>20<br>20 | ns<br>ns<br>ns<br>ns<br>s<br>%<br>ps<br>MHz<br>ns<br>ns | 0.8V - 2.0V<br>2.0V - 0.8V<br>1.4V switch point<br>Vcc/2 switch point |  |

## TIMING DIAGRAM



# ST49C103/104

| A2 A1 A0 |    | A0 | ST49C104-1 |        | ST49C104-2 |        | ST49C104-3 |         | ST49C   | 104-5* | ST49C103** |        |
|----------|----|----|------------|--------|------------|--------|------------|---------|---------|--------|------------|--------|
|          |    |    | NOMINAL    | ACTUAL | NOMINAL    | ACTUAL | NOMINAL    | ACTUAL  | NOMINAL | ACTUAL | NORMAL     | ACTUAL |
| 0        | 0  | 0  | Xtal       | Xtal   | 25.175     | 25.280 | 50.350     | 50.560  | 39.000  | 39.000 | 32.000     | 32.00  |
| 0        | .0 | 1  | 16.257     | 16.331 | 28.322     | 28.412 | 56.664     | 56.824  | 25.000  | 25.000 | 40.00      | 40.00  |
| 0        | 1  | 0  | Clk2       | Clk2   | 32.514     | 32.663 | 65.028     | 65.326  | 30.750  | 30.750 | 50.00      | 50.00  |
| 0        | 1  | 1  | 32.514     | 32.663 | 36.000     | 35.795 | 72.000     | 71.590  | 26.250  | 26.250 | 1.00       | 1.00   |
| - 1      | 0  | 0  | 25.175     | 25.056 | 40.000     | 39.822 | 80.000     | 79.640  | 32.000  | 32.000 | N/A        |        |
| 1        | 0  | 1  | 28.322     | 28.412 | 44.900     | 44.744 | 89.800     | 89.488  | 25.250  | 25.250 | N/A        |        |
| 1        | 1  | 0  | 24.000     | 23.938 | 50.000     | 50.113 | 75.000     | 75.169  | 31.250  | 31.250 | N/A        |        |
| 1        | 1  | 1  | 40.000     | 39.822 | 65.000     | 65.326 | 108.00     | 108.280 | 37.500  | 37.500 | N/A        |        |

| A2 A1 A |                  | ST49C                                                                        |                                                                              |  |  |
|---------|------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------|--|--|
| 0 1 (   | 1<br>0<br>1<br>0 | 25.500<br>16.500<br>20.750<br>22.500<br>24.500<br>19.500<br>15.000<br>14.000 | 25.500<br>16.500<br>20.750<br>22.500<br>24.500<br>19.500<br>15.000<br>14.000 |  |  |

Input clock frequency = 14.318 MHz
\* Input clock frequency = 16.0 MHz
\*\* Input clock frequency = 8.0 MHz



Printed September 2, 1994

### PREPROGRAMMED FREQUENCY GENERATOR

#### DESCRIPTION

The ST49C106 is a mask programmable monolithic analog CMOS device designed to generate up to 8 single frequency outputs from a single input clock. The ST49C106 is designed in a  $1.2\mu$  process to achieve 130 MHz speed for high end frequencies.

The ST49C106 is designed to replace existing video clocks generated from individual oscillators in order to reduce board space and number of oscillators. To provide high speed and low litter clock, the parts utilize a high speed analog CMOS phase locked loop using 14.318 MHz system clock as the reference clock (note that reference clock can be changed to generate optional frequencies from a standard programmed device). The programmed clock outputs are selectable via three address lines and address latch enable pin. The ST49C106 also includes a power on reset circuit which will cause the select logic to select the frequency at address "000" upon power up. The ST49C106 contains de-glitch circuit so that full clock cycles are provided whenever the HALT pin stops or starts the output clock.

#### **FEATURES**

- Can replace up to 8 oscillators/crystals and a multiplexer
- Pin-to-pin compatible to Avasem AV9106-14
- Programmable analog phase locked loop
- Low power single 5V CMOS technology
- 14 pin DIP or SOIC package.

### **SOIC Package**

| A1 1    |              | 14 A0   |
|---------|--------------|---------|
| A2 2    | 4            | 13 N.C. |
| LEN 3   | ST49C106CF14 | 12 AVCC |
| AGND 4  | 7106         | 11 DVCC |
| DGND 5  | 490          | 10 сько |
| XTAL1 6 | ST           | 9 HALT  |
| XTAL2 7 |              | 8 SEL   |

## Plastic-DIP package

| A1 1    |              | 14 A0   |
|---------|--------------|---------|
| A2 2    | 4            | 13 N.C. |
| LEN 3   | SCP          | 12 AVCC |
| AGND 4  | 106          | 11 DVCC |
| DGND 5  | ST49C106CP14 | 10 CLKO |
| XTAL1 6 | ST           | 9 HALT  |
| XTAL2 7 | -            | 8 SEL   |
|         |              |         |

#### ORDERING INFORMATION

Part number ST49C106CP14 ST49C106CF14 

## **BLOCK DIAGRAM**



## **SYMBOL DESCRIPTION**

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                                                                   |
|--------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A1     | 1   | l'          | Frequency select address input 2.                                                                                                                                                                                                 |
| A2     | 2*  | 1 .         | Frequency select address input 3.                                                                                                                                                                                                 |
| LEN    | 3*  | · 1         | Address latch enable input. To latch selected programmed clock output.                                                                                                                                                            |
| AGND   | 4   | 0           | Analog ground.                                                                                                                                                                                                                    |
| DGND   | 5   | 0           | Digital ground.                                                                                                                                                                                                                   |
| XTAL1  | 6   | 1 -         | Crystal or external clock input. A crystal can be connected to this pin and XTAL2 pin to generate internal phase locked loop reference clock. For external 14.318 MHz clock, XTAL2 is left open or used as buffered clock output. |
| XTAL2  | 7   | 0           | Crystal output.                                                                                                                                                                                                                   |
| SEL    | 8   | 1           | Clock level select / CLK1. When HALT is asserted, SEL selects whether the clock is high or low. This level must be selected before the clock is halted. SEL pin can be used as an xternal clock input when HALT is active.        |
| HALT   | 9   | 1           | Start / Stop output clock.                                                                                                                                                                                                        |
| CLKO   | 10  | 0           | Programmed output clock.                                                                                                                                                                                                          |
| DVCC   | 11  | 1           | Digital supply voltage. Single +5 volts.                                                                                                                                                                                          |
| AVCC   | 12  | 1           | Analog supply voltage. Single +5 volts.                                                                                                                                                                                           |
| A0     | 14  | I           | Frequency select address input 1.                                                                                                                                                                                                 |

<sup>\*</sup> Have internal pull-up resistors on inputs.

#### **EXTERNAL CLOCK CONNECTION**

To minimize the noise pickup, it is recommended to connect 0.047µF capacitor to XTAL1, and keep the lead length of the capacitor to XTAL1 to a minimum to reduce noise susceptibility.

#### FREQUENCY SELECT CALCULATION

The ST49C106 contains an analog phase locked loop circuit with digital closed loop dividers and a final output multiplexer to achieve the desired dividing ratios for the clock output.

The accuracy of the frequencies produced by the ST49C106 depends on the input frequency and divider ratios. The formula for calculating the exact output frequency is as follows:

CLKO = (Reference clock) X A/(B.C)

where A=1,2,3,......127 B=8, 16, 32 ,64 C=1,2,4,8

For proper output frequency, the ST49C106 can accept a reference frequency from 5 - 40 MHz and divider ratio up to 15.

#### **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

#### DC ELECTRICAL CHARACTERISTICS

 $T_A$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                   | Parameter                                                                             | Min        | Limits<br>Typ | Max                | Units             | Conditions                                                                      |
|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------|------------|---------------|--------------------|-------------------|---------------------------------------------------------------------------------|
| V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>OL</sub><br>V <sub>OH</sub> | Input low level Input high level Output low level Output high level Input low current | 2.0<br>2.4 |               | 0.8<br>0.4<br>-350 | V<br>V<br>V<br>μΑ | I <sub>oL</sub> = 8.0 mA<br>I <sub>OH</sub> = 8.0 mA<br>Except crystal<br>input |
| I <sub>IH</sub> I <sub>CC</sub> R <sub>IN</sub>                          | Input high current Operating current Input pull-up resistance                         | 15         | 20<br>20      | 1<br>30<br>25      | μΑ<br>mA<br>KΩ    | V <sub>IN</sub> =Vcc<br>No load.<br>DCLK=80MHz                                  |

## **AC ELECTRICAL CHARACTERISTICS**

 $T_A = 0^{\circ} - 70^{\circ} C$ , Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                                                   | Parameter                                                                                                                                                                                                  | Min                                  | Limits<br>Typ                    | Max                                              | Units                                                         | Conditions                                                            |
|------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------|--------------------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------|
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>6</sub> T <sub>6</sub> T <sub>7</sub> T <sub>8</sub> T <sub>10</sub> T <sub>11</sub> | Enable pulse width Setup time data to enable Hold time to data enable Rise time Fall time Duty cycle Duty cycle Jitter Input frequency Input clock rise time Input clock fall time Output frequency change | 20<br>20<br>10<br>40<br>45<br>14.318 | 1<br>1<br>48/52<br>48/52<br>±175 | 1.5<br>1.5<br>60<br>55<br>±300<br>32<br>20<br>20 | ns<br>ns<br>ns<br>ns<br>ns<br>%<br>%<br>ps<br>MHz<br>ns<br>ns | 0.8V - 2.0V<br>2.0V - 0.8V<br>1.4V switch point<br>Vcc/2 switch point |

| A2 | A1 | A0  | ST49C<br>NOMINAL |        |
|----|----|-----|------------------|--------|
| 0  | 0  | 0   | 39.000           | 39.000 |
| 0  | 0  | 1   | 25.000           | 25.000 |
| 0  | 1  | 0   | 30.750           | 30.750 |
| 0  | 1  | 1   | 26.250           | 26.250 |
| 1  | 0  | 0   | 32.000           | 32.000 |
| 1  | 0  | 1   | 25.250           | 25.250 |
| 1  | 1  | 0 . | 31.250           | 31.250 |
| 1  | 1  | 1   | 37.500           | 37.500 |

## TIMING DIAGRAM







Printed September 2, 1994

## PREPROGRAMMED CPU MOTHER BOARD FREQUENCY GENERATOR

#### DESCRIPTION

The ST49C107 is a mask programmable monolithic analog CMOS device designed to generate two similtaneous clock. One clock, the BCLK (buffered reference clock), is a fixed output frequency. The other clock, CLOCK, 1XCLK, and 2XCLK can vary from 2 to 100MHz, with up to 16 single selectable preprogrammed frequencies stored in internal ROM. The ST49C107 is designed to replace existing CPU mother board clocks generated from individual oscillators in order to reduce board space and number of oscillators. To provide high speed and low litter clock. the parts utilize a high speed analog CMOS phase locked loop using 14.318 MHz system clock as the reference clock (note that reference clock can be changed to generate optional frequencies from a standard programmed device). The programmed clock outputs are selectable via four address lines ( two address lines for ST49C107-05).

#### **FEATURES**

- Provides reference clock and synthesized clock
- 5 to 40MHz input reference frequency
- Pin-to-pin compatible to Avasem AV9107
- Programmable analog phase locked loop
- Low power single 5V CMOS technology
- Up to 16 frequencies stored internally
- 8/14 pin DIP or SOIC package.

#### ORDERING INFORMATION

 Part number
 Package
 Operating temperature

 ST49C107CP8
 Plastic-DIP
 0 ° C to +70° C

 ST49C107CF8
 SOIC
 0° C to +70° C

 ST49C107CP14
 Plastic-DIP
 0 ° C to +70° C

 ST49C107CF14
 SOIC
 0° C to +70° C

### **SOIC Package**

| A1 1    |              | 14 A0    |
|---------|--------------|----------|
| A2 2    | 4            | 13 BCLK  |
| A3 3    | ST49C107CF14 | 12 VCC   |
| AGND 4  | 707          | 11 CLOCK |
| DGND 5  | 490          | 10 CE2   |
| PD* 6   | ST           | 9 OE1    |
| XTAL1 7 |              | 8 XTAL2  |

#### ST49C107CF-03

| A1 1    |              | 14 A0    |
|---------|--------------|----------|
| A2 2    | 4            | 13 1XCLK |
| A3 3    | Ž,           | 12 VCC   |
| AGND 4  | 107:         | 11 2XCLK |
| DGND 5  | ST49C107CF14 | 10 CE2   |
| PD* 6   | ST           | 9 OE1    |
| XTAL1 7 |              | 8 XTAL2  |

#### ST49C107CF-04

| A0 1    | 8-     | 8 BCLK  |
|---------|--------|---------|
| GND 2   | 107CF8 | 7 VCC   |
| XTAL1 3 | 49C1   | 6 CLOCK |
| XTAL2 4 | ST     | 5 A1    |

ST49C107CF-05

### **BLOCK DIAGRAM**



## SYMBOL DESCRIPTION (ST49C107-03 package)

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                                                                   |
|--------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A1     | 1*  | ı           | Frequency select address input 2.                                                                                                                                                                                                 |
| A2     | 2*  | l ·         | Frequency select address input 3.                                                                                                                                                                                                 |
| A3     | 3*  | I           | Frequency select address input 4.                                                                                                                                                                                                 |
| AGND   | 4   | 0           | Analog ground.                                                                                                                                                                                                                    |
| DGND   | 5   | 0           | Digital ground.                                                                                                                                                                                                                   |
| PD     | 6*  | I           | Power-Down (Active low). Shuts off chip when low.                                                                                                                                                                                 |
| XTAL1  | 7   | l           | Crystal or EXternal Clock input. A crystal can be connected to this pin and XTAL2 pin to generate internal phase locked loop reference clock. For external 14.318 MHz clock, XTAL2 is left open or used as buffered clock output. |
| XTAL2  | 8   | 0           | Crystal output.                                                                                                                                                                                                                   |
| OE1    | 9*  | 1           | Buffered clock Output Enable (Active high). BCLK output is three stated when this pin is low.                                                                                                                                     |
| OE2    | 10* | 1           | Clock Output Enable (Active high). CLOCK output is three stated when this pin is low.                                                                                                                                             |
| сьоск  | 11  | 0           | Programmed output clock.                                                                                                                                                                                                          |
| vcc    | 12  | . 1         | Positive supply voltage. Single +5 volts.                                                                                                                                                                                         |
| BCLK   | 13  | 0           | Buffered crystal clock output.                                                                                                                                                                                                    |
| A0     | 14* | ı           | Frequency select address input 1.                                                                                                                                                                                                 |

<sup>\*</sup> Have internal pull-up resistors on inputs.

## SYMBOL DESCRIPTION (ST49C107-04 package)

| Symbol | Pin | Signal Type | Pin Description                                                                                                         |
|--------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------|
| A1     | 1*  | ı           | Frequency select address input 2.                                                                                       |
| A2     | 2*  | : 1         | Frequency select address input 3.                                                                                       |
| A3     | 3*  | 1 -         | Frequency select address input 4.                                                                                       |
| AGND   | 4   | 0           | Analog ground.                                                                                                          |
| DGND   | 5   | 0           | Digital ground.                                                                                                         |
| PD     | 6*  | ı           | Power-Down (Active low). Shuts off chip when low.                                                                       |
| XTAL1  | 7   |             | Crystal or EXternal Clock input. A crystal can be connected to this pin and XTAL2 pin to generate internal phase locked |
|        |     | en e        | loop reference clock. For external 14.318 MHz clock, XTAL2 is left open or used as buffered clock output.               |
| XTAL2  | 8   | 0           | Crystal output.                                                                                                         |
| OE1    | 9*  | n           | 1X-CLOCK Output Enable (Active high). 1X-CLOCK output is three stated when this pin is low.                             |
| OE2    | 10* |             | 2X-CLOCK Output Enable (Active high). 2X-CLOCK output is three stated when this pin is low.                             |
| 2XCLK  | 11  | 0           | Programmed output clock.                                                                                                |
| vcc    | 12  | s trail     | Positive supply voltage. Single +5 volts.                                                                               |
| 1XCLK  | 13  | 0           | 2X-CLOCK Divide-by-two output.                                                                                          |
| A0     | 14* | l           | Frequency select address input 1.                                                                                       |

<sup>\*</sup> Have internal pull-up resistors on inputs.

## SYMBOL DESCRIPTION (ST49C107-05 package)

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                                                                   |
|--------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0     | 1   | I           | Frequency select address input 1.                                                                                                                                                                                                 |
| A1     | 5   | 1           | Frequency select address input 2.                                                                                                                                                                                                 |
| GND    | 2   | 0           | Supply ground                                                                                                                                                                                                                     |
| XTAL1  | 3   | I           | Crystal or EXternal Clock input. A crystal can be connected to this pin and XTAL2 pin to generate internal phase locked loop reference clock. For external 14.318 MHz clock, XTAL2 is left open or used as buffered clock output. |
| XTAL2  | 4   | 0           | Crystal output.                                                                                                                                                                                                                   |
| сьоск  | 6   | 0           | Programmed output clock.                                                                                                                                                                                                          |
| vcc    | 7   | 1           | Positive supply voltage. Single +5 volts.                                                                                                                                                                                         |
| BCLK   | 8   | . 0         | Buffered crystal clock output.                                                                                                                                                                                                    |

#### FREQUENCY TRANSITIONS

The ST49C107 is designed to provide smooth, glitch-free frequency transitions on the CLOCK, 1XCLK and 2XCLK clocks when the frequency select pins are changed. These frequency transitions are less than 0.1% frequency change per clock period.

#### EXTERNAL CLOCK CONNECTION

To minimize the noise pickup , it is recommended to connect  $0.047\mu F$  capacitor to XTAL1, and keep the lead length of the capacitor to XTAL1 to a minimum to reduce noise susceptibility.

#### FREQUENCY SELECT CALCULATION

The ST49C107 contains an analog phase locked loop circuit with digital closed loop dividers and a final output multiplexer to achieve the desired dividing ratios for the clock output.

The accuracy of the frequencies produced by the ST49C107 depends on the input frequency and divider ratios. The formula for calculating the exact output frequency is as follows:

CLOCK = (Reference clock) X A/(B.C)

where A=5, 6, 7,......128 B=5, 6, 7,......128 C=1.2

For proper output frequency, the ST49C107 can accept a reference frequency from 5 - 40 MHz and divider ratio up to 15.

### **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

### DC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                          | Parameter                                                                                                                  | Limits Min Typ Max |           |                              | Units                         | Conditions                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------|-----------|------------------------------|-------------------------------|----------------------------------------------------------------------------------------------------------------|
| V <sub>IL</sub> V <sub>IH</sub> V <sub>OL</sub> V <sub>OH</sub> I <sub>IL</sub> I <sub>IH</sub> I <sub>CC</sub> | Input low level Input high level Output low level Output high level Input low current Input high current Operating current | 2.0                | 20        | 0.8<br>0.4<br>-10<br>1<br>30 | V<br>V<br>V<br>µА<br>µА<br>mA | I <sub>OL</sub> = 8.0 mA<br>I <sub>OH</sub> = 8.0 mA<br>Exc. crystal input<br>V <sub>IN</sub> =Vcc<br>No load. |
| I <sub>sb</sub><br>R <sub>in</sub>                                                                              | Standby current<br>Input pull-up resistance                                                                                | 500                | 25<br>900 | 1300                         | μ <b>Α</b><br><b>Κ</b> Ω      | CLOCK=80MHz<br>No load.                                                                                        |

### **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                                  | Parameter                                                                                                                                                                  | r Limits<br>Min Typ Max |                                  |                                                  | Units                                       | Conditions                                                            |
|-------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|----------------------------------|--------------------------------------------------|---------------------------------------------|-----------------------------------------------------------------------|
| T <sub>1</sub> T <sub>2</sub> T <sub>4</sub> T <sub>5</sub> T <sub>7</sub> T <sub>7</sub> T <sub>8</sub> T <sub>6</sub> | 1X, 2X-CLOCK rise time 1X, 2X-CLOCK fall time Duty cycle Duty cycle Jitter Input frequency Buffered clock rise time Buffered clock fall time 1X, 2X-CLOCK frequency change | 40<br>45<br>2           | 1<br>1<br>48/52<br>48/52<br>±175 | 1.5<br>1.5<br>60<br>55<br>±300<br>32<br>20<br>20 | ns<br>ns<br>%<br>%<br>ps<br>MHz<br>ns<br>ns | 0.8V - 2.0V<br>2.0V - 0.8V<br>1.4V switch point<br>Vcc/2 switch point |

CLOCK OUTPUT TABLE FOR ST49C107-03 (using 14.318 MHz input. All frequencies in MHz).

CLOCK OUTPUT TABLE FOR ST49C107-05 (using 14.318 MHz input. All frequencies in MHz).

| A1 A0 | CLOCK |
|-------|-------|
| 0 0   | 40.01 |
| 0 1   | 50.11 |
| 1 0   | 66.61 |
| 1 1   | 80.01 |

| А3  | A2 | A1 | A0 | сьоск  |
|-----|----|----|----|--------|
| 0   | 0  | 0  | 0  | 16.00  |
| . 0 | 0  | 0  | 1  | 40.01  |
| 0   | 0  | 1  | 0  | 50.11  |
| 0   | 0  | 1  | 1  | 80.01  |
| 0   | 1  | 0  | 0  | 66.58  |
| 0   | 1  | 0  | 1  | 100.23 |
| 0   | 1  | 1  | 0  | 8.02   |
| 0   | 1  | 1  | 1  | 4.01   |
| 1   | 0  | 0  | 0  | 8.02   |
| 1   | 0  | 0  | 1  | 20.00  |
| 1   | 0  | 1  | 0  | 25.06  |
| 1   | 0  | 1. | 1  | 40.01  |
| 1   | 1  | 0  | 0  | 33.29  |
| 1   | 1  | 0  | 1  | 50.11  |
| 1   | 1  | 1  | 0  | 4.01   |
| 1   | 1  | 1  | 1  | 2.05   |

CLOCK OUTPUT TABLE FOR ST49C107-04 (using 14.318 MHz input. All frequencies in MHz).

| А3 | A2 | A1 | Α0 | 2X-CLOCK    | CLOCK        |
|----|----|----|----|-------------|--------------|
| 0  | 0  | 0  | 0  | 80.02       | 40.01        |
| 0  | 0  | 0  | 1  | 66.62       | 33.31        |
| 0  | 0  | 1  | 0  | 50.11       | 25.06        |
| 0  | 0  | 1  | .1 | 40.01       | 20.00        |
| 0  | 1  | 0  | 0  | 100.23      | 50.11        |
| 0  | 1  | 0  | 1  | 33.31       | 16.66        |
| 0  | 1  | 1  | 0  | 32.01       | 16.00        |
| 0  | 1  | 1  | 1  | 25.06       | 12.47        |
| 1  | 0  | 0  | 0  | 64.02       | 32.01        |
| 1  | 0  | 0  | 1  | 2X-Input    | 1X-Input     |
| 1  | 0  | 1  | Ó  | 3X-Input    | 1.5X-Input   |
| 1  | 0  | 1  | 1  | 8X-Input    | 4X-Input     |
| 1  | 1  | 0  | 0  | 0.5X-Input  | 0.25X-Input  |
| 1  | 1  | 0  | 1  | 0.25X-Input | 0.125X-Input |
| 1  | 1  | 1  | 0  | 120.00      | 60.00        |
| 1  | 1  | 1  | 1  | 129.96      | 64.98        |

## TIMING DIAGRAM





Printed September 2, 1994

## PREPROGRAMMED CPU MOTHERBOARD FREQUENCY GENERATOR

### **GENERAL DESCRIPTION**

The ST49C154 is a monolithic analog CMOS device designed to generate six simultaneous clock outputs for mother board and disk drive applications. It is designed in a  $1.2\mu$  process to achieve 100 MHz operation with low clock litter.

The ST49C154 may be used to replace existing BUS, I/O, and disk drive clocks generated from individual oscillators so that board space and number of oscillators are reduced. The high speed analog CMOS phase locked loops use the 14.318 MHz system clock or external crystal connected between XTAL1 and XTAL2 as the reference clock (reference clock can be changed to generate non-standard frequencies from the standard programmed device).

The ST49C154 is metal mask programmable to provide any custom set of CPUCLK frequencies. The programmed clock outputs are selectable via four address lines for 1XCLK / 2XCLK outputs. The CPU clock makes glitch-free transitions from one frequency to the next and follows Intel's processors input clock specification.

#### **FEATURES**

- Pin -to-pin compatible to AV9154
- Compatible with 286, 386, and 486 CPUs
- Supports Turbo modes
- Generates communications clock, keyboard clock, floppy disk clock, system reference clock, bus clock and CPU clock
- Skew controlled 2X and 1X clocks
- Programmable analog phase locked loop
- High speed (up to 130 MHz output)
- Low power single 3V / 5V CMOS technology
- 16 pin dip or SOIC package

#### ORDERING INFORMATION

| Part number     | Package     | Opera | atin | g te | mperati | ıre |
|-----------------|-------------|-------|------|------|---------|-----|
| ST49C154CP16-xx | Plastic-DIP | 0°    | С    | to   | +70°    | С   |
| ST49C154CF16-xx | SOIC        | ٥°    | C    | tο   | +70°    | C   |

#### **SOIC Package**

| 1.8 MHZ 1 |                 | 16 A0       |
|-----------|-----------------|-------------|
| XTAL2 2   | .27             | 15 A1       |
| XTAL1 3   | ST49C154CF16-27 | 14 2XCLK    |
| VCC 4     | 4CF             | 13 VCC      |
| GND 5     | 215             | 12 GND      |
| 24 MHZ 6  | 749(            | 11 14.3 MHZ |
| 12 MHZ 7  | ြ               | 10 A2       |
| AGND 8    |                 | 9 PDCPU     |

| A0 1     |                 | 16 A1       |
|----------|-----------------|-------------|
| XTAL2 2  | \$              | 15 2XCLK    |
| XTAL1 3  | -16-            | 14 1XCLK    |
| VCC 4    | 4CF             | 13 VCC      |
| GND 5    | 215             | 12 GND      |
| 24 MHZ 6 | ST49C154CF16-04 | 11 14.3 MHZ |
| 8 MHZ 7  | ဟ               | 10 A2       |
| AGND 8   |                 | 9 PD*       |

| A2 1     |                 | 16 A0       |
|----------|-----------------|-------------|
| XTAL2 2  | 25              | 15 A1       |
| XTAL1 3  | -16-            | 14 1XCLK    |
| VCC 4    | 4CF             | 13 VCC      |
| GND 5    | C15             | 12 GND      |
| 32 MHZ 6 | ST49C154CF16-25 | 11 14.3 MHZ |
| 8 MHZ 7  | Ω               | 10 A3       |
| AGND 8   |                 | 9 PD*       |

### **BLOCK DIAGRAM**



## **SYMBOL DESCRIPTION**

| Symbol | Pin  | Signal Type    | Pin Description                                                                                                                       |
|--------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------|
| XTAL2  | 2    | 0              | Crystal output.                                                                                                                       |
| XTAL1  | 3    | l              | Crystal or External clock input.                                                                                                      |
| vcc    | 4,13 | I              | Digital supply voltage. Single +3 / +5 volts.                                                                                         |
| GND    | 5,12 | 0              | Digital signal ground.                                                                                                                |
| AGND   | 8    | 0              | Analog ground.                                                                                                                        |
| A0     | *    | 1              | CPU clock frequency select address 0.<br>ST49C154-4, -6, -16, -26, -60 > pin 1.<br>ST49C154-5, -10, -25, -27 > pin 16.                |
| A1     | *    | 1              | CPU clock frequency select address 1.<br>ST49C154-4, -6, -16, -26, -60 > pin 16.<br>ST49C154-5, -10, -25, -27 > pin 15.               |
| A2     | *    | 1 ,            | CPU clock frequency select address 2.<br>ST49C154-4, -26, -27 > pin 10.<br>ST49C154-5, -25 > pin 1.<br>ST49C154-6, -16, -60 > pin 15. |
| A3     | *    | I              | CPU clock frequency select address 3.<br>ST49C154-5, -25 > pin 10.                                                                    |
| PD*    | *    | <b>I</b> .     | Power down (active low). Shuts off entire chip when low. ST49C154-4, -5, -25, -26 > pin 9.                                            |
| PDCPU  | *    | <b>l</b>       | Power down (active high). Shuts off 2XCLK output when high.<br>ST49C154-6, -16, -60 > pin 10.                                         |
| PDREF  | *    | I <sup>1</sup> | Power down ( active high ). Shuts off the 14.318 MHz reference clock output. ST49C154-6, -16, -60 > pin 9.                            |
| PDCLK* | *    | 1              | Power down (active low). Shuts off the 1.846 MHz, 8 MHz, 16 MHz, and 24 MHz clock outputs. ST49C154-10 > pin 9.                       |
| PDCLK* | *    | I              | Power down (active low). Shuts off the 1.84<br>16 MHz, and 24 MHz clock outputs.                                                      |

## SYMBOL DESCRIPTION

| Symbol     | Pin | Signal Type | Pin Description                                                                                                 |
|------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------|
| 1XCLK      | *   | 0           | Selectable CPU clock output.<br>ST49C154-4, -5, -6, -10, -16, -25, -60 > pin 14.                                |
| 2XCLK      | *   | 0           | Selectable 2X-CPU clock output.<br>ST49C154-4, -6, -60 > pin 15.<br>ST49C154-27 > pin 14.                       |
| 1.846 MHz  | *   | 0           | 1.846 MHz clock output.<br>ST49C154-10 > pin 7.<br>ST49C154-27 > pin 1.                                         |
| 8 MHz      | *   | 0           | 8 MHz clock output.<br>ST49C154-4, -5, -25 > pin 7.<br>ST49C154-10 > pin 1.                                     |
| 12 MHz     | *   | 0           | 12 MHz clock output.<br>ST49C154-16, -26, -27 > pin 7.                                                          |
| 14.318 MHz | *   | 0           | 14.318 MHz reference clock output.<br>ST49C154-4, -5, -6, -16, -25, -27, -60 > pin 11.<br>ST49C154-10 > pin 10. |
| 16 MHz     | *   | 0           | 16 MHz clock output.<br>ST49C154-5, -10 > pin 6.                                                                |
| 24 MHz     | *   | 0           | 24 MHz clock output.<br>ST49C154-4, -6, -16, -26, -27, -60 > pin 6.<br>ST49C154-10 > pin 11.                    |
| 32 MHz     | *   | 0           | 32 MHz clock output.<br>ST49C154-25 > pin 6.                                                                    |
| 128 kHz    | *   | 0           | 128 kHz clock output.<br>ST49C154-6, -60 > pin 7.                                                               |

## SYMBOL DESCRIPTION (ST49C154-22 with 25 MHz reference frequency)

| Symbol | Pin     | Signal Type | Pin Description                               |
|--------|---------|-------------|-----------------------------------------------|
| XTAL2  | 2       | 0           | Crystal output.                               |
| XTAL1  | 1       | 1           | Crystal or External clock input.              |
| vcc    | 3,10,13 | 1           | Digital supply voltage. Single +3 / +5 volts. |
| GND    | 4,12    | 0           | Digital signal ground.                        |
| AGND   | 7       | 0           | Analog ground.                                |
| 20 MHz | 15      | 0           | 20 MHz clock output.                          |
| 24 MHz | 5       | 0           | 24 MHz clock output.                          |
| 25 MHz | 11      | 0           | 25 MHz clock output.                          |
| 32 MHz | 6       | 0           | 32 MHz clock output.                          |
| 40 MHz | 14      | 0           | 40 MHz clock output.                          |
|        |         |             | ·                                             |

1

## ST49C154 ACTUAL OUTPUT FREQUENCIES (using 14.318 MHz input. All frequencies in MHz).

| A3 A2 A1 A0                                                                                                                                   | CLK<br>-5                                                                                                                                     | CLK<br>-6                                                             | CLK<br>-10                                | CLK<br>-16                                                             | CLK<br>-25                                                                                                                                    | CLK<br>-27                                                               | <b>CLK</b><br>-60                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|-------------------------------------------|------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|-----------------------------------------------------------------------|
| 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 1 1 0 0 0 1 1 0 0 0 1 1 1 0 0 0 1 1 0 0 1 1 1 1 1 0 0 0 1 1 1 1 1 1 0 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 2.15<br>8.18<br>16.11<br>20.05<br>25.06<br>33.24<br>40.09<br>50.11<br>4.30<br>16.11<br>32.22<br>40.09<br>50.11<br>66.48*<br>80.18*<br>100.23* | 16.11<br>20.05<br>25.06<br>33.24<br>40.09<br>50.11<br>66.48<br>80.18* | PDCPU<br>40.09<br>50.11<br>66.48*         | 16.11<br>20.05<br>25.06<br>33.41<br>40.09<br>50.11<br>66.48*<br>80.18* | 2.15<br>8.18<br>16.11<br>20.05<br>25.06<br>33.24<br>40.09<br>50.11<br>4.30<br>16.11<br>32.22<br>40.09<br>50.11<br>66.48*<br>80.18*<br>100.23* | 75.17<br>31.94<br>60.136*<br>40.09<br>50.11<br>66.48*<br>80.18*<br>51.90 | 8.182<br>16.11<br>20.05<br>25.06<br>33.24<br>40.09<br>50.11<br>66.48* |
| I/O<br>Clocks                                                                                                                                 | 8.00<br>14.318<br>16.00                                                                                                                       | 0.128<br>14.318<br>24.00                                              | 1.846<br>8.00<br>14.318<br>16.00<br>24.00 | 12.00<br>14.318<br>24.00                                               | 8.00<br>14.318<br>32.01                                                                                                                       | 1.846<br>12.00<br>14.318<br>24.00                                        | 0.128<br>14.318<br>24.00                                              |

ST49C154-04, -26 ACTUAL OUTPUT FREQUENCIES (using 14.318 MHz input. All frequencies in MHz).

| A2 A1 A0                                                             | 2XCLK                                                                    | 1XCLK                                                               |
|----------------------------------------------------------------------|--------------------------------------------------------------------------|---------------------------------------------------------------------|
| 0 0 0<br>0 0 1<br>0 1 0<br>0 1 1<br>1 0 0<br>1 0 1<br>1 1 0<br>1 1 1 | 100.23*<br>80.18*<br>66.48*<br>50.11<br>40.09<br>32.22<br>24.23<br>15.75 | 50.11<br>40.09<br>33.24<br>25.06<br>20.05<br>16.11<br>12.12<br>7.88 |
| I/O<br>Clocks                                                        | 8.00,<br>24.00<br>14.318                                                 | 12.00**                                                             |

| XTAL2 1  |                 | 16 N.C.   |
|----------|-----------------|-----------|
| XTAL1 2  | 22              | 15 20 MHZ |
| VCC 3    | ST49C154CF16-22 | 14 40 MHZ |
| GND 4    | 4CF             | 13 VCC    |
| 24 MHZ 5 | C15             | 12 GND    |
| 32 kHZ 6 | T49             | 11 25 MHZ |
| AGND 7   | ဟ               | 10 VCC    |
| N.C. 8   |                 | 9 N.C.    |

<sup>\*</sup>These selections will only operate at 5V.

<sup>\*\*</sup> ST49C154-26 only

### **ABSOLUTE MAXIMUM RATINGS**

Supply voltage Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

## DC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                   | Parameter                                                                                                                                                                                            | Min              | Limits<br>Typ              | Max                         | Units                                   | Conditions                                                                                                                                   |
|----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------------------|-----------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>IL</sub> V <sub>OL</sub> V <sub>OH</sub> I <sub>IL</sub> I <sub>IH</sub> CC I <sub>SB</sub> CC CC | Input low level Input high level Output low level Output high level Input low current Input high current Operating current Stand by current Short circuit current Input capacitance Load capacitance | 2.0<br>2.4<br>25 | 25<br>15<br>40<br>10<br>20 | 0.8<br>0.4<br>-5<br>5<br>40 | > > > > Д Д Д Д Д Б Б Б Б Б Б Б Б Б Б Б | I <sub>oL</sub> = 4.0 mA<br>I <sub>OH</sub> = -8.0 mA<br>VIN=0V<br>VIN=Vcc<br>No load.<br>Power down.<br>Each output clock<br>Except Xtal1,2 |

| A2 1     | ſ               | 16 A0       | A0 1      |           | 16 A1       |
|----------|-----------------|-------------|-----------|-----------|-------------|
| XTAL2 2  | 92              | 15 A1       | XTAL2 2   | 90        | 15 A2       |
| XTAL1 3  | 16-             | 14 1XCLK    | XTAL1 3   | F16-06    | 14 1XCLK    |
| VCC 4    | ST49C154CF16-05 | 13 VCC      | VCC 4     | D<br>TO   | 13 VCC      |
| GND 5    | C15             | 12 GND      | GND 5     | ST49C154C | 12 GND      |
| 16 MHZ 6 | T49             | 11 14.3 MHZ | 24 MHZ 6  | T49       | 11 14.3 MHZ |
| 8 MHZ 7  | S               | 10 A3       | 128 kHZ 7 | တ         | 10 PDCPU    |
| AGND 8   |                 | 9 PD*       | AGND 8    |           | 9 PD*       |

## **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                 | Parameter                                                                                                                                                                                                                                                                                                                                       | Min                     | Limits<br>Typ                                                           | Max                                                                               | Units                                                                      | Conditions                                                                                                                  |
|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| T4<br>T5<br>T7<br>T7<br>T7<br>T7<br>T7<br>T7<br>T7<br>T7<br>T7<br>T7<br>T7<br>T7<br>T7 | Rise time 0.8 to 2.0V Fall time 0.8 to 2.0V Duty cycle Reference clock duty cycle Frequency transition time Power up time Output frequency Input frequency Input clock rise/fall time Jitter Jitter, 1 sigma Jitter, absolute Input frequency Input clock rise time Input clock fall time Enable pulse width Clock skew berween 1XCLK and 2XCLK | 40<br>40<br>2<br>2<br>2 | 1<br>1<br>48/52<br>48/52<br>15<br>14.318<br>±175<br>±0.8<br>2<br>14.318 | 2<br>2<br>60<br>55<br>20<br>50<br>32<br>20<br>±300<br>±2.5<br>5<br>32<br>20<br>20 | ns<br>ns<br>%<br>ms<br>ms<br>MHz<br>ns<br>ps<br>%<br>MHz<br>ns<br>ns<br>ns | 15pF load<br>15pF load<br>15pF load<br>From 2-20MHz<br>From off to 50MHz<br>16-100MHz<br>All frequencies<br>All frequencies |

| 8 MHZ 1   |                 | 16 A0       |
|-----------|-----------------|-------------|
| XTAL2 2   | 9               | 15 A1       |
| XTAL1 3   | -16             | 14 1XCLK    |
| VCC 4     | 5               | 13 VCC      |
| GND 5     | C15             | 12 GND      |
| 16 MHZ 6  | ST49C154CF16-10 | 11 24 MHZ   |
| 1.8 MHZ 7 | ဟ               | 10 14.3 MHZ |
| AGND 8    | 1               | 9 PDCLK*    |

| A0 1     |                 | 16 A1       |
|----------|-----------------|-------------|
| XTAL2 2  | 16              | 15 A2       |
| XTAL1 3  | 16              | 14 1XCLK    |
| VCC 4    | <u>7</u>        | 13 VCC      |
| GND 5    | 213             | 12 GND      |
| 24 MHZ 6 | ST49C154CF16-16 | 11 14.3 MHZ |
| 12 MHZ 7 | ်               | 10 PDCPU    |
| AGND 8   |                 | 9 PDREF     |

## **ABSOLUTE MAXIMUM RATINGS**

Supply voltage Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

### DC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=3.0 V ± 10% unless otherwise specified.

| Symbol                                                    | Parameter                                                                                                                                                                                            | Min                            | Limits<br>Typ        | Max                       | Units                                      | Conditions                                                                                                                                                   |
|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|----------------------|---------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VIL<br>VOL<br>VOH<br>IIL<br>IIH<br>ICC<br>ISB<br>ISC<br>C | Input low level Input high level Output low level Output high level Input low current Input high current Operating current Stand by current Short circuit current Input capacitance Load capacitance | 0.7VCC<br>VCC-0.1V<br>-5<br>-5 | 15<br>15<br>15<br>30 | 0.15VCC<br>0.1<br>-5<br>5 | >>> д<br>д д А<br>д А<br>д Б<br>р Б<br>р Б | I <sub>oL</sub> = 8.0 mA<br>I <sub>OH</sub> = -4.0 mA<br>V <sub>IN</sub> =0<br>V <sub>IN</sub> =Vcc<br>No load.<br>Power down.<br>No load.<br>Except Xtal1,2 |

| A0 1     | 1            | 16 A1       | A0 1      |           | 16 A1       |
|----------|--------------|-------------|-----------|-----------|-------------|
| XTAL2 2  | 58           | 15 2XCLK    | XTAL2 2   | <b>ထု</b> | 15 A2       |
| XTAL1 3  |              | 14 1XCLK    | XTAL1 3   | F16       | 14 1XCLK    |
| VCC 4    | 54           | 13 VCC      | VCC 4     | 5         | 13 VCC      |
| GND 5    | 215          | 12 GND      | GND 5     | 215       | 12 GND      |
| 24 MHZ 6 | ST49C154CF16 | 11 14.3 MHZ | 24 MHZ 6  | ST49C154C | 11 14.3 MHZ |
| 12 MHZ 7 | ν.           | 10 A2       | 128 kHZ 7 | ဟ         | 10 PDCPU    |
| AGND 8   |              | 9 PD*       | AGND 8    |           | 9 PD*       |

## **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=3.0 V ± 10% unless otherwise specified.

| Symbol                                                                                              | Parameter                                                                                                                                                                                                                                 | Min               | Limits<br>Typ                               | Max                                                                  | Units                                                           | Conditions                                                                                                        |
|-----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| $\begin{matrix}T_4\\T_5\\T_6\\T_7\\T_P\\T_8\\T_7\\T_{JIS}\\T_{JJA}\\T_9\\T_{10}\\T_{E}\end{matrix}$ | Rise time Fall time Duty cycle Frequency transition time Power up time Output frequency Input frequency Input clock rise/fall time Jitter Jitter, 1 sigma Jitter, absolute Input clock rise time Input clock fall time Enable pulse width | 40<br>2<br>2<br>2 | 48/52<br>15<br>14.318<br>±175<br>±8.5<br>±3 | 4<br>4<br>60<br>20<br>50<br>32<br>20<br>±300<br>±2<br>±5<br>20<br>20 | ns<br>ns<br>ms<br>ms<br>MHz<br>MHz<br>ns<br>ps<br>%<br>ns<br>ns | 15pF load.<br>15pF load.<br>15pF load.<br>From 2-20MHz<br>From off to 50MHz<br>All frequencies<br>All frequencies |

1





Printed September 12, 1994

### PREPROGRAMMED CPU MOTHERBOARD FREQUENCY GENERATOR

### **GENERAL DESCRIPTION**

The ST49C155 is a monolithic analog CMOS device designed to generate eight simultaneous clock outputs for mother board applications. It is designed in a  $1.2\mu$  process to achieve 130 MHz operation with low clock jitter.

The ST49C155 may be used to replace existing BUS and I/O clocks generated from individual oscillators so that board space and number of oscillators are reduced. The high speed analog CMOS phase locked loops use the 14.318 MHz system clock or external crystal connected between XTAL1 and XTAL2 as the reference clock (reference clock can be changed to generate non-standard frequencies from the standard programmed device).

The ST49C155 is metal mask programmable to provide any custom set of CPUCLK frequencies. The programmed clock outputs are selectable via four address lines for 1XCLK / 2XCLK outputs.

### **SOIC Package**

| CLK1 1  |                    | 20 A0    |
|---------|--------------------|----------|
| XTAL2 2 |                    | 19 A1    |
| XTAL1 3 | - 2                | 18 1XCL  |
| DVCC 4  | CF20-01<br>CF20-02 | 17 2XCLF |
| DGND 5  | 323 I              | 16 AVCC  |
| CLK2 6  | 49C1               | 15 AGND  |
| CLK3 7  | STS                | 14 CLK6  |
| CLK4 8  |                    | 13 CLK5  |
| AGND 9  |                    | 12 PD*   |
| OE 10   |                    | 11 A2    |

### **FEATURES**

- Can replace multiple oscillators/crystals
- Pin -to-pin compatible to AV9155
- Compatible with 286, 386, and 486 CPUs
- Supports Turbo modes
- Generates communications clock, keyboard clock, floppy disk clock, system reference clock, bus clock and CPU clock
- Skew controlled 2X and 1X clocks
- Programmable analog phase locked loop
- High speed (up to 130 MHz output)
- Low power single 5V CMOS technology
- 20 pin dip or SOIC package

| ~~~  |         | EAF       | 140TIOLI |
|------|---------|-----------|----------|
| 1121 | IPRING. | : INIE()6 | ΜΔΤΙΩΝ   |

| Part number      | Package     | Oper | atin | g te | mperati | ıre |
|------------------|-------------|------|------|------|---------|-----|
| ST49C155CP20-xx  | Plastic-DIP | 0°   | С    | to   | +70°    | С   |
| ST49C155CF20-xx  | SOIC        | 0°   | С    | to   | +70°    | С   |
| ST49C155C-120-xx | PLCC        | ٥Ô٥  | C    | to   | +70°    | C   |

| CLK1 1  |                 | 20 | Α0    |
|---------|-----------------|----|-------|
| XTAL2 2 |                 | 19 | A1    |
| XTAL1 3 | , m             | 18 | A2    |
| DVCC 4  | ST49C155CF20-23 | 17 | 1XCLK |
| DGND 5  | 22CF            | 16 | AVCC  |
| CLK2 6  | 49C1            | 15 | AGND  |
| CLK3 7  | l R             | 14 | CLK6  |
| CLK4 8  |                 | 13 | CLK5  |
| AGND 9  |                 | 12 | PD*   |
| OE 10   |                 | 11 | АЗ    |

### **BLOCK DIAGRAM**



## SYMBOL DESCRIPTION (ST49C155-01/-02)

| Symbol | Pin | Signal Type | Pin Description                                                                        |
|--------|-----|-------------|----------------------------------------------------------------------------------------|
| CLK1   | 1   | 0           | 1.8432 MHz clock output.                                                               |
| XTAL2  | 2   | 0           | Crystal output.                                                                        |
| XTAL1  | 3   | 1 :         | Crystal or External clock input.                                                       |
| DVCC   | 4   | 1           | Digital supply voltage. Single +5 volts.                                               |
| DGND   | 5   | 0           | Digital signal ground.                                                                 |
| CLK2   | . 6 | 0           | 16 MHz (ST49C155-01) or 32 MHz (ST49C155-02) clock output.                             |
| CLK3   | 7   | 0           | 24 MHz floppy disk clock output.                                                       |
| CLK4   | 8   | 0           | 12 MHz keyboard clock output.                                                          |
| AGND   | 9   | 0           | Analog ground.                                                                         |
| OE     | 10* | 0.          | Output Enable (active high). Low on this pin sets all the outputs to three state mode. |
| A2     | 11  | 1           | CPU clock frequency select address 2.                                                  |
| PD*    | 12* | 1           | Power down ( active low ). Shuts off entire chip when low.                             |
| CLK5   | 13  | 0           | 14.318 MHz reference clock output.                                                     |
| CLK6   | 14  | 0           | 14.318 MHz reference clock output.                                                     |
| AGND   | 15  | 0           | Analog ground.                                                                         |
| AVCC   | 16  | . 1         | Analog supply voltage. Single +5 volts.                                                |
| 2XCLK  | 17  | ı           | 2X CPU clock output.                                                                   |
| 1XCLK  | 18  | 1           | 1X CPU clock output.                                                                   |
| A1     | 19  | 1           | CPU clock frequency select address 1.                                                  |
| A0     | 20  | Age In the  | CPU clock frequency select address 0.                                                  |

<sup>\*</sup>Have internal pull-up resistor on inputs

## **SYMBOL DESCRIPTION (ST49C155-03)**

| Symbol | Pin   | Signal Type | Pin Description                                                                        |
|--------|-------|-------------|----------------------------------------------------------------------------------------|
| CLK1   | 1     | 0           | 6 MHz clock output.                                                                    |
| XTAL2  | 2     | 0 ,         | Crystal output.                                                                        |
| XTAL1  | 3     | I           | Crystal or External clock input.                                                       |
| DVCC   | 4 - 1 | 1           | Digital supply voltage. Single +5 volts.                                               |
| DGND   | 5     | <b>O</b> 4. | Digital signal ground.                                                                 |
| CLK2   | 6     | 0           | 24 MHz floppy disk clock output.                                                       |
| CLK3   | 7     | . o         | 16 MHz bus clock output.                                                               |
| CLK4   | 8     | 0           | 8 MHz keyboard clock output.                                                           |
| AGND   | 9     | 0           | Analog ground.                                                                         |
| OE     | 10*   | 0           | Output Enable (active high). Low on this pin sets all the outputs to three state mode. |
| A3     | 11    |             | CPU clock frequency select address 3.                                                  |
| PD*    | 12*   | √           | Power down ( active low ). Shuts off entire chip when low.                             |
| CLK5   | 13    | 0           | 14.318 MHz reference clock output.                                                     |
| CLK6   | 14    | 0           | 14.318 MHz reference clock output.                                                     |
| AGND   | 15    | 0           | Analog signal ground.                                                                  |
| AVCC   | 16    | 1           | Analog supply voltage. Single +5 volts.                                                |
| 1XCLK  | 17    | ı           | CPU clock output.                                                                      |
| A2     | 18    |             | CPU clock frequency select address 2.                                                  |
| A1     | 19    |             | CPU clock frequency select address 1.                                                  |
| A0     | 20    |             | CPU clock frequency select address 0.                                                  |

<sup>\*</sup>Have internal pull-up resistor on inputs

CPU CLOCK TABLE FOR ST49C155-01, -02 (using 14.318 MHz input. All frequencies in MHz).

| A2 | A1 | A0 | 2XCLK | 1XCLK |
|----|----|----|-------|-------|
| 0  | 0  | 0  | 8     | 4     |
| 0  | 0  | 1  | 16    | 8     |
| 0  | 1  | 0  | 32    | 16    |
| 0  | 1  | 1  | 40    | 20    |
| 1  | 0  | 0  | 50    | 25    |
| 1  | 0  | 1  | 66.66 | 33.33 |
| 1  | 1  | 0  | 80    | 40    |
| 1  | 1  | 1  | 100   | 50    |

CPU CLOCK TABLE FOR ST49C155-03(using 14.318 MHz input. All frequencies in MHz).

| А3  | A2     | A1     | A0     | 1XCLK       |
|-----|--------|--------|--------|-------------|
| 0   | 0      | 0      | 0<br>1 | 16<br>40    |
| 0   | 0      | 1      | 0      | 50<br>80    |
| 0   | 1      | 0      | 0      | 66.66       |
| 0   | 1      | 0<br>1 | 1<br>0 | 100<br>8    |
| 0   | 1<br>0 | 1<br>0 | 1<br>0 | 8           |
| 1 1 | 0      | 0      | 1<br>0 | 20<br>25    |
| 1   | 0<br>1 | 1      | 1<br>0 | 40<br>33.33 |
| 1   | 1      | 0      | 1      | 50          |
| 1 1 | 1      | 1      | 1      | 2           |

CPU CLOCK TABLE FOR ST49C155-23(using 14.318 MHz input. All frequencies in MHz).

| A2 | <b>A</b> 1 | A0 | 2XCLK | 1XCLK |
|----|------------|----|-------|-------|
| 0  | 0          | 0  | 75    | 37.5  |
| 0  | 0          | 1  | 32    | 16    |
| 0  | 1          | 0  | 60    | 30    |
| 0  | 1          | 1  | 40    | 20    |
| 1  | 0          | 0  | 50    | 25    |
| 1  | 0          | 1  | 66.66 | 33.33 |
| 1  | 1          | 0  | 80    | 40    |
| 1  | 1          | 1  | 52    | 26    |

PERIPHERAL CLOCK TABLE CHART FOR ST49C155-01 (MHz)

| CLK1   | CLK2 | CLK3 | CLK4 |
|--------|------|------|------|
| 1.8432 | 16   | 24   | 12   |

PERIPHERAL CLOCK TABLE CHART FOR ST49C155-02 (MHz)

| CLK1   | CLK2 | CLK3 | CLK4 |
|--------|------|------|------|
| 1.8432 | 32   | 24   | 12   |

PERIPHERAL CLOCK TABLE CHART FOR ST49C155-03 (MHz)

| CLK1 | CLK2 | CLK3 | CLK4 |
|------|------|------|------|
| 6    | 24   | 16   | 8    |

# PERIPHERAL CLOCK TABLE CHART FOR ST49C155-23 (MHz)

| CLK1  | CLK2 | CLK3 | CLK4 |
|-------|------|------|------|
| 1.843 | 16   | 24   | 12   |

#### **ACTUAL OUTPUT FREQUENCIES**

CPU CLOCK TABLE FOR ST49C155-01, -02 (using 14.318 MHz input. All frequencies in MHz).

| A2 | <b>A</b> 1 | A0 | 2XCLK  | 1XCLK |
|----|------------|----|--------|-------|
| 0  | 0          | 0  | 7.5    | 3.75  |
| 0  | 0          | 1  | 15.51  | 7.76  |
| 0  | 1          | 0  | 32.22  | 16.11 |
| 0  | 1          | 1  | 40.09  | 20.05 |
| 1  | 0          | 0  | 50.11  | 25.06 |
| 1  | 0          | 1  | 66.82  | 33.41 |
| 1  | 1          | 0  | 80.18  | 40.09 |
| 1  | 1          | 1  | 100.23 | 50.11 |

# CPU CLOCK TABLE FOR ST49C155-03(using 14.318 MHz input. All frequencies in MHz).

| А3  | A2 | A1 | A0 | 1XCLK  |
|-----|----|----|----|--------|
| 0   | 0  | 0  | 0  | 15.51  |
| 0   | 0  | 0  | 1  | 40.09  |
| 0   | 0  | 1  | 0  | 50.11  |
| 0   | 0  | 1  | 1  | 80.18  |
| 0   | 1  | 0  | 0  | 66.82  |
| 0   | 1  | 0  | 1  | 100.23 |
| 0   | 1  | 1  | 0  | 7.58   |
| 0   | 1  | 1  | 1  | 4.30   |
| 1   | 0  | 0  | 0  | 7.76   |
| . 1 | 0  | 0  | 1  | 20.05  |
| 1   | 0  | 1  | 0  | 25.06  |
| 1   | 0  | 1  | 1  | 40.09  |
| 1   | 1  | 0  | 0  | 33.41  |
| 1   | 1  | 0  | 1  | 50.11  |
| 1   | 1  | 1  | 0  | 3.79   |
| 1   | 1  | 1  | 1  | 2.15   |

## CPU CLOCK TABLE FOR ST49C155-23(using 14.318 MHz input. All frequencies in MHz).

| A2 | <b>A</b> 1 | A0 | 2XCLK  | 1XCLK  |
|----|------------|----|--------|--------|
| 0  | 0          | 0  | 75.170 | 37.585 |
| 0  | 0          | 1  | 31.940 | 15.970 |
| 0  | 1          | 0  | 60.136 | 30.068 |
| 0  | 1          | 1  | 40.090 | 20.045 |
| 1  | 0          | 0  | 50.113 | 25.057 |
| 1  | 0          | 1  | 66.476 | 33.238 |
| 1  | 1          | 0  | 80.181 | 40.091 |
| 1  | 1          | 1  | 51.903 | 25.952 |

## PERIPHERAL CLOCK TABLE CHART FOR ST49C155-01 (MHz)

| CLK1   | CLK2 | CLK3  | CLK4  |
|--------|------|-------|-------|
| 1.8432 | 16   | 23.71 | 11.86 |

# PERIPHERAL CLOCK TABLE CHART FOR ST49C155-02 (MHz)

| CLK1   | CLK2  | CLK3 | CLK4 |
|--------|-------|------|------|
| 1.8432 | 32.01 | 24   | 12   |

# PERIPHERAL CLOCK TABLE CHART FOR ST49C155-03 (MHz)

| CLK1 | CLK2 | CLK3 | CLK4 |
|------|------|------|------|
| 6    | 24   | 16   | 8    |

### **ABSOLUTE MAXIMUM RATINGS**

Supply voltage Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

### DC ELECTRICAL CHARACTERISTICS

 $T_*=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                   | Parameter                                                                             | Min | Limits<br>Typ | Max              | Units             | Conditions                                                                 |
|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-----|---------------|------------------|-------------------|----------------------------------------------------------------------------|
| V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>OL</sub><br>V <sub>OH</sub> | Input low level Input high level Output low level Output high level Input low current | 2.0 |               | 0.8<br>0.4<br>-1 | V<br>V<br>V<br>mA | I <sub>OL</sub> = 8.0 mA<br>I <sub>OH</sub> = 8.0 mA<br>Except pins 2, 10, |
| I <sub>IH</sub><br>I <sub>CC</sub><br>R <sub>IN</sub>                    | Input high current Operating current Internal pull-up resistance                      |     | 20<br>680     | 1<br>30          | mA<br>mA<br>KΩ    | 12<br>V <sub>IN</sub> =Vcc<br>No load.<br>Pins 10,12                       |

# PERIPHERAL CLOCK TABLE CHART FOR ST49C155-23 (MHz)

| CLK1  | CLK2 | CLK3 | CLK4 |
|-------|------|------|------|
| 1.843 | 16   | 24   | 12   |

### **FREQUENCY TRANSITIONS**

The ST49C155 is designed to provide smooth, glitch-free frequency transitions on the 1XCLK and 2XCLK clocks when the frequency select pins are changed. These frequency transitions are less than 0.1% frequency change per clock period.

### **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                       | Parameter                                                                   | Min      | Limits<br>Typ            | Max                    | Units                 | Conditions                                                            |
|--------------------------------------------------------------|-----------------------------------------------------------------------------|----------|--------------------------|------------------------|-----------------------|-----------------------------------------------------------------------|
| T₄<br>T₅<br>T <sub>6</sub><br>T <sub>6</sub>                 | Rise time Fall time Duty cycle Duty cycle                                   | 40<br>40 | 1<br>1<br>48/52<br>48/52 | 1.5<br>1.5<br>60<br>55 | ns<br>ns<br>%         | 0.8V - 2.0V<br>2.0V - 0.8V<br>1.4V switch point<br>Vcc/2 switch point |
| T <sub>7</sub> T <sub>8</sub> T <sub>9</sub> T <sub>10</sub> | Jitter<br>Input frequency<br>Input clock rise time<br>Input clock fall time |          | ±175<br>14.318           | ±300<br>20<br>20       | ps<br>MHz<br>ns<br>ns |                                                                       |
|                                                              |                                                                             |          |                          |                        |                       |                                                                       |

### TIMING DIAGRAM





Priliminary

# ST49C158

Printed September 9, 1994

### PREPROGRAMMED CPU MOTHERBOARD FREQUENCY GENERATOR

### GENERAL DESCRIPTION

The ST49C158 is a monolithic analog CMOS device designed to generate eight simultaneous clock outputs for mother board and green PC applications. It is designed in a 1.2 $\mu$  process to achieve 100 MHz operation with low clock jitter. The CPU and 2XCPU outputs are skew controlled within 250 psec.

The ST49C158 is designed for desktop and notebook PC's and supports Energy Star PC's. The ST49C158 can accept 14.318 MHz system clock or external crystal connected between XTAL1 and XTAL2 as the reference clock (reference clock can be changed to generate non-standard frequencies from the standard programmed device).

The ST49C158 is metal mask programmable to provide any custom set of 2XCPU frequencies. The programmed clock outputs are selectable via three address lines for CPU clocks.

### **SOIC Package**

| CPU2  | 1  |              | 24 | A0    |
|-------|----|--------------|----|-------|
| XTAL2 | 2  |              | 23 | A1    |
| XTAL1 | 3  |              | 22 | CPU1  |
| DVCC  | 4  | 4            | 21 | 2XCPU |
| DGND  | 5  | . SF2        | 20 | DVCC  |
| CLK1  | 6  | 280          | 19 | DGND  |
| CLK2  | 7  | 901          | 18 | BCLK  |
| CPU3  | 8  | ST49C158CF24 | 17 | CPU4  |
| AGND  | 9  |              | 16 | AVCC  |
| OE    | 10 |              | 15 | A2    |
| CPU5  | 11 |              | 14 | CPU6  |
| DGND  | 12 |              | 13 | CPU7  |

### **FEATURES**

- Can replace multiple oscillators/crystals
- Pin -to-pin compatible to ICS9158
- Compatible with 286, 386, and 486 CPUs
- Skew controlled 2X and 1X CPU clocks
- Programmable analog phase locked loop
- High speed (up to 100 MHz output)
- Low power single 5V CMOS technology
- Smooth and glitch-free clock transitions
- 24 pin PDIP or SOIC package

### ORDERING INFORMATION

Part number Packag ST49C158CP24 Plasti ST49C158CF24 SOIC

Package Operating temperature
Plastic-DIP 0° C to +70° C
SOIC 0° C to +70° C

### **DIP Package**

|       |    |              | _  |       |
|-------|----|--------------|----|-------|
| CPU2  | 1  |              | 24 | A0    |
| XTAL2 | 2  |              | 23 | A1    |
| XTAL1 | 3  |              | 22 | CPU1  |
| DVCC  | 4  | 24           | 21 | 2XCPU |
| DGND  | 5  | ST49C158CP24 | 20 | DVCC  |
| CLK1  | 6  | 7158         | 19 | DGND  |
| CLK2  | 7  | 490          | 18 | BCLK  |
| CPU3  | 8  | SI           | 17 | CPU4  |
| AGND  | 9  |              | 16 | AVCC  |
| OE    | 10 |              | 15 | A2    |
| CPU5  | 11 |              | 14 | CPU6  |
| DGND  | 12 |              | 13 | CPU7  |
|       |    |              |    |       |

### **BLOCK DIAGRAM**



## **SYMBOL DESCRIPTION**

| Symbol | Pin | Signal Type | Pin Description                                                                        |
|--------|-----|-------------|----------------------------------------------------------------------------------------|
| CPU2   | 1   | 0           | CPU clock output.                                                                      |
| XTAL2  | 2   | 0           | Crystal output.                                                                        |
| XTAL1  | 3   | 1           | Crystal or External clock input.                                                       |
| DVCC   | 4   | 1 .         | Digital supply voltage. Single +5 volts.                                               |
| DGND   | 5   | 0 .         | Digital signal ground.                                                                 |
| CLK1   | 6   | 0           | 16 MHz clock output.                                                                   |
| CLK2   | 7   | 0           | 24 MHz floppy disk clock output.                                                       |
| CPU3   | 8   | 0           | CPU clock output.                                                                      |
| AGND   | 9   | 0           | Analog ground.                                                                         |
| OE     | 10* | 0           | Output Enable (active high). Low on this pin sets all the outputs to three state mode. |
| CPU5   | 11  | 0           | CPU clock output.                                                                      |
| DGND   | 12  | 0           | Digital signal ground.                                                                 |
| CPU7   | 13  | 0           | CPU clock output.                                                                      |
| CPU6   | 14  | 0           | CPU clock output.                                                                      |
| A2     | 15* |             | 1X and 2X CPU clock frequency select address 2.                                        |
| AVCC   | 16  | 1           | Analog supply voltage. Single +5 volts.                                                |
| CPU4   | 17  | 0           | CPU clock output.                                                                      |
| BCLK   | 18  | 0           | Buffered 14.31818 MHz clock output.                                                    |
| DGND   | 19  | 0           | Digital signal ground.                                                                 |
| DVCC   | 20  | <b>l</b> .  | Digital supply voltage. Single +5 volts.                                               |

### SYMBOL DESCRIPTION

| Symbol | Pin | Signal Type | Pin Description                                 |
|--------|-----|-------------|-------------------------------------------------|
| 2XCPU  | 21  | 1           | CPU clock output.                               |
| CPU1   | 22  | 1           | CPU clock output.                               |
| A1     | 23* | 1           | 1X and 2X CPU clock frequency select address 1. |
| A0     | 24* | 1           | CPU clock frequency select address 0.           |

<sup>\*</sup>Have internal pull-up resistor on inputs

### **ACTUAL OUTPUT FREQUENCIES**

CPU CLOCK TABLE FOR ST49C158 (using 14.318 MHz input. All frequencies in MHz).

| A2 A1 A0 |   |     | 2XCPU  | CPU   |  |
|----------|---|-----|--------|-------|--|
| 0        | 0 | 0   | 7.58   | 3.79  |  |
| 0        | 0 | 1   | 15.51  | 7.76  |  |
| 0        | 1 | 0   | 59.87  | 29.93 |  |
| 0        | 1 | 1   | 40.09  | 20.05 |  |
| 1        | 0 | 0   | 50.11  | 25.06 |  |
| 1        | 0 | 1   | 66.47  | 33.24 |  |
| 1        | 1 | 0   | 79.77  | 39.89 |  |
| 1        | 1 | 1 . | 100.23 | 50.11 |  |

## PERIPHERAL CLOCK TABLE CHART FOR ST49C158 (MHz)

| CLK1 | CLK2 |
|------|------|
| 16   | 24   |

### **FREQUENCY TRANSITIONS**

The ST49C158 is designed to provide smooth, glitch-free frequency transitions on the CPU and 2XCPU clocks when the frequency select pins are changed. These frequency transitions are less than 0.1% frequency change per clock period.

### **ABSOLUTE MAXIMUM RATINGS**

Supply voltage Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

### DC ELECTRICAL CHARACTERISTICS

 $T_A$ =0° - 70° C,  $V_{CC}$ =5.0 V ± 10% unless otherwise specified.

| Symbol                                              | Parameter                                                                                                                                              | Min | Limits<br>Typ | Max                     | Units                               | Conditions                                                                                           |
|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------------|-------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------|
| VIL<br>VIH<br>VOL<br>VOH<br>IIL<br>IH<br>ICC<br>RIN | Input low level Input high level Output low level Output high level Input low current Input high current Operating current Internal pull-up resistance | 2.0 | 70<br>680     | 0.8<br>0.4<br>-40<br>40 | V<br>V<br>V<br>μΑ<br>μΑ<br>mA<br>kΩ | $I_{OL}$ = 8.0 mA<br>$I_{OH}$ = -8.0 mA<br>Except pins 2, 10<br>$V_{IN}$ = Vcc<br>No load.<br>Pin 10 |

### **AC ELECTRICAL CHARACTERISTICS**

 $T_A$ =0° - 70° C,  $V_{cc}$ =5.0 V ± 10% unless otherwise specified.

| Symbol                                                               | Parameter                                                                                      | Min      | Limits<br>Typ                | Max                           | Units                 | Conditions                                                            |
|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------|----------|------------------------------|-------------------------------|-----------------------|-----------------------------------------------------------------------|
| T <sub>4</sub><br>T <sub>5</sub><br>T <sub>6</sub><br>T <sub>6</sub> | Output rise time Output fall time Duty cycle Duty cycle                                        | 40<br>40 | 2.5<br>2.5<br>48/52<br>48/52 | 3<br>3<br>60<br>55            | ns<br>ns<br>%<br>%    | 0.8V - 2.0V<br>2.0V - 0.8V<br>1.4V switch point<br>Vcc/2 switch point |
| T <sub>7</sub> T <sub>8</sub> T <sub>9</sub> T <sub>10</sub>         | Jitter, one sigma Jitter, absolute Input frequency Input clock rise time Input clock fall time | 7        | ±85                          | ±100<br>500<br>20<br>20<br>20 | ps<br>ps<br>MHz<br>ns |                                                                       |
|                                                                      |                                                                                                |          |                              |                               | -                     |                                                                       |

### **TIMING DIAGRAM**





Printed September 2, 1994

### PREPROGRAMMED DUAL VIDEO/MEMORY FREQUENCY GENERATOR

#### GENERAL DESCRIPTION

The ST49C214 is a monolithic analog CMOS device designed to generate dual frequency outputs from sixteen possible combinations for video Dot clock frequencies and four memory clock frequencies for high performance video display systems. The ST49C214 is a mask option programmable device to provide different output frequencies for custom applications. It is designed with 1.2 process to achieve 130 MHz speed for high end frequencies.

The ST49C214 is designed to replace existing video clocks generated from individual oscillators, to reduce board space and number of oscillators. To provide high speed and low jitter clock, The ST49C214 utilizes high speed analog CMOS phase locked loop using 14.318 MHz system clock as reference clock (reference clock can be changed to generate optional frequencies from standard programmed device) or external crystal connected between XTAL1 and XTAL2.

The ST49C214 can provide optional clock frequencies, utilizing single layer metal mask option. The programmed clock outputs are selectable via four address lines and address latch enable pin for video Dot clock selection and two address lines for memory clock selection.

#### **FEATURES**

- Can replace multiple oscillators/crystals
- Pin -to-pin compatible to ICS2494, AV9194
- Programmable analog phase locked loop
- High speed (up to 130 MHz output)
- Low power single 5V CMOS technology
- 20 pin dip or SOIC package

#### ORDERING INFORMATION

| Part number     | Package     | Opera | atin | g te | mperati | ıre |
|-----------------|-------------|-------|------|------|---------|-----|
| ST49C214CP20-xx | Plastic-DIP | 0°    | С    | to   | +70°    | С   |
| ST49C214CF20-xx | SOIC        | 0°    | С    | to   | +70°    | С   |
| ST49C214CJ20-xx | PLCC        | 0°    | С    | to   | +70°    | С   |

### **SOIC Package**

| XTAL1    | 1  |              | 20 | DVCC |
|----------|----|--------------|----|------|
| XTAL2    | 2  | 19.00        | 19 | DCLK |
| EXCLK/A4 | 3  |              | 18 | BCLK |
| Α0       | 4  | ,F2(         | 17 | DGND |
| A1       | 5  | 140          | 16 | AGND |
| LEN      | 6  | ST49C214CF20 | 15 | AVCC |
| A2       | 7  | )T4          | 14 | AGND |
| А3       | 8  | "            | 13 | DVCC |
| MAO      | 9  |              | 12 | MCLK |
| DGND     | 10 |              | 11 | MA1  |

### **Plastic-DIP Package**

| XTAL1 1    |              | 20 | DVCC |
|------------|--------------|----|------|
| XTAL2 2    |              | 19 | DCLK |
| EXCLK/A4 3 |              | 18 | BCLK |
| A0 4       | ST49C214CP20 | 17 | DGND |
| A1 5       | 140          | 16 | AGND |
| LEN 6      | 9C2          | 15 | AVCC |
| A2 7       | ST4          | 14 | AGND |
| A3 8       | ,            | 13 | DVCC |
| MA0 9      | -            | 12 | MCLK |
| DGND 10    |              | 11 | MA1  |

### **BLOCK DIAGRAM**



### **SYMBOL DESCRIPTION**

| Symbol | Pin  | Signal Type | Pin Description                                                                                                                                                                                                                   |
|--------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XTAL1  | 1    | I           | Crystal or external clock input. A crystal can be connected to this pin and XTAL2 pin to generate internal phase locked loop reference clock. For external 14.318 MHz clock, XTAL2 is left open or used as buffered clock output. |
| XTAL2  | 2    | 0           | Crystal output.                                                                                                                                                                                                                   |
| EXCLK  | 3*   | 1           | External clock input.                                                                                                                                                                                                             |
| A0     | 4*   | ı           | Dot clock Frequency select address 1.                                                                                                                                                                                             |
| A1     | 5*   | l .         | Dot clock Frequency select address 2.                                                                                                                                                                                             |
| LEN    | . 6* |             | Address latch enable input (active high). To latch selected programmed clock output.                                                                                                                                              |
| A2     | 7*   | 1           | Dot clock Frequency select address 3.                                                                                                                                                                                             |
| A3     | 8*   | 1           | Dot clock Frequency select address 4.                                                                                                                                                                                             |
| мао    | 9*   | .1 .        | Memory clock Frequency select address 1.                                                                                                                                                                                          |
| GND    | 10   | 0           | Digital and Analog ground.                                                                                                                                                                                                        |
| MA1    | 11*  | ı           | Memory clock Frequency select address 2.                                                                                                                                                                                          |
| MCLK   | 12   | 0           | Programmed memory clock output frequency.                                                                                                                                                                                         |
| DVCC   | 13   | 1           | Digital supply voltage. Single +5 volts.                                                                                                                                                                                          |
| GND    | 14   | 0           | Digital and Analog ground.                                                                                                                                                                                                        |
| AVCC   | 15   | 1:          | Analog supply voltage. Single +5 volts.                                                                                                                                                                                           |
| GND    | 16   | . 0         | Digital and Analog ground.                                                                                                                                                                                                        |
| GND    | 17   | 0           | Digital and Analog ground.                                                                                                                                                                                                        |
| вськ   | 18*  | 0           | Buffered crystal clock output frequency.                                                                                                                                                                                          |
| DCLK   | 19   | 0           | Programmed video clock output frequency.                                                                                                                                                                                          |
| DVCC   | 20   | I ,         | Digital supply voltage. Single +5 volts.                                                                                                                                                                                          |

<sup>\*</sup> Have internal pull-up resistor on inputs.

### FREQUENCY SELECT CALCULATION

The ST49C214 contains an analog phase locked loop circuit with a digital closed loop divider and a final series divider to achieve desired dividing ratios for clock output.

The accuracy of the frequencies produced by the ST49C214 depends on the input frequency and final output frequency. The formula for calculating the exact output frequency is as follows:

XCLK = (Reference clock) X (A/B.C)

where A=1,2,3,......127, B=1,2,3,.....127, AND C=1,2,4

For proper output frequency, the ST49C214 can accept reference frequency from 5 - 40 MHz and divider ratio up to 15.

#### **MASK OPTIONS**

The following mask option are provided for custom applications.

\*Any frequency can be in any decoding position.

### **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

### DC ELECTRICAL CHARACTERISTICS

 $T_a=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                   | Parameter                   | Min | Limits<br>Typ | Max  | Units | Conditions                            |
|--------------------------------------------------------------------------|-----------------------------|-----|---------------|------|-------|---------------------------------------|
| <b>V</b> ,,                                                              | Input low level             |     |               | 0.8  | V     |                                       |
| ٧, ا                                                                     | Input high level            | 2.0 |               |      | V     |                                       |
| V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>OL</sub><br>V <sub>OH</sub> | Output low level            |     |               | 0.4  | V     | I <sub>oL</sub> = 8.0 mA              |
| VOL                                                                      | Output high level           | 2.4 |               |      | V     | $I_{OH}^{OE} = 8.0 \text{ mA}$        |
| I                                                                        | Input low current           |     |               | -350 | Α     | Except crystal input                  |
| I <sub>IH</sub>                                                          | Input high current          |     | *.            | 1    | Α     | V <sub>IN</sub> =Vcc                  |
| I <sup>'''</sup> <sub>CC</sub>                                           | Operating current           |     | 20            | 30   | mA    | No load.<br>DCLK=80MHz,<br>MCLK=40MHz |
| R <sub>IN</sub>                                                          | Internal pull-up resistance | 15  | 20            | 25   | K     |                                       |

### **AC ELECTRICAL CHARACTERISTICS**

 $T_A$ =0° - 70°C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                   | Parameter                                                                                                       | Min                        | Limits<br>Typ            | Max                    | Units                      | Conditions                                                            |
|----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|----------------------------|--------------------------|------------------------|----------------------------|-----------------------------------------------------------------------|
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>4</sub> T <sub>5</sub> T <sub>6</sub> T <sub>6</sub> | Enable pulse width Setup time data to enable Hold time to data enable Rise time Fall time Duty cycle Duty cycle | 20<br>20<br>10<br>40<br>45 | 1<br>1<br>48/52<br>48/52 | 1.5<br>1.5<br>60<br>55 | ns<br>ns<br>ns<br>ns<br>s  | 0.8V - 2.0V<br>2.0V - 0.8V<br>1.4V switch point<br>Vcc/2 switch point |
| T <sub>7</sub> T <sub>8</sub> T <sub>9</sub> T <sub>10</sub> T <sub>11</sub>                             | Jitter Input frequency Input clock rise time Input clock fall time Output frequency change                      | 14.318                     | ±8175                    | ±300<br>32<br>20<br>20 | ps<br>MHz<br>ns<br>ns<br>% |                                                                       |





| \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | ST49C214-1 | ST49C214-2 | ST49C214-3 | ST49C214-4 | ST49C214-5                            |
|---------------------------------------|------------|------------|------------|------------|---------------------------------------|
| Video clock<br>address                | Frequency  | Frequency  | Frequency  | Frequency  | Frequency                             |
| (Hex)                                 | (MHz)      | (MHz)      | (MHz)      | (MHz)      | (MHz)                                 |
|                                       | VTAL       | 22.222     | 05.475     | 22.222     | 50.050                                |
| 0                                     | XTAL       | 30.000     | 25.175     | 20.000     | 50.350                                |
|                                       | 65.028     | 77.250     | 28.325     | 24.000     | 56.644                                |
| 2                                     | EXCLK      | EXCLK      | 85.000     | 32.000     | 65.000                                |
| 3                                     | 36.000     | 80.000     | 44.900     | 40.000     | 72.000                                |
| 4                                     | 25.175     | 31.500     | 40.000     | 50.000     | 80.000                                |
| 5                                     | 28.322     | 36.000     | 48.000     | 66.667     | 89.800                                |
| 6                                     | 24.000     | 75.000     | 50.000     | 80.000     | 63.000                                |
| 7                                     | 40.000     | 50.000     | 81.150     | 100.000    | 75.000                                |
| 8                                     | 44.900     | 40.000     | 25.175     | 54.000     | 25.175                                |
| 9                                     | 50.350     | 50.000     | 28.325     | 70.000     | 28.322                                |
| Α                                     | 16.257     | 32.000     | 37.500     | 90.000     | 31.500                                |
| В                                     | 32.514     | 44.900     | 44.900     | 110.000    | 36.000                                |
| С                                     | 56.644     | 25.175     | 40.000     | 25.000     | 40.000                                |
| D                                     | 20.000     | 28.322     | 32.500     | 33.333     | 44.900                                |
| E                                     | 41.539     | 65.000     | 50.000     | 40.000     | 50.000                                |
| F                                     | 80.000     | 36.000     | 65.000     | 50.000     | 65.000                                |
| Memory                                | Frequency  | Frequency  | Frequency  | Frequency  | Frequency                             |
| clock                                 | (MHz)      | (MHz)      | (MHz)      | (MHz)      | (MHz)                                 |
| address                               |            |            |            |            |                                       |
| (Hex)                                 |            |            |            |            | · · · · · · · · · · · · · · · · · · · |
| 0                                     | 32.900     | 36.000     | 36.000     | 16.000     | 40.000                                |
| 1                                     | 35.600     | 44.347     | 40.000     | 24.000     | 41.612                                |
| 2                                     | 43.900     | 37.500     | 45.000     | 50.000     | 44.744                                |
| 3                                     | 49.100     | 44.773     | 50.000     | 66.667     | 50.000                                |
|                                       |            |            |            |            |                                       |

| Compatible with                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ICS-236<br>AV-36 | ICS-242<br>AV-42 | ICS-231 | ICS-244<br>AV-44 | ICS-237 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------|---------|------------------|---------|
| \frac{1}{2} \cdot \frac{1}{2} |                  |                  |         | AV-44            |         |
| Video Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | GD6410           | WD90C30          | ET4000  |                  | ET4000  |

|                                                                         | ST49C214-6                                                                                                                            | ST49C214-8                                                                                                                                          | ST49C214-9                                                                                                                                        | ST49C214-10                                                                                                                                        | ST49C214-16                                                                                                                                  |
|-------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Video clock<br>address<br>(Hex)                                         | Frequency<br>(MHz)                                                                                                                    | Frequency<br>(MHz)                                                                                                                                  | Frequency<br>(MHz)                                                                                                                                | Frequency<br>(MHz)                                                                                                                                 | Frequency<br>(MHz)                                                                                                                           |
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>A<br>B<br>C<br>D<br>E | 25.175<br>28.322<br>40.000<br>65.000<br>44.900<br>50.000<br>75.000<br>25.175<br>28.322<br>EXCLK<br>EXCLK<br>60.000<br>80.000<br>EXCLK | 25.175<br>28.322<br>40.000<br>32.500<br>50.000<br>65.000<br>38.000<br>44.900<br>31.500<br>36.000<br>80.000<br>63.000<br>50.000<br>100.000<br>76.000 | 25.175<br>28.322<br>40.000<br>EXCLK<br>50.000<br>77.000<br>36.000<br>44.889<br>130.00<br>120.00<br>80.000<br>31.500<br>110.00<br>65.000<br>75.000 | 30.250<br>65.000<br>85.000<br>36.000<br>25.175<br>28.322<br>34.000<br>40.000<br>44.900<br>50.350<br>31.500<br>32.500<br>63.000<br>72.000<br>75.000 | XTAL<br>16.257<br>EXCLK<br>32.514<br>25.175<br>28.322<br>24.000<br>40.000<br>XTAL<br>16.257<br>EXCLK<br>36.000<br>25.175<br>28.322<br>24.000 |
| Memory<br>clock<br>address<br>(Hex)                                     | Frequency<br>(MHz)                                                                                                                    | Frequency<br>(MHz)                                                                                                                                  | 72.000<br>Frequency<br>(MHz)                                                                                                                      | Frequency<br>(MHz)                                                                                                                                 | Frequency<br>(MHz)                                                                                                                           |
| 0<br>1<br>2<br>3                                                        | 50.000<br>60.000<br>65.000<br>75.000                                                                                                  | 70.000<br>63.830<br>60.000<br>81.000                                                                                                                | 55.000<br>75.000<br>70.000<br>80.000                                                                                                              | 36.000<br>44.000<br>49.000<br>40.000                                                                                                               | 31.000<br>36.000<br>43.000<br>49.000                                                                                                         |

| Compatible with  | ICS-253   | ICS-263 | ICS-256<br>AV-56 | ICS-266 | ICS-247 |
|------------------|-----------|---------|------------------|---------|---------|
| Video Controller | NCR77C22E | HT216   | S3/86C911        | GDS5410 | GDS5320 |

| Video clock                                                             | ST49C214-17                                                                                                                              | ST49C214-18                                                                                                                                       | ST49C214-19                                                                                                                                       | ST49C214-20                                                                                                                                       | ST49C214-25*                                                                                                                                       |
|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| address                                                                 | Frequency                                                                                                                                | Frequency                                                                                                                                         | Frequency                                                                                                                                         | Frequency                                                                                                                                         | Frequency                                                                                                                                          |
| (Hex)                                                                   | (MHz)                                                                                                                                    | (MHz)                                                                                                                                             | (MHz)                                                                                                                                             | (MHz)                                                                                                                                             | (MHz)                                                                                                                                              |
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>A<br>B<br>C<br>D<br>E | 25.175<br>28.322<br>28.636<br>36.000<br>40.000<br>42.954<br>44.900<br>57.272<br>60.000<br>63.960<br>75.000<br>80.000<br>85.000<br>99.000 | 25.175<br>28.322<br>40.000<br>EXCLK<br>50.000<br>77.000<br>36.000<br>44.889<br>130.00<br>120.00<br>80.000<br>31.500<br>110.00<br>65.000<br>75.000 | 25.175<br>28.322<br>40.000<br>EXCLK<br>50.000<br>77.000<br>36.000<br>44.889<br>130.00<br>120.00<br>80.000<br>31.500<br>110.00<br>65.000<br>75.000 | 50.350<br>56.644<br>33.250<br>52.000<br>80.000<br>63.000<br>EXCLK<br>75.000<br>25.175<br>28.322<br>31.500<br>36.000<br>40.000<br>44.900<br>50.000 | 25.175<br>28.322<br>40.000<br>72.000<br>50.000<br>77.000<br>36.000<br>44.900<br>130.00<br>120.00<br>80.000<br>31.500<br>110.00<br>65.000<br>75.000 |
| F  Memory clock address (Hex)                                           | 108.00                                                                                                                                   | 94.500                                                                                                                                            | 94.500                                                                                                                                            | 65.000                                                                                                                                            | 94.500                                                                                                                                             |
|                                                                         | Frequency                                                                                                                                | Frequency                                                                                                                                         | Frequency                                                                                                                                         | Frequency                                                                                                                                         | Frequency                                                                                                                                          |
|                                                                         | (MHz)                                                                                                                                    | (MHz)                                                                                                                                             | (MHz)                                                                                                                                             | (MHz)                                                                                                                                             | (MHz)                                                                                                                                              |
| 0                                                                       | 64.000                                                                                                                                   | 45.000                                                                                                                                            | 55.000                                                                                                                                            | 40.000                                                                                                                                            | 55.000                                                                                                                                             |
| 1                                                                       | 40.830                                                                                                                                   | 38.000                                                                                                                                            | 75.000                                                                                                                                            | 33.333                                                                                                                                            | 65.000                                                                                                                                             |
| 2                                                                       | 48.000                                                                                                                                   | 52.000                                                                                                                                            | 70.000                                                                                                                                            | 44.000                                                                                                                                            | 70.000                                                                                                                                             |
| 3                                                                       | 60.000                                                                                                                                   | 50.000                                                                                                                                            | 80.000                                                                                                                                            | 50.000                                                                                                                                            | 80.000                                                                                                                                             |
| 4<br>5<br>6<br>7                                                        |                                                                                                                                          |                                                                                                                                                   |                                                                                                                                                   |                                                                                                                                                   | 45.000<br>40.000<br>60.000<br>50.000                                                                                                               |

| Compatible with  | ICS-240     | ICS-275<br>AV-07 | ICS-305 | ICS-260         | CH9294-G   |
|------------------|-------------|------------------|---------|-----------------|------------|
| Video Controller | TI/34010/20 | S3/801/805       | S3/924  | WEITEK<br>W5186 | S3/801/805 |

| Video clock                                                                  | ST49C214-26                                                                                                                                        |  | ST49C214-27                                                                                                                    |
|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|--------------------------------------------------------------------------------------------------------------------------------|
| address<br>(Hex)                                                             | Frequency<br>(MHz)                                                                                                                                 |  | Frequency<br>(MHz)                                                                                                             |
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>A<br>B<br>C<br>D<br>E<br>F | 25.175<br>28.322<br>36.000<br>65.000<br>44.900<br>50.000<br>80.000<br>75.000<br>56.644<br>63.000<br>72.000<br>130.00<br>90.000<br>100.00<br>110.00 |  | 75.000<br>80.000<br>85.000<br>95.000<br>100.00<br>105.00<br>110.00<br>115.00<br>120.00<br>125.00<br>130.00<br>140.00<br>145.00 |
| Memory<br>clock<br>address<br>(Hex)                                          | Frequency<br>(MHz)                                                                                                                                 |  | Frequency<br>(MHz)                                                                                                             |
| 0<br>1<br>2<br>3                                                             | 50.000<br>60.000<br>65.000<br>75.000                                                                                                               |  | 40.000<br>45.000<br>50.000<br>55.000                                                                                           |
| 4<br>5<br>6<br>7                                                             | ,                                                                                                                                                  |  | 60.000<br>65.000<br>70.000<br>75.000                                                                                           |

Compatible with ICS-277
AV-46
Video Controller NCR77C22E+

<sup>\*=</sup>The External clock input pin has been changed to MA2 to privide four additional preprogrammed memory clock selections. When Pin-3 of the ST49C214-25 is connected to ground it is downward compatible to standard ST49C214-XX. This pin contains internal pull-up resistor.





Printed September 2, 1994

### PREPROGRAMMED STEREO CODEC'S CLOCK SYNTHESIZER

#### DESCRIPTION

The ST49C418 is a mask programmable monolithic analog CMOS device, designed to replace existing dual crystals/oscillators with single frequency clock input. The ST49C418 provides high speed and low jitter clock outputs for multi-media stereo codecs.

The ST49C418 interfaces to Analog Devices's AD1848 and Crystal Semiconductor's CS4231 stereo codecs. The ST49C418 provides 16.934 and 24.576 MHz clock outputs utilizing the 14.318 MHz clock input.

ST49C418 is designed in a 1.2μ process to achieve 150 MHz speed for high end frequencies.

### **SOIC Package**

| REFCLK 1 | 82     | 8 GND  |
|----------|--------|--------|
| VCC 2    | 418CF8 | 7 VCC  |
| GND 3    | 8      | 6 GND  |
| CLKA 4   | ST,    | 5 CLKE |

### **FEATURES**

- Programmable analog phase locked loop
- Low power single 5V CMOS technology
- 8 pin DIP or SOIC package
- Programmable input/output frequencies
- TTL compatible outputs
- No external components besides de-coupling capacitors

### Dip Package



### ORDERING INFORMATION

Part number ST49C418CP8 ST49C418CF8 Package Operating temperature
Plastic-DIP 0 ° C to +70 ° C
SOIC 0 ° C to +70 ° C

## ST49C418

### **BLOCK DIAGRAM**



### SYMBOL DESCRIPTION

| Symbol | Pin | Signal Type | Pin Description                                                                               |
|--------|-----|-------------|-----------------------------------------------------------------------------------------------|
| REFCLK | 1   | ı           | External Reference Clock input. REFCLK is used as internal phase locked loop reference clock. |
| vcc .  | 2   | ı           | Supply voltage. Single +5 volts.                                                              |
| GND    | 3   | 0           | Supply ground.                                                                                |
| CLKA   | 4   | 0           | Programmable output clock. Programmed for 16.9344 MHz output.                                 |
| CLKB   | 5   | 0           | Programmable output clock. Programmed for 24.576 MHz output.                                  |
| GND    | 6   | 0           | Supply ground.                                                                                |
| vcc    | 7   | 1 .         | Supply voltage. Single +5 volts.                                                              |
| GND    | 8   | 0           | Supply ground.                                                                                |
|        |     |             |                                                                                               |

### **EXTERNAL CLOCK CONNECTION**

To minimize the noise pickup , it is recommended to connect 0.01 to  $0.047\mu F$  capacitor to REFCLK, and keep the lead length of the capacitor to REFCLK to a minimum to reduce noise susceptibility.

#### FREQUENCY SELECT CALCULATION

The ST49C418 contains an analog phase locked loop circuit with digital closed loop dividers and a final output divider to achieve the desired dividing ratios for the clock output.

The accuracy of the frequencies produced by the ST49C418 depends on the input frequency and divider ratios. The formula for calculating the exact output frequency is as follows:

CLOCK = (Reference clock) X A/(B.C)

where A=5, 6, 7,......128 B=5, 6, 7,......128

C=2

For proper output frequency, the ST49C418 can accept a reference frequency from 5 - 40 MHz and divider ratio up to 15.

#### **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

### DC ELECTRICAL CHARACTERISTICS

 $T_A=25^{\circ}$  C,  $V_{cc}=5.0$  V  $\pm$  5% unless otherwise specified.

| Symbol                                                                                                         | Parameter                                                                                                | Min | Limits<br>Typ | Max                   | Units                   | Conditions                                                     |
|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-----|---------------|-----------------------|-------------------------|----------------------------------------------------------------|
| V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>OL</sub><br>V <sub>OH</sub><br>I <sub>IH</sub><br>I <sub>CC</sub> | Input low level Input high level Output low level Output high level Input high current Operating current | 2.0 | 20            | 0.8<br>0.5<br>1<br>25 | V<br>V<br>V<br>μA<br>mA | I <sub>oL</sub> = 25 mA<br>I <sub>oH</sub> = 25 mA<br>No load. |

#### **AC ELECTRICAL CHARACTERISTICS**

 $T_A=25^{\circ}$  C,  $V_{CC}=5.0$  V ± 5% unless otherwise specified.

| Symbol                                                                                      | Parameter                                                                                           | Min           | Limits<br>Typ                             | Max                                  | Units                                | Conditions                                                            |
|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|---------------|-------------------------------------------|--------------------------------------|--------------------------------------|-----------------------------------------------------------------------|
| T <sub>1</sub> T <sub>2</sub> T <sub>4</sub> T <sub>5</sub> T <sub>3</sub> T T <sub>6</sub> | CLOCK rise time CLOCK fall time Duty cycle Duty cycle Jitter Input frequency CLOCK frequency change | 40<br>45<br>5 | 1<br>48/52<br>48/52<br>±175<br>10<br>0.01 | 1.5<br>1.5<br>60<br>55<br>±300<br>40 | ns<br>ns<br>%<br>%<br>ps<br>MHz<br>% | 0.5V - 2.8V<br>2.8V - 0.5V<br>1.4V switch point<br>VCC/2 switch point |

# ST49C418

ST49C418





# Index

| ST26C31 | 2-3  |
|---------|------|
| ST26C32 |      |
| ST31C32 |      |
| ST34C50 | 2-15 |
| ST34C51 | 2-15 |
| ST34C86 |      |
| ST34C87 | 2-21 |



# ST26C31

Printed September 6, 1994

#### **QUAD RS-422 CMOS DIFFERENTIAL LINE DRIVER**

#### **DESCRIPTION**

The ST26C31 is a CMOS quad differential line driver designed to meet the standard RS-422 requirements and digital data transmission over balanced lines. To improve noise margin and output stability for slow changing input signals special hysteresis is built in the ST26C31 circuit.

The ST26C31 is a high speed CMOS line driver designed to operate with MFM / RLL controllers and hard disk drives as well as RS-422 digital data transmission applications. ST26C31 is suitable for low power 5V operation with high input voltage protection devices.

#### **SOIC** package

| INPUT A 1   |             | 16 VCC       |
|-------------|-------------|--------------|
| OUTPUT A+ 2 |             | 15 INPUT D   |
| OUTPUT A- 3 | F16         | 14 OUTPUT D+ |
| ENABLE 4    | 70          | 13 OUTPUT D- |
| OUTPUT B- 5 | ည်          | 12 ENABLE*   |
| OUTPUT B+ 6 | ST26C31CF16 | 11 ООТРОТ С- |
| INPUT B 7   |             | 10 OUTPUT C+ |
| GND 8       |             | 9 INPUT C    |

#### **FEATURES**

- Pin-to-pin compatible with National DS26C31C
- · Low power CMOS design
- Three-state outputs with enable pin
- Meets the EIA RS-422 requirements
- · Low propagation delays
- · High speed

# Plastic-DIP package

| INPUT A 1   |             | 16 VCC       |
|-------------|-------------|--------------|
| OUTPUT A+ 2 |             | 15 INPUT D   |
| OUTPUT A- 3 | P16         | 14 OUTPUT D+ |
| ENABLE 4    | ST26C31CP16 | 13 OUTPUT D- |
| OUTPUT B- 5 | ပို့        | 12 ENABLE*   |
| OUTPUT B+ 6 | ST2         | 11 OUTPUT C- |
| INPUT B 7   | -           | 10 OUTPUT C+ |
| GND 8       |             | 9 INPUT C    |

#### ORDERING INFORMATION

 Part number
 Package
 Operating temperature

 ST26C31CP16
 Plastic-DIP
 0° C to + 70° C

 ST26C31CF16
 SOIC
 0° C to + 70° C

 ST26C31IP16
 Plastic-DIP
 -40° C to + 85° C

 ST26C31IF16
 SOIC
 -40° C to + 85° C

# **BLOCK DIAGRAM**



# SYMBOL DESCRIPTION

| Symbol    | Pin  | Signal Type | Pin Description                                                                                                                                                    |
|-----------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INPUT A   | 1    | I           | Driver A input pin.                                                                                                                                                |
| OUTPUT A+ | 2    | 0           | Driver A differential non-inverting output pin.                                                                                                                    |
| OUTPUT A- | 3    | 0           | Driver A differential inverting output pin.                                                                                                                        |
| ENABLE    | 4    | l           | Gate control (active high). This pin is one of the two control pins which enables or disables all four drivers. All four drivers are gated with two input or gate. |
| ОИТРИТ В- | 5    | 0           | Driver B differential inverting output pin.                                                                                                                        |
| OUTPUT B+ | 6    | . 0         | Driver B differential non-inverting output pin.                                                                                                                    |
| INPUT B   | 7    | l l         | Driver B input pin.                                                                                                                                                |
| GND       | 8    | 0           | Signal and power ground.                                                                                                                                           |
| INPUT C   | 9    | l           | Driver C input pin.                                                                                                                                                |
| OUTPUT C+ | 10   | 0           | Driver C differential non-inverting output pin.                                                                                                                    |
| OUTPUT C- | 11 . | 0           | Driver C differential inverting output pin.                                                                                                                        |
| ENABLE*   | 12   | I           | Gate control (active low). See ENABLE pin description.                                                                                                             |
| OUTPUT D- | 13   | 0           | Driver D differential inverting output pin.                                                                                                                        |
| OUTPUT D+ | 14   | 0           | Driver D differential non-inverting output pin.                                                                                                                    |
| INPUT D   | 15   | l           | Driver D input pin.                                                                                                                                                |
| vcc       | 16   | <u>i</u>    | Power supply pin.                                                                                                                                                  |

#### Functional table

| Enable | Enable* | Input                           | Differential<br>Non-Inverting<br>Output | Differential<br>Inverting<br>Output |
|--------|---------|---------------------------------|-----------------------------------------|-------------------------------------|
|        | H H H   | X<br>L<br>H<br>L<br>H<br>L<br>H | Z<br>L<br>H<br>L<br>H<br>L              | Z<br>H<br>L<br>H<br>L               |

X=Don't care

Z=Three state (high impedance)



# **AC ELECTRICAL CHARACTERISTICS**

 $T_A = 0^{\circ} - 70^{\circ} C$ , Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                      | Parameter                                                                                                             | Min | Limits<br>Typ      | Max                        | Units                | Conditions                                            |
|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-----|--------------------|----------------------------|----------------------|-------------------------------------------------------|
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>4</sub> *T <sub>5</sub> | Propagation delay, input to output Differential output rise and fall time Output enable time Output disable time Skew |     | 8<br>8<br>18<br>18 | 10<br>10<br>20<br>20<br>20 | ns<br>ns<br>ns<br>ns | S1 open<br>S1 open<br>S1 close<br>S1 close<br>S1 open |

<sup>\*</sup> Skew is defined as the difference in propagation delays between complementary outputs at the 50% point.

# **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

# DC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol           | Parameter                        | Min | Limits<br>Typ | Max  | Units | Conditions                  |
|------------------|----------------------------------|-----|---------------|------|-------|-----------------------------|
| I <sub>IN</sub>  | Input current                    |     | ,             | ±1.0 | mA    |                             |
| Icc              | Operating current                | 1   | 200           |      | mA.   |                             |
|                  | Three state output leakage       |     | ±2.0          |      | mA.   |                             |
| V <sub>IH</sub>  | Input high level                 | 2.0 |               |      | · V   |                             |
| V.,              | Input low level                  |     |               | 0.8  | V     |                             |
| $V_{OH}$ .       | Output high level                | 2.5 |               |      | V     |                             |
| V                | Output low level                 |     |               | 0.5  | V     |                             |
| V <sub>Os</sub>  | Differential output level        | 2.0 |               |      | V .   | R,=100W                     |
| Voc              | Common mode output voltage       |     |               | 3.0  | V     | R,=100W                     |
| V <sub>od</sub>  | Difference in common mode output |     |               | 0.4  | V     | R,=100W                     |
| $C_{iN}$         | Input capacitance                | 7   | 10            | 15   | pF    | _                           |
| C <sub>PD</sub>  | Power dissipation capacitance    |     | 100           |      | pF    |                             |
| los              | Output short current             | -30 |               | -150 | mA    | V <sub>IN</sub> =VCC or GND |
| I <sub>OFF</sub> | Output leakage current power off |     |               | 100  | mA    | Vout=6V                     |
|                  |                                  |     |               | -100 | mA.   | Vout=0.25V                  |
| I <sub>DC</sub>  | Output current                   | 1   |               | ±150 | mA    |                             |

#### DIFFERENTIAL LINE DRIVER TIMING







Printed September 6, 1994

# QUAD RS-422, RS-423 CMOS DIFFERENTIAL LINE RECEIVER

#### DESCRIPTION

The ST26C32 is a CMOS quad differential line receiver designed to meet the standard RS-422, RS-423 requirements. The ST26C32 has an input sensitivity of 200mv over the common mode input voltage range of  $\pm 7V$ . To improve noise margin and output stability for slow changing input signal, special hysteresis is built in the ST26C32 circuit.

The ST26C32 is a high speed line receiver designed to operate with MFM / RLL controllers and hard disk drives as well as RS-422, and RS-423 differential applications. ST26C32 provides TTL compatible outputs to interface with standard 74LS and CMOS design environments. ST26C32 is suitable for low power 5V operation.

#### SOIC package

| INPUT A- 1 |             | 16 VCC      |
|------------|-------------|-------------|
| INPUT A+ 2 |             | 15 INPUT D- |
| OUTPUT A 3 | ST26C32CF16 | 14 INPUT D+ |
| ENABLE 4   | 35C         | 13 OUTPUT D |
| OUTPUT B 5 | )<br>မွ     | 12 ENABLE*  |
| INPUT B+ 6 | STZ         | 11 OUTPUT C |
| INPUT B- 7 |             | 10 INPUT C+ |
| GND 8      |             | 9 INPUT C-  |

#### **FEATURES**

- Pin-to-pin compatible with National DS26C32C
- Low power CMOS design
- Three-state outputs with enable pin
- Meets the EIA RS-422 requirements
- Low propagation delays
- · High speed

### Plastic-DIP package

| INPUT A- 1 |       | 16 VCC      |
|------------|-------|-------------|
| INPUT A+ 2 |       | 15 INPUT D- |
| OUTPUT A 3 | P16   | 14 INPUT D+ |
| ENABLE 4   | 32CP  | 13 OUTPUT D |
| OUTPUT B 5 | ပ္ထဲ  | 12 ENABLE*  |
| INPUT B+ 6 | ST26( | 11 OUTPUT C |
| INPUT B- 7 |       | 10 INPUT C+ |
| GND 8      |       | 9 INPUT C-  |

#### ORDERING INFORMATION

| Part number | Package     | Operating temperature |
|-------------|-------------|-----------------------|
| ST26C32CP16 | Plastic-DIP | 0° C to + 70° C       |
| ST26C32CF16 | SOIC        | 0° C to + 70° C       |
| ST26C32IP16 | Plastic-DIP | -40° C to +85° C      |
| ST26C32IF16 | SOIC        | -40° C to ± 85° C     |

# **BLOCK DIAGRAM**



# **SYMBOL DESCRIPTION**

| Symbol   | Pin | Signal Type | Pin Description                                                                                                   |
|----------|-----|-------------|-------------------------------------------------------------------------------------------------------------------|
| INPUT A- | 1   | I           | Receiver A differential inverting input pin.                                                                      |
| INPUT A+ | 2   | l           | Receiver A differential non-inverting input pin.                                                                  |
| OUTPUT A | 3   | 0           | Receiver A output pin.                                                                                            |
| ENABLE   | 4   | ı           | Gate control (active high). This pin is one of the two control pins which enables or disables all four receivers. |
| ОИТРИТ В | 5   | 0           | Receiver B output pin.                                                                                            |
| INPUT B+ | 6   | 1           | Receiver B differential non-inverting input pin.                                                                  |
| INPUT B- | 7   | 1           | Receiver B differential inverting input pin.                                                                      |
| GND      | 8   | 0           | Signal and power ground.                                                                                          |
| INPUT C- | 9   | 1           | Receiver C differential inverting input pin.                                                                      |
| INPUT C+ | 10  | 1           | Receiver C differential non-inverting input pin.                                                                  |
| оитрит с | 11  | 0           | Receiver C output pin.                                                                                            |
| ENABLE * | 12  | l           | Gate control (active low). See ENABLE description                                                                 |
| оитрит D | 13  | 0           | Receiver D output pin.                                                                                            |
| INPUT D+ | 14  | I           | Receiver D differential non-inverting input pin.                                                                  |
| INPUT D- | 15  | ı           | Receiver D differential inverting input pin.                                                                      |
| vcc      | 16  | ı           | Power supply pin.                                                                                                 |

# Functional table

| Enable | Enable* | Output | Differential<br>Non-Inverting<br>Input | Differential<br>Inverting<br>Input |
|--------|---------|--------|----------------------------------------|------------------------------------|
| L      | H       | Z      | ×                                      | X                                  |
| H      | L       | H      | H                                      | L                                  |

X=Don't care

Z=Three state (high impedance)



# **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                      | Parameter                                                                                                             | Min | Limits<br>Typ       | Max                        | Units                | Conditions                                                           |
|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-----|---------------------|----------------------------|----------------------|----------------------------------------------------------------------|
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>4</sub> | Propagation delay, input to output<br>Propagation delay, input to putput<br>Output enable time<br>Output disable time |     | 8<br>18<br>18<br>18 | 10<br>20<br>20<br>20<br>20 | ns<br>ns<br>ns<br>ns | S1=VCC<br>S1=GND<br>V <sub>DIF</sub> =2.5V<br>V <sub>DIF</sub> =2.5V |

#### **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any logic pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

#### DC ELECTRICAL CHARACTERISTICS

 $T_{\Delta}$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                | Parameter                                       | Min  | Limits<br>Typ | Max  | Units     | Conditions                                                  |
|-------------------------------------------------------|-------------------------------------------------|------|---------------|------|-----------|-------------------------------------------------------------|
| V <sub>IH</sub>                                       | Enable high level Enable low level              | 2.0  |               | 0.8  | V<br>V    |                                                             |
| V <sub>IL</sub><br>V <sub>OH</sub><br>V <sub>OL</sub> | Output high level Output low level              | 3.8  | 4.2<br>0.2    | 0.4  | v<br>V    | I <sub>oH</sub> = -6mA<br>I <sub>oH</sub> = 6mA             |
| V <sub>ID</sub><br>V <sub>H</sub>                     | Differential input level Input hysteresis       | -0.2 | 50            | +0.2 | V<br>mV   | -7V < V <sub>CM</sub> < +7V                                 |
| In                                                    | Input current Operating current                 |      | 200           | ±1.0 | mA<br>μA  | V <sub>DIF</sub> =+1V                                       |
| cc<br>l <sub>oz</sub><br>l <sub>en</sub>              | Three state output leakage Enable input current |      | ±1.0<br>±1.0  | ±5.0 | μA<br>mA  | V <sub>OUT</sub> =VCC or GND<br>V <sub>IN</sub> =VCC or GND |
| V <sub>R</sub>                                        | Input resistance                                |      | 10            |      | $K\Omega$ | -7V < V <sub>CM</sub> < +7V                                 |

# DIFFERENTIAL LINE RECEIVER TIMING





Printed September 6, 1994

#### DUAL RS-422, RS-423 CMOS DIFFERENTIAL LINE RECEIVER AND DRIVER

#### **GENERAL DESCRIPTION**

The ST34C50/51 is a CMOS dual differential line receiver and driver, designed to meet the standard RS-422, RS-423 requirements and digital data transmission over balanced lines. The ST34C50/51 has an input sensitivity of 200mv over the common mode input voltage range of  $\pm$  7V. To improve noise margin and output stability for slow changing input signal, special hysteresis is built in the ST34C50/51 circuit. The ST34C50/51 is a high speed line receiver and driver, designed to operate with MFM/RLL controllers and hard disk drives as well as RS-422 and RS-423 differential applications. ST34C50/51 provides TTL compatible outputs to interface with standard 74LS and CMOS design environments, ST34C50/51 is suitable for low power 5V operation with minimum board space requirements. ST34C50/51 provides dual differential line receiver with three state control pin and dual line driver with three state control capability.

#### **FEATURES**

- Pin -to-pin compatible to Motorola MC34050 and MC34051
- Low power CMOS design
- Three-state outputs with enable pin
- Meets the EIA RS-422/423 requirements
- Low propagation delays
- High speed
- Dual line receiver with three state control
- Dual line driver with three state control

#### ORDERING INFORMATION

| Part number | Package     | Operating temperature |
|-------------|-------------|-----------------------|
| ST34C50CP16 | Plastic-DIP | 0° C to + 70° C       |
| ST34C50CF16 | SOIC        | 0° C to + 70° C       |
| ST34C50IP16 | Plastic-DIP | -40° C to +85° C      |
| ST34C50IF16 | SOIC        | -40° C to +85° C      |
| ST34C51IP16 | Plastic-DIP | -40° C to +85° C      |
| ST34C51IF16 | SOIC        | -40° C to +85° C      |

#### **SOIC Package**

| INPUT A- 1     |        | 16 VCC        |
|----------------|--------|---------------|
| INPUT A+ 2     |        | 15 INPUT D-   |
| OUTPUT A 3     | F16    | 14 INPUT D+   |
| ENABLE A*/B* 4 | 250CF1 | 13 OUTPUT D   |
| OUTPUT B 5     |        | 12 ENABLE C/D |
| INPUT B+ 6     | ST34   | 11 OUTPUT C   |
| INPUT B- 7     |        | 10 INPUT C+   |
| GND 8          |        | 9 INPUT C-    |

ST34C50CF

# **SOIC Package**

| INPUT A- 1 |          | 16 VCC      |
|------------|----------|-------------|
| INPUT A+ 2 |          | 15 INPUT D- |
| OUTPUT A 3 | F16      | 14 INPUT D+ |
| ENABLE D 4 | C51CF16  | 13 OUTPUT D |
| OUTPUT B 5 | 4.<br>Y. | 12 ENABLE C |
| INPUT B+ 6 | ST34     | 11 OUTPUT,C |
| INPUT B- 7 |          | 10 INPUT C+ |
| GND 8      |          | 9 INPUT C-  |

**ST34C51CF** 

# ST34C50 BLOCK DIAGRAM



# **ST34C51 BLOCK DIAGRAM**



# **SYMBOL DESCRIPTION**

| Symbol     | Pin  | Signal Type | Pin Description                                                                                                                            |
|------------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| INPUT A-   | 1    | I           | Receiver A differential inverting input pin.                                                                                               |
| INPUT A+   | 2    | 1           | Receiver A differential non-inverting input pin.                                                                                           |
| OUTPUT A   | 3    | 0,          | Receiver A output pin.                                                                                                                     |
| ENABLE A/B | 4    | 1           | Gate control (active low, ST34C50 only). This pin enables/disables the two line receiver outputs (out A and out B of ST34C50).             |
| ENABLE D   | , 4* |             | Gate control (active high, ST34C51 only). This pin enables/disables the ST34C51differential line driver D section.                         |
| оитрит в   | 5    | 0           | Receiver B output pin.                                                                                                                     |
| INPUT B +  | 6    | 1           | Receiver B differential non-inverting input pin.                                                                                           |
| INPUT B -  | 7,   | . 1         | Receiver B differential inverting input pin.                                                                                               |
| GND        | 8    | 0           | Signal and power ground.                                                                                                                   |
| INPUT C    | 9    | . 1         | Driver C input pin.                                                                                                                        |
| OUTPUT C+  | 10   | 0           | Driver C differential non-inverted output pin.                                                                                             |
| оитрит с - | 11   | 0           | Driver C differential inverted output pin.                                                                                                 |
| ENABLE C/D | 12   | 1           | Gate control (active high, ST34C50 only). This pin enables/<br>disables the two line driver outputs (output C and output D<br>of ST34C50). |
| ENABLE C   | 12*  | <b>1</b>    | Gate control (active high, ST34C51 only). This pin enables/disables the ST34C51differential line driver C section.                         |
| OUTPUT D - | 13   | 0           | Driver D differential inverted output pin.                                                                                                 |
| OUTPUT D+  | 14   | 0           | Driver D differential non-inverted output pin.                                                                                             |
| INPUT D    | 15   | 1.          | Driver D input pin.                                                                                                                        |
| vcc        | 16   | I           | Power supply pin.                                                                                                                          |

#### Receiver Functional table (ST34C50 only)

| Enable<br>A/B | Output | Differential<br>Non-Inverting<br>Input | Differential<br>Inverting<br>Input |
|---------------|--------|----------------------------------------|------------------------------------|
| Н             | z      | X                                      | Х                                  |
| L             | L      | L                                      | Н                                  |
| L             | Н      | Н                                      | L                                  |

X=Don't care

Z=Three state (high impedance)

Receive sections of the ST34C51 are enabled all the time.

#### **Driver Functional table (ST34C50 only)**

| Enable<br>C/D | Input | Differential<br>Non-Inverted<br>Output | Differential<br>Inverted<br>Output |
|---------------|-------|----------------------------------------|------------------------------------|
| L             | Х     | Z                                      | Z                                  |
| Н             | L     | L                                      | H-                                 |
| н             | Н     | Н                                      | L                                  |

# \*Driver Functional table (ST34C51 only)

| Enable<br>C or D | Input | Differential<br>Non-Inverted<br>Output | Differential<br>Inverted<br>Output |
|------------------|-------|----------------------------------------|------------------------------------|
| L                | X     | Z                                      | Z                                  |
| H                | L     | L                                      | H                                  |
| H                | H     | H                                      | L                                  |

X=Don't care

Z=Three state (high impedance)

#### ST34C50/51 DRIVER AC TEST CIRCUIT



<sup>\*</sup> for each section of ST34C51.

# **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70°C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                      | Parameter                              | Min | Limits<br>Typ | Max | Units | Conditions             |
|-----------------------------------------------------------------------------|----------------------------------------|-----|---------------|-----|-------|------------------------|
|                                                                             | Line driver section                    |     |               |     |       |                        |
| T,                                                                          | Propagation delay, input to output     |     | 8             | 10  | ns    | S1 open                |
| Τ,                                                                          | Differential output rise and fall time |     | - 8           | 10  | ns ·  | S1 open                |
| T,                                                                          | Output enable time                     |     | 18            | 20  | ns    | S1 close               |
| T <sub>4</sub>                                                              | Output disable time                    |     | 18            | 20  | ns    | S1 close               |
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>4</sub> *T <sub>5</sub> | Skew                                   |     |               | 2   | ns    | S1 open                |
|                                                                             | Line receiver section                  |     |               |     |       |                        |
| Т.                                                                          | Propagation delay, input to output     |     | 8             | 10  | ns    | S1=VCC                 |
| T <sub>1</sub><br>T <sub>2</sub><br>T <sub>3</sub><br>T <sub>4</sub>        | Propagation delay, input to putput     |     | 18            | 20  | ns    | S1=GND                 |
| T <sub>3</sub>                                                              | Output enable time                     |     | 18            | 20  | ns    | V <sub>DIF</sub> =2.5V |
| T <sub>4</sub>                                                              | Output disable time                    |     | 18            | 20  | ns    | V <sub>DIF</sub> =2.5V |

<sup>\*</sup> Skew is defined as the difference in propagation delays between complementary outputs at the 50% point.

#### ST34C50/51 RECEIVER AC TEST CIRCUIT



#### **ABSOLUTE MAXIMUM RATINGS**

Operating supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

# DC ELECTRICAL CHARACTERISTICS

 $T_A$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                    | Parameter                                                                                                                                                                                                                                                                                                                                                                                                                         | Min                              | Limits<br>Typ           | Max                                                     | Units | Conditions                                                          |
|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-------------------------|---------------------------------------------------------|-------|---------------------------------------------------------------------|
| VIH VIL VROH VROL VRID VRH IRIN VRR ICC IOZ VDOH VDOL VDOS VDOC VDOD IDIN | Enable high level Enable low level Receiver output high level Receiver output low level Receiver differential input level Receiver input hysteresis Receiver input current Receiver input resistance Operating current Three state output leakage Driver input high level Driver output low level Driver differential output level Driver Common mode output voltage Driver difference in common mode output Driver input current | 2.0<br>3.8<br>-0.2<br>2.5<br>2.0 | 50<br>10<br>200<br>±2.0 | 0.8<br>0.4<br>+0.2<br>±1.0<br>0.5<br>3.0<br>0.4<br>±1.0 | >>>>> | $R_{L}$ =100 $Ω$ $R_{L}$ =100 $Ω$ $R_{L}$ =100 $Ω$ $R_{L}$ =100 $Ω$ |

#### DIFFERENTIAL LINE DRIVER TIMING





#### **DIFFERENTIAL LINE RECEIVER TIMING**





# ST34C86

Printed September 6, 1994

# QUAD RS-422, RS-423 CMOS DIFFERENTIAL LINE RECEIVER

#### **GENERAL DESCRIPTION**

The ST34C86 is a CMOS quad differential line receiver designed to meet the standard RS-422, RS-423 requirements. The ST34C86 has an input sensitivity of 200mv over the common mode input voltage range of  $\pm$  7V. To improve noise margin and output stability for slow changing input signal, special hysteresis is built in the ST34C86 circuit.

The ST34C86 is a high speed line receiver designed to operate with MFM / RLL controllers and hard disk drives as well as RS-422 and RS-423 differential applications. ST34C86 provides TTL compatible outputs to interface with standard 74LS and CMOS design environments. ST34C86 is suitable for low power 5V operation.

#### SOIC package

| INPUT A- 1   |         | 16 VCC        |
|--------------|---------|---------------|
| INPUT A+ 2   | F16     | 15 INPUT D-   |
| OUTPUT A 3   |         | 14 INPUT D+   |
| ENABLE A/B 4 | 286CF16 | 13 OUTPUT D   |
| OUTPUT B 5   | 4       | 12 ENABLE C/I |
| INPUT B+ 6   | ST3     | 11 OUTPUT C   |
| INPUT B- 7   |         | 10 INPUT C+   |
| GND 8        |         | 9 INPUT C-    |

#### **FEATURES**

- Pin-to-pin compatible with National DS34C86
- · Low power CMOS design
- · Three-state outputs with enable pin
- · Meets the EIA RS-422 requirements
- · Low propagation delays
- High speed

# Plastic-DIP package



#### ORDERING INFORMATION

| Part number | Package     | Operating temperature |
|-------------|-------------|-----------------------|
| ST34C86CP16 | Plastic-DIP | 0° C to + 70° C       |
| ST34C86CF16 | SOIC        | 0° C to + 70° C       |
| ST34C86IP16 | Plastic-DIP | -40° C to +85° C      |
| ST34C86IF16 | SOIC        | -40° C to + 85° C     |

# **BLOCK DIAGRAM**



# SYMBOL DESCRIPTION

| Symbol     | Pin | Signal Type | Pin Description                                                                                              |
|------------|-----|-------------|--------------------------------------------------------------------------------------------------------------|
| INPUT A-   | 1   | I           | Receiver A differential inverting input pin.                                                                 |
| INPUT A+   | 2   | 1           | Receiver A differential non-inverting input pin.                                                             |
| OUTPUT A   | 3   | 0           | Receiver A output pin.                                                                                       |
| ENABLE A/B | 4   | 1 ·         | Gate control (active high). This pin enables/disables the two line receiver outputs (out A and out B).       |
| оитрит в   | 5   | 0           | Receiver B output pin.                                                                                       |
| INPUT B+   | 6   | 1           | Receiver B differential non-inverting input pin.                                                             |
| INPUT B-   | 7   | 1 .         | Receiver B differential inverting input pin.                                                                 |
| GND        | 8   | 0           | Signal and power ground.                                                                                     |
| INPUT C-   | 9   | 1           | Receiver C differential inverting input pin.                                                                 |
| INPUT C+   | 10  | Ι           | Receiver C differential non-inverting input pin.                                                             |
| оитрит с   | 11  | 0           | Receiver C output pin.                                                                                       |
| ENABLE C/D | 12  | l           | Gate control (active high). This pin enables/disables the two line receiver outputs (output C and output D). |
| OUTPUT D   | 13  | 0           | Receiver D output pin.                                                                                       |
| INPUT D+   | 14  | ı           | Receiver D differential non-inverting input pin.                                                             |
| INPUT D-   | 15  | ı           | Receiver D differential inverting input pin.                                                                 |
| vcc        | 16  | <b>I</b>    | Power supply pin.                                                                                            |

# Functional table

| Enable<br>A/B<br>C/D | Output | Differential<br>Non-Inverting<br>Input | Differential<br>Inverting<br>Input |
|----------------------|--------|----------------------------------------|------------------------------------|
| L                    | z      | X                                      | ×                                  |
| Н                    | L      | L                                      | H                                  |
| Н                    | Н      | Н                                      | L                                  |

X=Don't care

Z=Three state (high impedance)



# **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                      | Parameter                                                                                                             | Min | Limits<br>Typ       | Max                  | Units          | Conditions                                                           |
|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-----|---------------------|----------------------|----------------|----------------------------------------------------------------------|
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>4</sub> | Propagation delay, input to output<br>Propagation delay, input to putput<br>Output enable time<br>Output disable time |     | 8<br>18<br>18<br>18 | 10<br>20<br>20<br>20 | ns<br>ns<br>ns | S1=VCC<br>S1=GND<br>V <sub>DIF</sub> =2.5V<br>V <sub>DIF</sub> =2.5V |

#### **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any logic pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

### DC ELECTRICAL CHARACTERISTICS

 $T_{\Delta}$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                                                                                        | Parameter                                                                                                                                                                                                        | Min                | Limits<br>Typ                           | Max                                | Units                   | Conditions                                                                                                                                            |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------------------------------|------------------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>IH</sub> V <sub>IL</sub> V <sub>OH</sub> V <sub>OL</sub> V <sub>ID</sub> V <sub>H</sub> I <sub>IN</sub> I <sub>CC</sub> I <sub>OZ</sub> I <sub>EN</sub> V <sub>R</sub> | Enable high level Enable low level Output high level Output low level Differential input level Input hysteresis Input current Operating current Three state output leakage Enable input current Input resistance | 2.0<br>3.8<br>-0.2 | 4.2<br>0.2<br>50<br>200<br>±1.0<br>±1.0 | 0.8<br>0.4<br>+0.2<br>±1.0<br>±5.0 | >>>>> m A A A A A A K G | $I_{OH} = -6mA$ $I_{OH} = 6mA$ $-7V < V_{CM} < +7V$ $V_{DIF} = +1V$ $V_{OUT} = VCC \text{ or GND}$ $V_{IN} = VCC \text{ or GND}$ $-7V < V_{CM} < +7V$ |

#### DIFFERENTIAL LINE RECEIVER TIMING





# ST34C87

Printed September 12, 19

#### QUAD RS-422 CMOS DIFFERENTIAL LINE DRIVER

#### GENERAL DESCRIPTION

The ST34C87 is a CMOS quad differential line driver designed to meet the standard RS-422 requirements and digital data transmission over balanced lines. To improve noise margin and output stability for slow changing input signals special hysteresis is built in the ST34C87 circuit.

The ST34C87 is a high speed CMOS line driver designed to operate with MFM / RLL controllers and hard disk drives as well as RS-422 digital data transmission applications. ST34C87 is suitable for low power 5V operation with high input voltage protection devices.

#### SOIC package

| INPUT A 1    |             | 16 VCC        |
|--------------|-------------|---------------|
| OUTPUT A+ 2  | -16         | 15 INPUT D    |
| OUTPUT A- 3  |             | 14 OUTPUT D+  |
| ENABLE A/B 4 | 2           | 13 OUTPUT D-  |
| OUTPUT B- 5  | <u>\$</u>   | 12 ENABLE C/C |
| OUTPUT B+ 6  | ST34C87CF16 | 11 OUTPUT C-  |
| INPUT B 7    |             | 10 OUTPUT C+  |
| GND 8        | İ           | 9 INPUT C     |

#### **FEATURES**

- Pin-to-pin compatible with National DS34C87
- Low power CMOS design
- Three-state outputs with enable pin
- Meets the EIA RS-422 requirements
- Low propagation delays
- High speed

# Plastic-DIP package

| INPUT A 1    |         | 16 VCC        |
|--------------|---------|---------------|
| OUTPUT A+ 2  |         | 15 INPUT D    |
| OUTPUT A- 3  | P16     | 14 OUTPUT D+  |
| ENABLE A/B 4 | C87CP16 | 13 OUTPUT D-  |
| OUTPUT B- 5  | 408     | 12 ENABLE C/D |
| OUTPUT B+ 6  | ST3     | 11 OUTPUT C-  |
| INPUT B 7    |         | 10 OUTPUT C+  |
| GND 8        | ·       | 9 INPUT C     |

#### ORDERING INFORMATION

 Part number
 Package
 Operating
 temperature

 ST34C87CP16
 Plastic-DIP
 0° C to + 70° C

 ST34C87CF16
 SOIC
 0° C to + 70° C

 ST34C87IP16
 Plastic-DIP
 -40° C to + 85° C

 ST34C87IF16
 SOIC
 -40° C to + 85° C

#### **BLOCK DIAGRAM**



# SYMBOL DESCRIPTION

| Symbol     | Pin | Signal Type | Pin Description                                                                                                 |
|------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------|
| INPUTA     | 1   | I           | Driver A input pin.                                                                                             |
| OUTPUTA+   | 2   | 0           | Driver A differential non-inverting output pin.                                                                 |
| OUTPUT A-  | 3   | 0           | Driver A differential inverting output pin.                                                                     |
| ENABLE A/B | 4   | ľ           | Gate control (active high). This pin is one of the two control pins which enables or disables two/four drivers. |
| оитритв-   | 5   | 0           | Driver B differential inverting output pin.                                                                     |
| оитритв+   | 6   | 0           | Driver B differential non-inverting output pin.                                                                 |
| INPUTB     | 7   | ı           | Driver B input pin.                                                                                             |
| GND        | 8   | 0           | Signal and power ground.                                                                                        |
| INPUTC     | 9   | ı           | Driver C input pin.                                                                                             |
| OUTPUTC+   | 10  | 0           | Driver C differential non-inverting output pin.                                                                 |
| оитритс-   | 11  | 0           | Driver C differential inverting output pin.                                                                     |
| ENABLE C/D | 12  | 1 .         | Gate control (active high). See ENABLE A/B pin description.                                                     |
| OUTPUTD-   | 13  | 0           | Driver D differential inverting output pin.                                                                     |
| OUTPUT D+  | 14  | 0           | Driver D differential non-inverting output pin.                                                                 |
| INPUTD     | 15  | 1           | Driver D input pin.                                                                                             |
| vcc        | 16  | l           | Power supply pin.                                                                                               |

## **Functional table**

| Enable<br>A/B<br>C/D | Input | Differential<br>Non-Inverting<br>Output | Differential<br>Inverting<br>Output |
|----------------------|-------|-----------------------------------------|-------------------------------------|
| L                    | X     | , , , ;<br>Z                            | Z                                   |
| Н                    | L     | L                                       | Н                                   |
| H                    | Н     | Н                                       | L                                   |
|                      |       |                                         |                                     |

X=Don't care Z=Three state (high impedance)



# AC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol          | Parameter                              | Min | Limits<br>Typ | Max | Units | Conditions |
|-----------------|----------------------------------------|-----|---------------|-----|-------|------------|
|                 |                                        |     | 21            |     |       |            |
| T,              | Propagation delay, input to output     |     | 8             | 10  | ns    | S1 open    |
| T,              | Differential output rise and fall time |     | 8             | 10  | ns    | S1 open    |
| T,              | Output enable time                     |     | 18            | 20  | ns    | S1 close   |
| T,              | Output disable time                    |     | 18            | 20  | ns    | S1 close   |
| *Ť <sub>5</sub> | Skew                                   |     |               | 2   | ns    | S1 open    |

<sup>\*</sup> Skew is defined as the difference in propagation delays between complementary outputs at the 50% point.

## **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW 1

2

# DC ELECTRICAL CHARACTERISTICS

 $T_{\Delta}=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol           | Parameter                        | Min | Limits<br>Typ | Max  | Units | Conditions                  |
|------------------|----------------------------------|-----|---------------|------|-------|-----------------------------|
| l <sub>in</sub>  | Input current                    |     |               | ±1.0 | μΑ    |                             |
| $I_\infty$       | Operating current                | :   | 200           |      | μΑ    |                             |
| loz              | Three state output leakage       |     | ±2.0          |      | μΑ    |                             |
| V <sub>IH</sub>  | Inputhighlevel                   | 2.0 |               |      | V     |                             |
| V <sub>II</sub>  | Input low level                  |     |               | 0.8  | V     |                             |
| $V_{OH}$         | Output high level                | 2.5 |               |      | V     |                             |
| V <sub>OI</sub>  | Output low level                 |     |               | 0.5  | V     |                             |
| $V_{os}$         | Differential output level        | 2.0 |               |      | V     | $R_{L}=100\Omega$           |
| $v_{\infty}$     | Common mode output voltage       |     |               | 3.0  | V     | R <sub>L</sub> =100Ω        |
| $V_{\infty}$     | Difference in common mode output |     |               | 0.4  | V     | R <sub>ι</sub> =100Ω        |
| $C_{N}$          | Input capacitance                | 7   | 10            | 15   | рF    | '                           |
| C <sub>PD</sub>  | Power dissipation capacitance    |     | 100           |      | pF.   |                             |
| l <sub>os</sub>  | Output short current             | -30 |               | -150 | mA .  | V <sub>IN</sub> =VCC or GND |
| l <sub>off</sub> | Output leakage current power off |     |               | 100  | μΑ    | Vout=6V                     |
|                  |                                  |     |               | -100 | μΑ    | Vout=0.25V                  |
| $I_{\infty}$     | Output current                   |     |               | ±150 | mA    |                             |

## DIFFERENTIAL LINE DRIVER TIMING







# ST31C32

Printed September 15, 1994

## RS-422. RS-423 CMOS DIFFERENTIAL LINE RECEIVERS AND DRIVERS

## GENERAL DESCRIPTION

The ST31C32 is a high speed CMOS combo differential line receiver and driver designed to meet the standard RS-422, RS-423 requirements for digital and transmission over balanced lines. It provides five differential line receivers with three state control and three line drivers also with three state control.

The line driver inputs and line receiver outputs are TTL compatible to interface with standard 74LS and CMOS environments. The ST31C32 has been designed for low power 5 volts operation and is especially suited for MODEM/UART applications.

The receiver in the ST31C32 has an input sensitivity of 200mv over the common mode input voltage range of  $\pm$  7V. They incorporate hysteresis for improved noise margin with slow changing input signals. Input fail-safe circuitry is also included which will cause the output of the receiver to go to a logic "1" level if the inputs are left open.

A special voltage sensing circuit is utilized in the drivers that will three-state the outputs during power down and power up. This will prevent spurious glitches from appearing on the outputs.

### **FEATURES**

- · Low power CMOS design
- Three-state outputs with enable pin
- Meets the EIA RS-422/423 requirements
- · Low propagation delays
- High speed
- Five line receivers with three state control
- Three line drivers with three state control
- 28 pin PLCC and SOIC package

## ORDERING INFORMATION

| Part number | Package | Operating temperature |
|-------------|---------|-----------------------|
| ST31C32CJ28 | PLCC    | 0° C to + 70° C       |
| ST31C32CF28 | SOIC    | 0° C to +70° C        |
| ST31C32IJ28 | PLCC    | -40° C to +85° C      |
| ST31C32IF28 | SOIC    | -40° C to +85° C      |

## PLCC Package



# SOIC Package



## **BLOCK DIAGRAM**



| Symbol     | Pin | Signal Type | Pin Description                                                                         |
|------------|-----|-------------|-----------------------------------------------------------------------------------------|
| INPUT B    | 1   | · I         | Line driver B input pin.                                                                |
| OUTPUT B+  | 2   | 0           | Line driver B differential non-inverted output pin.                                     |
| OUTPUT B - | 3   | 0           | Line driver B differential inverted output pin.                                         |
| OUTPUT C - | 4   | 0           | Line driver C differential inverted output pin.                                         |
| OUTPUT C+  | 5   | 0           | Line driver C differential non-inverted output pin.                                     |
| INPUT C    | 6   | . 1         | Line driver C input pin.                                                                |
| ENABLE A*  | 7*  | l           | Gate control A (active low). This pin enables/ disables the three line driver outputs.  |
| OUTPUT D   | 8   | 0           | Line receiver D output pin.                                                             |
| INPUT D +  | 9   | ı           | Line receiver D differential non-inverted input pin.                                    |
| INPUT D -  | 10  | Ι.          | Line receiver D differential inverted input pin.                                        |
| INPUT E -  | 11  | ı           | Line receiver E differential inverted input pin.                                        |
| INPUT E +  | 12  | 1           | Line receiver E differential non-inverted input pin.                                    |
| OUTPUT E   | 13  | 0           | Line receiver E output pin.                                                             |
| GND        | 14  | 0           | Signal and power ground.                                                                |
| ENABLE B*  | 15* | Ĺ           | Gate control B (active low). This pin enables/ disables the five line receiver outputs. |
| INPUT F -  | 16  | I.          | Line receiver F differential inverted input pin.                                        |
| INPUT F +  | 17  | 1           | Line receiver F differential non-inverted input pin.                                    |
| OUTPUT F   | 18  | 0           | Line receiver F output pin.                                                             |
| OUTPUT G   | 19  | 0           | Line receiver G output pin.                                                             |
| INPUT G +  | 20  | ( I         | Line receiver G differential non-inverted input pin.                                    |

# ST31C32

## SYMBOL DESCRIPTION

| Symbol     | Pin | Signal Type | Pin Description                                      |
|------------|-----|-------------|------------------------------------------------------|
| INPUT G -  | 21  | 1           | Line receiver G differential inverted input pin.     |
| INPUT H -  | 22  |             | Line receiver H differential inverted input pin.     |
| INPUT H +  | 23  | 1           | Line receiver H differential non-inverted input pin. |
| оитрит н   | 24  | 0           | Line receiver H output pin.                          |
| OUTPUT A - | 25  | 0,          | Line driver A differential inverted output pin.      |
| OUTPUT A+  | 26  | 0           | Line driver A differential non-inverted output pin.  |
| INPUT A    | 27  | 1 .         | Line driver A input pin.                             |
| vcc        | 28  | ı           | Power supply pin.                                    |

<sup>\*</sup>Has internal pull-up resistor on input

## **Receiver Functional table**

| Enable<br>B | Differential<br>Non-Inverting<br>Input | Differential<br>Inverting<br>Input | Output |  |  |
|-------------|----------------------------------------|------------------------------------|--------|--|--|
| Ι           | Х                                      | Х                                  | Z      |  |  |
| L           | L                                      | Н                                  | L      |  |  |
| L           | Н                                      | L                                  | H      |  |  |

## **Driver Functional table**

| Enable<br>A | Input | Differential<br>Non-Inverted<br>Output | Differential<br>Inverted<br>Output |
|-------------|-------|----------------------------------------|------------------------------------|
| H           | X     | Z                                      | Z                                  |
| L           | L     | L                                      | H                                  |
| L           | H     | H                                      | L                                  |

X=Don't care

Z=Three state (high impedance)

## **ST31C32 RECEIVER AC TEST CIRCUIT**



# **AC ELECTRICAL CHARACTERISTICS**

 $T_{\Delta}$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                               | Parameter                                                |     | mits<br>Typ | Max  | Units | Conditions             |
|----------------------------------------------------------------------|----------------------------------------------------------|-----|-------------|------|-------|------------------------|
|                                                                      | Line Bessiver Timing                                     |     |             |      |       |                        |
| т.                                                                   | Line Receiver Timing  Propagation delay, input to output |     | 8           | 10   | ns    | S1=VCC                 |
| T,<br>T.                                                             | Propagation delay, input to output                       |     | 18          | 20   | ns    | S1=GND                 |
| T <sub>2</sub><br>T <sub>3</sub><br>T <sub>4</sub>                   | Output enable time                                       | 1 1 | 18          | 20   | ns    | V <sub>DIF</sub> =2.5V |
| T₄³                                                                  | Output disable time                                      |     | 18          | 20   | ns    | V <sub>DIF</sub> =2.5V |
|                                                                      | Line Driver Timing                                       |     |             |      |       |                        |
| T,                                                                   | Propagation delay, input to output                       |     | 8           | - 10 | ns    | S1 open                |
| T,                                                                   | Differential output rise and fall time                   | 1 1 | 8           | 10   | ns    | S1 open                |
| T,                                                                   | Output enable time                                       | 1 1 | 18          | 20   | ns    | S1 close               |
| T₄                                                                   | Output disable time                                      | 1 1 | 18          | 20   | ns    | S1 close               |
| T <sub>2</sub><br>T <sub>3</sub><br>T <sub>4</sub><br>T <sub>5</sub> | Skew                                                     | 1 1 | 0.5         |      | ns    | S1 open                |

## ST31C32 DRIVER AC TEST CIRCUIT



# ST31C32

## **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

## DC ELECTRICAL CHARACTERISTICS

 $T_{\Delta}$ =0° - 70°C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                                                                                                                                                           | Parameter                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Min                              | Limits<br>Typ           | Max                                                     | Units | Conditions                                                  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-------------------------|---------------------------------------------------------|-------|-------------------------------------------------------------|
| V <sub>II</sub> Re V <sub>ROL</sub> Re V <sub>ROL</sub> Re V <sub>RID</sub> Re V <sub>RID</sub> Re I <sub>RIN</sub> Re I <sub>CC</sub> Op I <sub>OZ</sub> Th V <sub>DOL</sub> Dri V <sub>DOS</sub> Dri V <sub>DOD</sub> Dri V <sub>DOD</sub> Our | table high level table low level table ceiver output low level table ceiver differential input level table ceiver input tysteresis table ceiver input terrent table ceiver input resistance table ceiver input resistance table ceiver input leakage tare output leakage tare output low level tare output low level tare common mode output voltage tare difference in common mode taput tare input current | 2.0<br>3.8<br>-0.2<br>2.5<br>2.0 | 50<br>10<br>200<br>±2.0 | 0.8<br>0.4<br>+0.2<br>±1.0<br>0.5<br>3.0<br>0.4<br>±1.0 | >>>>  | $R_L$ =100 $Ω$ $R_L$ =100 $Ω$ $R_L$ =100 $Ω$ $R_L$ =100 $Ω$ |

## DIFFERENTIAL LINE DRIVER TIMING





# DIFFERENTIAL LINE RECEIVER TIMING







LUARTS 3

# Index

| ST16C1450  | 3-23  |
|------------|-------|
| ST16C1451  | 3-23  |
| ST16C1550  | 3-123 |
| ST16C1551  | 3-123 |
| ST16C1552  | 3-123 |
| ST16C2450  | 3-45  |
| ST16C2550  | 3-147 |
| ST16C2552  | 3-169 |
| ST16C450   | 3-3   |
| ST16C452AT | 3-269 |
| ST16C452PS | 3-269 |
| ST16C454   | 3-61  |
| ST16C550   | 3-97  |
| ST16C552   | 3-295 |
| ST16C553   | 3-323 |
| ST16C554   | 3-191 |
| ST16C650   | 3-235 |
| ST68C454   | 3-79  |
| ST68C554   | 3-213 |

Printed September 6, 1994



UNIVERSAL ASYNCHRONOUS RECEIVER/TRANSMITTER

## **DESCRIPTION**

The ST16C450 is a universal asynchronous receiver and transmitter. A programmable baud rate generator is provided to select transmit and receive clock rates from 50Hz to 448kHz.

The ST16C450 is an improved version of the NS16C450 UART with higher operating speed and lower access time. The ST16C450 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C450 provides internal loop-back capability for on board diagnostic testing.

The ST16C450 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

## **FEATURES**

- Pin to pin and functional compatible to NS16450,VL16C450,WD16C450
- Modern control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\*, CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- · Status report register
- Independent transmit and receive control
- TTL compatible inputs, outputs
- 448 kHz transmit/receive operation with 7.372 MHz crystal or external clock source

#### ORDERING INFORMATION

\* Industrial operating range are available.

# **PLCC Package**



## **Plastic-DIP Package**

| D0 (        |    |              | 40 | vcc   |
|-------------|----|--------------|----|-------|
| D1 [        | 2  |              | 39 | RI*   |
| D2 [        | 3  |              | 38 | CD*   |
| D3 [        | 4  |              | 37 | DSR*  |
| D4 [        | 5  |              | 36 | CTS*  |
| D5 {        | 6  |              | 35 | RESET |
| <b>D6</b> [ | 7  |              | 34 | OP1*  |
| D7 {        | 8  |              | 33 | DTR*  |
| RCLK [      | 9  | 40           | 32 | RTS*  |
| RX [        | 10 | ST16C450CP40 | 31 | OP2*  |
| TX [        | 11 | 745(         | 30 | INT   |
| CS0 [       | 12 | 160          | 29 | N.C.  |
| CS1         | 13 | S            | 28 | Α0    |
| CS2*        | 14 |              | 27 | A1    |
| BAUDOUT* [  | 15 |              | 26 | A2    |
| XTAL1       | 16 |              | 25 | AS*   |
| XTAL2       | 17 |              | 24 | CSOUT |
| IOW*        | 18 |              | 23 | DDIS* |
| IOW [       | 19 |              | 22 | IOR   |
| GND         | 20 |              | 21 | IOR*  |

# **BLOCK DIAGRAM**



| Symbol   | Pin | Signal Type | Pin Description                                                                                                                                                                                                                                                                                       |  |
|----------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| D0-D7    | 1-8 | I/O         | Bi-directional data bus, Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                                     |  |
| RCLK     | 9   | <b>I</b>    | Receive clock input. The external clock input to the ST16C450 receiver section if receiver data rate is different from transmitter data rate.                                                                                                                                                         |  |
| RX       | 10  | l           | Serial data input. The serial information (data) received from serial port to ST16C450 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. |  |
| тх       | 11  | 0           | Serial data output. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                                          |  |
| CS0      | 12  | ı           | Chip select 1 (active high). A high at this pin enables the ST16C450 / CPU data transfer operation.                                                                                                                                                                                                   |  |
| CS1      | 13  | .1          | Chip select 2 (active high). A high at this pin enables the ST16C450 / CPU data transfer operation.                                                                                                                                                                                                   |  |
| CS2*     | 14  | 1           | Chip select 3 (active low). A low at this pin (while CS0=1 and CS1=1) will enable the ST16C450 / CPU data transfer operation.                                                                                                                                                                         |  |
| BAUDOUT* | 15  | 0           | Baud rate generator clock output. This output provides the 16x clock of the internal selected baud rate. RCLK pin is connected externally to BAUDOUT* pin to provide the receiver clock.                                                                                                              |  |
| XTAL1    | 16  | l           | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                              |  |

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                                                                                                           |
|--------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XTAL2  | 17  | · I         | Crystal input 2 or buffered clock output. See XTAL1.                                                                                                                                                                                                                      |
| IOW*   | 18, | . I         | Write strobe (active low). A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                                                                                    |
| IOW    | 19  | 1           | Write strobe (active high). Same as IOW*, but uses active high input. Note that only an active IOW* or IOW input is required to transfer data from CPU to ST16C450 during write operation. All the unused pin should be tied to VCC or GND.                               |
| GND    | 20  | 0           | Signal and power ground.                                                                                                                                                                                                                                                  |
| IOR*   | 21  | 1           | Read strobe (active low). A low level on this pin transfers the contents of the ST16C450 data bus to the CPU.                                                                                                                                                             |
| IOR    | 22  |             | Read strobe (active high). Same as IOR*, but uses active high input. Note that only an active IOR* or IOR input is required to transfer data from ST16C450 to CPU during read operation. All the unused pin should be tied to VCC or GND.                                 |
| DDIS*  | 23  | 0           | Drive disable (active low). This pin goes low when the CPU is reading data from the ST16C450 to disable the external transceiver or logic's.                                                                                                                              |
| CSOUT  | 24  | 0           | Chip select out. A high on this pin indicates that the ST16C450 has been enabled by the chip select pin.                                                                                                                                                                  |
| AS*    | 25  | <b>!</b>    | Address strobe (active low). A low on this pin will latch the state of the chip selects and addressed register (A2-A0). This input is used when signals are not stable for the duration of a read or write operation. If not required, tie the AS* input permanently low. |
| A2     | 26  |             | Address select line 2. To select internal registers.                                                                                                                                                                                                                      |
| A1     | 27  |             | Address select line 1. To select internal registers.                                                                                                                                                                                                                      |
| A0     | 28  | l           | Address select line 0. To select internal registers.                                                                                                                                                                                                                      |

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|--------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| N/C    | 29  |             | No connection.                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| INT    | 30  | 0           | Interrupt output (active high). This pin goes high (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                                                                                                                     |  |  |
| OP2*   | 31  | 0           | General purpose output (active low). User defined output.<br>See bit-3 modem control register (MCR bit-3).                                                                                                                                                                                                                                                                                                |  |  |
| RTS*   | 32  | 0           | Request to send (active low). To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                                                                                          |  |  |
| DTR*   | 33  | 0           | Data terminal ready (active low). To indicate that ST16C450 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR*output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation. |  |  |
| OP1*   | 34  | 0           | General purpose output (active low). User defined output.<br>See bit-2 of modem control register (MCR bit-2).                                                                                                                                                                                                                                                                                             |  |  |
| RESET  | 35  | l           | Master reset (active high). A high on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                                                                                                                                                                                                       |  |  |
| стѕ*   | 36  | ı           | Clear to send (active low). The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation.                                                                                                                                                                                                           |  |  |
| DSR*   | 37  |             | Data set ready (active low). A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                                                                                                                                                                                                                           |  |  |

| Symbol | Pin | Signal Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Pin Description                                                                                                              |
|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| CD*    | 38  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Carrier detect (active low). A low on this pin indicates the carrier has been detected by the modem.                         |
| RI*    | 39  | 1. The state of th | Ring detect indicator (active low). A low on this pin indicates the modem has received a ringing signal from telephone line. |
| vcc    | 40  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Power supply input.                                                                                                          |

All unused input pins should be tied to VCC or GND.

# PROGRAMMING TABLE

| A2  | A1       | A0  | READ MODE                 | WRITE MODE                |  |  |
|-----|----------|-----|---------------------------|---------------------------|--|--|
| 0   | 0        | 0   | Receive Holding Register  | Transmit Holding Register |  |  |
| 0   | 0        | 1   |                           | Interrupt Enable Register |  |  |
| 0   | - 1      | 0 1 | Interrupt Status Register |                           |  |  |
| 0   | 1        | 1 1 |                           | Line Control Register     |  |  |
| 1 1 | 0        |     |                           | Modem Control Register    |  |  |
| 1   | 0        | 1 1 | Line Status Register      |                           |  |  |
| 1 1 | 1        | 0   | Modem Status Register     |                           |  |  |
| 1   | .1       | 1 1 | Scratchpad Register       | Scratchpad Register       |  |  |
| 0   | 0        | 0   |                           | LSB of Divisor Latch      |  |  |
| 0   | 0        | 1   |                           | MSB of Divisor Latch      |  |  |
|     | <u> </u> |     |                           |                           |  |  |

# **ST16C450 ACCESSIBLE REGISTERS**

| A2 | <b>A</b> 1 | A0 | Register | BIT-7                      | BIT-6           | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----|------------|----|----------|----------------------------|-----------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0  | 0          | 0  | RHR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0          | 0  | THR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0          | 1  | IER      | 0                          | 0               | 0                          | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0  | 1          | 0  | ISR      | 0                          | 0               | 0                          | 0                  | 0                            | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0  | 1          | 1  | LCR      | divisor<br>latch<br>enable | set<br>break    | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1  | 0          | 0  | MCR      | 0                          | 0               | 0                          | loop<br>back       | OP2*                         | OP1*                                   | RTS*                            | DTR*                           |
| 1  | 0          | 1  | LSR      | 0                          | trans.<br>empty | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1  | 1          | 0  | MSR      | CD                         | RI              | DSR                        | CTS                | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1  | 1          | 1  | SPR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0          | 0  | DLL      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0          | 1  | DLM      | bit-15                     | bit-14          | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

## REGISTER FUNCTIONAL DESCRIPTIONS

### TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

### PROGRAMMABLE BAUD RATE GENERATOR

The ST16C450 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to 2<sup>16</sup> -1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

### **INTERRUPT ENABLE REGISTER (IER)**

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the INT output pin.

#### IER BIT-0:

0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

### IER BIT-1:

0=disable the transmitter empty interrupt. 1=enable the transmitter empty interrupt.

#### IFR BIT-2:

0=disable the receiver line status interrupt. 1=enable the receiver line status interrupt.

#### IER BIT-3:

0=disable the modem status register interrupt. 1=enable the modem status register interrupt.

#### **IER BIT 7-4:**

All these bits are set to logic zero.

### **INTERRUPT STATUS REGISTER (ISR)**

The ST16C450 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C450 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

### Priority level

| Р | D2 | D1 | D0 | Source of the interrupt                    |
|---|----|----|----|--------------------------------------------|
| 1 | 1  | 1  | 0  | LSR (Receiver Line Status Register)        |
| 2 | 1  | 0  | 0  | RXRDY (Received Data<br>Ready)             |
| 3 | 0  | 1  | 0  | TXRDY( Transmitter Holding Register Empty) |
| 4 | 0  | 0  | 0  | MSR (Modern Status Register)               |

### ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1=no interrupt pending.

#### **ISR BIT 1-2:**

Logical combination of these bits, provides the highest priority interrupt pending.

#### **ISR BIT 3-7:**

These bits are not used and are set to "0".

## LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

### LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 | BIT-0 | Word length |
|-------|-------|-------------|
| 0     | 0     | 5           |
| 0     | 1 1   | 6           |
| . 1   | 0     | 7           |
| 1     | 1     | 8           |

#### LCR BIT-2:

The number of stop bits can be specified by this bit.

| BIT-2 | Word length | Stop bit(s) |
|-------|-------------|-------------|
| 0     | 5,6,7,8     | 1           |
| 1     | 5           | 1-1/2       |
| 1     | 6,7,8       | 2           |

#### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

#### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format.

#### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data. LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

## LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0=normal operating condition.

1=forces the transmitter output (TX) to go low to alert the communication terminal.

#### LCR BIT-7:

The internal baud rate counter latch enable (DLEN). 0=normal operation.

1=select divisor latch register.

#### MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

#### MCR BIT-0:

0=force DTR\* output to high. 1=force DTR\* output to low.

#### MCR BIT-1:

0=force RTS\* output to high. 1=force RTS\* output to low.

#### MCR BIT-2:

0=set OP1\* output to high. 1=set OP1\* output to low.

#### MCR BIT-3:

0=set OP2\* output to high. 1=set OP2\* output to low.

### MCR BIT-4:

0=normal operating mode.

1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, OP1\* and OP2\* are connected to modem control inputs. In this mode, the receiver and transmitter interrupts

are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER.

#### MCR BIT 5-7:

Not used. Are set to zero permanently.

### LINE STATUS REGISTER (LSR)

This register provides the status of data transfer to CPU.

#### LSR BIT-0:

0=no data in receive holding register 1=data has been received and saved in the receive holding register.

#### LSR BIT-1:

0=no overrun error (normal).

1=overrun error, next character arrived before receive holding register was emptied.

#### LSR BIT-2:

0=no parity error (normal).

1=parity error, received data does not have correct parity information.

#### LSR BIT-3:

0=no framing error (normal).

1=framing error received, received data did not have a valid stop bit. In

#### LSR BIT-4:

0=no break condition (normal).

1=receiver received a break signal (RX was low for one character time frame).

#### LSR BIT-5:

0=transmit holding register is full. ST16C450 will not accept any data for transmission.

1=transmit holding register is empty. CPU can load the next character.

#### LSR BIT-6:

0=transmitter holding and shift registers are full.
1=transmitter holding and shift registers are empty.

#### LSR BIT-7:

Not used. Set to "0".

#### MODEM STATUS REGISTER (MSR)

This register provides the current state of the control lines from the modern or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

#### MSR BIT-0:

Indicates that the CTS\* input to the ST16C450 has changed state since the last time it was read.

#### MSR BIT-1:

Indicates that the DSR\* input to the ST16C450 has changed state since the last time it was read.

#### MSR BIT-2:

Indicates that the RI\* input to the ST16C450 has changed from a low to a high state.

#### MSR BIT-3:

Indicates that the CD\* input to the ST16C450 has changed state since the last time it was read.

### MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

#### MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

#### MSR BIT-6:

This bit is equivalent to OP1 in the MCR during local loop-back mode. It is the compliment of the RI\* input.

#### MSR BIT-7

This bit is equivalent to OP2 in the MCR during local loop-back mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated.

## SCRATCHPAD REGISTER (SR)

ST16C450 provides a temporary data register to store 8 bits of information for variable use.

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16 x CLOCK<br>DIVISOR | % ERROR |
|-----------|-----------------------|---------|
| 50        | 2304                  |         |
| 75        | 1536                  |         |
| 110       | 1047                  | 0.026   |
| 134.5     | 857                   | 0.058   |
| 150       | 768                   | İ       |
| 300       | 384                   | j       |
| 600       | 192                   |         |
| 1200      | 96                    |         |
| 2400      | 48                    |         |
| 3600      | 32                    |         |
| 4800      | 24                    |         |
| 7200      | 16                    |         |
| 9600      | 12                    |         |
| 19.2K     | 6                     |         |
| 38.4K     | 3                     |         |
| 56K       | 2                     | 2.77    |
| 115.2K    | 1                     |         |

#### ST16C450 EXTERNAL RESET CONDITION

| REGISTERS | RESET STATE                 |
|-----------|-----------------------------|
| IER       | IER BITS 0-7=0              |
| ISR       | ISR BIT-0=1, ISR BITS 1-7=0 |
| LCR       | LCR BITS 0-7=0              |
| MCR       | MCR BITS 0-7=0              |
| LSR       | LSR BITS 0-4=0,             |
|           | LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR       | MSR BITS 0-3=0,             |
|           | MSR BITS 4-7=input signals  |

| RESET STATE |
|-------------|
| High        |
| Low         |
|             |

# ST16C450

# **AC ELECTRICAL CHARACTERISTICS**

 $T_A = 0^{\circ} - 70^{\circ} C$ , Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                         | Parameter                                                    | Min      | Limits<br>Typ | Max               | Units    | Conditions  |
|--------------------------------------------------------------------------------|--------------------------------------------------------------|----------|---------------|-------------------|----------|-------------|
| Т,                                                                             | Clock high pulse duration                                    | 50       |               |                   | ns       | Note: 2     |
| Τ,                                                                             | Clock low pulse duration                                     | 50       |               |                   | ns       | Note: 2     |
| T <sub>3</sub>                                                                 | Clock rise/fall time                                         |          |               | 10                | ns       |             |
| $T_{1}$ $T_{2}$ $T_{3}$ $T_{4}$ $T_{5}$ $T_{6}$ $T_{7}$ $T_{8}$ $T_{9}$        | Baud out rise/fall time                                      |          | 1             | 100               | ns       | 100 pF load |
| T <sub>5</sub>                                                                 | Address strobe width                                         | 30       |               |                   | ns       |             |
| T <sub>6</sub>                                                                 | Address setup time                                           | 15       |               |                   | ns       |             |
| T <sub>7</sub>                                                                 | Address hold time                                            | 15       |               |                   | ns       |             |
| <u>T</u> 8                                                                     | Chip select setup time                                       | 5        |               |                   | ns       |             |
|                                                                                | Chip select hold time                                        | 0        |               |                   | ns       |             |
| T <sub>10</sub>                                                                | CSOUT delay from chip select                                 |          |               | 10                | ns       |             |
| T <sub>11</sub>                                                                | IOR* to DDIS* delay                                          |          |               | 35                | ns       | 100 pF load |
| l <sub>12</sub>                                                                | Data setup time                                              | 15       |               |                   | ns       | Note: 1     |
| 140                                                                            | Data hold time                                               | 15       |               | 1                 | ns       | Note: 1     |
| T <sub>14</sub>                                                                | IOW* delay from chip select                                  | 10       |               |                   | ns       | Note: 1     |
| 15                                                                             | IOW* strobe width                                            | 55       |               |                   | ns       |             |
| 16                                                                             | Chip select hold time from IOW*                              | 0        |               |                   | ns       | Note: 1     |
| T <sub>17</sub>                                                                | Write cycle delay                                            | 55       |               |                   | ns       | ľ           |
| Tw                                                                             | Write cycle=T <sub>15</sub> +T <sub>17</sub> Data hold time  | 105      |               |                   | ns       |             |
| T <sub>19</sub>                                                                | IOR* delay from chip select                                  | 15<br>25 |               |                   | ns       | Note: 4     |
| <sup>1</sup> 21                                                                | IOR* strobe width                                            | 65       |               |                   | ns       | Note: 1     |
| T <sub>21</sub><br>T <sub>23</sub><br>T <sub>24</sub><br>T <sub>25</sub><br>Tr | Chip select hold time from IOR*                              | 0        |               |                   | ns       | Note: 1     |
| T <sup>24</sup>                                                                | Read cycle delay                                             | 55       |               |                   | ns       | Note: 1     |
| Tr 25                                                                          | Read cycle delay Read cycle=T <sub>23</sub> +T <sub>25</sub> | 115      |               | ,                 | ns<br>ns |             |
| T I                                                                            | Delay from IOR* to data                                      | 25       |               |                   | ns       | 100 pF load |
| T <sub>26</sub>                                                                | Delay from IOW* to output                                    | 23       |               | 50                | ns       | 100 pF load |
| T <sub>29</sub>                                                                | Delay to set interrupt from MODEM                            |          |               | 70                | ns       | 100 pF load |
| 29                                                                             | input                                                        |          |               | '                 | 113      | 100 pr load |
| T <sub>30</sub>                                                                | Delay to reset interrupt from IOR*                           |          |               | 70                | ns       | 100 pF load |
| T <sub>24</sub>                                                                | Delay from stop to set interrupt                             |          |               | 1 <sub>Rclk</sub> | *        | 100 pF load |
| T <sub>31</sub><br>T <sub>32</sub>                                             | Delay from IOR* to reset interrupt                           |          |               | 200               | ns       | 100 pF load |
| T <sub>33</sub>                                                                | Delay from initial INT reset to transmit                     | 8        |               | 24                | *        | p           |
| 33                                                                             | start                                                        | -        |               |                   |          |             |
|                                                                                |                                                              |          |               |                   |          |             |

## **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                  | Parameter                                                                               | Min | Limits<br>Typ | Max                              | Units    | Conditions |
|-----------------------------------------|-----------------------------------------------------------------------------------------|-----|---------------|----------------------------------|----------|------------|
| T <sub>34</sub><br>T <sub>35</sub><br>N | Delay from stop to interrupt<br>Delay from IOW* to reset interrupt<br>Baud rate devisor | 1   |               | 100<br>175<br>2 <sup>16</sup> -1 | ns<br>ns |            |

3

Note 1: Note 2: Applicable only when AS\* is tied low. 1.8432 Mhz crystal or External clock.

\* = Baudout\* cycle



# ST16C450

## **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

# DC ELECTRICAL CHARACTERISTICS

 $T_{\Delta}$ =0° - 70 C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                           | Parameter                                                                                                                                                                             | Min                               | Limits<br>Typ | Max                                           | Units                              | Conditions                                        |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---------------|-----------------------------------------------|------------------------------------|---------------------------------------------------|
| VILCK VIHCK VIH VOL VOH CC IL CL | Clock input low level Clock input high level Input low level Input high level Output low level on all outputs Output high level Avg. power supply current Input leakage Clock leakage | -0.5<br>3.0<br>-0.5<br>2.2<br>2.4 | 6             | 0.6<br>VCC<br>0.8<br>VCC<br>0.4<br>±10<br>±10 | V<br>V<br>V<br>V<br>MA<br>AA<br>AA | I <sub>OL</sub> = 6 mA<br>I <sub>OH</sub> = -6 mA |

3

# **CLOCK TIMING**



# BAUDOUT\* TIMING



# ST16C450

# GENERAL READ TIMING



3

# **GENERAL WRITE TIMING**



# ST16C450

## MODEM TIMING







# ST16C450







# ST16C1450 ST16C1451

Printed September 6, 1994

## UNIVERSAL ASYNCHRONOUS RECEIVER/TRANSMITTER

## DESCRIPTION

The ST16C1450/51 is a universal asynchronous receiver and transmitter. A programmable baud rate generator is provided to select transmit and receive clock rates from 50Hz to 448kHz.

The ST16C1450/51 is an improved version of the SSI 73M1550 and SSI 73M2550 UART with higher operating speed and lower access time. The ST16C1450/51 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C1450/51 provides internal loop-back capability for on board diagnostic testing.

The ST16C1450/51 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

### **FEATURES**

- Pin to pin and functional compatible to SSI 73M1550/2550
- Modern control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\*, CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- Software compatible with INS8250, NS16C550
- 448 kHz transmit/receive operation with 7.372 MHz crystal or external clock source
- 28 Pin plastic-Dip and PLCC package
- Pin-to-pin compatible to ST16C1550/1551

#### ORDERING INFORMATION

| Part number                                | Package O   | perating temperature |  |  |  |
|--------------------------------------------|-------------|----------------------|--|--|--|
| ST16C1450CP28                              | Plastic-DIP | 0° C to + 70° C      |  |  |  |
| ST16C1450CJ28                              | PLCC        | 0° C to + 70° C      |  |  |  |
| ST16C1450CQ48                              | TQFP        | 0° C to + 70° C      |  |  |  |
| ST16C1451CP28                              | Plastic-DIP | 0° C to + 70° C      |  |  |  |
| ST16C1451CJ28                              | PLCC        | 0° C to + 70° C      |  |  |  |
| ST16C1451CQ48                              | TQFP        | 0° C to + 70° C      |  |  |  |
| *Industrial operating range are available. |             |                      |  |  |  |

# ST16C1450 PLCC Package



## ST16C1451 PLCC Package



# ST16C1450 BLOCK DIAGRAM



# ST16C1451 BLOCK DIAGRAM



3

# ST16C1450 SYMBOL DESCRIPTION

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                                                                                                                                        |
|--------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7  | 1-8 | 1/0         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                                      |
| RX     | 9 , | <b>1</b>    | Serial data input. The serial information (data) received from serial port to ST16C1450 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. |
| TX     | 10  | 0           | Serial data output. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                                           |
| CS*    | 11  | · I .       | Chip select (active low). A low at this pin enables the ST16C1450 / CPU data transfer operation.                                                                                                                                                                                                       |
| XTAL1  | 12  | 1           | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                               |
| XTAL2  | 13  |             | Crystal input 2 or buffered clock output. See XTAL1.                                                                                                                                                                                                                                                   |
| IOW*   | 14  | l l         | Write strobe (active low). A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                                                                                                                 |
| GND    | 15  | 0           | Signal and power ground.                                                                                                                                                                                                                                                                               |
| IOR*   | 16  | 1.          | Read strobe (active low). A low level on this pin transfers the contents of the ST16C1450 data bus to the CPU                                                                                                                                                                                          |
| RI*    | 17  | 1           | Ring detect indicator (active low). A low on this pin indicates the modem has received a ringing signal from telephone line.                                                                                                                                                                           |
| INT    | 18  | 0           | Interrupt output. (three state / active high) This pin goes high                                                                                                                                                                                                                                       |

# ST16C1450 SYMBOL DESCRIPTION

| Symbol | Pin     | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |         |             | (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                                                                                                                                                                         |
| A0-A2  | 21-19   | 1           | Address select line. To select internal registers.                                                                                                                                                                                                                                                                                                                                                         |
| RTS*   | 22      | 0 .         | Request to send (active low). To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                                                                                           |
| DTR*   | 23      | O           | Data terminal read (active low). To indicate that ST16C1450 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation. |
| RESET  | 24      |             | Master reset (active high). A high on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                                                                                                                                                                                                        |
| стѕ*   | 25      | I           | Clear to send (active low). The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR bit-4. CTS* has no effect on the transmit or receive operation.                                                                                                                                                                                                            |
| DSR*   | 26      | l           | Data set ready (active low). A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                                                                                                                                                                                                                            |
| CD*    | 27      | 1           | Carrier detect (active low). A low on this pin indicates the carrier has been detected by the modem.                                                                                                                                                                                                                                                                                                       |
| vcc    | 28      | 1           | Power supply input.                                                                                                                                                                                                                                                                                                                                                                                        |
| L      | <u></u> | <u> </u>    |                                                                                                                                                                                                                                                                                                                                                                                                            |

# ST16C1451 SYMBOL DESCRIPTION

| Symbol | Pin            | Signal Type | Pin Description                                                                                                                                                                                                                                                                                        |
|--------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7  | 1-8            | I/O         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                                      |
| RX     | 9              | l           | Serial data input. The serial information (data) received from serial port to ST16C1451 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. |
| TX     | 10             | 0           | Serial data output. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                                           |
| cs*    | 11             | 1           | Chip select (active low). A low at this pin enables the ST16C1451 / CPU data transfer operation.                                                                                                                                                                                                       |
| CLK    | 12             | <b>1</b>    | External clock input. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                                                                                                                                                   |
| IOW*   | 13             | 1           | Write strobe (active low). A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                                                                                                                 |
| GND    | 14             | 0           | Signal and power ground.                                                                                                                                                                                                                                                                               |
| IOR*   | 15             | 1           | Read strobe (active low). A low level on this pin transfers the contents of the ST16C1451 data bus to the CPU.                                                                                                                                                                                         |
| RI*    | 16             |             | Ring detect indicator (active low). A low on this pin indicates the modem has received a ringing signal from telephone line.                                                                                                                                                                           |
| RST    | 17 - 17 - 18 1 |             | Reset output (active high). The ST16C1451 provides a buffered reset output which is gated internally with MCR bit-2.                                                                                                                                                                                   |
|        |                |             |                                                                                                                                                                                                                                                                                                        |

# ST16C1451 SYMBOL DESCRIPTION

| Symbol | Pin   | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT    | 18    | . 0         | Interrupt output. (three state / active high) This pin goes high (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                                                                                                        |
| A0-A2  | 21-19 | 1           | Address select line. To select internal registers.                                                                                                                                                                                                                                                                                                                                                         |
| RTS*   | 22    | 0           | Request to send (active low). To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                                                                                           |
| DTR*   | 23    | 0           | Data terminal read (active low). To indicate that ST16C1451 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation. |
| RESET  | 24    | 1           | Master reset (active high). A high on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                                                                                                                                                                                                        |
| стѕ*   | 25    | I .         | Clear to send (active low). The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation.                                                                                                                                                                                                            |
| DSR*   | 26    | l           | Data set ready (active low). A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                                                                                                                                                                                                                            |
| CD*    | 27    | 1           | Carrier detect (active low). A low on this pin indicates the carrier has been detected by the modem.                                                                                                                                                                                                                                                                                                       |
| vcc    | 28    | 1           | Power supply input.                                                                                                                                                                                                                                                                                                                                                                                        |

# **PROGRAMMING TABLE**

| A2  | A1 | A0 | READ MODE                 | WRITE MODE                |
|-----|----|----|---------------------------|---------------------------|
| .0  | 0  | 0  | Receive Holding Register  | Transmit Holding Register |
| 0   | 0  | 1  | · •                       | Interrupt Enable Register |
| 0   | 1  | 0  | Interrupt Status Register | · .                       |
| 0   | 1  | 1  |                           | Line Control Register     |
| 1   | 0  | 0  |                           | Modem Control Register    |
| 1   | 0  | 1  | Line Status Register      |                           |
| 1   | 1  | 0  | Modem Status Register     | •                         |
| 1   | 1  | 1  | Scratchpad Register       | Scratchpad Register       |
| . 0 | 0  | 0  |                           | LSB of Divisor Latch      |
| 0   | 0  | 1  |                           | MSB of Divisor Latch      |
|     | 1  |    |                           |                           |

All unused input pins should be tied to VCC or GND.



# **ST16C1450 ACCESSIBLE REGISTERS**

| A2 | Α1 | A0 | Register | BIT-7                      | BIT-6           | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----|----|----|----------|----------------------------|-----------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0  | 0  | 0  | RHR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 0  | THR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 1  | IER      | 0                          | 0               | 0/<br>special<br>mode      | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0  | 1  | 0  | ISR      | 0                          | 0               | 0                          | 0                  | 0                            | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0  | 1  | 1  | LCR      | divisor<br>latch<br>enable | set<br>break    | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1  | 0  | 0  | MCR      | 0/power<br>down            | 0               | 0                          | loop<br>back       | INT<br>enable                | SOFT reset                             | RTS*                            | DTR*                           |
| 1  | 0  | 1  | LSR      | 0                          | trans.<br>empty | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1  | 1  | 0  | MSR      | CD                         | RI              | DSR                        | CTS                | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1  | 1  | 1  | SPR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 0  | DLL      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 1  | DLM      | bit-15                     | bit-14          | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

# ST16C1451 ACCESSIBLE REGISTERS

| A2 | Αſ | 1 / | 70 | Register | BIT-7                      | BIT-6           | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----|----|-----|----|----------|----------------------------|-----------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0  | 0  | )   | 0  | RHR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | )   | 0  | THR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | )   | 1  | IER      | 0                          | 0               | 0/<br>special<br>mode      | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0  | 1  |     | 0  | ISR      | 0                          | 0               | 0                          | 0                  | 0                            | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0  | 1  |     | 1  | LCR      | divisor<br>latch<br>enable | set<br>break    | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1  | 0  | )   | 0  | MCR      | 0/power<br>down            | 0               | 0                          | loop<br>back       | INT<br>enable                | SOFT reset                             | RTS*                            | DTR*                           |
| 1  | 0  | )   | 1. | LSR      | 0                          | trans.<br>empty | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1  | 1  |     | 0  | MSR      | CD                         | RI              | DSR                        | CTS                | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1. | 1  | -   | 1  | SPR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | )   | 0  | DLL      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | )   | 1  | DLM      | bit-15                     | bit-14          | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

# REGISTER FUNCTIONAL DESCRIPTIONS

# TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

#### PROGRAMMABLE BAUD RATE GENERATOR

The ST16C1450/51 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to 2<sup>16</sup>-1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

# INTERRUPT ENABLE REGISTER (IER)

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modern status registers to the INT output pin.

### IER BIT-0:

0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

#### IER BIT-1:

0=disable the transmitter empty interrupt. 1=enable the transmitter empty interrupt.

### IER BIT-2:

0=disable the receiver line status interrupt.
1=enable the receiver line status interrupt.

### IER BIT-3:

0=disable the modem status register interrupt. 1=enable the modem status register interrupt.

### IER BIT-5:

0=normal ST16C450 mode.

1=special mode. Enable power down and SOFT rest.

## IER BIT 4,6-7:

All these bits are set to logic zero.

# **INTERRUPT STATUS REGISTER (ISR)**

The ST16C1450/51 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C1450/51 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

3

# **Priority levels**

| Р | D2 | D1 | D0 | Source of the interrupt                       |
|---|----|----|----|-----------------------------------------------|
| 1 | 1  | 1  | 0  | LSR (Receiver Line Status<br>Register)        |
| 2 | 1  | 0  | 0  | RXRDY (Received Data<br>Ready)                |
| 3 | 0  | 1  | 0  | TXRDY( Transmitter Holding<br>Register Empty) |
| 4 | 0  | 0  | 0  | MSR (Modem Status Register)                   |

# ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1=no interrupt pending.

# **ISR BIT 1-2:**

Logical combination of these bits, provides the highest priority interrupt pending.

# ISR bit 3-7:

Not used

# LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

# LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 | BIT-0 | Word length |
|-------|-------|-------------|
| 0     | 0     | 5           |
| 0     | 1     | 6           |
| 1 1   | 0     | 7           |
| 1     | 1     | 8           |

# LCR BIT-2:

The number of stop bits can be specified by this bit.

| BIT-2 | Word length | Stop bit(s) |
|-------|-------------|-------------|
| 0     | 5,6,7,8     | 1           |
| 1     | 5           | 1-1/2       |
| 1     | 6,7,8       | 2           |

#### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format.

### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

# LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0=normal operating condition.

1=forces the transmitter output (TX) to go low to alert the communication terminal.

# LCR BIT-7:

The internal baud rate counter latch enable (DLEN). 0=normal operation.

1=select divisor latch register.

# MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

## MCR BIT-0:

0=force DTR\* output to high. 1=force DTR\* output to low.

## MCR BIT-1:

0=force RTS\* output to high. 1=force RTS\* output to low.

### MCR BIT-2:

0=normal operation.

1=software reset, set RST output to high.

# MCR BIT-3:

0=set INT output pin to three state mode. 1=set INT output pin to normal operation mode.

### MCR BIT-4:

0=normal operating mode.

1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, SOFT reset and INT enable are connected to modem control inputs.

In this mode , the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER .

### MCR BIT 5-6:

Not used. Are set to zero permanently.

# MCR bit-7:

0=normal mode.

1=power down mode. XTAL1, XTAL2, and baud rate generators are disabled.

# LINE STATUS REGISTER (LSR)

This register provides the status of data transfer to CPU

## LSR BIT-0:

0=no data in receive holding register 1=data has been received and saved in the receive holding register.

# LSR BIT-1:

0=no overrun error (normal).

1=overrun error, next character arrived before receive holding register was emptied.

### LSR BIT-2:

0=no parity error (normal).

1=parity error, received data does not have correct parity information.

# LSR BIT-3:

0=no framing error (normal).

1=framing error received, received data did not have a valid stop bit.

# LSR BIT-4:

0=no break condition (normal).

1=receiver received a break signal (RX was low for one character time frame).

### LSR BIT-5:

0=transmit holding register is full. ST16C1450/51 will not accept any data for transmission.

1=transmit holding register is empty. CPU can load the next character.

# LSR BIT-6:

0=transmitter holding and shift registers are full.
1=transmitter holding and shift registers are empty.

#### LSR BIT-7:

Not used.

3

# **MODEM STATUS REGISTER (MSR)**

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

### MSR BIT-0:

Indicates that the CTS\* input to the ST16C1450/51 has changed state since the last time it was read.

# MSR BIT-1:

Indicates that the DSR\* input to the ST16C1450/51 has changed state since the last time it was read.

#### MSR BIT-2:

Indicates that the RI\* input to the ST16C1450/51 has changed from a low to a high state.

#### MSR BIT-3:

Indicates that the CD\* input to the ST16C1450/51 has changed state since the last time it was read.

## MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

# MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

### MSR BIT-6:

This bit is equivalent to SOFT reset in the MCR during local loop-back mode. It is the compliment of the RI\* input.

# MSR BIT-7:

This bit is equivalent to INT enable in the MCR during local loop-back mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated.

# SCRATCHPAD REGISTER (SR)

ST16C1450/51 provides a temporary data register to store 8 bits of information for variable use.

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16 x CLOCK<br>DIVISOR | % ERROR |
|-----------|-----------------------|---------|
| 50        | 2304                  |         |
| 75        | 1536                  | 1       |
| 110       | 1047                  | 0.026   |
| 150       | 768                   |         |
| 300       | 384                   |         |
| 600       | 192                   |         |
| 1200      | 96                    |         |
| 2400      | 48                    |         |
| 3600      | 32                    |         |
| 4800      | 24                    |         |
| 7200      | 16                    |         |
| 9600      | 12                    |         |
| 19.2K     | 6                     |         |
| 38.4K     | 3                     |         |
| 56K       | 2                     | 2.77    |
| 115.2K    | 1                     |         |

# ST16C1450/51 EXTERNAL RESET CONDITION

| REGISTERS          | RESET STATE                 |
|--------------------|-----------------------------|
| IER                | IER BITS 0-7=0              |
| ISR                | ISR BIT-0=1, ISR BITS 1-7=0 |
| LCR                | LCR BITS 0-7=0              |
| MCR                | MCR BITS 0-7=0              |
| LSR                | LSR BITS 0-4=0,             |
| a soversul in a st | LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR                | MSR BITS 0-3=0,             |
|                    | MSR BITS 4-7=input signals  |

| SIGNALS    | RESET STATE      |
|------------|------------------|
| TX         | High             |
| SOFT reset | High             |
| RTS*       | High             |
| DTR*       | High             |
| INT        | Three state mode |

# ST16C1450 Plastic-DIP Package



# ST16C1451 Plastic-DIP Package



# **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts
GND-0.3 V to VCC+0.3 V
0° C to +70° C
-40° C to +150° C
500 mW

# DC ELECTRICAL CHARACTERISTICS

 $T_A$ =0° - 70° C,  $V_{cc}$ =5.0 V ± 10% unless otherwise specified.

| Symbol                             | Parameter                                                                                                                                                                             | Limits<br>Min Typ Max             |   |                                               | Units                  | Conditions                                        |  |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---|-----------------------------------------------|------------------------|---------------------------------------------------|--|
| VILCK VIHCK VIL VOL VOH LCC LL LCL | Clock input low level Clock input high level Input low level Input high level Output low level on all outputs Output high level Avg. power supply current Input leakage Clock leakage | -0.5<br>3.0<br>-0.5<br>2.2<br>2.4 | 6 | 0.6<br>VCC<br>0.8<br>VCC<br>0.4<br>±10<br>±10 | >>>>> <del>E</del> A A | I <sub>oL</sub> = 6 mA<br>I <sub>oH</sub> = -6 mA |  |

# **AC ELECTRICAL CHARACTERISTICS**

 $T_A$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                     | Parameter                                      | Min | Limits<br>Typ | Max                | Units | Conditions  |
|--------------------------------------------------------------------------------------------|------------------------------------------------|-----|---------------|--------------------|-------|-------------|
| т                                                                                          | Clock high pulse duration                      | 50  |               |                    | ns    | Note: 1     |
| T <sup>1</sup>                                                                             | Clock low pulse duration                       | 50  |               |                    | ns    | Note: 1     |
| T <sup>2</sup>                                                                             | Clock rise/fall time                           |     | 1 1           | 10                 | ns    | 11010. 1    |
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>8</sub> T <sub>9</sub> T <sub>12</sub> | Chip select setup time                         | 5   |               |                    | ns    |             |
| T.                                                                                         | Chip select hold time                          | ŏ   |               |                    | ns    |             |
| T                                                                                          | Data setup time                                | 15  |               |                    | ns    |             |
| T <sub>13</sub>                                                                            | Data hold time                                 | 15  | ]             |                    | ns    |             |
| T <sub>14</sub>                                                                            | IOW* delay from chip select                    | 10  |               |                    | ns    |             |
| T <sub>15</sub>                                                                            | IOW* strobe width                              | 50  | 1             |                    | ns    |             |
| T <sub>16</sub>                                                                            | Chip select hold time from IOW*                | 0   | l l           |                    | ns    |             |
| T <sub>17</sub>                                                                            | Write cycle delay                              | 55  |               | ·                  | ns    |             |
| Τ₩                                                                                         | Write cycle=T <sub>15</sub> +T <sub>17</sub>   | 105 |               |                    | ns    |             |
| T <sub>19</sub>                                                                            | Data hold time                                 | 15  |               |                    | ns    |             |
| T,                                                                                         | IOR* delay from chip select                    | 10  |               |                    | ns    |             |
| T <sub>21</sub>                                                                            | IOR* strobe width                              | 65  |               |                    | ns    |             |
| T <sub>24</sub>                                                                            | Chip select hold time from IOR*                | 0   | 1             |                    | ns    |             |
| T <sub>24</sub><br>T <sub>25</sub><br>Tr                                                   | Read cycle delay                               | 55  |               |                    | ns    |             |
| Τr̈́                                                                                       | Read cycle=T <sub>23</sub> +T <sub>25</sub>    | 105 |               |                    | ns    |             |
| T <sub>26</sub>                                                                            | Delay from IOR* to data                        |     |               | 35                 | ns    | 100 pF load |
| T <sub>28</sub>                                                                            | Delay from IOW* to output                      |     |               | 50                 | ns    | 100 pF load |
| T <sub>26</sub><br>T <sub>28</sub><br>T <sub>29</sub>                                      | Delay to set interrupt from MODEM input        |     |               | 70                 | ns    | 100 pF load |
| T <sub>30</sub>                                                                            | Delay to reset interrupt from IOR*             |     |               | 70                 | ns    | 100 pF load |
| T <sub>31</sub>                                                                            | Delay from stop to set interrupt               |     |               | 1 <sub>Rclk</sub>  | *     | 100 pF load |
| T <sub>31</sub><br>T <sub>32</sub>                                                         | Delay from IOR* to reset interrupt             |     |               | 200                | ns    | 100 pF load |
| T <sub>33</sub>                                                                            | Delay from initial INT reset to transmit start | 8   |               | 24                 | *     |             |
| T <sub>34</sub>                                                                            | Delay from stop to interrupt                   |     |               | 100                | ns    |             |
| T <sub>35</sub>                                                                            | Delay from IOW* to reset interrupt             |     |               | 175                | ns    |             |
| N                                                                                          | Baud rate devisor                              | 1   |               | 2 <sup>16</sup> -1 |       |             |

Note 1:

1.8432 MHz crystal or External clock

\* = Baudout\* cycle

# **GENERAL WRITE TIMING**



# **GENERAL READ TIMING**



# MODEM TIMING



# **CLOCK TIMING**





16 BAUD RATE CLOCK





# ST16C2450

Printed September 6, 1994

# **DUAL UNIVERSAL ASYNCHRONOUS RECEIVER/TRANSMITTER**

# DESCRIPTION

The ST16C2450 is a dual universal asynchronous receiver and transmitter. Independent programmable baud rate generators are provided to select transmit and receive clock rates from 50Hz to 448kHz for each UART section.

The ST16C2450 is an improved version of the NS16C450 UART with higher operating speed and lower access time. The ST16C2450 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C2450 provides internal loop-back capability for on board diagnostic testing.

The ST16C2450 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

# **FEATURES**

- Functional compatible to NS16450, VL16C450, WD16C450
- Modern control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\*, CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- · Status report register
- Independent transmit and receive control
- TTL compatible inputs, outputs
- 448 kHz transmit/receive operation with 7.372 MHz crystal or external clock source

# ORDERING INFORMATION

Part number Package Operating temperature ST16C2450CP40 Plastic-DIP 0° C to + 70° C ST16C2450CJ44 PLCC 0° C to + 70° C

\*Industrial operating range are available

# PLCC Package



# Plastic-DIP Package

|          |               | -         |
|----------|---------------|-----------|
| D0 1     |               | 40 VCC    |
| D1 2     |               | 39 RIA*   |
| D2 3     |               | 38 CDA*   |
| D3 4     |               | 37 DSRA*  |
| D4 5     |               | 36 CTSA*  |
| D5 6     | -             | 35 RESET  |
| D6 7     |               | 34 DTRB** |
| D7 8     | Q             | 33 DTRA*  |
| RXB 9    | 7.2           | 32 RTSA*  |
| RXA 10   | ST16C2450CP40 | 31 OPA*   |
| TXA 11   | Š             | 30 INTA   |
| TXB 12   | )T16          | 29 INTB   |
| OPB* 13  | S             | 28 A0     |
| CSA* 14  |               | 27 A1     |
| CSB* 15  | The Control   | 26 A2     |
| XTAL1 16 |               | 25 CTSB*  |
| XTAL2 17 |               | 24 RTSB*  |
| 10W* 18  |               | 23 RIB*   |
| CDB* 19  |               | 22 DSRB*  |
| GND 20   |               | 21 IOR*   |



**BLOCK DIAGRAM** 

# SYMBOL DESCRIPTION

| Symbol  | Pin   | Signal Type | Pin Description                                                                                                                                                                                                                                                                                            |
|---------|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7   | 1-8   | 1/0         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                                          |
| RX A/B  | 10,9  | l           | Serial data input A/B. The serial information (data) received from serial port to ST16C2450 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. |
| TX A/B  | 11,12 | 0           | Serial data output A/B. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                                           |
| CS A/B* | 14,15 | l           | Chip select A/B. (active low) A low at this pin enables the ST16C2450 / CPU data transfer operation.                                                                                                                                                                                                       |
| XTAL1   | 16    | l           | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                                   |
| XTAL2   | 17    | ı           | Crystal input 2 or buffered clock output. See XTAL1.                                                                                                                                                                                                                                                       |
| IOW*    | 18    | l           | Write strobe. (active low) A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                                                                                                                     |
| IOR*    | 21    | 1           | Read strobe. (active low) A low level on this pin transfers the contents of the ST16C2450 data bus to the CPU.                                                                                                                                                                                             |
| A0-A2   | 28-26 | 1           | Address select lines. To select internal registers.                                                                                                                                                                                                                                                        |
| INT A/B | 30,29 | 0           | Interrupt output A/B. (active high) This pin goes high (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                  |

# ST16C2450

# **SYMBOL DESCRIPTION**

| Symbol   | Pin   | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPA/B*   | 31,13 | 0           | Interrupt enable output (active low). This pin stays high when INT out pin is set to three state mode and goes low when INT pin is enabled via OP2*. See bit-3 modem control register (MCR bit-3).                                                                                                                                                                                                              |
| RTS A/B* | 32,24 | 0           | Request to send A/B (active low). To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                                                                                            |
| DTR A/B* | 33,34 | Ο           | Data terminal ready A/B (active low). To indicate that ST16C2450 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation. |
| RESET    | 35    |             | Master reset. (active high) A high on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                                                                                                                                                                                                             |
| CTS A/B* | 36,25 |             | Clear to send A/B (active low). The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation.                                                                                                                                                                                                             |
| DSR A/B* | 37,22 | <b>I</b>    | Data set ready A/B (active low). A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                                                                                                                                                                                                                             |
| CD A/B*  | 38,19 | 1           | Carrier detect A/B (active low). A low on this pin indicates the carrier has been detected by the modem.                                                                                                                                                                                                                                                                                                        |
| RI A/B*  | 39,23 | <b>1</b>    | Ring detect indicator A/B (active low). A low on this pin indicates the modem has received a ringing signal from telephone line.                                                                                                                                                                                                                                                                                |

# SYMBOL DESCRIPTION

| Symbol | Pin | Signal Type | Pin Description          |
|--------|-----|-------------|--------------------------|
| vcc    | 40  | ı           | Power supply input.      |
| GND    | 20  | 0           | Signal and power ground. |

# PROGRAMMING TABLE

| A2 | A1 | A0 | READ MODE                 | WRITE MODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----|----|----|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0  | 0  | 0  | Receive Holding Register  | Transmit Holding Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0  | 0  | 1  | , ,                       | Interrupt Enable Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0  | 1  | .0 | Interrupt Status Register | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0  | 1  | 1  |                           | Line Control Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1  | 0  | 0  | ,                         | Modem Control Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1  | 0  | 1  | Line Status Register      | in the second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second se |
| 1  | 1  | 0  | Modem Status Register     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1  | 1  | 1  | Scratchpad Register       | Scratchpad Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0  | 0  | 0  |                           | LSB of Divisor Latch                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0  | 0  | 1  |                           | MSB of Divisor Latch                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

# ST16C2450

# ST16C2450 ACCESSIBLE REGISTERS A/B

| A2 A1 A0 | Register | BIT-7                      | BIT-6           | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----------|----------|----------------------------|-----------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0 0 0    | RHR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0 0    | THR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0 1    | IER      | <b>O</b>                   | 0               | 0                          | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0 1 0    | ISR      | 0                          | 0               | 0                          | 0                  | 0                            | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0 1 1    | LCR      | divisor<br>latch<br>enable | set<br>break    | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1 0 0    | MCR      | 0                          | 0               | 0                          | loop<br>back       | OP2/<br>INT<br>enable        | Not<br>used                            | RTS*                            | DTR*                           |
| 1 0 1    | LSR      | 0                          | trans.<br>empty | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1 1 0    | MSR      | CD                         | RI              | DSR                        | стѕ                | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1 1 1    | SPR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0 0    | DLL      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0 1    | DLM      | bit-15                     | bit-14          | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

# REGISTER FUNCTIONAL DESCRIPTIONS A/B

### TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

# PROGRAMMABLE BAUD RATE GENERATOR

The ST16C2450 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to  $2^{16}$  -1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

# INTERRUPT ENABLE REGISTER (IER)

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modern status registers to the INT output pin.

#### IER BIT-0:

0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

### IER BIT-1:

0=disable the transmitter empty interrupt. 1=enable the transmitter empty interrupt.

### IER BIT-2:

0=disable the receiver line status interrupt.
1=enable the receiver line status interrupt.

# IER BIT-3:

0=disable the modem status register interrupt. 1=enable the modem status register interrupt.

### **IER BIT 4-7:**

All these bits are set to logic zero.

# INTERRUPT STATUS REGISTER (ISR)

The ST16C2450 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C2450 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

# **Priority level**

| P | D2 | D1 | D0 | Source of the interrupt                   |
|---|----|----|----|-------------------------------------------|
| 1 | 1  | 1  | 0  | LSR (Receiver Line Status Register)       |
| 2 | 1  | Ó  | 0  | RXRDY (Received Data Ready)               |
| 3 | 0  | 1  | 0  | TXRDY(Transmitter Holding Register Empty) |
| 4 | 0  | 0  | 0  | MSR (Modern Status Register)              |

# ST16C2450

### ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1=no interrupt pending.

### **ISR BIT 1-2:**

Logical combination of these bits, provides the highest priority interrupt pending.

### **ISR BIT 3-7:**

These bits are not used and are set to "0".

# LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

# LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 | BIT-0 | Word length |
|-------|-------|-------------|
| 0     | 0     | 5           |
| 0     | 1     | 6           |
| 1     | 0     | 7           |
| 1     | 1     | 8           |

### LCR BIT-2:

The number of stop bits can be specified by this bit.

| BIT-2 | Word length | Stop bit(s) |
|-------|-------------|-------------|
| 0     | 5,6,7,8     | 1           |
| 1     | 6,7,8       | 1-1/2<br>2  |

## LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format.

# LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

### LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0=normal operating condition.

1=forces the transmitter output (TX) to go low to alert the communication terminal.

# LCR BIT-7:

The internal baud rate counter latch enable (DLEN). 0=normal operation.

1=select divisor latch register.

# MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

### MCR BIT-0:

0=force DTR\* output to high.

1=force DTR\* output to low.

# MCR BIT-1:

0=force RTS\* output to high. 1=force RTS\* output to low.

### MCR BIT-2:

not used except in local loop-back mode.

### MCR BIT-3:

0=set INT output pin to three state mode and OP2\* output to high.

1=set INT output pin to normal operating mode and OP2\* output to low.

# MCR BIT-4:

0=normal operating mode.

1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, MCR bit-2 and OP2\*/INT enable are connected to modem control inputs.

In this mode, the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER.

### MCR BIT 5-7:

Not used. Are set to zero permanently.

# LINE STATUS REGISTER (LSR)

This register provides the status of data transfer to CPU.

#### LSR BIT-0:

0=no data in receive holding register 1=data has been received and saved in the receive holding register.

# LSR BIT-1:

0=no overrun error (normal).

1=overrun error, next character arrived before receive holding register was emptied.

# LSR BIT-2:

0=no parity error (normal).

1=parity error, received data does not have correct parity information.

# LSR BIT-3:

0=no framing error (normal).

1=framing error received, received data did not have a valid stop bit. In

# LSR BIT-4:

0=no break condition (normal).

1=receiver received a break signal (RX was low for one character time frame).

### LSR BIT-5:

0=transmit holding register is full. ST16C2450 will not accept any data for transmission.

1=transmit holding register is empty. CPU can load the next character.

#### LSR BIT-6:

0=transmitter holding and shift registers are full.
1=transmitter holding and shift registers are empty.

# LSR BIT-7:

Not used. Set to "0".

# **MODEM STATUS REGISTER (MSR)**

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

### MSR BIT-0:

Indicates that the CTS\* input to the ST16C2450 has changed state since the last time it was read.

3

# MSR BIT-1:

Indicates that the DSR\* input to the ST16C2450 has changed state since the last time it was read.

### MSR BIT-2:

Indicates that the RI\* input to the ST16C2450 has changed from a low to a high state.

### MSR BIT-3:

Indicates that the CD\* input to the ST16C2450 has changed state since the last time it was read.

### MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

# MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

# MSR BIT-6:

This bit is equivalent to MCR bit-2 during local loopback mode. It is the compliment of the RI\* input.

# MSR BIT-7:

This bit is equivalent to OP2\*/INT enable in the MCR during local loop-back mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated.

| SIGNALS | RESET STATE      |
|---------|------------------|
| TX      | High             |
| OP2*    | High             |
| RTS*    | High             |
| DTR*    | High             |
| INT     | Three state mode |
|         | and a section    |

# SCRATCHPAD REGISTER (SR)

ST16C2450 provides a temporary data register to store 8 bits of information for variable use.

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16 x CLOCK<br>DIVISOR | % ERROR |  |  |
|-----------|-----------------------|---------|--|--|
| 50        | 2304                  |         |  |  |
| 75        | 1536                  |         |  |  |
| 110       | 1047                  | 0.026   |  |  |
| 134.5     | 857                   | 0.058   |  |  |
| 150       | 768                   |         |  |  |
| 300       | 384                   |         |  |  |
| 600       | 192                   |         |  |  |
| 1200      | 96                    |         |  |  |
| 2400      | 48                    |         |  |  |
| 3600      | 32                    |         |  |  |
| 4800      | 24                    |         |  |  |
| 7200      | 16                    | 1       |  |  |
| 9600      | 12                    |         |  |  |
| 19.2K     | 6                     |         |  |  |
| 38.4K     | 3                     |         |  |  |
| 56K       | 2                     | 2.77    |  |  |
| 115.2K    | 1                     |         |  |  |

# ST16C2450 EXTERNAL RESET CONDITION

| IER BITS 0-7=0              |
|-----------------------------|
| ISR BIT-0=1, ISR BITS 1-7=0 |
| LCR BITS 0-7=0              |
| MCR BITS 0-7=0              |
| LSR BITS 0-4=0.             |
| LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR BITS 0-3=0,             |
| MSR BITS 4-7=input signal   |
|                             |

# **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| T <sub>15</sub> T <sub>16</sub> Chip select hold to the cycle delay to the cycle delay to the cycle delay to the cycle delay to the cycle delay to the cycle delay to the cycle delay to the cycle delay to the cycle delay to the cycle delay from to the cycle delay from to the cycle delay to the cycle delay to the cycle delay to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from to the cycle delay from the cycle delay from to the cycle delay from the cycle delay from the cycle delay from the cycle delay from the cycle delay from the | Parameter                                                                                                                                                                                                                                                                                                              | Min                                                                                               | Limits<br>Typ | Max                                                     | Units                                    | Conditions                                                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|---------------|---------------------------------------------------------|------------------------------------------|-----------------------------------------------------------------------------------------|
| start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | w pulse duration te/fall time tect setup time tect hold time up time d time tobe width tect hold time from IOW* cle delay cle=T <sub>15</sub> +T <sub>17</sub> d time ay from chip select tobe width tect hold time from IOW* cle delay cle=T <sub>15</sub> +T <sub>17</sub> d time time time time time time time time | 50<br>50<br>15<br>0<br>15<br>15<br>10<br>50<br>0<br>55<br>105<br>15<br>10<br>65<br>0<br>55<br>115 | Тур           | 35<br>50<br>70<br>70<br>1 <sub>Reik</sub><br>2000<br>24 | ns ns ns ns ns ns ns ns ns ns ns ns ns n | External clock  100 pF load 100 pF load 100 pF load 100 pF load 100 pF load 100 pF load |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | om stop to interrupt<br>om IOW* to reset interrupt                                                                                                                                                                                                                                                                     | 1                                                                                                 |               | 100<br>175<br>2 <sup>16</sup> -1                        | ns<br>ns                                 |                                                                                         |

Note 1: \* = Baudout\* cycle

# ST16C2450

# **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts
GND-0.3 V to VCC+0.3 V
0° C to +70° C
-40° C to +150° C
500 mW

# DC ELECTRICAL CHARACTERISTICS

T<sub>a</sub>=0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                             | Parameter                                                                                                                                                                            |                                   | nits<br>yp Max                                     | Units                              | Conditions                                        |
|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|----------------------------------------------------|------------------------------------|---------------------------------------------------|
| VILCK VIHCK VIL VOL VOL ICC IL ICL | Clock input low level Clock input high level Input low level Input high level Output low level on all outputs Output high level Avg power supply current Input leakage Clock leakage | -0.5<br>3.0<br>-0.5<br>2.2<br>2.4 | 0.6<br>VCC<br>0.8<br>VCC<br>0.4<br>6<br>±10<br>±10 | V<br>V<br>V<br>V<br>mA<br>µA<br>µA | I <sub>oL</sub> = 6 mA<br>I <sub>OH</sub> = -6 mA |

3

# **GENERAL WRITE TIMING**



# **GENERAL READ TIMING**



# ST16C2450

# MODEM TIMING









# ST16C2450





# ST16C454

Printed September 6, 1994

## QUAD ASYNCHRONOUS RECEIVER AND TRANSMITTER

## DESCRIPTION

The ST16C454 is a quad universal asynchronous receiver and transmitter. A programmable baud rate generator is provided to select transmit and receive clock rates from 50Hz to 448kHz.

The ST16C454 is an improved version of the NS16C450 UART with higher operating speed and lower access time. The ST16C454 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C454 provides internal loop-back capability for on board diagnostic testing.

The ST16C454 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

## **PLCC Package**



## **FEATURES**

- Quad ST16C450
- Pin-to-pin compatible to ST16C554
- Modem control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\* (CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- · Status report register
- Independent transmit and receive control
- TTL compatible inputs, outputs
- 448 kHz transmit/receive operation with 7.372 MHz crystal or external clock source

## ORDERING INFORMATION

Part number ST16C454CJ68 ST16C454IJ68 Package PLCC PLCC Operating temperature 0° C to + 70° C -40° C to + 85° C J



3-62

# **SYMBOL DESCRIPTION**

| Symbol             | Pin            | Signal Type | Pin Description                                                                                                                                                                                                                                                                                       |
|--------------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7              | 5-66           | I/O         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                                     |
| RX A-B<br>RX C-D   | 7,29<br>41,63  | . <b>I</b>  | Serial data input. The serial information (data) received from serial port to ST16C454 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. |
| TX A-B<br>TX C-D   | 17,19<br>51,53 | 0           | Serial data output. The serial data is transmitted via this pin<br>with additional start, stop and parity bits. The TX will be held<br>in mark (high) state during reset, local loopback mode or                                                                                                      |
| CS A-B*<br>CS C-D* | 16,20<br>50,54 | l           | when the transmitter is disabled.  Chip select (active low). A low at this pin enables the ST16C454 / CPU data transfer operation. Each UART section of the ST16C454 can be accessed independently.                                                                                                   |
| XTAL1              | 35             | 1 .         | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                              |
| XTAL2              | 36             | 0           | Crystal input 2 or buffered clock output. See XTAL1.                                                                                                                                                                                                                                                  |
| IOW*               | 18             | . 1         | Write strobe (active low). A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                                                                                                                |
| GND<br>GND         | 6,23<br>40,57  | 0           | Signal and power ground.                                                                                                                                                                                                                                                                              |
| IOR*               | 52             | 1           | Read strobe (active low.) A low level on this pin transfers the contents of the ST16C454 data bus to the CPU.                                                                                                                                                                                         |
| RXRDY*             | 38             | 0           | Receive data ready (active low). This pin is the inverted output of internally "or-ed" four received data (LSR Bit-0) bits. Goes low when one of the UART's contains data in the receive holding register.                                                                                            |

# ST16C454

# **SYMBOL DESCRIPTION**

| Symbol               | Pin            | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INTSEL               | <b>65</b>      |             | Interrupt type select. Enable /disable the interrupt three state function. Normal interrupt output can be selected by connecting this pin to VCC ( MCR bit-3 does not have any effect on the interrupt output ). The three state interrupt output is selected when this pin is left open or connected to GND and MCR bit-3 is set to "1".                                                                  |
| TXRDY                | 39             | 0           | Transmit ready (active high). This pin is the output of internally "or-ed" four transmit empty signals (LSR Bit-6). This pin stays low when all four transmitters are empty.                                                                                                                                                                                                                               |
| A2                   | 32             | . 1         | Address select line 2. To select internal registers.                                                                                                                                                                                                                                                                                                                                                       |
| A1                   | 33             | 1           | Address select line 1. To select internal registers.                                                                                                                                                                                                                                                                                                                                                       |
| A0                   | 34             | 1           | Address select line 0. To select internal registers.                                                                                                                                                                                                                                                                                                                                                       |
| INT A-B<br>INT C-D   | 15,21<br>49,55 | 0           | Interrupt output. (active high) This pin goes high (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                                                                                                                      |
| RTS A-B*<br>RTS C-D* | 14,22<br>48,56 | 0           | Request to send. (active low) To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                                                                                           |
| DTR A-B*<br>DTR C-D* | 12,24<br>46,58 | 0           | Data terminal ready. (active low) To indicate that ST16C454 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation. |
| RESET                | 37             | l           | Master reset. (active high) A high on this pin will reset all the outputs and internal registers. The transmitter output and                                                                                                                                                                                                                                                                               |

# SYMBOL DESCRIPTION

| Symbol   | Pin   | Signal Type | Pin Description                                                                                                                                                                                 |
|----------|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ·        |       |             | the receiver input will be disabled during reset time.                                                                                                                                          |
| CTS A-B* | 11,25 |             |                                                                                                                                                                                                 |
| CTS C-D* | 45,59 | 1           | Clear to send. (active low) The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation. |
| DSR A-B* | 10,26 |             |                                                                                                                                                                                                 |
| DSR C-D* | 44,60 | 1           | Data set ready. (active low) A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                 |
| CD A-B*  | 9,27  |             |                                                                                                                                                                                                 |
| CD C-D*  | 43,61 | 1           | Carrier detect. (active low) A low on this pin indicates the carrier has been detected by the modern.                                                                                           |
| RI A-B*  | 8,28  |             |                                                                                                                                                                                                 |
| RI C-D*  | 42,62 | I           | Ring detect indicator. (active low) A low on this pin indicates the modem has received a ringing signal from telephone line.                                                                    |
| vcc      | 13,30 |             |                                                                                                                                                                                                 |
| vcc      | 47,64 | 1           | Power supply input.                                                                                                                                                                             |

# PROGRAMMING TABLE

| A2 | A1 | A0  | READ MODE                 | WRITE MODE                |
|----|----|-----|---------------------------|---------------------------|
| 0  | 0  | 0   | Receive Holding Register  | Transmit Holding Register |
| 0  | 0  | 1 1 | ,                         | Interrupt Enable Register |
| 0  | 1  | 0   | Interrupt Status Register | ,                         |
| 0  | 1  | 1 1 |                           | Line Control Register     |
| 1  | 0  | 0   |                           | Modem Control Register    |
| 1  | 0  | 1 1 | Line Status Register      |                           |
| 1  | 1  | 0   | Modem Status Register     |                           |
| 1  | 1  | 1 1 | Scratchpad Register       | Scratchpad Register       |
| 0  | 0  | 0   |                           | LSB of Divisor Latch      |
| 0  | 0  | 1 1 | ·                         | MSB of Divisor Latch      |

## **ST16C454 ACCESSIBLE REGISTERS**

| A2 | <b>A1</b> | A0 | Register | BIT-7                      | BIT-6           | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----|-----------|----|----------|----------------------------|-----------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0  | 0         | 0  | RHR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0         | 0  | THR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0         | 1  | IER      | 0                          | 0               | 0                          | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0  | 1         | 0  | ISR      | 0                          | 0               | 0                          | 0                  | 0                            | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0  | 1         | 1  | LCR      | divisor<br>latch<br>enable | set<br>break    | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1  | 0         | 0  | MCR      | 0                          | 0               | 0                          | loop<br>back       | INT<br>enable                | Not<br>used                            | RTS*                            | DTR*                           |
| 1  | 0         | 1  | LSR      | 0                          | trans.<br>empty | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1  | 1         | 0  | MSR      | CD                         | RI              | DSR                        | стѕ                | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1  | 1         | 1  | SPR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0         | 0  | DLL      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0         | 1  | DLM      | bit-15                     | bit-14          | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

## REGISTER FUNCTIONAL DESCRIPTIONS

### TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

## PROGRAMMABLE BAUD RATE GENERATOR

The ST16C454 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to 2<sup>16</sup> -1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

## INTERRUPT ENABLE REGISTER (IER)

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the INT output pin.

## IER BIT-0:

0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

### IER BIT-1:

0=disable the transmitter empty interrupt. 1=enable the transmitter empty interrupt.

#### IER BIT-2:

0=disable the receiver line status interrupt. 1=enable the receiver line status interrupt.

#### IER BIT-3:

0=disable the modern status register interrupt. 1=enable the modern status register interrupt.

## **IER BIT 7-4:**

All these bits are set to logic zero.

## INTERRUPT STATUS REGISTER (ISR)

The ST16C454 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C454 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

## **Priority level**

| P | D2 | D1 | D0 | Source of the interrupt                    |
|---|----|----|----|--------------------------------------------|
| 1 | 1  | 1  | 0  | LSR (Receiver Line Status Register)        |
| 2 | 1  | 0  | 0  | RXRDY (Received Data<br>Ready)             |
| 3 | 0  | 1  | 0  | TXRDY( Transmitter Holding Register Empty) |
| 4 | 0  | 0  | 0  | MSR (Modern Status Register)               |

### ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1=no interrupt pending.

## ISR BIT 1-2:

Logical combination of these bits, provides the highest priority interrupt pending.

#### **ISR BIT 3-7:**

These bits are not used and are set to "0".

## LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

## LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 | BIT-0 | Word length |
|-------|-------|-------------|
| 0     | 0     | 5           |
| 0     | 1     | 6           |
| 1     | 0     | 7           |
| 1     | 1     | 8           |

## LCR BIT-2:

The number of stop bits can be specified by this bit.

| BIT-2 | Word length | Stop bit(s) |
|-------|-------------|-------------|
| 0     | 5,6,7,8     | 1           |
| 1     | 5           | 1-1/2       |
| 1     | 6,7,8       | 2           |

#### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

## LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format.

#### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

#### LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0=normal operating condition.

1=forces the transmitter output (TX) to go low to alert the communication terminal.

## LCR BIT-7:

The internal baud rate counter latch enable (DLEN). 0=normal operation.

1=select divisor latch register.

## MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

## MCR BIT-0:

0=force DTR\* output to high. 1=force DTR\* output to low.

#### MCR BIT-1:

0=force RTS\* output to high. 1=force RTS\* output to low.

## MCR BIT-2:

Not used except, in internal loop-back mode.

### MCR BIT-3:

0=set INT output pin to three state mode. 1=set INT output pin to normal operating mode.

## MCR BIT-4:

0=normal operating mode.

1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, MCR bit-2 and INT enable are connected to modem control inputs.

In this mode , the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER .

#### MCR BIT 5-7:

Not used. Are set to zero permanently.

## **LINE STATUS REGISTER (LSR)**

This register provides the status of data transfer to CPU.

#### LSR BIT-0:

0=no data in receive holding register 1=data has been received and saved in the receive holding register.

## LSR BIT-1:

0=no overrun error (normal).

1=overrun error, next character arrived before receive holding register was emptied.

#### LSR BIT-2:

0=no parity error (normal).

1=parity error, received data does not have correct parity information.

## LSR BIT-3:

0=no framing error (normal).

1=framing error received, received data did not have a valid stop bit. In

## LSR BIT-4:

0=no break condition (normal).

1=receiver received a break signal (RX was low for one character time frame).

## LSR BIT-5:

0=transmit holding register is full. ST16C454 will not accept any data for transmission.

1=transmit holding register is empty. CPU can load the next character.

### LSR BIT-6:

0=transmitter holding and shift registers are full.
1=transmitter holding and shift registers are empty.

#### LSR BIT-7:

Not used. Set to "0".

## MODEM STATUS REGISTER (MSR)

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

#### MSR BIT-0:

Indicates that the CTS\* input to the ST16C454 has changed state since the last time it was read.

## MSR BIT-1:

Indicates that the DSR\* input to the ST16C454 has changed state since the last time it was read.

#### MSR BIT-2:

Indicates that the RI\* input to the ST16C454 has changed from a low to a high state.

## MSR BIT-3:

Indicates that the CD\* input to the ST16C454 has changed state since the last time it was read.

3

## MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

## MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

#### MSR BIT-6:

This bit is equivalent to MCR bit-2 during local loop-back mode. It is the compliment of the RI\* input.

### MSR BIT-7

This bit is equivalent to INT enable in the MCR during local loop-back mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated.

## SCRATCHPAD REGISTER (SR)

ST16C454 provides a temporary data register to store 8 bits of information for variable use.

| SIGNALS                                 | RESET STATE                                                        |
|-----------------------------------------|--------------------------------------------------------------------|
| TX OP1* OP2* RTS* DTR* INT RXRdy* TXRdy | High<br>High<br>High<br>High<br>High<br>Three state<br>High<br>Low |

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16 x CLOCK<br>DIVISOR | % ERROR |
|-----------|-----------------------|---------|
| 50        | 2304                  |         |
| 75        | 1536                  |         |
| 110       | 1047                  | 0.026   |
| 134.5     | 857                   | 0.058   |
| 150       | 768                   |         |
| 300       | 384                   |         |
| 600       | 192                   | 1       |
| 1200      | 96                    | 1       |
| 2400      | 48                    |         |
| 3600      | 32                    | 1       |
| 4800      | 24                    |         |
| 7200      | 16                    |         |
| 9600      | 12                    | 1       |
| 19.2K     | 6                     |         |
| 38.4K     | 3                     |         |
| 56K       | . 2                   | 2.77    |
| 115.2K    | 1                     |         |

## ST16C454 EXTERNAL RESET CONDITION

| REGISTERS | RESET STATE                 |
|-----------|-----------------------------|
| IER       | IER BITS 0-7=0              |
| ISR       | ISR BIT-0=1, ISR BITS 1-7=0 |
| LCR       | LCR BITS 0-7=0              |
| MCR       | MCR BITS 0-7=0              |
| LSR       | LSR BITS 0-4=0,             |
|           | LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR       | MSR BITS 0-3=0,             |
| MSR       | BITS 4-7=input signals      |

## **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Parameter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Min                                                                                    | Limits<br>Typ | Max                                                           | Units                                        | Conditions                                          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|---------------|---------------------------------------------------------------|----------------------------------------------|-----------------------------------------------------|
| $\begin{array}{c} T_{1} \\ T_{2} \\ T_{3} \\ T_{8} \\ T_{9} \\ T_{12} \\ T_{13} \\ T_{14} \\ T_{15} \\ T_{16} \\ T_{17} \\ T_{19} \\ T_{23} \\ T_{24} \\ T_{25} \\ T_{1} \\ T_{26} \\ T_{25} \\ T_{1} \\ T_{26} \\$ | Clock high pulse duration Clock low pulse duration Clock rise/fall time Chip select setup time Chip select hold time Data set up time Data hold time IOW* delay from chip select IOW* strobe width Chip select hold time from IOW* Write cycle delay Write cycle=T <sub>15</sub> +T <sub>17</sub> Data hold time IOR* delay from chip select IOR* strobe width Chip select hold time from IOR* Read cycle delay Read cycle delay Read cycle delay Read cycle=T <sub>23</sub> +T <sub>25</sub> Delay from IOR* to data Delay from IOW* to output | 50<br>50<br>15<br>0<br>15<br>15<br>10<br>55<br>105<br>15<br>10<br>65<br>0<br>55<br>115 |               | 10<br>35<br>50<br>70                                          | ns ns ns ns ns ns ns ns ns ns ns ns ns n     | External clock  100 pF load 100 pF load 100 pF load |
| T <sub>29</sub> T <sub>30</sub> T <sub>31</sub> T <sub>32</sub> T <sub>33</sub> T <sub>34</sub> T <sub>35</sub> T <sub>44</sub> T <sub>45</sub> T <sub>46</sub> T <sub>47</sub> N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Delay to set interrupt from MODEM input Delay to reset interrupt from IOR* Delay from stop to set interrupt Delay from IOR* to reset interrupt Delay from initial INT reset to transmit start Delay from stop to interrupt Delay from IOW* to reset interrupt Delay from stop to set RxRdy Delay from IOR* to reset RxRdy Delay from IOW* to set TxRdy Delay from start to reset TxRdy Baud rate devisor                                                                                                                                        | 8                                                                                      |               | 70 1 <sub>Rcik</sub> 200 24 100 175 1 <sub>RCLK</sub> 1 195 8 | ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>us<br>ns | 100 pF load<br>100 pF load<br>100 pF load           |

Note 1: \* = Baudout\* cycle

# ST16C454

## **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

## DC ELECTRICAL CHARACTERISTICS

 $T_A$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                             | Parameter                                                                                                                                                                             | Min                               | Limits<br>Typ | Max                                         | Units        | Conditions                                        |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---------------|---------------------------------------------|--------------|---------------------------------------------------|
| VILCK VIHCK VIH VOL VOH ICC IL ICL | Clock input low level Clock input high level Input low level Input high level Output low level on all outputs Output high level Avg. power supply current Input leakage Clock leakage | -0.5<br>3.0<br>-0.5<br>2.2<br>2.4 |               | 0.6<br>VCC<br>0.8<br>VCC<br>0.4<br>6<br>±10 | >>>>><br>#44 | I <sub>OL</sub> = 6 mA<br>I <sub>OH</sub> = -6 mA |

3

## **GENERAL READ TIMING**



## **GENERAL WRITE TIMING**



## **MODEM TIMING**







16 BAUD RATE CLOCK



## **RXRDY TIMING**



## TXRDY TIMING





# ST68C454

Printed September 6, 1994

## QUAD ASYNCHRONOUS RECEIVER AND TRANSMITTER

## DESCRIPTION

The ST68C454 is a quad universal asynchronous receiver and transmitter with modem control signals. Designed to interface with MOTOROLA, ROCKWELL, HITACHI bus and other popular microprocessors. An internal programmable baud rate generator is provided to select transmit and receive clock rates from 50Hz to 448kHz.

The ST68C454 is an improved, quad version of the NS16450 UART with faster operating access time. The on board status registers will provide the error conditions, type and status of the transfer operations being performed. Complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements to minimize the computing required to handle the communications link.

The ST68C454 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

## **FEATURES**

- · Motorola, Rockwell, Hitachi bus compatible
- Quad ST16C450
- Modem control signals (CTS\*,RTS\*, DSR\*, DTR\*, RI\*, CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- · Status report register
- TTL compatible inputs, outputs
- 448 kHz transmit/receive operation with 7.372 MHz external clock source

## **PLCC Package**



## **ORDERING INFORMATION**

 Part number
 Package
 Operating temperature

 ST68C454CJ68
 PLCC
 0° C to +70° C

 ST68C454IJ68
 PLCC
 -40° C to +85° C



**BLOCK DIAGRAM** 

# SYMBOL DESCRIPTION

| Symbol               | Pin              | Signal Type                           | Pin Description                                                                                                                                                                                                                                                                             |
|----------------------|------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D7-D0                | 5-66             | 1/0                                   | Bi-directional data I/O. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                           |
| RX A/B<br>RX C/D     | 7,29<br>41,63    | . <b>I</b>                            | Serial data input. The serial information received from MODEM or RS232 to ST68C454 receive circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. |
| TX A/B<br>TX C/D     | 17,19<br>51,53   | 0                                     | Serial data output A. The serial data of channel A is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                 |
| cs*                  | 16               | I                                     | Chip select (active low). A low at this pin will enable the UART A-D CPU data transfer operation.                                                                                                                                                                                           |
| XTAL1                | 35               | <b>l</b>                              | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                    |
| XTAL2                | 36               | · · · · · · · · · · · · · · · · · · · | Crystal input 2. See XTAL1.                                                                                                                                                                                                                                                                 |
| R/W*                 | 18               | l                                     | Read/Write strobe. A low on this pin will transfer the contents of the CPU data bus to the addressed register. A high on this pin will transfer the contents of the ST68C454 data bus to the CPU.                                                                                           |
| CD A/B*<br>CD C/D*   | 9,27<br>43,61    | ı                                     | Carrier detect A-D (active low). A low on this pin indicates that carrier has been detected by the modern.                                                                                                                                                                                  |
| GND<br>GND           | 6,23,31<br>40,57 | 0                                     | Signal and power ground.                                                                                                                                                                                                                                                                    |
| DSR A/B*<br>DSR C/D* | 10,26<br>44,60   | l                                     | Data set ready A-D. (active low) A low on this pin indicates that MODEM is ready to exchange data with UART.                                                                                                                                                                                |

# ST68C454

# SYMBOL DESCRIPTION

| Symbol                                       | Pin                                                              | Signal Type | Pin Description                                                                                                                                                                                                                                                                   |
|----------------------------------------------|------------------------------------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RI A/B*<br>RI C/D*                           | 8,28<br>42,62                                                    | l           | Ring detect A-D indicator . (active low) A low on this pin indicates that modem has received a ringing signal from telephone line.                                                                                                                                                |
| RTS A/B*<br>RTS C/D*<br>CTS A/B*<br>CTS C/D* | 14,22<br>48,56<br>11,25<br>45,59                                 | 0           | Request to send A-D. (active low) To indicate that transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to low state. After the reset this pin will be set to high.  Clear to send A-D. (active low) The CTS* signal s a |
| 013 0/15                                     | 40,08                                                            |             | MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmitter output.                                                                                                                                               |
| RXRDY*                                       | 38                                                               | 0           | Receive data ready (active low). This pin is the inverted output of internally "or-ed" four received data (LSR Bit-0) bits. Goes low when one of the UART's contains data in the receive holding register.                                                                        |
| TXRDY                                        | 39                                                               | 0           | Transmit ready (active high). This pin is the output of internally "or-ed" four transmit empty signals (LSR Bit-6). This pin stays low when all four transmitters are empty.                                                                                                      |
| A4                                           | 50                                                               | <b>l</b>    | Address line 4. To select one of the four UARTS.                                                                                                                                                                                                                                  |
| A3                                           | 20                                                               | ł           | Address line 3. To select one of the four UARTS.                                                                                                                                                                                                                                  |
| A2                                           | 32                                                               | 1           | Address line 2. To select internal registers.                                                                                                                                                                                                                                     |
| A1                                           | 33                                                               | 1           | Address line 1. To select internal registers.                                                                                                                                                                                                                                     |
| A0                                           | 34                                                               |             | Address line 0. To select internal registers.                                                                                                                                                                                                                                     |
| IRQ*                                         | 15<br>10 10 10 10 10<br>10 10 10 10 10 10 10 10 10 10 10 10 10 1 |             | Interrupt output. (active low open collector) This pin goes low (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty or modem status condition flag is detected on UART A-D.                                     |

# SYMBOL DESCRIPTION

| Symbol               | Symbol Pin     |   | Pin Description                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|----------------------|----------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| DTR A/B*<br>DTR C/D* | 12,24<br>46,58 | 0 | Data terminal ready A-D. (active low) To indicate that ST68C454 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. |  |  |  |  |
| RESET*               | 37             | 1 | Master reset. (active low) A low on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                                                                                                                            |  |  |  |  |
| vcc                  | 13,30<br>47,64 | 1 | Power supply input.                                                                                                                                                                                                                                                                                                          |  |  |  |  |

# **SERIAL PORT SELECTION GUIDE**

| CS* | A4 | А3 | UART X |
|-----|----|----|--------|
| 1   | Х  | Х  | Х      |
| 0   | 0  | 0  | UART A |
| 0   | 0  | 1  | UART B |
| 0   | 1  | 0  | UART C |
| 0   | 1  | 1  | UART D |

## PROGRAMMING TABLE

| A2  | A1  | A0  | READ MODE                 | WRITE MODE                |
|-----|-----|-----|---------------------------|---------------------------|
| 0   | 0   | 0   | Receive Holding Register  | Transmit Holding Register |
| 0   | 0   | 1.  |                           | Interrupt Enable Register |
| 0   | 1   | 0   | Interrupt Status Register |                           |
| 0   | . 1 | . 1 |                           | Line Control Register     |
| 1 1 | 0   | 0   |                           | Modem Control Register    |
| 1   | 0   | 1   | Line Status Register      |                           |
| 1   | 1   | 0   | Modem Status Register     | ·                         |
| 1   | 1   | 1   | Scratchpad Register       | Scratchpad Register       |
| 0   | 0   | 0   |                           | LSB of Divisor Latch      |
| 0   | 0   | 1   |                           | MSB of Divisor Latch      |

## REGISTER FUNCTIONAL DESCRIPTIONS

# TRANSMIT AND RECEIVE HOLDING REGISTER A-D

The serial transmitter section consists of a Transmit Hold Register A-D and Transmit Shift Register A-D. The status of the transmit hold register is provided in the Line Status Register A-D. Writing to this register will transfer the contents of the data bus (D7-D0) to the transmit holding register A-D whenever the transmitter holding register A-D or transmitter shift register A-D is empty. The transmit holding register empty A-D flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register A-D. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX A-D is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX A-D input. Receiver status codes will be posted in the Line Status Register A-D.

#### PROGRAMMABLE BAUD RATE GENERATOR

The ST68C454 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1

to 2<sup>16</sup>-1. Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

## INTERRUPT ENABLE REGISTER A-D

The Interrupt Enable Register A-D masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the IRQ\* output pin.

#### IER BIT-0:

0=disable the receiver ready interrupt 1=enable the receiver ready interrupt

## IER BIT-1:

0=disable transmitter empty interrupt 1=enable transmitter empty interrupt

#### IER BIT-2:

0=disable receiver line status interrupt 1=enable receiver line status interrupt

## IER BIT-3:

0=disable the modern status register interrupt 1=enable the modern status register interrupt

## **IER BIT 7-4:**

All these bits are set to logic zero.

## **INTERRUPT STATUS REGISTER A-D**

The ST68C454 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register A-D provides the source of the interrupt in prioritized manner. During the read cycle, the ST68C454 provides the highest interrupt level to be serviced by the CPU. No other interrupts are acknowledged until the particular interrupt has been serviced. The following are the prioritized interrupt levels:

| <b>a</b> | D3 | D2 | D1 | D0 | Source of the interrupt                    |
|----------|----|----|----|----|--------------------------------------------|
| 1        | 0  | 1  | 1  | 0  | LSR (Receiver Line Status Register)        |
| 2        | 0  | 1  | 0  | 0  | RXRDY (Received Data Ready)                |
| 3        | 0  | 0  | 1  | 0  | TXRDY( Transmitter Holding Register Empty) |
| 4        | 0  | 0  | 0  | 0  | MSR (Modern Status<br>Register)            |

## ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine

1=no interrupt pending

## **ISR BIT 1-2:**

Logical combination of these bits, provides the highest priority interrupt pending.

## **ISR BIT 3-7:**

These bits are not used and are set zero.

## LINE CONTROL REGISTER A-D

The Line Control Register is used to specify the asynchronous data communication format. The num-

ber of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

#### LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

00=5 bits word length

01=6 bits word length

10=7 bits word length

11=8 bits word length

### LCR BIT-2:

The number of stop bits can be specified by this bit.

0=1 stop bit , when word length=5, 6, 7, 8 bits 1=1 and 1/2 stop bit , when word length=5 bits 1=2 stop bits, word length=6, 7, 8 bits

#### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission; receiver also checks for received parity

### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=odd parity is generated by calculating odd number of 1's in the transmitted data; receiver also checks for same format.

1=an even parity bit is generated by calculating the number of even 1's in the transmitted data; receiver also checks for same format.

#### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

## LCR BIT-6:

Break control bit.

1=forces the transmitter output (TX A-D) to go low to alert the communication terminal 0=normal operating condition

## LCR BIT-7:

The internal baud rate counter latch enable (DLEN). 0=normal operation

1=select divisor latch register

#### MODEM CONTROL REGISTER A-D

This register controls the interface with the MODEM or a peripheral device (RS232).

#### MCR BIT-0:

0=force DTR\* output to high 1=force DTR\* output to low

## MCR BIT-1:

0=force RTS\* output to high 1=force RTS\* output to low

## MCR BIT2-3:

x=not used

## MCR BIT -4:

0=normal operating mode

1=enable local loop-back mode (diagnostics). The transmitter output (TX A-D) is set high (Mark condition), the Receiver inputs (RX A-D, CTS A-D\*, DSR A-D\*, CD A-D\*, and RI A-D\*) are disabled. Internally, the transmitter output is connected to the receiver input and DTR A-D\*, RTS A-D\* and MCR A-D bit2,3 are connected to modem control inputs. In this mode, the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupt sources are now the lower four bits of the Modem Control Register instead of the four Modem Control Inputs. The interrupts are still controlled by the IER A-D.

## MCR BIT 5-7:

Not used. Are set to zero permanently.

## **LINE STATUS REGISTER A-D**

This register provides the status of data transfer to CPU.

#### LSR BIT-0:

0=no data in receive holding register
1=a data has been received and saved in the receive holding register

### LSR BIT-1:

0=no overrun error (normal)

1=overrun error, next character arrived before receive holding register was empty

## LSR BIT-2:

0=no parity error (normal)

1=parity error, received data does not have correct parity information

## LSR BIT-3:

0=no framing error (normal)

1=framing error received, received data did not have a valid stop bit

## LSR BIT-4:

0=no break condition (normal)

1=receiver received a break signal (RX was low for one character time frame)

#### LSR BIT-5:

0=transmit holding register is full; ST68C454 will not accept any data for transmission

1=transmit holding register is empty; CPU can load the next character

#### LSR BIT-6:

0=transmitter holding and shift registers are full 1=transmitter holding and shift registers are empty

## LSR BIT-7:

Not used, set to "0".

## **MODEM STATUS REGISTER A-D**

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

## MSR BIT-0:

Indicates that the CTS\* input to the ST68C454 has changed state since the last time it was read.

### MSR BIT-1:

Indicates that the DSR\* input to the ST68C454 has changed state since the last time it was read.

### MSR BIT-2:

Indicates that the RI\* input to the ST68C454 has changed from a low to a high state.

### MSR BIT-3:

Indicates that the CD\* input to the ST68C454 has changed state since the last time it was read.

## MSR BIT-4:

This bit is equivalent to RTS in the MCR. It is the compliment of the CTS\* input.

#### MSR BIT-5:

This bit is equivalent to DTR in the MCR. It is the compliment of the DSR\* input.

## MSR BIT-6:

This bit is equivalent to MCR bit-2 during local loopback mode. It is the compliment of the RI\* input.

#### MSR BIT-7:

This bit is equivalent to MCR bit-3 during local loop-back mode. It is the compliment to the CD\* input.

## SCRATCHPAD REGISTER A-D

ST68C454 provides a temporary data register to store 8 bits of information for variable use.

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16xCLOCK<br>%ERROR | DVISOR |
|-----------|--------------------|--------|
| 50        | 2304               |        |
| 75        | 1536               |        |
| 150       | 768                |        |
| 300       | 384                |        |
| 600       | 192                | · ·    |
| 1200      | 96                 |        |
| 2400      | 48                 | ļ ·    |
| 4800      | 24                 |        |
| 7200      | 16                 | 1      |
| 9600      | 12                 | 1      |
| 19.2      | 6                  | 1      |
| 38.4K     | 3                  | İ      |
| 56K       | 2                  | 2.77   |
| 115.2K    | 1                  | 1      |

## ST68C454 EXTERNAL RESET CONDITION

| RESET STATE                                                                                                                     |
|---------------------------------------------------------------------------------------------------------------------------------|
| BITS 0-7=0<br>BIT-0=1, BIT-7=0<br>BITS 0-7=0<br>BITS 0-7=0<br>BITS 0-4=0, BITS 5-6=1, BIT-<br>=0<br>BITS 0-3=0, BITS 4-7= input |
|                                                                                                                                 |

| SIGNALS  | RESET STATE      |
|----------|------------------|
| TX A-D   | High             |
| RTS A-D* | High             |
| DTR A-D* | High             |
| IRQ      | Three state mode |
| RXRDY*   | High             |
| TXRDY    | Low              |

# **ST68C454 ACCESSIBLE REGISTERS**

| A2 A1 A0 | Register | BIT-7                      | BIT-6           | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----------|----------|----------------------------|-----------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0 0 0    | RHR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0 0    | THR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0 1    | IER      | 0                          | 0               | 0                          | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0 1 0    | ISR      | 0                          | 0               | 0                          | 0                  | int<br>priority<br>bit-2     | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0 1 1    | LCR      | divisor<br>latch<br>enable | set<br>break    | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1 0 0    | MCR      | 0                          | 0               | 0                          | loop<br>back       | Not<br>used                  | Not<br>used                            | RTS*                            | DTR*                           |
| 1 0 1    | LSR      | 0                          | trans.<br>empty | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1 1 0    | MSR      | CD                         | RI              | DSR                        | стѕ                | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1 1 1    | SPR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0 0    | DLL      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0 1    | DLM      | bit-15                     | bit-14          | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

 $T_A$ =0° - 70° C, VCC=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                    | Parameter                                       | Min | Limits<br>Typ | Max               | Units | Conditions     |
|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------|-----|---------------|-------------------|-------|----------------|
|                                                                                                           |                                                 |     | 196           | ,,,uA             |       |                |
| T <sub>1</sub><br>T <sub>2</sub><br>T <sub>3</sub><br>T <sub>8</sub><br>T <sub>9</sub><br>T <sub>12</sub> | Clock high pulse duration                       | 50  | 1             |                   | ns    |                |
| T <sub>2</sub>                                                                                            | Clock low pulse duration                        | 50  |               |                   | ns    | External clock |
| T <sub>3</sub>                                                                                            | Clock rise/fall time                            | İ   |               | 10                | ns    |                |
| T <sub>8</sub>                                                                                            | Chip select setup time                          | 5   |               |                   | ns    |                |
| T <sub>9</sub>                                                                                            | Chip select hold time                           | 0   |               |                   | ns    |                |
| T <sub>12</sub>                                                                                           | Data setup time                                 | 15  |               |                   | ns    |                |
| T,,                                                                                                       | Data hold time from write or CS*                | 15  |               |                   | ns    |                |
| 1 14                                                                                                      | Write set up time                               | 10  |               |                   | ns    |                |
| T <sub>15</sub>                                                                                           | Write strobe width                              | 50  |               |                   | ns    |                |
| T <sub>16</sub>                                                                                           | Chip select hold time from write                | 15  |               |                   | ns    |                |
| T <sub>17</sub>                                                                                           | Write cycle delay                               | 45  |               |                   | ns    |                |
| T <sub>18</sub>                                                                                           | Data setup time                                 | 15  |               |                   | ns    |                |
| Tw                                                                                                        | Write cycle=T <sub>15</sub> +T <sub>17</sub>    | 105 |               |                   | ns    |                |
| T <sub>24</sub>                                                                                           | Data hold time                                  | 0   |               |                   | ns    |                |
| T <sub>25</sub>                                                                                           | Read cycle delay                                | 25  |               |                   | ns    |                |
| Tr                                                                                                        | Read cycle=T <sub>18</sub> +T <sub>25</sub>     | 105 |               |                   | ns    |                |
| T <sub>27</sub>                                                                                           | Chip select pulse width                         | 75  |               |                   | ns    |                |
| T <sub>28</sub>                                                                                           | Delay from Write to output                      |     |               | 50                | ns    | 100 pF load    |
| T <sub>29</sub>                                                                                           | Delay to set interrupt from MODEM input         |     |               | 35                | ns    | 100 pF load    |
| T <sub>31</sub>                                                                                           | Delay from stop to set interrupt                |     |               | 1 <sub>Rcik</sub> | ns    | 100 pF load    |
| T <sub>32</sub>                                                                                           | Delay from Read to reset interrupt              |     |               | 200               | ns    | 100 pF load    |
| T <sub>33</sub>                                                                                           | Delay from initial IRQ* reset to transmit start | 8   |               | 24                | *     | ,              |
| T <sub>34</sub>                                                                                           | Delay from stop to interrupt                    | 1   | 1             | 100               | ns    |                |
| T <sub>35</sub>                                                                                           | Delay from Write to reset interrupt             |     | 1             | 75                | ns    |                |
| T <sub>44</sub>                                                                                           | Delay from stop to set RxRdy                    |     | 1             | 1 <sub>RCLK</sub> |       |                |
| T <sub>45</sub>                                                                                           | Delay from Read to reset RxRdy                  |     |               | 1 1               | μS    |                |
| T <sub>46</sub>                                                                                           | Delay from Write to set TxRdy                   |     | -             | 195               | ns    |                |
| T <sub>47</sub>                                                                                           | Delay from start to reset TxRdy                 |     |               | 8                 | *     |                |

<sup>\* =</sup> Baudout\* cycle

# ST68C454

## **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

## DC ELECTRICAL CHARACTERISTICS

 $T_{\Delta}$ =0° - 70° C, Vcc=5.0 V ±10% unless otherwise specified.

| Symbol                             | Parameter                      | Min  | Limits<br>Typ | Max        | Units           | Conditions                               |
|------------------------------------|--------------------------------|------|---------------|------------|-----------------|------------------------------------------|
| V <sub>ILCK</sub>                  | Clock input low level          | -0.5 |               | 0.6        | ٧               |                                          |
| VIHCK                              | Clock input high level         | 3.0  |               | VCC        | V               |                                          |
| V <sub>II</sub>                    | Input low level                | -0.5 |               | 0.8        | V               |                                          |
| V <sub>IL</sub><br>V <sub>IH</sub> | Input high level               | 2.2  |               | VCC        | V               |                                          |
| V <sub>ol</sub>                    | Output low level               |      | . '           | 0.4        | V               | l <sub>o∟</sub> = 6 mA on all<br>outputs |
| V <sub>OH</sub>                    | Output high level              | 2.4  |               |            | V               | I <sub>OH</sub> = -6 mA                  |
| I <sub>cc</sub>                    | Avg. power supply current      |      | 6             |            | mA <sub>.</sub> | Off                                      |
| l <sub>IL</sub>                    | Input leakage<br>Clock leakage |      | lest          | ±10<br>±10 | μA<br>μA        |                                          |

3

## **GENERAL WRITE TIMING**



## **GENERAL READ TIMING**



## **MODEM TIMING**











## **TXRDY TIMING**







Printed September 6, 1994

## UNIVERSAL ASYNCHRONOUS RECEIVER/TRANSMITTER WITH FIFOS

#### DESCRIPTION

The ST16C550 is a universal asynchronous receiver and transmitter with 16 byte transmit and receive FIFO. A programmable baud rate generator is provided to select transmit and receive clock rates from 50Hz to 448kHz

The ST16C550 is an improved version of the NS16C550 UART with higher operating speed and lower access time. The ST16C550 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C550 provides internal loop-back capability for on board diagnostic testing.

The ST16C550 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

#### **FEATURES**

- Pin to pin and functional compatible to NS16550,VL16C550,WD16C550
- 16 byte transmit FIFO
- 16 byte receive FIFO with error flags
- Modem control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\*, CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- Independent transmit and receive control
- TTL compatible inputs, outputs
- Software compatible with INS8250, NS16C450
- 448 kHz transmit/receive operation with 7.372 MHz crystal or external clock source

### ORDERING INFORMATION

| Part number  | Package (   | Operating | temperature |
|--------------|-------------|-----------|-------------|
| ST16C550CP40 | Plastic-DIP | 0° C      | to + 70° C  |
| ST16C550CJ44 | PLCC        | 0° C      | to + 70° C  |
| ST16C550CQ52 | QFP         | 0° C      | to + 70° C  |
| ST16C550CQ48 | TQFP        | 0° C      | to + 70° C  |
|              |             |           |             |

\*Industrial operating range are available

## **PLCC Package**



## Plastic-DIP Package

| D0 1        |              | 40 VCC    |
|-------------|--------------|-----------|
| D1 2        | 2            | 39 RI*    |
| D2 3        |              | 38 CD*    |
| D3 4        |              | 37 DSR*   |
| D4 5        | . 7          | 36 CTS*   |
| D5 6        |              | 35 RESET  |
| D6 7        | N.           | 34 OP1*   |
| D7 8        |              | 33 DTR*   |
| RCLK 9      | 6            | 32 RTS*   |
| RX 10       | ST16C550CP40 | 31 OP2*   |
| TX 11       | 355(         | 30 INT    |
| CS0 12      | 76           | 29 RXRDY* |
| CS1 13      | ST           | 28 A0     |
| CS2* 14     |              | 27 A1     |
| BAUDOUT* 15 |              | 26 A2     |
| XTAL1 16    |              | 25 AS*    |
| XTAL2 17    |              | 24 TXRDY  |
| 10W* 18     |              | 23 DDIS*  |
| IOW 19      |              | 22 IOR    |
| GND 20      |              | 21 IOR*   |

3



**BLOCK DIAGRAM** 

# **SYMBOL DESCRIPTION**

| Symbol   | Pin | Signal Type | Pin Description                                                                                                                                                                                                                                                                                       |
|----------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7    | 1-8 | 1/0         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                                     |
| RCLK     | 9   | , <b>I</b>  | Receive clock input. The external clock input to the ST16C550 receiver section if receiver data rate is different from transmitter data rate.                                                                                                                                                         |
| RX       | 10  | 1           | Serial data input. The serial information (data) received from serial port to ST16C550 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. |
| тх       | 11  | 0           | Serial data output. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                                          |
| CS0      | 12  | <b>l</b>    | Chip select 1. (active high) A high at this pin enables the ST16C550 / CPU data transfer operation.                                                                                                                                                                                                   |
| CS1      | 13  | 1           | Chip select 2. (active high) A high at this pin enables the ST16C550 / CPU data transfer operation.                                                                                                                                                                                                   |
| CS2*     | 14  | 1           | Chip select 3. (active low) A low at this pin (while CS0=1 and CS1=1) will enable the ST16C550 / CPU data transfer operation.                                                                                                                                                                         |
| BAUDOUT* | 15  | 0           | Baud rate generator clock output. This output provides the 16x clock of the internal selected baud rate. RCLK pin is connected externally to BAUDOUT* pin to provide receive clock.                                                                                                                   |
| XTAL1    | 16  |             | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                              |

# SYMBOL DESCRIPTION

| Symbol                | Pin                                              | Signal Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Pin Description                                                                                                                                                                                                                                                           |
|-----------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XTAL2                 | , . <b>17</b> - 5.                               | ı                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Crystal input 2 or buffered clock output. See XTAL1.                                                                                                                                                                                                                      |
| IOW*                  | 18                                               | gg (1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Write strobe. (active low) A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                                                                                    |
| IOW                   | 19                                               | 1 - A   1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Write strobe. (active high) Same as IOW*, but uses active high input. Note that only an active IOW* or IOW input is required to transfer data from CPU to ST16C550 during write operation. All the unused pin should be tied to VCC or                                    |
| es for<br>extra entra |                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | GND.                                                                                                                                                                                                                                                                      |
| GND                   | 20                                               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Signal and power ground.                                                                                                                                                                                                                                                  |
| IOR*                  | 21                                               | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Read strobe. (active low) A low level on this pin transfers the contents of the ST16C550 data bus to the CPU.                                                                                                                                                             |
| IOR                   | 22                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Read strobe. (active high) Same as IOR*, but uses active high input. Note that only an active IOR* or IOR input is required to transfer data from ST16C550 to CPU during read operation. All the unused pin should be tied to VCC or GND.                                 |
| DDIS*                 | 23<br>(**) 3 3 3 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Drive disable. (active low) This pin goes low when the CPU is reading data from the ST16C550 to disable the external transceiver or logic's.                                                                                                                              |
| TXRDY                 | <b>24</b>                                        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Transmit ready. (active high) This pin goes high when the transmit FIFO of the ST16C550 is full. It can be used as a single or multi-transfer.                                                                                                                            |
| AS* 12 1              | 25                                               | To be the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second of the second | Address strobe. (active low) A low on this pin will latch the state of the chip selects and addressed register (A2-A0). This input is used when signals are not stable for the duration of a read or write operation. If not required, tie the AS* input permanently low. |
| A2<br>A1              | 26<br>27                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Address select line 2. To select internal registers.  Address select line 1. To select internal registers.                                                                                                                                                                |

# **SYMBOL DESCRIPTION**

| Symbol | Pin      | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Α0     | 28       | ı           | Address select line 0. To select internal registers.                                                                                                                                                                                                                                                                                                                                                       |
| RXRDY* | 29       | 0           | Receive ready. (active low) This pin goes low when the receive FIFO is full. It can be used as a single or multi-                                                                                                                                                                                                                                                                                          |
| INT    | 30       | 0           | transfer.  Interrupt output. (active high) This pin goes high (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                                                                                                           |
| OP2*   | 31       | 0           | General purpose output. (active low) User defined output. See bit-3 modem control register (MCR bit-3).                                                                                                                                                                                                                                                                                                    |
| RTS*   | 32       | 0           | Request to send. (active low) To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                                                                                           |
| DTR*   | 33       | 0           | Data terminal ready. (active low) To indicate that ST16C550 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation. |
| OP1*   | 34       | 0           | General purpose output. (active low) User defined output.<br>See bit-2 of modem control register (MCR bit-2).                                                                                                                                                                                                                                                                                              |
| RESET  | 35       | <b>I</b>    | Master reset. (active high) A high on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                                                                                                                                                                                                        |
| стѕ*   | 36       | <b>1</b>    | Clear to send. (active low) The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation.                                                                                                                                                                                                            |
|        | <u> </u> |             |                                                                                                                                                                                                                                                                                                                                                                                                            |

# **SYMBOL DESCRIPTION**

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                 |
|--------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DSR*   | 37  |             | Data set ready. (active low) A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation. |
| CD*    | 38  | <b>1</b> .  | Carrier detect. (active low) A low on this pin indicates the carrier has been detected by the modern.                                                                           |
| RI*    | 39  | <b>1</b>    | Ring detect indicator. (active low) A low on this pin indicates the modem has received a ringing signal from telephone line.                                                    |
| vcc    | 40  | J           | Power supply input.                                                                                                                                                             |

# PROGRAMMING TABLE

| A2 | A1 | A0 | READ MODE                 | WRITE MODE                |
|----|----|----|---------------------------|---------------------------|
| 0  | 0  | 0  | Receive Holding Register  | Transmit Holding Register |
| 0  | 0  | 1  |                           | Interrupt Enable Register |
| 0  | 1  | 0  | Interrupt Status Register | FIFO Control Register     |
| 0  | 1  | 1  |                           | Line Control Register     |
| 1  | 0  | 0  |                           | Modem Control Register    |
| 1  | 0  | 1  | Line Status Register      |                           |
| 1  | 1  | 0  | Modem Status Register     |                           |
| 1  | 1  | 1  | Scratchpad Register       | Scratchpad Register       |
| 0  | 0  | 0  |                           | LSB of Divisor Latch      |
| 0  | 0  | 1  |                           | MSB of Divisor Latch      |

# **ST16C550 ACCESSIBLE REGISTERS**

| A2 | A1 | A0  | Register | BIT-7                      | BIT-6                    | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----|----|-----|----------|----------------------------|--------------------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0  | 0  | 0   | RHR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 0   | THR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 1   | IER      | 0                          | 0                        | 0                          | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0  | 1  | 0   | FCR      | RCVR<br>trigger<br>(MSB)   | RCVR<br>trigger<br>(LSB) | 0                          | 0                  | DMA<br>mode<br>select        | XMIT<br>FIFO<br>reset                  | RCVR<br>FIFO<br>reset           | FIFO<br>enable                 |
| .0 | 1  | 0   | ISR      | 0/<br>FIFOs<br>enabled     | 0/<br>FIFOs<br>enabled   | 0                          | 0                  | int<br>priority<br>bit-2     | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0  | 1  | 1   | LCR      | divisor<br>latch<br>enable | set<br>break             | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1  | 0  | 0   | MCR      | 0                          | 0                        | 0                          | loop<br>back       | OP2*                         | OP1*                                   | RTS*                            | DTR*                           |
| 1  | 0  | 1   | LSR      | 0/<br>FIFO<br>error        | trans.<br>empty          | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1  | 1  | 0   | MSR      | CD                         | RI                       | DSR                        | CTS                | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1  | 1  | 1   | SPR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 0   | DLL      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 1 . | DLM      | bit-15                     | bit-14                   | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

### REGISTER FUNCTIONAL DESCRIPTIONS

#### TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

### FIFO INTERRUPT MODE OPERATION

When the receive FIFO (FCR BIT-0=1) and receive interrupts (IER BIT-0=1) are enabled, receiver interrupt will occur as follows:

- A) The receive data available interrupts will be issued to the CPU when the FIFO has reached its programmed trigger level; it will be cleared as soon as the FIFO drops below its programmed trigger level.
- B) The ISR receive data available indication also occurs when the FIFO trigger level is reached, and like the interrupt it is cleared when the FIFO drops below the trigger level.
- C) The data ready bit (LSR BIT-0) is set as soon as a character is transferred from the shift register to the receiver FIFO, It is reset when the FIFO is empty.

#### FIFO POLLED MODE OPERATION

When FCR BIT-0=1; resetting IER BIT 3-0 to zero puts the ST16C550 in the FIFO polled mode of operation. Since the receiver and transmitter are controlled separately either one or both can be in the polled mode operation by utilizing the Line Status Register.

- A) LSR BIT-0 will be set as long as there is one byte in the receive FIFO.
- B) LSR BIT4-1 will specify which error(s) has occurred.
- C) LSR BIT-5 will indicate when the transmit FIFO is empty.
- D) LSR BIT-6 will indicate when both transmit FIFO and transmit shift register are empty.
- E) LSR BIT-7 will indicate when there are any errors in the receive FIFO.

The ST16C550 requires to have two step FIFO enable operation in order to enable receive trigger levels.

#### PROGRAMMABLE BAUD RATE GENERATOR

The ST16C550 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to 2<sup>16</sup> -1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

### INTERRUPT ENABLE REGISTER (IER)

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the INT output pin.

#### IER BIT-0:

0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

#### IER BIT-1:

**0=disable** the transmitter empty interrupt. **1=enable** the transmitter empty interrupt.

#### IER BIT-2:

0=disable the receiver line status interrupt. 1=enable the receiver line status interrupt.

#### IER BIT-3:

0=disable the modem status register interrupt. 1=enable the modem status register interrupt.

#### **IER BIT 7-4:**

All these bits are set to logic zero.

### **INTERRUPT STATUS REGISTER (ISR)**

The ST16C550 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C550 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

#### **Priority level**

| Р  | D3 | D2 | D1 | D0 | Source of the interrupt                             |
|----|----|----|----|----|-----------------------------------------------------|
| 1  | 0  | 1  | 1. | 0  | LSR (Receiver Line Sta-<br>tus Register)            |
| 2  | 0  | 1  | 0  | 0  | RXRDY (Received Data                                |
| 2* | 1  | 1  | o  | 0  | Ready) RXRDY (Receive Data time out)                |
| 3  | 0  | 0  | 1  | 0  | TXRDY( Transmitter                                  |
| 4  | 0  | 0  | 0  | 0  | Holding Register Empty) MSR (Modem Status Register) |

#### \*RECEIVE TIME-OUT:

This mode is enabled when STARTECH UART is operating in FIFO mode. Receive time out will not occur if the receive FIFO is empty. The time out counter will be reset at the center of each stop bit received or each time receive holding register is read. The actual time out value is T (Time out length in bits)= 4 X P (Programmed word length) + 12. To convert time out value to a character value, user has to divide this number to its complete word length + parity (if used) + number of stop bits and start bit.

Example -A: If user programs the word length = 7, and no parity and one stop bit, Time out will be:  $T = 4 \times 7$  (programmed word length) +12 = 40 bits Character time = 40 / 9 [ (programmed word length = 7) + (stop bit = 1) + (start bit = 1)] = 4.4 characters.

Example -B: If user programs the word length = 7, with parity and one stop bit, the time out will be:  $T = 4 \times 7$  (programmed word length) + 12 = 40 bits Character time = 40 / 10 [ (programmed word length = 7) + (parity = 1) + (stop bit = 1) + (start bit = 1) = 4 characters.

#### ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1=no interrupt pending.

#### **ISR BIT 1-3:**

Logical combination of these bits, provides the highest priority interrupt pending.

#### **ISR BIT 4-7:**

These bits are not used and are set to zero in ST16C450 mode. BIT 6-7: are set to "1" in ST16C550 mode.

#### FIFO CONTROL REGISTER (FCR)

This register is used to enable the FIFOs, clear the FIFOs, set the receiver FIFO trigger level, and select the type of DMA signaling.

#### FCR BIT-0:

0=Disable the transmit and receive FIFO.

1=Enable the transmit and receive FIFO.

This bit should be enabled before setting the FIFO trigger levels.

### FCR BIT-1:

0=No change.

1=Clears the contents of the receive FIFO and resets its counter logic to 0 (the receive shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-2:

0=No change.

1=Clears the contents of the transmit FIFO and resets its counter logic to 0 (the transmit shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-3:

0=No change.

1=Changes RXRDY and TXRDY pins from mode "0" to mode "1".

### Transmit operation in mode "0":

When ST16C550 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) when there are no characters in the transmit FIFO or transmit holding register, the TXRDY\* pin will go low. Once active the TXRDY\* pin will go high (inactive) after the first character is loaded into the transmit holding register.

#### Receive operation in mode "0":

When ST16C550 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) and there is at least 1 character in the receive FIFO, the RXRDY\* pin will go low. Once active the RXRDY\* pin will go high (inactive) when there are no more characters in the receiver.

#### Transmit operation in mode "1":

When ST16C550 is in FIFO mode (FCR bit-0=1, FCR bit-3=1) the TXRDY\* pin will become high (inactive) when the transmit FIFO is completely full. It will be low if one or more FIFO locations are empty.

### Receive operation in mode "1":

When ST16C550 is in FIFO mode (FCR bit-0=1, FCR bit-3=1) and the trigger level or the timeout has been reached, the RXRDY\* pin will go low. Once it is activated it will go high (inactive) when there are no more characters in the FIFO.

#### **FCR BIT 4-5:**

Not used.

#### FCR BIT 6-7:

These bits are used to set the trigger level for the receiver FIFO interrupt.

| BIT-7 | BIT-6 | FIFO trigger level |
|-------|-------|--------------------|
| 0     | 0     | 01                 |
| 0     | 1     | 04                 |
| 1     | 0     | 08                 |
| 1     | 1     | 14                 |
|       |       | i .                |

#### LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

#### LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 | BIT-0 | Word length |
|-------|-------|-------------|
| 0     | 0     | 5           |
| 0     | 1     | 6           |
| 1     | 0     | 7           |
| 1     | 1     | 8           |

#### LCR BIT-2:

The number of stop bits can be specified by this bit.

| BIT-2 | Word length | Stop bit(s) |
|-------|-------------|-------------|
| 0     | 5,6,7,8     | 1<br>1-1/2  |
| 1     | 6,7,8       | 2           |

#### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format.

#### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

#### LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0=normal operating condition.

1=forces the transmitter output (TX) to go low to alert the communication terminal.

#### LCR BIT-7:

The internal baud rate counter latch enable (DLAB). 0=normal operation.

1=select divisor latch register.

### MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

#### MCR BIT-0:

0=force DTR\* output to high. 1=force DTR\* output to low.

#### MCR BIT-1:

0=force RTS\* output to high. 1=force RTS\* output to low.

#### MCR BIT-2:

0=set OP1\* output to high. 1=set OP1\* output to low.

#### MCR BIT-3:

0=set OP2\* output to high. 1=set OP2\* output to low.

### MCR BIT-4:

0=normal operating mode.

1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, OP1\* and OP2\* are connected to modem control inputs. In this mode, the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER.

#### MCR BIT 5-7:

Not used. Are set to zero permanently.

#### LINE STATUS REGISTER (LSR)

This register provides the status of data transfer to CPU.

#### LSR BIT-0:

0=no data in receive holding register or FIFO. 1=data has been received and saved in the receive

holding register or FIFO.

#### LSR BIT-1:

0=no overrun error (normal).

1=overrun error, next character arrived before receive holding register was emptied or if FIFOs are enabled, an overrun error will occur only after the FIFO is full and the next character has been completely received in the shift register. Note that character in the shift register is overwritten, but it is not transferred to the FIFO.

#### LSR BIT-2:

0=no parity error (normal).

1=parity error, received data does not have correct parity information. In the FIFO mode this error is associated with the character at the top of the FIFO.

#### LSR BIT-3:

0=no framing error (normal).

1=framing error received, received data did not have a valid stop bit. In the FIFO mode this error is associated with the character at the top of the FIFO.

#### LSR BIT-4:

0=no break condition (normal).

1=receiver received a break signal (RX was low for one character time frame). In FIFO mode, only one zero character is loaded into the FIFO.

### LSR BIT-5:

0=transmit holding register is full. ST16C550 will not accept any data for transmission.

1=transmit holding register (or FIFO ) is empty. CPU can load the next character.

#### LSR BIT-6:

0=transmitter holding and shift registers are full. 1=transmitter holding and shift registers are empty. In FIFO mode this bit is set to one whenever the transmitter FIFO and transmit shift register are empty.

#### LSR BIT-7:

0=Normal.

1=At least one parity error, framing error or break indication in the FIFO. This bit is cleared when LSR is read.

## MODEM STATUS REGISTER (MSR)

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

#### MSR BIT-0:

Indicates that the CTS\* input to the ST16C550 has changed state since the last time it was read.

#### MSR BIT-1:

Indicates that the DSR\* input to the ST16C550 has changed state since the last time it was read.

#### MSR BIT-2:

Indicates that the RI\* input to the ST16C550 has changed from a low to a high state.

#### MSR BIT-3:

Indicates that the CD\* input to the ST16C550 has changed state since the last time it was read.

### MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

#### MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

### MSR BIT-6:

This bit is equivalent to OP1 in the MCR during local loop-back mode. It is the compliment of the RI\* input.

#### MSR BIT-7:

This bit is equivalent to OP2 in the MCR during local loop-back mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated.

## SCRATCHPAD REGISTER (SR)

ST16C550 provides a temporary data register to store 8 bits of information for variable use.

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE         | 16 x CLOCK<br>DIVISOR | % ERROR |
|-------------------|-----------------------|---------|
| 50                | 2304                  |         |
| 75                | 1536                  |         |
| 110               | 1047                  | 0.026   |
| 134.5             | 857                   | 0.058   |
| 150               | 768                   |         |
| 300               | 384                   |         |
| 600               | 192                   |         |
| 1200              | 96                    | Ì       |
| 2400              | 48                    |         |
| 3600              | 32                    |         |
| 4800              | 24                    |         |
| 7200 <sup>-</sup> | 16                    |         |
| 9600              | 12                    |         |
| 19.2K             | 6                     | 1       |
| 38.4K             | 3                     |         |
| 56K               | 2                     | 2.77    |
| 115.2K            | 1                     |         |

### ST16C550 EXTERNAL RESET CONDITION

| REGISTERS | RESET STATE                 |
|-----------|-----------------------------|
| IER       | IER BITS 0-7=0              |
| ISR       | ISR BIT-0=1, ISR BITS 1-7=0 |
| LCR       | LCR BITS 0-7=0              |
| MCR       | MCR BITS 0-7=0              |
| LSR       | LSR BITS 0-4=0,             |
|           | LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR       | MSR BITS 0-3=0,             |
|           | MSR BITS 4-7=input signals  |
| FCR       | FCR BITS 0-7=0              |

| SIGNALS | RESET STATE |
|---------|-------------|
| TX      | High        |
| OP1*    | High        |
| OP2*    | High        |
| RTS*    | High        |
| DTR*    | High        |
| RXRDY*  | High        |
| TXRDY   | Low         |
| INT     | Low         |

# **AC ELECTRICAL CHARACTERISTICS**

 $T_A = 0^{\circ} - 70^{\circ}$  C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                                                                                                                                                                                 | Parameter                                                                                                                                                                                                                                                                                                                                                                                         | Min                                                                    | Limits<br>Typ | Max                   | Units                                        | Conditions                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|---------------|-----------------------|----------------------------------------------|-----------------------------------------------------------------------------|
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>4</sub> T <sub>5</sub> T <sub>6</sub> T <sub>7</sub> T <sub>8</sub> T <sub>9</sub> T <sub>10</sub> T <sub>11</sub> T <sub>12</sub> T <sub>13</sub> T <sub>14</sub> T <sub>15</sub> T <sub>16</sub> T <sub>17</sub> | Parameter  Clock high pulse duration Clock low pulse duration Clock rise/fall time Baud out rise/fall time Address strobe width Address setup time Address hold time Chip select setup time Chip select hold time CSOUT delay from chip select IOR* to DDIS* delay Data setup time Data hold time IOW* delay from chip select IOW* strobe width Chip select hold time from IOW* Write cycle delay | 50<br>50<br>30<br>30<br>5<br>5<br>0<br>10<br>15<br>15<br>10<br>50<br>0 | Limits        | 10<br>100<br>25<br>25 | Units  Ins Ins Ins Ins Ins Ins Ins Ins Ins I | Conditions  External clock  100 pF load  Note: 1  Note: 1  Note: 1  Note: 1 |
| TW T <sub>19</sub> T <sub>21</sub> T <sub>23</sub> T <sub>24</sub> T <sub>25</sub> Tr T <sub>26</sub> T <sub>28</sub> T <sub>29</sub>                                                                                                                                  | Write cycle=T <sub>15</sub> +T <sub>17</sub> Data hold time IOR* delay from chip select IOR* strobe width Chip select hold time from IOR* Read cycle delay Read cycle=T <sub>23</sub> +T <sub>25</sub> Delay from IOR* to data Delay from IOW* to output Delay to set interrupt from MODEM                                                                                                        | 105<br>15<br>10<br>65<br>0<br>55<br>115                                |               | 25<br>35<br>50<br>70  | ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns | Note: 1  Note: 1  100 pF load 100 pF load 100 pF load                       |

 $T_{\Delta}$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                         | Parameter                                                                 | Min | Limits<br>Typ | Max                      | Units | Conditions                 |
|----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|-----|---------------|--------------------------|-------|----------------------------|
| T <sub>30</sub>                                                                                                | Delay to reset interrupt from IOR*                                        |     |               | 70                       | ns    | 100 pF load                |
| T <sub>31</sub>                                                                                                | input Delay from stop to set interrupt Delay from IOR* to reset interrupt |     |               | 1 <sub>RClk</sub>        | ns    | 100 pF load<br>100 pF load |
| T <sub>31</sub><br>T <sub>32</sub><br>T <sub>33</sub>                                                          | Delay from initial INT reset to transmit start                            | 8   |               | 24                       | *     | 100 pr 10au                |
| T <sub>34</sub>                                                                                                | Delay from stop to interrupt                                              |     |               | 100                      | ns    |                            |
| T <sub>34</sub><br>T <sub>35</sub><br>T <sub>44</sub><br>T <sub>45</sub><br>T <sub>46</sub><br>T <sub>47</sub> | Delay from IOW* to reset interrupt Delay from stop to set RxRdy           |     |               | 175<br>1 <sub>RCLK</sub> | ns    |                            |
| T <sub>45</sub>                                                                                                | Delay from IOR* to reset RxRdy                                            |     |               | 1                        | μS    |                            |
| T <sub>46</sub>                                                                                                | Delay from IOW* to set TxRdy                                              |     |               | 195                      | ns    | · ·                        |
| T <sub>47</sub>                                                                                                | Delay from start to reset TxRdy                                           |     |               | 8                        | *     |                            |
| N                                                                                                              | Baud rate devisor                                                         | 1   |               | 2 <sup>16</sup> -1       |       |                            |

Note 1:

Applicable only when AS\* is tied low

\* = Baudout\* cycle

# 52 Pin QFP Package



# 48 Pin TQFP Package



3

# **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

# DC ELECTRICAL CHARACTERISTICS

 $T_{\Delta}$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                          | Parameter                                                                                                                                                                            | Min                               | Limits<br>Typ | Max                                    | Units | Conditions                                        |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---------------|----------------------------------------|-------|---------------------------------------------------|
| VILCK VIHCK VIH VOL VOH ICC IIL | Clock input low level Clock input high level Input low level Input high level Output low level on all outputs Output high level Avg power supply current Input leakage Clock leakage | -0.5<br>3.0<br>-0.5<br>2.2<br>2.4 | 6             | 0.6<br>VCC<br>0.8<br>VCC<br>0.4<br>±10 | >>>>  | I <sub>оь</sub> = 6 mA<br>I <sub>он</sub> = -6 mA |

## **CLOCK TIMING**



# BAUDOUT\* TIMING



## GENERAL WRITE TIMING



# GENERAL READ TIMING



## MODEM TIMING











## TXRDY TIMING FOR MODE "1"



## **RXRDY TIMING FOR MODE "0"**



## **RXRDY TIMING FOR MODE "1"**





Printed September 15, 1994

## UNIVERSAL ASYNCHRONOUS RECEIVER/TRANSMITTER WITH FIFOS

### **DESCRIPTION**

The ST16C1550/51/52 is a universal asynchronous receiver and transmitter with 16 byte transmit and receive FIFO. A programmable baud rate generator is provided to select transmit and receive clock rates from 50Hz to 448kHz.

The ST16C1550/51/52 is an improved version of the SSI 73M1550 and SSI 73M2550 UART with higher operating speed and lower access time. The ST16C1550/51/52 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C1550/51/52 provides internal loop-back capability for on board diagnostic testing.

The ST16C1550/51/52 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

### **FEATURES**

- Pin to pin and functional compatible to SSI 73M1550/2550
- 16 byte transmit FIFO
- 16 byte receive FIFO with error flags
- Modem control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\*, CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- Software compatible with INS8250, NS16C550
- 448 kHz transmit/receive operation with 7.372 MHz crystal or external clock source

### ORDERING INFORMATION

| Part number                              | Package     | Operating  | temperature |
|------------------------------------------|-------------|------------|-------------|
| ST16C1550CP28                            | Plastic-DIP | 0° C       | to + 70° C  |
| ST16C1550CJ28                            | PLCC        | 0° C       | to + 70° C  |
| ST16C1550CQ48                            | TQFP        | 0° C       | to + 70° C  |
| ST16C1551CP28                            | Plastic-Dip | 0° C       | to + 70° C  |
| ST16C1551CJ28                            | PLCC        | 0° C       | to + 70° C  |
| ST16C1551CQ48                            | TQFP        | 0° C       | to + 70° C  |
| ST16C1552CQ52                            | QFP         | 0° C       | to + 70° C  |
| When also a dealer I have a condition of |             | !! -  -  - |             |

## \*Industrial operating range are available

## **PLCC Package**





## QFP Package



## ST16C1550 BLOCK DIAGRAM



# ST16C1551 BLOCK DIAGRAM



# ST16C1550 SYMBOL DESCRIPTION

| Symbol | Pin | Signal Type    | Pin Description                                                                                                                                                                                                                                                                                        |
|--------|-----|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7  | 1-8 | 1/0            | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                                      |
| RX     | 9   |                | Serial data input. The serial information (data) received from serial port to ST16C1550 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. |
| TX     | 10  | 0              | Serial data output. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                                           |
| CS*    | 11  | 1              | Chip select (active low). A low at this pin enables the ST16C1550 / CPU data transfer operation.                                                                                                                                                                                                       |
| XTAL1  | 12  | <b>)</b>       | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                               |
| XTAL2  | 13  | 1              | Crystal input 2 or buffered clock output. See XTAL1.                                                                                                                                                                                                                                                   |
| IOW*   | 14  | * • • <b>1</b> | Write strobe (active low). A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                                                                                                                 |
| GND    | 15  | 0              | Signal and power ground.                                                                                                                                                                                                                                                                               |
| IOR*   | 16  | <b>, l</b>     | Read strobe (active low). A low level on this pin transfers the contents of the ST16C1550 data bus to the CPU.                                                                                                                                                                                         |
| RI*    | 17  | 1              | Ring detect indicator (active low). A low on this pin indicates the modem has received a ringing signal from telephone line.                                                                                                                                                                           |
| INT    | 18  | O              | Interrupt output. (three state / active high) This pin goes high                                                                                                                                                                                                                                       |

# ST16C1550 SYMBOL DESCRIPTION

| Symbol | Pin   | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| :      |       |             | (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                                                                                                                                                                          |
| A0-A2  | 21-19 | l l         | Address select line. To select internal registers.                                                                                                                                                                                                                                                                                                                                                          |
| RTS*   | 22    | 0           | Request to send (active low). To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                                                                                            |
| DTR*   | 23    | 0           | Data terminal read (active low). To indicate that ST16C1550 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset . Note that this pin does not have any effect on the transmit or receive operation. |
| RESET  | 24    | ı           | Master reset (active high). A high on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                                                                                                                                                                                                         |
| стѕ*   | 25    | 1           | Clear to send (active low). The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR bit-4. CTS* has no effect on the transmit or receive operation.                                                                                                                                                                                                             |
| DSR*   | 26    | . <b>1</b>  | Data set ready (active low). A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                                                                                                                                                                                                                             |
| CD*    | 27    | <b> </b>    | Carrier detect (active low). A low on this pin indicates the carrier has been detected by the modem.                                                                                                                                                                                                                                                                                                        |
| VCC    | 28    |             | Power supply input.                                                                                                                                                                                                                                                                                                                                                                                         |

# ST16C1551 SYMBOL DESCRIPTION

| Symbol | Pin | Signal Type                            | Pin Description                                                                                                                                                                                                                                  |
|--------|-----|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7  | 1-8 | 1/0                                    | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                |
| RX     | 9   | 1                                      | Serial data input. The serial information (data) received from serial port to ST16C1551 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external |
| TX     | 40  |                                        | connection and connected to the TX output internally.                                                                                                                                                                                            |
|        | 10  | 0                                      | Serial data output. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                     |
| CS*    | 11  | <b>l</b>                               | Chip select (active low). A low at this pin enables the ST16C1551 / CPU data transfer operation.                                                                                                                                                 |
| CLK    | 12  | Ĺ                                      | External clock input. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                                                                                             |
| IOW*   | 13  | <b>,</b>                               | Write strobe (active low). A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                                                           |
| GND    | 14  | 0                                      | Signal and power ground.                                                                                                                                                                                                                         |
| IOR*   | 15  | 1 %                                    | Read strobe (active low). A low level on this pin transfers the contents of the ST16C1551 data bus to the CPU                                                                                                                                    |
| RI*    | 16  | 10 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Ring detect indicator (active low). A low on this pin indicates the modem has received a ringing signal from telephone line.                                                                                                                     |
| RST    | 17  | 0                                      | Reset output (active high). The ST16C1551 provides a buffered reset output which is gated internally with MCR bit-2.                                                                                                                             |
| INT    | 18  | 0                                      | Interrupt output. (three state / active high) This pin goes high                                                                                                                                                                                 |

# **ST16C1551 SYMBOL DESCRIPTION**

| Symbol | Pin   | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ·      |       |             | (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                                                                                                                                                                         |
| A0-A2  | 21-19 | 1           | Address select line. To select internal registers.                                                                                                                                                                                                                                                                                                                                                         |
| RTS*   | 22    | 0           | Request to send (active low). To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                                                                                           |
| DTR*   | 23    | 0           | Data terminal read (active low). To indicate that ST16C1551 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation. |
| RESET  | 24    | :1          | Master reset (active high). A high on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                                                                                                                                                                                                        |
| стѕ*   | 25    | I           | Clear to send (active low). The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation.                                                                                                                                                                                                            |
| DSR*   | 26    | 1           | Data set ready (active low). A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                                                                                                                                                                                                                            |
| CD*    | 27    | 4           | Carrier detect (active low). A low on this pin indicates the carrier has been detected by the modem.                                                                                                                                                                                                                                                                                                       |
| vcc    | 28    | 1           | Power supply input.                                                                                                                                                                                                                                                                                                                                                                                        |

## **PROGRAMMING TABLE**

| A2 | A1  | A0  | READ MODE                 | WRITE MODE                |
|----|-----|-----|---------------------------|---------------------------|
| 0  | 0   | 0   | Receive Holding Register  | Transmit Holding Register |
| 0  | 0   | 1   |                           | Interrupt Enable Register |
| 0  | . 1 | 0   | Interrupt Status Register | FIFO Control Register     |
| 0  | 1   | 1   |                           | Line Control Register     |
| 1  | 0   | 0   |                           | Modem Control Register    |
| 1  | 0   | . 1 | Line Status Register      |                           |
| 1  | 1   | 0   | Modem Status Register     |                           |
| 1  | 1   | 1   | Scratchpad Register       | Scratchpad Register       |
| 0  | 0   | 0   |                           | LSB of Divisor Latch      |
| 0  | 0   | 1   |                           | MSB of Divisor Latch      |



## ST16C1550 ACCESSIBLE REGISTERS

| A2 | <b>A</b> 1 | A0 | Register | BIT-7                      | BIT-6                    | BIT-5                      | BIT-4                      | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----|------------|----|----------|----------------------------|--------------------------|----------------------------|----------------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0  | 0          | 0  | RHR      | bit-7                      | bit-6                    | bit-5                      | bit-4                      | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0          | 0  | THR      | bit-7                      | bit-6                    | bit-5                      | bit-4                      | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0          | 1  | IER      | 0                          | 0                        | 0/<br>special<br>mode      | 0                          | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0  | 1          | 0  | FCR      | RCVR<br>trigger<br>(MSB)   | RCVR<br>trigger<br>(LSB) | 0 / TX<br>trigger<br>(MSB) | 0 / TX<br>trigger<br>(LSB) | DMA<br>mode<br>select        | XMIT<br>FIFO<br>reset                  | RCVR<br>FIFO<br>reset           | FIFO<br>enable                 |
| 0  | 1          |    | ISR      | 0/<br>FIFOs<br>enabled     | 0/<br>FIFOs<br>enabled   | 0/<br>RXRDY                | 0/<br>TXRDY                | int<br>priority<br>bit-2     | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0  | 1          | 1  | LCR      | divisor<br>latch<br>enable | set<br>break             | set<br>parity              | even<br>parity             | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1  | 0          | 0  | MCR      | 0/power<br>down            | 0                        | 0                          | loop<br>back               | INT<br>enable                | SOFT reset                             | RTS*                            | DTR*                           |
| 1  | 0          | 1  | LSR      | 0 /<br>FIFO<br>error       | trans.<br>empty          | trans.<br>holding<br>empty | break<br>interrupt         | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1  | 1          | 0  | MSR      | CD                         | RI                       | DSR                        | CTS                        | delta<br>CD*                 | delta<br>Ri*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1  | 1          | 1  | SPR      | bit-7                      | bit-6                    | bit-5                      | bit-4                      | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0          | 0  | DLL      | bit-7                      | bit-6                    | bit-5                      | bit-4                      | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0          | 1  | DLM      | bit-15                     | bit-14                   | bit-13                     | bit-12                     | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

# ST16C1551 ACCESSIBLE REGISTERS

| A2 A1 A | 0 Register | BIT-7                      | BIT-6                    | BIT-5                      | BIT-4                    | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|---------|------------|----------------------------|--------------------------|----------------------------|--------------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0 0 0   | RHR        | bit-7                      | bit-6                    | bit-5                      | bit-4                    | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 000     | ) THR      | bit-7                      | bit-6                    | bit-5                      | bit-4                    | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0 1   | IER        | . 0                        | 0                        | 0 /<br>special<br>mode     | 0                        | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0 1 0   | FCR        | RCVR<br>trigger<br>(MSB)   | RCVR<br>trigger<br>(LSB) | 0/TX<br>trigger<br>(MSB)   | 0/TX<br>trigger<br>(LSB) | DMA<br>mode<br>select        | XMIT<br>FIFO<br>reset                  | RCVR<br>FIFO<br>reset           | FIFO<br>enable                 |
| 0 1 0   | ) ISR      | 0 /<br>FIFOs<br>enabled    | 0 /<br>FIFOs<br>enabled  | 0/<br>RXRDY                | 0/<br>TXRDY              | int<br>priority<br>bit-2     | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0 1 1   | LCR        | divisor<br>latch<br>enable | set<br>break             | set<br>parity              | even<br>parity           | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1 0 0   | MCR        | 0/power<br>down            | 0                        | 0                          | loop<br>back             | INT<br>enable                | SOFT<br>reset                          | RTS*                            | DTR*                           |
| 1 0 1   | LSR        | 0/<br>FIFO<br>error        | trans.<br>empty          | trans.<br>holding<br>empty | break<br>interrupt       | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1 1 0   | MSR        | CD                         | RI ,                     | DSR                        | CTS                      | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1 1 1   | SPR        | bit-7                      | bit-6                    | bit-5                      | bit-4                    | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 000     | DLL        | bit-7                      | bit-6                    | bit-5                      | bit-4                    | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0 1   | 1 DLM      | bit-15                     | bit-14                   | bit-13                     | bit-12                   | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

### REGISTER FUNCTIONAL DESCRIPTIONS

### TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

### FIFO INTERRUPT MODE OPERATION

When the receive FIFO (FCR BIT-0=1) and receive interrupts (IER BIT-0=1) are enabled, receiver interrupt will occur as follows:

- A) The receive data available interrupts will be issued to the CPU when the FIFO has reached its programmed trigger level; it will be cleared as soon as the FIFO drops below its programmed trigger level.
- B) The ISR receive data available indication also occurs when the FIFO trigger level is reached, and like the interrupt it is cleared when the FIFO drops below the trigger level.
- C) The data ready bit (LSR BIT-0) is set as soon as a character is transferred from the shift register to the receiver FIFO. It is reset when the FIFO is empty.

### FIFO POLLED MODE OPERATION

When FCR BIT-0=1; resetting IER BIT 3-0 to zero puts the ST16C1550/51/52 in the FIFO polled mode of operation. Since the receiver and transmitter are controlled separately either one or both can be in the polled mode operation by utilizing the Line Status Register.

- A) LSR BIT-0 will be set as long as there is one byte in the receive FIFO.
- B) LSR BIT4-1 will specify which error(s) has occurred.
- C) LSR BIT-5 will indicate when the transmit FIFO is empty.
- D) LSR BIT-6 will indicate when both transmit FIFO and transmit shift register are empty.
- E) LSR BIT-7 will indicate when there are any errors in the receive FIFO.

The ST16C1550/51/52 requires to have two step FIFO enable operation in order to enable receive trigger levels.

### PROGRAMMABLE BAUD RATE GENERATOR

The ST16C1550/51/52 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to 2<sup>16</sup>-1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

### INTERRUPT ENABLE REGISTER (IER)

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the INT output pin.

#### IER BIT-0:

0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

### IER BIT-1:

0=disable the transmitter empty interrupt. 1=enable the transmitter empty interrupt.

### IER BIT-2:

0=disable the receiver line status interrupt. 1=enable the receiver line status interrupt.

#### IER BIT-3:

0=disable the modern status register interrupt. 1=enable the modern status register interrupt.

### **IER BIT 4:**

This bit is not used and set to zero.

### IER BIT 5:

0=disable the ISR bits 4-5 and MCR bit-7.
1=enable the ISR bits 4-5 and MCR bit-7 function.

### **IER BIT 6-7:**

These bits are not used and set to zero.

## **INTERRUPT STATUS REGISTER (ISR)**

The ST16C1550/51/52 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C1550/51/52 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

## **Priority level**

| Р   | D3 | D2 | D1 | D0 | Source of the interrupt                       |
|-----|----|----|----|----|-----------------------------------------------|
| 1   | 0  | 1  | 1  | 0  | LSR (Receiver Line Sta-<br>tus Register)      |
| 2   | 0  | 1  | 0  | 0  | RXRDY (Received Data Ready)                   |
| 2*  | 1  | 1  | 0  | 0  | RXRDY (Received Data time out)                |
| 3 . | 0  | 0  | 1  | 0  | TXRDY( Transmitter<br>Holding Register Empty) |
| 4   | 0  | 0  | 0  | 0  | MSR (Modem Status<br>Register)                |

### \*RECEIVE TIME-OUT:

This mode is enabled when STARTECH UART is operating in FIFO mode. Receive time out will not occur if the receive FIFO is empty. The time out counter will be reset at the center of each stop bit received or each time receive holding register is read. The actual time out value is T (Time out length in bits)= 4 X P (Programmed word length) + 12. To convert time out value to a character value, user has to divide this number to its complete word length + parity (if used) + number of stop bits and start bit.

Example -A: If user programs the word length = 7, and no parity and one stop bit, Time out will be:  $T = 4 \times 7$  (programmed word length) +12 = 40 bits Character time = 40 / 9 [ (programmed word length = 7) + (stop bit = 1) + (start bit = 1)] = 4.4 characters.

Example -B: If user programs the word length = 7, with parity and one stop bit, the time out will be:  $T = 4 \times 7$ (programmed word length) + 12 = 40 bits Character time = 40 / 10 [ (programmed word length = 7) + (parity = 1) + (stop bit = 1) + (start bit = 1) = 4 characters.

### ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1=no interrupt pending.

### **ISR BIT 1-2:**

Logical combination of these bits, provides the highest priority interrupt pending.

### ISR BIT 3:

This bit is used with conjunction of ISR bit 0-2: 0=normal interrupt mode 1=receive time-out indicator when priority level is set to "2" (D0=0, D1=0, and D2=1)

### ISR bit-4:

This bit is the compliment of TXRDY\* (ST16C550) pin when IER bit-4 is set to "1".

0=transmitter is full

1=transmitter is empty or less than full

### ISR bit-5:

This bit is the compliment of RXRDY\* (ST16C550) pin when IER biot-4 is set to "1".

0=receiver is empty.

1=receiver is not empty

### ISR bit-6-7:

0=16C450 mode 1=16C550 mode

### FIFO CONTROL REGISTER (FCR)

This register is used to enable the FIFOs, clear the FIFOs, set the receiver FIFO trigger level, and select the type of DMA signaling.

### FCR BIT-0:

0=Disable the transmit and receive FIFO.
1=Enable the transmit and receive FIFO.
This bit should be enabled before setting the FIFO trigger levels.

## FCR BIT-1:

0=No change.

1=Clears the contents of the receive FIFO and resets its counter logic to 0 (the receive shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-2:

0=No change.

1=Clears the contents of the transmit FIFO and resets its counter logic to 0 (the transmit shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

### FCR BIT-3:

0=No change.

1=Changes RXRDY and TXRDY pins from mode "0" to mode "1".

### Transmit operation in mode "0":

When ST16C550 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) when there are no characters in the transmit FIFO or transmit holding register, the TXRDY\* pin will go low. Once active the TXRDY\* pin will go high (inactive) after the first character is loaded into the transmit holding register.

## Receive operation in mode "0":

When ST16C550 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) and there is at least 1 character in the receive FIFO, the RXRDY\* pin will go low. Once active the RXRDY\* pin will go high (inactive) when there are no more characters in the receiver.

### Transmit operation in mode "1":

When ST16C550 is in FIFO mode (FCR bit-0=1, FCR bit-3=1) the TXRDY\* pin will become high (inactive) when the transmit FIFO is completely full. It will be low if one or more FIFO locations are empty.

### Receive operation in mode "1":

When ST16C550 is in FIFO mode (FCR bit-0=1, FCR bit-3=1) and the trigger level or the timeout has been reached, the RXRDY\* pin will go low. Once it is activated it will go high (inactive) when there are no more characters in the FIFO.

### **FCR BIT 4-5:**

These bits are used to set the transmit trigger levels. See receive FIFO trigger table.

3

### **FCR BIT 6-7:**

These bits are used to set the trigger level for the receiver FIFO interrupt.

| BIT-7 | BIT-6 | FIFO trigger level |
|-------|-------|--------------------|
| 0     | 0     | 01                 |
| 0     | 1     | 04                 |
| 1     | 0     | 08                 |
| 1     | 1     | 14                 |
|       |       |                    |

## LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

### LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 BIT-0 |     | Word length |
|-------------|-----|-------------|
| 0           | . 0 | 5           |
| 0           | 1   | 6           |
| 1           | 0   | 7           |
| 1           | -1- | 8           |

### LCR BIT-2:

The number of stop bits can be specified by this bit.

| BIT-2 | Word length | Stop bit(s) |
|-------|-------------|-------------|
| 0     | 5,6,7,8     | 1           |
| 1     | 5<br>6,7,8  | 1-1/2       |

### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format.

### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

### LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0=normal operating condition.

1=forces the transmitter output (TX) to go low to alert the communication terminal.

### LCR BIT-7:

The internal baud rate counter latch enable (DLEN). 0=normal operation.

1=select divisor latch register.

### MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

### MCR BIT-0:

0=force DTR\* output to high.

1=force DTR\* output to low.

### MCR BIT-1:

0=force RTS\* output to high. 1=force RTS\* output to low.

### MCR BIT-2:

0=normal operation.

1=software reset, set RST output to high.

### MCR BIT-3:

0=set INT output pin to three state mode. 1=set INT output pin to normal operation mode.

### MCR BIT-4:

0=normal operating mode.

1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, SOFT reset and INT enable are connected to modem control inputs.

In this mode , the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER .

### MCR BIT 5-6:

Not used. Are set to zero permanently.

### MCR bit-7:

0=normal mode.

1=power down mode. CLK, XTAL1, XTAL2, and baud rate generators are disabled.

### LINE STATUS REGISTER (LSR)

This register provides the status of data transfer to CPU.

## LSR BIT-0:

0=no data in receive holding register or FIFO. 1=data has been received and saved in the receive holding register or FIFO.

### LSR BIT-1:

0=no overrun error (normal).

1=overrun error, next character arrived before receive holding register was emptied or if FIFOs are enabled, an overrun error will occur only after the FIFO is full and the next character has been completely received in the shift register. Note that character in the shift register is overwritten, but it is not transferred to the FIFO.

### LSR BIT-2:

0=no parity error (normal).

1=parity error, received data does not have correct parity information. In the FIFO mode this error is associated with the character at the top of the FIFO.

### LSR BIT-3:

0=no framing error (normal).

1=framing error received, received data did not have a valid stop bit. In the FIFO mode this error is associated with the character at the top of the FIFO.

### LSR BIT-4:

0=no break condition (normal).

1=receiver received a break signal (RX was low for one character time frame). In FIFO mode, only one zero character is loaded into the FIFO.

### LSR BIT-5:

0=transmit holding register is full. ST16C1550/51/52 will not accept any data for transmission.

1=transmit holding register (or FIFO ) is empty. CPU can load the next character.

### LSR BIT-6:

0=transmitter holding and shift registers are full. 1=transmitter holding and shift registers are empty. In FIFO mode this bit is set to one whenever the transmitter FIFO and transmit shift register are empty.

### LSR BIT-7:

0=Normal.

1=At least one parity error, framing error or break indication in the FIFO. This bit is cleared when LSR is read.

## MODEM STATUS REGISTER (MSR)

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

### MSR BIT-0:

Indicates that the CTS\* input to the ST16C1550/51/52 has changed state since the last time it was read.

### MSR BIT-1:

Indicates that the DSR\* input to the ST16C1550/51/52 has changed state since the last time it was read.

### MSR BIT-2:

Indicates that the RI\* input to the ST16C1550/51/52 has changed from a low to a high state.

### MSR BIT-3:

Indicates that the CD\* input to the ST16C1550/51/52 has changed state since the last time it was read.

### MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

## MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

### MSR BIT-6:

This bit is equivalent to SOFT reset in the MCR during local loop-back mode. It is the compliment of the RI\* input.

### MSR BIT-7:

This bit is equivalent to INT enable in the MCR during local loop-back mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a

MODEM Status Interrupt is generated.

### SCRATCHPAD REGISTER (SR)

ST16C1550/51/52 provides a temporary data register to store 8 bits of information for variable use.

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16 x CLOCK<br>DIVISOR | % ERROR |
|-----------|-----------------------|---------|
| 50        | 2304                  |         |
| 75        | 1536                  |         |
| 110       | 1047                  | 0.026   |
| 134.5     | 857                   | 0.058   |
| 150       | 768                   |         |
| 300       | 384                   |         |
| 600       | 192                   |         |
| 1200      | 96                    |         |
| 2400      | 48                    | 1       |
| 3600      | 32                    |         |
| 4800      | 24                    | 1       |
| 7200      | 16                    | 1       |
| 9600      | 12                    |         |
| 19.2K     | 6                     | 1       |
| 38.4K     | 3                     | 1       |
| 56K       | 2                     | 2.77    |
| 115.2K    | 1                     |         |

| SIGNALS   | RESET STATE |
|-----------|-------------|
| TX        | High        |
| SOFTreset | High        |
| RTS*      | High        |
| DTR*      | High        |
| INT       | Three state |

# ST16C1550/51/52 EXTERNAL RESET CONDITION

| RESET STATE                 |
|-----------------------------|
| IER BITS 0-7=0              |
| ISR BIT-0=1, ISR BITS 1-7=0 |
| LCR BITS 0-7=0              |
| MCR BITS 0-7=0              |
| LSR BITS 0-4=0,             |
| LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR BITS 0-3=0,             |
| MSR BITS 4-7=input signals  |
| FCR BITS 0-7=0              |
|                             |

# **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                   | Parameter                                      | Min | Limits<br>Typ | Max              | Units | Conditions     |
|--------------------------------------------------------------------------|------------------------------------------------|-----|---------------|------------------|-------|----------------|
| T.                                                                       | Clock high pulse duration                      | 50  |               |                  | ns    |                |
| T.                                                                       | Clock low pulse duration                       | 50  | 1             |                  | ns    | External clock |
| T.                                                                       | Clock rise/fall time                           |     |               | 10               | ns    |                |
| T.                                                                       | Chip select setup time                         | 5   |               |                  | ns    | ·              |
| T.°                                                                      | Chip select hold time                          | 0   |               |                  | ns    |                |
| $egin{array}{c} T_1 & T_2 & & & & & & & & & & & & & & & & & & &$         | Data set up time                               | 15  |               |                  | ns    |                |
| T.,                                                                      | Data hold time                                 | 15  |               |                  | ns    |                |
| T.,                                                                      | IOW*delay from chip select                     | 10  |               |                  | ns    |                |
| T <sub>15</sub>                                                          | IOW* strobe width                              | 50  |               |                  | ns    |                |
| T <sub>16</sub>                                                          | Chip select hold time from IOW*                | 0   |               |                  | ns    |                |
| T <sub>17</sub>                                                          | Write cycle delay                              | 55  |               |                  | ns    |                |
| Τw                                                                       | Write cycle=T <sub>15</sub> +T <sub>17</sub>   | 105 |               |                  | ns    |                |
| T <sub>19</sub>                                                          | Data hold time                                 | 15  |               |                  | ns    |                |
| T <sub>21</sub>                                                          | IOR* delay from chip select                    | 10  | ]             |                  | ns    |                |
| T <sub>23</sub>                                                          | IOR* strobe width                              | 65  |               |                  | ns    |                |
| T <sub>24</sub>                                                          | Chip select hold time from IOR*                | 0   |               |                  | ns    |                |
| T <sub>05</sub>                                                          | Read cycle delay                               | 55  | 1 1           |                  | ns    |                |
| T <sub>25</sub><br>Tr                                                    | Read cycle=T <sub>23</sub> +T <sub>25</sub>    | 115 |               |                  | ns    |                |
| T                                                                        | Delay from IOR* to data                        |     |               | 35               | ns    | 100 pF load    |
| T <sub>26</sub><br>T <sub>28</sub>                                       | Delay from IOW* to output                      |     |               | 50               | ns    | 100 pF load    |
| T <sub>29</sub>                                                          | Delay to set interrupt from MODEM input        |     | 2.5           | 70               | ns    | 100 pF load    |
| T <sub>20</sub>                                                          | Delay to reset interrupt from IOR*             | 1.  | l 1           | 70               | ns    | 100 pF load    |
| T <sub>31</sub>                                                          | Delay from stop to set interrupt               |     |               | 1 <sub>Rdk</sub> | ns    | 100 pF load    |
| T <sub>x</sub>                                                           | Delay from IOR* to reset interrupt             | 1   |               | 200              | ns    | 100 pF load    |
| T <sub>30</sub><br>T <sub>31</sub><br>T <sub>32</sub><br>T <sub>33</sub> | Delay from initial INT reset to transmit start | 8   |               | 24               | *     | 9.             |
| T <sub>24</sub>                                                          | Delay from stop to interrupt                   | 1   |               | 100              | ns    |                |
| T <sub>34</sub><br>T <sub>35</sub>                                       | Delay from IOW* to reset interrupt             |     |               | 175              | ns    |                |
| 30                                                                       |                                                |     |               |                  | 2     |                |

Note 1: \* = Baudout\* cycle

## **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

# DC ELECTRICAL CHARACTERISTICS

 $T_a=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol          | Parameter                       | Min  | Limits<br>Typ | Max | Units | Conditions              |
|-----------------|---------------------------------|------|---------------|-----|-------|-------------------------|
| VILCK           | Clock input low level           | -0.5 |               | 0.6 | · v   |                         |
| VIHCK           | Clockinput high level           | 3.0  |               | VCC | V     |                         |
| VIL             | Input low level                 | -0.5 |               | 0.8 | V     |                         |
| ٧,۵             | Input high level                | 2.2  |               | vcc | V     |                         |
| V <sub>IH</sub> | Output low level on all outputs |      |               | 0.4 | V     | I <sub>oL</sub> = 6 mA  |
| V <sub>OH</sub> | Output high level               | 2.4  |               |     | V     | I <sub>он</sub> = -6 mA |
| Icc             | Avg. power supply current       |      | 6             |     | mA    | Or i                    |
| IL              | Inputleakage                    |      |               | ±10 | μΑ    |                         |
| l <sub>CL</sub> | Clockleakage                    |      |               | ±10 | μΑ    |                         |

# 28 PIN PLASTIC-DIP ST16C1550

|       | -  |                  |    |       |
|-------|----|------------------|----|-------|
| D0    | 1  |                  | 28 | VCC   |
| D1    | 2  |                  | 27 | CD*   |
| D2    | 3  |                  | 26 | DSR*  |
| D3    | 4  |                  | 25 | CTS*  |
| D4    | 5  |                  | 24 | RESET |
| D5    | 6  | - 58             | 23 | DTR*  |
| D6    | 7  | ST16C1550CP28    | 22 | RTS*  |
| D7    | 8  | 6C1 <del>(</del> | 21 | A0    |
| RX    | 9  | ST               | 20 | A1    |
| TX    | 10 |                  | 19 | A2    |
| CS*   | 11 |                  | 18 | INT   |
| KTAL1 | 12 |                  | 17 | RI*   |
| KTAL2 | 13 |                  | 16 | IOR*  |
| IOW*  | 14 |                  | 15 | GND   |
|       |    |                  | 1  |       |

# 28 PIN PLASTIC-DIP ST16C1551

|      | _  |               | <br>_ |       |
|------|----|---------------|-------|-------|
| D0   | 1  |               | 28    | VCC   |
| D1   | 2  |               | 27    | CD*   |
| D2   | 3  |               | 26    | DSR*  |
| D3   | 4  |               | 25    | CTS*  |
| D4   | 5  |               | 24    | RESET |
| D5   | 6  | 28            | 23    | DTR*  |
| D6   | 7  | ST16C1551CP28 | 22    | RTS*  |
| D7   | 8  | ĝ.            | 21    | A0    |
| RX   | 9  | ES.           | 20    | A1    |
| TX   | 10 |               | 19    | A2    |
| CS*  | 11 |               | 18    | INT   |
| CLK  | 12 |               | 17    | RST   |
| IOW* | 13 |               | 16    | RI*   |
| GND  | 14 |               | 15    | IOR*  |
|      | 1  |               | 1     |       |

# **GENERAL WRITE TIMING**



### **GENERAL READ TIMING**



## **MODEM TIMING**











Printed September 7, 1994

# **DUAL ASYNCHRONOUS RECEIVER/TRANSMITTER WITH FIFOS**

### DESCRIPTION

The ST16C2550 is a dual asynchronous receiver and transmitter with 16 byte transmit and receive FIFO. Independent programmable baud rate generators are provided to select transmit and receive clock rates from 50Hz to 448kHz for each UART.

The ST16C2550 is an improved version of the NS16C550 UART with higher operating speed and lower access time. The ST16C2550 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C2550 provides internal loop-back capability for on board diagnostic testing.

The ST16C2550 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

### **FEATURES**

- Pin to pin and functional compatible to ST16C2450
- 16 byte transmit FIFO
- 16 byte receive FIFO with error flags
- Modem control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\*, CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- Status report register
- Independent transmit and receive control
- TTL compatible inputs, outputs
- Software compatible with INS8250, NS16C550
- 448 kHz transmit/receive operation with 7.372 MHz crystal or external clock source

### ORDERING INFORMATION

Part number Package Operating temperature ST16C2550CP40 Plastic-DIP 0° C to + 70° C ST16C2550CJ44 PLCC 0° C to + 70° C \*Industrial operating range are available

# **PLCC Package**



## Plastic-DIP Package

|       | _  |               | _         |
|-------|----|---------------|-----------|
| D0    | 1  |               | 40 VCC    |
| D1    | 2  |               | 39 RIA*   |
| D2    | 3  |               | 38 CDA*   |
| D3    | 4  |               | 37 DSRA*  |
| D4    | 5  |               | 36 CTSA*  |
| D5    | 6  |               | 35 RESET  |
| D6    | 7  |               | 34 DTRB** |
| D7    | 8  | 0             | 33 DTRA*  |
| RXB   | 9  | PA C          | 32 RTSA*  |
| RXA   | 10 | 2200          | 31 OPA*   |
| TXA   | 11 | ST16C2550CP40 | 30 INTA   |
| TXB   | 12 | :T16          | 29 INTB   |
| OPB*  | 13 | Ø             | 28 A0     |
| CSA*  | 14 | **            | 27 A1     |
| CSB*  | 15 |               | 26 A2     |
| XTAL1 | 16 | N.            | 25 CTSB*  |
| XTAL2 | 17 | `             | 24 RTSB*  |
| IOW*  | 18 |               | 23 RIB*   |
| CDB*  | 19 | •             | 22 DSRB*  |
| GND   | 20 | •             | 21 IOR*   |
|       |    |               |           |

**BLOCK DIAGRAM** 



# **SYMBOL DESCRIPTION**

| Symbol  | Pin   | Signal Type | Pin Description                                                                                                                                                                                                                                                                                            |
|---------|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7   | 1-8   | I/O         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                                          |
| RX A/B  | 10,9  | l           | Serial data input A/B. The serial information (data) received from serial port to ST16C2550 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. |
| TX A/B  | 11,12 | 0           | Serial data output A/B. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                                           |
| CS A/B* | 14,15 | . 1         | Chip select A/B. (active low) A low at this pin enables the ST16C2550 / CPU data transfer operation.                                                                                                                                                                                                       |
| XTAL1   | 16    | l           | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                                   |
| XTAL2   | 17    | l           | Crystal input 2 or buffered clock output. See XTAL1.                                                                                                                                                                                                                                                       |
| IOW*    | 18    | ı           | Write strobe. (active low) A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                                                                                                                     |
| IOR*    | 21    | 1           | Read strobe. (active low) A low level on this pin transfers the contents of the ST16C2550 data bus to the CPU.                                                                                                                                                                                             |
| A0-A2   | 28-26 | ı           | Address select lines. To select internal registers.                                                                                                                                                                                                                                                        |
| INT A/B | 30,29 | 0           | Interrupt output A/B. (active high) This pin goes high (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                  |

# SYMBOL DESCRIPTION

| Symbol   | Pin       | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|-----------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OP2 A/B* | 31        |             | Interrupt enable output (active low). This pin stays high when INT out pin is set to three state mode and goes low when INT pin is enabled via OP2*. See bit-3 modem control register (MCR bit-3).                                                                                                                                                                                                              |
| RTS A/B* | 32,24     | 0           | Request to send A/B (active low). To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                                                                                            |
| DTR A/B* | 33,34     |             | Data terminal ready A/B (active low). To indicate that ST16C2550 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation. |
| RESET    | <b>35</b> |             | Master reset. (active high) A high on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                                                                                                                                                                                                             |
| CTS A/B* | 36,25     |             | Clear to send A/B (active low). The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation.                                                                                                                                                                                                             |
| DSR A/B* | 37,22     |             | Data set ready A/B (active low). A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                                                                                                                                                                                                                             |
| CD A/B*  | 38,19     |             | Carrier detect A/B (active low). A low on this pin indicates the carrier has been detected by the modem.                                                                                                                                                                                                                                                                                                        |
| RI A/B*  | 39,23     |             | Ring detect indicator A/B (active low). A low on this pin indicates the modem has received a ringing signal from telephone line.                                                                                                                                                                                                                                                                                |

# **SYMBOL DESCRIPTION**

| Symbol     | Pin     | Signal Type | Pin Description                                                                                                                                |
|------------|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| vcc        | 40      | ı           | Power supply input.                                                                                                                            |
| GND        | 20      | 0           | Signal and power ground.                                                                                                                       |
| TXRDY A/B  | 1,12**  | 0           | Transmit ready. (active high) This pin goes high when the transmit FIFO of the ST16C550 is full. It can be used as a single or multi-transfer. |
| RXRDY A/B* | 34,23** | 0           | Receive ready. (active low) This pin goes low when the receive FIFO is full. It can be used as a single or multi-transfer.                     |

<sup>\*\*</sup> Available on the PLCC package only.

# **PROGRAMMING TABLE**

| A2 | A1 | A0 | READ MODE                 | WRITE MODE                |
|----|----|----|---------------------------|---------------------------|
| Ó  | 0  | 0  | Receive Holding Register  | Transmit Holding Register |
| 0  | 0  | 1  |                           | Interrupt Enable Register |
| 0  | 1  | 0  | Interrupt Status Register | FIFO Control Register     |
| 0  | 1. | 1  |                           | Line Control Register     |
| 1  | 0  | 0  |                           | Modem Control Register    |
| 1  | 0  | 1  | Line Status Register      |                           |
| 1  | 1. | 0  | Modem Status Register     |                           |
| 1  | 1  | 1  | Scratchpad Register       | Scratchpad Register       |
| 0  | 0  | 0  |                           | LSB of Divisor Latch      |
| 0  | .0 | 1  |                           | MSB of Divisor Latch      |

# ST16C2550 ACCESSIBLE REGISTERS A/B

| A2 | A1 | A0 | Register | BIT-7                      | BIT-6                    | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----|----|----|----------|----------------------------|--------------------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0  | 0  | 0  | RHR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 0  | THR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 1  | IER      | 0                          | 0                        | 0                          | ,                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0  | 1  | 0  | FCR      | RCVR<br>trigger<br>(MSB)   | RCVR<br>trigger<br>(LSB) | 0                          | 0                  | DMA<br>mode<br>select        | XMIT<br>FIFO<br>reset                  | RCVR<br>FIFO<br>reset           | FIFO<br>enable                 |
| 0  | 1  | 0  | ISR      | 0/<br>FIFOs<br>enabled     | 0/<br>FIFOs<br>enabled   | 0                          | 0                  | int<br>priority<br>bit-2     | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0  | 1  | 1  | LCR      | divisor<br>latch<br>enable | set<br>break             | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1  | 0  | 0  | MCR      | 0                          | 0                        | 0                          | loop<br>back       | OP2/<br>INT<br>enable        | Not<br>used                            | RTS*                            | DTR*                           |
| 1  | 0  | 1  | LSR      | 0/<br>FIFO<br>error        | trans.<br>empty          | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1  | 1  | 0  | MSR      | CD                         | RI                       | DSR                        | стѕ                | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1  | 1  | 1  | SPR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 0  | DLL      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 1  | DLM      | bit-15                     | bit-14                   | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

3

### .

## REGISTER FUNCTIONAL DESCRIPTIONS

### TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

### FIFO INTERRUPT MODE OPERATION

When the receive FIFO (FCR BIT-0=1) and receive interrupts (IER BIT-0=1) are enabled, receiver interrupt will occur as follows:

- A) The receive data available interrupts will be issued to the CPU when the FIFO has reached its programmed trigger level; it will be cleared as soon as the FIFO drops below its programmed trigger level.
- B) The ISR receive data available indication also occurs when the FIFO trigger level is reached, and like the interrupt it is cleared when the FIFO drops below the trigger level.
- C) The data ready bit (LSR BIT-0) is set as soon as a character is transferred from the shift register to the receiver FIFO. It is reset when the FIFO is empty.

### FIFO POLLED MODE OPERATION

When FCR BIT-0=1; resetting IER BIT 3-0 to zero puts the ST16C2550 in the FIFO polled mode of operation. Since the receiver and transmitter are controlled separately either one or both can be in the polled mode operation by utilizing the Line Status Register.

- A) LSR BIT-0 will be set as long as there is one byte in the receive FIFO.
- B) LSR BIT4-1 will specify which error(s) has occurred.
- C) LSR BIT-5 will indicate when the transmit FIFO is empty.
- D) LSR BIT-6 will indicate when both transmit FIFO and transmit shift register are empty.
- E) LSR BIT-7 will indicate when there are any errors in the receive FIFO.

The ST16C2550 requires to have two step FIFO enable operation in order to enable receive trigger levels.

### PROGRAMMABLE BAUD RATE GENERATOR

The ST16C2550 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to 2<sup>16</sup> -1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

### INTERRUPT ENABLE REGISTER (IER)

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the INT output pin.

### IER BIT-0:

0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

### IER BIT-1:

0=disable the transmitter empty interrupt. 1=enable the transmitter empty interrupt.

### IER BIT-2:

0=disable the receiver line status interrupt. 1=enable the receiver line status interrupt.

### IER BIT-3:

0=disable the modern status register interrupt. 1=enable the modern status register interrupt.

### **IER BIT 4-7:**

All these bits are set to logic zero.

### **INTERRUPT STATUS REGISTER (ISR)**

The ST16C2550 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C2550 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

## Priority level

| Р  | D3 | D2 | D1 | D0 | Source of the interrupt                       |
|----|----|----|----|----|-----------------------------------------------|
| 1  | 0  | 1  | 1  | 0  | LSR (Receiver Line Status Register)           |
| 2  | 0  | 1  | 0  | 0  | RXRDY (Received Data<br>Ready)                |
| 2* | 1  | 1  | 0  | 0  | RXRDY (Received Data time out)                |
| 3  | 0  | 0  | 1  | 0  | TXRDY( Transmitter<br>Holding Register Empty) |
| 4  | 0  | 0  | 0  | 0  | MSR (Modern Status<br>Register)               |

### \*RECEIVE TIME-OUT:

This mode is enabled when STARTECH UART is operating in FIFO mode. Receive time out will not occur if the receive FIFO is empty. The time out counter will be reset at the center of each stop bit received or each time receive holding register is read. The actual time out value is T (Time out length in bits)= 4 X P (Programmed word length) + 12. To convert time out value to a character value, user has to divide this number to its complete word length + parity (if used) + number of stop bits and start bit.

Example -A: If user programs the word length = 7, and no parity and one stop bit, Time out will be:  $T = 4 \times 7$  (programmed word length) +12 = 40 bits Character time = 40 / 9 [ (programmed word length = 7) + (stop bit = 1) + (start bit = 1)] = 4.4 characters.

Example -B: If user programs the word length = 7, with parity and one stop bit, the time out will be:  $T = 4 \times 7$  (programmed word length) + 12 = 40 bits Character time = 40 / 10 [ (programmed word length = 7) + (parity = 1) + (stop bit = 1) + (start bit = 1) = 4 characters.

### ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1=no interrupt pending.

### **ISR BIT 1-3:**

Logical combination of these bits, provides the highest priority interrupt pending.

### **ISR BIT 4-7:**

These bits are not used and are set to zero in ST16C450 mode. BIT 6-7: are set to "1" in ST16C2550 mode.

### FIFO CONTROL REGISTER (FCR)

This register is used to enable the FIFOs, clear the FIFOs, set the receiver FIFO trigger level, and select the type of DMA signaling.

## FCR BIT-0:

0=Disable the transmit and receive FIFO.

1=Enable the transmit and receive FIFO.

This bit should be enabled before setting the FIFO trigger levels.

### FCR BIT-1:

0=No change.

1=Clears the contents of the receive FIFO and resets its counter logic to 0 (the receive shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

### FCR BIT-2:

0=No change.

1=Clears the contents of the transmit FIFO and resets its counter logic to 0 (the transmit shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

### FCR BIT-3:

0=No change.

1=Changes RXRDY and TXRDY pins from mode "0" to mode "1".

### Transmit operation in mode "0":

When ST16C2550 is in ST16C450 mode ( FCR bit-0=0) or in the FIFO mode ( FCR bit-0=1, FCR bit-3=0) when there are no characters in the transmit FIFO or transmit holding register, the TXRDY\* pin will go low. Once active the TXRDY\* pin will go high (inactive) after the first character is loaded into the transmit holding register.

### Receive operation in mode "0":

When ST16C2550 is in ST16C450 mode ( FCR bit-0=0) or in the FIFO mode ( FCR bit-0=1, FCR bit-3=0) and there is at least 1 character in the receive FIFO, the RXRDY\* pin will go low. Once active the RXRDY\* pin will go high (inactive) when there are no more characters in the receiver.

### Transmit operation in mode "1":

When ST16C2550 is in ST16C550 mode (FCR bit-0=1, FCR bit-3=1) the TXRDY\* pin will become high (inactive) when the transmit FIFO is completely full. It will be low if one or more FIFO locations are empty.

### Receive operation in mode "1":

When ST16C2550 is in ST16C550 mode (FCR bit-0=1, FCR bit-3=1) and the trigger level or the timeout has been reached, the RXRDY\* pin will go low. Once it is activated it will go high (inactive) when there are no more characters in the FIFO.

### **FCR BIT 4-5:**

Not used.

### **FCR BIT 6-7:**

These bits are used to set the trigger level for the receiver FIFO interrupt.

| BIT-7 | BIT-6 | FIFO trigger level |
|-------|-------|--------------------|
| 0     | 0     | 01                 |
| 0     | 1     | 04                 |
| 1     | 0     | 08                 |
| 1     | 1     | 14                 |
|       |       |                    |

### LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

#### LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 | BIT-0 | Word length |
|-------|-------|-------------|
| 0     | 0     | 5           |
| 0     | 1     | 6           |
| 1 1   | 0     | 7           |
| 1     | 1     | 8           |

### LCR BIT-2:

The number of stop bits can be specified by this bit.

| BIT-2 | Word length | Stop bit(s) |
|-------|-------------|-------------|
| 0     | 5,6,7,8     | 1           |
| 1     | 5           | 1-1/2       |
| 1     | 6,7,8       | 2           |

### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format.

### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

### LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0=normal operating condition.

1=forces the transmitter output (TX) to go low to alert the communication terminal.

### LCR BIT-7:

The internal baud rate counter latch enable (DLAB). 0=normal operation.

1=select divisor latch register.

### MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

#### MCR BIT-0:

0=force DTR\* output to high. 1=force DTR\* output to low.

### MCR BIT-1:

0=force RTS\* output to high. 1=force RTS\* output to low.

### MCR BIT-2:

Not used except in local loop-back mode.

#### MCR BIT-3:

0=set INT output pin to three state mode and OP2\* output to high.

1=set INT output pin to normal operating mode and OP2\* output to low.

### MCR BIT-4:

0=normal operating mode.

1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, MCR bit-2 and OP2\*/INT enable are connected to modem control inputs.

In this mode , the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER :

### MCR BIT 5-7:

Not used. Are set to zero permanently.

### LINE STATUS REGISTER (LSR)

This register provides the status of data transfer to CPU.

### LSR BIT-0:

0=no data in receive holding register or FIFO. 1=data has been received and saved in the receive holding register or FIFO.

### LSR BIT-1:

0=no overrun error (normal).

1=overrun error, next character arrived before receive holding register was emptied or if FIFOs are enabled, an overrun error will occur only after the FIFO is full and the next character has been completely received in the shift register. Note that character in the shift register is overwritten, but it is not transferred to the FIFO.

## LSR BIT-2:

0=no parity error (normal).

1=parity error, received data does not have correct parity information. In the FIFO mode this error is associated with the character at the top of the FIFO.

### LSR BIT-3:

0=no framing error (normal).

1=framing error received, received data did not have a valid stop bit. In the FIFO mode this error is associated with the character at the top of the FIFO.

#### LSR BIT-4:

0=no break condition (normal).

1=receiver received a break signal (RX was low for one character time frame). In FIFO mode, only one zero character is loaded into the FIFO.

### LSR BIT-5:

0=transmit holding register is full. ST16C2550 will not accept any data for transmission.

1=transmit holding register (or FIFO ) is empty. CPU can load the next character.

### LSR BIT-6:

0=transmitter holding and shift registers are full. 1=transmitter holding and shift registers are empty. In FIFO mode this bit is set to one whenever the transmitter FIFO and transmit shift register are empty.

### LSR BIT-7:

0=Normal.

1=At least one parity error, framing error or break indication in the FIFO. This bit is cleared when LSR is read

## MODEM STATUS REGISTER (MSR)

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

### MSR BIT-0:

Indicates that the CTS\* input to the ST16C2550 has changed state since the last time it was read.

#### MSR BIT-1:

Indicates that the DSR\* input to the ST16C2550 has changed state since the last time it was read.

### MSR BIT-2:

Indicates that the RI\* input to the ST16C2550 has changed from a low to a high state.

### MSR BIT-3:

Indicates that the CD\* input to the ST16C2550 has changed state since the last time it was read.

### MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

### MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

## MSR BIT-6:

This bit is equivalent to MCR bit-2during local loopback mode. It is the compliment of the RI\* input.

### MSR BIT-7:

This bit is equivalent to OP2\*/INT enable in the MCR during local loop-back mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated.

# SCRATCHPAD REGISTER (SR)

ST16C2550 provides a temporary data register to store 8 bits of information for variable use.

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16 x CLOCK<br>DIVISOR | % ERROR |
|-----------|-----------------------|---------|
| 50        | 2304                  |         |
| 75        | 1536                  |         |
| 110       | 1047                  | 0.026   |
| 134.5     | 857                   | 0.058   |
| 150       | 768                   |         |
| 300       | 384                   |         |
| 600       | 192                   |         |
| 1200      | 96                    |         |
| 2400      | 48                    | . 20    |
| 3600      | 32                    |         |
| 4800      | 24                    |         |
| 7200      | 16                    |         |
| 9600      | . 12                  |         |
| 19.2K     | 6                     |         |
| 38.4K     | 3                     |         |
| 56K       | 2                     | 2.77    |
| 115.2K    | 1                     |         |

### ST16C2550 EXTERNAL RESET CONDITION

| REGISTERS | RESET STATE                 |
|-----------|-----------------------------|
| IER       | IER BITS 0-7=0              |
| ISR       | ISR BIT-0=1, ISR BITS 1-7=0 |
| LCR       | LCR BITS 0-7=0              |
| MCR       | MCR BITS 0-7=0              |
| LSR       | LSR BITS 0-4=0,             |
|           | LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR       | MSR BITS 0-3=0,             |
|           | MSR BITS 4-7=input signals  |
| FCR       | FCR BITS 0-7=0              |

| SIGNALS | RESET STATE      |  |  |  |  |  |
|---------|------------------|--|--|--|--|--|
| TX      | High             |  |  |  |  |  |
| OP2*    | High             |  |  |  |  |  |
| RTS*    | High             |  |  |  |  |  |
| DTR*    | High             |  |  |  |  |  |
| INT     | Three state mode |  |  |  |  |  |
| l l     |                  |  |  |  |  |  |

# **AC ELECTRICAL CHARACTERISTICS**

 $T_A = 0^{\circ} - 70^{\circ} C$ , Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                                                                                                                                                                                                                                                                                                      | Parameter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 88:00                                                                                        | Limits        | Man                                                                         | Units                                    | Conditions                                                                                          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|---------------|-----------------------------------------------------------------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------|
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>8</sub> T <sub>19</sub> T <sub>12</sub> T <sub>13</sub> T <sub>14</sub> T <sub>15</sub> T <sub>16</sub> T <sub>17</sub> T <sub>28</sub> T <sub>28</sub> T <sub>28</sub> T <sub>29</sub> T <sub>30</sub> T <sub>31</sub> T <sub>32</sub> T <sub>32</sub> T <sub>33</sub> T <sub>34</sub> T <sub>35</sub> T <sub>44</sub> T <sub>45</sub> | Clock high pulse duration Clock low pulse duration Clock rise/fall time Chip select setup time Chip select hold time Data set up time Data hold time IOW* delay from chip select IOW* strobe width Chip select hold time from IOW* Write cycle delay Write cycle=T <sub>15</sub> +T <sub>17</sub> Data hold time IOR* delay from chip select IOR* strobe width Chip select hold time from IOR* Read cycle delay Read cycle delay Read cycle delay Read cycle=T <sub>23</sub> +T <sub>25</sub> Delay from IOR* to data Delay from IOR* to output Delay to set interrupt from MODEM input Delay to reset interrupt from IOR* Delay from iOR* to reset interrupt Delay from initial INT reset to transmit start Delay from stop to set RxRdy Delay from stop to set RxRdy Delay from stop to set RxRdy Delay from stop to set RxRdy | 50<br>50<br>50<br>15<br>15<br>10<br>50<br>0<br>55<br>105<br>15<br>10<br>65<br>0<br>55<br>115 | Limits<br>Typ | Max  10  35 50 70  70 1 <sub>Reik</sub> 200 24  100 175 1 <sub>RCLK</sub> 1 | ns ns ns ns ns ns ns ns ns ns ns ns ns n | Conditions  External clock  100 pF load 100 pF load 100 pF load 100 pF load 100 pF load 100 pF load |
| T <sub>46</sub><br>T <sub>47</sub>                                                                                                                                                                                                                                                                                                                                                          | Delay from IOW* to set TxRdy Delay from start to reset TxRdy Baud rate devisor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1                                                                                            |               | 195<br>8<br>2 <sup>16</sup> -1                                              | ns<br>*                                  |                                                                                                     |

Note 1: \* = Baudout\* cycle

# **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

# DC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                              | Parameter                                                                                                                                                                             | Min                               | Limits<br>Typ | Max                                           | Units | Conditions                                        |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---------------|-----------------------------------------------|-------|---------------------------------------------------|
| VILCK VIHCK VIH VOL VOH LCC IIL LCL | Clock input low level Clock input high level Input low level Input high level Output low level on all outputs Output high level Avg. power supply current Input leakage Clock leakage | -0.5<br>3.0<br>-0.5<br>2.2<br>2.4 | 6             | 0.6<br>VCC<br>0.8<br>VCC<br>0.4<br>±10<br>±10 | >>>>> | I <sub>oL</sub> = 6 mA<br>I <sub>он</sub> = -6 mA |

## **GENERAL WRITE TIMING**



### **GENERAL READ TIMING**



## **MODEM TIMING**



# **CLOCK TIMING**









## **RXRDY TIMING FOR MODE "1"**



# TXRDY TIMING FOR MODE "0"



#### TXRDY TIMING FOR MODE "1"





Printed September 7, 1994

## **DUAL ASYNCHRONOUS RECEIVER/TRANSMITTER WITH FIFOS**

#### **DESCRIPTION**

The ST16C2552 is a dual asynchronous receiver and transmitter with 16 byte transmit and receive FIFOs. Independent programmable baud rate generators are provided to select transmit and receive clock rates from 50Hz to 448kHz for each UART.

The on board status registers of the ST16C2552 provide the error conditions, type and status of the transfer operation being performed. Complete MODEM control capability and a processor interrupt system that may be software tailored to the user's requirements are included. The ST16C2552 provides internal loop-back capability for on board diagnostic testing.

Signalling for DMA transfers is done through two pins per channel (TXRDY, RXRDY\*). The RXRDY\* function is multiplexed on one pin with the OP2\* and BAUDOUT functions. CPU can select these functions through the Alternate Function Register.

The ST16C2552 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low power and high speed requirements.

#### **FEATURES**

- Pin to pin and functional compatible to National NS16C552
- 16 byte transmit FIFO
- 16 byte receive FIFO with error flags
- Modem control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\* CD\*)
- Programmable character lengths (5, 6, 7, 8) bits
- Even, odd, or no parity bit generation and detection
- · Status report register
- . TTL compatible inputs, outputs
- Independent transmit and receive control
- Software compatible with INS8250, NS16C550
- 448 kHz transmit/receive operation with 7.372 MHz crystal or external clock source

#### ORDERING INFORMATION

Part number ST16C2552CJ44 ST16C2552IJ44 Package PLCC PLCC Operating temperature 0° C to + 70° C -40° C to + 85° C **PLCC Package** 



**BLOCK DIAGRAM** 



| Symbol | Pin      | Signal Type | Pin Description                                                                                                                                                                                                                                                                                            |
|--------|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7  | 2-9      | I/O         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                                          |
| RX A/B | 39,25    | 1           | Serial data input A/B. The serial information (data) received from serial port to ST16C2552 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. |
| TX A/B | 38,26    | 0           | Serial data output A/B. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                                           |
| cs*    | 18       | 1           | Chip select. (active low) A low at this pin enables the ST16C2552 / CPU data transfer operation.                                                                                                                                                                                                           |
| CHSEL  | 16       | 1           | UART A/B select. UART A or B can be selected by changing the state of this pin when CS* is active. Low on this pin, selects the UART B and high on this pin selects UART A section.                                                                                                                        |
| XTAL1  | 11       | l           | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                                   |
| XTAL2  | 13       |             | Crystal input 2 or buffered clock output. See XTAL1.<br>Should be left open if a clcok is connected to XTAL1.                                                                                                                                                                                              |
| IOW*   | 20       | 1           | Write strobe. (active low) A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                                                                                                                     |
| IOR*   | 24       | <b>1</b> ** | Read strobe. (active low) A low level on this pin transfers the contents of the ST16C2552 data bus to the CPU.                                                                                                                                                                                             |
| A0-A2  | 10,14,15 | 1 .         | Address select lines. To select internal registers.                                                                                                                                                                                                                                                        |

| Symbol    | Pin   | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT A/B   | 34,17 | 0           | Interrupt output A/B. (active high) This pin goes high (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                                                                                                                                                                                                                                                                                                                |
| MF A/B*   | 35,19 | Ο           | OP2* (interrupt enable), BAUDOUT* and RXRDY* outputs. These outputs are multiplexed via Alternate Function Register. When output enable function is selected the MF* pin stays high when INT out pin is set to three state mode and goes low when INT pin is enabled. See bit-3 modem control register (MCR bit-3). When BAUDOUT function is selected, the 16 X TX/RX Baud rate clock output is generated. RXRDY function can be selected to use to request a DMA transfer of data from the Receive data FIFO. OP2* is the default signal and it is selected immediately after master reset or power-up. |
| TXRDY A/B | 1,32  | 0           | Transmit ready. (active high) This pin goes high when the transmit FIFO of the ST16C2552 is full. It can be used as a single or multi-transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| RTS A/B*  | 36,23 | 0           | Request to send A/B (active low). To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                                                                                                                                                                                                                                                                                     |
| DTR A/B*  | 37,27 | 0           | Data terminal ready A/B (active low). To indicate that ST16C2552 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation.                                                                                                                                                                                          |
| RESET     | 21    |             | Master reset. (active high) A high on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                                                                                                                                                                                                                                                                                                                                                                                                      |

## SYMBOL DESCRIPTION

| Symbol   | Pin   | Signal Type | Pin Description                                                                                                                                                                                     |
|----------|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CTS A/B* | 40,28 | I           | Clear to send A/B (active low). The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation. |
| DSR A/B* | 41,29 | I           | Data set ready A/B (active low). A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                 |
| CD A/B*  | 42,30 | 1           | Carrier detect A/B (active low). A low on this pin indicates the carrier has been detected by the modem.                                                                                            |
| RI A/B*  | 43,31 | 1           | Ring detect indicator A/B (active low). A low on this pin indicates the modem has received a ringing signal from telephone line.                                                                    |
| vcc      | 33,44 | ı           | Power supply input.                                                                                                                                                                                 |
| GND      | 12,22 | 0           | Signal and power ground.                                                                                                                                                                            |

## **PROGRAMMING TABLE**

| A2 | A1 | AO | READ MODE                   | WRITE MODE                  |
|----|----|----|-----------------------------|-----------------------------|
| 0  | 0  | 0  | Receive Holding Register    | Transmit Holding Register   |
| 0  | 0  | 1  |                             | Interrupt Enable Register   |
| 0  | 1  | 0  | Interrupt Status Register   | FIFO Control Register       |
| 0  | 1  | 1  |                             | Line Control Register       |
| 1  | 0  | 0  |                             | Modem Control Register      |
| 1  | 0  | 1  | Line Status Register        |                             |
| 1  | 1  | 0  | Modem Status Register       |                             |
| 1  | 1  | 1  | Scratchpad Register         | Scratchpad Register         |
| 0  | 0  | 0  |                             | LSB of Divisor Latch        |
| 0  | 0  | 1  |                             | MSB of Divisor Latch        |
| 0  | 1  | 0  | Alternate Function Register | Alternate Function Register |
| 0  | 1  | 0  | Alternate Function Register | Alternate Function Regis    |

## ST16C2552 ACCESSIBLE REGISTERS A/B

| A2 | A1 | A0  | Register | BIT-7                      | BIT-6                    | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----|----|-----|----------|----------------------------|--------------------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0  | 0  | 0   | RHR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 0   | THR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 1   | IER      | 0                          | 0                        | 0                          | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0  | 1  | 0 . | FCR      | RCVR<br>trigger<br>MSB)    | RCVR<br>trigger<br>(LSB) | 0                          | 0                  | DMA<br>mode<br>select        | XMIT<br>FIFO<br>reset                  | RCVR<br>FIFO<br>reset           | FIFO<br>enable                 |
| 0  | 1  | 0   | ISR      | 0/<br>FIFOs<br>enabled     | 0/<br>FIFOs<br>enabled   | 0                          | 0                  | int<br>priority<br>bit-2     | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0  | 1  | 1   | LCR      | divisor<br>latch<br>enable | set<br>break             | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1  | 0  | 0   | MCR      | 0                          | 0                        | 0 ′                        | loop<br>back       | OP2*                         | OP1*                                   | RTS*                            | DTR*                           |
| 1  | 0  | 1   | LSR      | 0/<br>FIFO<br>error        | trans.<br>empty          | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1  | 1  | 0   | MSR      | CD                         | RI                       | DSR                        | стѕ                | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1  | 1  | 1   | SPR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 0   | DLL      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 1   | DLM      | bit-15                     | bit-14                   | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |
| 0  | 1  | 0   | AFR      | O                          | 0                        | 0                          | 0                  | 0                            | MF*<br>sel-1                           | MF*<br>sel-0                    | SP<br>write                    |

These registers are accessible only when LCR bit-7 is set to "1".

#### REGISTER FUNCTIONAL DESCRIPTIONS

#### TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

#### FIFO INTERRUPT MODE OPERATION

When the receive FIFO (FCR BIT-0=1) and receive interrupts (IER BIT-0=1) are enabled, receiver interrupt will occur as follows:

- A) The receive data available interrupts will be issued to the CPU when the FIFO has reached its programmed trigger level; it will be cleared as soon as the FIFO drops below its programmed trigger level.
- B) The ISR receive data available indication also occurs when the FIFO trigger level is reached, and like the interrupt it is cleared when the FIFO drops below the trigger level.
- C) The data ready bit (LSR BIT-0) is set as soon as a character is transferred from the shift register to the receiver FIFO. It is reset when the FIFO is empty.

#### FIFO POLLED MODE OPERATION

When FCR BIT-0=1; resetting IER BIT 3-0 to zero puts the ST16C2552 in the FIFO polled mode of operation. Since the receiver and transmitter are controlled separately either one or both can be in the polled mode operation by utilizing the Line Status Register.

- A) LSR BIT-0 will be set as long as there is one byte in the receive FIFO.
- B) LSR BIT4-1 will specify which error(s) has occurred.
- C) LSR BIT-5 will indicate when the transmit FIFO is empty.
- D) LSR BIT-6 will indicate when both transmit FIFO and transmit shift register are empty.
- E) LSR BIT-7 will indicate when there are any errors in the receive FIFO.

#### PROGRAMMABLE BAUD RATE GENERATOR

Each UART section of the ST16C2552 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to 2<sup>16</sup>-1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

#### **INTERRUPT ENABLE REGISTER (IER)**

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the INT output pin.

#### IER BIT-0:

0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

#### IER BIT-1:

0=disable the transmitter empty interrupt. 1=enable the transmitter empty interrupt.

#### IER BIT-2:

0=disable the receiver line status interrupt. 1=enable the receiver line status interrupt.

#### IER BIT-3:

0=disable the modem status register interrupt. 1=enable the modem status register interrupt.

#### **IER BIT 4-7:**

All these bits are set to logic zero.

#### INTERRUPT STATUS REGISTER (ISR)

The ST16C2552 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C2552 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

#### **Priority level**

| P  | D3 | D2 | D1 | D0 | Source of the interrupt                       |
|----|----|----|----|----|-----------------------------------------------|
| 1  | 0  | 1  | 1  | 0  | LSR (Receiver Line Sta-<br>tus Register)      |
| 2  | 0  | 1  | 0  | 0  | RXRDY (Received Data<br>Ready)                |
| 2* | 1  | 1  | 0  | 0  | RXRDY (Receive Data time out)                 |
| 3  | 0  | 0  | 1  | 0  | TXRDY( Transmitter<br>Holding Register Empty) |
| 4  | 0  | 0  | 0  | 0  | MSR (Modern Status<br>Register)               |

#### \*RECEIVE TIME-OUT:

This mode is enabled when STARTECH UART is operating in FIFO mode. Receive time out will not occur if the receive FIFO is empty. The time out counter will be reset at the center of each stop bit received or each time receive holding register is read. The actual time out value is T (Time out length in bits)= 4 X P (Programmed word length) + 12. To convert time out value to a character value, user has to divide this number to its complete word length + parity (if used) + number of stop bits and start bit.

Example -A: If user programs the word length = 7, and no parity and one stop bit, Time out will be:  $T = 4 \times 7$  (programmed word length) +12 = 40 bits Character time = 40 / 9 [ (programmed word length = 7) + (stop bit = 1) + (start bit = 1)] = 4.4 characters.

Example -B: If user programs the word length = 7, with parity and one stop bit, the time out will be:  $T = 4 \times 7$  (programmed word length) + 12 = 40 bits Character time = 40 / 10 [ (programmed word length = 7) + (parity = 1) + (stop bit = 1) + (start bit = 1) = 4 characters

#### ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1=no interrupt pending.

#### **ISR BIT 1-3:**

Logical combination of these bits, provides the highest priority interrupt pending.

#### **ISR BIT 4-7:**

These bits are not used and are set to zero if the FIFOs are not enabled. BIT 6-7: are set to "1" when the FIFOs are enabled.

#### FIFO CONTROL REGISTER (FCR)

This register is used to enable the FIFOs, clear the FIFOs, set the receiver FIFO trigger level, and select the type of DMA signaling.

#### FCR BIT-0:

0=Disable the transmit and receive FIFO. 1=Enable the transmit and receive FIFO.

#### FCR BIT-1:

0=No change.

1=Clears the contents of the receive FIFO and resets its counter logic to 0 (the receive shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-2:

0=No change.

1=Clears the contents of the transmit FIFO and resets its counter logic to 0 (the transmit shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-3:

0=No change.

1=Changes RXRDY and TXRDY pins from mode "0" to mode "1".

#### Transmit operation in mode "0":

When ST16C2552 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) when there are no characters in the transmit FIFO or transmit holding register, the TXRDY\* pin will go low. Once active the TXRDY\* pin will go high (inactive) after the first character is loaded into the transmit holding register.

#### Receive operation in mode "0":

When ST16C2552 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) and there is at least 1 character in the receive FIFO, the RXRDY\* pin will go low. Once active the RXRDY\* pin will go high (inactive) when there are no more characters in the receiver.

#### Transmit operation in mode "1":

When ST16C2552 is in ST16C550 mode (FCR bit-0=1, FCR bit-3=1) the TXRDY\* pin will become high (inactive) when the transmit FIFO is completely full. It will be low if one or more FIFO locations are empty.

#### Receive operation in mode "1":

When ST16C2552 is in ST16C550 mode (FCR bit-0=1, FCR bit-3=1) and the trigger level or the timeout has been reached, the RXRDY\* pin will go low. Once it is activated it will go high (inactive) when there are no more characters in the FIFO.

#### **FCR BIT 4-5:**

Not used.

#### FCR BIT 6-7:

These bits are used to set the trigger level for the receiver FIFO interrupt.

| BIT-7 | BIT-6 | FIFO trigger level |
|-------|-------|--------------------|
| 0     | 0     | v. 01              |
| 0     | 1     | 04                 |
| 1 1   | -0    | 08                 |
| 1     | 1.    | 14                 |
| 1     |       |                    |

#### **ALTERNATE FUNCTION REGISTER (AFR)**

This is a read/write register used to select specific modes of MF\* operation and to allow both UART registers sets to be written concurrently.

#### AFR BIT-0:

When this bit is set, CPU can write concurrently to the same register in both UARTs. This function is intended to reduce the dual UART initialization time. It can be used by CPU when both channels are initialized to the same state. CPU can set or clear this bit by accessing either register set. When this bit is set the channel select pin still selects the channel to be accessed during read operation. Setting or clearing this bit has no effect on read operations.

The user should ensure that LCR Bit-7 of both channels are in the same state before executing a concurrent write to the registers at address 0,1, or 2.

#### **AFR BIT 1-2:**

Combinations of these bits selects one of the MF\* functions.

| BIT-2 | BIT-1 | MF* Function |
|-------|-------|--------------|
| 0     | 0     | OP2*         |
| 0     | 1     | BAUDOUT*     |
| 1     | 0     | RXRDY*       |
| 1     | 1     | Reserved     |

#### **AFR BIT 3-7:**

Not used. All these bits are set to logic zero.

#### LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

#### LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 | BIT-0 | Word length |
|-------|-------|-------------|
| 0     | 0     | 5           |
| 0     | - 1   | 6           |
| 1     | 0     | 7           |
| . 1   | 1     | 8           |

#### LCR BIT-2:

The number of stop bits can be specified by this bit.

| Nord length | Stop bit(s) |
|-------------|-------------|
| 5,6,7,8     | 1           |
| 5<br>6,7,8  | 1-1/2       |
|             | 5           |

#### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

#### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even number of 1's in the transmitted data, receiver also checks for same format.

#### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

#### LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0=normal operating condition.

1=forces the transmitter output (TX) to go low to alert the communication terminal.

#### LCR BIT-7:

The internal baud rate counter latch enable (DLAB). 0=normal operation.

1=select Divisor Latch Register and Alternate Function Register.

#### MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

#### MCR BIT-0:

0=force DTR\* output to high. 1=force DTR\* output to low.

#### MCR BIT-1:

0=force RTS\* output to high. 1=force RTS\* output to low.

#### MCR BIT-2:

Not used except in local loop-back mode.

#### MCR BIT-3:

0=force OP2\* output to high. 1=force OP2\* output to low.

#### MCR BIT-4:

0=normal operating mode.

1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, OP1\* and OP2\* are connected to modem control inputs. In this mode, the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER.

#### MCR BIT 5-7:

Not used. Are set to zero permanently.

#### **LINE STATUS REGISTER (LSR)**

This register provides the status of data transfer to CPU.

#### LSR BIT-0:

0=no data in receive holding register or FIFO. 1=data has been received and saved in the receive holding register or FIFO.

#### LSR BIT-1:

0=no overrun error (normal).

1=overrun error, next character arrived before receive holding register was emptied or if FIFOs are enabled, an overrun error will occur only after the FIFO is full and the next character has been completely received in the shift register. Note that character in the shift register is overwritten, but it is not transferred to the FIFO.

#### LSR BIT-2:

0=no parity error (normal).

1=parity error, received data does not have correct parity information. In the FIFO mode this error is associated with the character at the top of the FIFO.

#### LSR BIT-3:

0=no framing error (normal).

1=framing error received, received data did not have a valid stop bit. In the FIFO mode this error is associated with the character at the top of the FIFO.

#### LSR BIT-4:

0=no break condition (normal).

1=receiver received a break signal (RX was low for one character time frame). In FIFO mode, only one zero character is loaded into the FIFO.

#### LSR BIT-5:

0=transmit holding register is full. ST16C2552 will not accept any data for transmission.

1=transmit holding register (or FIFO ) is empty. CPU can load the next character.

#### LSR BIT-6:

0=transmitter holding and shift registers are full. 1=transmitter holding and shift registers are empty. In FIFO mode this bit is set to one whenever the transmitter FIFO and transmit shift register are empty.

#### LSR BIT-7:

0=Normal.

1=At least one parity error, framing error or break indication in the FIFO. This bit is cleared when LSR is read.

#### **MODEM STATUS REGISTER (MSR)**

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

#### MSR BIT-0:

Indicates that the CTS\* input to the ST16C2552 has changed state since the last time it was read.

#### MSR BIT-1:

Indicates that the DSR\* input to the ST16C2552 has changed state since the last time it was read.

MSR BIT-2:

Indicates that the RI\* input to the ST16C2552 has changed from a low to a high state.

#### MSR BIT-3:

Indicates that the CD\* input to the ST16C2552 has changed state since the last time it was read.

#### MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

#### MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

#### MSR BIT-6:

This bit is equivalent to OP1 in the MCR during local loop-back mode. It is the compliment of the RI\* input.

#### MSR BIT-7:

This bit is equivalent to OP2 in the MCR during local loop-back mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated.

#### SCRATCHPAD REGISTER (SR)

ST16C2552 provides a temporary data register to store 8 bits of information for variable use.

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16 x CLOCK<br>DIVISOR | % ERROR |
|-----------|-----------------------|---------|
| 50        | 2304                  |         |
| 75        | 1536                  |         |
| 150       | 768                   |         |
| 300       | 384                   |         |
| 600       | 192                   | 4 1     |
| 1200      | 96                    |         |
| 2400      | 48                    | 1       |
| 4800      | 24                    |         |
| 7200      | 16                    |         |
| 9600      | 12                    |         |
| 19.2K     | 6                     |         |
| 38.4K     | 3                     | 1       |
| 56K       | 2                     | 2.77    |
| 115.2K    | 1                     |         |

#### ST16C2552 EXTERNAL RESET CONDITION

| REGISTERS | RESET STATE                 |
|-----------|-----------------------------|
| IER       | IER BITS 0-7=0              |
| ISR       | ISR BIT-0=1, ISR BITS 1-7=0 |
| LCR       | LCR BITS 0-7=0              |
| MCR       | MCR BITS 0-7=0              |
| LSR       | LSR BITS 0-4=0,             |
|           | LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR       | MSR BITS 0-3=0,             |
|           | MSR BITS 4-7=input signals  |
| FCR       | FCR BITS 0-7=0              |
| MFR       | AFR BITS 0-7=0              |

| SIGNALS | RESET STATE |
|---------|-------------|
| TX      | High        |
| OP2*    | High        |
| RTS*    | High        |
| DTR*    | High        |
| INT     | Low /       |
| TxRdy   | Low         |

## **ABSOLUTE MAXIMUM RATINGS**

Supply Voltage Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

#### DC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

|                                 | Min                                                                                                                                                                 | Limits<br>Typ                                                                                                                                                                                 | Max                                                                                                                                                                                             | Units                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Conditions                                                                                                                                                                                                                  |
|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clock input low level           | -0.5                                                                                                                                                                |                                                                                                                                                                                               | 0.6                                                                                                                                                                                             | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                             |
| Clock input high level          | 3.0                                                                                                                                                                 | i i                                                                                                                                                                                           | VCC                                                                                                                                                                                             | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                             |
| Input low level                 | -0.5                                                                                                                                                                | ĺ                                                                                                                                                                                             | 0.8                                                                                                                                                                                             | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                             |
| Input high level                | 2.2                                                                                                                                                                 |                                                                                                                                                                                               | vcc                                                                                                                                                                                             | ٧ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                             |
| Output low level on all outputs | - [                                                                                                                                                                 | ľ                                                                                                                                                                                             | 0.4                                                                                                                                                                                             | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | I <sub>01</sub> = 6 mA                                                                                                                                                                                                      |
| Output high level               | 2.4                                                                                                                                                                 |                                                                                                                                                                                               |                                                                                                                                                                                                 | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | I <sub>oL</sub> = 6 mA<br>I <sub>oH</sub> = -6 mA                                                                                                                                                                           |
|                                 |                                                                                                                                                                     | 6                                                                                                                                                                                             |                                                                                                                                                                                                 | mA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | On                                                                                                                                                                                                                          |
| Input leakage                   |                                                                                                                                                                     |                                                                                                                                                                                               | ±10                                                                                                                                                                                             | μA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                             |
| Clock leakage                   |                                                                                                                                                                     |                                                                                                                                                                                               | ±10                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                             |
|                                 | Clock input high level<br>Input low level<br>Input high level<br>Output low level on all outputs<br>Output high level<br>Avg. power supply current<br>Input leakage | Clock input low level -0.5 Clock input high level 3.0 Input low level -0.5 Input high level 2.2 Output low level on all outputs Output high level 2.4 Avg. power supply current Input leakage | Clock input low level -0.5 Clock input high level 3.0 Input low level -0.5 Input high level 2.2 Output low level on all outputs Output high level 2.4 Avg. power supply current 6 Input leakage | Clock input low level Clock input high level Input low level Input low level Input high level Coutput low level on all outputs Cutput high level Cutput high level Cutput high level Cutput high level Cutput high level Avg. power supply current Input leakage  -0.5 0.6 VCC 0.8 VCC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 CC 0.4 | Clock input low level Clock input high level Input low level Input high level Output low level on all outputs Output high level Avg. power supply current Input leakage  -0.5 3.0 VCC V 0.8 V VCC V 0.4 V 0.4 V 0.4 V 0.4 V |

3

## **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                     | Parameter                                                                   |           | Limits |                          | Units    | Conditions     |
|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------|--------|--------------------------|----------|----------------|
|                                                                                            |                                                                             | Min       | Тур    | Max                      |          |                |
| T,                                                                                         | Clock high pulse duration                                                   | 50        |        |                          | ns       |                |
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>8</sub> T <sub>9</sub> T <sub>12</sub> | Clock low pulse duration Clock rise/fall time                               | 50        |        | 10                       | ns<br>ns | External clock |
| T <sub>8</sub>                                                                             | Chip select setup time                                                      | 5         |        |                          | ns       |                |
| T <sub>9</sub>                                                                             | Chip select hold time                                                       | 0         |        |                          | ns       |                |
| T <sub>12</sub>                                                                            | Data set up time<br>Data hold time                                          | 15<br>15  | į      |                          | ns       | -              |
| T <sub>13</sub><br>T <sub>14</sub>                                                         | IOW* delay from chip select                                                 | 10        |        |                          | ns<br>ns |                |
| T.,                                                                                        | IOW* strobe width                                                           | 50        |        |                          | ns       |                |
| 16                                                                                         | Chip select hold time from IOW*                                             | 0         |        |                          | ns       |                |
| . I <sub>17</sub>                                                                          | Write cycle delay                                                           | 55        |        |                          | ns       |                |
| Tw                                                                                         | Write cycle=T <sub>15</sub> +T <sub>17</sub> Data hold time                 | 105<br>15 |        |                          | ns       |                |
| T <sub>19</sub>                                                                            | IOR* delay from chip select                                                 | 10        |        |                          | ns<br>ns |                |
| T <sub>21</sub><br>T <sub>23</sub><br>T <sub>24</sub><br>T <sub>25</sub><br>Tr             | IOR* strobe width                                                           | 65        |        |                          | ns       |                |
| T <sub>24</sub>                                                                            | Chip select hold time from IOR*                                             | 0         |        |                          | ns       |                |
| T <sub>25</sub>                                                                            | Read cycle delay                                                            | 55        |        |                          | ns       | ,              |
| T                                                                                          | Read cycle=T <sub>23</sub> +T <sub>25</sub><br>Delay from IOR* to data      | 115       |        | 35                       | ns<br>ns | 100 pF load    |
| T <sub>26</sub><br>T <sub>28</sub>                                                         | Delay from IOW* to output                                                   |           |        | 50                       | ns       | 100 pF load    |
| T <sub>29</sub>                                                                            | Delay to set interrupt from MODEM input                                     |           |        | 70                       | ns       | 100 pF load    |
| T <sub>30</sub>                                                                            | Delay to reset interrupt from IOR*                                          | *         |        | 70                       | ns       | 100 pF load    |
| T <sub>31</sub>                                                                            | Delay from stop to set interrupt                                            |           |        | 1 <sub>Rclk</sub><br>200 | ns       | 100 pF load    |
| T <sub>32</sub><br>T <sub>33</sub>                                                         | Delay from IOR* to reset interrupt Delay from initial INT reset to transmit | 8         |        | 200                      | ns<br>*  | 100 pF load    |
| ' 33                                                                                       | start                                                                       |           |        | 2.7                      |          | . *            |
| T <sub>34</sub>                                                                            | Delay from stop to interrupt                                                |           |        | 100                      | ns       |                |
| Tar                                                                                        | Delay from IOW* to reset interrupt                                          |           |        | 175                      | ns       |                |
| T <sub>36</sub>                                                                            | Delay from initial Write to interrupt                                       | 16        |        | 24                       | *        |                |
| T <sub>44</sub> T <sub>45</sub>                                                            | Delay from stop to set RxRdy Delay from IOR* to reset RxRdy                 |           |        | 1 <sub>RCLK</sub>        | μS       |                |
| T <sub>46</sub>                                                                            | Delay from IOW* to set TxRdy                                                |           |        | 195                      | ns       |                |
| T <sub>47</sub>                                                                            | Delay from start to reset TxRdy                                             |           |        | 8                        | *        | 200            |
| N /                                                                                        | Baud rate devisor                                                           | 1         |        | 2 <sup>16</sup> -1       | e<br>Na  |                |

Note 1: \* = Baudout\* cycle

## **GENERAL WRITE TIMING**



## **GENERAL READ TIMING**



3-183

3

## **MODEM TIMING**



# EXTERNAL CLOCK PERIOD CLOCK PERIOD







#### **RXRDY TIMING FOR MODE "0"**



## **RXRDY TIMING FOR MODE "1"**





#### TXRDY TIMING FOR MODE "1"





Printed September 7, 1994

## QUAD ASYNCHRONOUS RECEIVER/TRANSMITTER WITH FIFOS

#### **DESCRIPTION**

The ST16C554 is a universal asynchronous receiver and transmitter with 16 byte transmit and receive FIFO. A programmable baud rate generator is provided to select transmit and receive clock rates from 50Hz to 448kHz.

The ST16C554 is an improved version of the NS16C550 UART with higher operating speed and lower access time. The ST16C554 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C554 provides internal loop-back capability for on board diagnostic testing.

The ST16C554 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

#### **FEATURES**

- Pin to pin and functional compatible to ST16C454
- 16 byte transmit FIFO
- 16 byte receive FIFO with error flags
- Modem control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\*, CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- · Status report register
- · Independent transmit and receive control
- TTL compatible inputs, outputs
- Software compatible with INS8250, NS16C550
- 448 kHz transmit/receive operation with 7.372 MHz crystal or external clock source

#### ORDERING INFORMATION

| Part number   | Package | Operating temperature |
|---------------|---------|-----------------------|
| ST16C554CJ68  | PLCC    | 0° C to + 70° C       |
| ST16C554IJ68  | PLCC    | -40° C to + 85° C     |
| ST16C554DCJ68 | PLCC    | 0° C to + 70° C       |
| ST16C554DIJ68 | PLCC    | -40° C to + 85° C     |

## **PLCC Package**







| Symbol             | Pin            | Signal Type | Pin Description                                                                                                                                                                                                                                                                                       |
|--------------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7              | 5-66           | I/O         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                                     |
| RX A-B<br>RX C-D   | 7,29<br>41,63  | <b>1</b>    | Serial data input. The serial information (data) received from serial port to ST16C554 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. |
| TX A-B<br>TX C-D   | 17,19<br>51,53 | 0           | Serial data output. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                                          |
| CS A-B*<br>CS C-D* | 16,20<br>50,54 | 1           | Chip select. (active low) A low at this pin enables the ST16C554 / CPU data transfer operation. Each UART sections of the ST16C554 can be accessed independently.                                                                                                                                     |
| XTAL1              | 35             | , <b>l</b>  | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                              |
| XTAL2              | 36             | 0           | Crystal input 2 or buffered clock output. See XTAL1.                                                                                                                                                                                                                                                  |
| IOW*               | 18             |             | Write strobe. (active low) A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                                                                                                                |
| GND<br>GND         | 6,23<br>40,57  | 0           | Signal and power ground.                                                                                                                                                                                                                                                                              |
| IOR*               | 52             |             | Read strobe. (active low) A low level on this pin transfers the contents of the ST16C554 data bus to the CPU.                                                                                                                                                                                         |

| Symbol               | Pin            | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                         |
|----------------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TXRDY                | 39             | 0           | Transmit ready. (active high) This pin goes high when the transmit FIFO of the ST16C554 is full. It can be used as a single or multi-transfer.                                                                                                                                                                                          |
| A2                   | 32             | 1           | Address select line 2. To select internal registers.                                                                                                                                                                                                                                                                                    |
| A1                   | 33             | 1           | Address select line 1. To select internal registers.                                                                                                                                                                                                                                                                                    |
| A0                   | 34             | ŀ           | Address select line 0. To select internal registers.                                                                                                                                                                                                                                                                                    |
| RXRDY*               | 38             | 0           | Receive ready. (active high) This pin goes high when the receive FIFO is full. It can be used as a single or multi-transfer.                                                                                                                                                                                                            |
| INTSEL               | 65**           | <b>1</b>    | Interrupt type select. Enable /disable the interrupt three state function. Normal interrupt output can be selected by connecting this pin to VCC (MCR bit-3 does not have any effect on the interrupt output). The three state interrupt output is selected when this pin is left open or connected to GND and MCR bit-3 is set to "1". |
| INT A-B<br>INT C-D   | 15,21<br>49,55 | 0           | Interrupt output. (active high) This pin goes high (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                                                   |
| RTS A-B*<br>RTS C-D* | 14,22<br>48,56 | 0           | Request to send. (active low) To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                        |
| DTR A-B*<br>DTR C-D* | 12,24<br>46,58 | 0           | Data terminal ready. (active low) To indicate that ST16C554 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low.                                                                                                            |

<sup>\*\*</sup> ST16C554D PARTS ONLY

| Symbol               | Pin            | Signal Type | Pin Description                                                                                                                                                                                 |
|----------------------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      |                | :           | This pin will be set to high state after writing a "0" to that register or after the reset . Note that this pin does not have any effect on the transmit or receive operation.                  |
| RESET                | 37             | 1 .         | Master reset. (active high) A high on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.             |
| CTS A-B*<br>CTS C-D* | 11,25<br>45,59 | 1           | Clear to send. (active low) The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation. |
| DSR A-B*<br>DSR C-D* | 10,26<br>44,60 | 1           | Data set ready. (active low) A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                 |
| CD A-B*<br>CD C-D*   | 9,27<br>43,61  | l           | Carrier detect. (active low) A low on this pin indicates the carrier has been detected by the modern.                                                                                           |
| RI A-B*<br>RI C-D*   | 8,28<br>42,62  | 1           | Ring detect indicator. (active low) A low on this pin indicates the modem has received a ringing signal from telephone line.                                                                    |
| VCC<br>VCC           | 13,30<br>47,64 | 1           | Power supply input.                                                                                                                                                                             |

## **ST16C554 ACCESSIBLE REGISTERS**

| Α | 2 | A1 | A0 | Register | BIT-7                      | BIT-6                    | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|---|---|----|----|----------|----------------------------|--------------------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| ď | ) | 0  | 0  | RHR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| C | ) | 0  | 0  | THR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| ( | ) | 0  | 1  | IER      | 0                          | 0                        | 0                          | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| ( | ) | 1  | 0  | FCR      | RCVR<br>trigger<br>(MSB)   | RCVR<br>trigger<br>(LSB) | 0                          | 0                  | DMA<br>mode<br>select        | XMIT<br>FIFO<br>reset                  | RCVR<br>FIFO<br>reset           | FIFO<br>enable                 |
| ( | ) | 1  | 0  | ISR      | 0/<br>FIFOs<br>enabled     | 0/<br>FIFOs<br>enabled   | 0                          | 0                  | int<br>priority<br>bit-2     | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| ( | ) | 1  | 1  | LCR      | divisor<br>latch<br>enable | set<br>break             | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
|   | ı | 0  | 0  | MCR      | 0                          | 0                        | 0                          | loop<br>back       | INT<br>enable                | Not<br>used                            | RTS*                            | DTR*                           |
|   | 1 | 0  | 1  | LSR      | 0/<br>FIFO<br>error        | trans.<br>empty          | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
|   | 1 | 1  | 0  | MSR      | CD                         | RI                       | DSR                        | стѕ                | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
|   | 1 | 1  | 1  | SPR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
|   | 0 | o  | 0  | DLL      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
|   | 0 | 0  | 1  | DLM      | bit-15                     | bit-14                   | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

#### PROGRAMMING TABLE

| A2 | A1  | A0  | READ MODE                 | WRITE MODE                |
|----|-----|-----|---------------------------|---------------------------|
| 0  | 0   | 0   | Receive Holding Register  | Transmit Holding Register |
| 0  | 0   | 1   |                           | Interrupt Enable Register |
| 0  | 1   | 0   | Interrupt Status Register | FIFO Control Register     |
| 0  | 1   | 1   |                           | Line Control Register     |
| 1  | 0   | 0   |                           | Modem Control Register    |
| 1  | 0   | 1   | Line Status Register      |                           |
| 1  | 1 1 | 0   | Modem Status Register     | ·                         |
| 1  | 1   | 1 1 | Scratchpad Register       | Scratchpad Register       |
| 0  | 0   | 0   | . 0                       | LSB of Divisor Latch      |
| 0  | 0   | 1 1 |                           | MSB of Divisor Latch      |
|    |     |     |                           |                           |

#### REGISTER FUNCTIONAL DESCRIPTIONS

#### TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

#### FIFO INTERRUPT MODE OPERATION

When the receive FIFO (FCR BIT-0=1) and receive interrupts (IER BIT-0=1) are enabled, receiver interrupt will occur as follows:

- A) The receive data available interrupts will be issued to the CPU when the FIFO has reached its programmed trigger level; it will be cleared as soon as the FIFO drops below its programmed trigger level.
- B) The ISR receive data available indication also occurs when the FIFO trigger level is reached, and like the interrupt it is cleared when the FIFO drops below the trigger level.
- C) The data ready bit (LSR BIT-0) is set as soon as a character is transferred from the shift register to the receiver FIFO. It is reset when the FIFO is empty.

#### FIFO POLLED MODE OPERATION

When FCR BIT-0=1; resetting IER BIT 3-0 to zero puts the ST16C554 in the FIFO polled mode of operation. Since the receiver and transmitter are controlled separately either one or both can be in the polled mode operation by utilizing the Line Status Register.

- A) LSR BIT-0 will be set as long as there is one byte in the receive FIFO.
- B) LSR BIT4-1 will specify which error(s) has occurred.
- C) LSR BIT-5 will indicate when the transmit FIFO is empty.
- D) LSR BIT-6 will indicate when both transmit FIFO and transmit shift register are empty.
- E) LSR BIT-7 will indicate when there are any errors in the receive FIFO

The ST16C554 requires to have two step FIFO enable operation in order to enable receive trigger levels.

#### PROGRAMMABLE BAUD RATE GENERATOR

The ST16C554 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to  $2^{16}$  -1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

#### **INTERRUPT ENABLE REGISTER (IER)**

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the INT output pin.

#### IER BIT-0:

0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

#### IER BIT-1:

0=disable the transmitter empty interrupt. 1=enable the transmitter empty interrupt.

#### IER BIT-2:

0=disable the receiver line status interrupt. 1=enable the receiver line status interrupt.

#### IER BIT-3:

0=disable the modern status register interrupt.
1=enable the modern status register interrupt.

#### **IER BIT 7-4:**

All these bits are set to logic zero.

#### **INTERRUPT STATUS REGISTER (ISR)**

The ST16C554 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C554 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

#### **Priority level**

| P  | D3 | D2 | D1 | D0 | Source of the interrupt                    |
|----|----|----|----|----|--------------------------------------------|
| 1  | 0  | 1  | 1  | 0  | LSR (Receiver Line Sta-<br>tus Register)   |
| 2  | 0  | 1  | 0  | 0  | RXRDY (Received Data Ready)                |
| 2* | 1  | 1  | 0  | 0  | RXRDY (Receive Data time out)              |
| 3  | 0  | 0  | 1  | 0  | TXRDY( Transmitter Holding Register Empty) |
| 4  | 0  | 0  | 0  | 0  | MSR (Modem Status<br>Register)             |

#### \*RECEIVE TIME-OUT:

This mode is enabled when STARTECH UART is operating in FIFO mode. Receive time out will not occur if the receive FIFO is empty. The time out counter will be reset at the center of each stop bit received or each time receive holding register is read. The actual time out value is T (Time out length in bits)= 4 X P (Programmed word length) + 12. To convert time out value to a character value, user has to divide this number to its complete word length + parity (if used) + number of stop bits and start bit.

Example -A: If user programs the word length = 7, and no parity and one stop bit, Time out will be:  $T = 4 \times 7$  (programmed word length) +12 = 40 bits Character time = 40 / 9 [ (programmed word length = 7) + (stop bit = 1) + (start bit = 1)] = 4.4 characters.

Example -B: If user programs the word length = 7, with parity and one stop bit, the time out will be:  $T = 4 \times 7$  (programmed word length) + 12 = 40 bits Character time = 40 / 10 [ (programmed word length = 7) + (parity = 1) + (stop bit = 1) + (start bit = 1) = 4 characters.

#### ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1=no interrupt pending.

#### **ISR BIT 1-3:**

Logical combination of these bits, provides the highest priority interrupt pending.

#### **ISR BIT 4-7:**

These bits are not used and are set to zero in ST16C450 mode. BIT 6-7: are set to "1" in ST16C554 mode.

#### FIFO CONTROL REGISTER (FCR)

This register is used to enable the FIFOs, clear the FIFOs, set the receiver FIFO trigger level, and select the type of DMA signaling.

#### FCR BIT-0:

0=Disable the transmit and receive FIFO. 1=Enable the transmit and receive FIFO. This bit should be enabled before setting the FIFO trigger levels.

#### FCR BIT-1:

0=No change.

1=Clears the contents of the receive FIFO and resets its counter logic to 0 (the receive shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-2:

0=No change.

1=Clears the contents of the transmit FIFO and resets its counter logic to 0 (the transmit shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-3:

0=No change.

1=Changes RXRDY and TXRDY pins from mode "0" to mode "1".

#### Transmit operation in mode "0":

When ST16C554 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) when there are no characters in the transmit.FIFO or transmit holding register, the TXRDY\* pin will go low. Once active the TXRDY\* pin will go high (inactive) after the first character is loaded into the transmit holding register.

#### Receive operation in mode "0":

When ST16C554 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) and there is at least 1 character in the receive FIFO, the RXRDY\* pin will go low. Once active the RXRDY\* pin will go high (inactive) when there are no more characters in the receiver.

#### Transmit operation in mode "1":

When ST16C554 is in ST16C550 mode (FCR bit-0=1, FCR bit-3=1) the TXRDY\* pin will become high (inactive) when the transmit FIFO is completely full. It will be low if one or more FIFO locations are empty.

## Receive operation in mode "1":

When ST16C554 is in ST16C550 mode (FCR bit-0=1, FCR bit-3=1) and the trigger level or the timeout has been reached, the RXRDY\* pin will go low. Once it is activated it will go high (inactive) when there are no more characters in the FIFO.

#### FCR BIT 4-5:

Not used.

#### **FCR BIT 6-7:**

These bits are used to set the trigger level for the receiver FIFO interrupt.

| BIT-7 | BIT-6 | FIFO trigger level |
|-------|-------|--------------------|
| 0     | 0     | 01                 |
| 0     | 1 1   | 04                 |
| 1     | 0     | 80                 |
| 1     | 1     | 14                 |
|       |       |                    |

#### LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

#### LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 | BIT-0 | Word length |
|-------|-------|-------------|
| 0     | 0     | 5           |
| 0     | 1     | 6           |
| 1 1   | 0     | 7           |
| 1     | 1     | 8           |

#### LCR BIT-2:

The number of stop bits can be specified by this bit.

| BIT-2 | Word length | Stop bit(s) |
|-------|-------------|-------------|
| 0     | 5,6,7,      | 1           |
| 1 1   | 5           | 1-1/2       |
| 1 1   | 6,7,8       | 2           |

#### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

#### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format.

#### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

#### LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0=normal operating condition.

1=forces the transmitter output (TX) to go low to alert the communication terminal.

#### LCR BIT-7:

The internal baud rate counter latch enable (DLAB). 0=normal operation.

1=select divisor latch register.

#### MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

#### MCR BIT-0:

0=force DTR\* output to high. 1=force DTR\* output to low.

#### MCR BIT-1:

0=force RTS\* output to high. 1=force RTS\* output to low.

#### MCR BIT-2:

Not used, except in internal loop-back mode.

#### MCR BIT-3:

0=set the INT A-D output pin to three state mode..
1=Enable the INT A-D output pin.

#### MCR BIT-4:

0=normal operating mode.

1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, MCR bit-2 and INT enable are connected to modem control inputs.

In this mode, the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER.

#### MCR BIT 5-7:

Not used. Are set to zero permanently.

#### LINE STATUS REGISTER (LSR)

This register provides the status of data transfer to CPU.

#### LSR BIT-0:

0=no data in receive holding register or FIFO. 1=data has been received and saved in the receive holding register or FIFO.

#### LSR BIT-1:

0=no overrun error (normal).

1=overrun error, next character arrived before receive holding register was emptied or if FIFOs are enabled, an overrun error will occur only after the FIFO is full and the next character has been completely received in the shift register. Note that character in the shift register is overwritten, but it is not transferred to the FIFO.

#### LSR BIT-2:

0=no parity error (normal).

1=parity error, received data does not have correct parity information. In the FIFO mode this error is associated with the character at the top of the FIFO.

#### LSR BIT-3:

0=no framing error (normal).

1=framing error received, received data did not have

a valid stop bit. In the FIFO mode this error is associated with the character at the top of the FIFO.

#### LSR BIT-4:

0=no break condition (normal).

1=receiver received a break signal (RX was low for one character time frame). In FIFO mode, only one zero character is loaded into the FIFO.

#### LSR BIT-5:

0=transmit holding register is full. ST16C554 will not accept any data for transmission.

1=transmit holding register (or FIFO ) is empty. CPU can load the next character.

#### LSR BIT-6:

0=transmitter holding and shift registers are full. 1=transmitter holding and shift registers are empty. In FIFO mode this bit is set to one whenever the transmitter FIFO and transmit shift register are empty.

#### LSR BIT-7:

0=Normal.

1=At least one parity error, framing error or break indication in the FIFO. This bit is cleared when LSR is read.

#### MODEM STATUS REGISTER (MSR)

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register

#### MSR BIT-0:

Indicates that the CTS\* input to the ST16C554 has changed state since the last time it was read.

#### MSR BIT-1:

Indicates that the DSR\* input to the ST16C554 has changed state since the last time it was read.

#### MSR BIT-2:

Indicates that the RI\* input to the ST16C554 has changed from a low to a high state.

#### MSR BIT-3:

Indicates that the CD\* input to the ST16C554 has changed state since the last time it was read.

#### MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

#### MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

#### MSR BIT-6:

This bit is equivalent to MCR bit-2 during local loopback mode. It is the compliment of the RI\* input.

#### MSR BIT-7:

This bit is equivalent to INT enable in the MCR during local loop-back mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated.

#### SCRATCHPAD REGISTER (SR)

ST16C554 provides a temporary data register to store 8 bits of information for variable use.

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16 x CLOCK<br>DIVISOR | % ERROR |  |  |
|-----------|-----------------------|---------|--|--|
| 50        | 2304                  |         |  |  |
| 110       | 1047                  | 0.026   |  |  |
| 150       | 768                   |         |  |  |
| 300       | 384                   | 1       |  |  |
| 600       | 192                   |         |  |  |
| 1200      | 96                    | · ·     |  |  |
| 2400      | 48                    | 1       |  |  |
| 4800      | 24                    | 1       |  |  |
| 7200      | 16                    |         |  |  |
| 9600      | 12                    | ļ       |  |  |
| 19.2K     | 6                     | }       |  |  |
| 38.4K     | 3                     |         |  |  |
| 56K       | 2                     | 2.77    |  |  |
| 115.2K    | 1                     | 1       |  |  |

#### ST16C554 EXTERNAL RESET CONDITION

| REGISTERS | RESET STATE                 |
|-----------|-----------------------------|
| IER       | IER BITS 0-7=0              |
| ISR       | ISR BIT-0=1, ISR BITS 1-7=0 |
| LCR       | LCR BITS 0-7=0              |
| MCR       | MCR BITS 0-7=0              |
| LSR       | LSR BITS 0-4=0,             |
|           | LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR       | MSR BITS 0-3=0,             |
|           | MSR BITS 4-7=input signals  |
| FCR       | FCR BITS 0-7=0              |
|           | '                           |

| RESET STATE      |  |  |
|------------------|--|--|
| High             |  |  |
| High             |  |  |
| High             |  |  |
| High             |  |  |
| Low              |  |  |
| Three state mode |  |  |
|                  |  |  |

## **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                     | Parameter                                      | Min  | Limits<br>Typ | Max                | Units | Conditions     |
|------------------------------------------------------------------------------------------------------------|------------------------------------------------|------|---------------|--------------------|-------|----------------|
| т                                                                                                          | Clock high pulse duration                      | 50   |               |                    | ns    |                |
| <u>'</u> 1                                                                                                 | Clock low pulse duration                       | 50   |               |                    | ns    | External clock |
| <b>+</b> 2                                                                                                 | Clock rise/fall time                           | ] 30 |               | 10                 | ns    | LATERNAL CIOCK |
| †3<br>T                                                                                                    | Chip select setup time                         | 5    |               | 10                 | ns    |                |
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>8</sub> T <sub>9</sub> T <sub>12</sub> T <sub>13</sub> | Chip select hold time                          | Ö    |               |                    | ns    |                |
| Ť                                                                                                          | Data setup time                                | 15   | ]             |                    | ns    |                |
| Ť <sup>12</sup>                                                                                            | Data hold time                                 | 15   |               |                    | ns    |                |
| T <sub>14</sub>                                                                                            | IOW* delay from chip select                    | 10   |               |                    | ns    |                |
| T <sub>15</sub>                                                                                            | IOW* strobe width                              | 50   |               |                    | ns    |                |
| T <sub>16</sub>                                                                                            | Chip select hold time from IOW*                | ő    | ]             |                    | ns    |                |
| T <sub>17</sub>                                                                                            | Write cycle delay                              | 55   | ] ]           |                    | ns    |                |
| Tw                                                                                                         | Write cycle=T <sub>15</sub> +T <sub>17</sub>   | 105  | 1             |                    | ns    |                |
| T <sub>19</sub>                                                                                            | Data hold time                                 | 15   | 1             | 25                 | ns    |                |
| T.,                                                                                                        | IOR* delay from chip select                    | 10   |               |                    | ns    |                |
| T <sub>21</sub><br>T <sub>23</sub>                                                                         | IOR* strobe width                              | 65   | 1 1           |                    | ns    |                |
| T <sub>24</sub>                                                                                            | Chip select hold time from IOR*                | 0    |               |                    | ns    |                |
| T <sub>25</sub>                                                                                            | Read cycle delay                               | 55   |               |                    | ns    |                |
| T <sub>25</sub><br>Tr                                                                                      | Read cycle=T <sub>23</sub> +T <sub>25</sub>    | 115  |               |                    | ns    |                |
| T <sub>26</sub>                                                                                            | Delay from IOR* to data                        |      |               | 35                 | ns    | 100 pF load    |
| T <sub>28</sub>                                                                                            | Delay from IOW* to output                      |      | 1             | 50                 | ns    | 100 pF load    |
| T <sub>29</sub>                                                                                            | Delay to set interrupt from MODEM input        |      |               | 70                 | ns    | 100 pF load    |
| T <sub>30</sub>                                                                                            | Delay to reset interrupt from IOR*             |      | 1             | 70                 | ns    | 100 pF load    |
| T <sub>30</sub><br>T <sub>31</sub><br>T <sub>32</sub>                                                      | Delay from stop to set interrupt               |      | 1             | 1 <sub>Rclk</sub>  | ns    | 100 pF load    |
| T <sub>32</sub>                                                                                            | Delay from IOR* to reset interrupt             |      |               | 200                | ns    | 100 pF load    |
| T <sub>33</sub>                                                                                            | Delay from initial INT reset to transmit start | 8    |               | 24                 | *     |                |
| T <sub>34</sub>                                                                                            | Delay from stop to interrupt                   |      |               | 100                | ns    | •              |
| T <sub>35</sub>                                                                                            | Delay from IOW* to reset interrupt             |      |               | 175                | ns    | <i>!</i>       |
| T <sub>35</sub><br>T <sub>44</sub><br>T <sub>45</sub>                                                      | Delay from stop to set RxRdy                   |      | , ,           | 1 <sub>RCLK</sub>  |       |                |
| T <sub>45</sub>                                                                                            | Delay from IOR* to reset RxRdy                 | . "- |               | 1                  | μS    |                |
| T <sub>46</sub>                                                                                            | Delay from IOW* to set TxRdy                   |      |               | 195                | ns    |                |
| T <sub>47</sub>                                                                                            | Delay from start to reset TxRdy                |      |               | 8                  | *     |                |
| N                                                                                                          | Baud rate devisor                              | 1    |               | 2 <sup>16</sup> -1 |       |                |

Note 1: \* = Baudout\* cycle

## **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

#### DC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                       | Parameter                                                                                                                                                             | Min                               | Limits Min Typ Max |                                 |   | Conditions                                        |
|--------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--------------------|---------------------------------|---|---------------------------------------------------|
| V <sub>IHCK</sub> V <sub>IL</sub> In V <sub>OL</sub> V <sub>OH</sub> O O O O O I C O I I I I I I I I I I I I | ock input low level ock input high level put low level put high level utput low level on all outputs utput high level yg power supply current put leakage ock leakage | -0.5<br>3.0<br>-0.5<br>2.2<br>2.4 | 6                  | 0.6<br>VCC<br>0.8<br>VCC<br>0.4 | ን | I <sub>OL</sub> = 6 mA<br>I <sub>OH</sub> = -6 mA |

3

# ST16C554 ST16C554D

#### **GENERAL WRITE TIMING**



#### GENERAL READ TIMING



MODEM TIMING







**RXRDY TIMING FOR MODE "0"** 



#### **RXRDY TIMING FOR MODE "1"**









#### TXRDY TIMING FOR MODE "1"







Printed September 7, 1994

## QUAD ASYNCHRONOUS RECEIVER AND TRANSMITTER WITH FIFO

#### DESCRIPTION

The ST68C554 is a quad universal asynchronous receiver and transmitter with FIFO and modem control signals. Designed to interface with MOTOROLA, ROCKWELL, HITACHI bus and other popular microprocessors. An internal programmable baud rate generator is provided to select transmit and receive clock rates from 50Hz to 448kHz.

The ST68C554 is an improved, quad version of the NS16550 UART with faster operating access time. The on board status registers will provide the error conditions, type and status of the transfer operations being performed. Complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements to minimize the computing required to handle the communications link.

The ST68C554 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

#### **FEATURES**

- . Motorola, Rockwell, Hitachi bus compatible
- Quad ST16C550
- 16 byte transmit FIFO
- 16 byte receive FIFO with error flags
- Modem control signals (CTS\*,RTS\*, DSR\*, DTR\*, RI\*, CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- · Status report register
- TTL compatible inputs, outputs
- 448 kHz transmit/receive operation with 7.372 MHz external clock source

# ORDERING INFORMATION

Part number ST68C554CJ68 ST68C554IJ68 Package PLCC PLCC Operating temperature 0° C to +70° C -40° C to +85° C

## **PLCC Package**



3

**BLOCK DIAGRAM** 



| Symbol             | Pin              | Signal Type | Pin Description                                                                                                                                                                                                                                                                             |
|--------------------|------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D7-D0              | 5-66             | 1/0         | Bi-directional data I/O. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                           |
| RX A/B<br>RX C/D   | 7,29<br>41,63    | . 1         | Serial data input. The serial information received from MODEM or RS232 to ST68C554 receive circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. |
| TX A/B<br>TX C/D   | 17,19<br>51,53   | 0           | Serial data output A. The serial data of channel A is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                 |
| CS*                | 16               | l           | Chip select (active low). A low at this pin will enable the UART A-D CPU data transfer operation.                                                                                                                                                                                           |
| XTAL1              | 35               | 1           | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                    |
| XTAL2              | 36               | 1           | Crystal input 2. See XTAL1.                                                                                                                                                                                                                                                                 |
| R/W*               | 18               | l           | Read/Write strobe. A low on this pin will transfer the contents of the CPU data bus to the addressed register. A high on this pin will transfer the contents of the ST68C554 data bus to the CPU.                                                                                           |
| CD A/B*<br>CD C/D* | 9,27<br>43,61    | l           | Carrier detect A-D (active low). A low on this pin indicates that carrier has been detected by the modern.                                                                                                                                                                                  |
| GND<br>GND         | 6,23,31<br>40,57 | 0           | Signal and power ground.                                                                                                                                                                                                                                                                    |

# ST68C554

| Symbol               | Pin            | Signal Type                           | Pin Description                                                                                                                                                                                                                               |
|----------------------|----------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DSR A/B*<br>DSR C/D* | 10,26<br>44,60 | • • • • • • • • • • • • • • • • • • • | Data set ready A-D. (active low) A low on this pin indicates that MODEM is ready to exchange data with UART.                                                                                                                                  |
| RI A/B*<br>RI C/D*   | 8,28<br>42,62  | <b>!</b>                              | Ring detect A-D indicator . (active low) A low on this pin indicates that modem has received a ringing signal from telephone line.                                                                                                            |
| RTS A/B*<br>RTS C/D* | 14,22<br>48,56 | O                                     | Request to send A-D. (active low) To indicate that transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to low state. After the reset this pin will be set to high.                  |
| CTS A/B*<br>CTS C/D* | 11,25<br>45,59 |                                       | Clear to send A-D. (active low) The CTS* signal s a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmitter output.                                                       |
| A4                   | 50             | : I                                   | Address line 4. To select one of the four UARTS.                                                                                                                                                                                              |
| А3                   | 20             | Ι                                     | Address line 3. To select one of the four UARTS.                                                                                                                                                                                              |
| A2                   | 32             | . 1                                   | Address line 2. To select internal registers.                                                                                                                                                                                                 |
| A1                   | 33             |                                       | Address line 1. To select internal registers.                                                                                                                                                                                                 |
| A0                   | <b>34</b>      |                                       | Address line 0. To select internal registers.                                                                                                                                                                                                 |
| IRQ*                 | 15             | 0                                     | Interrupt output. (active low open collector) This pin goes low (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty or modem status condition flag is detected on UART A-D. |
| DTR A/B*<br>DTR C/D* | 12,24<br>46,58 | 0                                     | Data terminal ready A-D. (active low) To indicate that                                                                                                                                                                                        |

## **SYMBOL DESCRIPTION**

| Symbol     | Pin            | Signal Type | Pin Description                                                                                                                                                                                                                                                       |
|------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |                |             | ST68C554 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. |
| RESET*     | 37             | 1           | Master reset. (active low) A low on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                                                                     |
| vcc<br>vcc | 13,30<br>47,64 | · 1         | Power supply input.                                                                                                                                                                                                                                                   |
| TXRDY      | 39             | 0           | Transmit ready (active high). This pin goes high when the transmit FIFO of the ST68C554 (any one) is full. It can be used as a single or multi-transfer DMA.                                                                                                          |
| RXRDY*     | 38             | 0           | Receive ready (active low). This pin goes low when the receive FIFO of the ST68C554 is full. It can be used as a single or multi-transfer DMA.                                                                                                                        |

# **SERIAL PORT SELECTION GUIDE**

| CS* | Α4 | АЗ | UART X |
|-----|----|----|--------|
| 1   | х  | х  | х      |
| 0   | 0  | 0  | UART A |
| 0   | 0  | 1  | UART B |
| 0   | 1  | 0  | UART C |
| 0   | 1. | 1  | UART D |

#### PROGRAMMING TABLE

| A2 | A1 | A0  | READ MODE                 | WRITE MODE                |
|----|----|-----|---------------------------|---------------------------|
| 0  | 0  | 0   | Receive Holding Register  | Transmit Holding Register |
| 0  | 0  | 1 1 |                           | Interrupt Enable Register |
| 0  | 1  | 0   | Interrupt Status Register | FIFO Control Register     |
| 0  | 1  | 1 1 |                           | Line Control Register     |
| 1  | 0  | lol |                           | Modem Control Register    |
| 1  | 0  | 1 1 | Line Status Register      |                           |
| 1  | 1  | 0   | Modem Status Register     |                           |
| 1  | 1  | 1   | Scratchpad Register       | Scratchpad Register       |
| 0  | 0  | 0   | •                         | LSB of Divisor Latch      |
| 0  | 0  | 1   |                           | MSB of Divisor Latch      |

#### REGISTER FUNCTIONAL DESCRIPTIONS

# TRANSMIT AND RECEIVE HOLDING REGISTER A-D

The serial transmitter section consists of a Transmit Hold Register A-D and Transmit Shift Register A-D. The status of the transmit hold register is provided in the Line Status Register A-D. Writing to this register will transfer the contents of the data bus (D7-D0) to the transmit holding register A-D whenever the transmitter holding register A-D or transmitter shift register A-D is empty. The transmit holding register empty A-D flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register A-D. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX A-D is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX A-D input. Receiver status codes will be posted in the Line Status Register A-D.

#### FIFO INTERRUPT MODE OPERATION

When the receive FIFO (FCR BIT-0=1) and receive interrupts (IER BIT-0=1) are enabled, receiver interrupt will occur as follows:

- A) The receive data available interrupts will be issued to the CPU when the FIFO has reached its programmed trigger level; it will be cleared as soon as the FIFO drops below its programmed trigger level.
- B) The ISR receive data available indication also occurs when the FIFO trigger level is reached, and like the interrupt it is cleared when the FIFO drops below the trigger level.
- C) The data ready bit (LSR BIT-0) is set as soon as a character is transferred from the shift register to the receiver FIFO. It is reset when the FIFO is empty.

#### FIFO POLLED MODE OPERATION

When FCR BIT-0=1; resetting IER BIT 3-0 to zero puts the ST68C554 in the FIFO polled mode of operation. Since the receiver and transmitter are controlled separately either one or both can be in the polled mode operation by utilizing the Line Status Register.

- A) LSR BIT-0 will be set as long as there is one byte in the receive FIFO.
- B) LSR BIT4-1 will specify which error(s) has occurred.
- C) LSR BIT-5 will indicate when the transmit FIFO is empty.

D) LSR BIT-6 will indicate when both transmit FIFO and transmit shift register are empty.

E) LSR BIT-7 will indicate when there are any errors in the receive FIFO.

#### PROGRAMMABLE BAUD RATE GENERATOR

The ST68C554 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to 2<sup>16</sup>-1. Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

#### INTERRUPT ENABLE REGISTER A-D

The Interrupt Enable Register A-D masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the IRQ\* output pin.

#### IER BIT-0:

0=disable the receiver ready interrupt 1=enable the receiver ready interrupt

#### IER BIT-1:

0=disable transmitter empty interrupt 1=enable transmitter empty interrupt

#### IER BIT-2:

0=disable receiver line status interrupt
1=enable receiver line status interrupt

#### IER BIT-3:

0=disable the modem status register interrupt 1=enable the modem status register interrupt

#### **IER BIT 7-4:**

All these bits are set to logic zero.

#### **INTERRUPT STATUS REGISTER A-D**

The ST68C554 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register A-D provides the source of the interrupt in prioritized manner. During the read cycle, the ST68C554 pro-

vides the highest interrupt level to be serviced by the CPU. No other interrupts are acknowledged until the particular interrupt has been serviced. The following are the prioritized interrupt levels:

| Р  | D3 | D2 | D1 | D0 | Source of the interrupt                    |
|----|----|----|----|----|--------------------------------------------|
| 1  | 0  | 1  | 1  | 0  | LSR (Receiver Line Status Register)        |
| 2  | 0  | 1  | 0  | 0  | RXRDY (Received Data Ready)                |
| 2* | 1  | 1  | 0  | 0  | RXRDY (Receive Data time out)              |
| 3  | 0  | 0  | 1  | 0  | TXRDY( Transmitter Holding Register Empty) |
| 4  | 0  | 0  | 0  | 0  | MSR (Modem Status<br>Register)             |

#### \*RECEIVE TIME-OUT:

This mode is enabled when STARTECH UART is operating in FIFO mode. Receive time out will not occur if the receive FIFO is empty. The time out counter will be reset at the center of each stop bit received or each time receive holding register is read. The actual time out value is T (Time out length in bits)= 4 X P (Programmed word length) + 12. To convert time out value to a character value, user has to divide this number to its complete word length + parity (if used) + number of stop bits and start bit.

Example -A: If user programs the word length = 7, and no parity and one stop bit, Time out will be:  $T = 4 \times 7$  (programmed word length) +12 = 40 bits Character time = 40 / 9 [ (programmed word length = 7) + (stop bit = 1) + (start bit = 1)] = 4.4 characters.

Example -B: If user programs the word length = 7, with parity and one stop bit, the time out will be:  $T = 4 \times 7$ (programmed word length) + 12 = 40 bits Character time = 40 / 10 [ (programmed word length = 7) + (parity = 1) + (stop bit = 1) + (start bit = 1) = 4 characters.

# ST68C554

#### ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine

1=no interrupt pending

#### **ISR BIT 1-2:**

Logical combination of these bits, provides the highest priority interrupt pending.

#### ISR BIT 3-5:

These bits are not used and are set zero.

#### **ISR BIT 6-7:**

0=Normal mode.

1=FIFO's are enabled.

#### FIFO CONTROL REGISTER (FCR)

This register is used to enable the FIFOs, clear the FIFOs, set the receiver FIFO trigger level, and select the type of DMA signaling.

#### FCR BIT-0:

0=Disable the transmit and receive FIFO. 1=Enable the transmit and receive FIFO.

#### FCR BIT-1:

0=No change.

1=Clears the contents of the receive FIFO and resets its counter logic to 0 (the receive shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-2:

0=No change.

1=Clears the contents of the transmit FIFO and resets its counter logic to 0 (the transmit shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-3:

0=No change.

1=Changes RXRDY and TXRDY pins from mode "0" to mode "1".

#### Transmit operation in mode "0":

When ST68C554 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) when there are no characters in the transmit FIFO or transmit holding register, the TXRDY\* pin will go low. Once active the TXRDY\* pin will go high (inactive) after the first character is loaded into the transmit holding register.

#### Receive operation in mode "0":

When ST68C554 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) and there is at least 1 character in the receive FIFO, the RXRDY\* pin will go low. Once active the RXRDY\* pin will go high (inactive) when there are no more characters in the receiver.

#### Transmit operation in mode "1":

When ST68C554 is in ST16C550 mode (FCR bit-0=1, FCR bit-3=1) the TXRDY\* pin will become high (inactive) when the transmit FIFO is completely full. It will be low if one or more FIFO locations are empty.

#### Receive operation in mode "1":

When ST68C554 is in ST16C550 mode (FCR bit-0=1, FCR bit-3=1) and the trigger level or the timeout has been reached, the RXRDY\* pin will go low. Once it is activated it will go high (inactive) when there are no more characters in the FIFO.

#### **FCR BIT 4-5:**

Not used.

#### FCR BIT 6-7:

These bits are used to set the trigger level for the receiver FIFO interrupt.

| BIT-7 | BIT-6 | FIFO trigger level |
|-------|-------|--------------------|
| 0     | 0     | 01                 |
| 0     | 1     | 04                 |
| 1     | 0     | 7. J. 08 - 1       |
| 1     | 1     | 14                 |
|       | L     | <u> </u>           |

#### LINE CONTROL REGISTER A-D

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

#### LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

00=5 bits word length 01=6 bits word length 10=7 bits word length 11=8 bits word length

#### LCR BIT-2:

The number of stop bits can be specified by this bit.

0=1 stop bit, when word length=5, 6, 7, 8 bits 1=1 and 1/2 stop bit, when word length=5 bits 1=2 stop bits, word length=6, 7, 8 bits

#### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission; receiver also checks for received parity

#### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=odd parity is generated by calculating odd number of 1's in the transmitted data; receiver also checks for same format.

1=an even parity bit is generated by calculating the number of even 1's in the transmitted data; receiver also checks for same format.

#### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

#### LCR BIT-6:

Break control bit.

1=forces the transmitter output (TX A-D) to go low to alert the communication terminal 0=normal operating condition

#### LCR BIT-7:

The internal baud rate counter latch enable (DLEN). 0=normal operation 1=select divisor latch register

#### MODEM CONTROL REGISTER A-D

This register controls the interface with the MODEM or a peripheral device (RS232).

#### MCR BIT-0:

0=force DTR\* output to high 1=force DTR\* output to low

#### MCR BIT-1:

0=force RTS\* output to high 1=force RTS\* output to low

#### MCR BIT2-3:

x=not used

#### MCR BIT -4:

0=normal operating mode

1=enable local loop-back mode (diagnostics). The transmitter output (TX A-D) is set high (Mark condition), the Receiver inputs (RX A-D, CTS A-D\*, DSR A-D\*, CD A-D\*, and RI A-D\*) are disabled. Internally, the transmitter output is connected to the receiver input and DTR A-D\*, RTS A-D\* and MCR A-D bit-2,3 are connected to modem control inputs. In this mode, the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupt sources are now the lower four bits of the Modem Control Register instead of the four Modem Control Inputs. The interrupts are still controlled by the IER A-D.

#### MCR BIT 5-7:

Not used. Are set to zero permanently.

# ST68C554

#### LINE STATUS REGISTER A-D

This register provides the status of data transfer to CPU.

#### LSR BIT-0:

0=no data in receive holding register

1=a data has been received and saved in the receive holding register

#### LSR BIT-1:

0=no overrun error (normal)

1=overrun error, next character arrived before receive holding register was empty

#### LSR BIT-2:

0=no parity error (normal)

1=parity error, received data does not have correct parity information

#### LSR BIT-3:

0=no framing error (normal)

1=framing error received, received data did not have a valid stop bit

#### LSR BIT-4:

0=no break condition (normal)

1=receiver received a break signal (RX was low for one character time frame)

#### LSR BIT-5:

0=transmit holding register is full; ST68C554 will not accept any data for transmission

1=transmit holding register is empty; CPU can load the next character

#### LSR BIT-6:

0=transmitter holding and shift registers are full 1=transmitter holding and shift registers are empty

#### LSR BIT-7:

0=Normal

1=At least one parity error, framing error or break indication in the FIFO. This bit is cleared when LSR is read.

#### MODEM STATUS REGISTER A-D

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

#### MSR BIT-0:

Indicates that the CTS\* input to the ST68C554 has changed state since the last time it was read.

#### MSR BIT-1:

Indicates that the DSR\* input to the ST68C554 has changed state since the last time it was read.

#### MSR BIT-2:

Indicates that the RI\* input to the ST68C554 has changed from a low to a high state.

#### MSR BIT-3:

Indicates that the CD\* input to the ST68C554 has changed state since the last time it was read.

#### MSR BIT-4:

This bit is equivalent to RTS in the MCR. It is the compliment of the CTS\* input.

#### MSR BIT-5:

This bit is equivalent to DTR in the MCR. It is the compliment of the DSR\* input.

#### MSR BIT-6:

This bit is equivalent to MCR bit-2 during local loopback mode. It is the compliment of the RI\* input.

#### MSR BIT-7:

This bit is equivalent to MCR bit-3 during local loopback mode. It is the compliment to the CD\* input.

#### SCRATCHPAD REGISTER A-D

ST68C554 provides a temporary data register to store 8 bits of information for variable use.

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16xCLOCK<br>%ERROR | DVISOR |
|-----------|--------------------|--------|
| 50        | 2304               |        |
| 75        | 1536               |        |
| 150       | 768                | }      |
| 300       | 384                |        |
| 600       | 192                |        |
| 1200      | 96                 |        |
| 2400      | 48                 |        |
| 4800      | 24                 |        |
| 7200      | 16                 |        |
| 9600      | 12                 |        |
| 19.2      | 6                  |        |
| 38.4K     | 3                  | }      |
| 56K       | 2                  | 2.77   |
| 115.2K    | 1                  |        |

#### ST68C554 EXTERNAL RESET CONDITION

| REGISTERS | RESET STATE                         |
|-----------|-------------------------------------|
| IER A-D   | BITS 0-7=0                          |
| ISR A-D   | BIT-0=1, BIT-7=0                    |
| LCR A-D   | BITS 0-7=0                          |
| MCR A-D   | BITS 0-7=0                          |
| LSR A-D   | BITS 0-4=0, BITS 5-6=1, BIT-<br>7=0 |
| MSR A-D   | BITS 0-3=0, BITS 4-7= input signals |

| SIGNALS  | RESET STATE      |
|----------|------------------|
| TX A-D   | High             |
| RTS A-D* | High             |
| DTR A-D* | High             |
| RxRdy*   | High             |
| TxRdy    | Low              |
| IRQ      | Three state mode |

# ST68C554

## ST68C554 ACCESSIBLE REGISTERS

| A2 | <b>A1</b> | A0  | Register     | BIT-7                      | BIT-6                    | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----|-----------|-----|--------------|----------------------------|--------------------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0  | 0         | 0   | RHR          | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0         | 0   | THR          | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0         | 1   | IER          | 0                          | 0                        | 0                          | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0  | 1         | 0   | FCR          | RCVR<br>trigger<br>(MSB)   | RCVR<br>trigger<br>(LSB) | 0                          | 0                  | DMA<br>mode<br>select        | XMIT<br>FIFO<br>reset                  | RCVR<br>FIFO<br>reset           | FIFO<br>enable                 |
| 0  | 1         | 0   | ISR<br>FIFOs | 0/<br>FIFOs<br>enabled     | 0/<br>enabled            | 0                          | 0<br>priority      | int<br>priority<br>bit-2     | int<br>priority<br>bit-1               | int<br>status<br>bit-0          | int                            |
| 0  | 1         | 1   | LCR          | divisor<br>latch<br>enable | set<br>break             | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1  | 0         | 0   | MCR          | 0                          | 0                        | 0                          | loop<br>back       | Not<br>used                  | Not<br>used                            | RTS*                            | DTR*                           |
| 1  | 0         | 1   | LSR          | 0/<br>FIFO<br>error        | trans.<br>empty          | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1  | 1         | 0 , | MSR          | CD                         | RI                       | DSR                        | стѕ                | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1  | 1         | 1   | SPR          | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| O  | 0         | 0   | DLL          | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0         | 1   | DLM          | bit-15                     | bit-14                   | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

## **AC ELECTRICAL CHARACTERISTICS**

 $T_A$ =0° - 70° C, Vcc=5.0 V  $\pm$  10% unless otherwise specified.

| Symbol                                                                                 | Parameter                                       | Min | Limits<br>Typ | Max               | Units | Conditions     |
|----------------------------------------------------------------------------------------|-------------------------------------------------|-----|---------------|-------------------|-------|----------------|
| Т.                                                                                     | Clock high pulse duration                       | 50  |               |                   | ns    |                |
| T.                                                                                     | Clock low pulse duration                        | 50  |               |                   | ns    | External clock |
| T <sub>1</sub><br>T <sub>2</sub><br>T <sub>3</sub><br>T <sub>8</sub><br>T <sub>9</sub> | Clock rise/fall time                            |     |               | 10                | ns    |                |
| T,                                                                                     | Chip select setup time                          | 5   |               |                   | ns    |                |
| T.                                                                                     | Chip select hold time                           | 0   |               | ·                 | ns    |                |
| T <sub>12</sub>                                                                        | Data setup time                                 | 15  |               | ·                 | ns    |                |
| 1 13                                                                                   | Data hold time from write or CS*                | 15  | 1             |                   | ns    |                |
| T <sub>14</sub>                                                                        | Write set up time                               | 10  |               |                   | ns    |                |
| 1,5                                                                                    | Write strobe width                              | 50  |               |                   | ns    | \$ 10 m        |
| Τ,,                                                                                    | Chip select hold time from write                | 15  |               |                   | ns    |                |
| T <sub>17</sub>                                                                        | Write cycle delay                               | 45  |               |                   | ns    |                |
| T <sub>18</sub>                                                                        | Data setup time                                 | 15  |               |                   | ns    |                |
| Tw                                                                                     | Write cycle=T <sub>15</sub> +T <sub>17</sub>    | 105 |               |                   | ns    |                |
| T <sub>24</sub>                                                                        | Data hold time                                  | 0   |               |                   | ns    |                |
| T <sub>25</sub>                                                                        | Read cycle delay                                | 25  |               |                   | ns    |                |
| Tr                                                                                     | Read cycle=T <sub>18</sub> +T <sub>25</sub>     | 105 |               |                   | ns    |                |
| T <sub>27</sub>                                                                        | Chip select pulse width                         | 75  |               |                   | ns    |                |
| T <sub>28</sub>                                                                        | Delay from Write to output                      |     |               | 50                | ns    | 100 pF load    |
| T <sub>29</sub>                                                                        | Delay to set interrupt from MODEM input         |     |               | 35                | ns    | 100 pF load    |
| T <sub>3</sub> ,                                                                       | Delay from stop to set interrupt                |     |               | 1 <sub>Rclk</sub> | ns    | 100 pF load    |
| T <sub>31</sub> T <sub>32</sub>                                                        | Delay from Read to reset interrupt              |     |               | 200               | ns    | 100 pF load    |
| T <sub>33</sub>                                                                        | Delay from initial IRQ* reset to transmit start | 8   |               | 24                | *     |                |
| T <sub>34</sub>                                                                        | Delay from stop to interrupt                    |     |               | 100               | ns    | }              |
| T <sub>35</sub>                                                                        | Delay from Write to reset interrupt             |     |               | 75                | ns    | 1              |
| Τ.,                                                                                    | Delay from stop to set RxRdy                    |     |               | 1 <sub>RCLK</sub> |       |                |
| T,,                                                                                    | Delay from read (CS*) to reset RxRdy            |     |               | 1                 | μs    |                |
| T <sub>46</sub>                                                                        | Delay from write to set TxRdy                   |     |               | 195               | ns    |                |
| T <sub>47</sub>                                                                        | Delay from start to reset TxRdy                 |     |               | 8                 | *     |                |

<sup>\* =</sup> Baudout\* cycle

# ST68C554

## **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

#### DC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                | Parameter                 | Min  | Limits<br>Typ | Max | Units | Conditions                            |
|-------------------------------------------------------|---------------------------|------|---------------|-----|-------|---------------------------------------|
| VILCK                                                 | Clock input low level     | -0.5 |               | 0.6 | V     |                                       |
| VIHCK                                                 | Clock input high level    | 3.0  |               | vcc | V     |                                       |
| V,                                                    | Input low level           | -0.5 |               | 0.8 | V     |                                       |
| ٧, ا                                                  | Input high level          | 2.2  |               | vcc | · V   |                                       |
| V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>OL</sub> | Output low level          |      | ·             | 0.4 | V     | I <sub>oL</sub> = 6 mA on all outputs |
| $V_{OH}$                                              | Output high level         | 2.4  |               |     | V     | I <sub>OH</sub> = -6 mA               |
| Icc                                                   | Avg. power supply current |      | 6             |     | mA    | Off                                   |
| i <sub>iL</sub>                                       | Input leakage             |      |               | ±10 | μΑ    |                                       |
| l <sub>c</sub> L                                      | Clock leakage             |      |               | ±10 | μA    |                                       |

## **GENERAL WRITE TIMING**



## **GENERAL READ TIMING**



#### **MODEM TIMING**



# EXTERNAL CLOCK PERIOD CLOCK PERIOD

## RECEIVE TIMING



#### **RXRDY TIMING FOR MODE "0"**



#### **RXRDY TIMING FOR MODE "1"**





## **TXRDY TIMING FOR MODE "0"**



ST68C554

# ST68C554

#### TXRDY TIMING FOR MODE "1"





Printed September 8, 1994

#### UNIVERSAL ASYNCHRONOUS RECEIVER/TRANSMITTER WITH FIFO's

#### **DESCRIPTION**

The ST16C650 is a universal asynchronous receiver and transmitter with 32 bytes transmit and receive FIFO. A programmable baud rate generator is provided to select transmit and receive clock rates from 50Hz to 448kHz.

The ST16C650 is an improved version of the ST16C550 UART with deeper FIFO, software/ hardware flow control. The ST16C650 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C650 provides internal loop-back capability for on board diagnostic testing. The ST16C650 provides pin selectable interface mode to function as stand alone ST16C550 or direct PC connect.

The ST16C650 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

#### **FEATURES**

- Pin to pin and functional compatible to NS16550, VL16C550, WD16C550, ST16C550
- 32 byte transmit FIFO
- 32 byte receive FIFO with error flags
- · Pin selectable interface mode
- Software/Hardware flow control
- Programmable Xon/Xoff characters
- Sleep mode (800µA stand-by)
- Low operating current (1.5mA typ.)
- Independent transmit and receive control
- 460 kHz transmit/receive operation
- Selectable Transmit/Receive trigger levels
- Infrared receive and transmit, input / output.

#### ORDERING INFORMATION

| Part number  | Package     | Operating | temperature |
|--------------|-------------|-----------|-------------|
| ST16C650CP40 | Plastic-DIP | 0° C      | to + 70° C  |
| ST16C650CJ44 | PLCC        | 0° C      | to + 70° C  |
| ST16C650CQ52 | QFP         | 0° C      | to + 70° C  |
| ST16C650CQ48 | TQFP        | 0° C      | to + 70° C  |
|              |             |           |             |

\*Industrial operating range are available

## **PLCC Package**



#### **Plastic-DIP Package**



## Patent pending

#### **BLOCK DIAGRAM**



| Symbol  | Pin | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                    |
|---------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| А9      | 1   | ı           | Address select line 9. When PC mode is selected, this pin is used as 10th address line to decode the standard COM1-4 ports.                                                                                                                                                                                        |
| D0-D7   | 2-9 | 1/0         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted.                                                                                                  |
| S2/RCLK | 10  | I           | Port select-2 or Receive clock input (dual function). When PC mode is selected the RCLK input is connected internally to BAUDOUT* output pin and S2 is used to select one of the ComPort addresses (Com1-4). During STD mode operation, this pin is used as external clock input to the ST16C650 receiver section. |
| RX      | 11  | l           | Serial data input. The serial information (data) received from serial port to ST16C650 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loop-back mode the RX input is disabled from external connection and connected to the TX output internally.             |
| A4      | 12  | l           | Address select line 4. When PC mode is selected, this pin is used as 5th address line to decode the standard COM1-4 ports.                                                                                                                                                                                         |
| TX      | 13  | 0           | Serial data output. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loop-back mode or when the transmitter is disabled.                                                                                      |
| A5/CS0  | 14  | 1           | Address line 5 or Chip select-1 (dual function). During the PC mode operation, this pin is used as 6th address line to decode the standard COM1-4 ports. During STD mode this pin acts as active high chip select input pin.                                                                                       |
| A6/CS1  | 15  | 1           | Address line 6 or Chip select-2 (dual function). During the PC mode operation, this pin is used as 7th address line to decode the standard COM1-4 ports. During STD mode this pin acts as active high chip select input pin                                                                                        |

# ST16C650

| Symbol     | Pin | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A7/CS2*    | 16  | I           | Address line 7 or Chip select -3 (dual function). During the PC mode operation, this pin is used as 8th address line to decode the standard COM1-4 ports. During STD mode this pin acts as active low chip select input pin.                                                                                                                                                                |
| BAUD/LPT1* | 17  | 0           | Baud rate generator clock output or LPT1 decode address (378 Hex) (dual function). This output provides the 16X clock of the internal selected baud rate during standard mode. RCLK pin is connected externally to BAUDOUT* pin to provide receive clock when STD mode is selected. This pin internally is connected to RCLK input and address 378 Hex is decoded when PC mode is selected. |
| XTAL1      | 18  |             | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                                                                                                                    |
| XTAL2      | 19  | <b>1</b>    | Crystal input 2 or buffered clock output. See XTAL1. External 1 $M\Omega$ resistor is required to connect between XTAL1 and XTAL2 pins.                                                                                                                                                                                                                                                     |
| IOW*       | 20  |             | Write strobe. (active low) A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                                                                                                                                                                                                      |
| A8/IOW     | 21  |             | Address 8 or Write strobe (dual function). During the PC mode operation, this pin is used as 9th address line to decode the standard COM1-4 ports. During STD mode this pin functions as Write strobe (active high). Same as IOW*, but uses active high input. Note that only an active IOW* or IOW input is required to transfer data from CPU to ST16C650 during write operation.         |
| GND        | 22  | 0           | Signal and power ground.                                                                                                                                                                                                                                                                                                                                                                    |
| S1         | 23  |             | Port select-1. S1 is used to select one of the ComPort addresses (Com1-4).                                                                                                                                                                                                                                                                                                                  |
| IOR*       | 24  | J. J.       | Read strobe. (active low) A low level on this pin transfers the contents of the ST16C650 data bus to the CPU.                                                                                                                                                                                                                                                                               |

| Symbol      | Pin | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A3/IOR      | 25  | 1           | Address line 3 or Read strobe (dual function). When PC mode is selected, this pin is used as 4th address line to decode the standard COM1-4 ports. During STD mode operation this pin is used as Read strobe. Same as IOR*, but it is used as active high Read strobe. Note that only an active IOR* or IOR input is required to transfer data from ST16C650 to CPU during read operation.   |
| DDIS*/LPT2* | 26  | 0           | Drive disable or LPT2 decoded address (278 Hex) (dual function). (active low) This pin goes low when the CPU is reading data from the ST16C650 to disable the external transceiver or logic's during STD mode. During PC mode, LPT2 address is decoded.                                                                                                                                      |
| IRQC/TXRDY  | 27  | O           | IRQ-C Interrupt (three state) or Transmit ready (dual function). Three state interrupt output during PC mode and Transmit ready during STD mode. When STD mode is selected this pin goes high when the transmit FIFO of the ST16C650 is full. See INTA/INT description for IRQ-C operation.                                                                                                  |
| AEN*/AS*    | 28  | . [         | Address enable or Address strobe (dual function). During PC mode operation Valid COM 1-4 ports are decoded when this pin goes low. A low on this pin During STD mode latches the state of the chip selects and addressed register (A2-A0). This input is used when signals are not stable for the duration of a read or write operation. If not required, tie the AS* input permanently low. |
| A2          | 29  | 1           | Address select line 2. To select internal registers.                                                                                                                                                                                                                                                                                                                                         |
| A1          | 30  | 1           | Address select line 1. To select internal registers.                                                                                                                                                                                                                                                                                                                                         |
| A0          | 31  | ı           | Address select line 0. To select internal registers.                                                                                                                                                                                                                                                                                                                                         |
| IRQB/RXRDY* | 32  | 0           | IRQ-B Interrupt (three state) or Receive ready (dual function). Three state interrupt output during PC mode and Receive ready during STD mode. During the STD mode operation this pin goes low when the receive FIFO is full. See INTA/INT description for IRQ-B operation.                                                                                                                  |

# ST16C650

| Symbol   | Pin                                     | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|-----------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IRQA/INT | 33                                      | Ο           | IRQ-A Interrupt (normal, three state or open source) or Interrupt output (triple function active high). During PC mode operation, this pin is activated when MCR Bit-3 is set to "1" and enabled by the interrupt enable register. whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected. During the STD mode operation three state mode is disabled and functions as active IRQ-A. Multiple ST16C650 interrupts can be connected to form a wired "Ored" function by setting the MCR bit-5 to "1" and connecting a 450 $\Omega$ resistor to ground. |
| SEL      | 34                                      | <b>1</b>    | Mode select (pulled-up). PC mode is selected by tying this pin to GND and STD mode is selected when this pin is left open or tied to VCC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| S3/OP2*  | 35                                      | 1/0         | Select-3 or User defined output (dual function). ComPort address select 1-4 when PC mode is selected and general purpose output when STD mode is selected. See bit-3 modem control register (MCR bit-3).                                                                                                                                                                                                                                                                                                                                                                                                        |
| RTS*     | 36 - 36 - 36 - 36 - 36 - 36 - 36 - 36 - | 0           | Request to send. (active low) To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation it is not enabled via EFR Bit-6.                                                                                                                                                                                                                                                                |
| DTR*     | 37                                      | 0           | Data terminal ready. (active low) To indicate that ST16C650 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation.                                                                                                                                                                                                      |
| OP1*     | 38                                      | <b>O</b>    | User defined output. See bit-2 of modem control register (MCR bit-2).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| RESET    | 39                                      | 1           | Master reset. (active high) A high on this pin will reset all the outputs and internal registers. The transmitter output and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

## SYMBOL DESCRIPTION

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                                                                    |
|--------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |     | :           | the receiver input will be disabled during reset time.                                                                                                                                                                             |
| стѕ*   | 40  | l           | Clear to send. (active low) The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation if it is not enabled via EFR Bit-7. |
| DSR*   | 41  | . 1         | Data set ready. (active low) A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                                                    |
| CD*    | 42  | 1           | Carrier detect. (active low) A low on this pin indicates the carrier has been detected by the modem.                                                                                                                               |
| RI*    | 43  | I           | Ring detect indicator. (active low) A low on this pin indicates the modem has received a ringing signal from telephone line.                                                                                                       |
| vcc    | 44  | j .         | Power supply input.                                                                                                                                                                                                                |

## **DESCRIPTION OF NEW FEATURES**

The ST16C650 is designed to upgrade the existing 16C550 market. It provides additional features to reduce the software over-head, external glue logic, operating and stand-by current, and maintain the 16C550 software compatibility with existing software's.

After reset ST16C650 is down-ward compatible with ST16C450 and ST16C550 except it provides 32 bytes of data FIFO ( when ST16C550 mode is enabled ) instead of 16 bytes. All other additional features are available through special function register. The 40 pin Dip package offers the software/Hardware flow control, sleep mode, selectable transmit trigger levels, and two selectable baud rate generators. The 44 pin

PLCC package offers all the above features with selectable dual foot print (direct PC connect), two additional three state interrupt lines, and one selectable open source interrupt output to "Or" other ST16C650 interrupt outputs to reduce the number of interrupt lines.

When direct PC mode is selected (44 pin PLCC package only), the external glue logic which is used to decode the COM-1 (3F8-3FF), COM-2 (2F8-2FF), COM-3 (3E8-3EF), and COM-4 (2E8-2EF) and select the proper interrupt lines have been implemented within the ST16C650. The ST16C650 provides Three selectable pins to select the desired ports and interrupts for automatic configurations. In addition to these

addresses the ST16C650 decodes two additional addresses for LPT-1 (378-37F, printer port-1), and LPT-2 (278-27F, printer port-2) via OP2 and Baudout pins. These address decodes are used for IBM PC or compatible computers serial and parallel ports. During Direct connect mode all three interrupts functions are three state interrupts, to activate the interrupts MCR bit-3 should be set to "1".

## **FUNCTIONAL DESCRIPTIONS**

The 32 bytes data FIFO's are enabled when user writes to the ST16C550/ST16C650 FIFO control register. With standard 16C550 parts, the user can only set receive trigger levels but not transmit trigger level. The ST16C650 provides independent trigger levels for both receiver and transmitter. To be compatible with ST16C550, 16 bytes transmit trigger level is selected after reset. Note that user can write to transmit trigger levels but activation will not take place till ST16C650 special mode is selected (EFR bit-4 is set to "1"). The ST16C650 is designed to work with high speed modems and shared network environments, that requires fast processing time. By increasing number of characters in the FIFO, networking units can handle more data within same time. Example: ST16C550 with 16 bytes of data, 115.2k and 8 bits wide word and one stop bit, will take 1.52 ms to transmit 16 bytes of data. But with 32 bytes of data buffer it will take 3.05 ms. This will gives additional time for the CPU to process other applications and reduce the interrupt servicing time.

The contents of the Xon-1,2 and Xoff 1,2 are not reset to any given values and user can write any values desired for software flow controls. Different conditions can be set to detect Xon/Xoff characters or start/stop the transmissions. See the table for all possible conditions. When single Xon/Xoff characters are selected, ST16C650 compares the incoming data with these values and controls the transmission, these characters are not stacked in data buffer or FIFO. Special case is provided to detect the special character and stack it into the data buffer or FIFO. These conditions are selected via Enhanced Feature Register (EFR bit 0-3).

Hardware flow control can be selected when either or both bits of the EFR bit 6-7 are set to "1". When auto CTS is selected, the ST16C650 will stop the transmission as soon as a complete character is transmitted and CTS input level is high. Transmission is resumed after CTS input changes to low level.

RTS pin will be forced to high state regardless of it's original state when receive FIFO reaches to the programmed trigger level. RTS pin resumes it original state after content of the data buffer (FIFO) drops below the programmed trigger level. Both hardware and software flow controls can be enabled for automatic operation. During these conditions the ST16C650 will accept additional data to fill the unused transmit and receive FIFO locations

Special interrupt modes have been added to monitor the hardware and software flow conditions. These are the IER bits 5-7.

The ST16C650 is designed to operate with low power consumption, special sleep mode has been added to stop the clock and reduce the power consumption when it is not used (Green PC). When EFR bit-4 and IER bit-4 are enabled (set to "1"), the ST16C650 enters into sleep mode and resumes it's normal operation when a data is received or state of the modem input pins changes or it is set to transmit data. The ST16C650 stays in this mode till it is disabled.

Special care should be considered for the following interrupt conditions and handling them. After reset if transmitter interrupt is enabled, ST16C650 will issue an interrupt to indicate that transmit holding register is empty, no other interrupts will be issued after enabling the interrupt. The LSR register has highest interrupt priority and CTS, RTS have lowest interrupt priority. The interrupt status register will show the highest interrupt priority condition, and after servicing the interrupt condition next priority interrupt level will be shown. There are two interrupt conditions that have same priority and it is important to know the conditions to service. Receive data ready and receive time out share the same priority with one additional bit (IER bit-3). Receiver issues interrupt after number of characters are reached the programmed trigger level, in this case the ST16C650 FIFO holds equal or more characters than the trigger level. After reading block of data, user can check the LSR bit-0 for additional characters. If number of characters in the receive data register did not reach to programmed trigger level within certain time frame, ST16C650 will issue receive data ready interrupt with ISR bit-3 set to "1".

Note that, receive time out is functional only in ST16C550/650 mode. Receive time out will not occur if the receive FIFO is empty. The time out counter will be reset at the center of each stop bit received or each time receive holding register is read. The actual time out value is T ( Time out length in bits)= 4 X P ( Programmed word length) + 12. To convert time out value to a character value, user has to divide this number to its complete word length + parity ( if used) + number of stop bits and start bit.

Example -A: If user programs the word length = 7, and no parity and one stop bit, Time out will be:  $T = 4 \times 7$  (programmed word length) +12 = 40 bits Character time = .40 / 9 [ (programmed word length = 7) + (stop bit = 1) + (start bit = 1)] = 4.4 characters.

Example -B: If user programs the word length = 7, with parity and one stop bit, the time out will be:  $T = 4 \times 7$ (programmed word length) + 12 = 40 bits Character time = 40 / 10 [ (programmed word length = 7) + (parity = 1) + (stop bit = 1) + (start bit = 1) = 4 characters.

Due to number of active simultaneous interrupt limitations in PC and compatibles, ST16C650 offers share interrupt out by setting MCR bit-5 to "1". If this mode is selected, it is required to connect 200-500 ohm resistor between the INTA pin to Ground. Note that other interrupts (INTB, INTC) will be inactive during this mode.

Dual baud rate generator is provided to maintain the 16C550 compatibility and provide higher data rate when it is needed. Example 14.4k to 19.2k modems requires to have 57k to 115.2k data rate and 28.8k modem requiems to have 230.4K. The 16C550 compatible parts can only offer 115.2k to maintain the software compatibility. The ST16C650 utilizes 7.32 MHz crystal/clock and provide 16C550 compatible data rate and higher. ST16C550 and ST16C650 baud

rate generator tables can be selected is setting and resetting the MCR bit-7.

The ST16C650 transmit trigger level, provides additional flexibility to the user for block mode operation. In ST16C550/650 mode LSR bits 5-6 gives indication that transmitter is empty or not, but there is no mechanism to identify FIFO full state or available empty locations in FIFO. User can select one of the two possible ways to operate the transmit and receive FIFO by utilizing the DMA mode (FCR bit-3). When FIFO's are enabled and DMA mode "0" is selected, the ST16C650 sets the interrupt bit and activates interrupt output pin for single transmit and receive operation like ST16C450 mode except it can receive and transmit 32 bytes of characters. When DMA mode "1" is activated, user takes the advantage of the block mode operation. In this mode, transmitter/receiver sets the interrupt flag and interrupt output pin, when characters in the FIFO are below the transmit trigger level or over receive trigger level. Note that since ST16C550 does not have transmit trigger levels, the default trigger level in the ST16C650 is set to 16 bytes (trigger level "0" ).

# ST16C650

# **PROGRAMMING TABLE**

| A2 | <b>A</b> 1 | A0 | READ MODE                 | WRITE MODE                |
|----|------------|----|---------------------------|---------------------------|
| 0  | 0          | 0  | Receive Holding Register  | Transmit Holding Register |
| 0  | 0          | 1  |                           | Interrupt Enable Register |
| 0  | 1          | 0  | Interrupt Status Register | FIFO Control Register     |
| 0  | 1.         | 1  |                           | Line Control Register     |
| 1  | 0          | 0  | ·                         | Modem Control Register    |
| 1  | 0          | 1  | Line Status Register      |                           |
| 1  | 1          | 0  | Modem Status Register     |                           |
| 1  | 1          | 1  | Scratchpad Register       | Scratchpad Register       |
| 0  | 0          | 0  | LSB of Divisor Latch      | LSB of Divisor Latch      |
| 0  | 0          | 1  | MSB of Divisor Latch      | MSB of Divisor Latch      |
| 0  | 1          | 0  | Enhanced Feature Register | Enhanced Feature Register |
| 1  | 0          | 0  | Xon-1 Word                | Xon-1 Word                |
| 1  | Ö          | 1  | Xon-2 Word                | Xon-2 Word                |
| 1  | 1          | 0  | Xoff-1 Word               | Xoff-1 Word               |
| 1  | 1          | 1  | Xoff-2 Word               | Xoff-2 Word               |

These registers are accessible only when LCR bit-7 is set to "1". Enhanced Feature Register is accessible only when LCR is set to "FF"

# **ST16C650 ACCESSIBLE REGISTERS**

| A2 | A1 | ΑO | Register | BIT-7                      | BIT-6                    | BIT-5                      | BIT-4                                                | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----|----|----|----------|----------------------------|--------------------------|----------------------------|------------------------------------------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0  | 0  | 0  | RHR      | bit-7                      | bit-6                    | bit-5                      | bit-4                                                | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 0  | THR      | bit-7                      | bit-6                    | bit-5                      | bit-4                                                | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 1  | IER      | 0/<br>CTS<br>interrupt     | 0/<br>RTS<br>interrupt   | 0/<br>Xoff<br>interrupt    | 0/<br>Sleep<br>mode                                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0  | 1  | 0  | FCR      | RCVR<br>trigger<br>(MSB)   | RCVR<br>trigger<br>(LSB) | 0/TX<br>trigger<br>(MSB)   | 0/TX<br>trigger<br>(LSB)                             | DMA<br>mode<br>select        | XMIT<br>FIFO<br>reset                  | RCVR<br>FIFO<br>reset           | FIFO<br>enable                 |
| 0  | 1  | 0  | ISR      | 0/<br>FIFO's<br>enabled    | 0/<br>FIFO's<br>enabled  | 0/<br>RTS,<br>CTS          | 0/<br>Xoff                                           | int<br>priority<br>bit-2     | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0  | 1  | 1  | LCR      | divisor<br>latch<br>enable | set<br>break             | set<br>parity              | even<br>parity                                       | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1  | 0  | 0  | MCR      | Clock<br>select            | 0/<br>IRRT<br>enable     | INTA<br>type<br>select     | loop<br>back                                         | OP2*/<br>IRQx<br>enable      | OP1*                                   | RTS*                            | DTR*                           |
| 1  | 0  | 1  | LSR      | 0/<br>FIFO<br>error        | trans.<br>empty          | trans.<br>holding<br>empty | break<br>interrupt                                   | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1  | 1  | 0  | MSR      | CD                         | RI                       | DSR                        | стѕ                                                  | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1  | 1  | 1  | SPR      | bit-7                      | bit-6                    | bit-5                      | bit-4                                                | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 0  | DLL      | bit-7                      | bit-6                    | bit-5                      | bit-4                                                | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 1  | DLM      | bit-15                     | bit-14                   | bit-13                     | bit-12                                               | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |
| 0  | 1  | 0  | EFR      | Auto<br>CTS                | Auto<br>RTS              | Special<br>Char.<br>select | Enable IER Bits 4-7, ISR, FCR Bits 4-5, MCR Bits 5,7 | Cont-3<br>Tx,Rx<br>Control   | Cont-2<br>Tx,Rx<br>Control             | Cont-1<br>Tx,Rx<br>Control      | Cont-0<br>Tx,Rx<br>Control     |

These registers are accessible only when LCR bit-7 is set to "1". <u>Enhanced Feature Register is accessible only when LCR is set to "FF"</u>

### REGISTER FUNCTIONAL DESCRIPTIONS

#### OPERATING MODE.

The ST16C650 provides pin selectable interface for existing 16C550 and new designs.

PC mode can be selected by tying the SEL pin to GND. When PC mode is selected the ST16C650 eliminates the external address decode logic (glue logic) for COM1-4 and jumper setting for IRQ3, IRQ4 or IRQn. The ST16C650 can be configured as follows:

| S3 S2 S1 | Address | ComPort | IRQ    |
|----------|---------|---------|--------|
| 0 0 0    | 3F8-3FF | COM-1   | IRQB** |
| 0 0 1    | 2F8-2FF | COM-2   | IRQC** |
| 0 1 0    | 3E8-3EF | COM-3   | IRQB** |
| 0 1 1    | 2E8-2EF | COM-4   | IRQC** |
| 1 0 0    | 3F8-3FF | COM-1   | IRQA** |
| 1 0 1    | 2F8-2FF | COM-2   | IRQA** |
| 1 1 0    | 3E8-3EF | COM-3   | IRQA** |
| 1 1 1    | 2E8-2EF | COM-4   | IRQA** |

<sup>\*\*</sup> All interrupt outputs are inactive (three state mode) except the selected address.

#### TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going

noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

#### FIFO INTERRUPT MODE OPERATION

When the receive FIFO (FCR BIT-0=1) and receive interrupts (IER BIT-0=1) are enabled, receiver interrupt will occur as follows:

- A) The receive data available interrupts will be issued to the CPU when the FIFO has reached its programmed trigger level; it will be cleared as soon as the FIFO drops below its programmed trigger level.
- B) The ISR receive data available indication also occurs when the FIFO trigger level is reached, and like the interrupt it is cleared when the FIFO drops below the trigger level.
- C) The data ready bit (LSR BIT-0) is set as soon as a character is transferred from the shift register to the receiver FIFO. It is reset when the FIFO is empty.

#### FIFO POLLED MODE OPERATION

When FCR BIT-0=1; resetting IER BIT 3-0 to zero puts the ST16C650 in the FIFO polled mode of operation. Since the receiver and transmitter are controlled separately either one or both can be in the polled mode operation by utilizing the Line Status Register.

- A) LSR BIT-0 will be set as long as there is one byte in the receive FIFO.
- B) LSR BIT4-1 will specify which error(s) has occurred.
- C) LSR BIT-5 will indicate when the transmit FIFO is empty.
- D) LSR BIT-6 will indicate when both transmit FIFO and transmit shift register are empty.
- E) LSR BIT-7 will indicate when there are any errors in the receive FIFO.

## PROGRAMMABLE BAUD RATE GENERATOR

The ST16C650 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-24 MHz and dividing it by any divisor from 1 to 2<sup>16</sup> -1. The output frequency of the Baud-out\* is equal to 16X of transmission baud rate (Baud-out\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

# BAUD RATE GENERATOR PROGRAMMING TABLE (7.372 MHz CLOCK):

| BAUD RATE<br>MCR<br>BIT-7=1 | BAUD RATE<br>MCR<br>Bit-7=0 | 16 x CLOCK<br>DIVISOR<br>"Decimal" |
|-----------------------------|-----------------------------|------------------------------------|
| 50                          | 200                         | 2304                               |
| 75                          | 300                         | 1536                               |
| 150                         | 600                         | 768                                |
| 300                         | 1200                        | 384                                |
| 600                         | 2400                        | 192                                |
| 1200                        | 4800                        | 96                                 |
| 2400                        | 9600                        | 48                                 |
| 4800                        | 19.2K                       | 24                                 |
| 7200                        | 28.8K                       | 16                                 |
| 9600                        | 38.4k                       | 12                                 |
| 19.2K                       | 76.8k                       | 6                                  |
| 38.4K                       | 153.6k                      | 3                                  |
| 57.6K                       | 230.4k                      | 2                                  |
| 115.2K                      | 460.8k                      | 1 1                                |

#### HARDWARE FLOW CONTROL OPERATION.

When hardware flow control operation is enabled, the ST16C650 monitors the CTS\* pin for transmit operation and receiver trigger level for RTS\* operation. When CTS\* changes state from low to high, the ST16C650 suspends the transmission operation as soon as complete character is transmitted. ISR bit-5 will be set (if enabled via IER bit 6-7). Transmission will resume as soon as CTS\* pin goes low. RTS\* pin will be forced to high state when receiver FIFO

reached to the programmed trigger level. RTS\* will go low when Receive Holding Register is below next lower trigger level. The ST16C650 will accept additional data when transmission is suspended during hardware flow control till all locations are filled.

#### SOFTWARE FLOW CONTROL

When software flow control operation is enabled, the ST16C650 will compare the two sequential receive data with Xoff-1.2 programmed characters. When these characters matched correctly, the ST16C650 will halt the transmission after finishing the transmission of the complete character. The receive ready, Xoff (if enabled via IER bit-5) flags will be set and the interrupt output pin (if receive interrupt is enabled) will be activated. After the recognition of the Xoff characters the ST16C650 will compare next two incoming characters with Xon-1,2 characters. The ST16C650 will resume the operation and clear the flags (ISR bit-4) when Xon characters are received. The ST16C650 will send Xoff-1,2 characters as soon as received data passed the programmed trigger level. The ST16C650 will transmit programmed Xon-1,2 characters as soon as receive data reached to the next lower trigger level.

## INTERRUPT ENABLE REGISTER (IER)

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the INT output pin.

#### IER BIT-0:

0= disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

#### IER BIT-1:

0= disable the transmitter empty interrupt. 1= enable the transmitter empty interrupt.

### IER BIT-2:

0= disable the receiver line status interrupt.1= enable the receiver line status interrupt.

#### IER BIT-3:

0= disable the modem status register interrupt.

1= enable the modern status register interrupt.

## IER BIT -4:

0= disable sleep mode.

1= enable sleep mode. The ST16C650 enters into power down mode and external clock or oscillator ciruit is disabled. Any change of state on the RX, RI\*, CTS\*, DSR\*, and CD\* pins start the ST16C650. The ST16C650 will not lose the programmed bits when sleep mode is activated or deactivated. The ST16C650 will not enter in sleep mode if any interrupt is pending.

#### IER BIT-5:

0= disable the received Xoff interrupt.

1= enable the received Xoff interrupt. The ST16C650 issues an interrupt when Xoff characters are received and correctly matched with Xoff 1,2 words.

#### IER BIT-6:

0= disable the RTS interrupt.

1= enable the RTS interrupt. The ST16C650 issues interrupt when RTS pin changes state from low to high.

#### IER BIT-7:

0= disable the CTS interrupt.

1= enable the CTS interrupt. The ST16C650 issues interrupt when CTS pin changes state from low to high.

## **INTERRUPT STATUS REGISTER (ISR)**

The ST16C650 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C650 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

## **Priority level**

| P                               | D5                    | D4                         | D3                         | D2                    | D1                         | D0     | Source of the interrupt                                                                                                                                                                                                                      |
|---------------------------------|-----------------------|----------------------------|----------------------------|-----------------------|----------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>2<br>2<br>3<br>4<br>5<br>6 | 0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>1<br>0 | 0<br>0<br>1<br>0<br>0<br>0 | 1<br>1<br>0<br>0<br>0 | 1<br>0<br>0<br>1<br>0<br>0 | 000000 | LSR (Receiver Line Status Register) RXRDY (Received Data Ready) RXRDY (Receive Data time out) TXRDY(Transmitter Holding Register Empty) MSR (Modem Status Register) RXRDY (Received Xoff signal)/ Special character CTS, RTS change of state |

#### ISR BIT-0:

0= an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1= no interrupt pending.

#### **ISR BIT 1-3:**

Logical combination of these bits, provides the highest priority interrupt pending.

#### ISR BIT 4-5:

These bits are enabled when FER bit-1 is set to "1". ISR bit-4 indicates that matching Xoff characters have been detected. ISR bit-5 indicates that CTS, RTS have been receiced or issued. Note that the ISR bit-4 will stay "1" till Xon characters are received.

#### **ISR BIT 6-7:**

These bits are not used and are set to zero in ST16C450 mode. BIT 6-7: are set to "1" in ST16C650 mode.

## FIFO CONTROL REGISTER (FCR)

This register is used to enable the FIFOs, clear the FIFOs, set the receiver FIFO trigger level, and select the type of DMA signaling.

#### FCR BIT-0:

0= disable the transmit and receive FIFO. 1= enable the transmit and receive FIFO. This bit should be enabled before setting the FIFO trigger levels.

#### FCR BIT-1:

#### 0= No change.

1= Clears the contents of the receive FIFO and resets its counter logic to 0 (the receive shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-2:

0= No change.

1= Clears the contents of the transmit FIFO and resets its counter logic to 0 (the transmit shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-3:

0= No change.

1= Changes RXRDY and TXRDY pins from mode "0" to mode "1".

#### Transmit operation in mode "0":

When ST16C650 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) when there are no characters in the transmit FIFO or transmit holding register, the TXRDY\* pin will go low. Once active the TXRDY\* pin will go high (inactive) after the first character is loaded into the transmit holding register.

### Receive operation in mode "0":

When ST16C650 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) and there is at least 1 character in the receive FIFO, the RXRDY\* pin will go low. Once active the RXRDY\* pin will go high (inactive) when there are no more characters in the receiver.

#### Transmit operation in mode "1":

When ST16C650 is in FIFO mode (FCR bit-0=1, FCR bit-3=1) the TXRDY\* pin will become high (inactive) when the transmit FIFO is completely full. It will be low if one or more FIFO locations are empty.

#### Receive operation in mode "1":

When ST16C650 is in FIFO mode (FCR bit-0=1, FCR bit-3=1) and the trigger level or the time-out has been reached, the RXRDY\* pin will go low. Once it is activated it will go high (inactive) when there are no more characters in the FIFO.

#### **FCR BIT 4-5:**

These bits are used to set the trigger level for the transmit FIFO interrupt. The ST16C650 will issue a transmit empty interrupt when number of characters in FIFO drops below the selected trigger level.

| BIT-5 | BIT-4 | FIFO trigger level |
|-------|-------|--------------------|
| 0     | 0     | 16                 |
| 0     | 1     | 8                  |
| 1     | . 0   | 24                 |
| 1     | 1     | 30                 |

#### **FCR BIT 6-7:**

These bits are used to set the trigger level for the receiver FIFO interrupt.

| BIT-6 | FIFO trigger level |
|-------|--------------------|
| 0     | 8                  |
| 1     | 16                 |
| 0     | 24                 |
| 1     | 28                 |
|       | 0<br>1<br>0<br>1   |

## LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

### LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 | BIT-0 | Word length |
|-------|-------|-------------|
| 0     | 0     | 5           |
| 0     | 1     | 6           |
| 1     | 0     | 7           |
| 1     | 1     | 8           |

#### LCR BIT-2:

The number of stop bits can be specified by this bit.

| BIT-2 | Word length | Stop bit(s) |
|-------|-------------|-------------|
| 0     | 5,6,7,8     | 1           |
| 1     | 5           | 1-1/2       |
| 1     | 6,7,8       | 2           |

#### LCR BIT-3:

Parity or no parity can be selected via this bit.

0= no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

## LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0= ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format.

### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

## LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0= normal operating condition.

1= forces the transmitter output (TX) to go low to alert the communication terminal.

#### LCR BIT-7:

The internal baud rate counter latch and Enhance Feature mode enable (DLAB).

0= normal operation.

1= Divisor latch and Enhanced Feature register enable.

## MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

#### MCR BIT-0:

0= force DTR\* output to high. 1= force DTR\* output to low.

#### MCR BIT-1:

0= force RTS\* output to high. 1= force RTS\* output to low.

RTS\* is used as hardware flow control signal when enabled via EFR bit-6. RTS\* goes high when FIFO is reached to the selected trigger level and goes low as soon as content of the receive holding register is below the trigger level. Content of this register changes with state of the hardware flow control. functions normally when hardware flow control is disabled.

#### MCR BIT-2:

0= set OP1\* output to high. 1= set OP1\* output to low.

#### MCR BIT-3:

0= set OP2\* output to high (STD mode). Forces INTx outputs to three state mode during PC mode selection.
1= set OP2\* output to low (STD mode). Sets the INTx outputs to active mode during PC mode selection

## MCR BIT-4:

0= normal operating mode.

1= enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, OP1\* and OP2\* are connected to modem control inputs. In this mode , the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER

#### MCR BIT-5:

0= Active or three state interrupt output.

1= Open source interrupt output. Required external

resistor from this pin to ground. This mode is provided for share interrupts.

#### MCR BIT-6:

0= Standard UART receive and transmit input / output.
1= Infrared receive and transmit input / output.

#### MCR BIT-7:

0= Normal or divide by one clock input. Standard ST16C550 baud rates can be selected when this bit is set to "0" and 1.8432 MHz crystal is used.

1= Divide by four clock input. Standard ST16C550 baud rates can be selected when this bit is set to "1" and 7.372 MHz crystal is used.

#### LINE STATUS REGISTER (LSR)

This register provides the status of data transfer to CPU.

#### LSR BIT-0:

0= no data in receive holding register or FIFO. 1= data has been received and saved in the receive holding register or FIFO.

#### LSR BIT-1:

0= no overrun error (normal).

1= overrun error, next character arrived before receive holding register was emptied or if FIFOs are enabled, an overrun error will occur only after the FIFO is full and the next character has been completely received in the shift register. Note that character in the shift register is overwritten, but it is not transferred to the FIFO.

#### LSR BIT-2:

0= no parity error (normal).

1= parity error, received data does not have correct parity information. In the FIFO mode this error is associated with the character at the top of the FIFO.

#### LSR BIT-3:

0= no framing error (normal).

1=framing error received, received data did not have a valid stop bit. In the FIFO mode this error is associated with the character at the top of the FIFO.

3

#### LSR BIT-4:

0= no break condition (normal).

1= receiver received a break signal (RX was low for one character time frame). In FIFO mode, only one zero character is loaded into the FIFO.

#### LSR BIT-5:

It indicates that the ST16C650 is ready to accept a new character for transmission. In addition, it causes the ST16C650 to issue an interrupt to the CPU when the transmit holding register empty interrupt enable is set.

0= transmit holding register is not empty.

1= transmit holding register (or FIFO) is empty. CPU can load the next characters. When this bit is set, CPU can load upto 32 bytes of data to the ST16C650.

#### LSR BIT-6:

0= transmitter holding and shift registers are full.
1= transmitter holding and shift registers are empty.
In FIFO mode this bit is set to one whenever the transmitter FIFO and transmit shift register are empty.

#### LSR BIT-7:

0= normal.

1= at least one parity error, framing error or break indication in the FIFO. This bit is cleared when LSR is read.

## MODEM STATUS REGISTER (MSR)

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

#### MSR BIT-0:

Indicates that the CTS\* input to the ST16C650 has changed state since the last time it was read.

#### MSR BIT-1:

Indicates that the DSR\* input to the ST16C650 has changed state since the last time it was read.

#### MSR BIT-2:

Indicates that the RI\* input to the ST16C650 has changed from a low to a high state.

#### MSR BIT-3:

Indicates that the CD\* input to the ST16C650 has changed state since the last time it was read.

#### MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

CTS\* functions as hardware flow control signal input if it is enabled via EFR bit-7. Transmit holding register is gated with this input to start/stop the transmission. A high at this pin will stop the transmission as soon as complete character is transmitted.

### MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

#### MSR BIT-6:

This bit is equivalent to OP1 in the MCR during local loop-back mode. It is the compliment of the RI\* input.

#### MSR BIT-7:

This bit is equivalent to OP2 in the MCR during local loop-back mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated.

#### SCRATCHPAD REGISTER (SR)

ST16C650 provides a temporary data register to store 8 bits of information for variable use.

#### **ENHANCED FEATURE REGISTER (EFR)**

Enhanced Features can be Enable/Disabled via this register.

#### **EFR BIT 0-3:**

Combinations of software flow control can be selected by programming this bits.

| Cont-3 | Cont-2 | Cont-1 | Cont-0 | Tx, Rx saftware flow controls                     |
|--------|--------|--------|--------|---------------------------------------------------|
| 0      | 0      | Х      | Х      | No transmit flow control                          |
| 1      | 0      | Х      | X      | Transmit Xon1, Xoff1                              |
| 0      | 1      | Х      | Χ      | Transmit Xon2, Xoff2                              |
| 1      | 1      | Х      | X      | Transmit Xon1 and Xon2 : Xoff1, Xoff2             |
| Χ      | Χ      | 0      | 0      | No receive flow control                           |
| Х      | Х      | 1      | 0      | Receiver compares Xon1, Xoff1                     |
| Х      | Χ      | 0      | 1      | Receiver compares Xon2, Xoff2                     |
| 1      | 0      | 1      | 1      | Transmit Xon1, Xoff1.                             |
| ·      |        |        |        | Receiver compares Xon1 or Xon2,                   |
|        |        |        |        | Xoff1 or Xoff2                                    |
| 0      | 1      | 1      | 1      | Transmit Xon2, Xoff2                              |
|        |        |        |        | Receiver compares Xon1 or Xon2,                   |
|        |        |        |        | Xoff1 or Xoff2                                    |
| 1      | 1      | 1      | 1      | Transmi Xon1 and Xon2 : Xoff1 and Xoff2           |
|        |        |        |        | Receiver compares Xon1 and Xon2 : Xoff1 and Xoff2 |
| 0      | 0      | 1      | 1      | No transmit flow control                          |
|        |        |        |        | Receiver compares Xon1 and Xon2 : Xoff1 and Xoff2 |
|        |        |        |        |                                                   |

#### EFR BIT-4:

Enhanced interrupt control bit.

0= disables the IER bits 4-7 and ISR bits 4-5. Standard ST16C550 mode.

1= enables the enhanced interrupt functions.

## EFR BIT-5:

0= Normal.

1= Special character detect. ST16C650 compares the incoming receive data with Xoff-2 data. Up on correct match, the received data will be transferred to FIFO

and ISR Bit-4 will be set to indicate detection of special character.

#### EFR BIT-6:

RTS\* flow control.

0 = Normal. RTS\* flow control is disabled. Standard ST16C550 mode.

1 = RTS pin goes high when receive FIFO's are reach to the programmed trigger level.

### EFR Bit-7:

CTS\* flow control.

- 0 = Normal. CTS\* flow control mode is disabled. Standard ST16C550 mode.
- 1 = Transmission is resumed when low input signal is detected on the CTS\* pin.

#### ST16C650 EXTERNAL RESET CONDITION

| REGISTERS | RESET STATE                 |
|-----------|-----------------------------|
| IER       | IER BITS 0-7=0              |
| ISR       | ISR BIT-0=1, ISR BITS 1-7=0 |
| LCR       | LCR BITS 0-7=0              |
| MCR       | MCR BITS 0-7=0              |
| LSR       | LSR BITS 0-4=0,             |
|           | LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR       | MSR BITS 0-3=0,             |
| 1         | MSR BITS 4-7= input signals |
| FCR       | FCR BITS 0-7=0              |
| FER       | FER BITS 0-7=0              |

| SIGNALS | RESET STATE                             |
|---------|-----------------------------------------|
| TX      | High                                    |
| OP1*    | High                                    |
| OP2*    | High                                    |
| RTS*    | High                                    |
| DTR*    | High                                    |
| RXRDY*  | High (STD mode),/ Three state (PC mode) |
| TXRDY*  | High (STD mode) / Three state (PC mode) |
| IRQn/NT | Low (STD mode) / Three state (PC mode)  |



# **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                                                  | Parameter                                    | Limits |     |                   | Units    | Conditions            |  |
|-----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|--------|-----|-------------------|----------|-----------------------|--|
| •                                                                                                                                       |                                              | Min    | Тур | Max               |          |                       |  |
|                                                                                                                                         | Olaski kish sa kasada saka                   |        | Ι   |                   |          | ·                     |  |
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>4</sub> T <sub>6</sub> T <sub>7</sub> T <sub>8</sub> T <sub>9</sub> T <sub>11</sub> | Clock high pulse duration                    | 50     |     |                   | ns       | Fr. dans all alle als |  |
| 12                                                                                                                                      | Clock low pulse duration                     | 50     |     | 46                | ns       | External clock        |  |
| <u>1</u> 3                                                                                                                              | Clock rise/fall time                         | }      |     | 10                | ns       |                       |  |
| <u> </u> 4                                                                                                                              | Baud out rise/fall time                      |        |     | 100               | ns       | 100 pF load           |  |
| 15                                                                                                                                      | Address strobe width                         | 30     |     |                   | ns       |                       |  |
| 16                                                                                                                                      | Address setup time                           | 30     |     |                   | ns       |                       |  |
| $T_7$                                                                                                                                   | Address hold time                            | 5      | 1   |                   | ns       |                       |  |
| T <sub>8</sub>                                                                                                                          | Chip select setup time                       | 5      |     |                   | ns       |                       |  |
| $T_{g}$                                                                                                                                 | Chip select hold time                        | 0      |     |                   | ns       |                       |  |
| T <sub>11</sub>                                                                                                                         | IOR* to DDIS* delay                          |        |     | 25                | ns       | 100 pF load           |  |
| T.,                                                                                                                                     | Data setup time                              | 15     |     |                   | ns       | Note: 1               |  |
| 13                                                                                                                                      | Data hold time                               | 15     |     |                   | ns       | Note: 1               |  |
|                                                                                                                                         | IOW* delay from chip select                  | 10     |     |                   | ns       | Note: 1               |  |
| T,5                                                                                                                                     | IOW* strobe width                            | 50     | 1   |                   | ns       |                       |  |
| T <sub>16</sub>                                                                                                                         | Chip select hold time from IOW*              | 0      |     |                   | ns       | Note: 1               |  |
| T <sub>17</sub>                                                                                                                         | Write cycle delay                            | 55     |     |                   | ns       |                       |  |
| Tw                                                                                                                                      | Write cycle=T <sub>15</sub> +T <sub>17</sub> | 105    |     |                   | ns       |                       |  |
| T <sub>19</sub>                                                                                                                         | Data hold time                               | 15     |     | 25                | ns       | 15.1                  |  |
| T <sub>21</sub>                                                                                                                         | IOR* delay from chip select                  | 10     |     |                   | ns       | Note: 1               |  |
| 1 22                                                                                                                                    | IOR* strobe width                            | 65     |     |                   | ns       |                       |  |
| T <sub>24</sub>                                                                                                                         | Chip select hold time from IOR*              | 0      |     |                   | ns       | Note: 1               |  |
| T <sub>24</sub><br>T <sub>25</sub><br>Tr                                                                                                | Read cycle delay                             | 55     |     |                   | ns       | ,                     |  |
| Tr̈̃                                                                                                                                    | Read cycle=T <sub>23</sub> +T <sub>25</sub>  | 115    |     |                   | ns       | •                     |  |
| T <sub>26</sub>                                                                                                                         | Delay from IOR* to data                      | }      |     | 35                | ns       | 100 pF load           |  |
| T                                                                                                                                       | Delay from IOW* to output                    | Ì      |     | 50                | ns       | 100 pF load           |  |
| T <sub>28</sub><br>T <sub>29</sub>                                                                                                      | Delay to set interrupt from MODEM            |        |     | 70                | ns       | 100 pF load           |  |
| T <sub>30</sub>                                                                                                                         | Delay to reset interrupt from IOR*           |        |     | 70                | ns       | 100 pF load           |  |
| . 30                                                                                                                                    | input                                        | l      | 1   |                   |          |                       |  |
| т                                                                                                                                       | Delay from stop to set interrupt             |        |     | 1 <sub>RCIk</sub> |          | 100 pF load           |  |
| T <sub>31</sub><br>T <sub>32</sub>                                                                                                      | Delay from IOR* to reset interrupt           |        |     | 200               | ns       | 100 pF load           |  |
| T <sub>33</sub>                                                                                                                         | Delay from initial INT reset to transmit     | 8      |     | 24                | *        | 100 pr 1000           |  |
| * 33                                                                                                                                    | start                                        |        |     | - '               |          |                       |  |
| T <sub>34</sub>                                                                                                                         | Delay from stop to interrupt                 | 1      |     | 100               | ns       |                       |  |
| Τ.                                                                                                                                      | Delay from IOW* to reset interrupt           | 1      |     | 175               | ns       |                       |  |
| T <sub>44</sub>                                                                                                                         | Delay from stop to set RxRdy                 |        |     |                   | 113      |                       |  |
| T <sup>44</sup>                                                                                                                         | Delay from IOR* to reset RxRdy               |        |     | 1 <sub>RCLK</sub> | μS       |                       |  |
| T <sub>45</sub><br>T <sub>46</sub>                                                                                                      | Delay from IOW* to set TxRdy                 |        |     | 195               | μs<br>ns |                       |  |
| T <sub>47</sub>                                                                                                                         | Delay from start to reset TxRdy              |        |     | 8                 | *        | · ·                   |  |
| 47                                                                                                                                      | Boldy from start to reset TXIVUY             |        |     | U                 |          |                       |  |

Note 1: Applicable only when AS\* is tied low

\* = Baud-out\* cycle

# ST16C650

# **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

# DC ELECTRICAL CHARACTERISTICS

 $T_{\Delta}$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| -0.5                             | T                  |                                         |                                 | Conditions                                        |  |
|----------------------------------|--------------------|-----------------------------------------|---------------------------------|---------------------------------------------------|--|
| 3.0<br>-0.5<br>2.2<br>2.4<br>2.7 | 1.2<br>750         | 0.6<br>VCC<br>0.8<br>VCC<br>0.4<br>5.50 | >>>>>                           | I <sub>ol</sub> = 8 mA<br>I <sub>oH</sub> = -8 mA |  |
|                                  | -0.5<br>2.2<br>2.4 | -0.5<br>2.2<br>2.4<br>2.7               | -0.5<br>2.2 0.4<br>2.4 1.2 5.50 | -0.5                                              |  |

## **CLOCK TIMING**



# **BAUDOUT\* TIMING**



ST16C650

# ST16C650

# **GENERAL READ TIMING**





Patent pending

# ST16C650

# MODEM TIMING







# **RXRDY TIMING FOR MODE "0"**











## TXRDY TIMING FOR MODE "1"



# IR TRANSMIT AND RECEICE INPUT/OUTPUT TIMING







Printed September 8, 1994

# DUAL ASYNCHRONOUS RECEIVER/TRANSMITTER WITH PARALLEL PRINTER PORT

#### DESCRIPTION

The ST16C452 is a dual universal asynchronous receiver and transmitter with a bi-directional CENTRONICS type parallel printer port. A programmable baud rate generator is provided to select transmit and receive clock rates from 50Hz to 448kHz. STARTECH ST16C452PS provides additional features to control the printer and direction without entertainty.

STARTECH ST16C452PS provides additional features to control the printer port direction without any additional external logic.

The ST16C452 is an improved version of the VL16C452 UART with higher operating speed and lower access time. The ST16C452 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C452 provides internal loop-back capability for on board diagnostic testing.

The ST16C452 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

## **FEATURES**

- Pin to pin and functional compatible to VL16C452, WD16C452
- Fully compatible with all new bi-directional PS/2 printer port registers.
- Modern control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\*, CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- Independent transmit and receive control
- Software compatible with INS8250, NS16C450
- 448 kHz transmit/receive operation with 7.372 MHz crystal or external clock source.
- Bi-directional hardware/software parallel port
- · Bi-directional I/O ports

## ORDERING INFORMATION

 Part number
 Package
 Operating temperature

 ST16C452CJ68
 PLCC
 0° C to + 70° C

 ST16C452IJ68
 PLCC
 -40° C to + 85° C

# **PLCC Package**



# **BLOCK DIAGRAM**



| Symbol   | Pin   | Signal Type | Pin Description                                                                                                                                                                                                   |
|----------|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7    | 14-21 | 1/0         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted. |
| A0-A2    | 35-33 | . 1         | Address select lines. To select internal registers.                                                                                                                                                               |
| CLK      | 4     | l           | Clock input. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                                                                       |
| BIDEN    | 1     | l .         | Printer direction select. A high puts the parallel port in the input mode for ST16C452AT and software controlled mode (input/output) to ST16C452PS. Allow sets the ST16C452 to output mode.                       |
| IOW*     | 36    | I           | Write strobe (active low). A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                            |
| IOR*     | 37    | l           | Read strobe (active low). A low level on this pin transfers the contents of the ST16C452 data bus to the CPU.                                                                                                     |
| RDOUT    | 44    | 0           | Read select out (active high). This pin goes high when the CPU is reading data from the ST16C452 to en/disable the external transceiver or logic's.                                                               |
| RESET*   | 39    | l . ·       | Master reset. (active low) A low on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                 |
| CS A/B*  | 32,3  | I           | Chip select A/B (active low). A low at this pin enables the serial port-A/B / CPU data transfer operation.                                                                                                        |
| DSR A/B* | 31,5  | I           | Data set ready A/B (active low). A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                               |
| RI A/B*  | 30,6  | <b>I</b>    | Ring detect indicator A/B (active low). A low on this pin indicates the modem has received a ringing signal from                                                                                                  |

| Symbol   | Pin   | Signal Type                                   | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|-------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |       |                                               | telephone line.                                                                                                                                                                                                                                                                                                                                                                                                 |
| CD A/B*  | 29,8  | 30 <b>1</b>                                   | Carrier detect A/B (active low). A low on this pin indicates the carrier has been detected by the modern.                                                                                                                                                                                                                                                                                                       |
| TX A/B   | 26,10 | O                                             | Serial data output A/B. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                                                                                                                                                |
| DTR A/B* | 25,11 | 0                                             | Data terminal ready A/B (active low). To indicate that ST16C452 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset . Note that this pin does not have any effect on the transmit or receive operation. |
| RTS A/B* | 24,12 | 0                                             | Request to send A/B (active low). To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                                                                                            |
| RX A/B   | 41,62 |                                               | Serial data input A/B. The serial information (data) received from serial port to ST16C452 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally.                                                                                                       |
| CTS A/B* | 28,13 | an III sa sa sa sa sa sa sa sa sa sa sa sa sa | Clear to send A/B (active low). The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation.                                                                                                                                                                                                             |
| INT A/B  | 45,60 | <b>O</b> .                                    | Interrupt output A/B (three state active high) This pin goes high (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                                                                                                            |

| Symbol          | Pin         | Signal Type | Pin Description                                                                                                                                                                                                                                                           |
|-----------------|-------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CSP*<br>PD7-PD0 | 38<br>46-53 | l<br>1/0    | Parallel printer port chip select (active low). A low at this pin enables the parallel port / CPU data transfer operation. Bi-directional parallel ports (three state). To transfer data in or out of the ST16C452 parallel port. PD7-PD0 are latched during output mode. |
| STROBE*         | 55*         | I/O         | General purpose I/O or data strobe output (open drain active low). This output indicates to the printer that valid data is available at the printer port (PD0-PD7).                                                                                                       |
| AUTOFDXT*       | 56*         | 1/0         | General purpose I/O or automatic line feed (open drain active low). When this signal is low the printer should automatically line feed after each line is printed.                                                                                                        |
| INIT            | 57*         | 1/0         | General purpose I/O or initialize line printer (open drain active low). When this signal is low it causes the printer to be initializes.                                                                                                                                  |
| SLCTIN*         | 58*         | I/O         | General purpose I/O or line printer select (open drain active low). When this signal is low it selects the printer.                                                                                                                                                       |
| ERROR*          | 63*         | . 1         | General purpose input or line printer error (active low) This is an output from the printer to indicate an error by holding it low during error condition.                                                                                                                |
| SLCT            | 65*         | <b>1</b>    | General purpose input or line printer selected (active high). This is an output from the printer to indicate that the line printer has been selected.                                                                                                                     |
| BUSY            | 66*         | 1           | General purpose input or line printer busy (active high). An output from the printer to indicate printer is not ready to accept data.                                                                                                                                     |
| PE              | 67*         | <b>I</b> .  | General purpose input or line printer paper empty (active high). An output from the printer to indicate out of paper.                                                                                                                                                     |
| ACK*            | 68*         |             | General purpose input or line printer acknowledge (active low). This input is pulsed low by the printer to indicate that data has been accepted successfully.                                                                                                             |

# SYMBOL DESCRIPTION

| Symbol  | Pin                | Signal Type | Pin Description                                                                                                                                                                                                                                                  |
|---------|--------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INTP*   | 59                 | 0           | Printer interrupt output (active low). To signal the state of the printer port. This pin tracks the ACK* input pin, When ACK* is low INTP is low and when ACK* is high INTP is high                                                                              |
| INTSEL* | 43                 |             | Interrupt select mode. The external ACK* can be selected as an interrupt source by connecting this pin to the GND. Connecting this pin to VCC will set the interrupt to latched mode, reading the status register of the printer section resets the INTP output. |
| GND     | 2,7,22<br>42,54,61 |             | Signal and power ground. All ground pins are connected internally.                                                                                                                                                                                               |
| vcc     | 23,40,64           | 1           | Power supply input. All power pins are connected internally.                                                                                                                                                                                                     |

<sup>\*</sup> Have internal pull-up resistor on inputs

# PROGRAMMING TABLE FOR SERIAL PORTS A/B

| A2 | A1 | A0  | READ MODE                 | WRITE MODE                |
|----|----|-----|---------------------------|---------------------------|
| 0  | 0  | 0   | Receive Holding Register  | Transmit Holding Register |
| 0  | 0  | 1   | de di Bara Tarifica       | Interrupt Enable Register |
| 0  | 1  | 0   | Interrupt Status Register |                           |
| 0  | 1  | 1   |                           | Line Control Register     |
| 1  | 0  | 0   |                           | Modem Control Register    |
| 1  | 0  | 1.  | Line Status Register      |                           |
| 1  | 1  | 0   | Modem Status Register     |                           |
| 1  | 1  | 1   | Scratchpad Register       | Scratchpad Register       |
| 0  | 0  | 0   |                           | LSB of Divisor Latch      |
| 0  | 0  | 1 , |                           | MSB of Divisor Latch      |
|    |    |     |                           |                           |

# **ST16C452 ACCESSIBLE REGISTERS**

| A2 A1 | A0 | Register | BIT-7                      | BIT-6           | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|-------|----|----------|----------------------------|-----------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0 0   | 0  | RHR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0   | 0  | THR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0   | 1  | IER      | 0                          | 0               | 0                          | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0 1   | 0  | ISR      | 0                          | 0               | 0                          | 0                  | 0                            | INT<br>priority<br>bit-1               | INT<br>priority<br>bit-0        | INT<br>status                  |
| 0 1   | 1  | LCR      | divisor<br>latch<br>enable | set<br>break    | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1 0   | 0  | MCR      | 0                          | 0               | 0                          | loop<br>back       | INT<br>enable                | Not<br>used                            | RTS*                            | DTR*                           |
| 1 0   | 1  | LSR      | 0                          | trans.<br>empty | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1 1   | 0  | MSR      | CD                         | RI              | DSR                        | CTS                | delta<br>CD*                 | delta<br>Ri*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1 1   | 1  | SPR      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0   | 0  | DLL      | bit-7                      | bit-6           | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0 0   | 1  | DLM      | bit-15                     | bit-14          | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

## REGISTER FUNCTIONAL DESCRIPTIONS

#### TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

## PROGRAMMABLE BAUD RATE GENERATOR

The ST16C452 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to 2<sup>16</sup> -1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

## **INTERRUPT ENABLE REGISTER (IER)**

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the INT output pin.

#### IER BIT-0:

0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

#### IER BIT-1:

0=disable the transmitter empty interrupt. 1=enable the transmitter empty interrupt.

#### IER BIT-2:

0=disable the receiver line status interrupt. 1=enable the receiver line status interrupt.

#### IER BIT-3:

0=disable the modern status register interrupt. 1=enable the modern status register interrupt.

#### **IER BIT 7-4:**

All these bits are set to logic zero.

#### **INTERRUPT STATUS REGISTER (ISR)**

The ST16C452 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C452 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

## **Priority level**

| Р | D2 | D1 | D0 | Source of the interrupt                           |
|---|----|----|----|---------------------------------------------------|
| 1 | 1  | 1  | 0  | LSR (Receiver Line Status Register)               |
| 2 | 1  | 0  | 0  | RXRDY (Received Data                              |
| 3 | 0  | 1  | 0  | Ready) TXRDY( Transmitter Holding Register Empty) |
| 4 | 0  | 0  | 0  | MSR (Modern Status Register)                      |

#### ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1=no interrupt pending.

#### **ISR BIT 1-2:**

Logical combination of these bits, provides the highest priority interrupt pending.

#### **ISR BIT 3-7:**

These bits are not used and are set to "0".

# LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

#### LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 | BIT-0 | Word length |
|-------|-------|-------------|
| 0     | 0     | 5           |
| 0     | 1     | 6           |
| 1     | 0     | 7           |
| 1     | 1     | 8           |

#### LCR BIT-2:

The number of stop bits can be specified by this bit.

| BIT-2 | Word length | Stop bit(s) |
|-------|-------------|-------------|
| 0     | 5,6,7,8     | 1           |
| 1     | 5           | 1-1/2       |
| 1     | 6,7,8       | 2           |

#### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

#### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format.

#### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

#### LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0=normal operating condition.

1=forces the transmitter output (TX) to go low to alert the communication terminal.

### LCR BIT-7:

The internal baud rate counter latch enable (DLEN). 0=normal operation.

1=select divisor latch register.

## MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

### MCR BIT-0:

0=force DTR\* output to high. 1=force DTR\* output to low.

#### MCR BIT-1:

0=force RTS\* output to high. 1=force RTS\* output to low.

#### MCR BIT-2:

This bit is used for internal loop-back mode, and is not used for regular operation.

#### MCR BIT-3:

0= sets the INT output pin to three state mode. 1= enables the INT output pin.

#### MCR BIT-4:

0=normal operating mode.

1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, MCR bit-2,3are connected to modem control inputs.

In this mode, the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER.

#### **MCR BIT 5-7:**

Not used. Are set to zero permanently.

## LINE STATUS REGISTER (LSR)

This register provides the status of data transfer to CPU.

#### LSR BIT-0:

0=no data in receive holding register 1=data has been received and saved in the receive holding register.

#### LSR BIT-1:

0=no overrun error (normal).

1=overrun error, next character arrived before receive holding register was emptied.

#### LSR BIT-2:

0=no parity error (normal).

1=parity error, received data does not have correct parity information.

#### LSR BIT-3:

0=no framing error (normal).

1=framing error received, received data did not have a valid stop bit. In

#### LSR BIT-4:

0=no break condition (normal).

1=receiver received a break signal (RX was low for one character time frame).

#### LSR BIT-5:

0=transmit holding register is full. ST16C452 will not accept any data for transmission.

1=transmit holding register is empty. CPU can load the next character.

#### LSR BIT-6:

0=transmitter holding and shift registers are full.
1=transmitter holding and shift registers are empty.

## LSR BIT-7:

Not used. Set to "0".

## **MODEM STATUS REGISTER (MSR)**

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

#### MSR BIT-0:

Indicates that the CTS\* input to the ST16C452 has changed state since the last time it was read.

#### MSR BIT-1:

Indicates that the DSR\* input to the ST16C452 has changed state since the last time it was read.

#### MSR BIT-2:

Indicates that the RI\* input to the ST16C452 has changed from a low to a high state.

## MSR BIT-3:

Indicates that the CD\* input to the ST16C452 has changed state since the last time it was read.

#### MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

#### MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

#### MSR BIT-6:

This bit is equivalent to MCR bit-2 during local loopback mode. It is the compliment of the RI\* input.

#### MSR BIT-7:

This bit is equivalent to MCR bit-3 during local loopback mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated.

## SCRATCHPAD REGISTER (SR)

ST16C452 provides a temporary data register to store 8 bits of information for variable use.

| SIGNAL | RESET STATE      |
|--------|------------------|
| TX     | High             |
| RTS*   | High             |
| DTR*   | High             |
| INT    | Three state mode |

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16 x CLOCK<br>DIVISOR | % ERROR |
|-----------|-----------------------|---------|
| 50        | 2304                  |         |
| 75        | 1536                  |         |
| 110       | 1047                  | 0.026   |
| 134.5     | 857                   | 0.058   |
| 150       | 768                   |         |
| 300       | 384                   |         |
| 600       | 192                   |         |
| 1200      | 96                    |         |
| 2400      | 48                    |         |
| 3600      | 32                    |         |
| 4800      | 24                    | ·       |
| 7200      | 16                    |         |
| 9600      | 12                    |         |
| 19.2K     | 6                     |         |
| 38.4K     | 3                     |         |
| 56K       | 2                     | 2.77    |
| 115.2K    | 1                     |         |

### ST16C452 EXTERNAL RESET CONDITION

| REGISTERS | RESET STATE                 |
|-----------|-----------------------------|
| IER       | BITS 0-7=0                  |
| ISR       | BIT-0=1, ISR BITS 1-7=0     |
| LCR       | BITS 0-7=0                  |
| MCR       | BITS 0-7=0                  |
| LSR       | BITS 0-4=0,                 |
|           | LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR       | BITS 0-3=0,                 |
|           | MSR BITS 4-7=input signals  |

# PRINTER PORT PROGRAMMING TABLE:

| A1 /  | A0    | IOW*                                           | IOR*                                                   |
|-------|-------|------------------------------------------------|--------------------------------------------------------|
| 0 0 1 | 1 1/0 | ORT REGISTER O SELECT REGISTER ONTROL REGISTER | PORT REGISTER<br>STATUS REGISTER *<br>COMMAND REGISTER |

<sup>\*</sup> Reading the status register will reset the INTP output.

# PARALLEL PORT DIRECTION SELECT REGISTER (WRITE ONLY)

| ST16C452XX | CONTROL REGISTE | ER (D5) | BIDEN | I/O SELECT REGISTER | PORT DIRECTION |
|------------|-----------------|---------|-------|---------------------|----------------|
| ST16C452AT | <b>X</b>        |         | 0     | X                   | Output mode    |
| ST16C452PS | X               |         | . 0   | AA Hex              | Input mode     |
| ST16C452PS | X               |         | 0     | 55 Hex              | Output mode    |
| ST16C452AT | Х               |         | 1     | X                   | Input mode     |
| ST16C452PS | 0               |         | 1     | X                   | Output mode    |
| ST16C452PS | 1               |         | 1     | X                   | Input mode     |

3

# PRINTER PORTREGISTER DESCRIPTIONS

### PORT REGISTER

Bi-directional printer port.

Writing to this register during output mode will transfer the contents of the data bus to the PD7-PD0 ports. Reading this register during input mode will transfer the states of the PD7-PD0 to the data bus. This register will be set to the output mode after reset.

#### PR BIT 7-0:

PD7-PD0 bi-directional I/O ports.

#### STATUS REGISTER

This register provides the state of the printer outputs and the interrupt condition.

#### SR BIT 1-0:

Not used. Are set to "1" permanently.

## SR BIT-2:

Interrupt condition.

0= an interrupt is pending

This bit will be set to "0" at the falling edge of the ACK\*

1= no interrupt is pending

Reading the STATUS REGISTER will set this bit to "1".

## SR BIT-3:

ERROR\* input state.

0= ERROR\* input is in low state

1= ERROR\* input is in high state

#### SR BIT-4:

SLCT input state.

0= SLCT input is in low state

1= SLCT input is in high state

#### SR BIT-5:

PE input state.

0= PE input is in low state

1= PE input is in high state

#### SR BIT-6:

ACK\* input state.

0= ACK\* input is in low state

1= ACK\* input is in high state

#### SR BIT-7:

BUSY input state.

0= BUSY input is in high state

1= BUSY input is in low state

#### COMMAND REGISTER

The state of the STROBE\*, AUTOFDXT\*, INIT, SLCTIN\* pins, and interrupt enable bit can be read by this register regardless of the I/O direction.

# COM BIT-0:

STROBE\* input pin.

0= STROBE\* pin is in high state

1= STROBE\* pin is in low state

#### COM BIT-1:

AUTOFDXT\* input pin.

0= AUTOFDXT\* pin is in high state

1= AUTOFDXT\* pin is in low state

#### COM BIT-2:

INIT input pin.

0= INIT pin is in low state

1= INIT pin is in high state

### COM BIT-3:

SLCTIN\* input pin.

0= SLCTIN\* pin is in high state

1= SLCTIN\* pin is in low state

#### COM BIT-4:

Interrupt mask.

0= Interrupt (INTP output) is disabled

1= Interrupt (INTP output) is enabled

### **COM BIT 7-5:**

Not used. Are set to "1" permanently.

#### CONTROL REGISTER.

Writing to this register will set the state of the STROBE\*, AUTOFDXT\*, INIT, SLCTIN pins, and interrupt mask register.

#### CON BIT-0:

STROBE\* output control bit.
0= STROBE\* output is set to high state
1= STROBE\* output is set to low state

#### CON BIT-1:

AUTOFDXT\* output control bit.
0= AUTOFDXT\* output is set to high state
1= AUTOFDXT\* output is set to low state

#### CON BIT-2:

INIT output control bit.
0= INIT output is set to low state
1= INIT output is set to high state

#### CON BIT-3:

SLCTIN\* output control bit.
0= SLCTIN\* output is set to high state
1= SLCTIN\* output is set to low state

# CON BIT-4:

Interrupt output control bit. 0= INTP output is disabled 1= INTP output is enabled

#### CON BIT-5:

I/O select. Direction of the PD7-PD0 can be selected by setting or clearing this bit. 0= PD7-PD0 are set for output mode 1= PD7-PD0 are set for input mode

#### **CON BIT 7-6:**

Not used.

#### I/O SELECT REGISTER

Software controlled I/O select.

Bi-directional mode can be selected by keeping the BIDEN input in high state and setting CON BIT-5 to "zero or one"

Hardware/software I/O select.

Bi-directional mode can be selected by keeping the BIDEN input in low state and setting I/O SELECT register to "AA" Hex for input or "55" Hex for output. I/O select register and control register bit-5 are only available for ST16C452PS parts.

#### ST16C452 EXTERNAL RESET CONDITION

| SIGNALS   | RESET STATE       |
|-----------|-------------------|
| PD0-PD7   | low, output mode  |
| STROBE*   | High, output mode |
| AUTOFDXT* | High, output mode |
| INIT      | Low, output mode  |
| SLCTIN*   | High, output mode |

# **ST16C452 PRINTER PORT REGISTER CONFIGURATIONS**

**PORT REGISTER** 

(READ/WRITE)

| D7  | 00  | D5  | D4  |     | D2  | D1  |     |
|-----|-----|-----|-----|-----|-----|-----|-----|
| PD7 | PD6 | PD5 | PD4 | PD3 | PD2 | PD1 | PD0 |

STATUS REGISTER

(READ ONLY)

|       | D6  |    | 04   | D3             | D2  | D1 | D0 |
|-------|-----|----|------|----------------|-----|----|----|
| BUSY* | ACK | PE | SLCT | ERROR<br>STATE | IRQ | 1  | 1  |

1= No interrupt 0= Interrupt (PS only)

COMMAND REGISTER (READ ONLY)

| D7 | D6 | D5 | D4            | D3      | D2   | D1             | D0      |
|----|----|----|---------------|---------|------|----------------|---------|
| 1  | 1  | 1  | IRQ<br>ENABLE | SLCTIN* | INIT | AUTO-<br>FDXT* | STROBE* |

0= IRQ disabled 1= IRQ enabled

**CONTROL REGISTER** 

(WRITE ONLY)

| D7       | D6         | D5            | D4          | D3      | D2   | D1             | D0      |
|----------|------------|---------------|-------------|---------|------|----------------|---------|
| _        | _          | I/O<br>SELECT | IRQ<br>MASK | SLCTIN* | INIT | AUTO-<br>FDXT* | STROBE* |
| <u> </u> | 0=Output ( | PS only)      | 0=INTP      | output  |      |                |         |

disabled
1=Input (PS only)
1=INTP output
enabled

# **AC ELECTRICAL CHARACTERISTICS**

 $T_A$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                     | Parameter                                    | Min | Limits<br>Typ | Max              | Units | Conditions     |
|------------------------------------------------------------------------------------------------------------|----------------------------------------------|-----|---------------|------------------|-------|----------------|
| Τ                                                                                                          | Clock high pulse duration                    | 50  |               |                  | ns    | ·              |
| †¹                                                                                                         | Clock low pulse duration                     | 50  |               |                  | ns    | External clock |
| T.                                                                                                         | Clock rise/fall time                         |     |               | 10               | ns    |                |
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>8</sub> T <sub>9</sub> T <sub>11</sub> T <sub>12</sub> | Chip select setup time                       | 5   |               |                  | ns    |                |
| T.                                                                                                         | Chip select hold time                        | Ö   |               |                  | ns    |                |
| T.                                                                                                         | IOR* to DDIS* delay                          |     | 1 1           | 25               | ns    | 100 pF load    |
| T."                                                                                                        | Data set up time                             | 15  |               |                  | ns    | F              |
| T.2                                                                                                        | IOW* delay from chip select                  | 10  |               | -                | ns    |                |
| T <sub>13</sub> T <sub>14</sub> T <sub>15</sub>                                                            | IOW* delay from chip select                  | 10  | 1             |                  | ns    |                |
| T.,                                                                                                        | IOW* strobe width                            | 50  |               |                  | ns    | ,              |
| T <sub>16</sub>                                                                                            | Chip select hold time from IOW*              | 0   | . !           |                  | ns    |                |
| T <sub>17</sub>                                                                                            | Write cycle delay                            | 55  | 1             |                  | ns    |                |
| Tw                                                                                                         | Write cycle=T <sub>15</sub> +T <sub>17</sub> | 105 | 1             |                  | ns    |                |
| T <sub>19</sub>                                                                                            | Data hold time                               | 15  |               |                  | ns    |                |
| T <sub>21</sub>                                                                                            | IOR* delay from chip select                  | 10  |               |                  | ns    |                |
| T <sub>21</sub><br>T <sub>23</sub><br>T <sub>24</sub><br>T <sub>25</sub>                                   | IOR* strobe width                            | 65  |               |                  | ns ns |                |
| T <sub>24</sub>                                                                                            | Chip select hold time from IOR*              | 0   | j             |                  | ns    |                |
| T <sub>25</sub>                                                                                            | Read cycle delay                             | 55  |               |                  | ns    |                |
| Tr                                                                                                         | Read cycle=T <sub>23</sub> +T <sub>25</sub>  | 115 |               |                  | ns    |                |
| T <sub>26</sub><br>T <sub>28</sub>                                                                         | Delay from IOR* to data                      |     |               | 35               | ns    | 100 pF load    |
| T <sub>28</sub>                                                                                            | Delay from IOW* to output                    |     |               | 50               | ns    | 100 pF load    |
| T <sub>29</sub>                                                                                            | Delay to set interrupt from MODEM            |     |               | 70               | ns    | 100 pF load    |
|                                                                                                            | input                                        |     |               |                  |       |                |
| T <sub>30</sub>                                                                                            | Delay to reset interrupt from IOR*           | 1   |               | 70               | ns    | 100 pF load    |
| T <sub>31</sub>                                                                                            | Delay from stop to set interrupt             | }   |               | 1 <sub>CLK</sub> | ns    | 100 pF load    |
| T <sub>32</sub>                                                                                            | Delay from IOR* to reset interrupt           | 1   |               | 200              | ns    | 100 pF load    |
| T <sub>33</sub>                                                                                            | Delay from initial INT reset to transmit     | 8   |               | 24               | *     | *              |
|                                                                                                            | start                                        | 1   |               |                  |       |                |

# **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                         | Parameter                                                                                                                                                                                     | Min                 | Limits<br>Typ | Max                | Units                      | Conditions |
|----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------|--------------------|----------------------------|------------|
| $T_{34}$ $T_{35}$ $T_{39}$ $T_{40}$ $T_{41}$ $T_{42}$ $T_{43}$ | Delay from stop to interrupt Delay from !OW* to reset interrupt ACK* pulse width PD7-PD0 setup time PD7-PD0 hold time Delay from ACK* low to interrupt low Delay from IOR* to reset interrupt | 75<br>10<br>25<br>5 |               | 100<br>175         | ns<br>ns<br>ns<br>ns<br>ns |            |
| N                                                              | Baud rate devisor                                                                                                                                                                             | 1                   |               | 2 <sup>16</sup> -1 |                            |            |

Note 1 \* = Baudout\* cycle

# **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

# DC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                       | Parameter                                                                                  | Min                        | Limits<br>Typ | Max                      | Units                | Conditions                                                                                                                                       |
|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|----------------------------|---------------|--------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>ILCK</sub><br>V <sub>IHCK</sub><br>V <sub>IL</sub><br>V <sub>IH</sub> | Clock input low level Clock input high level Input low level Input high level              | -0.5<br>3.0<br>-0.5<br>2.2 |               | 0.6<br>VCC<br>0.8<br>VCC | > > > >              | L = 6.0 mA D7 D0                                                                                                                                 |
| V <sub>oL</sub>                                                              | Output low level                                                                           |                            |               | 0.4                      | <b>V</b>             | $I_{oL}$ = 6.0 mA D7-D0<br>$I_{oL}$ = 20.0 mA PD7-PD0<br>$I_{oL}$ = 10 mA<br>SLCTIN*,<br>INIT*,STROBE*,<br>AUTOFDXT*<br>$I_{oL}$ = 6.0 mA on all |
| V <sub>OH</sub>                                                              | Output high level                                                                          | 2.4                        |               |                          | V                    | other outputs  I <sub>OH</sub> = -6.0 mA D7- D0  I <sub>OH</sub> = -12.0 mA PD7-PD0  I <sub>OH</sub> = -0.2 mA SLCTIN*, INIT*,STROBE*, AUTOFDXT* |
|                                                                              |                                                                                            |                            |               |                          |                      | I <sub>OH</sub> = -6.0 mA on all<br>the outputs                                                                                                  |
| I <sub>cc</sub><br>I <sub>IL</sub><br>I <sub>CL</sub><br>RIN                 | Avg. power supply current<br>Input leakage<br>Clock leakage<br>Internal pull-up resistance | 4                          | 12            | ±10<br>±10<br>15         | mA<br>μA<br>μA<br>kΩ | * Marked pins                                                                                                                                    |

3

# ST16C452AT ST16C452PS

## **GENERAL READ TIMING**





# **GENERAL WRITE TIMING**



3

# ST16C452AT ST16C452PS

# **MODEM TIMING**









# PARALLEL PORT GENERAL WRITE TIMING



# PARALLEL PORT READ TIMING





# ST16C552

3

Printed September 8, 1994

# UNIVERSAL ASYNCHRONOUS RECEIVER/TRANSMITTER WITH FIFO AND PARALLEL PRINTER PORT

#### DESCRIPTION

The ST16C552 is a dual universal asynchronous receiver and transmitter with 16 byte transmit and receive FIFO and a bi-directional CENTRONICS type parallel printer port. A programmable baud rate generator is provided to select transmit and receive clock rates from 50Hz to 448kHz.

The ST16C552 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C552 provides internal loopback capability for on board diagnostic testing.

The ST16C552 is fabricated in an advanced  $1.2\mu$  CMOS process to achieve low drain power and high speed requirements.

#### **FEATURES**

- Pin to pin and functional compatible to VL16C552, WD16C552
- 16 byte transmit FIFO
- 16 byte receive FIFO with error flags
- Modem control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\*, CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- · Status report register
- · Independent transmit and receive control
- TTL compatible inputs, outputs
- Software compatible with INS8250, NS16C550
- 448 kHz transmit/receive operation with 7.372 MHz crystal or external clock source.
- · Bi-directional hardware/software parallel port
- Bi-directional I/O ports

# ORDERING INFORMATION

Part number ST16C552CJ68 ST16C552IJ68 Package PLCC PLCC Operating temperature 0° C to + 70° C -40° C to + 85° C

# **PLCC Package**



# **BLOCK DIAGRAM**



# **SYMBOL DESCRIPTION**

| Symbol   | Pîn   | Signal Type | Pin Description                                                                                                                                                                                                   |
|----------|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7    | 14-21 | I/O         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. Do is the least significant bit of the data bus and the first serial data bit to be received or transmitted. |
| A0-A2    | 35-33 | 1           | Address select lines. To select internal registers.                                                                                                                                                               |
| CLK      | 4     | , I         | Clock input. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                                                                       |
| BIDEN    | · 1   | Ī           | Printer direction select. A high puts the parallel port in the input / output mode and low sets the ST16C552 to output mode.                                                                                      |
| IOW*     | 36    | l<br>I      | Write strobe (active low). A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                            |
| IOR*     | 37    | 1           | Read strobe (active low). A low level on this pin transfers the contents of the ST16C552 data bus to the CPU.                                                                                                     |
| RDOUT    | 44    | 0           | Read select out (active high). This pin goes high when the CPU is reading data from the ST16C552 to en/disable the external transceiver or logic's.                                                               |
| RESET*   | 39    | ı           | Master reset. (active low) A low on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                 |
| CS A/B*  | 32,3  | 1           | Chip select A/B (active low). A low at this pin enables the serial port-A/B / CPU data transfer operation.                                                                                                        |
| DSR A/B* | 31,5  | · I         | Data set ready A/B (active low). A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                               |
| RI A/B*  | 30,6  |             | Ring detect indicator A/B (active low). A low on this pin indicates the modem has received a ringing signal from telephone line.                                                                                  |

# SYMBOL DESCRIPTION

| Symbol    | Pin   | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CD A/B*   | 29,8  | l           | Carrier detect A/B (active low). A low on this pin indicates the carrier has been detected by the modem.                                                                                                                                                                                                                                                                                                       |
| TX A/B    | 26,10 | 0           | Serial data output A/B. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled.                                                                                                                                                                               |
| DTR A/B*  | 25,11 | 0           | Data terminal ready A/B (active low). To indicate that ST16C552 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation. |
| RTS A/B*  | 24,12 | Ο           | Request to send A/B (active low). To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation.                                                                                           |
| RX A/B    | 41,62 |             | Serial data input A/B. The serial information (data) received from serial port to ST16C552 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally.                                                                                                      |
| CTS A/B*  | 28,13 |             | Clear to send A/B (active low). The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation.                                                                                                                                                                                                            |
| INT A/B   | 45,60 | 0           | Interrupt output A/B (three state active high) This pin goes high (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected.                                                                                                                                                                           |
| TXRDY A/B | 22,42 | O           | Transmit ready A/B (active high). This pin goes high when the transmit FIFO of the ST16C552 is full. It can be used as                                                                                                                                                                                                                                                                                         |

# SYMBOL DESCRIPTION

| Symbol     | Pin   | Signal Type | Pin Description                                                                                                                                                     |
|------------|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |       |             | a single or multi-transfer.                                                                                                                                         |
| RXRDY A/B* | 9,61  | 0           | Receive ready A/B (active low). This pin goes low when the receive FIFO is full. It can be used as a single or multitransfer.                                       |
| CSP*       | 38    | ı           | Parallel printer port chip select (active low). A low at this pin enables the parallel port / CPU data transfer operation.                                          |
| PD7-PD0    | 46-53 | 1/0         | Bi-directional parallel ports (three state). To transfer data in or out of the ST16C552 parallel port. PD7-PD0 are latched during output mode.                      |
| STROBE*    | 55*   | 1/0         | General purpose I/O or data strobe output (open drain active low). This output indicates to the printer that valid data is available at the printer port (PD0-PD7). |
| AUTOFDXT*  | 56*   | 1/0         | General purpose I/O or automatic line feed (open drain active low). When this signal is low the printer should automatically line feed after each line is printed.  |
| INIT       | 57*   | 1/0         | General purpose I/O or initialize line printer (open drain active low). When this signal is low, it causes the printer to be initialized.                           |
| SLCTIN*    | 58*   | 1/0         | General purpose I/O or line printer select (open drain active low). When this signal is low, it selects the printer.                                                |
| ERROR*     | 63*   | l           | General purpose input or line printer error (active low). This is an output from the printer to indicate an error by holding it low during error condition.         |
| SLCT       | 65*   | <b>!</b>    | General purpose input or line printer selected (active high). This is an output from the printer to indicate that the line printer has been selected.               |
| BUSY       | 66*   | 1           | General purpose input or line printer busy (active high). An output from the printer to indicate printer is not ready to accept data.                               |
|            |       |             |                                                                                                                                                                     |

| Symbol  | Pin          | Signal Type | Pin Description                                                                                                                                                                                                                                                  |
|---------|--------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PE      | 67*          | 1           | General purpose input or line printer paper empty (active high). An output from the printer to indicate out of paper.                                                                                                                                            |
| ACK*    | 68*          | (1) (1)     | General purpose input or line printer acknowledge (active low). This input is pulsed low by the printer to indicate that data has been accepted successfully.                                                                                                    |
| INTP*   | 59           | 0           | Printer interrupt output (active low). To signal the state of the printer port. This pin tracks the ACK* input pin, When ACK* is low INTP is low and when ACK* is high INTP is high                                                                              |
| INTSEL* | 43           | I           | Interrupt select mode. The external ACK* can be selected as an interrupt source by connecting this pin to the GND. Connecting this pin to VCC will set the interrupt to latched mode, reading the status register of the printer section resets the INTP output. |
| GND     | 2,7,54<br>27 | O           | Signal and power ground.                                                                                                                                                                                                                                         |
| vcc     | 23,40,64     | 1           | Power supply input.                                                                                                                                                                                                                                              |

<sup>\*</sup> Have internal pull-up resistor on inputs

# PROGRAMMING TABLE FOR SERIAL PORTS

| A2  | A1  | A0  | READ MODE                 | WRITE MODE                |
|-----|-----|-----|---------------------------|---------------------------|
| 0   | 0 . | 0   | Receive Holding Register  | Transmit Holding Register |
| 0   | 0   | 1 1 |                           | Interrupt Enable Register |
| 0   | 1 . | 0   | Interrupt Status Register | FIFO Control Register     |
| 0   | 1   | 1   |                           | Line Control Register     |
| 1   | 0   | 0   |                           | Modem Control Register    |
| 1 1 | 0   | 1   | Line Status Register      |                           |
| 1 1 | 1   | 0   | Modem Status Register     |                           |
| 1 1 | 1   | 1   | Scratchpad Register       | Scratchpad Register       |
| 0   | 0   | 0   |                           | LSB of Divisor Latch      |
| 0   | 0   | 1   |                           | MSB of Divisor Latch      |

# **ST16C552 ACCESSIBLE REGISTERS**

| A2 | A1 | A0 | Register | BIT-7                      | BIT-6                    | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                                  | BIT-1                           | BIT-0                          |
|----|----|----|----------|----------------------------|--------------------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------|
| 0  | 0  | 0  | RHR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 0  | THR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 1  | IER      | 0                          | 0                        | 0                          | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register |
| 0  | 1  | 0  | FCR      | RCVR<br>trigger<br>(MSB)   | RCVR<br>trigger<br>(LSB) | 0                          | O                  | DMA<br>mode<br>select        | XMIT<br>FIFO<br>reset                  | RCVR<br>FIFO<br>reset           | FIFO<br>enable                 |
| 0  | 1  | 0  | ISR      | 0/<br>FIFOs<br>enabled     | 0/<br>FIFOs<br>enabled   | 0                          | 0                  | int<br>priority<br>bit-2     | int<br>priority<br>bit-1               | int<br>priority<br>bit-0        | int<br>status                  |
| 0  | 1  | 1  | LCR      | divisor<br>latch<br>enable | set<br>break             | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits                           | word<br>length<br>bit-1         | word<br>length<br>bit-0        |
| 1  | 0  | 0  | MCR      | 0                          | 0                        | 0                          | loop<br>back       | INT<br>enable                | Not<br>used                            | RTS*                            | DTR*                           |
| 1  | 0  | 1  | LSR      | 0/<br>FIFO<br>error        | trans.<br>empty          | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error                        | overrun<br>error                | receive<br>data<br>ready       |
| 1  | 1  | 0  | MSR      | CD                         | RI                       | DSR                        | CTS                | delta<br>CD*                 | delta<br>RI*                           | delta<br>DSR*                   | delta<br>CTS*                  |
| 1  | 1  | 1  | SPR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 0  | DLL      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                                  | bit-1                           | bit-0                          |
| 0  | 0  | 1  | DLM      | bit-15                     | bit-14                   | bit-13                     | bit-12             | bit-11                       | bit-10                                 | bit-9                           | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

## REGISTER FUNCTIONAL DESCRIPTIONS

#### TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

#### FIFO INTERRUPT MODE OPERATION

When the receive FIFO (FCR BIT-0=1) and receive interrupts (IER BIT-0=1) are enabled, receiver interrupt will occur as follows:

- A) The receive data available interrupts will be issued to the CPU when the FIFO has reached its programmed trigger level; it will be cleared as soon as the FIFO drops below its programmed trigger level.
- B) The ISR receive data available indication also occurs when the FIFO trigger level is reached, and like the interrupt it is cleared when the FIFO drops below the trigger level.
- C) The data ready bit (LSR BIT-0) is set as soon as a character is transferred from the shift register to the receiver FIFO. It is reset when the FIFO is empty.

#### FIFO POLLED MODE OPERATION

When FCR BIT-0=1; resetting IER BIT 3-0 to zero puts the ST16C552 in the FIFO polled mode of operation. Since the receiver and transmitter are controlled separately either one or both can be in the polled mode operation by utilizing the Line Status Register.

- A) LSR BIT-0 will be set as long as there is one byte in the receive FIFO.
- B) LSR BIT4-1 will specify which error(s) has occurred.
- C) LSR BIT-5 will indicate when the transmit FIFO is empty.
- D) LSR BIT-6 will indicate when both transmit FIFO and transmit shift register are empty.
- E) LSR BIT-7 will indicate when there are any errors in the receive FIFO.

The ST16C552 requires to have two step FIFO enable operation in order to enable receive trigger levels.

#### PROGRAMMABLE BAUD RATE GENERATOR

The ST16C552 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to 2<sup>16</sup>-1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

#### INTERRUPT ENABLE REGISTER (IER)

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the INT output pin.

#### IER BIT-0:

0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

#### IER BIT-1:

0=disable the transmitter empty interrupt. 1=enable the transmitter empty interrupt.

#### IER BIT-2:

0=disable the receiver line status interrupt. 1=enable the receiver line status interrupt.

#### IER BIT-3:

0=disable the modern status register interrupt. 1=enable the modern status register interrupt.

#### **IER BIT 7-4:**

All these bits are set to logic zero.

#### **INTERRUPT STATUS REGISTER (ISR)**

The ST16C552 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C552 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

#### Priority level

| Р  | D3 | D2 | D1 | D0 | Source of the interrupt                    |
|----|----|----|----|----|--------------------------------------------|
| 1  | 0  | 1  | 1  | 0  | LSR (Receiver Line Sta-<br>tus Register)   |
| 2  | 0  | 1  | 0  | 0  | RXRDY (Received Data Ready)                |
| 2* | 1  | 1  | 0  | 0  | RXRDY (Receive Data time out)              |
| 3  | 0  | 0  | 1  | 0  | TXRDY( Transmitter Holding Register Empty) |
| 4  | 0  | 0  | 0  | 0  | MSR (Modern Status<br>Register)            |

#### \*RECEIVE TIME-OUT:

This mode is enabled when STARTECH UART is operating in FIFO mode. Receive time out will not occur if the receive FIFO is empty. The time out counter will be reset at the center of each stop bit received or each time receive holding register is read. The actual time out value is T ( Time out length in bits)= 4 X P ( Programmed word length) + 12. To convert time out value to a character value, user has to divide this number to its complete word length + parity ( if used) + number of stop bits and start bit.

Example -A: If user programs the word length = 7, and no parity and one stop bit, Time out will be:

T = 4 X 7( programmed word length) +12 = 40 bits

Character time = 40 / 9 [ (programmed word length = 7) + (stop bit = 1) + (start bit = 1)] = 4.4 characters.

Example -B: If user programs the word length = 7, with parity and one stop bit, the time out will be:  $T = 4 \times 7$  (programmed word length) + 12 = 40 bits Character time = 40 / 10 [ (programmed word length = 7) + (parity = 1) + (stop bit = 1) + (start bit = 1) = 4 characters.

#### ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1=no interrupt pending.

#### **ISR BIT 1-3:**

Logical combination of these bits, provides the highest priority interrupt pending.

### **ISR BIT 4-7:**

These bits are not used and are set to zero in ST16C450 mode. BIT 6-7: are set to "1" in ST16C552 mode.

#### FIFO CONTROL REGISTER (FCR)

This register is used to enable the FIFOs, clear the FIFOs, set the receiver FIFO trigger level, and select the type of DMA signaling.

#### FCR BIT-0:

0=Disable the transmit and receive FIFO.

1=Enable the transmit and receive FIFO.

This bit should be enabled before setting the FIFO trigger levels.

#### FCR BIT-1:

0=No change.

1=Clears the contents of the receive FIFO and resets its counter logic to 0 (the receive shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-2:

0=No change.

1=Clears the contents of the transmit FIFO and resets its counter logic to 0 (the transmit shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

#### FCR BIT-3:

0=No change.

1=Changes RXRDY and TXRDY pins from mode "0" to mode "1".

#### Transmit operation in mode "0":

When ST16C552 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) when there are no characters in the transmit FIFO or transmit holding register, the TXRDY\* pin will go low. Once active the TXRDY\* pin will go high (inactive) after the first character is loaded into the transmit holding register.

### Receive operation in mode "0":

When ST16C552 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) and there is at least 1 character in the receive FIFO, the RXRDY\* pin will go low. Once active the RXRDY\* pin will go high (inactive) when there are no more characters in the receiver.

### Transmit operation in mode "1":

When ST16C552 is in ST16C550 mode (FCR bit-0=1, FCR bit-3=1) the TXRDY\* pin will become high (inactive) when the transmit FIFO is completely full. It will be low if one or more FIFO locations are empty.

#### Receive operation in mode "1":

When ST16C552 is in ST16C550 mode (FCR bit-0=1, FCR bit-3=1) and the trigger level or the timeout has been reached, the RXRDY\* pin will go low. Once it is activated it will go high (inactive) when there are no more characters in the FIFO.

#### FCR BIT 4-5:

Not used.

#### **FCR BIT 6-7:**

These bits are used to set the trigger level for the receiver FIFO interrupt.

| BIT-7 | BIT-6 | FIFO trigger level |  |  |  |
|-------|-------|--------------------|--|--|--|
| 0     | 0     | 01                 |  |  |  |
| 0     | 1     | 04                 |  |  |  |
| 1     | . 0   | 08                 |  |  |  |
| 1     | 1     | 14                 |  |  |  |

# LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

#### LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 | BIT-0 | Word length |
|-------|-------|-------------|
| 0     | 0     | 5           |
| 0     | 1     | 6           |
| 1     | 0 .   | 7           |
| . 1   | 1     | 8           |

#### LCR BIT-2:

The number of stop bits can be specified by this bit.

| BIT-2 | Word length | Stop bit(s) |
|-------|-------------|-------------|
| 0     | 5,6,7,8     | 1           |
| 1     | 5           | 1-1/2       |
| 1     | 6,7,8       | 2           |

#### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

#### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format.

#### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

#### LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0=normal operating condition.

1=forces the transmitter output (TX) to go low to alert the communication terminal.

#### LCR BIT-7:

The internal baud rate counter latch enable (DLEN). 0=normal operation.

1=select divisor latch register.

### MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

#### MCR BIT-0:

0=force DTR\* output to high. 1=force DTR\* output to low.

#### MCR BIT-1:

0=force RTS\* output to high. 1=force RTS\* output to low.

#### MCR BIT-2:

Not used.

#### MCR BIT-3:

0=set INT output pin to three state mode. 1=set INT output pin to normal / active operating mode.

# MCR BIT-4:

0=normal operating mode.

1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, MCR bit-2 and INT enable are connected to modem control inputs.

In this mode, the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER.

#### MCR BIT 5-7:

Not used. Are set to zero permanently.

## LINE STATUS REGISTER (LSR)

This register provides the status of data transfer to CPU.

#### LSR BIT-0:

0=no data in receive holding register or FIFO. 1=data has been received and saved in the receive holding register or FIFO.

#### LSR BIT-1:

0=no overrun error (normal).

1=overrun error, next character arrived before receive holding register was emptied or if FIFOs are enabled, an overrun error will occur only after the FIFO is full and the next character has been completely received in the shift register. Note that character in the shift register is overwritten, but it is not transferred to the FIFO.

#### LSR BIT-2:

0=no parity error (normal).

1=parity error, received data does not have correct parity information. In the FIFO mode this error is associated with the character at the top of the FIFO.

#### LSR BIT-3:

0=no framing error (normal).

1=framing error received, received data did not have a valid stop bit. In the FIFO mode this error is associated with the character at the top of the FIFO.

#### LSR BIT-4:

0=no break condition (normal).

1=receiver received a break signal (RX was low for one character time frame). In FIFO mode, only one zero character is loaded into the FIFO.

#### LSR BIT-5:

0=transmit holding register is full. ST16C552 will not accept any data for transmission.

1=transmit holding register (or FIFO ) is empty. CPU can load the next character.

#### LSR BIT-6:

0=transmitter holding and shift registers are full. 1=transmitter holding and shift registers are empty. In FIFO mode this bit is set to one whenever the transmitter FIFO and transmit shift register are empty.

#### LSR BIT-7:

0=Normal.

1=At least one parity error, framing error or break indication in the FIFO. This bit is cleared when LSR is read.

#### MODEM STATUS REGISTER (MSR)

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

#### MSR BIT-0:

Indicates that the CTS\* input to the ST16C552 has changed state since the last time it was read.

#### MSR BIT-1:

Indicates that the DSR\* input to the ST16C552 has changed state since the last time it was read.

### MSR BIT-2:

Indicates that the RI\* input to the ST16C552 has changed from a low to a high state.

#### MSR BIT-3:

Indicates that the CD\* input to the ST16C552 has changed state since the last time it was read.

#### MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

#### MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

#### MSR BIT-6:

This bit is equivalent to MCR bit-2 during local loopback mode. It is the compliment of the RI\* input. This bit is equivalent to INT enable in the MCR during local loop-back mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated.

## SCRATCHPAD REGISTER (SR)

ST16C552 provides a temporary data register to store 8 bits of information for variable use.

## ST16C552 EXTERNAL RESET CONDITION

| REGISTERS | RESET STATE                 |
|-----------|-----------------------------|
| IER       | BITS 0-7=0                  |
| ISR       | ISR BIT-0=1, ISR BITS 1-7=0 |
| LCR       | LCR BITS 0-7=0              |
| MCR       | MCR BITS 0-7=0              |
| LSR       | LSR BITS 0-4=0,             |
|           | LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR       | MSR BITS 0-3=0,             |
|           | MSR BITS 4-7=input signals  |
| FCR       | FCR BITS 0-7=0              |
|           |                             |

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16 x CLOCK<br>DIVISOR | % ERROR |
|-----------|-----------------------|---------|
| 50        | 2304                  |         |
| 110       | 1047                  | 0.026   |
| 150       | 768                   |         |
| 300       | 384                   |         |
| 600       | 192                   |         |
| 1200      | 96                    |         |
| 2400      | 48                    | \$ 1.0  |
| 4800      | 24                    |         |
| 7200      | 16                    |         |
| 9600      | 12                    |         |
| 19.2K     | 6                     |         |
| 38.4K     | 3                     |         |
| 56K       | 2                     | 2.77    |
| 115.2K    | 1                     |         |

| SIGNALS | RESET STATE      |
|---------|------------------|
| TX      | High             |
| RTS*    | High             |
| DTR*    | High             |
| INT     | Three state mode |
| RXRDY*  | High             |
| TXRDY   | Low              |

# PRINTER PORT PROGRAMMING TABLE:

| A1          | A0          | loW*                                               | IOR*                                                   |
|-------------|-------------|----------------------------------------------------|--------------------------------------------------------|
| 0<br>0<br>1 | 0<br>1<br>0 | PORT REGISTER I/O SELECT REGISTER CONTROL REGISTER | PORT REGISTER<br>STATUS REGISTER *<br>COMMAND REGISTER |
|             |             |                                                    | 35.21                                                  |

<sup>\*</sup> Reading the status register will reset the INTP output.

### PRINTER PORT REGISTER DESCRIPTIONS

#### PR BIT 7-0:

PD7-PD0 bi-directional I/O ports.

#### STATUS REGISTER

This register provides the state of the printer outputs and the interrupt condition.

#### SR BIT 1-0:

Not used. Are set to "1" permanently.

#### SR BIT-2:

Interrupt condition.

0= an interrupt is pending

This bit will be set to "0" at the falling edge of the ACK\*

1= no interrupt is pending

Reading the STATUS REGISTER will set this bit to "1".

#### SR BIT-3:

ERROR\* input state.

0= ERROR\* input is in low state

1= ERROR\* input is in high state

#### SR BIT-4:

SLCT input state.

0= SLCT input is in low state

1= SLCT input is in high state

#### SR BIT-5:

PE input state.

0= PE input is in low state

1= PE input is in high state

#### SR BIT-6:

ACK\* input state.

0= ACK\* input is in low state

1= ACK\* input is in high state

## SR BIT-7:

BUSY input state.

0= BUSY input is in high state

1= BUSY input is in low state

#### COMMAND REGISTER

The state of the STROBE\*, AUTOFDXT\*, INIT, SLCTIN\* pins, and interrupt enable bit can be read by this register regardless of the I/O direction.

#### COM BIT-0:

STROBE\* input pin.

0= STROBE\* pin is in high state

1= STROBE\* pin is in low state

#### COM BIT-1:

AUTOFDXT\* input pin.

0= AUTOFDXT\* pin is in high state

1= AUTOFDXT\* pin is in low state

#### COM BIT-2:

INIT input pin.

0= INIT pin is in low state

1= INIT pin is in high state

#### COM BIT-3:

SLCTIN\* input pin.

0= SLCTIN\* pin is in high state

1= SLCTIN\* pin is in low state

#### COM BIT-4:

Interrupt mask.

0= Interrupt (INTP output) is disabled

1= Interrupt (INTP output) is enabled

#### **COM BIT 7-5:**

Not used. Are set to "1" permanently.

#### CONTROL REGISTER.

Writing to this register will set the state of the STROBE\*, AUTOFDXT\*, INIT, SLCTIN pins, and interrupt mask register.

#### CON BIT-0:

STROBE\* output control bit.

0= STROBE\* output is set to high state

1= STROBE\* output is set to low state

3

## CON BIT-1:

AUTOFDXT\* output control bit. 0= AUTOFDXT\* output is set to high state 1= AUTOFDXT\* output is set to low state

#### CON BIT-2:

INIT output control bit. 0= INIT output is set to low state 1= INIT output is set to high state

#### CON BIT-3:

SLCTIN\* output control bit. 0= SLCTIN\* output is set to high state 1= SLCTIN\* output is set to low state

#### CON BIT-4:

Interrupt output control bit. 0= INTP output is disabled 1= INTP output is enabled

# CON BIT-5:

I/O select. Direction of the PD7-PD0 can be selected by setting or clearing this bit. 0= PD7-PD0 are set for output mode 1= PD7-PD0 are set for input mode

#### **CON BIT 7-6:**

Not used.

#### I/O SELECT REGISTER

Software controlled I/O select.

Bi-directional mode can be selected by keeping the BIDEN input in high state and setting CON BIT-5 to "zero or one"

Hardware/software I/O select.

Bi-directional mode can be selected by keeping the BIDEN input in low state and setting I/O SELECT register to "AA" Hex for input or "55" Hex for output.

#### ST16C552 EXTERNAL RESET CONDITION

| SIGNALS   | RESET STATE       |
|-----------|-------------------|
| PD0-PD7   | Low, output mode  |
| STROBE*   | High, output mode |
| AUTOFDXT* | High, output mode |
| INIT      | Low, output mode  |
| SLCTIN*   | High, output mode |

| CONTROL REGISTER (D5) | BIDEN | I/O SELECT REGISTER | PORT DIRECTION |
|-----------------------|-------|---------------------|----------------|
| X                     | 0     | AA Hex              | Input mode     |
| l x                   | 1 0   | 55 Hex              | Output mode    |
| 0                     | 1     | X                   | Output mode    |
| 1                     | 1     | X                   | Input mode     |
| 1                     | 1     | l                   | I              |

# **ST16C552 PRINTER PORT REGISTER CONFIGURATIONS**

| PO | RT | RF | GIS | TFR |
|----|----|----|-----|-----|

# (READ/WRITE)

| D7  |     |     |     | DS  | D2  | D1  |     |
|-----|-----|-----|-----|-----|-----|-----|-----|
| PD7 | PD6 | PD5 | PD4 | PD3 | PD2 | PD1 | PD0 |

# STATUS REGISTER

# (READ ONLY)

|       | D6  | טט | υ4   | DS             | D2  | D1 |   |
|-------|-----|----|------|----------------|-----|----|---|
| BUSY* | ACK | PE | SLCT | ERROR<br>STATE | IRQ | 1  | 1 |

1= No interrupt 0= Interrupt

# COMMAND REGISTER

# (READ ONLY)

| 1  | 1  | 1 .1 | IRQ<br>ENABLE | SLCTIN* | INIT | AUTO-<br>FDXT* | STROBE* |
|----|----|------|---------------|---------|------|----------------|---------|
|    |    |      |               |         | 4    |                |         |
| D7 | D6 | D5   | D4            | D3      | D2   | D1             | D0      |

0= IRQ disabled 1= IRQ enabled

enabled

# **CONTROL REGISTER**

# (WRITE ONLY)

| D7 | D6                  | D5            | D4                                   | D3      | D2   | D1             | D0      |  |
|----|---------------------|---------------|--------------------------------------|---------|------|----------------|---------|--|
| -  |                     | I/O<br>SELECT | IRQ<br>MASK                          | SLCTIN* | INIT | AUTO-<br>FDXT* | STROBE* |  |
|    | 0=Output<br>1=Input |               | 0=INTP output disabled 1=INTP output |         |      |                |         |  |

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                     | Parameter Limits                            |      | Units | Conditions               |          |                                       |
|--------------------------------------------------------------------------------------------|---------------------------------------------|------|-------|--------------------------|----------|---------------------------------------|
|                                                                                            | , didinates                                 | Min  | Тур   | Max                      | Omes     | Conditions                            |
|                                                                                            |                                             |      |       |                          |          |                                       |
| т                                                                                          | Clock high pulse duration                   | 50   |       |                          | ns       |                                       |
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>8</sub> T <sub>9</sub> T <sub>12</sub> | Clock low pulse duration                    | 50   | :     |                          | ns       | External clock                        |
| T <sub>2</sub>                                                                             | Clock rise/fall time                        | "    |       | 10                       | ns       | External brook                        |
| T.                                                                                         | Chip select setup time                      | 5    |       |                          | ns       |                                       |
| T <sub>o</sub>                                                                             | Chip select hold time                       | 0    | İ     |                          | ns       |                                       |
| T <sub>12</sub>                                                                            | Data setup time                             | 15   |       |                          | ns       |                                       |
| l T                                                                                        | Data hold time                              | 15   |       |                          | ns       |                                       |
| 1 144                                                                                      | IOW* delay from chip select                 | 10   |       |                          | ns       |                                       |
| 15                                                                                         | IOW* strobe width                           | 50   | İ     |                          | ns       | ·                                     |
| T <sub>16</sub> T <sub>17</sub>                                                            | Chip select hold time from IOW*             | 0    |       |                          | ns       |                                       |
| T <sub>17</sub>                                                                            | Write cycle delay                           | 55   |       |                          | ns       |                                       |
| T <sub>19</sub>                                                                            | Data hold time                              | 15   |       |                          | ns       |                                       |
| 1 24                                                                                       | IOR* delay from chip select                 | 10   |       |                          | ns       |                                       |
| T <sub>23</sub>                                                                            | IOR* strobe width                           | 65   | :     |                          | ns       |                                       |
| T <sub>23</sub> T <sub>24</sub> T <sub>25</sub>                                            | Chip select hold time from IOR*             | 0    |       |                          | ns       |                                       |
| 1 <sub>25</sub>                                                                            | Read cycle delay                            | 55   |       |                          | ns       |                                       |
| Tr                                                                                         | Read cycle=T <sub>23</sub> +T <sub>25</sub> | 115  |       | 25                       | ns       | 400 - 51 1                            |
| T <sub>26</sub><br>T <sub>28</sub>                                                         | Delay from IOR* to data                     |      |       | 35                       | ns       | 100 pF load                           |
| T <sup>28</sup>                                                                            | Delay from IOW* to output                   |      |       | 50                       | ns       | 100 pF load                           |
| T <sub>29</sub>                                                                            | Delay to set interrupt from MODEM input     |      |       | 70                       | ns       | 100 pF load                           |
| т .                                                                                        | Delay to reset interrupt from IOR*          |      |       | 70                       | ne       | 100 pF load                           |
| T <sub>30</sub><br>T <sub>31</sub><br>T <sub>32</sub><br>T <sub>33</sub>                   | Delay from stop to set interrupt            |      |       |                          | ns<br>ns | 100 pF load                           |
| <sup>'31</sup>                                                                             | Delay from IOR* to reset interrupt          |      |       | 1 <sub>Rclk</sub><br>200 | ns       | 100 pF load                           |
| T 32                                                                                       | Delay from initial INT reset to transmit    | 8    |       | 24                       | *        | 100 pr load                           |
| 33                                                                                         | start                                       | "    |       | 24                       |          |                                       |
| T <sub>34</sub>                                                                            | Delay from stop to interrupt                |      |       | 100                      | ns       |                                       |
| T <sub>35</sub>                                                                            | Delay from IOW* to reset interrupt          | -    |       | 175                      | ns       |                                       |
| T <sub>39</sub>                                                                            | ACK* pulse width                            | 75   |       |                          | ns       |                                       |
| T <sub>40</sub>                                                                            | PD7 - PD0 setup time                        | - 10 |       |                          | ns       |                                       |
| T <sub>41</sub>                                                                            | PD7 - PD0 hold time                         | 25   |       |                          | ns       |                                       |
| T,,                                                                                        | Delay from ACK* low to interrupt low        | 5    |       |                          | ns       |                                       |
| T <sub>43</sub>                                                                            | Delay from IOR* to reset interrupt          | 5    |       |                          | ns       |                                       |
| T <sub>43</sub><br>T <sub>44</sub>                                                         | Delay from stop to set RxRdy                |      |       | 1 <sub>RCLK</sub>        |          |                                       |
| T <sub>45</sub>                                                                            | Delay from IOR* to reset RxRdy              |      |       | 1                        | μS       | į.                                    |
| T,6                                                                                        | Delay from IOW* to set TxRdy                |      |       | 195                      | ns       | '                                     |
| T <sub>47</sub>                                                                            | Delay from start to reset TxRdy             |      |       | 8                        | *        |                                       |
|                                                                                            |                                             |      |       |                          |          | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ |
| N                                                                                          | Baud rate devisor                           | 1    |       | 216-1                    |          |                                       |

Note 1 \*= Baudout\* cycle

# **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

# DC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                          | Parameter                                                                                      | Min | Limits<br>Typ | Max                             | Units                | Conditions                                                                                                               |
|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-----|---------------|---------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------|
| V <sub>ILCK</sub><br>V <sub>IHCK</sub><br>V <sub>IL</sub><br>V <sub>IH</sub><br>V <sub>OL</sub> | Clock input low level Clock input high level Input low level Input high level Output low level |     |               | 0.6<br>VCC<br>0.8<br>VCC<br>0.4 | V<br>V<br>V<br>V     | I <sub>oL</sub> = 6.0 mA D7-D0                                                                                           |
|                                                                                                 |                                                                                                |     |               |                                 |                      | $I_{ol}$ = 20.0 mA PD7-<br>PD0 $I_{ol}$ = 10 mA SLCTIN*, INIT*,STROBE*, AUTOFDXT* $I_{ol}$ = 6.0 mA on all other outputs |
| V <sub>oH</sub>                                                                                 | Output high level                                                                              | 2.4 |               |                                 |                      | $I_{OH}$ = -6.0 mA D7-<br>D0<br>$I_{OH}$ = -12.0 mA<br>PD7-PD0<br>$I_{OH}$ = -0.2 mA<br>SLCTIN*,                         |
|                                                                                                 |                                                                                                |     |               |                                 |                      | INIT*,STROBE*,<br>AUTOFDXT*<br>I <sub>OH</sub> = -6.0 mA on all<br>other outputs                                         |
| I <sub>CC</sub><br>I <sub>LL</sub><br>R <sub>IN</sub>                                           | Avg power supply current<br>Input leakage<br>Clock leakage<br>Internal pull-up resistance      | 4   | 12            | ±10<br>±10<br>15                | mA<br>μA<br>μA<br>kΩ | *Marked pins                                                                                                             |

### **GENERAL WRITE TIMING**



### **GENERAL READ TIMING**



# **MODEM TIMING**



# **CLOCK TIMING**







### TXRDY TIMING FOR MODE "0"



### TXRDY TIMING FOR MODE "1"





### **RXRDY TIMING FOR MODE "0"**



# **RXRDY TIMING FOR MODE "1"**



3

# PARALLEL PORT GENERAL WRITE TIMING



### PARALLEL PORT READ TIMING





# ST16C553

3

Printed September 8, 1994

# UNIVERSAL ASYNCHRONOUS RECEIVER/TRANSMITTER WITH FIFO AND PARALLEL PRINTER PORT WITH 83 BYTE FIFO

### DESCRIPTION

The ST16C553 is a dual universal asynchronous receiver and transmitter with 16 byte transmit and receive FIFO and a bi-directional CENTRONICS type parallel printer port with 83 bytes of FIFO. A programmable baud rate generator is provided to select transmit and receive clock rates from 50Hz to 448kHz. The ST16C553 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C553 provides internal loopback capability for on board diagnostic testing. The ST16C553 is fabricated in an advanced 1.2 µ CMOS process to achieve low drain power and high speed requirements.

### **FEATURES**

- Pin to pin and functional compatible to VL16C552, WD16C552
- 16 byte transmit FIFO
- 16 byte receive FIFO with error flags
- 83 bytes of printer output FIFO
- Modem control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\*, CD\*)
- Programmable character lengths (5, 6, 7, 8)
- Even, odd, or no parity bit generation and detection
- Status report register
- Independent transmit and receive control
- TTL compatible inputs, outputs
- Software compatible with INS8250, NS16C550
- 448 kHz transmit/receive operation with 7.372 MHz crystal or external clock source.
- Bi-directional hardware/software parallel port
- Bi-directional I/O ports

### ORDERING INFORMATION

Part number ST16C553CJ68 ST16C553IJ68 Package PLCC Operating temperature 0° C to + 70° C

PLCC -40° C to + 85° C

# **PLCC Package**



**BLOCK DIAGRAM** 



| Symbol   | Pin   | Signal Type | Pin Description                                                                                                                                                                                                   |
|----------|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7    | 14-21 | I/O         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted. |
| A0-A2    | 35-33 | ı           | Address select lines. To select internal registers.                                                                                                                                                               |
| CLK      | 4     | 1           | Clock input. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                                                                       |
| BIDEN    | 1     | I           | Printer direction select. A high puts the parallel port in the input / output mode and low sets the ST16C553 to output mode.                                                                                      |
| IOW*     | 36    |             | Write strobe (active low). A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                                                                            |
| IOR*     | 37    |             | Read strobe (active low). A low level on this pin transfers the contents of the ST16C553 data bus to the CPU.                                                                                                     |
| RDOUT    | 44    | 0           | Read select out (active high). This pin goes high when the CPU is reading data from the ST16C553 to en/disable the external transceiver or logic's.                                                               |
| RESET*   | 39    | <b>I</b>    | Master reset (active low). A low on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time.                                 |
| CS A/B*  | 32,3  | . 1         | Chip select A/B (active low). A low at this pin enables the serial port-A/B / CPU data transfer operation.                                                                                                        |
| DSR A/B* | 31,5  | <b>l</b>    | Data set ready A/B (active low). A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation.                               |
| RI A/B*  | 30,6  |             | Ring detect indicator A/B (active low). A low on this pin indicates the modem has received a ringing signal from telephone line.                                                                                  |
| ÷,       |       | 4 · · · · · | toophone line.                                                                                                                                                                                                    |

| Symbol    | Pin                                                                                                                                                                                                                               | Signal Type     | Pin Description                                                                                                                                                                                                                               |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CD A/B*   | 29,8                                                                                                                                                                                                                              | <b>,</b>        | Carrier detect A/B (active low). A low on this pin indicates the carrier has been detected by the modern.                                                                                                                                     |  |
| TX A/B    | 26,10                                                                                                                                                                                                                             | 0               | Serial data output A/B. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback                                                        |  |
|           |                                                                                                                                                                                                                                   |                 | mode or when the transmitter is disabled.                                                                                                                                                                                                     |  |
| DTR A/B*  | 25,11                                                                                                                                                                                                                             | 0               | Data terminal ready A/B (active low). To indicate that ST16C553 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0).                                                                              |  |
|           |                                                                                                                                                                                                                                   |                 | Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation. |  |
| RTS A/B*  | 24,12                                                                                                                                                                                                                             | 0               | Request to send A/B (active low). To indicate that the transmitter has data ready to send. Writing a "1" in the                                                                                                                               |  |
| a y s     |                                                                                                                                                                                                                                   |                 | modem control register (MCR bit-1) will set this pin to a low<br>state. After the reset this pin will be set to high. Note that<br>this pin does not have any effect on the transmit or receive                                               |  |
|           |                                                                                                                                                                                                                                   |                 | operation.                                                                                                                                                                                                                                    |  |
| RX A/B    | 41,62                                                                                                                                                                                                                             |                 | Serial data input A/B. The serial information (data) receive from serial port to ST16C553 receive input circuit. A mai (high) is logic one and a space (low) is logic zero. During the                                                        |  |
|           |                                                                                                                                                                                                                                   |                 | local loopback mode the RX input is disabled from external connection and connected to the TX output internally.                                                                                                                              |  |
| CTS A/B*  | 28,13 m                                                                                                                                                                                                                           |                 | Clear to send A/B (active low). The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the                                                                          |  |
|           | i de la companya di seria di seria di seria di seria di seria di seria di seria di seria di seria di seria di s<br>Seria di seria                | transmit or receive operation.                                                                                                                                                                                                                |  |
| INT A/B   | 45,60                                                                                                                                                                                                                             | <b>O</b> 2 (14) | Interrupt output A/B (three state active high) This pin goes high (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter                                                             |  |
|           |                                                                                                                                                                                                                                   |                 | empty, or modem status condition flag is detected.                                                                                                                                                                                            |  |
| TXRDY A/B | 22,42                                                                                                                                                                                                                             | 0               | Transmit ready A/B (active high). This pin goes high when the transmit FIFO of the ST16C553 is full. It can be used as                                                                                                                        |  |

| Symbol     | Pin   | Signal Type | Pin Description                                                                                                                                                              |
|------------|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | -     |             | a single or multi-transfer.                                                                                                                                                  |
| RXRDY A/B* | 9,61  | 0           | Receive ready A/B (active low). This pin goes low when the receive FIFO is full. It can be used as a single or multitransfer.                                                |
| CSP*       | 38    | 1           | Parallel printer port chip select (active low). A low at this pin enables the parallel port / CPU data transfer operation.                                                   |
| PD7-PD0    | 46-53 | I/O         | Bi-directional parallel ports (three state). To transfer data in or out of the ST16C553 parallel port. PD7-PD0 are latched during output mode.                               |
| STROBE*    | 55*   | I/O         | General purpose I/O or data strobe output (open drain active low). This output indicates to the printer that valid data is available at the printer port (PD0-PD7).          |
| AUTOFDXT*  | 56*   | I/O         | General purpose I/O or automatic line feed (open drain active low). When this pin this signal is low, the printer should automatically line feed after each line is printed. |
| INIT       | 57*   | I/O         | General purpose I/O or line printer initialize (open drain active high). To signal the line printer to enter internal initialization routine.                                |
| SLCTIN*    | 58*   | 1/0         | General purpose I/O or line printer select (open drain active low). When this signal is low, it selects the printer.                                                         |
| ERROR*     | 63*   | 1           | General purpose input or line printer error (active low). This is an output from the printer to indicate an error by holding it low during error condition.                  |
| SLCT       | 65*   | 1           | General purpose input or line printer selected (active high). This is an output from the printer to indicate that the line printer has been selected.                        |
| BUSY       | 66*   | 1           | General purpose input or line printer busy (active high). An output from the printer to indicate printer is not ready to accept data.                                        |
|            |       |             |                                                                                                                                                                              |

| Symbol  | Pin       | Signal Type | Pin Description                                                                                                                                                                                                                                                  |
|---------|-----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PE      | 67*       | · I         | General purpose input or line printer paper empty (active high). An output from the printer to indicate out of paper.                                                                                                                                            |
| ACK*    | 68*       | <b>I</b>    | General purpose input or line printer acknowledge (active low). This input is pulsed low by the printer to indicate that data has been accepted successfully.                                                                                                    |
| INTP*   | 59        | 0           | Printer interrupt output (active low). To signal the state of the printer port. This pin tracks the ACK* input pin, When ACK* is low INTP is low and when ACK* is high INTP is high                                                                              |
| INTSEL* | <b>43</b> |             | Interrupt select mode. The external ACK* can be selected as an interrupt source by connecting this pin to the GND. Connecting this pin to VCC will set the interrupt to latched mode, reading the status register of the printer section resets the INTP output. |
| GND     | 2,7,54    | O           | Signal and power ground.                                                                                                                                                                                                                                         |
| vcc     | 23,40,64  | 1 4         | Power supply input.                                                                                                                                                                                                                                              |

<sup>\*</sup> Have internal pull-up resistor on inputs

# PROGRAMMING TABLE FOR SERIAL PORTS

| A2  | A1 | A0 | READ MODE                 | WRITE MODE                |
|-----|----|----|---------------------------|---------------------------|
| 0   | 0  | 0  | Receive Holding Register  | Transmit Holding Register |
| 0   | 0  | 1  |                           | Interrupt Enable Register |
| 0   | 1  | 0  | Interrupt Status Register | FIFO Control Register     |
| 0   | 1  | 1  |                           | Line Control Register     |
| 1 1 | 0  | 0  |                           | Modem Control Register    |
| 1 1 | 0  | 1  | Line Status Register      |                           |
| 1   | 1  | 0  | Modem Status Register     |                           |
| 1   | 1  | 1  | Scratchpad Register       | Scratchpad Register       |
| 0   | 0  | 0  |                           | LSB of Divisor Latch      |
| 0   | 0  | 1  | *                         | MSB of Divisor Latch      |
|     |    |    |                           |                           |

# **ST16C553 ACCESSIBLE REGISTERS A/B**

| A2 | A1 | A0 | Register | BIT-7                      | BIT-6                    | BIT-5                      | BIT-4              | BIT-3                        | BIT-2                     | BIT-1                                        | BIT-0                          |
|----|----|----|----------|----------------------------|--------------------------|----------------------------|--------------------|------------------------------|---------------------------|----------------------------------------------|--------------------------------|
| 0  | 0  | 0  | RHR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                     | bit-1                                        | bit-0                          |
| 0  | 0  | 0  | THR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                     | bit-1                                        | bit-0                          |
| 0  | 0  | 1  | IER      | 0                          | 0                        | 0                          | 0                  | modem<br>status<br>interrupt | receive<br>line<br>status | transmit<br>holding<br>register<br>interrupt | receive<br>holding<br>register |
| 0  | 1  | 0  | FCR      | RCVR<br>trigger<br>(MSB)   | RCVR<br>trigger<br>(LSB) | 0                          | 0                  | DMA<br>mode<br>select        | XMIT<br>FIFO<br>reset     | RCVR<br>FIFO<br>reset                        | FIFO<br>enable                 |
| 0  | 1  | 0  | ISR      | 0/<br>FIFOs<br>enabled     | 0/<br>FIFOs<br>enabled   | 0                          | 0                  | int<br>priority<br>bit-2     | int<br>priority<br>bit-1  | int<br>priority<br>bit-0                     | int<br>status                  |
| 0  | 1  | 1  | LCR      | divisor<br>latch<br>enable | set<br>break             | set<br>parity              | even<br>parity     | parity<br>enable             | stop<br>bits              | word<br>length<br>bit-1                      | word<br>length<br>bit-0        |
| 1  | 0  | 0  | MCR      | 0                          | 0                        | 0                          | loop<br>back       | INT<br>enable                | not<br>used               | RTS*                                         | DTR*                           |
| 1  | 0  | 1  | LSR      | 0/<br>FIFO<br>error        | trans.<br>empty          | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error             | parity<br>error           | overrun<br>error                             | receive<br>data<br>ready       |
| 1  | 1  | 0  | MSR      | CD                         | RI                       | DSR                        | стѕ                | delta<br>CD*                 | delta<br>RI*              | delta<br>DSR*                                | delta<br>CTS*                  |
| 1  | 1  | 1  | SPR      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                     | bit-1                                        | bit-0                          |
| 0  | 0  | 0  | DLL      | bit-7                      | bit-6                    | bit-5                      | bit-4              | bit-3                        | bit-2                     | bit-1                                        | bit-0                          |
| 0  | 0  | 1  | DLM      | bit-15                     | bit-14                   | bit-13                     | bit-12             | bit-11                       | bit-10                    | bit-9                                        | bit-8                          |

DLL and DLM are accessible only when LCR bit-7 is set to "1".

### REGISTER FUNCTIONAL DESCRIPTIONS

### TRANSMIT AND RECEIVE HOLDING REGISTER

The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set.

On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register.

### FIFO INTERRUPT MODE OPERATION

When the receive FIFO (FCR BIT-0=1) and receive interrupts (IER BIT-0=1) are enabled, receiver interrupt will occur as follows:

- A) The receive data available interrupts will be issued to the CPU when the FIFO has reached its programmed trigger level; it will be cleared as soon as the FIFO drops below its programmed trigger level.
- B) The ISR receive data available indication also occurs when the FIFO trigger level is reached, and like the interrupt it is cleared when the FIFO drops below the trigger level.
- C) The data ready bit (LSR BIT-0) is set as soon as a character is transferred from the shift register to the receiver FIFO. It is reset when the FIFO is empty.

### FIFO POLLED MODE OPERATION

When FCR BIT-0=1; resetting IER BIT 3-0 to zero puts the ST16C553 in the FIFO polled mode of operation. Since the receiver and transmitter are controlled separately either one or both can be in the polled mode operation by utilizing the Line Status Register.

- A) LSR BIT-0 will be set as long as there is one byte in the receive FIFO.
- B) LSR BIT4-1 will specify which error(s) has occurred.
- C) LSR BIT-5 will indicate when the transmit FIFO is empty.
- D) LSR BIT-6 will indicate when both transmit FIFO and transmit shift register are empty.
- E) LSR BIT-7 will indicate when there are any errors in the receive FIFO.

The ST16C553 requires to have two step FIFO enable operation in order to enable receive trigger levels.

### PROGRAMMABLE BAUD RATE GENERATOR

The ST16C553 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-8 MHz and dividing it by any divisor from 1 to 2<sup>16</sup> -1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator.

### INTERRUPT ENABLE REGISTER (IER)

The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the INT output pin.

### IER BIT-0:

0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt.

### IER BIT-1:

0=disable the transmitter empty interrupt. 1=enable the transmitter empty interrupt.

### IER BIT-2:

0=disable the receiver line status interrupt. 1=enable the receiver line status interrupt.

### IER BIT-3:

0=disable the modern status register interrupt. 1=enable the modern status register interrupt.

### **IER BIT 7-4:**

All these bits are set to logic zero.

### **INTERRUPT STATUS REGISTER (ISR)**

The ST16C553 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C553 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels:

### **Priority level**

| Р  | D3 | D2 | D1 | D0 | Source of the interrupt                    |
|----|----|----|----|----|--------------------------------------------|
| 1  | 0  | 1  | 1  | 0  | LSR (Receiver Line Status Register)        |
| 2  | 0  | 1  | 0  | 0  | RXRDY (Received Data<br>Ready)             |
| 2* | 1  | 1  | 0  | 0  | RXRDY (Receive Data time out)              |
| 3  | 0  | 0  | 1  | 0  | TXRDY( Transmitter Holding Register Empty) |
| 4  | 0  | 0  | 0  | 0  | MSR (Modern Status<br>Register)            |

### \*RECEIVE TIME-OUT:

This mode is enabled when STARTECH UART is operating in FIFO mode. Receive time out will not occur if the receive FIFO is empty. The time out counter will be reset at the center of each stop bit received or each time receive holding register is read. The actual time out value is T (Time out length in bits)= 4 X P (Programmed word length) + 12. To convert time out value to a character value, user has to divide this number to its complete word length + parity (if used) + number of stop bits and start bit.

Example -A: If user programs the word length = 7, and no parity and one stop bit, Time out will be:

T = 4 X 7( programmed word length) +12 = 40 bits

Character time = 40 / 9 [ (programmed word length = 7) + (stop bit = 1) + (start bit = 1)] = 4.4 characters.

Example -B: If user programs the word length = 7, with parity and one stop bit, the time out will be:  $T = 4 \times 7$  (programmed word length) + 12 = 40 bits Character time = 40 / 10 [ (programmed word length = 7) + (parity = 1) + (stop bit = 1) + (start bit = 1) = 4 characters.

### ISR BIT-0:

0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine.

1=no interrupt pending.

### **ISR BIT 1-3:**

Logical combination of these bits, provides the highest priority interrupt pending.

### **ISR BIT 4-7:**

These bits are not used and are set to zero in ST16C450 mode. BIT 6-7: are set to "1" in ST16C553 mode.

### FIFO CONTROL REGISTER (FCR)

This register is used to enable the FIFOs, clear the FIFOs, set the receiver FIFO trigger level, and select the type of DMA signaling.

### FCR BIT-0:

0=Disable the transmit and receive FIFO.

1=Enable the transmit and receive FIFO.

This bit should be enabled before setting the FIFO trigger levels.

### FCR BIT-1:

0=No change.

1=Clears the contents of the receive FIFO and resets its counter logic to 0 (the receive shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

### FCR BIT-2:

0=No change.

1=Clears the contents of the transmit FIFO and resets its counter logic to 0 (the transmit shift register is not cleared or altered). This bit will return to zero after clearing the FIFOs.

### FCR BIT-3:

0=No change.

1=Changes RXRDY and TXRDY pins from mode "0" to mode "1".

### Transmit operation in mode "0":

When ST16C553 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) when there are no characters in the transmit FIFO or transmit holding register, the TXRDY\* pin will go low. Once active the TXRDY\* pin will go high (inactive) after the first character is loaded into the transmit holding register.

### Receive operation in mode "0":

When ST16C553 is in ST16C450 mode (FCR bit-0=0) or in the FIFO mode (FCR bit-0=1, FCR bit-3=0) and there is at least 1 character in the receive FIFO, the RXRDY\* pin will go low. Once active the RXRDY\* pin will go high (inactive) when there are no more characters in the receiver.

### Transmit operation in mode "1":

When ST16C553 is in ST16C550 mode (FCR bit-0=1, FCR bit-3=1) the TXRDY\* pin will become high (inactive) when the transmit FIFO is completely full. It will be low if one or more FIFO locations are empty.

### Receive operation in mode "1":

When ST16C553 is in ST16C550 mode (FCR bit-0=1, FCR bit-3=1) and the trigger level or the timeout has been reached, the RXRDY\* pin will go low. Once it is activated it will go high (inactive) when there are no more characters in the FIFO.

### **FCR BIT 4-5:**

Not used.

### FCR BIT 6-7:

These bits are used to set the trigger level for the receiver FIFO interrupt.

| BIT-7 | BIT-6 | FIFO trigger level |
|-------|-------|--------------------|
| 0     | 0     | 01                 |
| 0     | 1     | 04                 |
| 1     | 0     | 08                 |
| -1    | 1     | 14                 |

### LINE CONTROL REGISTER (LCR)

The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register.

### LCR BIT1-0:

These two bits specify the word length to be transmitted or received.

| BIT-1 | BIT-0  | Word length |
|-------|--------|-------------|
| 0     | 0      | 5           |
| 0     | 1      | 6           |
| 1     | 0      | 7           |
| 1:0   | :;: 1; | 8           |

### LCR BIT-2:

The number of stop bits can be specified by this bit.

| BIT-2 | Word length | Stop bit(s) |
|-------|-------------|-------------|
| 0     | 5,6,7,8     | 1           |
| 1     | 5           | 1-1/2       |
| 1     | 6,7,8       | 2           |

### LCR BIT-3:

Parity or no parity can be selected via this bit. 0=no parity

1=a parity bit is generated during the transmission, receiver also checks for received parity.

### LCR BIT-4:

If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format.

0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format.

1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format.

### LCR BIT-5:

If the parity bit is enabled, LCR BIT-5 selects the forced parity format.

LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data.

LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data.

### LCR BIT-6:

Break control bit. It causes a break condition to be transmitted (the TX is forced to low state).

0=normal operating condition.

1=forces the transmitter output (TX) to go low to alert the communication terminal.

### LCR BIT-7:

The internal baud rate counter latch enable (DLEN). 0=normal operation.

1=select divisor latch register.

### MODEM CONTROL REGISTER (MCR)

This register controls the interface with the MODEM or a peripheral device (RS232).

### MCR BIT-0:

0=force DTR\* output to high. 1=force DTR\* output to low.

### MCR BIT-1:

0=force RTS\* output to high. 1=force RTS\* output to low.

### MCR BIT-2:

Not used.

### MCR BIT-3:

0=set INT output pin to three state mode. 1=set INT output pin to normal / active operating mode.

### MCR BIT-4:

0=normal operating mode.

1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, MCR bit-2 and INT enable are connected to modem control inputs.

In this mode, the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER.

### MCR BIT 5-7:

Not used. Are set to zero permanently.

### LINE STATUS REGISTER (LSR)

This register provides the status of data transfer to CPU.

### LSR BIT-0:

0=no data in receive holding register or FIFO. 1=data has been received and saved in the receive holding register or FIFO.

### LSR BIT-1:

0=no overrun error (normal).

1=overrun error, next character arrived before receive holding register was emptied or if FIFOs are enabled, an overrun error will occur only after the FIFO is full and the next character has been completely received in the shift register. Note that character in the shift register is overwritten, but it is not transferred to the FIFO.

### LSR BIT-2:

0=no parity error (normal).

1=parity error, received data does not have correct parity information. In the FIFO mode this error is associated with the character at the top of the FIFO.

### LSR BIT-3:

0=no framing error (normal).

1=framing error received, received data did not have a valid stop bit. In the FIFO mode this error is associated with the character at the top of the FIFO.

### LSR BIT-4:

0=no break condition (normal).

1=receiver received a break signal (RX was low for one character time frame). In FIFO mode, only one zero character is loaded into the FIFO.

### LSR BIT-5:

0=transmit holding register is full. ST16C553 will not accept any data for transmission.

1=transmit holding register (or FIFO ) is empty. CPU can load the next character.

### LSR BIT-6:

0=transmitter holding and shift registers are full.
1=transmitter holding and shift registers are empty. In

FIFO mode this bit is set to one whenever the transmitter FIFO and transmit shift register are empty.

### LSR BIT-7:

0=Normal.

1=At least one parity error, framing error or break indication in the FIFO. This bit is cleared when LSR is read

### **MODEM STATUS REGISTER (MSR)**

This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register.

### MSR BIT-0:

Indicates that the CTS\* input to the ST16C553 has changed state since the last time it was read.

### MSR BIT-1:

Indicates that the DSR\* input to the ST16C553 has changed state since the last time it was read.

### MSR BIT-2:

Indicates that the RI\* input to the ST16C553 has changed from a low to a high state.

### MSR BIT-3:

Indicates that the CD\* input to the ST16C553 has changed state since the last time it was read.

### MSR BIT-4:

This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input.

### MSR BIT-5:

This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input.

### MSR BIT-6:

This bit is equivalent to MCR bit-2 during local loop-

### MSR BIT-7:

This bit is equivalent to INT enable in the MCR during local loop-back mode. It is the compliment to the CD\* input.

Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated.

### SCRATCHPAD REGISTER (SR)

ST16C553 provides a temporary data register to store 8 bits of information for variable use.

### ST16C553 EXTERNAL RESET CONDITION

| REGISTERS | RESET STATE                 |
|-----------|-----------------------------|
| IER       | IER BITS 0-7=0              |
| ISR       | ISR BIT-0=1, ISR BITS 1-7=0 |
| LCR       | LCR BITS 0-7=0              |
| MCR       | MCR BITS 0-7=0              |
| LSR       | LSR BITS 0-4=0,             |
|           | LSR BITS 5-6=1 LSR, BIT 7=0 |
| MSR       | MSR BITS 0-3=0,             |
|           | MSR BITS 4-7=input signals  |
| FCR       | FCR BITS 0-7=0              |
| AFR       | AFR BIT 0-7=0               |

# BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK):

| BAUD RATE | 16 x CLOCK<br>DIVISOR | % ERROR |
|-----------|-----------------------|---------|
| 50        | 2304                  |         |
| 110       | 1047                  | 0.026   |
| 150       | 768                   |         |
| 300       | 384                   | l l     |
| 600       | 192                   |         |
| 1200      | 96                    |         |
| 2400      | 48                    |         |
| 4800      | 24                    | ŀ       |
| 7200      | 16                    |         |
| 9600      | 12                    |         |
| 19.2K     | 6                     |         |
| 38.4K     | 3                     | 1       |
| 56K       | . 2                   | 2.77    |
| 115.2K    | 1                     | \       |

| RESET STATE      |
|------------------|
| High             |
| High             |
| High             |
| Three state mode |
| High             |
| Low              |
|                  |

### PRINTER PORT PROGRAMMING TABLE:

| A1               | A0               | IOW*                                                                           | IOR*                                                                      |
|------------------|------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | PORT REGISTER I/O SELECT REGISTER CONTROL REGISTER ALTERNATE FUNCTION REGISTER | PORT REGISTER STATUS REGISTER * COMMAND REGISTER FIFO BYTE COUNT REGISTER |

<sup>\*</sup> Reading the status register will reset the INTP output.

### PRINTER FUNCTIONAL DESCRIPTION

The ST16C553 parallel port is designed to operate as a normal CENTRONICS printer interface. The port contains 83 byte FIFO that may be enabled via bit-7 of the Alternate Function Register (AFR). After reset, the FIFO is disabled and the part will function identical to the ST16C552. Once the FIFO is enabled via AFR bit-7, the port will enter FIFO mode after the first byte of data is strobed to the printer and the printer responds with either an ACK\* or BUSY signal.

The ST16C553 will remain in FIFO mode until the part is reset or INIT is brought low. While in FIFO mode, data transfer to the printer will be controlled by the printer without any user intervention. The printer port also contains a FIFO byte counter that maintains a count of the number of bytes remaining in the FIFO. The FIFO and the FIFO byte counter are cleared by a reset or by a change of state of the INIT pin. All FIFO related timing is derived from the clock input to pin 4 of the part.

A special parallel port write / read mode is activated when INIT is held low, either by writing a "0" to Control Register bit-2 or by forcing the INIT pin low. In this mode the FIFO read pointer is advanced by reading the parallel port instead of the ACK\* or BUSY signals. The STROBE\* output is forced high. This allows the user to perform write to parallel port and read from parallel port operations without strobing data to the printer.

Following an INIT, the parallel port will not be in the FIFO mode. Control Register bit-0 is used as the STROBE\*, Status Register bit-7 is the inverse of the BUSY signal, and INTP\* is derived from ACK\*. The transition into FIFO mode will occur after the first STROBE\* is generated and the printer responds with either an ACK\* or BUSY. In FIFO mode, STROBE\* is generated automatically and writing to Control Register bit-0 has no effect on STROBE\*. Alternate Function Register bit 0-2 are used to control the delay and width of STROBE\*. Handshaking between the printer and the ST16C553 may be controlled by bit-3 of the Alternate Function Register. Setting this bit to a "1" will result in the use of BUSY instead of ACK\* for FIFO

reading and interrupt control. INTP\* will transition low when a "1" is written to Control Register bit-0 and will transition high when a write to parallel port is performed. In FIFO mode, data transfer to the printer will be controlled by the printer and will occur at the printer's maximum data rate.

The FIFO byte counter is incremented one count for each parallel port write and decremented one count for each FIFO read (data taken by printer). A FIFO read will be generated at the falling edge of either ACK\* or BUSY. The byte counter will require two to three clock cycles to update. Hence, a read to Fifo Byte Count Register (FBCR) should only be performed minimum of three clock after the falling edge of either ACK\* or BUSY. The counter is reset whenever the FIFO is reset. If write to parallel port operation is attempted when the FIFO is full, the data will not be written into the FIFO and the counter will not increment.

Two interrupt modes are available and are selected with the INTSEL\* pin. If this pin is tied high, a latched interrupt will result. In this mode, INTP\* will transition low when a "1" is written to Control Register bit-0. A reset or reading the Status Register will clear the interrupt. If INTSEL\* pin is tied low, INTP\* will transition low when a "1" is written to Control Register bit-0 and will transition high when a write to the parallel port is issued. This (non-latched) interrupt signal is always available in Status Register bit-6 regardless of the state of the INTSEL\* pin. Status Register bit-2 will always contain the latched interrupt state. The polarity of the INTP\* pin may be inverted by setting Alternate Function Register bit-6 high.

The ST16C553 provides additional programmable interrupt output options by programming the Alternate Function Register bit 4-5. INTP\* output can be selected as FIFO full or FIFO empty interrupt.

### PRINTER PORT REGISTER DESCRIPTIONS

### PORT REGISTER

Bi-directional printer port.

Writing to this register during output mode will transfer the contents of the data bus to the PD7-PD0 ports. Reading this register during input mode will transfer the states of the PD7-PD0 to the data bus. This register will be set to the output mode after reset.

### PR BIT 7-0:

PD7-PD0 bi-directional I/O ports.

### **STATUS REGISTER**

This register provides the state of the printer outputs and the interrupt condition.

### SR BIT 1-0:

This bit is set to "1" normally except when interrupt is selected as FIFO empty via AFR.

### SR BIT-2:

Interrupt condition.

0= an interrupt is pending

This bit will be set to "0" at the falling edge of the ACK\* input.

1= no interrupt is pending

Reading the STATUS REGISTER will set this bit to "1".

### SR BIT-3:

ERROR input state.

0= ERROR input is in low state

1= ERROR input is in high state

### SR BIT-4:

SLCT input state.

0= SLCT input is in low state

1= SLCT input is in high state

### SR BIT-5:

PE input state.

0= PE input is in low state

1= PE input is in high state

### SR BIT-6:

ACK\* input state.
0= ACK\* input is in low state
1= ACK\* input is in high state

### SR BIT-7:

BUSY or FIFO full/ FIFO empty signal.

ST16C552 mode (FIFO is not enabled). 0= BUSY input is in high state 1= BUSY input is in low state

FIFO is enabled.

0= FIFO is full

1= One or more empty locations in FIFO

### **COMMAND REGISTER**

The state of the STROBE\*, AUTOFDXT\*, INIT, SLCTIN\* pins, and interrupt enable bit can be read by this register regardless of the I/O direction.

### COM BIT-0:

STROBE\* input pin.
0= STROBE\* pin is in high state
1= STROBE\* pin is in low state

### COM BIT-1:

AUTOFDXT\* input pin.
0= AUTOFDXT\* pin is in high state
1= AUTOFDXT\* pin is in low state

### COM BIT-2:

INIT input pin.
0= INIT pin is in low state
1= INIT pin is in high state

### COM BIT-3:

SLCTIN\* input pin. 0= SLCTIN\* pin is in high state 1= SLCTIN\* pin is in low state

### COM BIT-4:

Interrupt mask.

0= Interrupt (INTP output) is disabled 1= Interrupt (INTP output) is enabled

### **COM BIT 7-5:**

Not used. Are set to "1" permanently.

### CONTROL REGISTER.

Writing to this register will set the state of the STROBE\*, AUTOFDXT\*, INIT, SLCTIN pins, and interrupt mask register.

### CON BIT-0:

STROBE\* output control bit.

0= STROBE\* output is set to high state

1= STROBE\* output is set to low state

### CON BIT-1:

AUTOFDXT\* output control bit.

0= AUTOFDXT\* output is set to high state

1= AUTOFDXT\* output is set to low state

### CON BIT-2:

INIT output control bit.

0= INIT output is set to low state

1= INIT output is set to high state

### CON BIT-3:

SLCTIN\* output control bit.

0= SLCTIN\* output is set to high state

1= SLCTIN\* output is set to low state

### CON BIT-4:

Interrupt output control bit.

0= INTP output is disabled (three state mode)

1= INTP output is enabled

### CON BIT-5:

I/O select. Direction of the PD7-PD0 can be selected by setting or clearing this bit.

0= PD7-PD0 are set for output mode

1= PD7-PD0 are set for input mode

### **CON BIT 7-6:**

Not used.

### **ALTERNATE FUNCTION REGISTER (AFR)**

This register En/Disables FIFO operation and provides additional capabilities to control STROBE\*. INTP\* and change interrupt functions.

### AFR BIT 0-2:

Timing select.

The STROBE\* delay and width can be controlled by these bits.

| AFR<br>Bit-1 | AFR<br>Bit-0               | TSD<br>(clocks) | TSW<br>(clocks)                                                                                                                                                                                                                                                        |
|--------------|----------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0            | 0                          | 3               | 2                                                                                                                                                                                                                                                                      |
| . 0          | 1                          | 5               | 4                                                                                                                                                                                                                                                                      |
| 1            | 0                          | 5               | 4                                                                                                                                                                                                                                                                      |
| 1            | 1                          | 9               | - 8                                                                                                                                                                                                                                                                    |
| 0            | 0                          | 6               | 4                                                                                                                                                                                                                                                                      |
| 0            | 1                          | 10              | 8                                                                                                                                                                                                                                                                      |
| 1            | 0                          | 10              | 8                                                                                                                                                                                                                                                                      |
| 1            | 1                          | 18              | 16                                                                                                                                                                                                                                                                     |
|              | ASSESSMENT OF THE PARTY OF | Bit-1 Bit-0     | Bit-1         Bit-0         (clocks)           0         0         3           0         1         5           1         0         5           1         1         9           0         0         6           0         1         10           1         0         10 |

### AFR BIT-3:

Interrupt source.

0= ACK\* input pin is selected as printer handshaking source

1= BUSY input pin is selected as printer handshaking source

### **AFR BIT 4-5:**

Interrupt type. State of the INTP\* output pin can be selected for one of the following options.

| Bit-5 | Bit-4 | INTP* output | SR<br>bit-0 | SR<br>bit-6 |
|-------|-------|--------------|-------------|-------------|
| 0     | 0     | Normal mode  | 1           | BUSY*       |
| 0     | 1     | FIFO empty   | 1           | FIFO empty  |
| 1     | 0     | FIFO full    | 1           | FIFO full   |
| 1     | 1     | FIFO empty   | 0           | FIFO empty  |

### AFR BIT-6:

INTP\* output polarity.

0= Normal. INTP\* output follows the ACK\* input

1= Inverted INTP\* output

### AFR BIT-7:

FIFO enable / disable function.

0= FIFO is disabled( default mode). The ST16C552 compatible mode.

1= FIFO is enabled. Internal 83 byte of FIFO is enabled.

### FIFO BYTE COUNT REGISTER (FBCR)

State and content of the printer FIFO can be monitored by reading this register.

### FCBR BIT 0-6:

FIFO byte count. Number of characters left in FIFO.

### FBCR BIT-7:

FIFO state.

0= FIFO is enabled

1= FIFO is disabled

### I/O SELECT REGISTER

Software controlled I/O select.

Bi-directional mode can be selected by keeping the BIDEN input in high state and setting CON BIT-5 to "zero or one"

Hardware/software I/O select.

Bi-directional mode can be selected by keeping the BIDEN input in low state and setting I/O SELECT register to "AA" Hex for input or "55" Hex for output.

### ST16C553 EXTERNAL RESET CONDITION

| SIGNALS   | RESET STATE       |
|-----------|-------------------|
| PD0-PD7   | Low, output mode  |
| STROBE*   | High, output mode |
| AUTOFDXT* | High, output mode |
| INIT      | Low, output mode  |
| SLCTIN*   | High, output mode |

### PARALLEL PORT DIRECTION SELECT REGISTER (WRITE ONLY)

| CONTROL REGISTER (D5) | BIDEN | I/O SELECT REGISTER | PORT DIRECTION            |
|-----------------------|-------|---------------------|---------------------------|
| ×                     | 0     | AA Hex<br>55 Hex    | Input mode<br>Output mode |
| ) ô                   | 1     | X                   | Output mode Output mode   |
| 1                     | 1     | X                   | Input mode                |

# **ST16C553 PRINTER PORT REGISTER CONFIGURATIONS**

| A2 | 2 / | <b>\1</b> | Α0 | REGISTER | D7                              | D6                | D5                   | D4                   | D3              | D2                        | D1                        | D0                        |
|----|-----|-----------|----|----------|---------------------------------|-------------------|----------------------|----------------------|-----------------|---------------------------|---------------------------|---------------------------|
| X  |     | 0         | 0  | PR       | PD7                             | PD6               | PD5                  | PD4                  | PD3             | PD2                       | PD1                       | PD0                       |
| X  |     | 0         | 1  | STR      | BUSY*/<br>Alternate<br>function | ACK               | PE                   | SLCT                 | ERROR           | IRQ                       | 1                         | 1                         |
| Х  |     | 0         | 1  | 1/0      | bit-7                           | bit-6             | bit-5                | bit-4                | bit-3           | bit-2                     | bit-1                     | bit-0                     |
| X  |     | 1         | 0  | СОМ      | 1                               | 1                 | 1                    | IRQ<br>state         | SLCTIN*         | INIT                      | AUTO-<br>FDXT*            | STROBE*                   |
| X  |     | 1         | 0  | CON      | 1                               | 1                 | I/O<br>select        | IRQ<br>mask          | SLCTIN*         | INIT                      | AUTO-<br>FDXT             | STROBE*                   |
| Х  |     | 1         | 1  | AFR      | FIFO<br>enable                  | INTP*<br>polarity | IRQ<br>type<br>bit-1 | IRQ<br>type<br>bit-0 | INTP*<br>source | TIMING<br>select<br>bit-2 | TIMING<br>select<br>bit-1 | TIMING<br>select<br>bit-0 |
| Х  |     | 1         | 1  | FBCR     | FIFO*<br>status                 | FBC-6             | FBC-5                | FBC-4                | FBC-3           | FBC-2                     | FBC-1                     | FBC-0                     |

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                  | Parameter                                      | Min | Limits<br>Typ | Max               | Units | Conditions     |
|-----------------------------------------------------------------------------------------|------------------------------------------------|-----|---------------|-------------------|-------|----------------|
| Т,                                                                                      | Clock high pulse duration                      | 50  |               |                   | ns    |                |
| T.                                                                                      | Clock low pulse duration                       | 50  |               |                   | ns    | External clock |
| T,                                                                                      | Clock rise/fall time                           |     |               | 10                | ns    |                |
| T <sub>2</sub><br>T <sub>3</sub><br>T <sub>8</sub><br>T <sub>9</sub><br>T <sub>11</sub> | Chip select setup time                         | 5   |               |                   | ns    | •              |
| T <sub>o</sub>                                                                          | Chip select hold time                          | 0   |               |                   | ns    |                |
| T,,                                                                                     | IOR* to DDIS* delay                            |     | ]             | 25                | ns    | 100 pF load    |
| T.,                                                                                     | Data setup time                                | 15  | 1 1           |                   | ns    |                |
| T.,                                                                                     | Data hold time                                 | 15  |               |                   | ns    |                |
| 1 14                                                                                    | IOW* delay from chip select                    | 10  |               |                   | ns    |                |
| T <sub>15</sub>                                                                         | IOW* strobe width                              | 50  |               |                   | ns    |                |
| T <sub>16</sub>                                                                         | Chip select hold time from IOW*                | 0   |               |                   | ns    |                |
| T <sub>17</sub>                                                                         | Write cycle delay                              | 55  |               |                   | ns    |                |
| Tw                                                                                      | Write cycle=T <sub>15</sub> +T <sub>17</sub>   | 105 |               |                   | ns    | N. Carlotte    |
| T <sub>19</sub>                                                                         | Data hold time                                 | 15  |               |                   | ns    |                |
| T <sub>21</sub>                                                                         | IOR* delay from chip select                    | 10  |               |                   | ns    |                |
| T <sub>23</sub>                                                                         | IOR* strobe width                              | 65  |               |                   | ns    |                |
| T <sub>24</sub>                                                                         | Chip select hold time from IOR*                | 0   |               |                   | ns    |                |
| T <sub>25</sub>                                                                         | Read cycle delay                               | 55  |               |                   | ns    |                |
| Tr                                                                                      | Read cycle=T <sub>23</sub> +T <sub>25</sub>    | 115 | - 1           |                   | ns    |                |
| T <sub>26</sub>                                                                         | Delay from IOR* to data                        |     |               | 35                | ns    | 100 pF load    |
| T <sub>28</sub>                                                                         | Delay from IOW* to output                      |     | i i           | 50                | ns    | 100 pF load    |
| T <sub>29</sub>                                                                         | Delay to set interrupt from MODEM input        | :   |               | 70                | ns    | 100 pF load    |
| T <sub>30</sub>                                                                         | Delay to reset interrupt from IOR*             |     | 1 1           | 70                | ns    | 100 pF load    |
| T <sub>31</sub>                                                                         | Delay from stop to set interrupt               |     |               | 1 <sub>Rclk</sub> | ns    | 100 pF load    |
| T <sub>32</sub>                                                                         | Delay from IOR* to reset interrupt             |     |               | 200               | ns    | 100 pF load    |
| T <sub>33</sub>                                                                         | Delay from initial INT reset to transmit start | 8   |               | 24                | *     |                |
| T <sub>34</sub>                                                                         | Delay from stop to interrupt                   |     |               | 100               | ns    | •              |
| T <sub>35</sub>                                                                         | Delay from IOW* to reset interrupt             |     |               | 175               | ns    |                |
| T <sub>39</sub>                                                                         | ACK* pulse width                               | 75  | 1 1           |                   | ns    | Į v            |
| T <sub>40</sub>                                                                         | PD7 - PD0 setup time                           | 10  |               |                   | ns    |                |

3

# AC ELECTRICAL CHARACTERISTICS

 $T_A$ =0° - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                                                                          | Parameter                                                                                                                                                                                                            | Min          | Limits<br>Typ | Max                                | Units                      | Conditions |
|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------------|------------------------------------|----------------------------|------------|
| T <sub>41</sub> T <sub>42</sub> T <sub>43</sub> T <sub>44</sub> T <sub>45</sub> T <sub>46</sub> T <sub>47</sub> | PD7 - PD0 hold time Delay from ACK* low to interrupt low Delay from IOR* to reset interrupt Delay from stop to set RxRdy Delay from IOR* to reset RxRdy Delay from IOW* to set TxRdy Delay from start to reset TxRdy | 25<br>5<br>5 |               | 1 <sub>RCLK</sub><br>1<br>195<br>8 | ns<br>ns<br>ns<br>μs<br>ns |            |
| N                                                                                                               | Baud rate devisor                                                                                                                                                                                                    | 1            |               | 2 <sup>16</sup> -1                 | e                          |            |

Note 1 \* = Baudout\* cycle

# **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

# DC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

|  |  | ************************************** |
|--|--|----------------------------------------|
|  |  |                                        |

| Symbol                              | Parameter                                                                                      | Min                        | Limits<br>Typ | Max                             | Units            | Conditions                                                                                                                                                                  |
|-------------------------------------|------------------------------------------------------------------------------------------------|----------------------------|---------------|---------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VILCK<br>VIHCK<br>VIL<br>VIH<br>VOL | Clock input low level Clock input high level Input low level Input high level Output low level | -0.5<br>3.0<br>-0.5<br>2.2 |               | 0.6<br>VCC<br>0.8<br>VCC<br>0.4 | V<br>V<br>V      | I <sub>ol</sub> = 6.0 mA D7-D0<br>I <sub>ol</sub> = 15mA PD7-<br>PD0<br>I <sub>ol</sub> = 6.0 mA on all<br>other outputs                                                    |
| V <sub>oH</sub>                     | Output high level                                                                              | 2.4                        |               |                                 | <b>V</b>         | $I_{OH}$ = -6.0 mA D7-D0<br>$I_{OH}$ = -12.0 mA<br>PD7-PD0<br>$I_{OH}$ = -150 $\mu$ A<br>SLCTIN*,<br>INIT*,STROBE*,<br>AUTOFDXT*<br>$I_{OH}$ = -6.0 mA on all other outputs |
| I <sub>cc</sub> I <sub>IL</sub>     | Avg. power supply current Input leakage Input pullup resistance                                |                            | 12            | 20<br>±10                       | mA<br>μA<br>ΚΩ   | Exc. pins 63, 65,<br>66, 67, 68<br>Pins 63, 65, 66,                                                                                                                         |
| I <sub>CL</sub><br>Rin              | Clock leakage<br>Internal pull-up resistance                                                   | 4                          |               | ±10<br>15                       | μA<br><b>k</b> Ω | *Marked pins                                                                                                                                                                |

## **GENERAL WRITE TIMING**



### **GENERAL READ TIMING**



# **MODEM TIMING**



# EXTERNAL CLOCK PERIOD CLOCK PERIOD



### **RXRDY TIMING FOR MODE "0"**



# **RXRDY TIMING FOR MODE "1"**





# TXRDY TIMING FOR MODE "0"



# TXRDY TIMING FOR MODE "1"



# PARALLEL PORT GENERAL WRITE TIMING



# PARALLEL PORT READ TIMING



# ST16C553 PRINTER SPECIAL MODE



# ST16C553 PRINTER AUTO FIFO OPERATION



# ST16C553 PRINTER FIFO TIMING WITH MORE THAN ONE BYTE IN THE FIFO

### ACK SELECTEDFOR FIFO OPERATION



# ST16C553 PRINTER FIFO, WITH ONE BYTE IN THE FIFO



PERIPHERALS 4

# Index

| ST37C65 | <br> | 4-37     |
|---------|------|----------|
|         |      |          |
| ST84C01 | <br> | <br>4-21 |
| ST84C72 |      | <br>4-29 |
|         |      |          |



Printed September 8, 1994

# **GENERAL PURPOSE PARALLEL PRINTER PORT WITH 83 BYTE FIFO**

### **DESCRIPTION**

The ST78C34 is a monolithic Bidirectional Parallel port designed to operate as a general purpose I/O port. It contains all the necessary input/output signals to be configured as a CENTRONICS printer port.

The ST78C34 is a general purpose input/output controller with 83 byte internal FIFO. FIFO operation can be enabled or disabled. For CENTRONICS printer operation, all registers are mapped to IBM printer port registers.

The ST78C34 is designed to operate as normal printer interface without any additional settings. Contents of the FIFO will be cleared after reset or setting the INIT pin to a low state. The auto FIFO operation starts after the first ACK\* is received from the printer. Contents of the FIFO transfer to the printer at the printer loading speed.

# PLCC Package



### **FEATURES**

- 83 bytes of printer output FIFO
- Bi-directional software parallel port
- · Bi-directional I/O ports
- Pin-to-pin compatible to ST78C35
- Register compatible to IBM XT, AT, compatible 386, 486
- · Selectable interrupt polarity
- Selectable FIFO interrupts

# **ORDERING INFORMATION**

| Part number | Package     | Operating temperature |
|-------------|-------------|-----------------------|
| ST78C34CJ44 | PLCC        | 0° C to + 70° C       |
| ST78C34IJ44 | PLCC        | -40° C to + 85° C     |
| ST78C34CP40 | Plastic-Dip | 0° C to + 70° C       |
| ST78C34IP40 | Plastic-Dip | -40° C to + 85° C     |

# Plastic-DIP Package

| ERROR  | 1  |             | 40 | vcc      |
|--------|----|-------------|----|----------|
| SLCT   | 2  |             | 39 | IOR*     |
| BUSY*  | 3  |             | 38 | IOW*     |
| ACK*   | 4  |             | 37 | A1       |
| PE     | 5  |             | 36 | A0       |
| INTSEL | 6  |             | 35 | A2       |
| D7     | 7  | •           | 34 | PD7      |
| D6     | 8  |             | 33 | PD6      |
| D5     | 9  | ST78C34CP40 | 32 | PD5      |
| D4     | 10 | 74CI        | 31 | PD4      |
| D3     | 11 | ပ္ထိ        | 30 | PD3      |
| D2     | 12 | ST7         | 29 | PD2      |
| D1     | 13 |             | 28 | PD1      |
| D0     | 14 |             | 27 | PD0      |
| N.C.   | 15 |             | 26 | GND      |
| INT    | 16 |             | 25 | SLCTIN*  |
| XTAL1  | 17 |             | 24 | INIT     |
| XTAL2  | 18 |             | 23 | AUTOFDX* |
| CS*    | 19 |             | 22 | STROBE*  |
| GND    | 20 |             | 21 | RESET    |

# **BLOCK DIAGRAM**



# SYMBOL DESCRIPTION

| Symbol | Pin  | Signal Type | Pin Description                                                                                                                                                                                                                                                   |
|--------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ERROR* | 1    | I           | General purpose input or line printer error (active low). This is an output from the printer to indicate an error by holding it low during error condition.                                                                                                       |
| SLCT   | 2    | I           | General purpose input or line printer selected (active high). This is an output from the printer to indicate that the line printer has been selected.                                                                                                             |
| BUSY   | 3    | l           | General purpose input or line printer busy (active high). An output from the printer to indicate printer is not ready to accept data.                                                                                                                             |
| ACK*   | . 4  | I           | General purpose input or line printer acknowledge (active low). An output from the printer to indicate that data has been accepted successfully.                                                                                                                  |
| PE     | . 5  | . 1         | General purpose input or line printer paper empty (active high). An output from the printer to indicate out of paper.                                                                                                                                             |
| INTSEL | 6    | <b>!</b>    | Interrupt select mode (pulled-up). The external ACK* can be selected as an interrupt source by connecting this pin to the VCC or left open. Connecting this pin to GND will set the interrupt to latched mode, reading the status register resets the INT output. |
| D0-D7  | 14-7 | 1/0         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus.                                                                                                             |
| N.C.   | 15   |             | No connect. Should be left open for future expansion.                                                                                                                                                                                                             |
| INT    | 16   | 0           | Interrupt output (selectable active low or high). To signal the state of the printer port. This pin tracks the ACK* input pin, When ACK* is low INT is low and when ACK* is high INT is high if selected as active low interrupt.                                 |
| XTAL1  | 17   | I           | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock oscillator circuit.                                                              |

| Symbol    | Pin   | Signal Type                           | Pin Description                                                                                                                               |
|-----------|-------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| XTAL2     | 18    | 0                                     | Crystal input 2 or buffered clock output. See XTAL1.                                                                                          |
| CS*       | 19    | 1                                     | Chip select (active low). A low at this pin enables the ST78C34 / CPU data transfer operation.                                                |
| GND       | 20    | 0                                     | Signal and power ground.                                                                                                                      |
| RESET     | 21    | <b>.</b>                              | Master reset (active high). A high on this pin will reset all the outputs and internal registers.                                             |
| STROBE*   | 22    | I/O                                   | General purpose I/O or strobe output (open drain active low). To transfer latched data to the external peripheral or printer.                 |
| AUTOFDXT* | 23    | I/O                                   | General purpose I/O or line printer auto feed (open drain active low). To signal the printer for continuous form feed.                        |
| INIT      | 24    | I/O                                   | General purpose I/O or line printer initialize (open drain active high). To signal the line printer to enter internal initialization routine. |
| SLCTIN*   | 25    | I/O                                   | General purpose I/O or line printer select (open drain active low). To select the line printer.                                               |
| GND       | 26    | 0                                     | Power and signal ground.                                                                                                                      |
| PD7-PD0   | 34-27 | I/O                                   | Bi-directional parallel ports (three state). To transfer data in or out of the ST78C34 parallel port. PD7-PD0 are latched during output mode. |
| A2        | 35    |                                       | Address line A2. To select internal registers.                                                                                                |
| A0-A1     | 36-37 | 1                                     | Address lines. To select internal registers.                                                                                                  |
| IOW*      | 38    | 1                                     | Write strobe (active low). A low on this pin will transfer the contents of the CPU data bus to the addressed register.                        |
| IOR*      | 39    | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Read strobe (active low). A low level on this pin transfers the contents of the ST78C34 data bus to the CPU.                                  |
| vcc       | 40    | 1                                     | Power supply input.                                                                                                                           |

### PRINTER PORT PROGRAMMING TABLE:

| A1 | A0 | IOW*                        | IOR*                     |
|----|----|-----------------------------|--------------------------|
| 0  | 0  | PORT REGISTER               | PORT REGISTER            |
| 0  | 1  |                             | STATUS REGISTER *        |
| 1  | 0  | CONTROL REGISTER            | COMMAND REGISTER         |
| 1  | 1  | ALTERNATE FUNCTION REGISTER | FIFO BYTE COUNT REGISTER |
| 1  | 1  |                             |                          |

<sup>\*</sup> Reading the status register will reset the INT output.

### PRINTER FUNCTIONAL DESCRIPTION

The ST78C34 parallel port is designed to operate as a normal CENTRONICS printer interface. The port contains 83 byte FIFO that may be enabled via bit-7 of the Alternate Function Register (AFR). After reset, the FIFO is disabled and the part will function identical to the ST16C552. Once the FIFO is enabled via AFR bit-7, the port will enter FIFO mode after the first byte of data is strobed to the printer and the printer responds with either an ACK\* or BUSY signal.

The ST78C34 will remain in FIFO mode until the part is reset or INIT is brought low. While in FIFO mode, data transfer to the printer will be controlled by the printer without any user intervention. The printer port also contains a FIFO byte counter that maintains a count of the number of bytes remaining in the FIFO. The FIFO and the FIFO byte counter are cleared by a reset or by a change of state of the INIT pin. All FIFO related timing is derived from the clock input to pin 17 of the part.

A special parallel port write / read mode is activated when INIT is held low, either by writing a "0" to Control Register bit-2 or by forcing the INIT pin low. In this mode the FIFO read pointer is advanced by reading the parallel port instead of the ACK\* or BUSY signals. The STROBE\* output is forced high. This allows the user to perform parallel port write and read from operations without strobing data to the printer.

Following an INIT, the parallel port will not be in the

FIFO mode. Control Register bit-0 is used as the STROBE\*, Status Register bit-7 is the inverse of the BUSY signal, and INT is derived from ACK\*. The transition into FIFO mode will occur after the first STROBE\* is generated and the printer responds with either an ACK\* or BUSY. In FIFO mode, STROBE\* is generated automatically and writing to Control Register bit-0 has no effect on STROBE\*. Alternate Function Register bit 0-2 are used to control the delay and width of STROBE\*. Handshaking between the printer and the ST78C34 may be controlled by bit-3 of the Alternate Function Register, Setting this bit to a "1" will result in the use of BUSY instead of ACK\* for FIFO reading and interrupt control. INT will transition low when a "1" is written to Control Register bit-0 and will transition high when a write to parallel port is performed. In FIFO mode, data transfer to the printer will be controlled by the printer and will occur at the printer's maximum data rate.

The FIFO byte counter is incremented one count for each parallel port write and decremented one count for each FIFO read (data taken by printer). A FIFO read will be generated at the falling edge of either ACK\* or BUSY. The byte counter will require two to three clock cycles to update. Hence, a read of FIFO Byte Count Register (FBCR) should only be performed a minimum of three clock after the falling edge of either ACK\* or BUSY. The counter is reset whenever the FIFO is reset. If write to parallel port operation is attempted when the FIFO is full, the data

will not be written into the FIFO and the counter will not increment.

Two interrupt modes are available and are selected with the INTSEL pin. If this pin is tied low, a latched interrupt will result. In this mode, INT will transition low when a "1" is written to Control Register bit-0. A reset or reading the Status Register will clear the interrupt. If INTSEL pin is tied high, INT will transition low when a "1" is written to Control Register bit-0 and will transition high when a write to the parallel port is issued. This (non-latched) interrupt signal is always available in Status Register bit-6 regardless of the state of the INTSEL pin. Status Register bit-2 will always contain the latched interrupt state. The polarity of the INT pin may be inverted by setting Alternate Function Register bit-6 high.

The ST78C34 provides additional programmable interrupt output options by programming the Alternate Function Register bit 4-5. INT output can be selected as FIFO full or FIFO empty interrupt.

#### REGISTER DESCRIPTIONS

#### PORT REGISTER

Bi-directional printer port.

Writing to this register during output mode will transfer the contents of the data bus to the PD7-PD0 ports. Reading this register during input mode will transfer the states of the PD7-PD0 to the data bus. This register will be set to the output mode after reset.

#### PR BIT 7-0:

PD7-PD0 bi-directional I/O ports.

#### **STATUS REGISTER**

This register provides the state of the printer outputs and the interrupt condition.

#### SR BIT 1-0:

This bits are set to "1" normally except when AFR bit 5-4 are both set to "1".

#### SR BIT-2:

Interrupt condition.
0= an interrupt is pending
This bit will be set to "0" at the falling edge of the ACK\* input.
1= no interrupt is pending

Reading the STATUS REGISTER will set this bit to "1".

#### SR BIT-3:

ERROR input state.
0= ERROR input is in low state
1= ERROR input is in high state

#### SR BIT-4:

SLCT input state.
0= SLCT input is in low state
1= SLCT input is in high state

#### SR BIT-5:

PE input state.
0= PE input is in low state
1= PE input is in high state

#### SR BIT-6:

ACK\* input state.
0= ACK\* input is in low state
1= ACK\* input is in high state

#### SR BIT-7:

BUSY or FIFO full signal.

0= BUSY input is in high state 1= BUSY input is in low state

FIFO is enabled. 0= FIFO is full

1= One or more empty locations in FIFO

### **COMMAND REGISTER**

The state of the STROBE\*, AUTOFDXT\*, INIT, SLCTIN\* pins, and interrupt enable bit can be read by this register regardless of the I/O direction.

#### COM BIT-0:

STROBE\* input pin.
0= STROBE\* pin is in high state
1= STROBE\* pin is in low state

#### COM BIT-1:

AUTOFDXT\* input pin.
0= AUTOFDXT\* pin is in high state
1= AUTOFDXT\* pin is in low state

#### COM BIT-2:

INIT input pin. 0= INIT pin is in low state 1= INIT pin is in high state

#### COM BIT-3:

SLCTIN\* input pin.
0= SLCTIN\* pin is in high state
1= SLCTIN\* pin is in low state

#### COM BIT-4:

Interrupt mask.
0= Interrupt (INT output) is disabled
1= Interrupt (INT output) is enabled

#### COM BIT 7-5:

Not used. Are set to "1" permanently.

#### CONTROL REGISTER.

Writing to this register will set the state of the STROBE\*, AUTOFDXT\*, INIT, SLCTIN pins, and interrupt mask register.

#### CON BIT-0:

STROBE\* output control bit.
0= STROBE\* output is set to high state
1= STROBE\* output is set to low state

#### CON BIT-1:

AUTOFDXT\* output control bit.
0= AUTOFDXT\* output is set to high state
1= AUTOFDXT\* output is set to low state

#### CON BIT-2:

INIT output control bit.
0= INIT output is set to low state
1= INIT output is set to high state

#### CON BIT-3:

SLCTIN\* output control bit.
0= SLCTIN\* output is set to high state
1= SLCTIN\* output is set to low state

#### CON BIT-4:

Interrupt output control bit.
0= INT output is disabled (three state mode)
1= INT output is enabled

#### CON BIT-5:

I/O select. Direction of the PD7-PD0 can be selected by setting or clearing this bit.
PD7-PD0 are set for output mode
PD7-PD0 are set for input mode

#### CON BIT 7-6:

Not used.

#### **ALTERNATE FUNCTION REGISTER (AFR)**

This register En/Disables FIFO operation and provides additional capabilities to control STROBE\*. INT and change interrupt functions.

#### AFR BIT 0-2:

Timing select.

The STROBE\* delay and width can be controlled by these bits.

| AFR<br>Bit-2 | AFR<br>Bit-1 | AFR<br>Bit-0 | TSD<br>(clocks) | TSW<br>(clocks) |  |
|--------------|--------------|--------------|-----------------|-----------------|--|
| 1            | 0            | 0            | 3               | 2               |  |
| 1            | 0            | 1            | 5               | 4               |  |
| 1            | 1            | 0            | 5               | 4               |  |
| 1            | 1            | 1            | 9               | 8               |  |
| 0            | 0            | .0           | 6               | 4               |  |
| 0            | 0            | 1            | 10              | 8               |  |
| 0            | 1            | 0            | 10              | 8               |  |
| 0            | 1            | 1            | 18              | 16              |  |

### AFR BIT-3:

Interrupt source.

0= ACK\* input pin is selected as printer handshaking source

1= BUSY input pin is selected as printer handshaking source

#### **AFR BIT 4-5:**

Interrupt type. State of the INT output pin can be selected for one of the following options.

| Bit-5 | Bit-4 | INT output  | SR<br>bit-0 | SR<br>bit-6 |
|-------|-------|-------------|-------------|-------------|
| 0     | 0     | Normal mode | 1           | ACK*        |
| 0     | 1     | FIFO empty  | 1           | FIFO empty  |
| 1     | 0     | FIFO full   | 1           | FIFO full   |
| 1     | 1     | FIFO empty  | 0           | FIFO empty  |

#### AFR BIT-6:

INT output polarity.

0= Normal. INT output follows the ACK\* input

1= Inverted INT output

#### AFR BIT-7:

FIFO enable / disable function.

0= FIFO is disabled( default mode).

1= FIFO is enabled. Internal 83 byte of FIFO is enabled.

# FIFO BYTE COUNT REGISTER (FBCR)

State and content of the printer FIFO can be monitored by reading this register.

# FCBR BIT 0-6:

FIFO byte count. Number of characters left in FIFO. FCRB bit-0 is the LSB bit of the counter and FCRB bit-6 is the MSB bit of the counter.

### FBCR BIT-7:

FIFO state.

0= FIFO is enabled

1= FIFO is disabled

#### ST78C34 EXTERNAL RESET CONDITION

| SIGNALS   | RESET STATE          |
|-----------|----------------------|
| PD0-PD7   | Unknown, output mode |
| STROBE*   | High                 |
| AUTOFDXT* | High                 |
| INIT      | Low                  |
| SLCTIN*   | High                 |

# **ST78C34 REGISTER CONFIGURATIONS**

| A | 1 | A0 | REGISTER | D7                      | D6                     | D5                   | D4                   | D3            | D2                        | D1                        | D0                        |
|---|---|----|----------|-------------------------|------------------------|----------------------|----------------------|---------------|---------------------------|---------------------------|---------------------------|
|   | ) | 0  | PR       | PD7                     | PD6                    | PD5                  | PD4                  | PD3           | PD2                       | PD1                       | PD0                       |
|   | ) | 1  | STR      | BUSY*/<br>FIFO<br>full* | None<br>Latched<br>INT | PE                   | SLCT                 | ERROR         | Latched<br>INT            | 1                         | 1                         |
| • | 1 | 0  | сом      | 1                       | 1                      | 1                    | INT<br>enable        | SLCTIN*       | INIT                      | AUTO-<br>FDXT*            | STROBE*                   |
|   | 1 | 0  | CON      | Х                       | Х                      | I/O<br>select        | INT<br>mask          | SLCTIN*       | INIT                      | AUTO-<br>FDXT             | STROBE*                   |
|   | 1 | 1  | AFR      | FIFO<br>enable          | INT<br>polarity        | INT<br>type<br>bit-1 | INT<br>type<br>bit-0 | INT<br>source | TIMING<br>select<br>bit-2 | TIMING<br>select<br>bit-1 | TIMING<br>select<br>bit-0 |
|   | 1 | 1  | FBCR     | FIFO*<br>status         | FBC-6                  | FBC-5                | FBC-4                | FBC-3         | FBC-2                     | FBC-1                     | FBC-0                     |

# **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                          | Parameter                                                                          | Min             | Limits<br>Typ | Max | Units          | Conditions     |
|-----------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------|---------------|-----|----------------|----------------|
| T <sub>1</sub> T <sub>2</sub> T                                 | Clock high pulse duration<br>Clock low pulse duration<br>Clock rise/fall time      | 50<br>50        |               | 10  | ns<br>ns<br>ns | External clock |
| $T_1$ $T_2$ $T_3$ $T_8$ $T_9$ $T_{12}$ $T_{13}$                 | Chip select setup time Chip select hold time                                       | 5               |               | 10  | ns<br>ns       |                |
| T <sub>13</sub><br>T <sub>14</sub>                              | Data setup time Data hold time IOW* delay from chip select                         | 15<br>15<br>10  |               |     | ns<br>ns<br>ns |                |
| T <sub>14</sub> T <sub>15</sub> T <sub>16</sub> T <sub>17</sub> | IOW* strobe width Chip select hold time from IOW* Write cycle delay                | 50<br>0<br>55   |               |     | ns<br>ns<br>ns |                |
| Tw<br>T <sub>39</sub><br>T <sub>40</sub>                        | Write cycle=T <sub>15</sub> +T <sub>17</sub> ACK* pulse width PD7 - PD0 setup time | 105<br>75<br>10 |               |     | ns<br>ns<br>ns |                |
| T <sub>41</sub><br>T <sub>42</sub>                              | PD7 - PD0 hold time<br>Delay from ACK* low to interrupt low                        | 25<br>5         |               |     | ns<br>ns       |                |
| T <sub>43</sub>                                                 | Delay from IOR* to reset interrupt                                                 | 5               |               |     | ns             | :              |

# **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

# DC ELECTRICAL CHARACTERISTICS

 $T_a=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                              | Parameter                                                                                               | Min                        | Limits<br>Typ | Max                             | Units                      | Conditions                                                                                                                                             |
|-------------------------------------|---------------------------------------------------------------------------------------------------------|----------------------------|---------------|---------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| VILCK<br>VIHCK<br>VIL<br>VIH<br>VOL | Clock input low level Clock input high level Input low level Input high level Output low level          | -0.5<br>3.0<br>-0.5<br>2.2 |               | 0.6<br>VCC<br>0.8<br>VCC<br>0.4 | V<br>V<br>V<br>V           | I <sub>oL</sub> = 6.0 mA D7-D0<br>I <sub>oL</sub> = 15mA PD7-<br>PD0<br>I <sub>oL</sub> = 6.0 mA on all<br>other outputs                               |
| V <sub>OH</sub>                     | Output high level                                                                                       | 2.4                        |               |                                 | V                          | $I_{OH}$ = -6.0 mA D7-D0 $I_{OH}$ = -12.0 mA PD7-PD0 $I_{OH}$ = -150 $\mu$ A SLCTIN*, INIT*,STROBE*, AUTOFDXT* $I_{OH}$ = -6.0 mA on all other outputs |
|                                     | Avg. power supply current<br>Input leakage<br>Input leakage<br>Input pullup resistance<br>Clock leakage | 12                         | 12            | 20<br>±10<br>-450<br>40<br>±10  | mA<br>μA<br>μA<br>ΚΩ<br>μA | Except Pins 1-6<br>Pins 1-6 @ Vin=0V<br>Pins 1-6                                                                                                       |



# **GENERAL WRITE TIMING**



### **CLOCK TIMING**



# **GENERAL READ TIMING**



# ST78C34 SPECIAL MODE



# ST78C34 AUTO FIFO OPERATION



# ST78C34 FIFO TIMING WITH MORE THAN ONE BYTE IN THE FIFO

# ACK SELECTEDFOR FIFO OPERATION



# ST78C34 FIFO TIMING, WITH ONE BYTE IN THE FIFO





# ST84C01

Printed September 7, 1994

# **INFRARED RECEIVER AND TRANSMITTER**

### DESCRIPTION

The ST84C01/02 is a single channel Infrared receiver and transmitter, designed for wireless peripheral communications. It meets the standard IrDa specification for wireless applications. The ST84C01 is offered with standard and programmable custom frequencies. The ST84C01 can interface directly to ST16C450, ST16C550, and ST16C650 products.

ST84C01/02 is designed in a  $1.2\mu$  process to achieve 115.2k baud transmission rate.

# **Plastic-DIP Package**

| 16XBAUD 1 | φ      | 8 vcc   |
|-----------|--------|---------|
| RX 2      | C01CF8 | 7 TX    |
| IRRX 3    | ST84C  | 6 IRTX  |
| GND 4     | , io   | 5 RESET |

### **FFATURES**

- Selectable transmit/receive bit rate
- Low power single 5V CMOS technology
- 8, 14 pin DIP or SOIC package.
- · Crystal oscillator circuit on board

| EXCLK 1 | m      | 8 vcc   |
|---------|--------|---------|
| RX 2    | C02CF8 | 7 TX    |
| IRRX 3  |        | 6 IRTX  |
| GND 4   | ST8    | 5 RESET |

# ORDERING INFORMATION

| Part number | Package     | Operating temperature |  |
|-------------|-------------|-----------------------|--|
| ST84C01CP8  | Plastic-DIP | 0 ° C to +70° C       |  |
| ST84C01CF8  | SOIC        | 0° C to +70° C        |  |
| ST84C01CP14 | Plastic-Dip | 0° C to +70° C        |  |
| ST84C01CF14 | SOIC        | 0° C to +70° C        |  |
| ST84C02CP8  | Plastic-DIP | 0 ° C to +70° C       |  |
| ST84C02CF8  | SOIC        | 0° C to +70° C        |  |
|             |             |                       |  |



# **BLOCK DIAGRAM**



# SYMBOL DESCRIPTION (ST84C01CP/CF14 Package)

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                                                  |
|--------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BCLK   | 1   | 0           | Buffered clock output. To drive external UART clock.                                                                                                                                                             |
| XTAL1  | 2   | 1           | Crystal or External Clock input. A crystal can be connected to this pin and XTAL2 pin to generate internal reference clock. For external clock application, XTAL2 is left open or used as buffered clock output. |
| XTAL2  | 3   | 0           | Crystal clock output.                                                                                                                                                                                            |
| RX     | 4   | 0           | Receive data output. Standard UART data output for 8 bits wide word with 1 start and stop bits recovered from IRRX receive data.                                                                                 |
| IRRX   | 5   | . 1         | Infrared receive data input.                                                                                                                                                                                     |
| GND    | 6   | . 0         | Supply ground.                                                                                                                                                                                                   |
| A0     | 7*  | I           | Address select 0. To select the internal preprogrammed data rates.                                                                                                                                               |
| A1     | 8*  | ı           | Address select 1. To select the internal preprogrammed data rates.                                                                                                                                               |
| A2     | 9*  | 1           | Address select 2. To select the internal preprogrammed data rates.                                                                                                                                               |
| RESET  | 10  | I           | Reset input (active high). To reset internal counters, receiver and transmitter.                                                                                                                                 |
| IRTX   | 11  | 0           | Infrared transmit data output. Converted standard UART 8 bits wide word with 1 start and stop bit to IrDa specified pattern.                                                                                     |
| TX     | 12  | l           | Transmit data input. Standard UART data input for 8 bits wide word with 1 start and stop bits.                                                                                                                   |
| vcc    | 13  | 1           | Positive supply input.                                                                                                                                                                                           |
| A3     | 14* | l           | Address select 3. To select the internal preprogrammed data rates.                                                                                                                                               |

<sup>\*</sup> Have internal pull-up resistors

# SYMBOL DESCRIPTION ( ST84C01CP/CF8 Package )

| Symbol              | Pin                            | Signal Type           | Pin Description                                                                                                                      |
|---------------------|--------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 16XBAUD             | 19119 <b>1</b> 3903341<br>1913 | 1 4 <b>1</b> 1 4.     | 16 X BAUD rate clock input. User selectable transmit and receive data rates. This pin can be connected to ST16C450/550 baud-out pin. |
| the growth with the | a nagarawa bi                  |                       |                                                                                                                                      |
| RX                  | 2                              | 0                     | Receive data output. Standard UART data output for 8 bits wide word with 1 start and stop bits converted from IRRX receive data.     |
| IRRX                | 3<br>3                         |                       | Infrared receive data input.                                                                                                         |
| GND                 | 4                              | 0                     | Supply ground.                                                                                                                       |
| RESET               | 5                              | <b>l</b><br>Sales sõi | Reset input (active high). To reset internal counters, receiver and transmitter.                                                     |
| IRTX                | 8                              | 0                     | Infrared transmit data output. Converted standard UART 8 bits wide word with 1 start and stop bit to IrDa specified                  |
| the side of the     | j. 114                         |                       | pattern.                                                                                                                             |
| TX                  | 7                              | and the second        | Transmit data input. Standard UART data input for 8 bits wide word with 1 start and stop bits.                                       |
| vcc                 | 8                              | 1                     | Positive supply input.                                                                                                               |

# SYMBOL DESCRIPTION ( ST84C02CP/CF8 Package )

| Symbol | Pin | Signal Type | Pin Description                                                                                                                  |  |
|--------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------|--|
| EXCLK  | 1   | l           | 1.8432 MHz clock input. For custom data rates, see the data rate selection table.                                                |  |
| RX     | 2   | 0           | Receive data output. Standard UART data output for 8 bits wide word with 1 start and stop bits converted from IRRX receive data. |  |
| IRRX   | 3   | 1           | Infrared receive data input.                                                                                                     |  |
| GND    | 4   | 0           | Supply ground.                                                                                                                   |  |
| RESET  | 5   | ı           | Reset input (active high). To reset internal counters, receiver and transmitter.                                                 |  |
| IRTX   | 8   | 0           | Infrared transmit data output. Converted standard UART 8 bits wide word with 1 start and stop bit to IrDa specified pattern.     |  |
| TX     | 7   | 1 .         | Transmit data input. Standard UART data input for 8 bits wide word with 1 start and stop bits.                                   |  |
| vcc    | 8   | 1           | Positive supply input.                                                                                                           |  |

# **DATA RATE SELECTION TABLE**

| А3 | A2 | A1 | Α0 | BAUD<br>RATE | DIVISOR |
|----|----|----|----|--------------|---------|
| 0  | 1  | 0  | 1  | 600          | 192     |
| 0  | 1  | 1  | 0  | 1200         | 96      |
| 0  | 1  | 1  | 1  | 2400         | 48      |
| 1  | 0  | 0  | 0  | 3600         | 32      |
| 1  | 0  | 0  | 1  | 4800         | 24      |
| 1  | 0  | 1  | 0  | 7200         | 16      |
| 1  | 0  | 1  | 1  | 9600         | 12      |
| 1  | 1  | 0  | 0  | 19.2k        | 6       |
| 1  | 1  | 0  | 1  | 38.4k        | 3       |
| 1  | 1  | 1  | 0  | 57.6k        | 2       |
| 1  | 1  | 1  | 1  | 115.2k       | 1       |

## **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

## DC ELECTRICAL CHARACTERISTICS

 $T_A=0 - 70^{\circ}$  C, VCC=5.0 V ± 10% unless otherwise specified.

| Symbol                | Parameter                                                                                                                                           | Min              | Limits<br>Typ | Max                                  | Units                               | Conditions                                                                                                   |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------|--------------------------------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------|
| > H O H O H C R R C R | Input low level Input high level Output low level Output high level Input low current Input high current Operating current Input pull-up resistance | 2.0<br>2.8<br>35 | 1<br>50       | 0.8<br>0.5<br>-100<br>1<br>1.2<br>65 | V<br>V<br>V<br>μΑ<br>μΑ<br>mA<br>ΚΩ | I <sub>OL</sub> = 6.0 mA<br>I <sub>OH</sub> = 6.0 mA<br>Pin 3 only<br>V <sub>IN</sub> =Vcc Pin 3<br>No load. |

## **AC ELECTRICAL CHARACTERISTICS**

 $T_{\Delta}$ =0 - 70° C, VCC=5.0 V ± 5% unless otherwise specified.

| Symbol         | Parameter       | Min | Limits<br>Typ | Max | Units | Conditions  |
|----------------|-----------------|-----|---------------|-----|-------|-------------|
| T,             | CLOCK rise time |     | 1.5           | 2   | ns    | 0.5V - 2.8V |
| T <sub>2</sub> | CLOCK fall time |     | 1.5           | 2   | ns    | 2.8V - 0.5V |
| _              |                 |     |               |     |       |             |

4

# **TIMING DIAGRAM**







# **IDE INTERFACE WITH I/O DECODE**

#### DESCRIPTION

The ST84C72 is designed to replace all necessary TTL logics for 16 bit IDE interface and decode logic for floppy controller and serial / parallel I/O ports. A select pin is provided to select primary or secondary address for hard and floppy decodes. On board crystal oscillator circuit provides 16, 9, and 1.8461 MHz clock outputs for some floppy controllers and uart from 48 MHz external crystal connected to ST84C72.

## PLCC package



## **FEATURES**

- Low power CMOS design
- Direct bus connect
- Replacement for more than 7 TTL parts
- · High speed for new design
- Selectable I/O decode ports. ( COM1-COM4, LPT1-LPT2 )
- · Floppy address decode
- Pin selectable primary and secondary address decodes

#### ORDERING INFORMATION

## **BLOCK DIAGRAM**



| Symbol  | Pin   | Signal Type | Pin Description                                                                                                                                                                                                                                                              |
|---------|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SA0-SA2 | 28-30 | <b>I</b>    | Host address lines A0-A2.                                                                                                                                                                                                                                                    |
| SA3-SA9 | 33-40 | ı           | Host address lines A3-A9.                                                                                                                                                                                                                                                    |
| SA10    | 43    | 1           | Host address line A10.                                                                                                                                                                                                                                                       |
| SALE    | 32    | 1 .         | Host address latch enable (active high).                                                                                                                                                                                                                                     |
| SAEN*   | 42    | ı           | Host address enable (active low). All decoded addresses are valid when SAEN* is low.                                                                                                                                                                                         |
| SIOW*   | 41    | l           | Host I/O write signal input (active low). Buffered data bus (BD7-BD0) are gated with SIOW*, SIOR* and I/O decoded addresses to insure proper valid data time slots.                                                                                                          |
| SIOR*   | 40    | I           | Host I/O read signal input (active low).Buffered data bus (B07-BD7) are gated with SIOR*, SIOW* and I/O decoded addresses to insure proper valid data time slots.                                                                                                            |
| SD0-SD7 | 46-53 | I/O         | Host data bus.                                                                                                                                                                                                                                                               |
| SRESET* | 55    | l           | Host system reset (internally pulled up, active low). This pin is used to set internal clock dividers to known state. For normal operation this pin should be left open or connected to VCC.                                                                                 |
| XTAL1   | 17    | <b>l</b>    | Crystal or external clock input. A crystal can be connected between XTAL1 and XTAL2 with some additional filters to generate 48 Mhz clock frequency for floppy controller and UART clock . This pin can be connected to VCC or GND if CLK16, CLK9.6 and CLK1.8 are not used. |
| XTAL2   | 18    | 0           | Crystal output. This pin should be left open if external clock is used to connect to XTAL1 or clock is not used.                                                                                                                                                             |
| LPT1*   | 58    | , O         | Line printer enable (active low). Primary printer enable signal. Decoded for address 378 Hex (LPT1).                                                                                                                                                                         |
| LPT2*   | 60    | 0           | Line printer enable (active low). Secondary printer enable signal. Decoded for address 278 Hex (LPT2).                                                                                                                                                                       |

| Symbol | Pin | Signal Type  | Pin Description                                                                                                                                                                                                                                                                                                                                                            |
|--------|-----|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| COM1*  | 67  | 0            | Serial communication select pin (active low). Decoded for 3F8 Hex (COM-1).                                                                                                                                                                                                                                                                                                 |
| СОМ2*  | 65  | 0            | Serial communication select pin (active low). Decoded for 2F8 Hex (COM-2).                                                                                                                                                                                                                                                                                                 |
| сомз*  | 63  | 0            | Serial communication select pin (active low). Decoded for 3E8 Hex (COM-3).                                                                                                                                                                                                                                                                                                 |
| COM4*  | 61  | 0            | Serial communication select pin (active low). Decoded for 2E8 Hex (COM-4).                                                                                                                                                                                                                                                                                                 |
| CLK1.8 | 56  | 0            | 1.8461 Mhz clock output generated from 48 Mhz crystal (crystal frequency or external clock divide by 26). This clock can substitute the standard 1.8432 Mhz serial communication clock.                                                                                                                                                                                    |
| IOEN   | 45  | <b>1</b>     | Serial and parallel port access. Connecting this pin to pin 44 (RDOUT) of the ST16C452, ST16C552, or ST16C553 enables the BD0-BD7 to access the serial and parallel ports. This pin should be tied to GND if external serial/parallel ports are not used.                                                                                                                  |
| FDCEN* | 15  |              | Floppy controller enable/disable (internally pulled up). Floppy controller select is disabled when this pin is left open or connected to VCC. Floppy controller can be selected when this pin is connected to host SA7 pin (primary selection address 3F7, 3F5, 3F4 and 3F2 Hex) or A7* output pin of the ST84C72 (secondary selection address 377, 375, 374 and 372 Hex). |
| FOR*   | 22  | 0            | Floppy controller address decode (372/3F2 Hex).                                                                                                                                                                                                                                                                                                                            |
| FCS*   | 23  | 0            | Floppy controller address decode (377/3F7 Hex).                                                                                                                                                                                                                                                                                                                            |
| FCR*   | 24  | <b>O</b> ( ) | Floppy controller address decode (374-5/3F4-5 Hex).                                                                                                                                                                                                                                                                                                                        |
| CLK16  | 20  | 0            | 16 Mhz clock output generated from 48 Mhz crystal (crystal frequency or external clock divided by 3).                                                                                                                                                                                                                                                                      |

| Symbol  | Pin       | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                 |
|---------|-----------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLK9.6  | 21        | 0           | 9.6 Mhz clock output generated from 48 Mhz crystal (crystal frequency or external clock divide by 5).                                                                                                                                                                                                                                           |
| IOCS16* | 25        | l           | IDE 16 bit data transfer enable (internally pulled up, active low). This pin enables the external 74LS245 bus driver (HIBEN*) when IDE port is selected and 16 bit data transfer is required.                                                                                                                                                   |
| IDEEN*  | 14        | , <b>I</b>  | IDE Enable/Disable (internally pulled up). IDE select is disabled when this pin is left open or connected to VCC. IDE controller can be selected when this pin is connected to A7* output pin of the ST84C72 (primary selection address 3F0-3F7 and 1F0-1F7 Hex) or host address line SA7 (secondary selection address 370-377 and 170-177Hex). |
| IDE1*   | 4         | 0           | IDE drive/register select-1 (active low). When IDEEN* is enabled via SA7, this pin is enabled when I/O port address 3F6 or 3F7 Hex is accessed. When IDEEN* is enabled via A7* pin, IDE1* is enabled when I/O port address 376 or 377 Hex is accessed.                                                                                          |
| IDE0*   | 1         | 0           | IDE drive/register select-0 (active low). When IDEEN* is enabled via SA7, this pin is enabled when I/O port address 1F0-1F7 Hex is accessed. When IDEEN* is enabled via A7* pin, IDE0* is enabled when I/O port address 170-177 Hex is accessed.                                                                                                |
| HIBEN*  | 26        | 0           | High order data bus enable. This pin enables the external 74LS245 data buffer (host SD8-SD15) when IOCS16* is active and IDE port is selected.                                                                                                                                                                                                  |
| A0-A1   | 11-10     | 0           | Buffered host addresses A0 and A1.                                                                                                                                                                                                                                                                                                              |
| A2      | 13        | 0           | Buffered host address A2.                                                                                                                                                                                                                                                                                                                       |
| A7*     | 16        | 0           | Inverted host address line SA7. This pin is used to primary IDE and floppy controller.                                                                                                                                                                                                                                                          |
| BD3-BD0 | 5,2,68,66 | 1/0         | Buffered LSB of low order host data bus (SD0-SD3). These bits are set to input mode when SIOW* is low.                                                                                                                                                                                                                                          |

| Symbol  | Pin        | Signal Type | Pin Description                                                                                                                                                                 |
|---------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BD4-BD6 | 64,62,59   | I/O         | Buffered MSB of low order host data bus (SD4-SD6). These bits are set to input mode when SIOW* is low.                                                                          |
| BD7     | 57         | 1/0         | Buffered host data bit -7 (SD7). This bit goes to high impedance when address 3F7 or 1F7 Hex is accessed during I/O read operation. BD7 is set to input mode when SIOW* is low. |
| ALE     | 9          | 0           | Buffered host address latch (SALE).                                                                                                                                             |
| IOR*    | 8          | 0           | Buffered host I/O read signal (HIOR*).                                                                                                                                          |
| IOW*    | 7          | 0           | Buffered host I/O write signal (HIOW*).                                                                                                                                         |
| GND     | 6,19,31,54 | 0           | Signal and power ground.                                                                                                                                                        |
| vcc     | 3,12,27,44 | · · · . I   | Power supply input.                                                                                                                                                             |

# Optional external filter.



## **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

## DC ELECTRICAL CHARACTERISTICS

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                              | Parameter                                                                                                                                                                            | Lin<br>Min Ty                     |                                              | Units                        | Conditions                                        |
|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|----------------------------------------------|------------------------------|---------------------------------------------------|
| VILCK VIHCK VIL VOL VOH LCC IIL LCL | Clock input low level Clock input high level Input low level Input high level Output low level on all outputs Output high level Avg power supply current Input leakage Clock leakage | -0.5<br>3.0<br>-0.5<br>2.2<br>2.4 | 0.6<br>VCC<br>0.8<br>VCC<br>0.4<br>15<br>±10 | V<br>V<br>V<br>V<br>MA<br>μA | I <sub>oL</sub> = 6 mA<br>I <sub>oH</sub> = -6 mA |





# ST37C65

Printed September 7, 1994

## FLOPPY DISK SUBSYSTEM CONTROLLER

#### DESCRIPTION

The ST37C65 Floppy Disk Subsystem Controller is an LSI device that provides all the needed functionality between the host processor and the floppy disk drive. This "super-chip" integrates the following functions: formatter / controller, data separation, write precompensation, data rate selection (to a maximum of 1Mbit per second), and clock generation. It also provides interface drivers and receivers for the floppy drive.

The ST37C65 is functionally compatible pin-for-pin with the WD37C65C. In addition the ST37C65 Supports a power down mode for laptop and portable systems.

#### **FEATURES**

- IBM\*PC AT\* compatible format (single and double density)
- BIOS compatible, supports dual speed spindle drives
- Address mark detection circuitry (internal to floppy disk controller)
- Multi-sector and multi-track transfer capability
- Direct floppy disk drive interface (no buffers needed)
- 48 mA sink output drivers
- Automatic write pre-compensation Disable option, Pin selectable inner track values of 125 or 187 nanoseconds
- Integrated high-performance DPLL data separator, industry standard error rates of <10E-9</li>
- Data rates of 125, 250, 300, 500 Kbits/second and 1 Mbit/second
- User programmable track stepping rate and head load/unload times
- Supports four floppy drives

### ORDERING INFORMATION

Part number Package ST37C65CJ44 PLCC ST37C65CP40 Plastic-Dir

Package Operating temperature
PLCC 0° C to + 70° C
Plastic-Dip 0° C to + 70° C

## **PLCC Package**



## **DIP Package**



# **BLOCK DIAGRAM**



| Symbol  | Pin  | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RD*     | 1    | I           | Read signal (active low). Control signal for transfer of data or status onto the data bus by the ST37C65.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| WR*     | 2    | I           | Write signal (active low). Control signal for latching data from the bus into the ST37C65 buffer register.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| cs*     | 3    | <b>l</b>    | Chip select (active low). Selected when low allowing RD* or WR* operation from the host.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| A0      | 4    | ı           | Address line 1. Address line selecting data or status information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| DACK*   | 5    | l l         | DMA ACKNOWLEDGE (active low). Used by DMA controller to transfer data from the ST37C65 onto the bus. AT/EISA mode, this signal is qualified by DMAEN from the Operation Register.                                                                                                                                                                                                                                                                                                                                                                              |
| тс      | 6    | 1           | Terminal Count (active high). This signal indicates to ST37C65 that data transfer is complete. If DMA operation mode is selected for command execution, TC will be qualified by DACK*, but not in the programmed I/O execution. In AT/EISA or Special mode, qualification by DACK* requires the Operation Register signal DMAEN to be logically true. Note also AT/EISA mode, TC will be qualified by DACK*, whether in DMA or non-DMA host operation. Programmed I/O in AT/EISA mode will cause an abnormal termination error at the completion of a command. |
| DB0-DB7 | 7-14 | 1/0         | Data bus. 8 bit, bi-directional, three state, data bus. DB0 id the least significant bit and DB7 is the most significant bit.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| DMA     | 15   | 0           | Direct Memory Access (three state, active high). DMA request for byte transfers of data. In Special or AT/EISA mode, this pin is three stated, enabled by the DMAEN signal from the Operation Register. This pin is driven in the Base mode.                                                                                                                                                                                                                                                                                                                   |
| IRQ     | 16   | 0           | Interrupt (three state, active high). Interrupt request indicating the completion of command execution or data transfer requests (in non-DMA mode). Normally driven in Base                                                                                                                                                                                                                                                                                                                                                                                    |

| Symbol  | Pin | Signal Type | Pin Description                                                                                                                                                                                                      |
|---------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |     |             | mode. In Special AT/EISA mode, this pin is three stated, enabled by DMAEN signal from the Operation Register.                                                                                                        |
| DCHGEN* | 17  | <b>l</b>    | Disk Change Enable (active low). This input must be at logic "0" to enable DCHG* input status at pin 40 to be placed on bit-7 of the data bus during RD* of LDCR*. It has internal pull-up.                          |
| LDOR*   | 18  | <b></b>     | Load Operations Register (active low). Address decode which enables the loading of the Operation Register. Internally gated with WR* creates the strobe which latches the data bus into the Operations Register.     |
| LDCR*   | 19  | <b>l</b>    | Load Control Register (active low). Address decode which enablesloading of the Control Register. Internally gated with WR* create the strobe which latches the two LSBs from the data bus into the Control Register. |
| RST     | 20  | <b>l</b>    | Reset (active high). Resets controller, placing microsequencer in idle. Resets device outputs. Puts device in Base mode, not PC AT or Special mode.                                                                  |
| RDD*    | 21  |             | Read Disk Data. This is the raw serial bit stream from the disk drive. Each falling edge of the pulses represents a flux transition of encoded data.                                                                 |
| *CLK2   | 21  | - 1         | Clock-2. TTL level clock input used for non-standard data rates; is 9.6 MHz for 300 kb/s, and can only be selected from the Control Register.                                                                        |
| XTAL20  | 22  | 0           | Crystal oscillator drive output. A crystal oscillator is connected from this pin to XTAL2i pin. This pin should be left floating if TTL inputs used at pin XTAL2i.                                                   |
| XTAL2i  | 23  | <b>1</b>    | Crystal oscillator or External clock input pin. Used for non-<br>standard data rates.                                                                                                                                |
| DRV     | 24  |             | Drive Type. This input indicates to the device that a two speed spindle motor is used if logic is "0". In that case, the second clock input will never be selected and must be grounded.                             |

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                                                                                                              |
|--------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| *CLK1  | 23  | 1.          | Clock1. TTL level clock input is used to generate all internal timing for standard data rates. Frequency must be 16 MHz $\pm 0.1\%$ or 32 MHz $\pm 0.1\%$ , and may have 40/60 or 60/40 duty cycle.                                                          |
| XTAL10 | 25  | 0           | Crystal oscillator drive output. A crystal oscillator is connected from this pin to XTAL1i pin. This pin should be left floating if TTL inputs used at pin XTAL1i.                                                                                           |
| XTAL1i | 26  |             | Crystal oscillator or External clock input pin. Requires 16 MHz or 32 MHz crystal. This oscillator is used for all standard data rates, and may be driven with TTL level signal.                                                                             |
| PCVAL  | 27  | 1           | Pre-Compensation Value. This pin determines the amount of write pre-compensation used on the inner tracks of the diskette. Logic "1" = 125 ns, logic "0" = 187 ns. If the data defeat option is used, PCVAL is unimportant and pre-compensation is disabled. |
| HS*    | 28  | 0           | Head Select (active low). High current driver (HCD) output selects the head (side) of the floppy disk that is being read or written. Logic "1" = side 0.                                                                                                     |
| WE*    | 29  | 0           | Write Enable (active low). The output becomes true, just prior to writing on the diskette. This allows current to flow through the write head.                                                                                                               |
| WD*    | 30  | 0           | Write Data. Each falling edge of the encoded data pulse stream causes a flux transition on the media.                                                                                                                                                        |
| DIRC*  | 31  | 0           | Direction (active low). DIRC* determines the direction of the head stepper motor. Logic "1" = outward motion.                                                                                                                                                |
| STEP*  | 32  | 0           | Step Pulse (active low). STEP* output issues an active low pulse for each track to track movement of the hrad.                                                                                                                                               |
| DS1*   | 33  | 0           | Drive Select-1 (active low). It enables the interface to this disk drive. This signal comes from the Operation Register. In Base mode, or Special mode, this output is #1 of the four decoded Unit Selects, as specified in the device command               |

| Symbol     | Pin | Signal Type | Pin Description                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |     |             | syntax.                                                                                                                                                                                                                                                                                                                                                                                   |
| GND        | 34  | 0           | Supply ground.                                                                                                                                                                                                                                                                                                                                                                            |
| DS2*       | 35  | 0           | Drive Select-2 (active low). It enables the interface to this disk drive. This signal comes from the Operation Register. In Base mode, or Special mode, this output is #2 of the four decoded Unit Selects, as specified in the device command syntax.                                                                                                                                    |
| MO1*, DS3* | 36  | 0           | Motor On enable for disk drive #1 (active low). This signal comes from the Operation Register. In Base mode, or Special mode, this output is #3 of the four decoded Unit Selects, as specified in the device command syntax.                                                                                                                                                              |
| MO2*, DS4* | 37  | 0           | Motor On enable for disk drive #2 (active low). This signal comes from the Operation Register. In Base mode, or Special mode, this output is #4 of the four decoded Unit Selects, as specified in the device command syntax.                                                                                                                                                              |
| HDL*       | 38  | 0           | Head Load (active low). When HDL* is low, causes the head to be loaded againt the media in the selected drive.                                                                                                                                                                                                                                                                            |
| RWC*, RPM* | 39  | 0           | Readuced Write Current / Revolutions Per Minute (active low). When low, causes a Reduced Write Current when bit density is increased toward the inner tracks, becoming active when tracks > 28 are accessed. This condition is valid for Base or Special mode, and is indicative of when write pre-compensation is necessary. In the AT/EISA mode, this signal will be active when CR0=1. |
| DCHG*      | 40  |             | Disk Change (active low). This input senses status from the drive. Active low indicates that drive door is open or that the diskette has possibly changed since the last drive selection. It has internal pull-up.                                                                                                                                                                        |
| WP*        | 41  | <b>.</b>    | Write Protected (active low). This input senses status from disk drive, indicating active low when a diskette is Write Protected.                                                                                                                                                                                                                                                         |
| TR00*      | 42  |             | Track Zero (active low). This input senses status from disk                                                                                                                                                                                                                                                                                                                               |

| Symbol | Pin | Signal Type | Pin Description                                                                                                                                                      |
|--------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |     |             | drive, indicating active low when the head is positioned over the outermost track, Track 00.                                                                         |
| IDX*   | 43  | 1           | Index (active low) This input senses status from disk drive, indicating active low when the head is positioned over the begining of a track marked by an index hole. |
| vcc    | 44  | 1           | Positive supply input.                                                                                                                                               |

<sup>\* 40</sup> Pin package only

#### **FUNCTIONAL DESCRIPTION**

ST37C65 includes data separation designed to address high performance error rate on floppy disk drives. It contains all the necessary Logic to achieve classical 2nd order, type 2, phase locked-loop performance. Write pre-compensation is included, in addition to the usual formatting, encoding/decoding, stepper motor control, and status sensing functions. All inputs are TTL compatible Schmitt Trigger line receivers, and outputs are high current, open drain, with 48 mA drivers which meet the ANSI specification.

The host interface supports an 8 or 12 MHz, 286 microprocessor bus without the use of wait states. The inputs are Schmitt Triggers. Output drive capability is 20 LS-TTL loads, allowing direct interconnection to bus structures without the use of buffers or transceivers. For PC, PC AT and EISA applications, qualification of interrupt request and DMA request is provided.

Traditionally, data rate selection, drive selection, and stepper motor control have been output ports of the host processor architecture. In the ST37C65, these functions are latched into registers addressed within the I/O mapping of the system. The ST37C65 has eight internal registers. The eight bit main status register contains status information about the

ST37C65 and may be accessed any time. Another four status registers under system control also give various status and error information. The. Control Register provides support logic that latches the two LSBs used to select the desired data rate that controls internal clock generation. The Operations Register replaces the standard latched port used in floppy subsystems. These registers are incorporated into the ST37C65.

#### **CLOCK GENERATION**

SCLK - Sampling Clock, WCLK- Write Clock, and MCLK - Master Clock, are included in the ST37C65. XTAL oscillator circuits provide the necessary signals for internal liming when using the 44 pin PLCC. If the 40 pin DIP is used, the TTL level clock inputs must be provided. There are two oscillator inputs to the ST37C65. The first at 32 MHz that handles all standard data rates (1Mb/sec, 500, 250, and 125 kb/sec or 16 MHz to handle 500, 250, and 125 Kb/sec.). The second oscillator is at 9.6 MHz to support the 300 kb/sec data rate used in PC AT designs.

Some AT compatibles use two-speed disk drives. If a two speed disk drive is used, the DRV input should be grounded along with the CLK2 input.

# ST37C65

#### **ARCHITECTURE**

The ST37C65 Floppy Disk Subsystem Controller is an LSI device that provides all the needed functionality between the host processor and the floppy disk drive. This "super-chip" integrates formatter/controller, data separation, write precompensation, data rate selection, clock generation, drive interface drivers and receivers.

#### HOST INTERFACE

The host interface is the Host Microprocessor Peripheral Bus. This bus is composed of eight control signals and eight data signals. In the Special or AT/EISA modes IRQ and DMA request are three-stated and qualified by DMA enable which is provided by the Operations Register. The data bus, DMA, and IRQ outputs are designed to handle 20 LS-TTL loading. Inputs are Schmitt Trigger receivers and can be hooked up to a bus or back plane without any additional buffering.

During the Command or Result phases, the Main Status Register must be read by the processor before each byte of information is written into or read from the Data Register. After each byte of data is read from or written into the Data Register, the CPU waits for 12µs before reading the Main Status Register. Bits D6 and D7 in the Main Status Register must be in a 0 and 1 state, respectively, before each byte of The command word may be written into the ST37C65. Many of the commands require multiple bytes. As a result, the Main Status Register must be read prior to each byte transfer to the ST37C65. During the Result phase, Bits D6 and D7 in the Main Status Register must both be 1's (D6=1 and D7=1) before reading each byte from the Data Register.

Note that this reading of the Main Status Register before each byte transfer to the ST37C65 is required only in the Command and Result phases, and not during the Execution phase. Note also that DB6 and DB7 in the MSR can be polled instead of waiting 12µs.

During the Execution phase, the Main Status Register need not be read. If the ST37C65 is in the non-DMA Mode, then the receipt of each data byte (ST37C65 is reading data from the FDD) is indicated by an interrupt signal on pin 16 (IRQ=1). The generation of a Read signal (RD\*=0) clears the interrupt and sends the data

onto the data bus. If the processor cannot handle interrupts fast enough (every  $13\mu s$  for the MFM mode and  $27\mu s$  for the FM mode), then it may poll the Main Status Register and bit D7 (RQM) functions as the Interrupt signal. If a Write Command is in process then the WR\* signal performs the reset to the Interrupt signal.

All timings mentioned above double for mini floppy data rates.

Note that in the non-DMA mode it is necessary to examine the Main Status Register to determine the cause of the interrupt since it could be a data interrupt or a command termination interrupt, either normal or abnormal. If the ST37C65 is in the DMA mode, no interrupt signals are generated during the Execution phase. The ST37C65 generates DMA's (DMA Reguests) when each byte of data is available The DMA Controller responds to this request with both DACK\*= 0 (DMA Acknowledge) and an RD\*=0 (Read signal). When the DMA Acknowledge signal goes low (DACK\*= 0), the DMA Request is cleared DMA= 0) If a Write Command has been issued, then a WR\* signal will appear instead of RD\*. After the Execution phase has been completed (Terminal Count has occurred) The EOT sector read/written, then an Interrupt will occur (IRQ=1) this signifies the begining of the result phase. When the first byte of data is read during the Result phase, the interrupt is automatically cleared (IRQ=0). Note that in PC AT usage, non-DMA Host transfers are not the normal procedure. If the user chooses to do so, the ST37C65 will successfully complete commands, but will at ways give abnormal termination error status since TC is qualified by an inactive DACK\*. The RD\* or WD\* signals should be asserted while DACK\* is true The CS\* signal is used in conjunction with RD\* and WR\* as gating function during programmed I/O operations. CS\* has no effect during DMA operations. It the non-DMA mode is chosen, the DACK signal should be pulled up to VCC.

Note that during the Result phase all bytes shown in the Command Table must be read.

The Read Data Command, for example has several bytes of data in the Result phase. All seven bytes must be read in order to successfully complete the Read Data command. The ST37C65 will not accept a new command until all seven bytes have been read. Other commands may require fewer bytes to be read during

the Result phase. The ST37C65 contains five Status Registers. The Main Status Register mentioned may be read by the processor at any time. The other four Status Registers (ST0, ST1, ST2, and ST3) are available only during the Result phase and may be read only after completing a command. The particular command that has been executed determines how many of the Status Registers will be read.

The bytes of data which are sent to the ST37C65 to form the command phase, and are read out of the ST37C65 in the result phase, must occur in the order shown in the Command table. The command code must be sent first and the other bytes sent in the prescribed sequence. No foreshortening of the Command or Result phases is allowed. After the last byte of data in the command phase is sent to the ST37C65, the Execution phase automatically starts. In a similar fashion, when the last byte of data is read out in the result phase, the command is automatically ended and the ST37C65 is ready for a new command.

#### **CONTROL REGISTER**

The Control Register is a write only register that is used to set the data transfer rate and disable write precompensation. It provides support logic that latches

the two LSBs of the data bus upon receiving LDCR\* and WR\*. CS\* should not be active when this happens. These bits are used to select the desired data rate, which in turn controls the internal clock generation. Clock switch over is internally "deglitched", allowing continuous operation after changing data rates. If the Control Register is not used, the data rate is governed by the supplied clock or crystal. The frequency must be 64 times the desired MFM data rate. This implies a maximum data rate of 250 kb/s for a frequency of 16 MHz or a maximum data rate of 500 kb/s for a frequency of 32 MHz, unless the Control Register is used. Switching of this clock must be "alitchess" or the device will need to be reset. Table 1 and Table 2 present the Control Register configuration for 16 MHz and 32 MHz frequencies, respectively.

ST37C65 optionally supports 150 kbits FM data transfer rate. The Control Register configuration is shown in Table 3. The 150 kb/s data rate can be selected by using a 9.6 MHz XTAL or TTL level clock input on pin 26 (44-pin PLCC) or pin 23 (40-pin DIP). Only two data transfer rates can be selected with this configuration 150 kb/s FM and 300 kb/s MFM.

**TABLE 1. CONTROL REGISTER CONFIGURATION 16 MHz** 

| CR1 | CR0 | DRV | DATA RATE | COMMENTS         | RPM (AT/EISA mode) |
|-----|-----|-----|-----------|------------------|--------------------|
| 0   | 0   | X   | 500 k     | MFM              | 1                  |
| 0   | 0   | Х   | 250 k     | FM               | 1                  |
| 0   | 1   | . 0 | 250 k     | MFM              | O                  |
| 0   | 1   | 1   | 300 k     | MFM (9.6 MHz)    | 0                  |
| 1   | 0   | X   | 250 k     | MFM, RST Default | 1                  |
| 1   | 0   | Х   | 125 k     | FM, RST Default  | 1                  |
| 1   | 1   | Х   | 125 k     | FM               | 0                  |

**TABLE 2. CONTROL REGISTER CONFIGURATION 32 MHz** 

| CR1 | CR0 | DRV | DATA RATE | COMMENTS         | RPM (AT/EISA mode) |
|-----|-----|-----|-----------|------------------|--------------------|
| 0   | 0   | Х   | 1 M       | MFM              | 1                  |
| 0   | 0   | X   | 500 k     | FM               | 1                  |
| 0   | 1   | 0   | 500 k     | MFM              | 0                  |
| 0   | 1   | 1   | 300 k     | MFM (9.6 MHz)    | 0                  |
| 1   | 0   | X   | 500 k     | MFM, RST Default | 1                  |
| 1   | 0   | Х   | 250 k     | FM, RST Default  | 11                 |
| 1   | 1   | X   | 250 k     | FM               | 0                  |

**TABLE 2. CONTROL REGISTER CONFIGURATION - OPTIONS** 

| CR1 | CR0    | DRV | DATA RATE      | COMMENTS  | RPM (AT/EISA mode) |
|-----|--------|-----|----------------|-----------|--------------------|
| 0   | 0<br>0 | ×   | 300 k<br>150 k | MFM<br>FM | 1 1                |

In AT/EISA mode, write pre-compensation can be disabled by a logic high on bit-2 of the Control Register. (see table 4.)

TABLE 4. CONTROL REGISTER CONFIGURATION - AT/EISA MODE

|   | віт | SIGNAL NAME AND FUNCTION  | RESET | CLOCK QUALIFIER |
|---|-----|---------------------------|-------|-----------------|
|   | 0   | Data rate                 | 0     | None            |
| 1 | 1   | Data rate                 | 0     | None            |
| 1 | 2   | No Write Pre-compensation | 0     | None            |
|   | 3-7 | Reserved                  | None  | None            |
| L |     |                           |       |                 |

#### MASTER STATUS REGISTER

The Master Status Register is an eight-bit, read/write register that contains the status information of the FDC. It can be accessed at any time. The ST37C65 provides a write only register, called Master Status Register 1 (MSR1) which is used only to select power down mode. In power down mode the XTAL oscillator, controller circuitry and all linear circuitry are turned off so that the controller draws very low current. Normal operation is restored by asserting reset to the ST37C65 (see Master Status Register 1).

Only the Master Status Register may be read and used to facilitate the transfer of data between the processor and ST37C65. The DIO and RQM bits in the Master Status Register indicate when data is ready and in which direction data will be transferred on the data bus. The maximum time between the last RD\* or WR\* during a Command or Result phase and the setting of DIO and RQM is 12 $\mu s$  if 500 kb/s MFM data rate is selected. (If 250 kb/s MFM is selected, the delay is 24 $\mu s$ . If 1 Mb/s is selected, the delay is 6 $\mu s$ .) For this reason, everytime the Master Status Register is read, the CPU should wait 12 $\mu s$ . The maximum time from

## **MASTER STATUS REGISTER 1**

(MSR1 - Write Only)

The ST37C65 will enter power down mode, when bit of MSR1 is set to logical "1" and the following conditions are met:

- 1.The RST pin to the FDC is inactive.
- 2.Bit 2 in the Operations Register is "SRST= 1".

3. The ST37C65 is a waiting a command from the host

The ST37C65 can also be programmed with external logic to automatically enter power down mode a few msec. after the beginning of idle mode.

Normal operation is restored when the RST pin to the FDC is active and the FDC is reset. This in turn resets bit of MSR1 register to logic 0.

TABLE 5. AT/EISA MODE. MASTER STATUS REGISTER 1 CONFIGURATION

| BIT | SIGNAL NAME AND FUNCTION | RESET | CLOCK QUALIFIER |
|-----|--------------------------|-------|-----------------|
| 0   | Power down mode (PDM)    | 0     | None            |
| 1-7 | Reserved                 | None  | None            |

#### **TABLE 6. MASTER STATUS REGISTER BITS**

| BIT | NAME           | SYMBOL | DESCRIPTION                                                                                                                                                                               |
|-----|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0  | FDD 0 busy     | D0B    | FDD number is 0 in the Seek Mode. If any of the bits is set, FDC will not accept READ or WRITE command.                                                                                   |
| D1  | FDD 1 busy     | D1B    | FDD number is 1 in the Seek Mode. If any of the bits is set, FDC will not accept READ or WRITE command.                                                                                   |
| D2  | FDD 2 busy     | D2B    | FDD number is 2 in the Seek Mode. If any of the bits is set, FDC will not accept READ or WRITE command.                                                                                   |
| D3  | FDD 3 busy     | D3B    | FDD number is 3 in the Seek Mode. If any of the bits is set, FDC will not accept READ or WRITE command.                                                                                   |
| D4  | FDC busy       | СВ     | A READ or WRITE command is in progress. FDC will not accept any other command.                                                                                                            |
| D5  | Execution mode | EXM    | This bit is set only during execution phase in non-DMA mode. When D5 goes low Execution phase has ended and Results Phase has started. It operates only during non-DMA mode of operation. |

# ST37C65

| ВІТ | NAME               | SYMBOL | DESCRIPTION                                                                                                                                                                                              |
|-----|--------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D6  | Data input         | DIO    | Indicates direction of data transfer between FDC and Data Register. If DIO = 1, then transfer is from Data Register to the processor. If DIO = 0, then transfer is from the processor to Data Register.  |
| D7  | Request for Master | RQM    | Indicates Data Register is ready to send or receive data to or from the processor. Both bits DIO and RQM should be used to perform the handshaking function of "ready" and "direction" to the processor. |

## TABLE 7. STATUS REGISTER 0 BITS

| BIT | NAME            | SYMBOL | DESCRIPTION                                                                                                                                                                                                                                                                                               |
|-----|-----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0  | Unit select 0   | US0    | This flag is used to indicate a Drive Unit Number at interrupt.                                                                                                                                                                                                                                           |
| D1  | Unit select 1   | US1    | This flag is used to indicate a Drive Unit Number at interrupt.                                                                                                                                                                                                                                           |
| D2  | Head select     | нѕ     | This flag is used to indicate the state of the head at interrupt.                                                                                                                                                                                                                                         |
| D3  | Not ready       | NR     | Since drive Ready is always presumed true, this will always be a logic "0" (low).                                                                                                                                                                                                                         |
| D4  | Equipment check | EC     | If the Track "0" signal fails to occur after 77 step pulses per<br>Recalibrate Command, then this flag is set.                                                                                                                                                                                            |
| D5  | Seek end        | SE     | When the FDC completes the SEEK command, this flag is set to "1" (high).                                                                                                                                                                                                                                  |
| D6  | Interrupt code  | IC     | See D7.                                                                                                                                                                                                                                                                                                   |
| D7  | Interrupt code  | IC     | D7 = 1 and D6 = 0, invalid command issue. Command which was issued was never started.D7 = 0 and D6 = 0, normal termination of command was completed and properly executed. D7 = 0 and D6 = 1, abnormal termination of command, (AT). Execution of command was started but was not successfully completed. |

## **TABLE 8. STATUS REGISTER 1 BITS**

| BIT | NAME                 | SYMBOL | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|----------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0  | Missing address mark | MA     | If the FDC cannot detect the ID Address Mark after encountering the index hole twice, then this flag is set. If the FDC cannot detect the Data Address Mark or Deleted Data Address Mark, this flag is set. At the same time the MD (Missing Address Mark in data field) of Status Register 2 is set.                                                                                                     |
| D1  | Not writeable        | NW     | During execution of Write Data, Write Deleted Data or Format a Track commands, if the FDC detectes a WP* signal from the FDD, then this flag is set.                                                                                                                                                                                                                                                      |
| D2  | No data              | ND     | During execution of Read Data, Write Deleted Data, or Scan command, if the FDC cannot find the sector specified in the IDR (Internal Data Register), this flag is set. During execution of the Read ID command, if the FDC cannot read the ID field without an error, then this flag is set. During execution of the Read a Track command, if the starting sector cannot be found, then this flag is set. |
| D3  | Not used             |        | This bit is always set to "0".                                                                                                                                                                                                                                                                                                                                                                            |
| D4  | Overrun              | OR     | If the FDC is set not serviced by the host system during data transfers within a certain time interval, this flag is set.                                                                                                                                                                                                                                                                                 |
| D5  | Data error           | DE     | When the FDC detects a CRC (Cyclic Redundancy Check) error in either the ID field or the data field, this flag is set.                                                                                                                                                                                                                                                                                    |
| D6  | Not used             |        | This bit is always set to "0".                                                                                                                                                                                                                                                                                                                                                                            |
| D7  | End od cylinder      | EN     | When the FDC tries to access a sector beyond the final sector of a cylinder, this flag is set.                                                                                                                                                                                                                                                                                                            |

# ST37C65

# **TABLE 9. STATUS REGISTER 2 BITS**

| BIT | NAME            | SYMBOL                                                                                                         | DESCRIPTION                                                                                                                                                              |
|-----|-----------------|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0  | Missing address | MD                                                                                                             | Missing address mark in data field. When data is read from the medium, if FDC cannot find a Data Address Mark of Deleted Data Address Mark, then this flag is set.       |
| D1  | Bad cylinder    | вс                                                                                                             | This bit is related to the ND bit, and when the contents of C on the medium is different from that stored in the IDR and the contents of C is FF, then this flag is set. |
| D2  | Scan not        | SN                                                                                                             | During execution of the SCAN command, if the FDC cannot find a sector on the cylinder which meets the condition, then this flag is set.                                  |
| D3  | Scan equal      | SH                                                                                                             | During execution of the SCAN command, if the condition of "equal" is satisfied, this flag is set.                                                                        |
| D4  | Wrong cylinder  | wc                                                                                                             | This bit is related to the ND bit, and when contents of cylinder on the medium is different from that stored in the IDR, this flag is set.                               |
| D5  | Data error      | DD                                                                                                             | If the FDC detects a CRC error in the data field, then this flag is set.                                                                                                 |
| D6  | Control mark    | СМ                                                                                                             | During execution of the Read Data or Scan Command, if the FDC encounters a sector which contains a Deleted Data Address Mark, this flag is set.                          |
| D7  | Not used        | en de la companya de la companya de la companya de la companya de la companya de la companya de la companya de | This bit is always set to "0".                                                                                                                                           |

#### **TABLE 10. STATUS REGISTER 3 BITS**

| BIT | NAME            | SYMBOL | DESCRIPTION                                                                                          |
|-----|-----------------|--------|------------------------------------------------------------------------------------------------------|
| D0  | Unit select 2   | US0    | This bit is used to indicate the status of the Unit Select 0 signal to the FDD.                      |
| D1  | Unit select 1   | US1    | This bit is used to indicate the status of the Unit Select 1 signal to the FDD.                      |
| D2  | Head select     | HS     | This bit is used to indicate the status of the Side Select signal to the FDD.                        |
| D3  | Write protected | WP*    | This bit is used by the ST37C65 to indicate the status of the Write Protected (WP*) signal from FDD. |
| D4  | Track 0         | ТО     | This bit is used to indicated the status of the Track 0 signal from the FDD.                         |
| D5  | Ready           | RY     | This bit will always be a logic "1". Drive is presumed to be ready.                                  |
| D6  | Write protected | WP*    | This bit is used to indicate the status of the Write Protected (WP*) signal from FDD.                |
| D7  | Not used        |        | This bit is always set to "0".                                                                       |

#### **DATA REGISTER**

The eight-bit Data Register stores data, commands, parameters, and FDD status information. Data bytes are read out A0, or written into, the Data Register in order to program or obtain the results after a particular

command.The relationship between the Master Status Register and the Data Register and the signals RD\*, WR\*, and A0 are shown in Table 11.

**Table 11. MASTER STATUS AND DATA REGISTER** 

| A0 | RD* | WR* | FUNCTION                  |
|----|-----|-----|---------------------------|
| 0  | 0   | 1   | Read Main Status Register |
| 0  | 1   | 0   | Illegal                   |
| 0  | 0   | 0   | Illegal                   |
| 1  | 0   | 0   | Illegal                   |
| 1  | 0   | 1   | Read from Data Register   |
| 1  | 1   | 0   | Write into Data Register  |

# ST37C65

#### **OPERATIONS REGISTER**

The Operations Register provides support logic that latches the data bus upon receiving LDOR\* and WR\*. CS\* should not be active when this happens. The

Operations Register replaces the typical latched port found in floppy subsystems used to control disk drive spindle motors and to selected the desired disk drive. Table 12 represents the Operations Register.

#### **TABLE 12. OPERATIONS REGISTER**

| OR0 | DSEL   | Drive Select, if low and MOEN1 = 1, then DS1* is active. If high and MOEN2 = 1, then DS2* is active, but only in the AT/IEISA mode. |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------|
| OR1 | (X)    | This must be a logic 0 for DS1* and DS2* to become active.                                                                          |
| OR2 | SRST*  | Soft reset, active low.                                                                                                             |
| OR3 | DMAEN  | DMA enable, active in Special and AT/EISA modes. Qualifies DMA and IRQ outputs and DACK* input.                                     |
| OR4 | MOEN1  | Motor On enable, inverted output M01* is active only in AT/IEISA mode.                                                              |
| OR5 | MOEN2  | Motor On enable, inverted output M02* Is active only in AT/EISA mode.                                                               |
| OR6 | (X)    | Has no defined function. A spare.                                                                                                   |
| OR7 | (MSEL) | Mode Select. During a soft reset condition, may be used to select between Special mode (1) and AT/IEISA mode (0).                   |

#### BASE, SPECIAL, AND AT/EISA MODES

Base, Special, PC AT and EISA modes allow subtle differences which the user may find desirable. The Control Register may be used in any mode without altering functionality.

#### **Base Mode**

After a hardware reset, RST active, the ST37C65 will be held in soft reset, SRST\* active, with the normally driven signals, DMA request and IRQ request outputs three-stated. Base mode may be initiated at this time by a chip access by the host. Although this may be any read or write, it is strongly recommended that the Base mode user's first chip access be a read of the Master Status Register. Once Base mode is entered, the soft reset is released, and IRQ and DMA are driven. Base mode prohibits the use of the Operations Register.

hence there can be no qualifying DMAEN and no soft resets. The Drive Select outputs, DS1\* to DS4\*, offer a 1 of 4 decoding of the Unit Select bits resident in the command structure. Pin RWC\* represents Reduce Write Current and is indicative of when write precompensation is necessary.

#### **Special Mode**

Special mode allows use of the Operations Register for the DMAEN signal as a qualifier and to do a software driven device reset, SRST\*. To enter Special mode, the Operations Register is loaded with (1 X 0 0 X 0 X X), setting mode Select to a logic 1 disabling MOEN1 and MOEN2 and causing SRST\* to be active. Then a read of the Control Register address, LDCR\* and places the device in Special mode. The DS1\*

through DS4\* is again offered in this mode, as is RWC\*.

#### AT/EISA Modes

For AT/EISA compatibility, users write to the Operations Register, LDOR\* and WR\*; this action, performed after a hardware reset, or in the Base mode. initiates AT/EISA mode, AT/EISA mode can also be entered from Special mode by loading the Operations Register with (0 X 0 0 X 0 X X), setting Mode Select to a logic 0, disabling MOEN1 and MOEN2, and causing SRST\* to be active. Then a read of the Control Register address sets the device into AT/EISA mode. The DS\* outputs are replaced with the DSEL and MOEN signals buffered from the Operations Register. DMAEN and SRST\* are supported and compatible with the current BIOS. RWC\* pin function is now RPM\* so that users with two-speed drives may reduce spindle speed from a nominal 360 revolutions per minute to 300 revolutions per minute when active low. It can also be used to reduce write current when a slower data rate is selected for a given drive.

#### POLLING ROUTINE

After any reset the ST37C65, (a hard RST or soft SRST\*), will automatically go into a Polling routine. In between commands (and between step pulses in the SEEK Command), the ST37C65 polls all four FDDs looking for a change in the Ready line from any of the drives. Since the drive is always presumed Ready, an interrupt will only be generated following a reset. This occurs because a reset forces Not Ready status, which then promptly becomes Ready. Note that in Special, AT/EISA modes, if DMAEN is not valid 1ms after reset goes inactive, then IRQ may be already set and pending when finally enabled onto the bus. The polling of the Ready line by the ST37C65 occurs continuously between Each drive is polled every 1.024ms, except during the READ/WRITE commands. For mini- floppies, the polling rate is 2.048ms. The drive polling sequence is 1-2-4-3. Note that in the AT/EISA mode, the user will not see the polling at the Drive Select signals. Figure 4 illustrates the Drive Select Polling Timing.

#### FIGURE 4.

#### DRIVE SELECT POLLING TIMING



# ST37C65

#### **DEVICE RESETS**

The ST37C65 supports both hardware reset (RST pin 19) and a software reset (SRST\*) through use of the Operations Register. The RST pin will cause a device reset for the active duration. RST causes a default to Base mode, and selects 250kb MFM (or 125kb FM code dependent) as the data rate (16 MHz input clock) The default data rate for a 32 MHz input clock is 500kb MFM. SRST\* will reset the micro controller as did the RST, but will not affect the current data rate selection or the mode RST, when active, will disable the current driver outputs to the disk drive. RST and SRST\* will not affect the values set for the internal timers HUT, HTL, and SRT.

If the XTAL oscillators are used, instead of the TTL driven clock inputs, the hardware RST active time requirement will be extended. The oscillator circuit is designed so that RST will bootstrap the circuit into guaranteed oscillation in a fixed amount of time. The extended reset time allows the growth of the oscillation to produce stable internal clock timing.

#### **DATA SEPARATOR**

The Data Separator is a WD92C32 Digital Phase Lock Loop Floppy Disk Data Separator (DPLL). It was designed to address high performance error rates on floppy disk drives, and to provide superior performance in terms of available bit jitter tolerance. It contains the necessary logic to achieve classical 2nd order, type 2, phase locked loop performance. Figure 1 illustrates the WD92C32 used as the Data Separator in the ST37C65 system. The bit jitter tolerance for the data separator is 60%, which guarantees an error rate of <10E-9.

#### WRITE PRE-COMPENSATION

The ST37C65 maintains the standard first level algorithm to determine when write pre compensation should be applied. The EARLY and LATE signals are used internally to select the appropriate delay in the write data pulse stream. The encoded WRITE DATA signal is synchronized to the 16 MHz or 32 MHz clock if this is the frequency on CLK1 pin (23), and clocked through a shift register. Signals EARLY, NOM, and LATE determine the amount of delay through the shift register before a multiplexed gates the chosen bit to the output. The output data pulse width has a 25% duty

cycle, i.e., one fourth of the bit cell period, and equal to one half the WCLK period.

When PCVAL pin (24)=1, all data will be pre-compensated by ±125ns, regardless of track number and data rate. However, this is only for MFM encoding. There is no write pre-compensation for FM. If PCVAL = 0, and if a track inside number 28 is accessed, then ±187ns pre-compensation will be generated. For frequencies other then 16MHz or 32MHz on the CLK1 pin, the precompensation values will be two and three clock cycles respectively. When the non-standard 300 kb/ s data rate using CLK2 is chosen, the MFM precompensation will always be two clock cycles For 9.6 MHz, this is ±208ns. In this case, the PCVAL function is disabled. Write pre-compensation can be disabled by bit-2 of the Control Register for the AT/EISA. The PCVAL input to ST37C65 is ignored if there is no write pre-compensation.

#### **CLOCK GENERATION**

This logical block provides all the clocks needed by the ST37C65. They are: Sampling Clock (SCLK), Write Clock (WCLK), and the Master Clock (MCLK). SCLK drives the WD92C32 Data Separator used during data recovery. This clock's frequency is always 32 times the selected data rate.

WCLK is used by the encoder logic to place MFM or FM on the serial WD-stream to the disk. WCLK always has a frequency two times the selected data rate.

MCLK is used by microsequencer. MCLK and MCLK\* clock all latches in a two-phase scheme. One microinstruction cycle is four MCLK cycles. MCLK has a frequency equal to eight times the selected MFM data rate or 16 times the FM data rate. Table 13 presents the Clock Data Rate.

In power down mode the XTAL oscillator and the clok circuitry are turned off.

## **TABLE 13. CLOCK DATA RATE**

| DATA RATE | CODE | SCLK     | MCLK    | WCLK    |
|-----------|------|----------|---------|---------|
| 1Mb/s     | MFM  | 32.0 MHz | 8.0 MHz | 2.0 MHz |
| 500 kb/s  | MFM  | 16.0 MHz | 4.0 MHz | 1.0 MHz |
| 500 kb/s  | FM   | 16.0 MHz | 8.0 MHz | 1.0 MHz |
| 250 kb/s  | FM   | 8.0 MHz  | 4.0 MHz | 500 kHz |
| 250 kb/s  | MFM  | 8.0 MHz  | 2.0 MHz | 500 kHz |
| 125 kb/s  | FM   | 4.0 MHz  | 2.0 MHz | 250 kHz |
| 300 kb/s  | MFM  | 9.6 MHz  | 2.4 MHz | 600 kHz |

#### **COMMAND PARAMETERS**

The ST37C65 is capable of performing 15 different commands. Each command is initiated by a multibyte transfer from the processor. The results after execution of the command may also be a multibyte transfer back to the processor. The commands consist of three phases: Command phase, Execution phase, and the Result phase.

- Command phase
   The Floppy Disk Controller (FDC) receives all information required to perform a particular operation from the processor.
- Execution phase
   The FDC performs the operation it was instructed to do.
- Result phase
   After completion of the operation, status and other
   housekeeping information are made available to
   the processor.

Table 14 lists the 15 ST37C65 commands.

#### **TABLE 14. ST37C65 COMMANDS**

- Read Data
- Read Deleted Data
- Write Data
- Write Deleted Data
- Read a Track
- Read ID
- Format a Track
- Scan Equal
- · Scan Low or Equal
- Scan High or Equal
- Recalibrate
- Sense Interrupt Status
- Specify
- Sense Drive Status
- Seek

## TABLE 15. READ DATA

| PHASE     | R/W                   | D7      | D6      | D5      | D4     | D3                   | D2      | D1       | D0       | DESCRIPTION                                                                                                  |
|-----------|-----------------------|---------|---------|---------|--------|----------------------|---------|----------|----------|--------------------------------------------------------------------------------------------------------------|
| COMMAND   | w                     | MT<br>X | MF<br>X | SK<br>X | 0<br>X | 0<br>X               | 1<br>HS | 1<br>US1 | 0<br>US0 | Command code.                                                                                                |
|           | W<br>W<br>W<br>W<br>W |         |         |         |        | C  H R N EOT GPL DTL |         |          |          | Sector ID informatiom prior to command execution. The four bytes are compared against header on floppy disk. |
| EXECUTION | e in the second       |         |         |         |        |                      |         |          |          | Data transfer between FDD and main system.                                                                   |
| RESULTS   | R                     |         |         |         |        | STO                  |         |          |          | Status information after com-                                                                                |
|           | R<br>R                |         |         |         |        | ST1<br>ST2           |         |          |          |                                                                                                              |
|           | R                     |         |         |         |        | С                    |         |          |          | Sector ID information after command execution.                                                               |
|           | R<br>R<br>R           |         |         |         |        | H<br>R<br>N          |         |          |          |                                                                                                              |
|           | R<br>R<br>R<br>R      |         |         |         |        | ST2<br>C<br>H<br>R   |         |          |          | mand execution.  Sector ID information after comand execution.                                               |

## **TABLE 16. READ DELETED DATA**

| PHASE     | R/W    | D7      | D6      | D5      | D4 |            | D3     | D2      | D1       | D0       | DESCRIPTION                                                                                                  |
|-----------|--------|---------|---------|---------|----|------------|--------|---------|----------|----------|--------------------------------------------------------------------------------------------------------------|
| COMMAND   | W      | MT<br>X | MF<br>X | SK<br>X |    |            | 1<br>X | 1<br>HS | 0<br>US1 | 0<br>US0 | Command code.                                                                                                |
|           | w      | ,       | ^       | ^       |    | С          | ^      | 110     | 001      | 000      | Sector ID informatiom prior to command execution. The four bytes are compared against header on floppy disk. |
|           | w<br>w |         |         |         |    | H<br>R     |        |         |          |          |                                                                                                              |
|           | W      |         |         |         |    | N          |        |         |          |          |                                                                                                              |
|           | W      |         |         |         |    | EOT<br>GPL |        |         |          |          |                                                                                                              |
|           | w      |         |         |         |    | DTL        |        |         |          |          |                                                                                                              |
| EXECUTION |        |         |         |         |    |            |        |         |          |          | Data transfer between FDD and main system.                                                                   |
| RESULTS   | R      |         |         |         |    | ST0        |        |         |          |          | Status information after com-                                                                                |
|           | R      | }       |         |         |    | ST1        |        |         |          |          | mana execution.                                                                                              |
|           | R      |         |         |         | ,  | ST2<br>C   |        |         |          |          | Sector ID information after com-                                                                             |
|           |        |         |         |         |    | _          |        |         |          |          | mand execution.                                                                                              |
|           | R      |         |         |         |    | H<br>R     |        |         |          |          |                                                                                                              |
|           | R      |         |         |         |    | N          |        |         |          |          |                                                                                                              |
|           |        |         |         |         |    |            |        |         |          |          | L                                                                                                            |

# **TABLE 17. WRITE DATA**

| PHASE     | R/W         | D7      | D6 | D5     | D4                                      |                    | D3 | D2 | D1  | D0       | DESCRIPTION                                                                                                  |
|-----------|-------------|---------|----|--------|-----------------------------------------|--------------------|----|----|-----|----------|--------------------------------------------------------------------------------------------------------------|
| COMMAND   | W           | MT<br>X | MF | 0<br>X | 0                                       |                    | 0  | 1  | 0   | 1<br>US0 | Command code.                                                                                                |
|           | W           | ^       |    | ^ ,    | · • • • • • • • • • • • • • • • • • • • | С                  | ^  | ПЭ | 031 | 030      | Sector ID informatiom prior to command execution. The four bytes are compared against header on floppy disk. |
|           | W<br>W<br>W |         |    |        |                                         | H<br>R<br>N<br>EOT |    |    |     |          |                                                                                                              |
|           | W<br>W      |         |    |        |                                         | GPL<br>DTL         |    |    | 1   |          |                                                                                                              |
| EXECUTION |             |         |    |        |                                         |                    |    |    |     |          | Data transfer between FDD and main system.                                                                   |
| RESULTS   | R           |         |    |        |                                         | ST0                |    |    |     |          | Status information after command execution.                                                                  |
|           | RRR         |         |    |        |                                         | ST1<br>ST2         |    |    |     |          | Sector ID information after com-                                                                             |
|           | R           |         |    |        |                                         | C<br>H<br>R        |    |    |     |          | mand execution.                                                                                              |
|           | R           |         |    |        |                                         | N                  |    |    |     |          |                                                                                                              |

# **TABLE 18. WRITE DELETED DATA**

| PHASE     | R/W                   | D7      | D6      | D5 | D4     |                                  | D3     | D2  | D1  | D0       | DESCRIPTION                                                                                                  |
|-----------|-----------------------|---------|---------|----|--------|----------------------------------|--------|-----|-----|----------|--------------------------------------------------------------------------------------------------------------|
| COMMAND   | W                     | MT<br>X | MF<br>X | 0  | 0<br>X |                                  | 1<br>X | 0   | 0   | 1<br>US0 | Command code.                                                                                                |
|           | Ŵ                     | ^       | ^       | ^  | ,      | С                                |        | 110 | 001 | 000      | Sector ID informatiom prior to command execution. The four bytes are compared against header on floppy disk. |
|           | W<br>W<br>W<br>W<br>W |         |         |    |        | H<br>R<br>N<br>EOT<br>GPL<br>DTL |        |     |     |          |                                                                                                              |
| EXECUTION |                       | - 41    |         |    |        |                                  |        |     |     |          | Data transfer between FDD and main system.                                                                   |
| RESULTS   | R<br>R<br>R           |         |         |    |        | ST0<br>ST1<br>ST2                |        |     |     |          | Status information after command execution.                                                                  |
|           | RRRR                  |         |         |    |        | C<br>H<br>R<br>N                 |        |     |     |          | Sector ID information after command execution.                                                               |

## **TABLE 19. READ TRACK**

| PHASE     | R/W            | D7      | D6  | D5      | D4       |                   | D3     | D2  | D1       | D0  | DESCRIPTION                                                                                                  |
|-----------|----------------|---------|-----|---------|----------|-------------------|--------|-----|----------|-----|--------------------------------------------------------------------------------------------------------------|
| COMMAND   | 8              | MT<br>X | MF  | SK<br>X | 0        |                   | 0<br>X | 0   | 1<br>US1 | 0   | Command code.                                                                                                |
|           | w              | , ^     | · , |         | <b>X</b> | С                 | ^      | 110 | 001      | 000 | Sector ID informatiom prior to command execution. The four bytes are compared against header on floppy disk. |
|           | <b>V V V V</b> |         |     |         |          | H<br>R<br>N       |        |     |          |     |                                                                                                              |
|           | <b>8 8 8</b>   |         |     |         |          | EOT<br>GPL<br>DTL |        |     |          |     |                                                                                                              |
| EXECUTION |                |         |     |         |          |                   |        |     |          |     | Data transfer between FDD and main system. FDD reads all data fiels from index hole to EOT.                  |
| RESULTS   | R              |         |     |         |          | ST0               |        |     |          |     | Status information after com-                                                                                |
|           | R              |         |     |         |          | ST1<br>ST2        |        |     |          |     | mand execution.                                                                                              |
|           | R              |         |     |         |          | С                 |        |     |          |     | Sector ID information after command execution.                                                               |
|           | R<br>R<br>R    |         |     |         |          | H<br>R<br>N       |        |     |          |     |                                                                                                              |

## TABLE 20. READ ID

| PHASE     | R/W         | D7     | D6      | D5     | D4     |             | D3     | D2      | D1       | D0       | DESCRIPTION                                                                    |
|-----------|-------------|--------|---------|--------|--------|-------------|--------|---------|----------|----------|--------------------------------------------------------------------------------|
| COMMAND   | W           | 0<br>X | MF<br>X | 0<br>X | 0<br>X |             | 1<br>X | 0<br>HS | 1<br>US1 | 0<br>US0 | Command code.                                                                  |
| EXECUTION |             |        |         |        |        |             |        |         |          |          | The first corrected ID information on the cylinder is stored in Data Register. |
| RESULTS   | R           |        |         |        |        | ST0         |        |         |          |          | Status information after com-                                                  |
|           | R           |        |         |        |        | ST1<br>ST2  |        |         |          |          | mand execution.                                                                |
|           | R           |        |         |        |        | C           |        |         |          |          | Sector ID information read during Execution Phase from floppy                  |
|           | R<br>R<br>R |        |         |        |        | H<br>R<br>N |        |         |          |          | disk.                                                                          |

## **TABLE 21. FORMAT A TRACK**

| PHASE     | R/W | D7 | D6 | D5 | D4 |     | D3 | D2 | D1  | D0  | DESCRIPTION                       |
|-----------|-----|----|----|----|----|-----|----|----|-----|-----|-----------------------------------|
| COMMAND   | w   | 0  | MF | 0  | 0  |     | 1  | 1  | 0   | 1   | Command code.                     |
|           | W   | X  | Х  | Х  | Х  |     | Х  | HS | US1 | US0 |                                   |
|           | W   | 1  |    |    |    | N   |    |    |     |     | Bytes/Sector.                     |
|           | W   |    |    |    |    | SC  |    |    |     |     | Sectors/Track.                    |
|           | W   |    |    |    |    | GPL |    |    |     |     | Gap 3.                            |
|           | W   |    |    |    |    | D   |    |    |     |     | Filler Byte.                      |
| EXECUTION |     |    |    |    |    |     |    |    |     |     | Floppy Disk Controller (FDC) for- |
|           |     | }  |    |    |    |     |    |    |     |     | mats an entire track.             |
| RESULTS   | R   | ,  |    |    |    | ST0 |    |    |     |     | Status information after com-     |
|           | R   | }  |    |    |    | ST1 |    |    |     |     | I mand execution.                 |
|           | R   | 1  |    |    |    | ST2 |    |    |     |     |                                   |
|           | R   | 1  |    |    |    | C   |    |    |     |     | In this case, the ID information  |
|           | '`  | l  |    |    |    | Ü   |    |    |     |     | has no meaning.                   |
|           | R   | 1  |    |    |    | Н   |    |    |     |     | l nao no moaning.                 |
|           | R   |    |    |    |    | R   |    |    |     |     |                                   |
|           | R   |    |    |    |    | N   |    |    |     |     |                                   |

## **TABLE 22. SCAN EQUAL**

| PHASE     | R/W         | D7               | D6      | D5      | D4     |                        | D3     | D2      | D1       | D0       | DESCRIPTION                                       |
|-----------|-------------|------------------|---------|---------|--------|------------------------|--------|---------|----------|----------|---------------------------------------------------|
| COMMAND   | w           | MT<br>X          | MF<br>X | SK<br>X | 1<br>X |                        | 0<br>X | 0<br>HS | 0<br>US1 | 1<br>US0 | Command code.                                     |
|           | w           |                  |         |         | ^      | С                      | ^      | 110     |          |          | Sector ID informatiom prior to command execution. |
|           | W<br>W      |                  |         |         |        | H<br>R                 |        |         |          |          |                                                   |
| 9 × 1     | W<br>W<br>W | t de<br>de<br>de |         |         |        | N<br>EOT<br>GPL<br>STP |        |         |          |          |                                                   |
| EXECUTION |             |                  |         |         |        |                        |        |         |          |          | Data compared between the FDD and main system.    |
| RESULTS   | R           |                  |         |         |        | ST0                    |        |         |          |          | Status information after com-<br>mand execution.  |
|           | R<br>R      |                  |         |         |        | ST1<br>ST2             |        |         |          |          | mand execution.                                   |
|           | R           |                  |         |         |        | С                      |        |         |          |          | Sector ID information after command execution.    |
|           | R<br>R      |                  |         |         |        | H<br>R                 |        |         |          |          |                                                   |
|           | R           |                  |         |         |        | N                      |        |         |          |          |                                                   |
|           |             |                  |         |         |        |                        |        |         |          |          |                                                   |

## **TABLE 23. SCAN LOW OR EQUAL**

| PHASE     | R/W | D7      | D6      | D5      | D4     |            | D3     | D2      | D1  | D0       | DESCRIPTION                                       |
|-----------|-----|---------|---------|---------|--------|------------|--------|---------|-----|----------|---------------------------------------------------|
| COMMAND   | W   | MT<br>X | MF<br>X | SK<br>X | 1<br>X |            | 1<br>X | 0<br>HS | 0   | 1<br>US0 | Command code.                                     |
|           | w   |         | ^       | ^       | ^      | С          | ^      | 110     | 001 | 500      | Sector ID informatiom prior to command execution. |
|           | W   |         |         |         |        | H<br>R     |        |         |     |          |                                                   |
|           | W   |         |         |         |        | N<br>EOT   |        |         |     |          |                                                   |
|           | W   |         |         |         |        | GPL<br>DTL |        |         |     |          |                                                   |
| EXECUTION |     |         |         |         |        |            |        |         |     |          | Data compared between FDD and main system.        |
| RESULTS   | R   |         |         |         |        | ST0        |        |         |     |          | Status information after com-<br>mand execution.  |
|           | R   |         |         |         |        | ST1        |        |         |     |          | mund excountry.                                   |
|           | R   |         |         |         |        | ST2<br>C   |        |         |     |          | Sector ID information after com-                  |
|           | RR  |         |         |         |        | H<br>R     |        |         |     |          |                                                   |
|           | R   |         |         |         |        | N          |        |         |     |          |                                                   |
|           |     |         |         |         |        |            |        |         |     |          |                                                   |

**TABLE 24. SCAN HIGH OR EQUAL** 

| PHASE     | R/W    | D7      | D6      | D5      | D4     |            | D3     | D2      | D1       | D0       | DESCRIPTION                                       |
|-----------|--------|---------|---------|---------|--------|------------|--------|---------|----------|----------|---------------------------------------------------|
| COMMAND   | w      | MT<br>X | MF<br>X | SK<br>X | 1<br>X |            | 1<br>X | 1<br>HS | 0<br>US1 | 1<br>US0 | Command code.                                     |
|           | w      | ,       |         |         | ^      | С          |        | 110     |          |          | Sector ID informatiom prior to command execution. |
|           | w      |         |         |         |        | H<br>R     |        |         |          |          | Sommana Sociation.                                |
|           | W      |         |         |         |        | N<br>EOT   |        |         |          |          |                                                   |
|           | W      |         |         |         |        | GPL<br>STP |        |         |          |          |                                                   |
| EXECUTION |        |         |         |         |        |            |        |         |          |          | Data compared between FDD and main system.        |
| RESULTS   | R      | jira i  |         |         |        | ST0        |        |         |          | w        | Status information after com-<br>mand execution.  |
|           | R<br>R |         |         |         |        | ST1<br>ST2 |        |         |          |          | mand excedition.                                  |
|           | R      |         |         |         |        | С          |        |         |          | •        | Sector ID information after command execution.    |
|           | R<br>R |         |         |         |        | H<br>R     |        |         |          |          |                                                   |
|           | R      |         |         |         |        | N          |        |         | -        |          |                                                   |

## TABLE 25. RECALIBRATE

| PHASE     | R/W    | D7     | D6     | D5     | D4     | D3     | D2 | D1       | D0       | DESCRIPTION                   |  |
|-----------|--------|--------|--------|--------|--------|--------|----|----------|----------|-------------------------------|--|
| COMMAND   | W<br>W | 0<br>X | 0<br>X | 0<br>X | 0<br>X | 0<br>X | 1  | 1<br>US1 | 1<br>US0 | Command code.                 |  |
| EXECUTION | ,      |        |        |        |        |        |    |          |          | Head retracted to Track zero. |  |

## **TABLE 26. SENSE INTERRUPT STATUS**

| PHASE   | R/W    | D7     | D6     | D5     | D4     | D3     | D2 | D1       | D0       | DESCRIPTION                      |
|---------|--------|--------|--------|--------|--------|--------|----|----------|----------|----------------------------------|
| COMMAND | W<br>W | 0<br>X | 0<br>X | 0<br>X | 0<br>X | 1<br>X | 0  | 0<br>US1 | 0<br>US0 | Command code.                    |
| RESULTS | R      |        |        |        | S      | то     |    |          |          | Status information about the FDC |
|         | R      |        |        |        | Р      | CN     |    |          |          | at the end of seek operation.    |

## **TABLE 27. SPECIFY**

| PHASE   | R/W | D7 | D6 | D5 | D4              | D3              | D2 | D1 | D0 | DESCRIPTION   |
|---------|-----|----|----|----|-----------------|-----------------|----|----|----|---------------|
| COMMAND | >>> | 1  |    |    | 0<br>SRT<br>HLT | 0<br>HUT<br>HLT |    |    |    | Command code. |

## **TABLE 28. SENSE DRIVE STATUS**

| PHASE   | R/W    | D7     | D6     | D5     | D4     | D:     | 3 D2    | D1       | D0       | DESCRIPTION                   |
|---------|--------|--------|--------|--------|--------|--------|---------|----------|----------|-------------------------------|
| COMMAND | W<br>W | 0<br>X | 0<br>X | 0<br>X | 0<br>X | 0<br>X | 1<br>HS | 0<br>US1 | 0<br>US0 | Command code.                 |
| RESULTS | R      | ,      |        |        |        | ST3    |         |          |          | Status information about FDC. |

## **TABLE 29. SEEK**

| PHASE     | R/W                   | D7     | D6     | D5     | D4            |     | D3                                                       | D2 | D1       | D0       | DESCRIPTION   |
|-----------|-----------------------|--------|--------|--------|---------------|-----|----------------------------------------------------------|----|----------|----------|---------------|
| COMMAND   | <b>&gt; &gt; &gt;</b> | 0<br>X | 0<br>X | 0<br>X | 0<br>X        | NCN | 1<br>X                                                   | 1  | 1<br>US1 | 1<br>US0 | Command code. |
| EXECUTION |                       |        |        |        | Heac<br>cylin |     | Head is positioned over proper cylinder on the diskette. |    |          |          |               |

## TABLE 30. COMMAND SYMBOL DESCRIPTIONS

| SYMBOL  | NAME                | DESCRIPTION                                                                                                                                                               |
|---------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Α0      | Address line 0      | A0 controls selection of Main Status Register (A0=0) or Data Register (A0=1).                                                                                             |
| С       | Cylinder Number     | C stands for the current/selected cylinder (track) number 0 through 255 of the medium.                                                                                    |
| D       | Data                | D stands for the data pattern which is going to be written into a sector.                                                                                                 |
| D7 - D0 | Data Bus            | 8-bits Data Bus, where D7 stands for a most significant bit, and D0 stands for a least significant bit.                                                                   |
| DTL     | Data Length         | When N is defined as 00, DTL stands for the Data length which users are going to read out or write into the sector.                                                       |
| EOT     | End of Track        | EOT stands for the final sector number on a cylinder. During Read or Write operations, FDC will stop data transfer a sector number equal to EOT.                          |
| GPL     | Gap Length          | GPL stands for the length of Gap 3. During the FORMAT Command, it determines the size of Gap 3.                                                                           |
| н       | Head Address        | H stands for head number 0 or 1, as specified in the ID field.                                                                                                            |
| HLT     | Head Load Time      | HLT stands for the Head Load Time in FDD (2 to 254 ms in 2 ms increments).                                                                                                |
| нѕ      | Head Select         | HS stands for a selected head number 0 or 1 and controls the polarity of pin 25 (in 40 pin DIP) or pin 28 (in 44 pin PLCC).                                               |
| HUT     | Head Unload Time    | HUT stands for the HEAD UNLOAD TIME after a Read or Write operation has occurred (16 to 240 ms in 16 ms increments).                                                      |
| MF      | FM or MFM           | If MF is low, FM mode is selected. If it is high, MFM mode is selected.                                                                                                   |
| MT      | MultiTrack          | If MT is high, a MUTITRACK operation is performed. If MT=1 after finishing Read/Write operation on side 0, FDC will automatically start searching for sector 1 on side 1. |
| N       | Number              | N stands for the NUMBER of data bytes written in a sector.                                                                                                                |
| NCN     | New Cylinder Number | NCN stands for a NEW CYLINDER NUMBER which is going to be reached as a result of the Seek operation. Desired position of head.                                            |
| ND      | Non-DMA Mode        | ND stands for operation in the NON-DMA MODE.                                                                                                                              |

**TABLE 30. COMMAND SYMBOL DESCRIPTIONS** 

| SYMBOL | NAME             | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCN    | Present Cylinder | PCN stands for the cylinder number at the completion of the SENSE<br>INTERRUPT STATUS Command. Position of head ar present time.                                                                                                                                                                                                                                                                            |
| R      | Record           | R stands for the sector number which will be read or written.                                                                                                                                                                                                                                                                                                                                               |
| R/W    | Read/Write       | R/W stands for either READ or WRITE signal.                                                                                                                                                                                                                                                                                                                                                                 |
| sc     | Sector           | SC indicates the number of sectores per cylinder.                                                                                                                                                                                                                                                                                                                                                           |
| sĸ     | Skip             | SK stands for SKIP Deleted Data Address Mark.                                                                                                                                                                                                                                                                                                                                                               |
| SRT    | Step Rate Time   | SRT stabds for the Stepping Rate for the FDD (1 to 16 ms in 1 ms increments). Stepping Rate applies to all drives. In 2's complement format, F (hex)=1 ms, E (hex)=2 ms, etc.                                                                                                                                                                                                                               |
| ST0-3  | Status 0-3       | ST0-3 stands for one of four registers which store the STATUS information after a command has been executed. This information is available during the result phase after command execution. These registers should not be confused with the Main Status Register (selected by A0=0). ST0-3 may be read only after a command has been executed and contains information relevant to that particular command. |
| STP    |                  | During a SCAN operation, If STP=1, the data in contiguous sectors is compared byte by byte with data sent from the processor ( or DMA); if STP=2, then alternate sectore are read and compared.                                                                                                                                                                                                             |
| US0-1  | Unit Select 0-1  | US stands for a selected drive; binary encoded, 1 of 4.                                                                                                                                                                                                                                                                                                                                                     |

## COMMAND DESCRIPTIONS

#### **Read Data**

A set of nine byte words are required to place the FDC into the Read Data Mode. After the Read Data command has been issued, the FDC loads the head (if it is in the unloaded state), waits the specified head settling time Idefined in Ihe Specify Command), and begins reading ID Address Marks and ID fields. When the current sector number ("R") stored in the ID Register (IDR) compares with the sector number read of the diskette, then the FDC outputs data (from the

data field) byte-to-byte to the main system via the dala bus. After completion of the read operation from the current sector, the Sector Number is incremented by one, and the data from the next sector is read and output on the data bus. This continuous read function is called a "Multi- sector Read Operation" The Read Data Command may be terminated by the receipt of a Terminal Count signal. TC should be issued at the same time thal the DACK\* for the last byte of data is

sent. Upon receipt of this signal, the FDC stops outputting data to the processor, but will continue to read data from the current sector, check CRC (Cyclic Redundancy Count) bytes, and then at the end of the sector terminate the Read Data command. The amount of data which can be handled with a single command to the FDC depends upon MT (multitrack), MF (MFM/FM), and N (number of bytes sector). Table 31 lists the Transfer Capacity.

**TABLE 31. TRANSFER CAPACITY** 

| Multi- | MFM/ | Bytes/   | Maximum Transfer Capacity              | Final Sector                    |
|--------|------|----------|----------------------------------------|---------------------------------|
| Track  | FM   | Sector   | (Bytes/Sector)                         | Read from                       |
| MT     | MF   | N        | (Number of Sectors)                    | Diskettes                       |
| 0      | 0    | 00<br>01 | (128) (26) = 3328<br>(256) (26) = 6656 | 26 at side 0<br>or 26 at side 1 |
| 1 1    | 0    | 00       | (128) (52) = 6656                      | 26 at side 1                    |
|        | 1    | 01       | (256) (52) = 13312                     | 26 at side 1                    |
| 0      | 0    | 01       | (256) (15) = 3840                      | 15 at side 0                    |
|        | 1    | 02       | (512) (15) = 7680                      | or 15 at side 1                 |
| 1      | 0    | 01       | (256) (30) = 7680                      | 15 at side 1                    |
|        | 1    | 02       | (512) (30) = 15360                     | 15 at side 1                    |
| 0      | 0    | 02<br>03 | (512) (8) = 4096<br>(1024) (8) = 8192  | 8 at side 0<br>8 at side 1      |
| 1      | 0    | 02       | (512) (16) = 8192                      | 8 at side 1                     |
|        | 1    | 03       | (1024) (16) = 16384                    | 8 at side 1                     |

The "multi-track" function (MT) allows the FDC to read data from both sides of the diskette. For a particular cylinder, data will be transferred starting at Sector 1, Side 0 and completing at Sector L, Side 1 (Sector L = last sector on the side). Note, this function pertains to only one cylinder (the same track) on each side of the diskette. When N=0, then DTL defines the data length which the FDC must treat as a sector. If DTL is smaller than the actual data length in a sector, the data beyond

DTL in the sector is not sent to the Data Bus. The FDC reads (internaily) the complete sector performing the CRC check, and depending upon the manner of command termination, may perform a Multi-Sector Read operation. When N is non-zero, then DTL has no meaning and should be set to FF hexidecimal.

At the completion of the Read Dala command, the head is not unloaded until after Head Unload Time

4

Interval (specified in the Specity command) has elapsed. If the processor issues another command before the head unloads, then the head settling time may be saved between subsequent reads. This time out is particularly valuable when a diskette is copied from one drive to another If the FDC detects the Index Hole twice without finding the right sector, (indicated in 'R'), then the FDC sets the ND (No Data) flag in Status Register 1 to a 1 (high), and terminates the Read Data command. (Status Register 0 also has bits 7 and 6 set to 0 and 1 respectively.)

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

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

During disk data transfers between the FDC and the processor via the data bus, the FDC must be serviced by the processor every  $27\mu s$  in the FM mode, and every  $19\mu s$  in the MFM mode or the FDC sets the OR (Overrun) flag in Status Register 1 to a 1 (high), and terminates the Read Data command. If the processor terminates a read (or write) operation in the FDC, then the ID information in the Result phase is dependent upon the state of the MT bit and EOT byte. Table 32 shows the values for C, H, A, and N, when the processor terminates the command.

TABLE 32. C, H, R, AND N VALUES

|    |    | Final Sector<br>Transferred   | ID Information at<br>Result Phase |           |            |          |  |  |  |  |
|----|----|-------------------------------|-----------------------------------|-----------|------------|----------|--|--|--|--|
| MT | HD | to Processor                  | С                                 | Н         | R          | N        |  |  |  |  |
| 0  | 0  | Less than EOT<br>Equal to EOT | NC<br>C+1                         | NC<br>NC  | R+1<br>R=1 | NC<br>NC |  |  |  |  |
| 0  | 1  | Less that EOT<br>Equal to EOT | NC<br>C+1                         | NC<br>NC  | R+1<br>R=1 | NC<br>NC |  |  |  |  |
| 1  | 0  | Less than EOT<br>Equal to EOT | NC<br>NC                          | NC<br>LSB | R+1<br>R=1 | NC<br>NC |  |  |  |  |
| 1  | 1  | Less than EOT<br>Equal to EOT | NC<br>C+1                         | NC<br>LSB | R+1<br>R=1 | NC<br>NC |  |  |  |  |

Note: NC (No Change): The same value as the one at the beginning of command execution.

#### **Write Datas**

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

After writing data into the current sector, the sector number stored in 'R' is incremented by one, and the next data field is written into. The FDC continues this 'Multisector Write Operation" until the issuance of a Terminal Count signal. If a Terminal Count signal is sent complete the data field. If the Terminal Counl signal is received while a data field is being written, then the remainder of the data field is filled with zeros.

The FDC reads the ID field of each sector and checks the CRC bytes in one of the ID fields, it sets the DE (Data Error) flag of Status Register 1 to a 1 (high) and terminates the Wrile Data command. (Status Register 0 also has bits 7 and 6 set to 0 and 1 respectively.)

The Write command operates in much the same manner as the Read command. The following items are the same, and one should refer to the Read Data

#### command for details

- Transfer capacity
- . EN (End of Cylinder) flag
- · ND (No Data) flag
- · Head Unload Time interval
- ID Information when the processor terminates command
- Definition of DTL when N = 0 and when N= 0

In the Write Data mode, data transfers between the processor and FDC via the data bus, must occur every  $27\mu s$  in the FM mode and every  $13\mu s$  in the MFM mode. If the time interval between data transfers is longer than this, then the FDC sets the OR (Overrun) flag in Status Register 1 to a 1 (high) and terminates the Write Data command (Status Register 0 also has bits 7 and 6 set to 0 and 1 respectively.)

#### Write Deleted Data

This command is the same as the Write Data command except a Deleted Data Address mark is written at the beginning of the data field instead of the normal Data address mark.

#### Read Deteted Data.

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

#### Read A Track

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

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

#### Read ID

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

#### **Format A Track**

The Format command allows an entire track to be formatted. After the index hole is detected, data is written on the diskette; Gaps, Address marks, ID fields and data fields, all per the IBM System 34 (double density) or System 3740 (single density) format are recorded. The particular format which will be written is controlled by the values programmed inlo N (number ot bytes/sector), SC (sectors/cylinder), GPL (gap length), and D (data pattern) which are supplied by the processor during the Command phase. The data field is filled with the byte of data stored in D. The ID field for each sector is supplied by the processor; that is, four data requests per sector are made by the FDC for C (cylinder number), H (head number), R (sector number) and N (number of bytes/sector). This allows the diskette to be formatted with nonsequential sector numbers, if desired.

The processor must send new values for C, H, R, and N to the ST37C65 for each sector on the track. If FDC is set for the DMA mode, it will issue four DMA requests per sector. If it is set for the Interrupt mode, it will issue four interrupts per sector and the processor must supply C, H, R, and N loads for each sector. The contents of the R register are incremented by 1 after

each sector is formatted; thus, the R register contains a value of R when it is read during the Result phase. This incrementing and formatting continues for the whole track until the FDC detects the index hole for the second time, whereupon it terminates the command.

Table 33 shows the relationship between N, SC, and GPL for various sector sizes.

TABLE 33. N, SC AND GPL RELATIONSHIP

| FORMAT                 | SECTOR SIZE      | N  | SC | GPL1 | GPL2,3 |
|------------------------|------------------|----|----|------|--------|
|                        | ARD FLOPPY       |    |    |      |        |
| FM MODE                |                  |    |    |      |        |
|                        | 128 bytes/sector | 00 | 1A | 07   | 1B     |
|                        | 256              | 01 | OF | 0E   | 2A     |
|                        | 512              | 02 | 80 | 1B   | 3A     |
|                        | 1024             | 03 | 04 | 47   | 8A     |
|                        | 2048             | 04 | 02 | C8   | FF     |
|                        | 4096             | 05 | 01 | C8   | FF     |
| MFM                    | 256              | 01 | 1A | 0E   | 36     |
|                        | 512              | 02 | 0F | 1B   | 54     |
|                        | 1024             | 03 | 08 | 35   | 74     |
|                        | 2048             | 04 | 04 | 99   | FF     |
|                        | 4096             | 05 | 02 | C8   | FF     |
|                        | 8192             | 06 | 01 | C8   | FF     |
| 5 1/4" MINI<br>FM MODE | -FLOPPY          |    |    |      |        |
|                        | 128              | 00 | 12 | 07   | 09     |
|                        | 128              | 00 | 10 | 10   | 19     |
|                        | 256              | 01 | 08 | 18   | 30     |
|                        | 512              | 02 | 04 | 46   | 87     |
|                        | 1024             | 03 | 02 | C8   | FF     |
| -                      | 2048             | 04 | 01 | C8   | FF     |
| MFM MOD                | E                |    |    |      |        |
|                        | 256              | 01 | 12 | 0A   | 0C     |
|                        | 256              | 01 | 10 | 20   | 32     |
|                        | 512              | 02 | 08 | 2A   | 50     |
|                        | 1024             | 03 | 04 | 80   | F0     |
|                        | 2048             | 04 | 02 | C8   | FF     |
|                        | 4096             | 05 | 01 | C8   | FF     |
| 3 1/2" SON<br>FM MODE  | Y MICRO-FLOPPY   |    |    |      |        |
|                        | 128              | 00 | 0F | 07   | 1B     |
|                        | 256              | 01 | 09 | 0E   | 2A     |
|                        | 512              | 02 | 05 | 1B   | 3A     |
| мғм мор                | E                |    |    |      |        |
|                        | 256              | 01 | 0F | 0E   | 36     |
|                        | 256              | 02 | 09 | 1B   | 54     |
|                        | 1024             | 03 | 05 | 35   | 74     |

#### Scan Commands

The Scan commands allow data which is being read from the diskette to be compared against data which is being supplied from the main system. The FDC compares the data on a byte-by-byte basis and looks for a sector of data which meets the conditions The hexidecimal byte of FF either from memory or from FDD can be used as a mask byte because it always meets the condition of the comparison. Ones complement arithmetic is used for comparison (FF=largest number. 00=smallest number). After a whole sector of data is compared, if the conditions are not met, the sector number is incremented (R + STP -8R), and the scan operation is continued. The scan operation continues until one of the following conditions occur the conditions for scan are met (equal, low, or high), the last sector on the track is reached (EOT), or the terminal count signal is received.

If the conditions for scan are met, then the FDC sets the SH (Scan Hit) flag of Status Register 2 to a 1 (high) and terminates the Scan command. If the conditions for scan are not met between the starting sector (as specified by R) and the last sector on the cylinder (EOT), then the FDC sets the SN (Scan Not Satisfied) flag of Status Regisler 2 is a 1 (high) and terminates the Scan command. The receipt of a Terminal Count signal from the processor or DMA controller durring the scan operation will cause the FDC to complete the comparison of the particular byte which is in process and the to terminale the command. Table 34 shows the status of bits SH and SN under various conditions of Scan.

TABLE 34, STATUS OF BITS SH AND SN

| STATUS REGIS |    | BIT-3 | COMMENTS          |
|--------------|----|-------|-------------------|
| Scan Equal   | 0  | 1     | DFDD = Dprocessor |
| •            | 1  | 0     | DFDD ≠ Dprocessor |
|              | 0  | 1     | DFDD = Dprocessor |
| Scan Low     | 0  | 0     | DFDD < Dprocesso  |
| or Equal     | 1  | 0     | DFDD > Dprocessor |
|              | 0  | 1     | DFDD = Dprocessor |
| Scan High    | 0  | 0     | DFDD > Dprocesso  |
| or Equal     | 1, | 0     | DFDD < Dprocesso  |

## ST37C65

If the FDC encounters a Deleted Data Address mark on one of the sectors (and SK=0), then it regards the sector as the last sector on the cylinder, sets the CM (Control mark) flag of Status Register 2 to a 1 (high) and terminates the command If SK=1, the FDC skips the sector with the Deleted Address mark and reads the next sector. In the second case (SK=1), the FDC sets the CM (Conlrol mark) flag of Status Register 2 to a 1 (high) in order to show that a deleted sector had been encountered.

When either the STP (contiguous sectors=01, or alternate sectors=02) sectors are read or the MT (Multitrack) is programmed it is necessary to remember that the last sector on the track must be read. For example, if STP=02, MT=0, the sectors are numbered sequentially 1 through 26 and the Scan command is started at sertor 21, the following will happen: sectors 21, 23, and 25 will be read, then the next sector (26) will be skipped and the index hole will be encountered before the EOT value of 26 can be read. This will result in an abnormal termination of the command. If the EOT had been set at 25 or the scanning started at sector 20, then the Scan command would be completed in a normal manner.

During the Scan command, data is supplied by either the processor or DMA controller for comparison against the data read from the diskette. In order to avoid having the OR (Overrun) flag set in Status Register 1, it is necessary to have the data available in less than 27 $\mu$ s (FM mode) or 13 $\mu$ s (MFM mode). If an Overrun occurs, the FDC ends the command with bits 7 and 6 of Status Register 0 set to 0 and 1, respectively.

#### Seek

The Read/Write head within the FDD is moved from cylinder to cylinder under control of the Seek command. FDC has four independent Present Cylinder Registers for each drive. They are cleared only after the Recalibrate command. The FDC compares the PCN (Present Cylinder Number) which is the current head position with the NCN (New Cylinder Number), and if Ihere is a difference, performs the following operations:

PCN < NCN: Direction signal to FDD set to a 1 (high), and step pulses are issued. (Step In)

PCN > NCN: Direction signal to FDD set to a 0 (low), and step pulses are issued. (Step Out)

The rate at which step pulses are issued is controlled by SRT (Stepping Rate Time) in the Specify command. After each step pulse is issued NCN is compared against PCN, and when NCN = PCN, lhe SE (Seek End) flag is set in Status Register 0 to a 1 (high), and the command is terminated At this point FDC interrupt goes high. Bits D0B-D3B in the Main Status Register are set during the Seek operation and are cleared by the Sense Interrupt Status command.

During the command phase of the Seek operation the FDC is in the FDC Busy state; but during the Execution phase, it is in the non-busy state. While the FDC is in the non-busy state, another Seek command may be issued, and in this manner parallel Seek operations may be done on up to four drives at once. No other command can be issued as long as the FDC is in the process of sending step pulses to any drive.

If the time to write three bytes of Seek command exceeds 150µs, the timing between the first two step pulses may be shorter than that set in the Specify command by as much as 1ms.

#### Recalibrate

Tne function of this command is to retract the Read/ Write nead within the FDD to the Track 0 position. The FDC clears the contents of the PCN counter and checks the status of the Track 0 signal from the FDD. As long as the Track 0 signal is low, the Direction signal remains 0 (low) and step pulses are issued. When the Track 0 signal goes high, the SE (Seek End) flag in Status Register 0 is set to a 1 (high) and the command is terminated If the Track 0 signal is still low after 255 step pulses have been issued, the FDC sets the SE (Seek End) and EC (Equipment Check) flags of Status Register 0 to both 1s command after bits 7 and 6 of Status Register 0 are set to 0 and 1 respectively The ability to do overlap Recalibrate commands to multiple FDDs and the loss of the Ready signal, as described in the Seek command, also applies to the Recalibrate command.

#### **Sense Interrupt Status**

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

- 1 Upon entering the Result phase of
- Read Data command
- Read A Track command
- Read ID command
- · Read Deleted Data command
- Write Data command
- Format A Cylinder command
- Write Deleted Data command
- Scan commands
- 2 Ready Line of FDD changes state
- 3 End of Seek or Recalibrate command
- 4 During Execution phase in the non-DMA mode

Interrupts caused by reasons 1 and 4 above occur during normal command operations and are easily discernible by the processor During an Execution phase in non-DMA mode, DBS in the Main Status Register is high. Upon entering the Result phase, this bit gets cleared. Reasons 1 and 4 do not require Sense Interrupt Status commands.

The interrupt is cleared by Reading/Writing data to the FDC. Interrupts caused by reasons 2 and 3 above may be uniquely identified with the aid of the Sense Interrupt Status command. This command, when issued. resets the Interrupt signal and via bits 5, 6, and 7 ot Status Register 0 identifies the cause of the interrupt.

TABLE 35. INTERRUPT CAUSE

| BIT-5 | BIT-6 | BIT-7 | CAUSE                                                |
|-------|-------|-------|------------------------------------------------------|
| 0     | 1     | 1     | Ready line changed state, either polarity.           |
| 1     | . 0   | 0     | Normal Termination of Seek or Recalibrate command.   |
| 1     | 1     | 0     | Abnormal Termination of Seek or Recalibrate command. |

The Sense Interrupt Status command is used in conjunction with the Seek and Recalibrate commands which have no Result phase. When the disk drive has reached the desired head position, the ST37C65 will Set the Interrupt line true. The host CPU must then issue a Sense Interrupt Status command to determine the actual cause of the interrupt, which could be Seek End or a change in ready status from one of the drives. See Figure 7.

The Specify command sets the initial values for each of the three internal timers: The HUT (Head Unload Time) defines the time from the end of the Execution phase of one of the Read/Write commands to the head unload state This timer is programmable from 16 to 240ms in increments of 16ms (01=16ms, 02=120ms, 0F=240ms). The SRT (Step Rate Time) defines the time interval between adjacent step pulses. This timer is programmable from 1 to 16ms in increments of 1ms (F=1ms, E=2ms, D=3ms, etc.). The HLT (Head Load Time) defines the time between when the Head Load signal goes high and the Read/Write operation starts. This timer is programmable from 2 to 254ms in increments of 2ms (01=2ms, 02=4ms, 03=6ms . . . 7F=254ms).

The time intervals mentioned above are a direct lunction of the clock (CLK on pin 23). Times indicated above are for a 16MHz clock; if the clock was reduced to 8MHz, then all time intervals are increased by a factor of 2. If the clock was increased to 32MHz, then all time in tervals are decreased by half.

The choice of DMA or non-DMA operation is made by the ND (Non-DMA) bit. When this bit is high (ND = 1), the Non-OMA mode is selected; and when ND = 0, the DMA mode is selected.

#### Sense Drive Status

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

#### Invalid

If an Invalid command is sent to the FDC (a command not defined above), then the FDC will terminate the command after bits 7 and 6 of Status Register 0 are set

## ST37C65

to 1 and 0 respectively. No interrupt is generated during this condition. Bits 6 and 7 (DIO and RQM) in the Main Status Register are both high (1), indicating to the processor that the ST37C65 is in the Result phase and the contents of Status Register 0 (STD) must be read When the processor reads Status Register 0, it will find an 80 hex, indicating an Invalid command was received.

A Sense Interrupt Status command must be sent after a Seek or Recalibrate interrupt; otherwise the FDC will consider the next command to be an invalid command. In some applications, the user may wish to use this command as a No-Op command to place the FDC in a standby or No Operation state.

#### FIGURE 8. ST37C65 FM MODE FORMAT

| GAP : | SYNC | IAM | GAP | SYNC | IDAM | С | H | s | ·N | C | GAP | SYNC | DATA | DATA | С | GAP | GAP  |
|-------|------|-----|-----|------|------|---|---|---|----|---|-----|------|------|------|---|-----|------|
| (4a)  | 6x   | FC. | (1) | 6x   | FE   | Υ | D | Ė | 0  | R | (2) | 6x   | AM   |      | R | (3) | (4b) |
| 40x   | 00   |     | 26x | .00  |      | L |   | С |    | С | 11x | 00   | FB   |      | c |     |      |
| FF    |      |     | FF  |      |      |   |   |   |    |   | FF  |      | or   |      |   |     |      |
| 1 1   |      |     |     |      | 1    |   |   | · |    |   |     |      | F8   |      |   |     | İ    |

## FIGURE 9. ST37C65 MFM MODE FORMAT

| GAP<br>(4a) | SYNC<br>12x | IAM<br>3x | GAP<br>(1) | SYNC<br>12x | 3x       | C<br>Y | H<br>D | SE | N<br>O | CRC | GAP<br>(2) | SYNC<br>12x | DATA<br>AM           | DATA | R | GAP<br>(3) | GAP<br>(4b) |
|-------------|-------------|-----------|------------|-------------|----------|--------|--------|----|--------|-----|------------|-------------|----------------------|------|---|------------|-------------|
| 80x<br>FF   | 00          | C2<br>FC  | 50x<br>4E  | 00          | A1<br>FE | L      |        | С  |        | С   | 22x<br>4E  | 00          | 3x<br>A1<br>FB<br>F8 |      | С |            |             |

## **AC ELECTRICAL CHARACTERISTICS**

 $T_A=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                                                      | Parameter                                            |      | Limits |                 | Units           | Conditions |
|-------------------------------------------------------------|------------------------------------------------------|------|--------|-----------------|-----------------|------------|
|                                                             |                                                      | Min  | Тур    | Max             |                 |            |
| т                                                           | Clock high pulse duration                            | 13.5 |        |                 | ns              |            |
| T. 1                                                        | Clock low pulse duration                             | 13.5 | İ      |                 | ns              |            |
| T.                                                          | Clock rise/fall time                                 |      | 1      | 2               | ns              |            |
| T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> T <sub>4</sub> | A0, CS*, DACK* set up time                           | 0    |        | _               | ns              |            |
|                                                             | to RD* low                                           |      |        |                 |                 |            |
| T <sub>5</sub>                                              | RD* width                                            | 90   |        |                 | ns              |            |
| T <sub>6</sub>                                              | A0, CS*, DACK* hold time to RD* high                 | 0    |        |                 | ns              |            |
| T.                                                          | Data access time from RD* low                        |      |        | 90              | ns              |            |
| T.°                                                         | Data bus to float delay from RD* high                | 10   |        | 65              | ns              | *          |
| T <sub>8</sub> T <sub>9</sub> T <sub>10</sub>               | IRQ reset delay time from RD* high                   |      |        | T <sub>18</sub> | ns              | +150ns     |
| T <sub>11</sub>                                             | A0, CS*, DACK*, LDCR*, LDOR*                         | 0    | j i    |                 | ns              | N. T.      |
| - ''                                                        | set up time to WR* low                               |      |        |                 |                 | * *        |
| T <sub>12</sub>                                             | WR* width                                            | 60   |        |                 | ns              | 4,         |
| T <sub>13</sub>                                             | A0, CS*, DACK*, LDCR*, LDOR* hold time from WR* high | 0    |        |                 | ns              | 7 1.       |
| T <sub>15</sub>                                             | Data set up time to WR* high                         | 80   |        |                 | ns              |            |
| T <sub>16</sub>                                             | Data hold time from WR* high                         | 0    |        |                 | ns              |            |
| T <sub>17</sub>                                             | IRQ reset delay time from WR* high                   |      | ļ      | T <sub>18</sub> | ns              | +150ns     |
| T <sub>18</sub>                                             | DMA cycle time                                       | 52   |        | 1 10            | T <sub>18</sub> | . 100113   |
| 1 1                                                         | DACK* delay time from DMA high                       | 0    | İ      |                 | ns              |            |
| T <sub>20</sub>                                             | DMA reset delay time from DACK* low                  |      |        | 140             | ns              |            |
| T. 20                                                       | DACK* width                                          | 90   |        | ,               | ns              |            |
| T <sub>21</sub><br>T <sub>22</sub>                          | RD* or WR* response from DMA high                    |      |        | 48              | T <sub>18</sub> |            |
| T <sub>23</sub>                                             | RD* delay from DMA                                   | 0    |        |                 | ns              |            |
| T                                                           | WR* delay from DMA                                   | Ö    |        |                 | ns              |            |
| T <sub>24</sub><br>T <sub>28</sub>                          | TC delay from last DMA or IRQ, RD*                   | Ö    | i      | 192             | T <sub>18</sub> |            |
| T <sub>29</sub>                                             | TC delay from last DMA or IRQ, WR*                   | ō    |        | 384             | T <sub>18</sub> |            |
| T.,                                                         | TC width                                             | 60   |        |                 | ns              |            |
| T <sub>30</sub><br>T <sub>31</sub>                          | Reset width - TTL driven CLK1                        | 60   | į i    |                 | ns              |            |
| T <sub>32</sub>                                             | Chip access delay from RST low                       | 32   |        |                 | T <sub>18</sub> |            |
| T,,                                                         | DIRC* hold & set up to STEP* low                     | 4    |        |                 | T <sub>18</sub> |            |
| T <sub>33</sub><br>T <sub>34</sub>                          | STEP* active time low                                | 24   |        | -               | T <sub>18</sub> |            |
| T <sub>35</sub>                                             | DIRC* hold time after STEP*                          | 96   |        |                 | T <sub>18</sub> |            |
| T <sub>36</sub>                                             | STEP* cycle time                                     | 132  |        |                 | T <sub>18</sub> |            |
| T <sub>37</sub>                                             | DSX* hold time from STEP* low                        | 20   |        |                 | T <sub>18</sub> |            |
| Т.,                                                         | IDX* index pulse width                               | 2    |        |                 | T <sub>18</sub> |            |
| T <sub>39</sub>                                             | RDD* active time low                                 | 40   |        |                 | ns              |            |
| T <sub>40</sub>                                             | WD* write data width low                             |      | 1/2    |                 | WCLK            |            |

## **ABSOLUTE MAXIMUM RATINGS**

Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW

## DC ELECTRICAL CHARACTERISTICS

 $T_a=0^{\circ}$  - 70° C, Vcc=5.0 V ± 10% unless otherwise specified.

| Symbol                              | Parameter                          | Min  | Limits<br>Typ | Max | Units | Conditions              |
|-------------------------------------|------------------------------------|------|---------------|-----|-------|-------------------------|
| V <sub>IL</sub>                     | Input low level                    | -0.5 |               | 0.8 | V     |                         |
| V,,                                 | Input high level                   | 2.2  |               | VCC | V     |                         |
| V <sub>IH</sub><br>V <sub>OL</sub>  | Output low level for Dx, IRQ, DMA  |      |               | 0.4 | V     | I <sub>OL</sub> = 24 mA |
| V <sub>oH</sub>                     | Output high level for Dx, IRQ, DMA | 2.8  |               |     | ٧     | I <sub>OH</sub> = -5 mA |
| V <sub>OLHC</sub>                   | Output low-high current open drain |      |               | 0.4 | ٧     | I <sub>OL</sub> = 24 mA |
| I <sub>cc</sub>                     | Avg. power supply current          |      | 5             |     | mΑ    |                         |
| I <sub>ccc</sub>                    | Power down current                 |      | 100           |     | μΑ    |                         |
|                                     | Input leakage                      |      |               | ±10 | μΑ    |                         |
| I <sub>IL</sub><br>V <sub>ILT</sub> | Input low trashold - "Schmitt"     | 0.8  |               | 1.1 | V     |                         |
| V <sub>IHT</sub>                    | Input high trashold - "Schmitt"    | 1.7  |               | 2.0 | V     |                         |
| V <sub>HYS</sub>                    | Schmitt trigger hysterisis         | 0.45 |               |     | V     |                         |

## **CLOCK TIMING**



## **GENERAL READ TIMING**



## **GENERAL WRITE TIMING**



## ST37C65



## TERMINAL COUNT TIMING



## **RESET TIMING**



4

## DISK DRIVE TIMING



PRODUCTS PREVIEW 8

# Index

| ST56C5XX | 6-15    |
|----------|---------|
| ST78C36  | <br>6-3 |



Printed September 8, 1994

## **ECP/EPP PARALLEL PRINTER PORT WITH 16 BYTE FIFO**

### DESCRIPTION

The ST78C36 is a monolithic Bidirectional ECP/EPP Parallel port designed to operate as a general purpose I/O port. It contains all the necessary input/output signals to be configured as a CENTRONICS printer port, MicroSoft/HP ECP, IBM EPP smart printer port. The ST78C36 is a general purpose input/output controller with 16 byte internal FIFO. FIFO operation can be enabled or disabled. For CENTRONICS printer operation, all registers are mapped to IBM printer port registers.

The ST78C36 is designed to operate as normal printer interface without any additional settings.

#### **PLCC Package**



#### **FEATURES**

- 16 bytes of printer output FIFO
- · Bi-directional parallel port
- Bi-directional I/O ports
- Register compatible to IBM XT, AT, compatible 386, 486
- MicroSoft ECP compatible.

## ORDERING INFORMATION

 Part number
 Package
 Operating temperature

 ST78C36CJ44
 PLCC
 0° C to + 70° C

 ST78C36IJ44
 PLCC
 -40° C to + 85° C

 ST78C36CQ48
 TQFP
 0° C to + 70° C

## **BLOCK DIAGRAM**



| Symbol  | Pin  | Signal Type | Pin Description                                                                                                                                                                                                                 |
|---------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ERROR*  | 1*   | I           | General purpose input or line printer error (active low). This is an output from the printer to indicate an error by holding it low during error condition.                                                                     |
| SLECET  | 2*   | 1           | General purpose input or line printer selected (active high). This is an output from the printer to indicate that the line printer has been selected.                                                                           |
| BUSY*   | 3*   | I           | General purpose input or line printer busy (active low). An output from the printer to indicate printer is not ready to accept data.                                                                                            |
| ACK*    | 4*   | 1           | General purpose input or line printer acknowledge (active low). This input is pulsed low by the printer to indicate that data has been accepted successfully.                                                                   |
| PE      | 5*   | I           | General purpose input or line printer paper empty (active high). An output from the printer to indicate out of paper.                                                                                                           |
| тс      | 6    | I           | Terminal Count (active high). This signal indicates to ST78C36 that data transfer is complete. If DMA operation mode is selected for command execution, TC will be qualified by DACK*, but not in the programmed I/O execution. |
| DRQ     | 7    | 0           | Direct Memory Access Request (three state, active high).<br>DMA request for byte transfers of data.                                                                                                                             |
| DACK*   | 8    | 1           | DMA ACKNOWLEDGE (active low). Used by DMA controller to transfer data from the ST78C36 onto the bus.                                                                                                                            |
| D7-D0   | 9-16 | 1/0         | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus.                                                                           |
| AEN*    | 17   | 1           | Host address enable (active low). All decoded addresses are valid when AEN* is low.                                                                                                                                             |
| REFRESH | 18   | ı           | Referesh cycle.                                                                                                                                                                                                                 |
| IRQ     | 19   | 0           | Printer interrupt output (active low). To signal the state of the printer port. This pin tracks the ACK* input pin, When ACK* is low IRQ is low and when ACK* is high IRQ is high                                               |
| XTAL1   | 20   | . 1         | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal                                                                                                           |

| Symbol                                       | Pin   | Signal Type                             | Pin Description                                                                                                                                                     |
|----------------------------------------------|-------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                              |       |                                         | oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates.                                  |
| XTAL2                                        | 21    | 1 4                                     | Crystal input 2 or buffered clock output. See XTAL1.                                                                                                                |
| CS*                                          | 22    | <b>l</b>                                | Parallel printer port chip select (active low). A low at this pin enables the parallel port / CPU data transfer operation.                                          |
| RESET                                        | 24    | · • • • • • • • • • • • • • • • • • • • | Master reset. (active high) A high on this pin will reset all the outputs and internal registers.                                                                   |
| STROBE*                                      | 25*   | 1/0                                     | General purpose I/O or data strobe output (open drain active low). This output indicates to the printer that valid data is available at the printer port (PD0-PD7). |
| AUTOFDXT*                                    | 26*   | 1/0                                     | General purpose I/O or automatic line feed (open drain active low). When this signal is low the printer should automatically line feed after each line is printed.  |
| INIT AND AND AND AND AND AND AND AND AND AND | 27*   | 1/0                                     | General purpose I/O or initialize line printer (open drain active low). When this signal is low, it causes the printer to be initialized.                           |
| SLCTIN*                                      | 28*   | I/O                                     | General purpose I/O or line printer select (open drain active low). When this signal is low, it selects the printer.                                                |
| A10                                          | 29    |                                         | Address select line. To select internal registers.                                                                                                                  |
| PD0-PD7                                      | 31-38 | 1/0                                     | Bi-directional parallel ports (three state). To transfer data in or out of the ST78C36 parallel port. PD7-PD0 are latched during output mode.                       |
| A0-A2                                        | 39-41 | 1                                       | Address select lines. To select internal registers.                                                                                                                 |
| IOW*                                         | 42    | ti ti a <b>p</b> at<br>ti attava e      | Write strobe (active low). A low on this pin will transfer the contents of the CPU data bus to the addressed register.                                              |
| IOR*                                         | 43    | 1                                       | Read strobe (active low). A low level on this pin transfers the contents of the ST78C36 data bus to the CPU.                                                        |
| GND                                          | 23,30 | O                                       | Signal and power ground.                                                                                                                                            |
| vcc                                          | 44    | 1<br>1<br>1<br>10-14:50                 | Power supply input.                                                                                                                                                 |

<sup>\*</sup> Have internal pull-up resistor on inputs

#### INTRODUCTION

This parallel interface is designed to provide all of the signals and registers needed to communicate through a standard parallel printer port as found in the IBM PC, AT, PS/2 and Centronics systems. The address decoding of the registers utilizing A0, A1 and A10 is

shown in Table 1. All bits in these registers are located in the same positions and have the same functions as the registers of the systems listed above.

| NAME  | ADDRESS    | R/W | SIZE  | MODE | FUNCTION                  |
|-------|------------|-----|-------|------|---------------------------|
| DATA  | Port+0 Hex | R/W | byte  | 000  | Data Register             |
| DATA  | Port+0 Hex | R/W | byte  | 001  | Data Register             |
| AFIFO | Port+0 Hex | R/W | byte  | 011  | ECP FIFO                  |
| STR   | Port+1 Hex | R   | byte  | ALL  | Status Register           |
| CTR   | Port+2 Hex | R/W | byte  | ALL  | Control Register          |
| CFIFO | 400 Hex    | R/W | PWord | 010  | Parallel Port Data FIFO   |
| DFIFO | 400 Hex    | R/W | PWord | 011  | ECP FIFO                  |
| TFIFO | 400 Hex    | R/W | PWord | 110  | Test FIFO                 |
| CNFGA | 400 Hex    | R/W | byte  | 111  | Configuration Register A  |
| CNFGB | 401 Hex    | R/W | byte  | 111  | Configuration Register B  |
| ECR   | 402 Hex    | R/W | byte  | ALL  | Extended Control Register |

#### **REGISTER DEFINITIONS**

#### DATA REGISTER (Mode 000, 001)

This is a bi-directional data port that transfers 8-bit data to or from PD7-0. The CTR-5 bit will determine the data direction in conjunction with the Read and Write strobes.

#### AFIFO (Mode 011)

ECP Add FIFO register. Write only. In the forward direction a byte written into this register is pushed into the FIFO and tagged as a ECP Address / RLE command. Reading this register has no effect and the data read is undefined. Writes to this register during backward direction have no effect and the data is ignored.

#### Bit-7:

1 = AFIFO bits 0-6 are ECP address. 0 = AFIFO bits 0-6 is a run length (RLE), indicating how many times the next data byte is to appear. 000000 = 1 time.

000001 = 2 time.

000010 = 3 time.

and so on.

#### Bit 0-6:

Address or RLE fields.

#### STATUS REGISTER

This register provides status for the signals listed below. It a read only register. Writing to it is an invalid operation that has no effect.

#### Bit-0:

When in EPP mode, this is the time-out status bit. When this bit is "1", time-out occurred on EPP cycle (min.  $10\mu s$ ). It is cleared to "0" after STR is read. Consecutive reads(after the first read) always return "0". It is also cleared to "0" when EPP is enabled. When not in EPP mode, this bit is "1".



#### Bit-1:

Reserved, this bit is always "1".

#### Bit-2:

In the compatible mode, or in ECP and EPP mode with bit-4 of PCR = 0, this bit is always "1". In the Extended Mode (PTR-7 bit is "1"), or in ECP and EPP with bit-4 of PCR = 1 this bit is the status bit. In the Extended mode, If CTR-4 = 1, then this bit is latched low when the ACK\* signal makes a transition from low to high. Reading this bit sets it to a "1".

#### Bit-3:

This bit represents the current state of the printer error signal. The printer sets this bit low when there is a printer error. This bit follows the state of the error pin.

#### Bit-4:

This bit represents the current state of the printer select signal (SLCT). The printer sets this bit high when it is selected. This bit follows the state of the SLCT pin.

#### Bit-5:

This bit represents the current state of the printer paper end signal (PE). The printer sets this bit high when it detects the end of the paper. This bit follows the state of the PE pin.

#### Bit-6:

This bit represents the current state of the printer acknowledge signal (ACK\*). The printer pulses this signal low after it has received a character and is ready to receive another one. This bit follows the state of the ACK\* pin.

#### Bit-7

:This bit represents the current state of the printer BUSY\* signal. The printer sets this bit low when it is BUSY\* and cannot accept another Characters. This bit is the inverse of the (BUSY\*) pin.

#### CONTROL REGISTER

This register provides all output signals to control the printer. Except for bit-5, it is a read and write register.

Normally when the Control Register is read, the bit values are provided by the internal output data latch. These bit values can be superseded by the logic level of the STROBE\*, AFD\*, INIT, and SLIN\* pins, if These pins are forced high or low by an external voltage. In order to force these pins high or low the corresponding bits should be set to their lnactive state.

#### Bit-0:

This bit directly controls the data STROBE\* signal to the printer via the STROBE\* pin. This bit is the inverse of the pin.

#### Bit-1:

This bit directly control the automatic feed XT signal to the printer the AFD\* pin. Setting this bit high causes the printer to automatically feed after each line is printed. This bit is the inverse of the AFD\* pin.

#### Bit-2:

This bit directly controls the signal to initialize the printer via the INIT pin. Setting this bit to low initializes the printer. This bit follows the INIT signal pin.

#### Bit-3:

This bit directly controls the select in signal to the printer via the SLIN\* pin. Setting this bit high selects the printer. It is the inverse of the SLIN\* pin.

#### Bit-4:

This bit enables the parallel port interrupt. Setting this bit low puts IRQ into THREE-STATE and clears any pending interrupts. In the AT Compatible Mode, or in EPP or ECP modes when this bit is set high, the IRQ signal follows the ACK\* signal transitions (pulse interrupt). In the Extended Mode, or in either EPP or ECP modes when this bit is set high, The IRQ signal should set high on the low to high transition of the ACK\* signal.

#### Bit-5:

This bit determines the parallel port direction. The default condition results in the parallel pin being in the output mode. This is a Read/Write bit in EPP mode. In compatible mode it is a write only bit; a read from it will return "1".

#### Bits 6-7:

Reserved. These bits are always.

#### CFIFO (Mode 010)

Parallel Port FIFO Register. Write only. A byte written, or DMA-ed, to this registers pushed into The FIFO and tagged as data. Reading this register has no effect and the data read is undefined.

#### DFIFO (Mode 011)

ECP Data FIFO Register. In the forward direction a byte written, or DMA-ed, to this register is pushed into the FIFO and tagged as data. Reading this register has no effect and the data read is undefined. In the backward direction the ECP automatically issues ECP read cycles to fill the FIFO. Reading this register pops a byte from the FIFO. Writing this register has no effect and the data written is ignored.

#### TFIFO (Mode110)

Test FIFO Register. A byte written into this register is pushed into the FIFO. A byte read from this register is popped from the FIFO The ECP does not issue a ECP cycle to transfer the data to or from the peripheral device. The TFIFO is readable and writ able in both directions. In the forward direction PD7-0 is driven, but the data is undefined. The FIFO does not stall when overwritten or under-run (access is ignored). Bytes are always read from the top of the FIFO, regardless of the direction bit.

#### CNFGA(Mode 111)

Configuration Register A. Read only. Reading this register always returns 10Hex. Writing this register has no effect and the data is ignored.

#### CNFGB (Mode111)

Configuration Register B. Read only. Reading this register returns the configuration parallel port interrupt line, and its state.

#### **ECR**

Extended Control Register. This register controls the ECP and parallel port functions. Upon reset this register is Initialized to 16Hex.

#### Bit 5-7:

#### Mode 000:

Standard mode. Write cycles are performed under software control. Bit-5 of CTR is forced to "0" and PD7-0 is driven. The FIFO is reset (empty).

#### Mode 001:

PS/2 mode. Read and write cycles are performed under software control. The FIFO is reset.

#### Mode 010:

Parallel Port FIFO mode. Write cycles are performed under hardware control (STROBE\* is controlled by hardware). Bit-5 of CTR is forced to "0" and PD7-0 are driven.

#### Mode 011:

ECP FIFO mode. The FIFO direction is controlled by bit-5 of CTR. Read and write cycle to the device are performed under hardware control (STROBE\* and AFD\* are controlled by hardware).

#### Mode 100:

Reserved.

#### Mode 101:

Reserved.

#### Mode 110:

FIFO test mode. The FIFO is accessible via the TFIFD register. The ECP does not issue ECP cycles to fill/empty the FIFO.

#### Mode 111:

Configuration mode. The CNFGA and CNFGB registers are accessible in this mode.

#### Bit-4:

ECP Interrupt Mask bit. When this bit is "0" an interrupt is generated on ERROR assertion. An interrupt is also generated when ERROR is asserted while this bit is changed from "1" to "0"; this prevents the loss of an interrupt between ECR read and ECR write. When this bit is "1", no interrupt is generated.



#### Bit-3:

ECP DMA Enable bit. When this bit is "0", DMA is disabled and the PDRQ pin is in TRI-STATE. When this bit is "1", DMA is enabled and DMA starts when bit-2 of ECR is "0".

#### Bit-2:

ECP Service bit. When this bit is "0", and one of the following three interrupt events occur, an interrupt is generated and this bit is set to "1" by hardware.

- a. Bit-9 of ECR is "1", and terminal count is reached during DMA.
- b. Bit-3 of ECR is "0" and bit-5 of CTR is "0", and there are eight or more bytes free in the FIFO.
- c. Bit-3 of ECR is "0" and bit-5 of CTR is "1", and there are eight or more bytes to be read from the FIFO. When this bit is "1", DMA and the above three interrupts are disabled. Writing "1" to this bit does not cause an interrupt. When the ECP clock is stopped this bit is read as "0", regardless of its actual value.

#### Bit-1:

FIFO Full bit. Read only. This bit is "0" when the FIFO has at least one free byte. This bit is "1" when the FIFO is full. This bit continuously reflects the FIFO state, and therefore can only be read. Data written to this bit is ignored. When the ECP clock is stopped the bit is read as "1", regardless of the actual FIFO state.

#### Bit-0:

FIFO Empty bit. Read only. This bit is "0" when the FIFO has at least one byte of data. This bit is "1" when the FIFO is empty. This bit continuously reflects the FIFO state, and therefore can only be read. Data written to this bit is ignored. When the ECP clock is stopped, this bit is read as "1", regardless of the actual FIFO state.

## EXTENDED CAPABILITIES PARALLEL PORT (ECP)

The ECP support includes a 16-byte FIFO that can be configured for either direction, command / data FIFO, a FIFO threshold interrupt for both directions, FIFO

empty and full status bits, automatic generation of strobes (by hardware) to fill or empty the FIFO, transfer of commands and data, and a Run Length Encoding (RLE) expanding /decompression) as explained below.

The Extended Capabilities Port (ECP) is enabled when bit-2 of PCR is "1". Once enabled, its mode is controlled via the mode field of ECR-bits 5, 6, 7 of ECR register.

#### The ECP has ten registers:

The AFIFO, CFIFO, DFIFO and TFIFO registers access the same ECP FIFO. The FIFO is accessed at Base + 000Hex, or Base + 400Hex, depending on the mode field of ECR and the register. FIFO can be accessed by host DMA cycles, as well as host PIO cycles.

When DMA is configured and enabled (bit-3 of ECR is "1" and bit-2 of ECR is "0") the ECP automatically issues DMA requests to fill the FIFO (in the forward direction when bit-5 of CTR is "0") or to empty the FIFO (in the backward direction when bit-5 of CTR is "1"). All DMA transfers are to or from these registers. The ECP does not assert DMA request for more than 32 consecutive DMA cycles. The ECP stops requesting DMA when TC is detected during an ECP DMA cycle.

Writing into a full FIFO, and reading from an empty FIFO, are ignored. The written data is lost, and the read data is undefined. The FIFO empty and full status bits are not latched by such access. Some registers are not accessible in all modes of operation, or may be accessed in one direction only. Accessing a non-accessible register has no effect: Data read is undefined, data written is ignored, the FIFO does not update. The ST78C36 Parallel Port registers (DTR, STR and CTR) are not accessible when ECP is enabled.

To improve noise immunity in ECP cycles, The state machine does not examine the control handshake response lines until the data has had time to switch.

a. The software should enable ECP after bits 0-

- When ECP is enabled, and the software wishes to switch modes, it should switch only through modes 000 or 001.
- When ECP is enabled, The software should change direction only in mode 001.
- The software should switch from mode 010, or 011, to mode 000, or 001, only when the FIFO is empty.
- e. The software should switch to mode 011 when bits 0.1 of CTR are "0".
- f. The software should switch to mode 010 when bit-0 of CTR is "0".
- g. The software should disable ECP only when in mode 000 or 001.

Software may switch from mode 011 backward direction to modes 000 or 001 when there is an ongoing ECP read cycle. In this case the read cycle is aborted by deasserting AFD\*. The FIFO is reset and a potential byte expansion is automatically terminated since the new mode is 000 or 001.

The ECP uses the Xtal1 clock. This clock can be stopped for power down mode. When this power-down mode occurs, the DMA is disabled, all interrupts (except ACK\*) are masked, and the FIFO registers are not accessible. The other ECP registers are always accessible when the ECP is enabled. During this period the FIFO status and contents are not lost, although the host reads bit-2 of ECR as "0", bit-1 of ECR as "1" and bit-0 of ECR as "1", regardless of the actual values of these bits. When the clock starts toggling again these bits resume their original functions.

When the clock is stopped, an on going ECP cycle may be corrupted but the next ECP cycle will not start even if in forward direction the FIFO is not empty, and in backward direction the FIFO is not full. If the ECP clock starts or stops toggling during a host cycle that

accesses the FIFO, the cycle may yield wrong data.

## SOFTWARE CONTROLLED DATA TRANSFER (MODES 000 AND 001)

Software controlled data transfer is supported in modes 000 and 001. The software generates peripheral device cycle by modifying the DATA and CTR registers and reading the STR, CTR and DATA registers. The negotiation phase and nibble mode transfer, as defined in the IEEE 1284 standard, are performed in these modes. In these modes the FIFO is reset and is not

Mode 000 is for the forward direction only; the direction bit is forced to "0" and PD7-0 is driven. Mode 001 is for both the forward and backward directions. The direction bit controls whether PD7-0 are driven.

## AUTOMATIC DATA TRANSFER (Modes 010 and 011)

Automatic data transfer (ECP cycles generated by hardware) is supported only in modes 010 and 011. Automatic DMA access to fill or empty the FIFO is supported in modes 010, 011 and 110. Mode 010 is for the forward direction only; the direction bit is forced to "0" and PD7-0 is driven. Mode 011 is for both the forward and backward directions. The direction bit controls whether PD7-0 is driven.

Automatic Run Length Expanding (RLE) is supported in the backward direction.

#### Forward Direction (Bit-5 of CTR = 0)

When the ECP is in forward direction and the FIFO is not full

(bit-1 of ECR is "0") the FIFO can be filled by software writes to the FIFO registers (AFIFO and DFIFO in mode 011, and CFIFO in mode 010).

When DMA is enabled (bit-3 of ECR is "1" and bit-2 of ECR is "0") the ECP automatically issues DMA requests to till the FIFO with normal data bytes. When the ECP is in forward direction and the FIFO is not empty the ECP pops a byte from the FIFO write cycle to the peripheral device. The ECP drives AFD\* according to the operation mode (ECR bits 5-7) and according to the tag of the popped byte as follows: In Parallel Port FIFO mode (mode 010) AFD\* is

6

controlled by bit "1" of CTR. In ECP mode (mode 011) AFD\* is controlled by the popped tag. AFD\* is driven high for normal data byte and driven low for command byte.

#### **ECP (Forward) Write Cycle**

An ECP write cycle starts when the ECP drives the popped tag onto AFD\* and popped byte onto PD7-0. When BUSY\* is low the ECP asserts STROBE\*. In 010 mode the ECP deasserts STROBE\* to terminate the write cycle. In 011 mode the ECP waits for BUSY\* to be high. When BUSY\* is high the ECP deasserts STROBE\* and changes AFD\* and PD7-0 only after BUSY\* is low.

#### Backward Direction (Bit-5 of CTR is "1")

When the ECP is in the backward direction, and the FIFO is not full (bit-1 of ECR is "0"), the ECP issues a read cycle from the peripheral device and monitors the BUSY\* signal. If BUSY\* is high the byte is a data byte and it is pushed into the FIFO. If BUSY\* is low the byte is a command byte.

The ECP checks bit-7 of the command byte, if it is high the byte is ignored, if it is low the byte is tagged as an RLC byte (not pushed into the FIFO but used as a Run Length Count to expand The next byte read). Following an RLC read the ECP issues a read cycle from the peripheral device to read The data byte to be expanded. This byte is considered a data byte, regardless of its BUSY\* state. This byte is pushed into the FIFO (RLC+ 1) times.

When The ECP is in the backward direction, and the FIFO is not empty (bit-0 of ECR is "0"), the FIFO can be emptied by software reads from the FIFO register (only DFIFO in mode 011, no AFIFO and CFIFO read). When DMA is enabled (bit-9 of ECR is "1" and bit-2 of ECR is "0") the ECP automatically issues DMA requests to empty the FIFO (only in mode 011).

#### ECP (Backward) Read Cycle

An ECP read cycle starts when the ECP drives AFD\* low. The peripheral device drives BUSY\* high for a normal data read cycle, or drives BUSY\* low for a command read cycle, and drives the byte to be read

#### onto PD7-0.

When ACK\* is asserted the ECP drives AFD\* high then reads the PD7-0 byte. When AFD\* is high the peripheral device deasserts ACK\* and may change BUSY\* and PD7-0 states in preparation for the next cycle.

#### FIFO TEST ACCESS (MODE 110)

Mode 110 is for testing the FIFO in PIO and DMA cycles. Both read and write operations (pop and push) are supported, regardless of the direction bit. In the forward direction PD7-0 are driven, but the data is undefined This mode can be used to measure the host ECP cycle throughput, usually with DMA cycles. This mode can also be used to check the FIFO depth and its interrupt threshold, usually with PIO cycles.

## CONFIGURATION REGISTERS ACCESS (MODE 111)

The two configuration registers, CNFGA and CNFGB, are accessible only in this mode.

#### Interrupt

Interrupt is generated when any of the following events occur.

- a. When bit-2 of ECR is "0", bit-3 of ECR is "1" and TC is asserted during the ECP DMA cycle.
- b. When bit-2 of ECR is "0", bit-3 of ECR is "0", bit-5 of CTR is "0" and There are eight or more bytes free in the FIFO. It includes the case when bit-2 of ECR is cleared to "0" and there are already eight or more bytes free in the FIFO (modes 010, 011 and 110 only).
- c. When bit-2 of ECR is "0", bit-3 of ECR is "0", bit-5 of CTR is "1" and there are eight or more bytes to be read from the FIF0. It includes the case when bit-2 of ECR is cleared to "0" and there are already eight or more bytes to be read from the FIFO (modes 011 and 110 only).
- d. When bit-4 of ECR is "0" and ERROR is asserted (high to low edge) or ERROR is asserted when bit-4 of ECR is modified from "1" to "0".
- e. When bit-4 of CTR is "1" and ACK\* is deasserted (low-to-high edge). The interrupt is generated according to bits 4, 5 and 6 of PCR.

Special circuitry provides protection against damage that might be caused when the printer is powered but the ST78C36 is not.

Enhanced Parallel Port (EPP) modes of operation and one Extended Capabilities Port (ECP) mode to complete a full IEEE 1286 parallel port. In Compatible mode a write operation causes the data to be presented on pins PD7-0. A read operation In this mode causes the Data Register to present the last data written to it by the CPU.

In the Extended mode a write operation to the data register causes the data to be latched. If the Data Port Direction bit (CTR-5) is "0", the latched data is presented to the pins; if it "1" the data is only latched. When Data Port Direction bit (CTR-5) is "0", a read operation from this register allows the CPU to read the last data it written to the port. In the Extended Mode with the Data Port Direction bit set to "1" (read), a read from this register causes the port to present the data on pins PD7-0.





## ST56CXXX

Printed September 8, 1994

## ADVANCED HIGH PERFORMANCE SUPER-I/O CONTROLLER

#### DESCRIPTION

The ST56C5XX is an advanced high performance super-I/O controller, designed to replace the IDE controller, four Floppy controllers, two serial ST16C550 UART's with advanced Microsoft/Hewlett Packard ECP, IBM EPP printer port and game port. The ST56C5XX utilizes digital phase locked loop for the floppy controller section to eliminate the external components (except the main crystal). The ST56C5XX is optimized for mother board applications as well as controller board applications. ST56C5XX provides high ESD circuits on the printer data bus and I/O to prevent damage caused by the printer being powered when the ST56C5XX is not powered.

## **FEATURES**

- Licensed CMOS WD37C65C floppy controller.
- · Supports vertical recording format
- 100% IBM compatible
- 48 mA drivers and schmitt Trigger inputs.
- DMA enable logic
- FDC primary and secondary address selection
- Two 16C550 serial ports
- Microsoft/Hewlett Packard Bi-directional ECP parallel port
- IBM EPP (Enhanced Printer Port)
- 16 bit IDE interface and decode logic
- Game port
- 100 pin TQFP and QFP packages
- Low power CMOS 1.2μ technology

#### ORDERING INFORMATION

Part number Package ST56CXXXCQ100 QFP ST56CXXXCTQ100 TQFP Operating temperature 0° C to + 70° C

0° C to + 70° C

# ST56CXXX

### **GENERAL APPLICATION NOTE FOR STARTECH UART FAMILY**

The AN-450 provides additional information to guide users to design or utilize the STARTECH product line. This document can also be used for all the STARTECH UART product lines.

### **GENERAL INFORMATION**

STARTECH offers UART's with or without FIFO capabilities, and are marked as 45X for non FIFO families and 55X for FIFO families. All parts with sharing part numbers are foot print compatible in some extent, like ST16C450 and ST16C550, ST16C2450 and ST16C2550, etc.

This section will describe general terms for commonly used flags and registers.

### **OVERRUN ERROR:**

The flag is set to "1" to warn the user that a serial data has been received and previous serial data has not been read from receive holding register. The new serial data will over write the previous data in the receive holding register. Note that previous serial data has been lost and user does not have an access to that data.

### **PARITY ERROR:**

This flag is set "1" to indicate that received serial data contains mismatched parity or data bit error in the received data.

### **PARITY:**

Four common types of parities are used in the STARTECH Uart families; Odd Parity, Even Parity, Forced Mark Parity and Forced Space Parity.

### ODD PARITY:

Odd Parity is calculated by adding all the "1's" in a data stream and adding a parity bit to the total bits, to make the total count an odd number.

Example -1: A data byte with the following pattern 11010010 will require to add a parity bit of "1" to bring the total count for "1's" to an odd number. Based on this data pattern, serial data with odd parity will be transmitted as 110100101.

Example -2: A data byte with the following pattern 10011000 will require to add a parity bit of "0" to maintain the total count of "1's" to an odd number.

Based on this data pattern, serial data with odd parity will be transmitted as 100110000.

### **EVEN PARITY:**

Even Parity is calculated by adding all the "1's" in a data stream and adding a parity bit to the total bits, to make the count an even number.

Example -3: A data byte with the following pattern 10000101 will require to add a parity bit of "1" to bring the total count for "1's" to an even number. Based on this data pattern, serial data with even parity will be transmitted as 100001011.

Example -4: A data byte with the following pattern 00001111 will require to add a parity bit of "0" to maintain the total count for "1's" to an even number. Based on this data pattern, serial data with even parity, will be transmitted as 000011110.

### FORCED SPACE PARITY:

Parity bit on the serial byte is set to "0" regardless of total number of "1's" (even or odd counts).

### FORCED MARK PARITY:

Parity bit on the serial byte is set to "1" regardless of total number of "1's" (even or odd counts).

### FRAMING ERROR:

The flag is set to "1" to indicate that received data does not have correct start or stop bits. This can cause when the Uarts are set for 8-bits word and receiving a serial data of 7-bits word or any mismatched data patterns.

### **BREAK SIGNAL INDICATION:**

This flag is set to "1" to warn the user that transmitter is sending continuous "0" data without stop bit (RX input is low for more that one word).

### TRANSMIT/RECEIVE FIFO:

STARTECH offers 16 byte transmit FIFO and 16 byte receive FIFO for all its products with 55X part numbers. These FIFO's are static 19 X 16 bit RAM with control logic to form a ring counter. Initializing the FIFO will set the write and read pointers to the same location.

### TRANSMIT EMPTY:

This flag is set "1" to indicate that, there is no character in the transmit holding and transmit shift register

### TRANSMIT HOLDING EMPTY:

This flag is set "1" to indicate that, there is one or more empty locations in the transmit holding register. User has to check this bit before loading characters in the transmit holding register. In non FIFO mode, user can load one character at a time when this flag is set and 16 characters when FIFO mode is utilized.

### **RECEIVER DATA READY:**

This bit is set "1" to indicate that, receiver has one or more character in the receive holding register. User has to check this bit prior to read receive holding register. In non FIFO mode, only one character at time can be read. In FIFO mode up to 16 characters can be read if time bit is set.

### RECEIVE TIME-OUT:

This mode is enabled when STARTECH UART is operating in FIFO mode. Receive time out will not occur if the receive FIFO is empty. The time out counter will be reset at the center of each stop bit received or each time receive holding register is read. The actual time out value is T (Time out length in bits)= 4 X P (Programmed word length) + 12. To convert time out value to a character value, user has to divide this number to its complete word length + parity (if used) + number of stop bits and start bit.

Example -7: If user programs the word length = 7, and no parity and one stop bit, Time out will be:

T = 4 X 7( programmed word length) +12 = 40 bits Character time = 40 / 9 [ (programmed word length = 7) + (stop bit = 1) + (start bit = 1)] = 4.4 characters.

Example -8: If user programs the word length = 7, with parity and one stop bit, the time out will be:

T = 4 X 7(programmed word length) + 12 = 40 bits Character time = 40 / 10 [ (programmed word length = 7) + (parity = 1) + (stop bit = 1) + (start bit = 1) = 4 characters.

#### BAUD RATE GENERATOR:

STARTECH provides a 16 bit digital divider to obtain all necessary baud rates. The 16 bit divider is broken down in to two 8-bit dividers which will be addressed as MSB divider (upper 8-bits) and LSB divider (lower 8-bits). To calculate the transmit/receive data rate it is necessary to know the provided clock rate (frequency) to STARTECH parts. STARTECH utilizes 16 clocks for each transmit bit and 16 clocks to sample the received data. Note that inorder to access these

dividers, user has to enable the divisor latch access bit through the Line Control Register.

Bit rate is calculated by:

Dividing decimal number = (Clock rate) / (16 X bit rate).

To program the digital divider, dividing decimal number should be converted to hex (base 16) number and split into two 8-bits sections.

Example -5: To obtain 4800 Hz baud rate, assuming 1.8432 MHz input clock, the dividing decimal value is (input clock=1843200) / (16 X 4800) = 24

24 decimal = 0018 Hex, this value is translated to MSB = 00 Hex and LSB = 18 Hex.

### BAUD RATE VERSUS BIT RATE:

The baud rate defines the width of each bit regardless of word, parity and stop bit length. Bit rate, is the rate of the transmission which each character is transmitted or received. The 2400 baud rate transmission is translated to 2400 Hz per bit for each character in a word. With 2400 baud you can transmit between 7 to 12 characters per slot.

### PROGRAMMING STEPS:

The AN-450 provides the easy steps to program STARTECH Uart family. Note that all numbers are in Hex format not decimal.

Write 80 Hex to LCR (Line Control Register) to enable baud rate generator divider latch to set 2400 Hz baud rate:

to set 2400 Hz baud rate.

write 00 Hex to MSB of baud rate generator (address location 1).

Write 30 Hex to LSB of baud rate generator (address location 0).

Select you word, parity and stop bit format from STARTECH Uart data sheet.

to set 8 bits, no parity and one top bit and disable the divisor access latch

write 03 Hex to LCR (Line Control Register):

if you need to use Uarts with FIFO, select your receive trigger level from data sheet.

to enable FIFO with 14 character trigger level write CF Hex to FCR (FIFO Control Register)

enable interrupt sources write 01 Hex to IER (Interrupt Enable Register) to select receive interrupt.

to set RTS and DTR outputs to low and enable the interrupt output write 0B Hex to MCR (Modem Control Register).

The STARTECH Uart is ready for transmit and receive operation.

Read MSR (Modern Status Register) to check the status of CD, RI, DSR, CTS input pins.

Read LSR (Line Status Register).

For polling applications (non interrupt mode) user has to monitor bit zero of this register to verify valid data in the receive holding register.

Check the Transmit Holding Empty bit before loading data in the transmit holding register,

continue the transmission.

# Parallel Crystal Connections



# External Clock Connections



# Serial Crystal Connections



### C PROGRAM SAMPLE

```
; File: sample.c
                       Package:UART init
; This is a sample code to show how to initialize the UART series of chips
: from Startech Semiconductors.
; This also includes some basic external loop back thru' two different
: ports using the FIFO capability.
; This also includes external loop back thru a different computer
#include
             <stdio.h>
#include
             <string.h>
#include
             <fcntl.h>
#define
             TRUE
#define
             FALSE
                                      0
/* These are the various offsets for the registers inside the chip */
                                      0x00 /* Receive Holding Register
#define
             RHR
                                                                            */
             THR
                                      0x00 /* Receive Holding Register
#define
#define
             IER
                                      0x01 /* Interrupt Enable Register
                                                                          */
                                      0x02 /* FIFO control Register
#define
             FCR
                                                                          */
                                                                          */
#define
             ISR
                                      0x02 /* Interrupt Status Register
                                      0x03 /* Line control register
#define
             LCR
#define
             MCR
                                      0x04 /* Modem Control Register
                                                                           */
#define
             LSR
                                      0x05 /* Line Status Register
                                                                         */
#define
             MSR
                                      0x06 /* Modem Status Register
                                                                           */
#define
             SCR
                                      0x07 /* Scratch pad Register
                                                                          */
/* This two offsets are used for defining the baud rate
#define
             DIVLSB
                                      0x00 /* Divisor LSB latch address
#define
             DIVMSB
                                      0x01 /* Divisor MSB Latch address
* Program table for baud rate
* This represents the LSB and MSB divisor latch data
char baud_table[8][2] = {
         { 0x80, 0x01 },
                                       /* 300 */
         \{0x60, 0x00\},\
                                      /* 1200 */
         { 0x30, 0x00 },
                                      /* 2400 */
         { 0x0c, 0x00 },
                                      /* 9600 */
         \{0x06, 0x00\},\
                                      /* 19K */
         \{0x03, 0x00\},\
                                      /* 38k */
         \{0x02, 0x00\},\
                                      /* 56k */
         { 0x01, 0x00 }
                                      /* 115k */
};
```

```
/* Baud Rates */
#define
            _COM_300_
#define
            _COM_1200_
                                   1
                                   2
#define
            _COM_2400_
#define
             COM 9600
                                   3
#define
             COM_19K_
                                   4
                                   5
#define
            _COM_38K_
#define
             COM_56K_
                                   6
#define
            COM 115K
                                   7
/* Parity */
#define
            COM NOPARITY
                                   0
            _COM_ODDPARITY
#define
#define
            COM EVENPARITY
                                   2
/* Stopbits */
            _COM_STOP1_
#define
                                   0
#define
            _COM_STOP2_
                                   1
#define
            COM STOP1 5
                                   1
/* word length */
#define
            _COM_CHR5_
                                   0
#define
            COM_CHR6_
                                   1
            _COM_CHR7_
#define
                                   2
#define
            _COM_CHR8_
/* word length */
            _COM_FIFO1_
#define
                                   0
#define
            COM FIFO4
                                   1
                                   2
#define
            COM FIFO8
#define
            COM FIFO14
                                   3
/*\
* This function checks the existence of a port.
* It is very simple. Take the port address then write to the scratch pad
* an the read it back. If the data read back the same as one that was
* written then return TRUE else return FALSE.
\*/
int
check_port(com_port)
int com_port;
{
 int i:
    printf("Checking for port %4xH\n".com port):
 /* Write 1010 1010 (0xaa) to scratch pad*/
```

```
printf("Writing AAH in %4xH\n",com port);
 outportb(com port + SCR, 0xaa);
 /* read it back. If it the same then return TRUE */
 i = inportb(com_port + SCR);
   printf("Read back %2xH from %4xH\n",i,com_port);
 if(i == 0xaa)
      return TRUE:
 else
      return FALSE;
}
/*\
* This is the work horse function which actually setups the UART.
* It needs to know every thing.
\*/
init_uart(port.baud.parity.data.stop.fifo.trigger)
int port, baud, parity, data, stop, fifo, trigger;
  char lcr byte:
  /* Set divisor latch */
  outportb(port+LCR, 0x80);
  printf("Divisor Latch is %2xH %2xH (High Low)\n",
                         baud table[baud][1],baud table[baud][0]);
 outportb(port+DIVLSB, baud table[baud][0]);
  outportb(port+DIVMSB, baud_table[baud][1]);
 /* Reset to normal Programming */
 /* Program the lcr byte for the above parameters */
  Icr byte = 0x00:
  lcr_byte = data; /* Set the bit0 & bit1 for word length */
  lcr_byte ;= stop << 3; /* Set the bit2 for stop bit */</pre>
  if(parity != COM NOPARITY ) {
    Icr byte := 1 << 4; /* Set the bit3 for parity */
    if(parity == COM EVENPARITY )
      lcr_byte ;= 1 << 5; /* Set the bit4 for EVEN parity */</pre>
 }
  printf("LCR byte is %2xH\n",lcr_byte);
  /* Program LCR */
```

```
outportb(port+LCR, lcr_byte);
  if(fifo) {
   char fifo byte;
   printf("Programming FIFOs without DMA mode\n"):
   /* Have to first set the fifo enable */
   fifo byte = 0x01:
   outportb(port+FCR,fifo_byte);
   /* Now program the FIFO */
   fifo byte = 0x07; /* set bit0 - FIFO enable, Reset RCVR and XMIT FIFO */
   fifo byte := trigger << 7; /* set bit6 and bit7 with the trigger level */
   /* Program FCR */
   outportb(port+FCR,fifo byte);
   if(~(inportb(port + ISR) & 0xc0)) {
      printf("This port %4xH does not have FIFOs\n");
      printf("Hence did not program Enable FIFOs\n");
   }
  /* Program IER */
  printf("Programming IER for interrupt on bit0 RCV holding Register\n");
  outportb(port+IER, 0x01);
  return TRUE;
}
 * This is the test mode.
* It gets the address of the ports checks to see if they are there.
 * Note: If a driver already exists I am not sure how to temporarily remove it.
 * Well we will worry about it later.
 * Warn the use to remove any drivers that are on the ports.
 * Especially the mouse driver.
 * pass the address to the test552 routine.
\*/
int test_mode()
{
      int i,j,k; /* generic variables */
      char port1[10], port2[10];
      int pt1,pt2; /* this are the integer port numbers */
      void test552();
      printf("WARNING: This program will not work if the ports to be tested\n");
```

}

\\*/

```
have drivers installed in them. e.g Mouse driver\n");
      printf("
     printf("
                  Please remove the drivers before doing this test.\n");
      while(TRUE) {
       printf("First Port Address (In HEX) > ");
       scanf("%s",port1);
       pt1 = strtol(port1, NULL, 16);
       fflush(stdin);
       /*\
        * Check if this port exists, else loop
        if(check_port(pt1))
            break:
        printf("Error: Port %4xH does not exist. Try again\n",pt1);
     }
      while(TRUE) {
       printf("Second Port Address (In HEX) > ");
       scanf("%s",port2);
       pt2 = strtol(port2, NULL, 16);
       fflush(stdin);
       /*\
        * Check if this port exists, else loop
        if(check_port(pt2))
            break;
        printf("Error: Port %4xH does not exist. Try again\n",pt2);
      }
      /* Test 554 with the two port addresses */
      test552(pt1,pt2);
      return TRUE;
* It first generates a random number for the data size to be generated.
* Then generates a random data whose length is equal to the data size.
* It puts it out on both the ports and polls for the interrupt to occur.
* It reads both the ports until all characters are received OR a timeout
* has occured. It then prints out the error Messages if any.
* This loop is done for ever.
```

```
void test552(p1,p2)
unsigned int p1, p2;
 int i,i,c,w,n;
 unsigned char outbuf[20], inbuf1[20], inbuf2[20];
 unsigned char pbuf[200];
 unsigned long timeout, pass;
 printf("ST16C552 External Loop Test Beginning\n");
 printf("Testing ports %4x and %4x\n\n", p1, p2);
 printf("Programing ports for 56K,8 bit,no parity,1 stop bit,FIFO trigger level 01\n");
 printf("This program uses POLLED mode for testing\n");
 printf("Press Cntrl-C to stop the testing and quit\n");
 printf("Note: The ports will remain at the above settings after the TEST\n");
 /* Programming ports for 8 bits, no parity, 56K baud.
                             FIFO enabled at level 01 */
 /* Program first port */
 printf("Programming port %x4\n",p1);
 init_uart(p1,_COM_56K_,_COM_NOPARITY_,
          COM_CHR8_, COM_STOP1_, TRUE, COM_FIFO1_);
 /* Program Second Port */
 printf("Programming port %x4\n",p2);
 init_uart(p2,_COM_56K_,_COM_NOPARITY_,
          _COM_CHR8_,_COM_STOP1_,TRUE,_COM_FIFO1_);
 printf("Starting test\n");
 for (pass = 1;; pass++) {
      /* generate random size for data */
       n = rand():
       n += n >> 8;
       n \&= 0x0f:
      /* Make sure we never get a 0 as the random size data */
      if(n != 0x0f)
        n++ :
      /* generate random data */
       for (w = 0; w < n; w++) {
            c = rand();
            c += c >> 8;
            c \&= 0xff;
            c := 0x01 ; /* no NULLs allowed */
            outbuf[w] = c;
      }
```

```
outbuf[w] = NULL;
printf("****** Pass %10ld Sending %d ****** \015", pass, n);
/* Transmitt the data */
for (i = 0; i < n; i++) {
     outportb(p1, outbuf[i]);
     outportb(p2, outbuf[i]);
}
/* loop waiting for intr pending */
for (i = 0;;i++) {
     if ((~inportb(p1+ISR) & 0x01) && (~inportb(p2+ISR) & 0x01))
}
/* receive data until all has been received OR timeout */
timeout = 0x0008F;
for (i = j = 0; ((i < 20) && (j < 20));) {
     if (inportb(p1+LSR) \& 0x01) inbuf1[i++] = inportb(p1);
     c = rand();
     c += c >> 8
     c \&= 0x001f;
     C++;
     for (; c!= 0; c--);
     if (inportb(p2+LSR) \& 0x01) inbuf2[j++] = inportb(p2);
     if (timeout— == 0) break;
}
/* If timed out then print message else comparse data */
if(timeout == 0)
     printf("Timed out on Ports\n");
else {
 inbuf1[i] = inbuf2[j] = NULL;
 /* compare results */
 if (strcmp(outbuf, inbuf1);; ( i != n)) {
       printf("\nError:%04x Sent: ", p2);
       for (w = 0; w < n; w++)
            printf(" %02x", outbuf[w]);
       printf("\n%04x Received:", p1);
       for (w = 0; w < i; w++)
            printf(" %02x", inbuf1[w]);
       printf("\n");
  if (strcmp(outbuf, inbuf2) ;; ( j != n )) {
       printf("\nError:%04x Sent: ", p1);
       for (w = 0; w < n; w++)
            printf(" %02x", outbuf[w]);
```

### GENERAL APPLICATION NOTE FOR STARTECH CLOCK FAMILY

The ST49CXXX video / memory clock chips provide 5-130 MHz clock outputs which may cause unwanted EMI problems.

To minimize problems with meeting FCC EMI requirements, consideration should be given to the following sections of the board design.

Power supply conditioning
Printed Circuit Board Layout
Video / Memory clock outputs and drive capabilities
External clock sources
Reference clock sources
Digital control / select inputs
External loop filters

### Power supply considerations

Under normal conditions no external components are required for propper operation of any of the internal circuitry of the ST49CXXX. It is required to have spike free ( or minimum ) and stable supply source to the chips. To provide stable and clean supply voltage to STARTECH clock chips we recommend to use  $0.1\mu\text{F}$  capacitors close to IC's power supply lines (VCC, AVCC and DVCC inputs). Analog and digital supply lines are separated from each other to reduce noise generated due to internal digital switching.

In most of the design cases +5V and +12V supplies are provided. A clean +5V supply can be obtained from the +12V supply by utilizing a 470 $\Omega$  drop resistor and 5.1V zener diode bypassed by 0.047 $\mu$ F and 2.2 $\mu$ F Tantalum capacitors ( or higher ) to ground.

Trace width should be maximized from the supply source and good ground planes on top and bottom layers of the printed circuit board are recommended.

### Printed Circuit Board (PCB) layout

We recommend to place all external components as close as possible to the clock chips to reduce trace length between pin and component connections. It is important to keep components not related to clock IC's (DRAM and other memory devices) far and not share the grounds. In applications utilizing a multi-layer board, GND, AGND, and DGND should be directly connected to the ground plane. If possible A full power and ground plane layout should be employed both under and around the IC package.

# Video / Memory clock outputs and drive capabilities

Video clock is usually the highest frequency present in video graphics system board/card and consideration should be given to FCC EMI requirements.

The trace connecting DCLK and MCLK clock output pins to other components should be kept as close as possible ( with optional 33 $\Omega$  resistor in series ) to reduce the possible emitting signals and jitter.

#### External clock sources

When an external clock source is used to bypass the internal VCO to DCLK and MCLK outputs, clock should have fast rise / fall times and minimum jitter. This signal will be connected internally to the clock output pin when it is selected / enabled. The internal VCO circuit will be locked to its internal selected frequency.

### Reference clock sources

The internal oscillator circuit contains all of the passive components required for the external crystal. An appropriate parallel resonant crystal should be connected between XTAL1 and XTAL2.

The crystal leads and input pins should be maintained as close as possible, and the body of the crystal should be grounded to minimize the noise pickup. For IBM compatible applications, the 14.31818 MHz system or crystal clock is used as a reference clock to the chip.

### Digital control / select inputs

The ST49CXXX provides TTL compatible address select and latch input pins to interface with CMOS or TTL/LSTTL devices. The A0-A4 and M0-M1 can also be connected to the Data bus if required.







### 1.0 Quality and Reliability information

The STARTECH semiconductor quality program starts with the design of new products. Each design circuit performance is verified using simulations over voltage and temperature values beyond those of specified product operation.

The design process includes consideration of quality issues such as signal levels, power dissipation, noise generated from internal clock circuits and testability of all device functions.

The STARTECH semiconductor document control department maintains control over all manufacturing specifications, lot travelers, procurement specifications and drawings and test programs.

HP Laserjet III

All changes of design are subject to approval by the Engineering, Quality and Manufacturing managers.

STARTECH semiconductor performs a thorough internal product qualification prior to the delivery of any new product or enhanced existing products other than prototypes/samples.

### 1.1 Design Tools

Schematics entry:

Logic & Fault simulators:

Layout Synthesis:

Layout Editor: Layout Verification: View Logic Startech Advanced Logic simulator Goliath (Startech Layout synthesis) Opal

Opai Dracula



150 samples from three different product lots are selected to perform extended temperature operation test, 85° C/ 85% R.H. / 5.5V temperature humidity bias. Same samples are used for accelerated burn-in and electro-static tests.

STARTECH semiconductor subcontracts its fabrication process to ORBIT semiconductor located in Sunnyvale, California. Packaging and final testing are also subcontracted to other vendors located locally or overseas.

### 1.2 Determination of the Failure Rate

In the simplest form, the failure rate prediction at a given temperature can be predicted as follows.

Failure rate= N/DH

Where:

N= number of failures D= number of devices H= number of hours tested

assuming that semiconductors exhibit a log normal distribution.

### **Acceleration Factors**

The effects of temperature, voltage, time and other related functions are key when predicting life times of semiconductor devices. Understanding these effects with the use of a more accurate mathematical model, provides a better means of evaluating the change in reaction rate to changes in temperature.

 $F(T1, T2) = \exp(-Ea/k(1/T1-1/T2))$ 

Where:

F= Acceleration factor
T1= Test temperature (° C+273)
T2= Desired temperature (° C+273)
k= Boltzman's constant (8.63 E-5eV / K)
Ea= Thermal activation energy (eV)



The equivalent device hours can be determined at temperature T2 can be expressed as:

EDH (T2) = F (T1, T2) x DH (T1) The failure rate at T2 can be expressed as:

Failure rate (T2)= N/EDH (T2)

Where:

N= Number of failures EDH= Equivalent device hours



C.L.=Confidence Level

# 1.3 Activation Energies for Primary Failure Mechanisms

| 1-1.4 eV<br>0.5 eV |
|--------------------|
| 0.5.6\/            |
| U.J & V            |
| 1 eV               |
| 0.3 eV             |
| 0.5 eV             |
| 1 eV               |
|                    |

### 1.4 Definition and common test methods

### Accelerated operating life stress

Accelerated operating life stressing is performed to accelerate failure mechanisms, which are thermally activated, through the application of extreme temperature and dynamic biasing conditions. The typical temperature and voltage conditions used in the stress are 125 °C with a bias level at the maximum data sheet specifications.

### 85 °C/ 85 % R.H.

85 °C/ 85 % R.H. is an environmental stress performed at a temperature of 85 °C and relative humidity of 85%. The test is designed to measure the moisture resistance of encapsulated devices.

### Electrostatic discharge testing

Electrostatic discharge testing is performed to determine the handling sensitivity of a semiconductor device.

### **CMOS latch-up test**

CMOS latch-up test is performed to determine the sensitivity of a device input to overshoot and undershoot signals connected to device inputs.



# Commercial and Industrial Product Flows







# Design and Layout Flow TARGET SPECIFICATION CIRCUIT DESIGN SCHEMATICS ENTRY H-SPICE SIMULATION SAL SIMULATION OPTIMIZATION LAYOUT DRC ERC LVS CORRECTIONS GDSII TAPEOUT MASK CHECK

8





8-11

# HIGH TEMPERATURE OPERATING LIFE

### 2.0 EARLY FAILURE RATE SUMMARY

### 2.1 Early Failure rate Determination

High temperature operating life testing for as log as 96 hours, is used to estimate device early failure rate. Using our standard failure rate assumption, the early failure rate period extends through the first 2000 hours of device operation. Afterwards, the device reliability is characterized by the long term failure rate.

Test:

High Temperature Operating Life Test (HTOL)

Conditions:

Dynamic Operating Conditions, Vcc = 5.25 Volts, 150 ° C or 125 ° C,

Frequency = 2 MHz.

Duration:

Early Failure Rate samples are tested between 48 and 96 hours HTOL

at 150 ° C or 96 hours at 125 ° C.

Failure:

A failure is any device that fails to meet data sheet electrical requirements following the HTOL test. Failure analysis is performed on every failure to identify the specific mechanism and determine a corrective action. Corrective actions are implemented and audited under the total

quality management system.

### 2.2 Early Failure Rate Summary

| Technology | No. of Devices Tested | No. of Fails | Failure mode | Defects (PPM) |
|------------|-----------------------|--------------|--------------|---------------|
| ST16C450   | 1000                  | 0            | None         | 0             |
| ST16C550   | 1500                  | 2            | Leakage      | 1333          |
| ST16C452   | 1500                  | .1           | Functional   | 666           |
| ST16C552   | 2000                  | 0            | None         | 0             |
| ST16C554   | 2000                  | 1            | Leakage      | 500           |
| ST26C31    | 1000                  | 0            | None         | 0             |
| ST26C32    | 1000                  | 0            | None         | 0             |

### 3.0 LONG TERM FAILURE RATE SUMMARY

### 3.1 Long Term Failure Rate Determination

A High temperature Operating Life test is used to estimate long term reliability. By operating the devices at accelerated temperature and voltage, hundreds of thousands of use hours can be compressed into thousands of test hours. The method used to estimate failure rates from stress data is summarized.

Test:

High Temperature Operating Life Test (HTOL)

Conditions:

Dynamic Operating Conditions, Vcc = 5.25 Volts, 150 ° C, Frequency

= 2 MHz.

Duration:

Long term Failure Rate is minimum 168 hours HTOL at 150 ° C

periodically tested to 2000 hours.

Reliability:

 $\label{lem:failure} \textbf{Failure mechanisms common to semiconductor components are accel-}$ 

erated by temperature and voltage. In calculating failure rates, though,

only temperature acceleration is included.

### 3.2 Long term Failure Rate Summary

| Technology | No. of Devices Tested | No. of Fails                            | Failure mode | Defects (PPM) |
|------------|-----------------------|-----------------------------------------|--------------|---------------|
| ST16C450   | 5000                  | · 1                                     | Functional   | 200           |
| ST16C550   | 8000                  | 1                                       | Leakage      | 125           |
| ST16C452   | 7500                  | 0                                       | None         | . 0           |
| ST16C552   | 5000                  | 0                                       | None         | 0             |
| ST16C554   | 7000                  | 4                                       | Functional   | 143           |
| ST26C31    | 1000                  | • • • • • • • • • • • • • • • • • • • • | None         | 0             |
| ST26C32    | 1000                  | 0 0                                     | None         | 0             |



### 4.0 HIGH TEMPERATURE STEADY STATE LIFE TEST

The High Temperature Steady State Life test is used to accelerated ionic contamination problems. Static bias is used because a constant voltage gradient accelerated diffusion of ionic species. The method used to estimate failure rates from stress data is summarized.

| Technology | No. of Devices Tested | No. of Fails | Failure mode | Defects (PPM)                           |
|------------|-----------------------|--------------|--------------|-----------------------------------------|
| ST16C450   | 3000                  | 1 N          | Functional   | 333                                     |
| ST16C550   | 3000                  | 0            | None         | 0                                       |
| ST16C452   | 4500                  | 1            | Functional   | 222                                     |
| ST16C552   | 1000                  | 0            | None         | 0                                       |
| ST16C554   | 1000                  | 1.0 m        | None         | · . · · · · · · · · · · · · · · · · · · |
| ST26C31    | 1000                  | 0            | None         | 0                                       |
| ST26C32    | 1000                  | 0            | None         | 0                                       |

### 5.0 PACKAGE STRESS TESTS

Startech Semiconductor Reliability qualifies and continuously monitors the packaging reliability to ensure exceptional resistance to environmental stress. Package reliability stress testing and failure rates are summarized.

### 5.1 Pressure Cooker Test

Test:

Pressure Cooker Test (PCT)

Conditions:

15 PSIG, 120 °C, No bias, 295 hours minimum time

Purpose:

The Pressure Cooker Test is a highly accelerated packaging stress test used to ensure environmental durability of epoxy packaged parts. Passivation cracks, ionic contamination and corrosion susceptibility are

all accelerated by this stress.

Failure:

Any device which fails to meet all data sheet requirements is classified

as a failure.

### 5.2 Pressure Cooker Summary

| Technology   | No. of Devices Tested | No. of Fails | Failure mode | Defects (PPM) |
|--------------|-----------------------|--------------|--------------|---------------|
| ST16C450CP40 | 5000                  | 1            | Functional   | 200           |
| ST16C450CJ44 | 5000                  | 0            | None         | 0             |
| ST16C550CP40 | 5000                  | 0            | None         | 0             |
| ST16C550CJ44 | 5000                  | 1            | Leakage      | 200           |
| ST16C452CP68 | 5000                  | <b>1</b> ,   | Functional   | 200           |
| ST16C552CP68 | 5000                  | 1            | Functional   | 200           |
| ST16C554CP68 | 5000                  | 0            | None         | 0             |
| ST26C31CP16  | 1000                  | , 0          | None         | 0             |
| ST26C32CP16  | 1000                  | 0            | None         | 0             |

### 5.2 Highly Accelerated Stress Test

Test: High A

High Accelerated Stress Test (HAST)

Conditions:

18.6 PSIG, 125 °C, 85% RH, 5.5 Volts bias, minimum test time, 96

hours.

Purpose:

HAST is an accelerated biased humidity test that literature, and tests

run at Startech, has shown provides an acceleration 10-15X over 85 ° C/85%. This test provides the factory with rapid feedback regarding the

quality of the epoxy package process.

Failure:

A failure is defined as a device which fails to pass the standard data

sheet test program.

٥.

### 5.4 Accelerated Stress Summary

| Technology   | No. of Devices Tested | No. of Fails | Failure mode | Defects (PPM) |
|--------------|-----------------------|--------------|--------------|---------------|
| ST16C450CP40 | 5000                  | 0            | None         | 0             |
| ST16C450CJ44 | 5000                  | 0            | None         | 0             |
| ST16C550CP40 | 5000                  | o o          | None         | . 0           |
| ST16C550CJ44 | 5000                  | 0            | None         | 0             |
| ST16C452CP68 | 5000                  | 0            | None         | 0             |
| ST16C552CP68 | 5000                  | . 0          | None         | 0             |
| ST16C554CP68 | 5000                  | 0            | None         | 0             |
| ST26C31CP16  | 1000                  | 0            | None         | 0             |
| ST26C32CP16  | 1000                  | . 0          | None         | 0             |

### 5.5 Temperature Cycle Test

Differences in thermal expansion coefficients are accentuated by cycling devices through temperature extremes. If the materials do not expand and contact equally, large stresses can develop.

Test:

**Temperature Cycle** 

Conditions:

MIL-STD-883C, Method test stress mechanical integrity by exposing a device to alternating temperature extremes. Weakness and thermal expansion mismatches in die interconnections, die attach, and wire

bonds are often detected with this acceleration test.

Purpose:

100 cycles minimum, periodically tested to 1000 cycles

Failure:

Any device which fails to meet all data sheet requirements is classified

as a failure.

### 5.6 Temperature Cycle Summary

| Technology   | No. of Devices Tested | No. of Fails | Failure mode | Defects (PPM) |
|--------------|-----------------------|--------------|--------------|---------------|
| ST16C450CP40 | 5000                  | 0            | None         | 0             |
| ST16C450CJ44 | 5000                  | 0            | None         | 0             |
| ST16C550CP40 | 5000                  | 0            | None         | 0             |
| ST16C550CJ44 | 5000                  | 2            | Leakage      | 400           |
|              |                       |              | Functional   |               |
| ST16C452CP68 | 5000                  | 0            | None         | 0             |
| ST16C552CP68 | 5000                  | 0            | None         | 0             |
| ST16C554CP68 | 5000                  | 0            | None         | 0             |
| ST26C31CP16  | 1000                  | 0            | None         | 0             |
| ST26C32CP16  | 1000                  | 0            | None         | 0             |

### ESD AND LATCH-UP TEST

### 6.0 Latch-up Sensitive

Test:

Latch-up Sensitivity

Conditions:

Current Injection = 200mA Trigger, Hot Socket = Vcc 0-7 Volts, Vcc

Oscillation at Vcc = 3.5-7.0 Volts at 1 MHz. Temperature = 150 ° C.

Purpose:

The latch-up test is designed to test resistance of the devices to extreme

voltage and current excursions. Latch-up has historically been a

problem associated with CMOS devices.

Failure:

Any device which fails the Latch-up test if Latch-up occurs at less than

200mA of current.

### 6.1 Results:

All products are tested for latch-up during qualification.

Outputs:

All outputs are tested using a hot socket technique where the full voltage is applied instantly, on a voltage ramp, where voltage is increased

slowly. During the hot socket technique, a maximum of 400 mA was

allowed in order to protect the outputs from overstress.

Inputs:

All inputs are tested using both the hot socket technique and the voltage

ramp technique.

### 6.2 Conclusion:

Startech Semiconductor products are very resistant to latch-up.

### 7.0 Electrostatic Discharge (ESD)

Test:

Electrostatic Discharge

Conditions:

MIL-STD-883C, Method 3015

Purpose:

The ESD test established the sensitive of device to electrostatic

discharge of the type than can occur during ordinary handling.

Failure:

A device fails the ESD stress test is any pin combination defined in method 3015 of MIL-STD-883C is damaged after testing with a 2000 Volts discharge. Data sheet electrical testing is performed to determine

if a device has been damaged.

### 7.1 Results:

All Startech Semiconductor products are tested for resistance to ESD during qualification. All pins pass ESD testing at 2000 Volts.

### 7.2 Conclusion:

Startech Semiconductor products are not ESD sensitive per the definition of MIL-STD-883C.

# **QUALITY / RELIABILITY**

ORDERING INFORMATION 9

#### ORDERING INFORMATION AND PART NUMBERING GUIDE .



# Temperature Range C Commercial 0° C To +70° C I Industrial -40° C To +85° C M Military -55° C To +125° C

#### Package Type

- P Plastic Dip
- C Ceramic
- **D** Cerdip
- L Leadless Chip Carrier (LCC)
- J Plastic Leaded Chip Carrier (PLCC)
- F Flat Pack(SOIC)
- Q Quad Flat Pack
- G Pin Grid
- T Thin Shrink Small Outline Package (TSSOP)

# PACKAGE MARKING INFORMATION (EXCEPT CLOCK SYNTHESIZERS AND TQFP PACKAGES)



#### DATE CODE AND OPTIONS MARKING



#### "ST16C452" DATE CODE AND OPTIONS MARKING



# PACKAGE MARKING INFORMATION (CLOCK SYNTHESIZERS)



#### DATE CODE AND OPTIONS MARKING



#### 48-TQFP PACKAGE MARKING INFORMATION



#### DATE CODE AND OPTIONS MARKING



PACKAGING INFORMATION





































### **North American Representatives**

Alabama

Bits Inc.

TEL (205) 881-2900 FAX (205) 881-7333

Arizona

SUNTECH SALES TEL (602) 860-8262 FAX (602) 860-9730

Arkansas

ARRAYTECH SALES TEL (919) 676-1880 FAX (919) 676-1881

California

PRO ASSOCIATES TEL (408) 248-5300 FAX (408) 244-7939

INFINITY SALES

TEL (714) 833-0300 FAX (714) 833-0303

INFINITY SALES TEL (310) 455-2566

INFINITY SALES TEL (619) 535-9300 FAX (619) 550-3707

INFINITY SALES TEL (818) 880-6480 FAX (818) 880-1922

Colorado SPECTRUM MARKETING TEL (303) 480-9991 FAX (303) 455-5303

Connecticut
DYNAMIC SALES
TEL (203) 693-0451
FAX (203) 693-1302

Florida SEC

TEL (407) 830-8444 FAX (407) 830-8684

SEC

TEL (305) 783-6900 FAX (305) 782-7274

Georgia

BITS Inc. TEL (404) 564-5599 FAX (404) 564-5588

Illinois

MICRO SALES INC. TEL (708) 285-1000 FAX (708) 285-1008

Kentucky

BITS Inc.

TEL (404) 564-5599 FAX (404) 564-5588

Maine

DYNAMIC SALES TEL (617) 272-5676 FAX (617) 273-4856

Massachusetts

DYNAMIC SALES TEL (617) 272-5676 FAX (617) 273-4856

Michigan

J.M.J & ASSOCIATES TEL (616) 285-8887 FAX (616) 285-7633

Minnesota MURNCO

TEL (612) 854-4161 FAX (612) 854-9634

### **North American Representatives**

Mississippi

BITS Inc.

TEL (205) 881-2900 FAX (205) 881-7333

**New Hampshire** 

BITS Inc. TEL (6 FAX (6

(617) 272-5676 (617) 273-4856

**New Jersey** 

ERA Inc.

TEL (516) 543-0510 FAX (516) 543-0758

New York

ERA Inc.

TEL (516) 543-0510 FAX (516) 543-0758

**North Carolina** 

BITS Inc.

TEL (919) 676-1880 FAX (919) 676-1881

Oklahoma

ARRAYTECH SALES TEL (919) 676-1880 FAX (919) 676-1881

Oregon

ADAPT ELECTRONICS TEL (503) 297-2151 FAX (503) 297-2042

Pennsylvania

**TECH SALES** 

TEL (215) 784-0170 FAX (215) 784-9201

**Puerto Rico** 

SEC

TEL (809) 841-4220 FAX (809) 259-7223 Rhode Island

DYNAMIC SALES

TEL (617) 272-5676 FAX (617) 273-4856

**South Carolina** 

BITS Inc.

TEL (404) 564-5599

FAX (404) 564-5588

**Tennessee** 

BITS Inc.

TEL (404) 564-5599

FAX (404) 564-5588

TEL (205) 881-2900

FAX (205) 881-7333

**Texas** 

ARRAYTECH SALES

TEL (214) 392-1199

FAX (214) 392-1399

ARRAYTECH SALES

TEL (512) 335-4105

FAX (512) 335-8128

ARRAYTECH SALES

TEL (713) 861-5009

FAX (713) 861-0402

Utah

SPECTRUM MARKETING

TEL (303) 480-9991

FAX (303) 455-5303

Vermont

DYNAMIC SALES

TEL (802) 476-4223

Washington

ADAPT ELECTRONICS

TEL (509) 327-4838

FAX (509) 327-2030

# **North American Distributors**

| ADAPT ELECTRONICS                        | Florida                                  |  |  |  |  |
|------------------------------------------|------------------------------------------|--|--|--|--|
| TEL (206) 820-6216<br>FAX (206) 820-6216 | TEL (407) 682-1199<br>FAX (407) 682-1286 |  |  |  |  |
| Wisconsin                                | LCD ELECTRONICS, INC.                    |  |  |  |  |
| MICRO SALES INC.                         |                                          |  |  |  |  |
| TEL (414) 786-1403<br>FAX (414) 786-1813 | Texas<br>TEL (214) 245-0600              |  |  |  |  |
| 1700 (414) 700-1010                      | FAX (214) 245-0342                       |  |  |  |  |
| NORTH AMERICAN DISTRIBUTORS              | TEL (512) 388-0900                       |  |  |  |  |
| RELL MICROPROPLICES                      | FAX (512) 280-6583                       |  |  |  |  |
| BELL MICROPRODUCTS                       | TEL (800) 245-0342                       |  |  |  |  |
| California                               | PARTS ONE                                |  |  |  |  |
| TEL (408) 451-9400<br>FAX (408) 451-1600 | PARTS ONL                                |  |  |  |  |
| 1700 (400) 401 1000                      | Minnesota                                |  |  |  |  |
| TEL (714) 470-2900                       | TEL (800) 247-0867                       |  |  |  |  |
| FAX (714) 470-2929                       | FAX (612) 633-2310                       |  |  |  |  |
| Massachussets                            | TEL (800) 424-6204                       |  |  |  |  |
| TEL (508) 658-0222                       | FAX (218) 624-0850                       |  |  |  |  |
| FAX (508) 694-9987                       | NU HORIZON                               |  |  |  |  |
| TEL (508) 667-2400                       |                                          |  |  |  |  |
| FAX (508) 683-7474                       | California<br>TEL (408) 434-0800         |  |  |  |  |
| Texas                                    | FAX (408) 434-0800                       |  |  |  |  |
| TEL (214) 783-4191                       | 1700 (400) 404 0000                      |  |  |  |  |
| FAX (214) 783-4192                       | New Jersey                               |  |  |  |  |
|                                          | TEL (201) 882-8300                       |  |  |  |  |
| New Jersey                               | FAX (201) 882-8398                       |  |  |  |  |
| TEL (201) 777-4100                       | TEL (609) 231-0900                       |  |  |  |  |
| FAX (201) 777-6194                       | FAX (609) 231-9510                       |  |  |  |  |
| New York                                 |                                          |  |  |  |  |
| TEL (516) 543-2000                       | Connecticut                              |  |  |  |  |
| FAX (516) 543-2030                       | TEL (203) 265-0162<br>FAX (203) 261-6657 |  |  |  |  |
| Maryland                                 |                                          |  |  |  |  |
| TEL (410) 720-5100                       | Alabama                                  |  |  |  |  |
| FAX (410) 381-2172                       | TEL (205) 722-9330<br>FAX (205) 722-9348 |  |  |  |  |
|                                          | 1701 (200) 122-00-0                      |  |  |  |  |

## North American Distributors

Ohio

TEL (216) 349-2008 FAX (216) 249-2080

Florida

TEL (305) 735-2555 FAX (305) 735-2880

TEL (407) 831-8008 FAX (407) 831-8862

Georgia

TEL (404) 416-8666 FAX (404) 416-9060

Maryland

TEL (410) 995-6330 FAX (410) 995-6332

New York

TEL (516) 226-6000 FAX (516) 226-6140

TEL (716) 292-0777 FAX (716) 292-0750

Massachusetts TEL (617) 246-4442 FAX (617) 246-4462

Texas

TEL (214) 488-2255 FAX (214) 488-2265 Charles Control (1994) Supplies (1994) (1994)

### International Representatives

Australia

**LOGIC 4 AUSTRALASIA** (61) 8-373-2811 FAX (61) 8-373-2286

**LOGIC 4 AUSTRALASIA** (61) 3-887-3800 TFI FAX (61) 3-887-3811

Austria

**ELBATEX** 

TEL (43) 1-816020 FAX (46) 1-81602201

Belgium

TME ELECTRONICS TEL (32) 3-325-1910 FAX (32) 3-326-0510

Canada

INTELATECH, INC. TEL (905) 629-0082 FAX (905) 629-1795

INTELATECH, INC. TEL (403) 230-3190 FAX (403) 230-3183

INTELATECH, INC. TEL (613) 599-7330 FAX (613) 599-7329

INTELATECH, INC. (514) 343-4877 TEL FAX (514) 343-4355

Denmark

E. V. JOHANSSEN ELEKTRONIK A/S TEL (45) 3183-9022 FAX (45) 3183-9222

England

FAX

BRITCOMP SALES LTD (BSL) TEL (44) 932-346256 (44) 932-347110

2001 ELECTRONIC COMPONENTS

TEL (44) 438-742001 FAX (44) 438-742002

France

3D

TEL (33) 1-6447-2929 FAX (33) 1-6447-0084

MICROEL

TEL (33) 1-6938-7678 FAX (33) 1-6938-7960

Hong Kong

**TEKTRON ELECTRONICS** TEL (852) 388-0629 FAX (852) 780-5871

TWIN-STAR TRADING TEL (852) 346-9085 FAX (852) 347-0926

Germany

EUROCOMP ELEKTRONIK Gmbh TEL (49) 6031-61076

FAX (49) 6031-61788

DISCOMP ELEKTRONIK Gmbh

TEL (49) 2722-71 (49) 2722-7150 FAX

HY-LINE COMPUTER COMPONENTS Gmbh

TEL (49) 89-614-9010 FAX (49) 89-614-0960

KAMAKA ELEKTRONIK Gmbh

TEL (49) 7275-8600 FAX (49) 7275-8675

Greece

DROGETA ENGINEERING

TEL: (30)

(30) 1-991-0948 FAX

# International Representatives

India

DIGIPRO MKTG. PVT. LTD. TEL (91) 80-52-72659

FAX (91) 80-55-93088

Israel

STAR-TRONICS LTD.

TEL (972) 3-696-0148 FAX (972) 3-696-0255

Italy KEVIN

TEL (39) 2-4870-6300

FAX (39) 2-4870-6500

Japan

ISI TEL

(81) 3-3264-3301

FAX (81) 3-3264-3419

NICHIMEN ELECTRONICS COMPONENTS

TEL (06) 226-0015

FAX (06) 226-0016

TEL (03) 3662-6880

FAX (03) 3662-6841

Korea

I & C MICROSYSTEMS Co.

TEL (82) 2-577-9131

FAX (82) 2-577-9130

Malaysia

MICROTRONICS

TEL (65) 748-1835

FAX (65) 743-3065

Netherlands

**AVE ELECTRONICS** 

TEL (31) 78-138288

FAX (31) 78-140390

Norway

HANS H. SCHIVE

TEL (47) 66-900-900

FAX (47) 66-904-484

**Singapore** 

SERIAL SYSTEMS MKTG.

TEL (65) 280-0200

FAX (65) 286-6723

Spain

MATRIX ELECTRONICA, S.L.

TEL (34) 1-560-2737

FAX (34) 1-565-2865

South Africa

KH DISTRIBUTORS

TEL (27) 11-852-5011

TEL (27) 11-852-2670

FAX (27) 11-852-6513

Sweden

**BEXAB TECHNOLOGY** 

TEL (46) 8-630-8810

FAX (46) 8-732-7058

Taiwan

JATRON ELECTRONICS, INC.

TEL (886) 2-3070152

FAX (886) 2-3055629

|   |   | , Commission on the con- | The second section of the second section of the second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second sec |   |
|---|---|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|   | · |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
| • |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | • |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
| 1 |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   | * |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |   |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |

