SLLS189D – NOVEMBER 1994 – REVISED JANUARY 1999

- IBM PC/AT<sup>™</sup> Compatible
- Two TL16C550 ACEs
- Enhanced Bidirectional Printer Port
- 16-Byte FIFOs Reduce CPU Interrupts
- Up to 16-MHz Clock Rate for up to 1-Mbaud Operation
- Transmit, Receive, Line Status, and Data Set Interrupts on Each Channel Independently Controlled
- Individual Modem Control Signals for Each Channel

- Programmable Serial Interface Characteristics for Each Channel:
  - 5-, 6-, 7-, or 8-Bit Characters
  - Even, Odd, or No Parity Bit Generation and Detection
  - 1-, 1-1/2-, or 2-Stop Bit Generation
- 3-State Outputs Provide TTL Drive for the Data and Control Bus on Each Channel
- Hardware and Software Compatible With TL16C452





Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.

IBM PC/AT is a trademark of International Business Machines Corporation.

PRODUCTION DATA information is current as of publication date. Products conform to specifications per the terms of Texas Instruments standard warranty. Production processing does not necessarily include testing of all parameters.



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

PN PACKAGE (TOP VIEW)



#### description

The TL16C552A is an enhanced dual-channel version of the popular TL16C550B asynchronous communications element (ACE). The device serves two serial input/output interfaces simultaneously in microcomputer or microprocessor-based systems. Each channel performs serial-to-parallel conversion on data characters received from peripheral devices or modems and parallel-to-serial conversion on data characters transmitted by the CPU. The complete status of each channel of the dual ACE can be read at any time during functional operation by the CPU. The information obtained includes the type and condition of the transfer operations being performed and the error conditions encountered.

In addition to its dual communications interface capabilities, the TL16C552A provides the user with a bidirectional parallel data port that fully supports the parallel Centronics-type printer interface. The parallel port and the two serial ports provide IBM PC/AT-compatible computers with a single device to serve the three system ports. A programmable baud rate generator that can divide the timing reference clock input by a divisor between 1 and  $(2^{16} - 1)$  is included.

The TL16C552A is available in a 68-pin plastic-leaded chip-carrier (FN) package, a 48-pin TQFP (PN) package, and the 80-pin TQFP (PN) package. The TL16C552AM is available in a 68-pin ceramic quad flat (HV) package.



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

#### functional block diagram





SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

## **Terminal Functions**

| TE                               | RMINAL        |               |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------------------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME                             | N             | 0.            | 1/0 | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                  | FN            | PN            |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ACK                              | 68            | 10            | I   | Line printer acknowledge. ACK goes low to indicate a successful data transfer has taken place. ACK generates a printer port interrupt during its positive transition.                                                                                                                                                                                                                                                                                                                                 |
| AFD                              | 56            | 75            | I/O | Line printer autofeed. $\overline{\text{AFD}}$ is an open-drain line that provides the printer with an active-low signal when continuous form paper is to be autofed to the printer. $\overline{\text{AFD}}$ has an internal pullup resistor to V <sub>DD</sub> of approximately 10 k $\Omega$ .                                                                                                                                                                                                      |
| A0, A1, A2                       | 35, 34,<br>33 | 51, 50,<br>49 | I   | Address. The address lines $A0 - A2$ select the internal registers during CPU bus operations. See Table 2 for the decode of the serial channels and Table 13 for the decode of the parallel printer port.                                                                                                                                                                                                                                                                                             |
| BDO                              | 44            | 63            | 0   | Bus buffer. BDO is the active-high output and is asserted when either the serial channel or the parallel port is read. BDO controls the system bus driver (74LS245 or 54LS245).                                                                                                                                                                                                                                                                                                                       |
| BUSY                             | 66            | 8             | I   | Line printer busy. BUSY is an input line from the printer that goes high when the printer is not ready to accept data.                                                                                                                                                                                                                                                                                                                                                                                |
| CLK                              | 4             | 14            | 1   | Clock. CLK is the external clock input to the baud rate divisor of each ACE.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <u>CS0</u> , <u>CS1</u> ,<br>CS2 | 32, 3,<br>38  | 48, 13,<br>54 | I   | Chip select. Each $\overline{CSx}$ input acts as an enable for the write and read signals for serial channels 1 ( $\overline{CS0}$ ) and 2 ( $\overline{CS1}$ ). $\overline{CS2}$ enables the signals to the printer port.                                                                                                                                                                                                                                                                            |
| <u>CTS0,</u><br>CTS1             | 28, 13        | 44, 26        | I   | Clear to send. The logical state of each $\overline{\text{CTSx}}$ terminal is reflected in the CTS bit of the modem status register ( <u>CTS</u> is bit 4 of the modem status register, written as MSR4) of each ACE. A change of state in either $\overline{\text{CTS}}$ terminal since the previous reading of the associated MSR causes the setting of $\Delta$ CTS (MSR0) of each modem status register.                                                                                          |
| DB0 –<br>DB7                     | 14 – 21       | 27 – 34       | I/O | Data bits DB0–DB7. The data bus provides eight I/O lines with 3-state outputs for the transfer of data, control, and status information between the TL16C552A and the CPU. These lines are normally in the high-impedance state except during read operations. DB0 is the least significant bit (LSB) and is the first serial data bit to be received or transmitted.                                                                                                                                 |
| DCD0,<br>DCD1                    | 29, 8         | 45, 18        | I   | Data carrier detect. DCD is a modem input. Its condition can be tested by the CPU by reading MSR7 (DCD) of the modem status registers. MSR3 ( $\Delta$ DCD) of the modem status register indicates whether DCD has changed states since the previous reading of the MSR. DCD has no effect on the receiver.                                                                                                                                                                                           |
| DSR0,<br>DSR1                    | 31, 5         | 47, 15        | I   | Data set ready. The logical state of the DSRx terminals is reflected in MSR5 of its associated modem status register. $\Delta$ DSR (MSR1) indicates whether the associated DSRx terminal has changed states since the previous reading of the MSR.                                                                                                                                                                                                                                                    |
| DTR0,<br>DTR1                    | 25, 11        | 38, 24        | 0   | Data terminal ready. Each DTRx can be set low by setting MCR0, modem control register bit 0 of its associated ACE. DTRx is cleared (high) by clearing the DTR bit (MCR0) or whenever a reset occurs. When active (low), DTRx indicates that its ACE is ready to receive data.                                                                                                                                                                                                                         |
| ENIRQ                            | 43            | 59            | I   | Parallel port interrupt source mode selection. When ENIRQ is low, the AT mode of interrupts is enabled.<br>In AT mode, INT2 is internally connected to ACK. When ENIRQ is tied high, the PS-2 mode of interrupt<br>is enabled and INT2 is internally tied to the inverse of the PRINT bit in the line printer status register.<br>INT2 is latched high on the rising edge of ACK. INT2 is held until the status register is read, which then<br>clears the PRINT status bit and INT2.                 |
| ERR                              | 63            | 5             | I   | Line printer error. ERR is an input line from the printer. The printer reports an error by holding ERR low during the error condition.                                                                                                                                                                                                                                                                                                                                                                |
| GND                              | 7, 27,<br>54  | 17, 43,<br>73 |     | Ground (0 V). All terminals must be tied to GND for proper operation.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| INIT                             | 57            | 76            | I/O | Line printer initialize. $\overline{\text{INIT}}$ is an open-drain line that provides the printer with an active-low signal that allows the printer initialization routine to be started. INIT has an internal pullup resistor to V <sub>DD</sub> of approximately 10 kΩ.                                                                                                                                                                                                                             |
| INTO, INT1                       | 45, 60        | 64, 79        | 0   | External serial channel interrupt. Each serial channel interrupt 3-state output (enabled by bit 3 of the MCR) goes active (high) when one of the following interrupts has an active (high) condition and is enabled by the interrupt enable register of its associated channel: receiver error flag, received data available, transmitter holding register empty, and modem status. The interrupt is cleared on appropriate service. Upon reset, the interrupt output is in the high-impedance state. |



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

## **Terminal Functions (Continued)**

| TE                | RMINAL |        |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------|--------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NO.<br>NAME FN PN |        |        | 1/0 | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| NAME              | FN     | PN     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| INT2              | 59     | 78     | 0   | Printer port interrupt. INT2 is an active-high, 3-state output generated by the positive transition of ACK. INT2 is enabled by bit 4 of the write control register. Upon reset, INT2 is in the high-impedance state. Its mode is also controlled by ENIRQ.                                                                                                                                                                                                              |
| IOR               | 37     | 53     | I   | Input/output read strobe. $\overline{\text{IOR}}$ is an active-low input that enables the selected channel to output data to the data bus (DB0–DB7). The data output depends on the register selected by the address inputs A0, A1, A2, and chip select. Chip select 0 ( $\overline{\text{CS0}}$ ) selects ACE #1, chip select 1 ( $\overline{\text{CS1}}$ ) selects ACE #2, and chip select 2 ( $\overline{\text{CS2}}$ ) selects the printer port.                    |
| IOW               | 36     | 52     | I   | Input/output write strobe. IOW is an active-low input causing data from the data bus to be input to either ACE or to the parallel port. The destination depends on the register selected by the address inputs A0, A1, A2, and chip selects CS0, CS1, and CS2.                                                                                                                                                                                                          |
| PD0-PD7           | 53-46  | 72–65  | I/O | Parallel data bits $(0-7)$ . PD0-PD7 provide a byte wide input or output port to the system.                                                                                                                                                                                                                                                                                                                                                                            |
| PE                | 67     | 9      | I   | Line printer paper empty. PE is an input line from the printer that goes high when the printer runs out of paper.                                                                                                                                                                                                                                                                                                                                                       |
| PEMD              | 1      | 11     | I   | Printer enhancement mode. When low, PEMD enables the write data register to the PD0–PD7 lines. A high on PEMD allows direction control of the PD0–PD7 port by the DIR bit in the control register. PEMD is usually tied low for the printer operation.                                                                                                                                                                                                                  |
| RESET             | 39     | 55     | I   | Reset. When low, RESET forces the TL16C552A into an idle mode in which all serial data activities are suspended. The modem control register and its associated outputs are cleared. The line status register is cleared except for the transmitter holding register empty (THRE) and TEMT bits, which are set. All functions of the device remain in an idle state until programmed to resume serial data activities. RESET has a hysteresis level of typically 400 mV. |
| RTS0,<br>RTS1     | 24, 12 | 37, 25 | 0   | Request to send. The $\overline{\text{RTS}}$ outputs are set low by setting MCR1 of its UARTs modem control register.<br>Both $\overline{\text{RTS}}$ terminals are reset high by $\overline{\text{RESET}}$ . A low on $\overline{\text{RTS}}$ indicates that its ACE has data ready to transmit. In half-duplex operations, $\overline{\text{RTS}}$ controls the direction of the line.                                                                                |
| RXRDY0,<br>RXRDY1 | 9, 61  | 19, 3  | 0   | Receiver ready. Receiver direct memory access (DMA) signaling is also available through this output. One of two types of DMA signaling can be selected using FCR3 when in FIFO mode. Only DMA mode 0 is allowed when in TL16C450 mode. For signal transfer DMA (a transfer is made between CPU bus cycles), mode 0 is used. Multiple transfers that are made continuously until the receiver FIFO has been emptied are supported by mode 1.                             |
|                   |        |        |     | Mode 0. $\overrightarrow{\text{RXRDY}}$ is active (low) in FIFO mode (FCR0 = 1, FCR3 = 0) or in TL16C450 mode (FCR0 = 0) and the receiver FIFO or receiver holding register contains at least one character. When there are no more characters in the FIFO or holding register, $\overrightarrow{\text{RXRDY}}$ goes inactive (high).                                                                                                                                   |
|                   |        |        |     | Mode 1. $\overline{\text{RXRDY}}$ goes active (low) in the FIFO mode (FCR0 = 1) when FCR3 = 1 and the time-out or trigger levels have been reached. $\overline{\text{RXRDY}}$ goes inactive (high) when the FIFO or holding register is empty.                                                                                                                                                                                                                          |
| RI0, RI1          | 30, 6  | 46, 16 | I   | Ring indicator. The $\overline{RI}$ signal is a modem control input. Its condition is tested by reading MSR6 (RI) of each ACE. The modem status register output TERI (MSR2) indicates whether $\overline{RI}$ has changed from high to low since the previous reading of the modem status register.                                                                                                                                                                     |
| SIN0,<br>SIN1     | 41, 62 | 57, 4  | I   | Serial data. SIN0 and SIN1 move information from the communication line or modem to the TL16C552A receiver circuits. Mark is a high state and space is a low state. Data on serial data inputs is disabled in loop mode.                                                                                                                                                                                                                                                |
| SLCT              | 65     | 7      | Ι   | Line printer select. SLCT is an input line from the printer that goes high when the printer is selected.                                                                                                                                                                                                                                                                                                                                                                |
| SLIN              | 58     | 77     | I/O | Line printer select. SLIN is an open-drain I/O that selects the printer when active (low). SLIN has an internal pullup resistor to $V_{DD}$ of approximately 10 k $\Omega$ .                                                                                                                                                                                                                                                                                            |

SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

## **Terminal Functions (Continued)**

| TERMINAL         |               |              |             |                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------|---------------|--------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NO.              |               | I/O          | DESCRIPTION |                                                                                                                                                                                                                                                                                                                                                                                         |
| NAME<br>FN PN    |               |              |             |                                                                                                                                                                                                                                                                                                                                                                                         |
| SOUT0,<br>SOUT1  | 26, 10        | 39, 23       | 0           | Serial data outputs. SOUT0 and SOUT1 are the serial data outputs from the ACE transmitter circuitry. A mark is a high state and a space is a low state. Each SOUT is held in the mark condition when the transmitter is disabled (RESET is asserted low), the transmitter register is empty, or when in the loop mode.                                                                  |
| STB              | 55            | 74           | I/O         | Line printer strobe. STB provides communication between the TL16C552A and the printer. When STB is active (low), it provides the printer with a signal to latch the data currently on the parallel port. STB has an internal pullup resistor to $V_{DD}$ of approximately 10 k $\Omega$ .                                                                                               |
| TRI              | 2             | 12           | I           | 3-state output control input. TRI controls the 3-state control of all I/O and output terminals. When TRI is asserted, all I/Os and outputs are in the high-impedance state, allowing board level testers to drive the outputs without overdriving internal buffers. TRI is level sensitive and is pulled down with an internal resistor that is approximately 5 k $\Omega$ .            |
| TXRDY0<br>TXRDY1 | 22, 42        | 35, 58       | 0           | Transmitter ready. Two types of DMA signaling are available. Either can be selected using FCR3 when operating in FIFO mode. Only DMA mode 0 is allowed when in TL16C450 mode. Single-transfer DMA (a transfer is made between CPU bus cycles) is supported by mode 0. Multiple transfers that are made continuously until the transmitter FIFO has been filled are supported by mode 1. |
|                  |               |              |             | Mode 0. In FIFO mode (FCR0 = 1, FCR3 = 0) or in TL16C450 mode (FCR0 = 0) when there are no characters in the transmitter holding register or transmitter FIFO, TXRDYx is active (low). Once TXRDYx is activated (low), it goes inactive after the first character is loaded into the holding register of the transmitter FIFO.                                                          |
|                  |               |              |             | Mode 1. $\overline{\text{TXRDY}}$ goes active (low) in FIFO mode (FCR0 = 1) when FCR3 = 1 and there are no characters in the transmitter FIFO. When the transmitter FIFO is completely full, $\overline{\text{TXRDY}}$ goes inactive (high).                                                                                                                                            |
| V <sub>DD</sub>  | 23, 40,<br>64 | 6, 36,<br>56 |             | Power supply. The V <sub>DD</sub> requirement is 5 V $\pm$ 5%.                                                                                                                                                                                                                                                                                                                          |

### absolute maximum ratings over operating free-air temperature range (unless otherwise noted)<sup>†</sup>

| Supply voltage range, V <sub>DD</sub> (see Note 1)               | $-0.5 \text{ V to V}_{\text{DD}} + 0.3 \text{ V}$ |
|------------------------------------------------------------------|---------------------------------------------------|
| Input voltage range, V <sub>1</sub>                              | 0.5 V to 7 V                                      |
| Output voltage range, V <sub>O</sub>                             | $-0.5 \text{ V to V}_{\text{DD}} + 0.3 \text{ V}$ |
| Continuous total power dissipation                               | See Dissipation Rating Table                      |
| Operating free-air temperature range, T <sub>A:</sub> : I suffix | –40°C to 85°C                                     |
| M suffix                                                         | –55°C to 125°C                                    |
| Storage temperature range, T <sub>stg</sub>                      | –65°C to 150°C                                    |

 Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
 NOTE 1: All voltage levels are with respect to GND.

#### DISSIDATION PATING TABLE+

|         | DISSIFATION RATING TABLET             |                                                 |                                       |                                        |  |  |  |  |  |  |
|---------|---------------------------------------|-------------------------------------------------|---------------------------------------|----------------------------------------|--|--|--|--|--|--|
| PACKAGE | $T_A \le 25^{\circ}C$<br>POWER RATING | DERATING FACTOR§<br>ABOVE T <sub>A</sub> = 25°C | T <sub>A</sub> = 70°C<br>POWER RATING | T <sub>A</sub> = 125°C<br>POWER RATING |  |  |  |  |  |  |
| FN      | 1730 mW                               | 19.2 mW/° C                                     | 865 mW                                | -                                      |  |  |  |  |  |  |
| HV      | 1689 mW                               | 13.5 mW/° C                                     | 1081 mW                               | 337 mW                                 |  |  |  |  |  |  |

<sup>‡</sup> Power ratings assume a maximum junction temperature (T<sub>J</sub>) of 115°C for 'I' and 150°C for 'M' suffix devices. § Derating factor is the inverse of the junction-to-ambient thermal resistance,  $R_{\theta,IA}$ .



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

#### recommended operating conditions

|                                          |          |       | MIN | NOM | MAX             | UNIT |
|------------------------------------------|----------|-------|-----|-----|-----------------|------|
| Supply voltage, V <sub>DD</sub>          |          |       |     | 5   | 5.25            | V    |
| Clock high-level input voltage, VIH(CLK) |          |       | 2   |     | V <sub>DD</sub> | V    |
| lock low-level input voltage, VIL(CLK)   |          |       | 0   |     | 0.8             | V    |
| High-level input voltage, VIH            |          |       | 2   |     | V <sub>DD</sub> | V    |
| Low-level input voltage, VIL             |          |       | 0   |     | 0.8             | V    |
| Clock frequency, f <sub>clock</sub>      |          |       |     |     | 16              | MHz  |
| Operating free-air temperature, TA       | I suf    | iffix | -40 |     | 85              | °C   |
|                                          | M suffix |       | -55 |     | 125             | C    |

#### package thermal characteristics

|                 | PARAMETER                             | TEST CONDITIONS            | FN  | Packag | je  | HV Package |     |     | UNIT |
|-----------------|---------------------------------------|----------------------------|-----|--------|-----|------------|-----|-----|------|
| PARAMETER       |                                       | TEST CONDITIONS            | MIN | TYP    | MAX | MIN        | TYP | MAX | UNIT |
| $R_{\theta JA}$ | Junction-to-ambient thermal impedance | Board mounted, no air flow |     | 52     |     |            | 74  |     | °C/W |
| $R_{\theta JC}$ | Junction-to-case thermal impedance    |                            |     | 14     |     |            | 3   |     | °C/W |
| Тј              | Junction temperature                  |                            |     |        | 115 |            |     | 150 | °C/W |

# electrical characteristics over recommended ranges of operating free-air temperature and supply voltage (unless otherwise noted)

|                 | PARAMETER                     | TEST CONDITIONS                                                                                                                                  | MIN | MAX | UNIT |
|-----------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|------|
| Vон             | High-level output voltage     | $I_{OH} = -12$ mA for PD0-PD7,<br>$I_{OH} = -4$ mA for all other outputs (see Note 2),                                                           | 2.4 |     | V    |
| V <sub>OL</sub> | Low-level output voltage      | $I_{OL} = 12 \text{ mA for PD0-PD7,}$<br>$I_{OL} = 12 \text{ mA for INIT, AFD, STB, and SLIN,}$<br>$I_{OL} = 4 \text{ mA for all other outputs}$ |     | 0.4 | V    |
| II              | Input current                 | V <sub>DD</sub> = 5.25 V (see Note 3),<br>All other terminals are floating                                                                       |     | ±10 | μΑ   |
| II(CLK)         | Clock input current           | V <sub>I</sub> = 0 to 5.25 V                                                                                                                     |     | ±10 | μΑ   |
| I <sub>OZ</sub> | High-impedance output current | $V_{DD}$ = 5.25 V, $V_{O}$ = 0 with chip deselected or $V_{O}$ = 5.25 V with chip and write mode selected (see Note 2)                           |     | ±20 | μA   |
| IDD             | Supply current                | $V_{DD} = 5.25 \text{ V},$ No loads on outputs,<br>Inputs at 0.8 V or 2 V, $f_{clock} = 8 \text{ MHz}$                                           |     | 50  | mA   |

NOTES: 2. Excluding INIT, AFD, STB, and SLIN. They are open-drain terminals with an internal pullup resistor to V<sub>DD</sub> of approximately 10 KΩ.
 3. Excluding the TRI input terminal. It contains an internal pulldown resistor of approximately 5 kΩ.

## clock timing requirements over recommended ranges of operating free-air temperature and supply voltage

| L |                                                                  | MIN  | MAX | UNIT |
|---|------------------------------------------------------------------|------|-----|------|
| t | w1 Pulse duration, CLK ↑ (external clock) (see Figure 1)         | 31   |     | ns   |
| t | Pulse duration, CLK $\downarrow$ (external clock) (see Figure 1) | 31   |     | ns   |
| t | w3 Pulse duration, RESET                                         | 1000 |     | ns   |



read cycle timing requirements over recommended ranges of operating free-air temperature and supply voltage (see Note 4 and Figure 4)

|                  |                                                                                                  | MIN | MAX | UNIT |
|------------------|--------------------------------------------------------------------------------------------------|-----|-----|------|
| t <sub>w4</sub>  | Pulse duration, $\overline{IOR}\downarrow$                                                       | 80  |     | ns   |
| t <sub>su1</sub> | Setup time, $\overline{\text{CSx}}$ valid before $\overline{\text{IOR}} \downarrow$ (see Note 5) | 15  |     | ns   |
| t <sub>su2</sub> | Setup time, A2–A0 valid before $\overline{\text{IOR}}\downarrow$ (see Note 5)                    | 15  |     | ns   |
| t <sub>h1</sub>  | Hold time, A2–A0 valid after $\overline{\text{IOR}}$ (see Note 5)                                | 20  |     | ns   |
| t <sub>h2</sub>  | Hold time, CSx valid after IOR ↑ (see Note 5)                                                    | 20  |     | ns   |
| <sup>t</sup> d1  | Delay time, t <sub>SU2</sub> + t <sub>W4</sub> + t <sub>d2</sub> (see Note 6)                    | 175 |     | ns   |
| t <sub>d2</sub>  | Delay time, $\overline{IOR}$ $\uparrow$ to $\overline{IOR}$ or $\overline{IOW}$ $\downarrow$     | 80  |     | ns   |

NOTES: 4. These parameters are not production tested.

5. The internal address strobe is always active.

 In FIFO mode, t<sub>d1</sub> = 425 ns (min) between reads of the receiver FIFO and the status registers (interrupt identification register and line status register).

# write cycle timing requirements over recommended ranges of operating free-air temperature and supply voltage (see Note 7 and Figure 5)

|                  |                                                                                                  | MIN | MAX | UNIT |
|------------------|--------------------------------------------------------------------------------------------------|-----|-----|------|
| t <sub>w5</sub>  | Pulse duration, $\overline{\text{IOW}}\downarrow$                                                | 80  |     | ns   |
| t <sub>su4</sub> | Setup time, $\overline{\text{CSx}}$ valid before $\overline{\text{IOW}} \downarrow$ (see Note 8) | 15  |     | ns   |
| t <sub>su5</sub> | Setup time, A2–A0 valid before $\overline{\text{IOW}} \downarrow$ (see Note 8)                   | 15  |     | ns   |
| t <sub>su6</sub> | Setup time, DB0−DB7 valid before IOW ↑                                                           | 15  |     | ns   |
| t <sub>h3</sub>  | Hold time, A2–A0 valid after $\overline{\text{IOW}}$ (see Note 8)                                | 20  |     | ns   |
| t <sub>h4</sub>  | Hold time, $\overline{\text{CSx}}$ valid after $\overline{\text{IOW}}$ (see Note 8)              | 20  |     | ns   |
| t <sub>h5</sub>  | Hold time, DB0−DB7 valid after IOW ↑                                                             | 15  |     | ns   |
| t <sub>d3</sub>  | Delay time, t <sub>su5</sub> + t <sub>w5</sub> + t <sub>d4</sub>                                 | 175 |     | ns   |
| t <sub>d4</sub>  | Delay time, $\overline{IOW}$ $\uparrow$ to $\overline{IOW}$ or $\overline{IOR}$ $\downarrow$     | 80  |     | ns   |

NOTES: 7. These parameters are not production tested.

8. The internal address strobe is always active.

# read cycle switching characteristics over recommended ranges of operating free-air temperature and supply voltage, $C_L = 100 \text{ pF}$ (see Note 9 and Figure 4)

|                  | PARAMETER                                                                                                                     | MIN | MAX | UNIT |
|------------------|-------------------------------------------------------------------------------------------------------------------------------|-----|-----|------|
| <sup>t</sup> pd1 | Propagation delay time from $\overline{IOR}\downarrow$ to BDO $\uparrow$ or from $\overline{IOR}\uparrow$ to BDO $\downarrow$ |     | 60  | ns   |
| ten              | Enable time from $\overline{\text{IOR}}\downarrow$ to DB0–DB7 valid (see Note 10)                                             |     | 60  | ns   |
| <sup>t</sup> dis | Disable time from $\overline{\text{IOR}}$ $\uparrow$ to DB0–DB7 released (see Note 10)                                        |     | 60  | ns   |

NOTES: 9. These parameters are not production tested.

10.  $V_{OL}$  and  $V_{OH}$  (and the external loading) determine the charge and discharge time.



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

# transmitter switching characteristics over recommended ranges of operating free-air temperature and supply voltage (see Note 11 and Figures 6, 7, and 8)

|                  | PARAMETER                                                                                               | TEST CONDITIONS                          | MIN | MAX | UNIT           |
|------------------|---------------------------------------------------------------------------------------------------------|------------------------------------------|-----|-----|----------------|
| td5              | Delay time, interrupt THRE $\downarrow$ to SOUT $\downarrow$ at start                                   | See Figure 6                             | 8   | 24  | RCLK<br>cycles |
| <sup>t</sup> d6  | Delay time, SOUT $\downarrow$ at start to interrupt THRE $\uparrow$                                     | See Note 12 and Figure 6                 | 8   | 9   | RCLK<br>cycles |
| td7              | Delay time, $\overline{\text{IOW}}$ (WR THR) $\uparrow$ to interrupt THRE $\uparrow$                    | See Note 12 and Figure 6                 | 16  | 32  | RCLK<br>cycles |
| t <sub>d8</sub>  | Delay time, SOUT $\downarrow$ at start to TXRDY $\downarrow$                                            | CL = 100 pF,<br>See Figures 7 and 8      |     | 8   | RCLK<br>cycles |
| t <sub>pd2</sub> | Propagation delay time from $\overline{	ext{IOW}}$ (WR THR) $\downarrow$ to interrupt THRE $\downarrow$ | C <sub>L</sub> = 100 pF,<br>See Figure 6 |     | 140 | ns             |
| t <sub>pd4</sub> | Propagation delay time from $\overline{IOR}$ (RD IIR) $\uparrow$ to interrupt THRE $\downarrow$         | C <sub>L</sub> = 100 pF,<br>See Figure 6 |     | 140 | ns             |
| <sup>t</sup> pd5 | Propagation delay time from $\overline{IOW}$ (WR THR) $\uparrow$ to $\overline{TXRDY}$ $\uparrow$       | CL = 100 pF,<br>See Figures 7 and 8      |     | 195 | ns             |

NOTES: 11. These parameters are not production tested.

12. When the transmitter interrupt delay is active, this delay is lengthened by one character time minus the last stop bit time.

# receiver switching characteristics over recommended ranges of operating free-air temperature and supply voltage (see Note 13 and Figures 9 through 13)

|                 | PARAMETER                                                                                                 | TEST CONDITIONS | MIN MAX | UNIT          |
|-----------------|-----------------------------------------------------------------------------------------------------------|-----------------|---------|---------------|
| t <sub>d9</sub> | Delay time from stop to INT $\uparrow$                                                                    | See Note 14     | 1       | RCLK<br>cycle |
| tpd6            | Propagation delay time from RCLK $\uparrow$ to sample CLK $\uparrow$                                      |                 | 100     | ns            |
| tpd7            | Propagation delay time from $\overline{IOR}$ (RD RBR/RD LSR) $\downarrow$ to reset interrupt $\downarrow$ | CL = 100 pF     | 150     | ns            |
| tpd8            | Propagation delay time from $\overline{IOR}$ (RD RBR) $\downarrow$ to $\overline{RXRDY}$ $\uparrow$       |                 | 150     | ns            |

NOTES: 13. These parameters are not production tested.

14. The receiver data available indicator, the overrun error indicator, the trigger level interrupts, and the active RXRDY indicator are delayed three RCLK cycles in FIFO mode (FCR0 = 1). After the first byte has been received, status indicators (PE, FE, BI) are delayed three RCLK cycles. These indicators are updated immediately for any further bytes received after RDRBR goes active. There are eight RCLK cycle delays for trigger change level interrupts.

# modem control switching characteristics over recommended ranges of operating free-air temperature and supply voltage, $C_L = 100 \text{ pF}$ (see Note 15 and Figure 14)

|                   | PARAMETER                                                                                                                      | MIN | MAX | UNIT |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------|-----|-----|------|
| tpd9              | Propagation delay time from $\overline{IOW}$ (WR MCR) $\uparrow$ to $\overline{RTS}$ ( $\overline{DTR}$ ) $\downarrow\uparrow$ |     | 100 | ns   |
| <sup>t</sup> pd10 | Propagation delay time from modem input ( $\overline{CTS}, \overline{DSR}$ ) $\downarrow\uparrow$ to interrupt $\uparrow$      |     | 170 | ns   |
| tpd11             | Propagation delay time from $\overline{IOR}$ (RD MSR) $\uparrow$ to interrupt $\downarrow$                                     |     | 140 | ns   |
| <sup>t</sup> pd12 | Propagation delay time from $\overline{RI}$ $\uparrow$ to interrupt $\uparrow$                                                 |     | 170 | ns   |

NOTE 15: These parameters are not production tested.



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

## parallel port timing requirements over recommended ranges of supply voltage and operating free-air temperature (see Note 16 and Figures 15, 16, and 17)

|                  |                                                                               | MIN          | MAX    | UNIT |
|------------------|-------------------------------------------------------------------------------|--------------|--------|------|
| t <sub>su7</sub> | Setup time, data valid before $\overline{STB}\downarrow$                      | 1            |        | μs   |
| t <sub>h6</sub>  | Hold time, data valid after $\overline{STB}$ $\uparrow$                       | 1            |        | μs   |
| t <sub>w6</sub>  | Pulse duration, $\overline{\text{STB}}\downarrow$                             | 1            |        | μs   |
| <sup>t</sup> d10 | Delay time, BUSY $\uparrow$ to $\overline{ACK}\downarrow$                     | Defined by p | rinter |      |
| <sup>t</sup> d11 | Delay time, BUSY $\downarrow$ to $\overline{ACK}\downarrow$                   | Defined by p | rinter |      |
| tw7              | Pulse duration, BUSY ↑                                                        | Defined by p | rinter |      |
| t <sub>w8</sub>  | Pulse duration, $\overline{ACK}\downarrow$                                    | Defined by p | rinter |      |
| <sup>t</sup> d12 | Delay time, BUSY ↑ after STB ↑                                                | Defined by p | rinter |      |
| <sup>t</sup> d13 | Delay time, INT2 $\downarrow$ after $\overline{ACK} \downarrow$ (see Note 17) |              | 22     | ns   |
| <sup>t</sup> d14 | Delay time, INT2 $\uparrow$ after $\overline{ACK}$ $\uparrow$ (see Note 17)   |              | 20     | ns   |
| <sup>t</sup> d15 | Delay time, INT2 $\uparrow$ after $\overline{ACK}$ $\uparrow$ (see Note 17)   |              | 24     | ns   |
| <sup>t</sup> d16 | Delay time, INT2 $\downarrow$ after $\overline{\text{IOR}}$ (see Note 17)     |              | 25     | ns   |

NOTES: 16. These parameters are not production tested.

17.  $t_{d13}-t_{d16}$  are all measured with a 15-pF load.

### PARAMETER MEASUREMENT INFORMATION



Figure 1. CLK Voltage Waveform





Figure 2. Output Load Circuit



SLLS189D – NOVEMBER 1994 – REVISED JANUARY 1999

## PARAMETER MEASUREMENT INFORMATION







Figure 4. Read Cycle Timing Waveforms



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999



PARAMETER MEASUREMENT INFORMATION



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999



#### PARAMETER MEASUREMENT INFORMATION

Figure 9. Receiver Timing Waveforms



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999



NOTE A: This is the reading of the last byte in the FIFO.





SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

### PARAMETER MEASUREMENT INFORMATION



NOTES: A. This is the reading of the last byte in the FIFO.

B. If FCR0 = 1,  $t_{d9}$  = 3 RCLK cycles. For a time-out interrupt,  $t_{d9}$  = 8 RCLK cycles.





NOTES: A. This is the reading of the last byte in the FIFO. B. If FCR0-1,  $t_{d9}$  = 3 RCLK cycles. For a trigger change level interrupt,  $t_{d9}$  = 8 RCLK.

#### Figure 13. Receiver Ready Mode 1 Waveforms



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999





Figure 15. Parallel Port Timing Waveforms



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

## PARAMETER MEASUREMENT INFORMATION









Figure 17. Parallel Port PS/2 Mode Timing (ENIRQ = High) Waveforms



Figure 18. RESET Voltage Waveform



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

## **PRINCIPLES OF OPERATION**

Three types of information are stored in the internal registers used in the ACE: control, status, and data. Mnemonic abbreviations for the internal registers are shown in Table 1.

| CONTROL                   | MNEMONIC | STATUS                | MNEMONIC | DATA                         | MNEMONIC |
|---------------------------|----------|-----------------------|----------|------------------------------|----------|
| Line control register     | LCR      | Line status register  | LSR      | Receiver buffer register     | RBR      |
| FIFO control register     | FCR      | Modem status register | MSR      | Transmitter holding register | THR      |
| Modem control register    | MCR      |                       |          |                              |          |
| Divisor latch LSB         | DLL      |                       |          |                              |          |
| Divisor latch MSB         | DLM      |                       |          |                              |          |
| Interrupt enable register | IER      |                       |          |                              |          |

The address, read, and write inputs are used with the divisor latch access bit (DLAB) in the line control register (bit 7) to select the register to be written to or read from (see Table 2). Individual bits within the registers are referred to by the register mnemonic and the bit number in parenthesis. As an example, LCR7 refers to line control register bit 7.

The transmitter holding register and receiver buffer register are data registers that hold from five to eight bits of data. If fewer than eight data bits are transmitted, data is right justified to the LSB. Bit 0 of a data word is always the first serial data bit received and transmitted. The ACE data registers are double buffered (TL16C450 mode) or FIFO buffered (FIFO mode) so that read and write operations can be performed when the ACE is performing the parallel-to-serial or serial-to-parallel conversion.

| DLAB | A2 | A1 | A0 | MNEMONIC | REGISTER                                      |
|------|----|----|----|----------|-----------------------------------------------|
| L    | L  | L  | L  | RBR      | Receiver buffer register (read only)          |
| L    | L  | L  | L  | THR      | Transmitter holding register (write only)     |
| L    | L  | L  | Н  | IER      | Interrupt enable register                     |
| Х    | L  | Н  | L  | IIR      | Interrupt identification register (read only) |
| х    | L  | Н  | L  | FCR      | FIFO control register (write only)            |
| Х    | L  | Н  | Н  | LCR      | Line control register                         |
| Х    | Н  | L  | L  | MCR      | Modem control register                        |
| Х    | Н  | L  | Н  | LSR      | Line status register                          |
| Х    | Н  | Н  | L  | MSR      | Modem status register                         |
| Х    | Н  | Н  | Н  | SCR      | Scratch pad register                          |
| н    | L  | L  | L  | DLL      | LSB divisor latch                             |
| H    | L  | L  | Н  | DLM      | MSB divisor latch                             |

#### Table 2. Register Selection<sup>†</sup>

<sup>†</sup> The serial channel is accessed when either  $\overline{CS0}$  or  $\overline{CS1}$  is low.

X = irrelevant, L = low level, H = high level



#### accessible registers

Using the CPU, the system programmer has access to and control over any of the ACE registers that are summarized in Table 1. These registers control ACE operations, receive data, and transmit data. Descriptions of these registers follow Table 3.

| ADDRESS | REGISTER            |                                           |                                |                                                       | REGISTER                       | BIT NUMBER                                             |                                                           |                                                                               |                                                                 |
|---------|---------------------|-------------------------------------------|--------------------------------|-------------------------------------------------------|--------------------------------|--------------------------------------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------|-----------------------------------------------------------------|
| ADDRE55 | MNEMONIC            | BIT 7                                     | BIT 6                          | BIT 5                                                 | BIT 4                          | BIT 3                                                  | BIT 2                                                     | BIT 1                                                                         | BIT 0                                                           |
| 0       | RBR<br>(read only)  | Data Bit 7<br>(MSB)                       | Data Bit 6                     | Data Bit 5                                            | Data Bit 4                     | Data Bit 3                                             | Data Bit 2                                                | Data Bit 1                                                                    | Data Bit 0<br>(LSB)                                             |
| 0       | THR<br>(write only) | Data<br>Bit 7                             | Data<br>Bit 6                  | Data<br>Bit 5                                         | Data<br>Bit 4                  | Data<br>Bit 3                                          | Data<br>Bit 2                                             | Data<br>Bit 1                                                                 | Data<br>Bit 0                                                   |
| 0†      | DLL                 | Bit 7                                     | Bit 6                          | Bit 5                                                 | Bit 4                          | Bit 3                                                  | Bit 2                                                     | Bit 1                                                                         | Bit 0                                                           |
| 1†      | DLM                 | Bit 15                                    | Bit 14                         | Bit 13                                                | Bit 12                         | Bit 11                                                 | Bit 10                                                    | Bit 9                                                                         | Bit 8                                                           |
| 1       | IER                 | 0                                         | 0                              | 0                                                     | 0                              | (EDSSI) Enable<br>modem status<br>interrupt            | (ERLSI)<br>Enable<br>receiver line<br>status<br>interrupt | (ETBEI)<br>Enable<br>transmitter<br>holding<br>register<br>empty<br>interrupt | (ERBFI)<br>Enable<br>received<br>data<br>available<br>interrupt |
| 2       | FCR<br>(write only) | Receiver<br>trigger (MSB)                 | Receiver<br>trigger (LSB)      | Reserved                                              | Reserved                       | DMA<br>mode select                                     | Transmitter<br>FIFO reset                                 | Receiver<br>FIFO reset                                                        | FIFO<br>enable                                                  |
| 2       | IIR<br>(read only)  | FIFOs<br>enabled <sup>‡</sup>             | FIFOs<br>enabled <sup>‡</sup>  | 0                                                     | 0                              | Interrupt ID<br>bit 3 <sup>‡</sup>                     | Interrupt ID<br>bit 2                                     | Interrupt ID<br>bit 1                                                         | 0 if<br>interrupt<br>pending                                    |
| 3       | LCR                 | (DLAB)<br>Divisor latch<br>access bit     | Set<br>break                   | Stick<br>parity                                       | (EPS)<br>Even parity<br>select | (PEN)<br>Parity enable                                 | (STB)<br>Number of<br>stop bits                           | (WLSB1)<br>Word length<br>select bit 1                                        | (WLSB0)<br>Word length<br>select bit 0                          |
| 4       | MCR                 | 0                                         | 0                              | 0                                                     | Loop                           | OUT2 Enable<br>external<br>interrupt<br>(INT0 or INT1) | OUT1<br>(an unused<br>internal<br>signal)                 | (RTS)<br>Request<br>to send                                                   | (DTR)<br>Data<br>terminal<br>ready                              |
| 5       | LSR                 | Error in<br>receiver<br>FIFO <sup>‡</sup> | (TEMT)<br>Transmitter<br>empty | (THRE)<br>Transmitter<br>holding<br>register<br>empty | (BI)<br>Break<br>interrupt     | (FE)<br>Framing<br>error                               | (PE)<br>Parity<br>error                                   | (OE)<br>Overrun<br>error                                                      | (DR)<br>Data<br>ready                                           |
| 6       | MSR                 | (DCD)<br>Data carrier<br>detect           | (RI)<br>Ring<br>indicator      | (DSR)<br>Data set<br>ready                            | (CTS)<br>Clear<br>to send      | (∆ DCD)<br>Delta data<br>carrier detect                | (TERI)<br>Trailing edge<br>ring indicator                 | (∆DSR)<br>Delta data<br>set ready                                             | (∆CTS)<br>Delta clear<br>clear to send                          |
| 7       | SCR                 | Bit 7                                     | Bit 6                          | Bit 5                                                 | Bit 4                          | Bit 3                                                  | Bit 2                                                     | Bit 1                                                                         | Bit 0                                                           |

#### **Table 3. Summary of Accessible Registers**

† DLAB = 1

<sup>‡</sup> These bits are always 0 when FIFOs are disabled.



### FIFO control register (FCR)

This write-only register is at the same location as the interrupt identification register. It enables and clears the FIFOs, sets the trigger level of the receiver FIFO, and selects the type of DMA signaling.

- Bit 0: FCR0 enables both the transmitter and receiver FIFOs. All bytes in both FIFOs can be cleared by clearing FCR0. Data is cleared automatically from the FIFOs when changing from the FIFO mode to the TL16C450 mode and vice versa. Programming of other FCR bits is enabled by setting FCR0.
- Bit 1: When set, FCR1 clears all bytes in the receiver FIFO and resets the counter. This does not clear the shift register.
- Bit 2: When set, FCR2 clears all bytes in the transmitter FIFO and resets the counter. This does not clear the shift register.
- Bit 3: When set, FCR3 changes the RXRDY and TXRDY terminals from mode 0 to mode 1 when FCR0 is set.
- Bits 4 and 5: FCR4 and FCR5 are reserved for future use.
- Bits 6 and 7: FCR6 and FCR7 set the trigger level for the receiver FIFO interrupt (see Table 4).

| Table 4. Receiver FIFO Trigger Level |    |                       |  |  |  |
|--------------------------------------|----|-----------------------|--|--|--|
| В                                    | IT | RECEIVER FIFO         |  |  |  |
| 7 6                                  |    | TRIGGER LEVEL (BYTES) |  |  |  |

| В | IT | RECEIVER FIFO         |
|---|----|-----------------------|
| 7 | 6  | TRIGGER LEVEL (BYTES) |
| 0 | 0  | 01                    |
| 0 | 1  | 04                    |
| 1 | 0  | 08                    |
| 1 | 1  | 14                    |

#### FIFO interrupt mode operation

The following receiver status occurs when the receiver FIFO and receiver interrupts are enabled:

- 1. LSR0 is set when a character is transferred from the shift register to the receiver FIFO. When the FIFO is empty, it is reset.
- 2. IIR = 06 receiver line status interrupt has higher priority than the received data available interrupt IIR = 04.
- 3. Receive data available interrupt is issued to the CPU when the programmed trigger level is reached by the FIFO. When the FIFO drops below its programmed trigger level, it is cleared.
- 4. IIR = 04 (receive data available indicator) also occurs when the FIFO reaches its trigger level. It is cleared when the FIFO drops below the programmed trigger level.

The following receiver FIFO character time-out status occurs when receiver FIFO and receiver interrupts are enabled.



#### FIFO interrupt mode operation (continued)

- 1. When the following conditions exist, a FIFO character time-out interrupt occurs:
  - a. Minimum of one character in FIFO
  - b. The last received serial character is longer than four previous continuous-character times (if two stop bits are programmed, the second one is included in the time delay).
  - c. The last CPU read of the FIFO is more than four previous continuous-character times. At 300 baud and 12-bit characters, the FIFO time-out interrupt causes a latency of 160 ms maximum from received character to interrupt issued.
- 2. By using the RCLK input for a clock signal, the character times can be calculated. The delay is proportional to the baud rate.
- 3. The time-out timer is reset after the CPU reads the receiver FIFO or after a new character is received when there has been no time-out interrupt.
- 4. A time-out interrupt is cleared and the timer is reset when the CPU reads a character from the receiver FIFO.

Transmitter interrupts occur as follows when the transmitter and transmitter FIFO interrupts are enabled (FCR0 = 1, IER = 1).

- 1. When the transmitter FIFO is empty, the transmitter holding register interrupt (IIR = 02) occurs. The interrupt is cleared when the transmitter holding register is written to or the IIR is read. One to sixteen characters can be written to the transmit FIFO when servicing this interrupt.
- 2. The transmitter FIFO empty indicators are delayed one character time minus the last stop bit time when the following occurs:

THRE = 1 and there is not a minimum of two bytes at the same time in transmitter FIFO since the last THRE = 1. The first transmitter interrupt after changing FCR0 is immediate, assuming it is enabled.

Receiver FIFO trigger level and character time-out interrupts have the same priority as the received data available interrupt. The transmitter holding register empty interrupt has the same priority as the transmitter FIFO empty interrupt.

#### FIFO polled mode operation

Clearing IER0, IER1, IER2, IER3, or all with FCR0 = 1 puts the ACE into the FIFO polled mode. The receiver and transmitter are controlled separately. Either one or both can be in the polled mode.

In the FIFO polled mode, there is no time-out condition indicated or trigger level reached. However, the receiver and transmitter FIFOs still have the capability of holding characters. The LSR must be read to determine the ACE status.

#### interrupt enable register (IER)

The IER independently enables the four serial channel interrupt sources that activate the interrupt (INT0 or INT1) output. All interrupts are disabled by clearing IER0 – IER3. Interrupts are enabled by setting the appropriate bits of the IER. Disabling the interrupt system inhibits the interrupt identification register and the active (high) interrupt output. All other system functions operate in their normal manner, including the setting of the LSRs and MSRs. The contents of the IER shown in Table 3 are described in the following bulleted list.

 Bit 0: When IER0 is set, IER0 enables the received data available interrupt and the time-out interrupts in the FIFO mode.



#### interrupt enable register (IER) (continued)

- Bit 1: When IER1 is set, the transmitter holding register empty interrupt is enabled.
- Bit 2: When IER2 is set, the receiver line status interrupt is enabled.
- Bit 3: When IER3 is set, the modem status interrupt is enabled.
- Bits 4 7: IER4 through IER7 are cleared.

In order to minimize software overhead during data character transfers, the serial channel prioritizes interrupts into four levels. The four levels of interrupt conditions are as follows:

- Priority 1 Receiver line status (highest priority)
- Priority 2 Receiver data ready or receiver character time out
- Priority 3 Transmitter holding register empty
- Priority 4–Modem status (lowest priority)

Information indicating that a prioritized interrupt is pending and the type of interrupt is stored in the IIR. The IIR indicates the highest priority interrupt pending. The contents of the IIR are indicated in Table 5.

| INTERRUPT<br>IDENTIFICATION<br>REGISTER |       |       |       | INTERRUPT SET AND RESET FUNCTIONS |                              |                                                                                                                                                                              |                                                             |  |  |
|-----------------------------------------|-------|-------|-------|-----------------------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|--|--|
| BIT 3                                   | BIT 2 | BIT 1 | BIT 0 | PRIORITY<br>LEVEL                 | INTERRUPT TYPE               | INTERRUPT SOURCE                                                                                                                                                             | INTERRUPT RESET<br>CONTROL                                  |  |  |
| 0                                       | 0     | 0     | 1     | None                              | None                         | None                                                                                                                                                                         | None                                                        |  |  |
| 0                                       | 1     | 1     | 0     | First                             | Receiver line status         | OE, PE, FE, or BI                                                                                                                                                            | LSR read                                                    |  |  |
| 0                                       | 1     | 0     | 0     | Second                            | Received data available      | Receiver data available or trigger level reached                                                                                                                             | RBR read until FIFO<br>drops below the<br>trigger level     |  |  |
| 1                                       | 1     | 0     | 0     | Second                            | Character time-out indicator | No characters have been removed from or<br>input to the receiver FIFO during the last<br>four character times and there is at least<br>one character in it during this time. | RBR read                                                    |  |  |
| 0                                       | 0     | 1     | 0     | Third                             | THRE                         | THRE                                                                                                                                                                         | IIR read if THRE is<br>the interrupt source<br>or THR write |  |  |
| 0                                       | 0     | 0     | 0     | Fourth                            | Modem status                 | CTS, DSR, RI, or DCD                                                                                                                                                         | MSR read                                                    |  |  |

#### **Table 5. Interrupt Control Functions**

- Bit 0: IIR0 indicates whether an interrupt is pending. When IIR0 is cleared, an interrupt is pending.
- Bits 1 and 2: IIR1 and IIR2 identify the highest priority interrupt pending, as indicated in Table 5.
- Bit 3: IIR3 is always cleared in TL16C450 mode. This bit is set along with bit 2 in FIFO mode and when a trigger change level interrupt is pending.
- Bits 4 and 5: IIR4 and IIR5 are always cleared.
- Bits 6 and 7: IIR6 and IIR7 are set when FCR0 = 1.



### line control register (LCR)

The format of the data character is controlled by the LCR. The LCR can be read. Its contents are described in the following bulleted list and shown in Figure 19.

- Bits 0 and 1: LCR0 and LCR1 are the word length select bits. The number of bits in each serial character is programmed as shown.
- Bit 2: LCR2 is the stop bit select bit. LCR2 specifies the number of stop bits in each transmitted character. The receiver always checks for one stop bit.
- Bit 3: LCR3 is the parity enable bit. When LCR3 is set, a parity bit between the last data word bit and stop bit is generated and checked.
- Bit 4: LCR4 is the even parity select bit. When LCR4 is set, even parity is enabled.
- Bit 5: LCR5 is the stick parity bit. When parity is enabled (LCR3 = 1), LCR5 = 1 causes the transmission and reception of a parity bit to be in the opposite state from the value of LCR4. This forces parity to a known state and allows the receiver to check the parity bit in a known state.
- Bit 6: LCR6 is the break control bit. When LCR6 is set, the serial output (SOUT1/SOUT0) is forced to the spacing state (low). The break control bit acts only on the serial output and does not affect the transmitter logic. When the following sequence is used, no invalid characters are transmitted because of the break:

Step 1: Load a zero byte in response to the transmitter holding register empty (THRE) status indicator.

Step 2: Set the break in response to the next THRE status indicator.

- Step 3: Wait for the transmitter to be idle when transmitter empty status signal is set high (TEMT = 1); then clear the break when the normal transmission has to be restored.
- Bit 7: LCR7 is the divisor latch access bit (DLAB) bit. LCR7 must be set to access the divisor latches DLL and DLM of the baud rate generator during a read or write operation. LCR7 must be cleared to access the receiver buffer register, the transmitter holding register, or the interrupt enable register.



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

## **PRINCIPLES OF OPERATION**

### line control register (LCR) (continued)



Figure 19. Line Control Register Contents

#### line printer port

The line printer port contains the functionality of the port included in the TL16C452 but offers a hardware programmable extended mode controlled by the printer enhancement mode (PE) terminal. This enhancement is the addition of a direction control bit and an interrupt status bit.

#### register 0 line printer data register

The line printer (LPT) port is either output only or bidirectional depending on the state of the extended mode terminal and data direction control bits.

Compatibility mode (PEMD = L)

Reads to the LPT data register and returns the last data that was written to the port. Write operations immediately output data to PD0-PD7.

#### Extended mode (PEMD = H)

Read operations return either the data last written to the LPT data register when the direction bit is cleared or return the data that is present on PD0 – PD7 when the direction is set to read. Write operations to the LPT data register latch data into the output register; however, they only drive the LPT port when the direction bit is cleared.



#### line printer port (continued)

Table 6 summarizes the configuration of the PD port based on the combinations of the logic level on the PEMD terminal and the value of the direction control bit (DIR).

#### Table 6. Extended Mode and Direction Control Bit Combinations

| PEMD | DIR | PD0-PD7 FUNCTION    |
|------|-----|---------------------|
| L    | Х   | PC/AT mode – output |
| Н    | 0   | PS/2 mode – output  |
| Н    | 1   | PS/2 mode – input   |

#### register 1 read line printer status register

The line printer status (LPS) register is a read-only register that contains interrupt and printer status of the LPT connector terminals. Table 7 (in the default column) shows the values of each bit after reset in the case of the printer being disconnected from the port.

| BIT | DESCRIPTION | DEFAULT |
|-----|-------------|---------|
| 0   | Reserved    | 1       |
| 1   | Reserved    | 1       |
| 2   | PRINT       | 1       |
| 3   | ERR         | †       |
| 4   | SLCT        | †       |
| 5   | PE          | †       |
| 6   | ACK         | †       |
| 7   | BSY         | †       |
| 1   |             |         |

Table 7. LPS Register Bit Description

<sup>†</sup> Outputs are dependent upon device inputs.

- Bits 0 and 1: LPS0 and LPS1 are reserved and always set.
- Bit 2: LPS2 is the printer interrupt (PRINT, active low) status bit. When cleared, LPS2 indicates that the printer has acknowledged the previous transfer with an ACK handshake (if bit 4 of the control register is set). The bit is cleared on the active-to-inactive transition of the ACK signal. This bit is set after a read of the status port.
- Bit 3: ERR is the error status bit and corresponds to ERR input.
- Bit 4: SLCT is the select status bit and corresponds to SLCT input.
- Bit 5: PE is the paper empty status bit and corresponds to PE input.
- Bit 6: ACK is the acknowledge status bit corresponds to ACK input.
- Bit 7: BSY is the busy status bit and corresponds to BUSY input (active high).



#### TL16C552A, TL16C552AM DUAL ASYNCHRONOUS COMMUNICATIONS ELEMENT WITH FIFO SLLS189D – NOVEMBER 1994 – REVISED JANUARY 1999

PRINCIPLES OF OPERATION

#### register 2 line printer control register

The line printer control (LPC) register is a read/write port that controls the PD0–PD7 direction and drives the printer control lines. Write operations set or clear these bits, whereas read operations return the state of the last write operation to this register. The bits in this register are defined in Table 8 and the following bulleted list.

| Table 8. L | PC Register Bit | Description |
|------------|-----------------|-------------|
|------------|-----------------|-------------|

| BIT | DESCRIPTION |
|-----|-------------|
| 0   | STB         |
| 1   | AFD         |
| 2   | INIT        |
| 3   | SLIN        |
| 4   | INT2 EN     |
| 5   | DIR         |
| 6   | Reserved 0  |
| 7   | Reserved 0  |

- Bit 0: STB is the printer strobe control bit. When STB is set, the STB signal is asserted on the LPT interface. When STB is cleared, the STB signal is negated.
- Bit 1: AFD is the autofeed control bit. When AFD is set, the AFD signal is asserted on the LPT interface. When AFD is cleared, the signal is negated.
- Bit 2: INIT is the initialize printer control bit. When INIT is set, the INIT signal is negated. When INIT is cleared, the INIT signal is asserted on the LPT interface.
- Bit 3: SLIN is the select input control bit. When SLIN is set, the SLIN signal is asserted on the LPT interface. When SLIN is cleared, the signal is negated.
- Bit 4: INT2 EN is the interrupt request enable control bit. When set, INT2 EN enables interrupts from the LPT port. When cleared, INT2 EN disables interrupts and places INT2 signal in the high-impedance state.
- Bit 5: DIR is the direction control bit which is only used when PEMD is high. When DIR is set, the output buffers in the LPD port are disableded to allow data driven from external sources to be read from the LPD port. When DIR is cleared, the LPD port is in the output mode.
- Bits 6 and 7: These bits are reserved and are always cleared.



### line status register (LSR)

The LSR is a single register that provides status indicators. The LSR bits shown in Table 9 are described in the following bulleted list.

- Bit 0: DR is the data ready bit. When set, an incoming character is received and transferred into the receiver buffer register or in the FIFO. LSR0 is cleared by a CPU read of the data in the receiver buffer register or in the FIFO.
- Bit 1: OE is the overrun error bit. An OE indicates that data in the receiver buffer register is not read by the CPU before the next character is transferred into the receiver buffer register overwriting the previous character. The OE indicator is cleared whenever the CPU reads the contents of the LSR. An overrun error occurs in FIFO mode after the FIFO is full and the next character is completely received. The overrun error is detected by the CPU on the first LSR read after it happens. The character in the shift register is not transferred to the FIFO, but it is overwritten.
- Bit 2: PE is the parity error bit. A PE indicates that the received data character does not have the correct
  parity as selected by LCR3 and LCR4. The PE bit is set upon detection of a parity error and is cleared when
  the CPU reads the contents of the LSR. In FIFO mode, the parity error is associated with a particular
  character in the FIFO. LSR2 reflects the error when the character is at the top of the FIFO.
- Bit 3: FE is the framing error bit. An FE indicates that the received character does not have a valid stop bit. LSR3 is set when the stop bit following the last data bit or parity bit is detected as a zero bit (spacing level). The FE indicator is cleared when the CPU reads the contents of the LSR. In FIFO mode, the framing error is associated with a particular character in the FIFO. LSR3 reflects the error when the character is at the top of the FIFO.
- Bit 4: BI is the break interrupt bit. BI is set when the received data input is held in the spacing (low) state for longer than a full word transmission time (start bit + data bits + parity + stop bits). The BI indicator is cleared when the CPU reads the contents of the LSR. In FIFO mode, this is associated with a particular character in the FIFO. LSR4 reflects BI when the break character is at the top of the FIFO. The error is detected by the CPU when its associated character is at the top of the FIFO during the first LSR read. Only one zero character is loaded into the FIFO when BI occurs.

LSR1 – LSR4 are the error conditions that produce a receiver line status interrupt (priority 1 interrupt in the interrupt identification register) when any of the conditions are detected. This interrupt is enabled by setting IER2 in the interrupt enable register.

- Bit 5: THRE is the transmitter holding register empty bit. THRE indicates that the ACE is ready to accept a new character for transmission. The THRE bit is set when a character is transferred from the transmitter holding register into the transmitter shift register. LSR5 is cleared by the loading of the transmitter holding register by the CPU. LSR5 is not cleared by a CPU read of the LSR. In FIFO mode when the transmitter FIFO is empty, this bit is set. It is cleared when one byte is written to the transmitter FIFO. When the THRE interrupt is enabled by IER1, THRE causes a priority 3 interrupt in the IIR. If THRE is the interrupt source indicated in IIR, INTRPT is cleared by a read of the IIR.
- Bit 6: TEMT is the transmitter empty bit. TEMT is set when the transmitter holding register (THR) and the transmitter shift register are both empty. LSR6 is cleared when a character is loaded into the THR and remains cleared until the character is transferred out of SOUT. TEMT is not cleared by a CPU read of the LSR. In FIFO mode, when both the transmitter FIFO and shift register are empty, TEMT is set.
- Bit 7: LSR7 is the receiver FIFO error bit. The LSR7 bit is always cleared in TL16C450 mode. In FIFO mode, it is set when at least one of the following data errors occurs in the FIFO: parity error, framing error, or break interrupt indicator. It is cleared when the CPU reads the LSR if there are no subsequent errors in the FIFO.



### line status register (LSR) (continued)

NOTE:

The LSR may be written to. However, this function is intended only for factory test. It should be considered as read only by applications software.

| LSR BITS                                       | 1             | 0                |
|------------------------------------------------|---------------|------------------|
| LSR0 data ready (DR)                           | Ready         | Not ready        |
| LSR1 overrun error (OE)                        | Error         | No error         |
| LSR2 parity error (PE)                         | Error         | No error         |
| LSR3 framing error (FE)                        | Error         | No error         |
| LSR4 break interrupt (BI)                      | Break         | No break         |
| LSR5 transmitter holding register empty (THRE) | Empty         | Not empty        |
| LSR6 transmitter empty (TEMT)                  | Empty         | Not empty        |
| LSR7 receiver FIFO error                       | Error in FIFO | No error in FIFO |

#### Table 9. Line Status Register Bits

#### master reset

After power up, the ACE RESET input should be held low for one microsecond to reset the ACE circuits to an idle mode until initialization. A low on RESET causes the following:

- It initializes the transmitter and receiver clock counters.
- It clears the LSR except for transmitter shift register empty (TEMT) and transmit holding register empty (THRE), which are set. The MCR is also cleared. All of the discrete lines, memory elements, and miscellaneous logic associated with these register bits are also cleared or turned off. The LCR, divisor latches, receiver buffer register, and transmitter holding buffer register are not affected.

Following the removal of the reset condition (RESET high), the ACE remains in idle mode until programmed. A hardware reset of the ACE sets the THRE and TEMT status bit in the LSR. When interrupts are subsequently enabled, an interrupt occurs due to THRE. A summary of the effect of a reset on the ACE is given in Table 10.



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

## **PRINCIPLES OF OPERATION**

## master reset (continued)

| REGISTER/SIGNAL                   | RESET CONTROL            | RESET                                                                                     |
|-----------------------------------|--------------------------|-------------------------------------------------------------------------------------------|
| Interrupt enable register         | Reset                    | All bits cleared (0-3 forced and 4-7 permanent)                                           |
| Interrupt identification register | Reset                    | Bit 0 is set, bits 1, 2, 3, 6, and 7 are cleared, and bits $4-5$ are permanently cleared. |
| Line control register             | Reset                    | All bits are cleared.                                                                     |
| Modem control register            | Reset                    | All bits are cleared (5–7 permanently).                                                   |
| FIFO control register             | Reset                    | All bits are cleared.                                                                     |
| Line status register              | Reset                    | All bits are cleared, except bits 5 and 6 are set.                                        |
| Modem status register             | Reset                    | Bits 0-3 are cleared, bits 4-7 input signal.                                              |
| SOUT                              | Reset                    | High                                                                                      |
| Interrupt (RCVR errors)           | Read LSR/Reset           | Low                                                                                       |
| Interrupt (receiver data ready)   | Read RBR/Reset           | Low                                                                                       |
| Interrupt (THRE)                  | Read IIR/Write THR/Reset | Low                                                                                       |
| Interrupt (modem status changes)  | Read MSR/Reset           | Low                                                                                       |
| OUT2                              | Reset                    | High                                                                                      |
| RTS                               | Reset                    | High                                                                                      |
| DTR                               | Reset                    | High                                                                                      |
| OUT1                              | Reset                    | High                                                                                      |

#### Table 10. RESET Effects on Registers and Signals

#### modem control register (MCR)

The MCR controls the interface with the modem or data set as described in Figure 20. MCR can be written to and read from. The RTS and DTR outputs are directly controlled by their control bits in this register. A high input asserts a low signal (active) at the output terminals. The MCR bits are defined in the following bulleted list.

- Bit 0: When MCR0 is set, the DTR output is forced low. When MCR0 is cleared, the DTR output is forced high. The DTR output of the serial channel can be input into an inverting line driver in order to obtain the proper polarity input at the modem or data set.
- Bit 1: When MCR1 is set, the RTS output is forced low. When MCR1 is cleared, the RTS output is forced high. The RTS output of the serial channel can be input into an inverting line driver to obtain the proper polarity input at the modem or data set.
- Bit 2: MCR2 has no effect on operation.
- Bit 3: When MCR3 is set, the external serial channel interrupt is enabled.
- Bit 4: MCR4 provides a local loopback feature for diagnostic testing of the channel. When MCR4 is set, SOUT is set to the marking (high) state and the SIN is disconnected. The output of the transmitter shift register is looped back into the receiver shift register input. The four modem control inputs (CTS, DSR, DCD, and RI) are disconnected. The modem control outputs (DTR, RTS, OUT1, and OUT2) are internally connected to the four modem control inputs. The modem control output terminals are forced to their inactive (high) state on the TL16C552A. In the diagnostic mode, data transmitted is immediately received. This allows the processor to verify the transmit and receive data paths of the selected serial channel. Interrupt control is fully operational; however, interrupts are generated by controlling the lower four MCR bits internally. Interrupts are not generated by activity on the external terminals represented by those four bits.



### modem control register (MCR) (continued)

• Bits 5 – 7: MCR5 – MCR7 are permanently cleared.



Figure 20. Modem Control Register Contents

#### modem status register (MSR)

The MSR provides the CPU with status of the modem input lines from the modem or peripheral devices. The MSR allows the CPU to read the serial channel modem signal inputs. This is done by accessing the data bus interface of the ACE in addition to the current status of four bits of the MSR. These four bits indicate whether the modem inputs have changed since the last reading of the MSR. The delta status bits are set when a control input from the modem changes state and are cleared when the CPU reads the MSR.

The modem input lines are CTS, DSR, RI, and DCD. MSR4 – MSR7 are status indicators of these lines. A set status bit indicates that the input is low. A cleared status bit indicates that the input is high. When the modem status interrupt in the interrupt enable register is enabled (IER3), an interrupt is generated whenever MSR0 – MSR3 is set. The MSR is a priority-4 interrupt. The contents of the MSR are described in Table 11.

- Bit 0: MSR0 is the delta clear-to-send (△CTS) bit. △CTS displays that the CTS input to the serial channel has changed states since it was last read by the CPU.
- Bit 1: MSR1 is the delta data set ready ( $\Delta$ DSR) bit.  $\Delta$ DSR indicates that the DSR input to the serial channel has changed states since the last time it was read by the CPU.
- Bit 2: MSR2 is the trailing edge of the ring indicator (TERI) bit. TERI indicates that the RI input to the serial channel has changed states from low to high since the last time it was read by the CPU. High-to-low transitions on RI do not activate TERI.



#### modem status register (MSR) (continued)

- Bit 3: MSR3 is the delta data carrier detect (ΔDCD) bit. ΔDCD indicates that the DCD input to the serial channel has changed states since the last time it was read by the CPU.
- Bit 4: MSR4 is the clear-to-send (CTS) bit. CTS is the complement of the CTS input from the modem that indicates to the serial channel that the modem is ready to receive data from SOUT. When the serial channel is in the loop mode (MCR4 is set), MSR4 reflects the value of RTS in the MCR.
- Bit 5: MSR5 is the data set ready (DSR) bit. DSR is the complement of the DSR input from the modem to the serial channel that indicates that the modem is ready to provide received data to the serial channel receiver circuitry. When the channel is in loop mode (MCR4 is set), MSR5 reflects the value of DTR in the MCR.
- Bit 6: MSR6 is the ring indicator (RI) bit. RI is the complement of the RI input. When the channel is in loop mode (MCR4 is set), MSR6 reflects the value of OUT1 in the MCR.
- Bit 7: MSR7 is the data carrier detect (DCD) bit. Data carrier detect indicates the status of the data carrier detect (DCD) input. When the channel is in loop mode (MCR4 is set), MSR7 reflects the value of OUT2 in the MCR.

Reading the MSR register clears the delta modem status indicators but has no effect on the other status bits. For LSR and MSR, the setting of status bits is inhibited during status register read operations. If a status condition is generated during a read IOR operation, the status bit is not set until the trailing edge of the read. When a status bit is set during a read operation and the same status condition occurs, that status bit is cleared at the trailing edge of the read instead of being set again. In loop back mode, when modem status interrupts are enabled, the CTS, DSR, RI and DCD input terminals are ignored; however, a modem status interrupt can still be generated by writing to MCR3–MCR0. Applications software should not write to the MSR.

| MSR BIT | MNEMONIC | DESCRIPTION                     |
|---------|----------|---------------------------------|
| MSR0    | ∆CTS     | Delta clear to send             |
| MSR1    | ∆DSR     | Delta data set ready            |
| MSR2    | TERI     | Trailing edge of ring indicator |
| MSR3    | ΔDCD     | Delta data carrier detect       |
| MSR4    | CTS      | Clear to send                   |
| MSR5    | DSR      | Data set ready                  |
| MSR6    | RI       | Ring indicator                  |
| MSR7    | DCD      | Data carrier detect             |

Table 11. Modem Status Register Bits



#### parallel port registers

The TL16C552A parallel port can connect the device to a Centronic-style printer interface. When chip select 2  $\overline{(CS2)}$  is low, the parallel port is selected. Table 12 shows the registers associated with this parallel port. The read or write function of the register is controlled by the state of the read ( $\overline{IOR}$ ) and write ( $\overline{IOW}$ ) terminals as shown. The read data register allows the microprocessor to read the information on the parallel bus.

The read status register allows the microprocessor to read the status of the printer in the six most significant bits. The status bits are printer busy BSY, acknowledge (ACK) (a handshake function), paper empty (PE), printer selected (SLCT), error (ERR), and printer interrupt (PRINT). The read control register allows the state of the control lines to be read. The write control register sets the state of the control lines. They are direction (DIR), interrupt enable (INT2 EN), select in (SLIN), initialize the printer (INIT), autofeed the paper (AFD), and strobe (STB), which informs the printer of the presence of a valid byte on the parallel bus. The write data register allows the microprocessor to write a byte to the parallel bus. The parallel port is completely compatible with the parallel port implementation used in the IBM serial parallel adapter.

| REGISTER      | REGISTER BITS |       |            |         |       |       |       |       |
|---------------|---------------|-------|------------|---------|-------|-------|-------|-------|
| REGISTER      | BIT 7         | BIT 6 | BIT 5      | BIT 4   | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
| Read data     | PD7           | PD6   | PD5        | PD4     | PD3   | PD2   | PD1   | PD0   |
| Read status   | BSY           | ACK   | PE         | SLCT    | ERR   | PRINT | 1     | 1     |
| Read control  | 0             | 0     | PEMD • DIR | INT2 EN | SLIN  | INIT  | AFD   | STB   |
| Write data    | PD7           | PD6   | PD5        | PD4     | PD3   | PD2   | PD1   | PD0   |
| Write control | 0             | 0     | DIR        | INT2 EN | SLIN  | INIT  | AFD   | STB   |

| Table 12. Parallel Port Registers | Table 12 | 2. Paralle | I Port Re | gisters |
|-----------------------------------|----------|------------|-----------|---------|
|-----------------------------------|----------|------------|-----------|---------|

|     | СО  | REGISTER SELECTED |    |    |                   |
|-----|-----|-------------------|----|----|-------------------|
| IOR | IOW | CS2               | A1 | A0 | REGISTER SELECTED |
| L   | Н   | L                 | L  | L  | Read data         |
| L   | Н   | L                 | L  | Н  | Read status       |
| L   | Н   | L                 | Н  | L  | Read control      |
| L   | Н   | L                 | Н  | Н  | Invalid           |
| Н   | L   | L                 | L  | L  | Write data        |
| Н   | L   | L                 | L  | Н  | Invalid           |
| Н   | L   | L                 | Н  | L  | Write control     |
| Н   | L   | L                 | Н  | Н  | Invalid           |

#### Table 13. Parallel Port Register Select

#### programmable baud rate generator

The ACE serial channel contains a programmable baud rate generator (BRG) that divides the clock (dc to 8 MHz) by any divisor from 1 to  $(2^{16}-1)$ . The output frequency of the baud generator is 16x the data rate [divisor # = clock ÷ (baud rate x 16)], referred to in this document as RCLK. Two 8-bit divisor latch registers store the divisor in a 16-bit binary format. These divisor latch registers must be loaded during initialization. Upon loading either of the divisor latches, a 16-bit baud counter is immediately loaded. This prevents long counts on initial load. The BRG can use any of three different popular frequencies to provide standard baud rates. These frequencies are 1.8432 MHz, 3.072 MHz, and 8 MHz. With these frequencies, standard bit rates from 50 to 512 kbps are available. Tables 14, 15, 16, and 17 illustrate the divisors needed to obtain standard rates using these three frequencies.



## programmable baud rate generator (continued)

| BAUD RATE<br>DESIRED | DIVISOR (N) USED TO<br>GENERATE 16x CLOCK | PERCENT ERROR DIFFERENCE<br>BETWEEN DESIRED AND ACTUAL |
|----------------------|-------------------------------------------|--------------------------------------------------------|
| 50                   | 2304                                      | -                                                      |
| 75                   | 1536                                      | -                                                      |
| 110                  | 1047                                      | 0.026                                                  |
| 134.5                | 857                                       | 0.058                                                  |
| 150                  | 768                                       | -                                                      |
| 300                  | 384                                       | -                                                      |
| 600                  | 192                                       | -                                                      |
| 1200                 | 96                                        | -                                                      |
| 1800                 | 64                                        | -                                                      |
| 2000                 | 58                                        | 0.690                                                  |
| 2400                 | 48                                        | -                                                      |
| 3600                 | 32                                        | -                                                      |
| 4800                 | 24                                        | -                                                      |
| 7200                 | 16                                        | -                                                      |
| 9600                 | 12                                        | -                                                      |
| 19200                | 6                                         | -                                                      |
| 38400                | 3                                         | -                                                      |
| 56000                | 2                                         | 2.860                                                  |

#### Table 14. Baud Rates Using a 1.8432-MHz Crystal

#### Table 15. Baud Rates Using a 3.072-MHz Crystal

| BAUD RATE<br>DESIRED | DIVISOR (N) USED TO<br>GENERATE 16x CLOCK | PERCENT ERROR DIFFERENCE<br>BETWEEN DESIRED AND ACTUAL |
|----------------------|-------------------------------------------|--------------------------------------------------------|
| 50                   | 3840                                      | -                                                      |
| 75                   | 2560                                      | -                                                      |
| 110                  | 1745                                      | 0.026                                                  |
| 134.5                | 1428                                      | 0.034                                                  |
| 150                  | 1280                                      | -                                                      |
| 300                  | 640                                       | -                                                      |
| 600                  | 320                                       | -                                                      |
| 1200                 | 160                                       | -                                                      |
| 1800                 | 107                                       | 0.312                                                  |
| 2000                 | 96                                        | -                                                      |
| 2400                 | 80                                        | -                                                      |
| 3600                 | 53                                        | 0.628                                                  |
| 4800                 | 40                                        | -                                                      |
| 7200                 | 27                                        | 1.230                                                  |
| 9600                 | 20                                        | -                                                      |
| 19200                | 10                                        | -                                                      |
| 38400                | 5                                         | -                                                      |



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

## **PRINCIPLES OF OPERATION**

### programmable baud rate generator (continued)

| BAUD RATE<br>DESIRED | DIVISOR (N) USED TO<br>GENERATE 16x CLOCK | PERCENT ERROR DIFFERENCE<br>BETWEEN DESIRED AND ACTUAL |
|----------------------|-------------------------------------------|--------------------------------------------------------|
| 50                   | 10000                                     | -                                                      |
| 75                   | 6667                                      | 0.005                                                  |
| 110                  | 4545                                      | 0.010                                                  |
| 134.5                | 3717                                      | 0.013                                                  |
| 150                  | 3333                                      | 0.010                                                  |
| 300                  | 1667                                      | 0.020                                                  |
| 600                  | 833                                       | 0.040                                                  |
| 1200                 | 417                                       | 0.080                                                  |
| 1800                 | 277                                       | 0.080                                                  |
| 2000                 | 250                                       | -                                                      |
| 2400                 | 208                                       | 0.160                                                  |
| 3600                 | 139                                       | 0.080                                                  |
| 4800                 | 104                                       | 0.160                                                  |
| 7200                 | 69                                        | 0.644                                                  |
| 9600                 | 52                                        | 0.160                                                  |
| 19200                | 26                                        | 0.160                                                  |
| 38400                | 13                                        | 0.160                                                  |
| 56000                | 9                                         | 0.790                                                  |
| 128000               | 4                                         | 2.344                                                  |
| 256000               | 2                                         | 2.344                                                  |
| 512000               | 1                                         | 2.400                                                  |

#### Table 16. Baud Rates Using an 8-MHz Clock

#### Table 17. Baud Rates Using a 16-MHz Clock

| BAUD RATE<br>DESIRED | DIVISOR (N) USED TO<br>GENERATE 16x CLOCK | PERCENT ERROR DIFFERENCE<br>BETWEEN DESIRED AND ACTUAL |
|----------------------|-------------------------------------------|--------------------------------------------------------|
| 50                   | 20000                                     | 0.00                                                   |
| 75                   | 13334                                     | 0.00                                                   |
| 110                  | 9090                                      | 0.01                                                   |
| 134.5                | 7434                                      | 0.01                                                   |
| 150                  | 6666                                      | 0.01                                                   |
| 300                  | 3334                                      | -0.02                                                  |
| 600                  | 1666                                      | 0.04                                                   |
| 1200                 | 834                                       | -0.08                                                  |
| 1800                 | 554                                       | 0.28                                                   |
| 2000                 | 500                                       | 0.00                                                   |
| 2400                 | 416                                       | 0.16                                                   |
| 3600                 | 278                                       | -0.08                                                  |
| 4800                 | 208                                       | 0.16                                                   |
| 7200                 | 138                                       | 0.64                                                   |
| 9600                 | 104                                       | 0.16                                                   |
| 19200                | 52                                        | 0.16                                                   |
| 38400                | 26                                        | 0.16                                                   |
| 56000                | 18                                        | -0.79                                                  |
| 128000               | 8                                         | -2.34                                                  |
| 256000               | 4                                         | -2.34                                                  |
| 512000               | 2                                         | -2.34                                                  |
| 100000               | 1                                         | 0.00                                                   |



#### programming

The serial channel of the ACE is programmed by the control registers: LCR, IER, DLL, DLM, MCR, and FCR. These control words define the character length, number of stop bits, parity, baud rate, and modem interface.

While the control registers can be written to in any order, the IER should be written to last because it controls the interrupt enables. Once the serial channel is programmed and operational, these registers can be updated any time the ACE serial channel is not transmitting or receiving data.

#### receiver

Serial asynchronous data is input into SIN. The ACE continually searches for a high-to-low transition from the idle state. When the transition is detected, a counter is reset and counts the  $16 \times \text{clock}$  to 7 1/2, which is the center of the start bit. The start bit is valid if SIN is still low. Verifying the start bits prevents the receiver from assembling a false data character due to a low-going noise spike on the SIN input.

The LCR determines the number of data bits in a character (LCR0 and LCR1). When parity is used, LCR3 and the polarity of parity LCR4 is needed. Status for the receiver is provided in the LSR. When a full character is received, including parity and stop bits, the data received indicator in LSR0 is set. The CPU reads the receiver buffer register, which clears LSR0. If the character is not read prior to a new character transfer from the RSR to the RBR, the overrun error status indicator is set in LSR1. If there is a parity error, the parity error is set in LSR2. If a stop bit is not detected, a framing error indicator is set in LSR3.

If the data into SIN is a symmetrical square wave, the center of the data cells occurs within  $\pm 3.125\%$  of the actual center, providing an error margin of 46.875%. The start bit can begin as much as one  $16 \times$  clock cycle prior to being detected.

#### scratchpad register

The scratch register is an 8-bit read/write register that has no effect on either channel in the ACE. It is intended to be used by the programmer to hold data temporarily.



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

**MECHANICAL DATA** 



NOTES: A. All linear dimensions are in inches (millimeters).

B. This drawing is subject to change without notice.

C. This package can be hermetically sealed with a ceramic lid using glass frit.



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

#### MECHANICAL DATA

#### LEADLESS CERAMIC CHIP CARRIER

FK (S-CQCC-N\*\*)



NOTES: A. All linear dimensions are in inches (millimeters).

- B. This drawing is subject to change without notice.
- C. This package can be hermetically sealed with a metal lid.
- D. The terminals are gold plated.
- E. Falls within JEDEC MS-004



SLLS189D - NOVEMBER 1994 - REVISED JANUARY 1999

PN (S-PQFP-G80)

**MECHANICAL DATA** 

PLASTIC QUAD FLATPACK



NOTES: A. All linear dimensions are in millimeters.

- B. This drawing is subject to change without notice.
- C. Falls within JEDEC MS-026



#### **IMPORTANT NOTICE**

Texas Instruments and its subsidiaries (TI) reserve the right to make changes to their products or to discontinue any product or service without notice, and advise customers to obtain the latest version of relevant information to verify, before placing orders, that information being relied on is current and complete. All products are sold subject to the terms and conditions of sale supplied at the time of order acknowledgement, including those pertaining to warranty, patent infringement, and limitation of liability.

TI warrants performance of its semiconductor products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are utilized to the extent TI deems necessary to support this warranty. Specific testing of all parameters of each device is not necessarily performed, except those mandated by government requirements.

CERTAIN APPLICATIONS USING SEMICONDUCTOR PRODUCTS MAY INVOLVE POTENTIAL RISKS OF DEATH, PERSONAL INJURY, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE ("CRITICAL APPLICATIONS"). TI SEMICONDUCTOR PRODUCTS ARE NOT DESIGNED, AUTHORIZED, OR WARRANTED TO BE SUITABLE FOR USE IN LIFE-SUPPORT DEVICES OR SYSTEMS OR OTHER CRITICAL APPLICATIONS. INCLUSION OF TI PRODUCTS IN SUCH APPLICATIONS IS UNDERSTOOD TO BE FULLY AT THE CUSTOMER'S RISK.

In order to minimize risks associated with the customer's applications, adequate design and operating safeguards must be provided by the customer to minimize inherent or procedural hazards.

TI assumes no liability for applications assistance or customer product design. TI does not warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor products or services might be or are used. TI's publication of information regarding any third party's products or services does not constitute TI's approval, warranty or endorsement thereof.

Copyright © 1999, Texas Instruments Incorporated