SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 - Capable of Running With All Existing TL16C450 Software - After Reset, All Registers Are Identical to the TL16C450 Register Set - In the FIFO Mode. Transmitter and Receiver Are Each Buffered With 16-Byte FIFOs to Reduce the Number of Interrupts to the **CPU** - In the TL16C450 Mode, Hold and Shift **Registers Eliminate the Need for Precise** Synchronization Between the CPU and **Serial Data** - **Programmable Baud Rate Generator Allows** Division of Any Input Reference Clock by 1 to $(2^{16}-1)$ and Generates an Internal 16× Clock - **Standard Asynchronous Communication** Bits (Start, Stop, and Parity) Added to or **Deleted From the Serial Data Stream** - **Independent Receiver Clock Input** - Transmit, Receive, Line Status, and Data **Set Interrupts Independently Controlled** - **Fully Programmable Serial Interface Characteristics:** - 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 - Baud Generation (DC to 562 Kbit/s) - **False-Start Bit Detection** - **Complete Status Reporting Capabilities** - 3-State Outputs Provide TTL Drive Capabilities for Bidirectional Data Bus and **Control Bus** - **Line Break Generation and Detection** - **Internal Diagnostic Capabilities:** - Loopback Controls for Communications Link Fault Isolation - Break, Parity, Overrun, Framing Error Simulation - Fully Prioritized Interrupt System Controls - Modem Control Functions (CTS, RTS, DSR, DTR, RI, and DCD) - Faster Plug-In Replacement for National Semiconductor NS16550A #### description The TL16C550B and the TL16C550Bl are functional upgrades of the TL16C450 asynchronous communications element (ACE). Functionally identical to the TL16C450 on power up (character mode<sup>†</sup>), the TL16C550B and TL16C550Bl can be placed in an alternate mode (FIFO) to relieve the CPU of excessive software overhead. In this alternate FIFO mode, internal FIFOs are activated allowing 16 bytes (plus 3 bits of error data per byte in the receiver FIFO) to be stored in both receive and transmit modes. To minimize system overhead and maximize system efficiency, all logic is on the chip. Two of the TL16C450 terminal functions (RXRDY and TXRDY) have been changed to allow signalling of DMA transfers. The TL16C550B and the TL16C550BI perform serial-to-parallel conversions on data received from a peripheral device or modem and parallel-to-serial conversion on data received from its CPU. The CPU can read and report on the status of the ACE at any point in the ACE operation. Reported status information includes: the type of transfer operation in progress, the status of the operation, and any error conditions encountered. 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. †The TL16C550B and the TL16C550BI can also be reset to the TL16C450 mode under software control. SLLS136B – JANUARY 1994 – REVISED AUGUST 1996 #### description (continued) The TL16C550B and the TL16C550BI ACE include programmable, on-board, baud rate generators. These generators are capable of dividing a reference clock input by divisors from 1 to $(2^{16}-1)$ and producing a $16 \times$ clock for driving the internal transmitter logic. Provisions are included to use this $16 \times$ clock to drive the receiver logic. Also included in the ACE is a complete modem control capability and a processor interrupt system that may be software tailored to user requirements to minimize the computing required to handle the communications link. The TL16C550B is available in a 40-pin DIP (N) package, 44-pin PLCC (FN) package, and 48-pin TQFP (PT) package. The TL16C550BI is available in a 44-pin PLCC (FN) package. SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 NC-No internal connection SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### functional block diagram s е ı Receiver Internal е **FIFO** Data Bus С t Receiver 10 Shift SIN Data Receiver Register D7-D0 Bus **Buffer** Register **Buffer** Receiver Line RCLK Timing and Control Control Register 28 A0 **Divisor** Α1 Latch (LS) 15 BAUDOUT 26 **Baud A2** Generator Divisor 12 Latch (MS) CS0 13 CS1 14 Line CS2 Line Control Status 25 Register ADS Register 35 Select MR **Transmitter** and S 21 **FIFO** Control RD1 е Logic 22 1 RD2 **Transmitter** е 11\_ WR1 18 Control SOUT Holding Register Register 19 WR2 23 **DDIS** 32 RTS Modem TXRDY 24 Control CTS Register 33 DTR **XOUT** 17 37 Modem DSR Modem RXRDY 29 **Status** Control 38 DCD Register Logic 39 RI 34 OUT1 31 OUT2 Interrupt 30 INTRPT Interrupt Enable Control Register Logic Interrupt I/O Register **FIFO** Control Register Terminal numbers shown are for the N package. SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### **Terminal Functions** | TERMINAL | | | | | | |----------------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NAME | NO.<br>N | NO.<br>FN | NO.<br>PT | I/O | DESCRIPTION | | A0<br>A1<br>A2 | 28<br>27<br>26 | 31<br>30<br>29 | 28<br>27<br>26 | I | Register select. A0-A2 are used during read and write operations to select the ACE register to read from or write to. Refer to Table 1 for register addresses, and refer to the address strobe (ADS) signal description. | | ADS | 25 | 28 | 24 | I | Address strobe. When ADS is active (low), the register select signals (A0, A1, and A2) and chip select signals (CS0, CS1, CS2) drive the internal select logic directly; when high, the register select and chip select signals are held in the state they are in when the low-to-high transition of ADS occurs. | | BAUDOUT | 15 | 17 | 12 | 0 | Baud out. BAUDOUT is a 16× clock signal for the transmitter section of the ACE. The clock rate is established by the reference oscillator frequency divided by a divisor specified by the baud generator divisor latches. BAUDOUT can also be used for the receiver section by tying this output to RCLK. | | CS0<br>CS1<br>CS2 | 12<br>13<br>14 | 14<br>15<br>16 | 9<br>10<br>11 | I | Chip select. When CS0 = high, CS1 = high, and $\overline{\text{CS2}}$ = low, these three inputs select the ACE. When any of these inputs are inactive, the ACE remains inactive. Refer to the $\overline{\text{ADS}}$ signal description. | | CTS | 36 | 40 | 38 | I | Clear to send. $\overline{\text{CTS}}$ is a modem status signal. Its condition can be checked by reading bit 4 (CTS) of the modem status register. Bit 0 ( $\Delta$ CTS) of the modem status register indicates that this signal has changed states since the last read from the modem status register. If the modem status interrupt is enabled when $\overline{\text{CTS}}$ changes state, an interrupt is generated. | | D0<br>D1<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7 | 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8 | 2<br>3<br>4<br>5<br>6<br>7<br>8<br>9 | 43<br>44<br>45<br>46<br>47<br>2<br>3 | I/O | Data bus. Eight data lines with 3-state outputs provide a bidirectional path for data, control, and status information between the ACE and the CPU. | | DCD | 38 | 42 | 40 | | Data carrier detect. DCD is a modem status signal. Its condition can be checked by reading bit 7 (DCD) of the modem status register. Bit 3 (\DCD) of the modem status register indicates that this signal has changed states since the last read from the modem status register. If the modem status interrupt is enabled when DCD changes state, an interrupt is generated. | | DDIS | 23 | 26 | 22 | 0 | Driver disable. This output is active (high) when the CPU is not reading data. When active, this output can disable an external transceiver. | | DSR | 37 | 41 | 39 | ı | Data set ready. $\overline{\text{DSR}}$ is a modem status signal. Its condition can be checked by reading bit 5 (DSR) of the modem status register. Bit 1 ( $\Delta$ DSR) of the modem status register indicates this signal has changed states since the last read from the modem status register. If the modem status interrupt is enabled when $\overline{\text{DSR}}$ changes state, an interrupt is generated. | | DTR | 33 | 37 | 33 | 0 | Data terminal ready. When active (low), DTR informs a modem or data set that the ACE is ready to establish communication. DTR is placed in the active state by setting the DTR bit of the modem control register to a high level. DTR is placed in the inactive state either as a result of a master reset, during loop mode operation, or clearing the DTR bit. | | INTRPT | 30 | 33 | 30 | 0 | Interrupt. When active (high), INTRPT informs the CPU that the ACE has an interrupt to be serviced. Four conditions that cause an interrupt to be issued are: a receiver error, received data is available or timed out (FIFO mode only), the transmitter holding register is empty, or an enabled modem status interrupt. The INTRPT output is reset (deactivated) either when the interrupt is serviced or as a result of a master reset. | | MR | 35 | 39 | 35 | I | Master reset. When active (high), MR clears most ACE registers and sets the state of various output signals. Refer to Table 2. | | OUT1<br>OUT2 | 34<br>31 | 38<br>35 | 34<br>31 | 0 | Outputs 1 and 2. User-designated outputs that are set to their active low states by setting their respective modem control register bits (OUT1 and OUT2) high. OUT1 and OUT2 are set to their inactive (high) states as a result of master reset, during loop mode operations, or by clearing bit 2 (OUT1) or bit 3 (OUT2) of the modem control register. | | RCLK | 9 | 10 | 5 | Ī | Receiver clock. RCLK is the 16× baud rate clock for the receiver section of the ACE. | SLLS136B – JANUARY 1994 – REVISED AUGUST 1996 ### **Terminal Functions (Continued)** | TERMINAL | | | | | | |-------------|----------|-----------|-----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NAME | NO.<br>N | NO.<br>FN | NO.<br>PT | I/O | DESCRIPTION | | RD1<br>RD2 | 21<br>22 | 24<br>25 | 19<br>20 | I | Read inputs. When either input is active (low or high respectively) while the ACE is selected, the CPU is allowed to read status information or data from a selected ACE register. Only one of these inputs is required for the transfer of data during a read operation; the other input should be tied in its inactive state (i.e., RD2 tied low or RD1 tied high). | | RI | 39 | 43 | 41 | I | Ring indicator. $\overline{RI}$ is a modem status signal. Its condition can be checked by reading bit $\underline{6}$ (RI) of the modem status register. Bit 2 (TERI) of the modem status register indicates that the $\overline{RI}$ input has transitioned from a low to a high state since the last read from the modem status register. If the modem status interrupt is enabled when this transition occurs, an interrupt is generated. | | RTS | 32 | 36 | 32 | 0 | Request to send. When active, RTS informs the modem or data set that the ACE is ready to receive data. RTS is set to its active state by setting the RTS modem control register bit and is set to its inactive (high) state either as a result of a master reset or during loop mode operations or by clearing bit 1 (RTS) of the MCR. | | RXRDY | 29 | 32 | 29 | 0 | Receiver ready output. Receiver direct memory access (DMA) signalling is available with this terminal. When operating in the FIFO mode, one of two types of DMA signalling can be selected using the FIFO control register bit 3 (FCR3). When operating in the TL16C450 mode, only DMA mode 0 is allowed. Mode 0 supports single-transfer DMA in which a transfer is made between CPU bus cycles. Mode 1 supports multitransfer DMA in which multiple transfers are made continuously until the receiver FIFO has been emptied. In DMA mode 0 (FCR0 = 0 or FCR0 = 1, FCR3 = 0), when there is at least one character in the receiver FIFO or receiver holding register, RXRDY is active low. When RXRDY has been active but there are no characters in the FIFO or holding register, RXRDY goes inactive (high). In DMA mode 1 (FCR0 = 1, FCR3 = 1), when the trigger level or the timeout has been reached, RXRDY goes active (low); when it has been active but there are no more characters in the FIFO or holding register, it goes inactive (high). | | SIN | 10 | 11 | 7 | 1 | Serial data input. Input from a connected communications device | | SOUT | 11 | 13 | 8 | 0 | Composite serial data output. Output to a connected communication device. SOUT is set to the marking (set) state as a result of master reset. | | TXRDY | 24 | 27 | 23 | 0 | Transmitter ready output. Transmitter DMA signalling is available with this terminal. When operating in the FIFO mode, one of two types of DMA signalling can be selected using FCR3. When operating in the TL16C450 mode, only DMA mode 0 is allowed. Mode 0 supports single-transfer DMA in which a transfer is made between CPU bus cycles. Mode 1 supports multitransfer DMA in which multiple transfers are made continuously until the transmit FIFO has been filled. | | Vcc | 40 | 44 | 42 | | 5-V supply voltage | | VSS | 20 | 22 | 18 | | Supply common | | WR1<br>WR2 | 18<br>19 | 20<br>21 | 16<br>17 | I | Write inputs. When either input is active (high or low respectively) and while the ACE is selected, the CPU is allowed to write control words or data into a selected ACE register. Only one of these inputs is required to transfer data during a write operation; the other input should be tied in its inactive state (i.e., WR2 tied low or WR1 tied high). | | XIN<br>XOUT | 16<br>17 | 18<br>19 | 14<br>15 | I/O | External clock. XIN and XOUT connect the ACE to the main timing reference (clock or crystal). | SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### absolute maximum ratings over operating free-air temperature range (unless otherwise noted) | Supply voltage range, V <sub>CC</sub> (see Note 1) | | |-------------------------------------------------------------------------------|---------------| | Output voltage range, V <sub>O</sub> | | | Continuous total power dissipation at (or below) 70°C | 300 mW | | Storage temperature range, T <sub>stq</sub> | 65°C to 150°C | | Operating free-air temperature range, T <sub>A</sub> : TL16C550B | | | TL16C550BI | | | Case temperature for 10 seconds, T <sub>C</sub> : FN package | 260°C | | Lead temperature 1,6 mm (1/16 inch) from case for 10 seconds: N or PT package | 260°C | <sup>†</sup> 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 values are with respect to VSS (ground). #### recommended operating conditions | | | MIN | NOM | MAX | UNIT | |------------------------------------------------|------------|------|-----|------|------| | Supply voltage, V <sub>CC</sub> | 2 1 | 4.75 | 5 | 5.25 | V | | High-level input voltage, VIH | 44 | 2 | | VCC | V | | Low-level input voltage, V <sub>IL</sub> | 4 3 | -0.5 | | 0.8 | V | | Operating free-air temperature, T <sub>A</sub> | TL16C550B | 0 | | 70 | °C | | Operating nee-an temperature, 14 | TL16C550BI | -40 | | 85 | °C | ### electrical characteristics over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted) | | PARAMETER | TEST CONDITIONS | MIN | TYP <sup>†</sup> | MAX | UNIT | |---------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------------|-----|------| | V <sub>OH</sub> ‡ | High-level output voltage | I <sub>OH</sub> = -1 mA | 2.4 | | | V | | V <sub>OL</sub> ‡ | Low-level output voltage | I <sub>OL</sub> = 1.6 mA | | | 0.4 | V | | i <sub>l</sub> | Input current | $V_{CC} = 5.25 \text{ V},$ $V_{SS} = 0,$ All other terminals floating | g | | 10 | μА | | loz | High-impedance-state output current | $V_{CC} = 5.25 \text{ V},$ $V_{SS} = 0,$ $V_{O} = 0$ to 5.25 V, Chip selected in write mode or chip deselect | | | ±20 | μА | | Icc | Supply current | $\begin{array}{c} V_{CC} = 5.25 \text{ V,} \\ \text{SIN, } \overline{\text{DSR, }} \overline{\text{DCD, }}, \overline{\text{CTS, }} \text{ and } \overline{\text{RI at 2 V,}} \\ \text{All other inputs at 0.8 V,} \\ \text{No load on outputs,} \end{array}$ | | | 10 | mA | | C <sub>i(CLK)</sub> | Clock input capacitance | | | 15 | 20 | pF | | C <sub>o(CLK)</sub> | Clock output capacitance | $V_{CC} = 0,$ $V_{SS} = 0,$ $T_{A} = 25^{\circ}C,$ | | 20 | 30 | pF | | Ci | Input capacitance | All other terminals grounded | | 6 | 10 | pF | | Co | Output capacitance | - | | 10 | 20 | pF | <sup>&</sup>lt;sup>†</sup> All typical values are at $V_{CC} = 5 \text{ V}$ , $T_A = 25^{\circ}\text{C}$ . <sup>&</sup>lt;sup>‡</sup>These parameters apply for all outputs except XOUT. SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 ### system timing requirements over recommended ranges of supply voltage and operating free-air temperature | | PARAMETER | ALT. SYMBOL | FIGURE | TEST CONDITIONS | MIN I | MAX | UNIT | |-------------------|------------------------------------------------------------------------------------------------|------------------|--------|------------------------|-------|-----|------| | t <sub>cR</sub> | Cycle time, read (t <sub>W7</sub> + t <sub>d8</sub> + t <sub>d9</sub> ) | RC | | | 87 | | ns | | t <sub>cW</sub> | Cycle time, write (t <sub>w6</sub> + t <sub>d5</sub> + t <sub>d6</sub> ) | WC | | | 87 | | ns | | t <sub>w1</sub> | Pulse duration, clock high | tXH | 1 | f = 9 MHz maximum | 40 | | ns | | t <sub>w2</sub> | Pulse duration, clock low | t <sub>XL</sub> | 1 | f = 9 MHz maximum | 40 | | ns | | t <sub>w5</sub> | Pulse duration, address strobe low | <sup>t</sup> ADS | 2,3 | | 9 | | ns | | tw6 | Pulse duration, write strobe | tWR | 2 | | 40 | | ns | | t <sub>w7</sub> | Pulse duration, read strobe | tRD | 3 | | 40 | | ns | | t <sub>w8</sub> | Pulse duration, master reset | t <sub>MR</sub> | | | 1 | | μs | | t <sub>su1</sub> | Setup time, address valid before ADS↑ | t <sub>AS</sub> | 2,3 | | 8 | | ns | | t <sub>su2</sub> | Setup time, chip select valid before ADS↑ | tCS | 2,3 | | 8 | | ns | | t <sub>su3</sub> | Setup time, data valid before WR1 ↓ or WR2 | t <sub>DS</sub> | 2 | | 15 | | ns | | t <sub>h1</sub> | Hold time, address low after ADS↑ | <sup>t</sup> AH | 2,3 | | 0 | | ns | | t <sub>h2</sub> | Hold time, chip select valid after ADS↑ | <sup>t</sup> CH | 2,3 | 4 | 0 | | ns | | th3 | Hold time, chip select valid after $\overline{\text{WR1}} \uparrow$ or $\text{WR2} \downarrow$ | twcs | 2 | 2 15 | 10 | | ns | | t <sub>h4</sub> | Hold time, address valid after WR1↑ or WR2↓ | t₩A | 2 | | 10 | | ns | | t <sub>h5</sub> | Hold time, data valid after WR1↑ or WR2↓ | <sup>t</sup> DH | 2 | C | 5 | | ns | | th6 | Hold time, chip select valid after $\overline{\text{RD1}}\uparrow$ or $\text{RD2}\downarrow$ | tRCS | 3 | 414 | 10 | | ns | | t <sub>h7</sub> | Hold time, address valid after RD1↑ or RD2↓ | <sup>t</sup> RA | 3 | | 20 | | ns | | t <sub>d4</sub> † | Delay time, chip select valid before WR1↓ or WR2↑ | tCSW | 2 | | 7 | | ns | | t <sub>d5</sub> † | Delay time, address valid before WR1 | t <sub>AW</sub> | 2 | | 7 | | ns | | t <sub>d6</sub> † | Delay time, write cycle, WR1↑ or WR2↓ to ADS↓ | twc | 2 | | 40 | | ns | | t <sub>d7</sub> † | Delay time, chip select valid to RD1 ↓ or RD2↑ | tCSR | 3 | | 7 | | ns | | t <sub>d8</sub> † | Delay time, address valid to RD1↓ or RD2↑ | <sup>t</sup> AR | 3 | | 7 | | ns | | t <sub>d</sub> 9 | Delay time, read cycle, RD1↑ or RD2↓ to ADS↓ | tRC | 3 | | 40 | | ns | | <sup>t</sup> d10 | Delay time, RD1↓ or RD2↑ to data valid | <sup>t</sup> RVD | 3 | C <sub>L</sub> = 75 pF | 45 | | ns | | <sup>t</sup> d11 | Delay time, RD1↑ or RD2↓ to floating data | <sup>t</sup> HZ | 3 | C <sub>L</sub> = 75 pF | 20 | | ns | <sup>†</sup>Only applies when ADS is low ### system switching characteristics over recommended ranges of supply voltage and operating free-air temperature (see Note 2) | PARAMETER | ALT. SYMBOL | FIGURE | TEST CONDITIONS | MIN MAX | UNIT | |----------------------------------------------------------------------------------------------------------------------|------------------|--------|------------------------|---------|------| | $t_{dis(R)}$ Disable time, $\overline{RD1}\uparrow\downarrow$ or $RD2\downarrow\uparrow$ to $DDIS\uparrow\downarrow$ | t <sub>RDD</sub> | 3 | C <sub>L</sub> = 75 pF | 20 | ns | NOTE 2: Charge and discharge time is determined by VOL, VOH, and external loading. ### baud generator switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $C_L = 75 \text{ pF}$ | | PARAMETER | ALT. SYMBOL | FIGURE | TEST CONDITIONS | MIN | MAX | UNIT | |-----------------|-------------------------------|------------------|--------|--------------------|-----|-----|------| | t <sub>w3</sub> | Pulse duration, BAUDOUT low | tLW | 1 | f = 9 MHz, CLK ÷ 2 | 80 | | ns | | t <sub>w4</sub> | Pulse duration, BAUDOUT high | tHW | 1 | f = 9 MHz, CLK ÷ 2 | 80 | | ns | | t <sub>d1</sub> | Delay time, XIN↑ to BAUDOUT↑ | <sup>t</sup> BLD | 1 | | | 75 | ns | | t <sub>d2</sub> | Delay time, XIN↑↓ to BAUDOUT↓ | <sup>t</sup> BHD | 1 | | | 65 | ns | SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### receiver switching characteristics over recommended ranges of supply voltage and operating free-air temperature (see Note 3) | | PARAMETER | ALT. SYMBOL | FIGURE | TEST CONDITIONS | MIN | MAX | UNIT | |------------------|---------------------------------------------------------------------------------------------------------------|-------------------|-----------|------------------------|-----|-----|---------------| | t <sub>d12</sub> | Delay time, RCLK to sample | tSCD | 4 | | | 10 | ns | | <sup>t</sup> d13 | Delay time, stop to set interrupt or read RBR to LSI interrupt or stop to $\overrightarrow{RXRDY} \downarrow$ | <sup>t</sup> SINT | 4,5,6,7,8 | | | 1 | RCLK<br>cycle | | t <sub>d14</sub> | Delay time, read RBR/LSR to reset interrupt low | <sup>t</sup> RINT | 4,5,6,7,8 | C <sub>L</sub> = 75 pF | | 40 | ns | NOTE 3: In the FIFO mode, the read cycle (RC) = 425 ns (minimum) between reads of the receiver FIFO and the status registers (interrupt identification register or line status register). #### transmitter switching characteristics over recommended ranges of supply voltage and operating free-air temperature | | PARAMETER | ALT. SYMBOL | FIGURE | TEST CONDITIONS | MIN | MAX | UNIT | |------------------|---------------------------------------------------------------------|------------------|--------|------------------------|-----|-----|-------------------| | <sup>t</sup> d15 | Delay time, initial write (INTRPT low) to transmit start (SOUT low) | <sup>t</sup> IRS | 9 | | 8 | 24 | baudout<br>cycles | | <sup>t</sup> d16 | Delay time, stop (SOUT low) to interrupt (INTRPT high) | <sup>t</sup> STI | 9 | | 8 | 9 | baudout<br>cycles | | t <sub>d17</sub> | Delay time, WR THR high to reset interrupt (INTRPT low) | <sup>t</sup> HR | 9 | C <sub>L</sub> = 75 pF | | 50 | ns | | t <sub>d18</sub> | Delay time, initial WR THR low to THRE interrupt (INTRPT high) | tsı 🦸 | 9 | Ch | 16 | 32 | baudout<br>cycles | | <sup>t</sup> d19 | Delay time, RD IIR low to reset THRE interrupt (INTRPT low) | t <sub>IR</sub> | 9 | C <sub>L</sub> = 75 pF | | 35 | ns | | t <sub>d20</sub> | Delay time, WR THR high to TXRDY high (inactive) | t <sub>WXI</sub> | 10,11 | C <sub>L</sub> = 75 pF | | 35 | ns | | <sup>t</sup> d21 | Delay time, start (SOUT low) to TXRDY low (active) | tSXA | 10,11 | C <sub>L</sub> = 75 pF | | 8 | baudout<br>cycles | ## modem control switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $C_L = 75~pF$ | | PARAMETER | ALT. SYMBOL | FIGURE | MIN MAX | UNIT | |------------------|--------------------------------------------------------------------------------|------------------|--------|---------|------| | t <sub>d22</sub> | Delay time, WR MCR low to output (RTS, DTR, OUT1, OUT2) low or high | tMDO | 12 | 50 | ns | | t <sub>d23</sub> | Delay time, modem interrupt (CTS, DSR, DCD) low to set interrupt (INTRPT) high | <sup>t</sup> SIM | 12 | 35 | ns | | t <sub>d24</sub> | Delay time, RD MSR low to reset interrupt (INTRPT) low | <sup>t</sup> RIM | 12 | 40 | ns | SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### PARAMETER MEASUREMENT INFORMATION #### PARAMETER MEASUREMENT INFORMATION † Applicable only when ADS is low. Figure 2. Write Cycle Timing Waveforms #### PARAMETER MEASUREMENT INFORMATION Figure 3. Read Cycle Timing Waveforms SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 Figure 4. Receiver Timing Waveforms Figure 5. Receiver FIFO First Byte (Sets DR Bit) Waveforms NOTE A: For a timeout interrupt, t<sub>d13</sub> = 8 RCLKs. Figure 6. Receiver FIFO Bytes Other Than the First Byte (DR Internal Bit Already Set) Waveforms #### PARAMETER MEASUREMENT INFORMATION NOTES: A. This is the reading of the last byte in the FIFO. B. For a timeout interrupt, $t_{d13} = 8$ RCLKs. NOTES: A. This is the reading of the last byte in the FIFO. B. For a timeout interrupt, $t_{d13} = 8$ RCLKs. Figure 8. Receiver Ready (RXRDY) Waveforms, FCR = 1 or FCR3 = 1 (Mode 1) #### PARAMETER MEASUREMENT INFORMATION Figure 9. Transmitter Timing Waveforms Figure 10. Transmitter Ready (TXRDY) Waveforms, FCR0 = 0 or FCR0 = 1 and FCR3 = 0 (Mode 0) Figure 11. Transmitter Ready (TXRDY) Waveforms, FCR0 = 1 and FCR3 = 1 (Mode 1) SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### PARAMETER MEASUREMENT INFORMATION Figure 12. Modem Control Timing Waveforms #### **APPLICATION INFORMATION** Figure 13. Basic TL16C550B Configuration Figure 14. Typical Interface for a High-Capacity Data Bus #### **APPLICATION INFORMATION** Terminal numbers shown are for the N package. Figure 15. Typical TL16C550B Connection to a CPU #### **PRINCIPLES OF OPERATION** **Table 1. Register Selection** | DLAB† | A2 | A1 | A0 | REGISTER | |-------|----|----|----|-----------------------------------------------------| | 0 | L | L | L | Receiver buffer (read), transmitter holding (write) | | 0 | L | L | Н | Interrupt enable register | | Х | L | Н | L | Interrupt identification register (read only) | | Х | L | Н | L | FIFO control register (write) | | Х | L | Н | Н | Line control register | | Х | Н | L | L | Modem control register | | Х | Н | L | Н | Line status register | | Х | Н | Н | L | Modem status register | | Х | Н | Н | Н | Scratch register | | 1 | L | L | L | Divisor latch (LSB) | | 1 | L | L | Н | Divisor latch (MSB) | <sup>†</sup> The divisor latch access bit (DLAB) is the most significant bit of the line control register. The DLAB signal is controlled by writing to this bit location (see Table 3). | T The divisor latch access bit (DLAB) is the most significant bit of the line control register. The DLAB signal is controlled by writing to this bit location (see Table 3). Table 2. ACE Reset Functions RESET STATE | | | | | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------------------------------------------------------------|--|--|--|--| | Table 2. ACE Reset Functions | | | | | | | | REGISTER/SIGNAL | RESET<br>CONTROL | RESET STATE | | | | | | Interrupt Enable Register | Master Reset | All bits cleared (bits 0-3 forced and bits 4-7 permanent) | | | | | | Interrupt Identification Register | Master Reset | Bit 0 is set, bits 1-3 are cleared, and bits 4-7 are permanently cleared | | | | | | FIFO Control Register | Master Reset | All bits cleared | | | | | | Line Control Register | Master Reset | All bits cleared | | | | | | Modem Control Register | Master Reset | All bits cleared (5-7 permanent) | | | | | | Line Status Register | Master Reset | Bits 5 and 6 are set, all other bits are cleared | | | | | | Modem Status Register | Master Reset | Bits 0-3 are cleared, bits 4-7 are input signals | | | | | | SOUT | Master Reset | High | | | | | | INTRPT (receiver error flag) | Read LSR/MR | Low | | | | | | INTRPT (received data available) | Read RBR/MR | Low | | | | | | INTRPT (transmitter holding register empty) | Read IR/Write THR/MR | Low | | | | | | INTRPT (modem status changes) | Read MSR/MR | Low | | | | | | OUT2 | Master Reset | High | | | | | | RTS | Master Reset | High | | | | | | DTR | Master Reset | High | | | | | | OUT1 | Master Reset | High | | | | | | Scratch Register | Master Reset | No effect | | | | | | Divisor Latch (LSB and MSB) Registers | Master Reset | No effect | | | | | | Receiver Buffer Registers | Master Reset | No effect | | | | | | Transmitter Holding Registers | Master Reset | No effect | | | | | | RCVR FIFO | MR/FCR1-FCR0/<br>∆FCR0 | All bits low | | | | | | XMIT FIFO | MR/FCR2-FCR0/<br>∆FCR0 | All bits low | | | | | SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### PRINCIPLES OF OPERATION #### accessible registers The system programmer, using the CPU, has access to and control over any of the ACE registers that are summarized in Table 3. These registers control ACE operations, receive data, and transmit data. Descriptions of these registers follow Table 3. **Table 3. Summary of Accessible Registers** | | REGISTER ADDRESS | | | | | | | | | | | | |------------|--------------------------------------------------|-------------------------------------------------------|----------------------------------------------------------------|---------------------------------------------------|------------------------------------------------|---------------------------------------------|------------------------------------|----------------------------------------------|----------------------------------------------|---------------------|---------------------------|----------------| | | 0 DLAB = 0 | 0 DLAB = 0 | 1 DLAB = 0 | 2 | 2 | 3 | 4 | 5 | 6 | 7 | 0 DLAB = 1 | 1 DLAB = 1 | | Bit<br>No. | Receiver<br>Buffer<br>Register<br>(Read<br>Only) | Transmitter<br>Holding<br>Register<br>(Write<br>Only) | Interrupt<br>Enable<br>Register | Interrupt<br>Ident.<br>Register<br>(Read<br>Only) | FIFO<br>Control<br>Register<br>(Write<br>Only) | Line<br>Control<br>Register | Modem<br>Control<br>Register | Line<br>Status<br>Register | Modem<br>Status<br>Register | Scratch<br>Register | Divisor<br>Latch<br>(LSB) | Latch<br>(MSB) | | 1 | RBR | THR | IER | IIR | FCR | LCR | MCR | LSR | MSR | SCR | DLL | DLM | | 0 | Data Bit 0 <sup>†</sup> | Data Bit 0 | Enable<br>Received<br>Data<br>Available<br>Interrupt<br>(ERBI) | 0 if<br>interrupt<br>Pending | FIFO<br>Enable | Word<br>Length<br>Select<br>Bit 0<br>(WLS0) | Data<br>Terminal<br>Ready<br>(DTR) | Data<br>Ready<br>(DR) | Delta<br>Clear<br>to Send<br>(ΔCTS) | Bit 0 | Bit 0 | Bit 8 | | 1 | Data Bit 1 | Data Bit 1 | Enable Transmitter Holding Register Empty Interrupt (ETBEI) | Interrupt<br>ID<br>Bit (1) | Receiver<br>FIFO<br>Reset | Word<br>Length<br>Select<br>Bit 1<br>(WLS1) | Request<br>to Send<br>(RTS) | Overrun<br>Error<br>(OE) | Delta<br>Data<br>Set<br>Ready<br>(ADSR) | Bit 1 | Bit 1 | Bit 9 | | 2 | Data Bit 2 | Data Bit 2 | Enable Receiver Line Status Interrupt (ELSI) | Interrupt<br>ID<br>Bit (2) | Transmitter<br>FIFO<br>Reset | Number<br>of<br>Stop Bits<br>(STB) | OUT1 | Parity<br>Error<br>(PE) | Trailing<br>Edge Ring<br>Indicator<br>(TERI) | Bit 2 | Bit 2 | Bit 10 | | 3 | Data Bit 3 | Data Bit 3 | Enable<br>Modem<br>Status<br>Interrupt<br>(EDSSI) | Interrupt<br>ID<br>Bit (2)<br>(see<br>Note 4) | DMA<br>Mode<br>Select | Parity<br>Enable<br>(PEN) | OUT2 | Framing<br>Error<br>(FE) | Delta Data Carrier Detect (\(\Delta\)DCD) | Bit 3 | Bit 3 | Bit 11 | | 4 | Data Bit 4 | Data Bit 4 | 0 | 0 | Reserved | Even<br>Parity<br>Select<br>(EPS) | Loop | Break<br>Interrupt<br>(BI) | Clear<br>to<br>Send<br>(CTS) | Bit 4 | Bit 4 | Bit 12 | | 5 | Data Bit 5 | Data Bit 5 | 0 | 0 | Reserved | Stick<br>Parity | 0 | Transmitter<br>Holding<br>Register<br>(THRE) | Data<br>Set<br>Ready<br>(DSR) | Bit 5 | Bit 5 | Bit 13 | | 6 | Data Bit 6 | Data Bit 6 | 0 | FIFOs<br>Enabled<br>(see<br>Note 4) | Receiver<br>Trigger<br>(LSB) | Break<br>Control | 0 | Transmitter<br>Empty<br>(TEMT) | Ring<br>Indicator<br>(RI) | Bit 6 | Bit 6 | Bit 14 | | 7 | Data Bit 7 | Data Bit 7 | 0 | FIFOs<br>Enabled<br>(see<br>Note 4) | Receiver<br>Trigger<br>(MSB) | Divisor<br>Latch<br>Access<br>Bit<br>(DLAB) | 0 | Error in<br>RCVR<br>FIFO<br>(see<br>Note 4) | Data<br>Carrier<br>Detect<br>(DCD) | Bit 7 | Bit 7 | Bit 15 | † Bit 0 is the least significant bit. It is the first bit serially transmitted or received. NOTE 4: These bits are always 0 in the TL16C450 mode. SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### PRINCIPLES OF OPERATION #### FIFO control register (FCR) The FCR is a write-only register at the same location as the IIR, which is a read-only register. The FCR enables the FIFOs, clears the FIFOs, sets the receiver FIFO trigger level, and selects the type of DMA signalling. Bit 0: FCR0, when set, enables the transmit and receive FIFOs. This bit must be set when other FCR bits are written to or they are not programmed. Changing this bit clears the FIFOs. - Bit 1: FCR1, when set, clears all bytes in the receiver FIFO and clears its counter. The shift register is not cleared. The one that is written to this bit position is self clearing. - Bit 2: FCR2, when set, clears all bytes in the transmit FIFO and clears its counter. The shift register is not cleared. The one that is written to this bit position is self clearing. - Bit 3: When FCR0 is set, setting FCR3 causes the RXRDY and TXRDY to change from mode 0 to mode 1. - 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 FLF O interrupt (see Table 4). RECEIVER FIFO BIT 7 BIT 6 TRIGGER LEVEL (BYTES) 0 01 04 08 14 Table 4. Receiver FIFO Trigger Level #### FIFO interrupt mode operation When the receiver FIFO and receiver interrupts are enabled (FCR0 = 1, IER0 = 1) receiver interrupt occur as follows: - 1. The receive data available interrupt is issued to the microprocessor when the FIFO has reached its programmed trigger level. It is cleared when the FIFO drops below its programmed trigger level. - 2. The IIR receive data available indication also occurs when the FIFO trigger level is reached, and like the interrupt, it is cleared when the FIFO drops below the trigger level. - 3. The receiver line status interrupt (IIR = 0110) has higher priority than the received data available interrupt (IIR = 0100). - 4. The data ready bit (LSR0) is set when a character is transferred from the shift register to the receiver FIFO. It is cleared when the FIFO is empty. SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### PRINCIPLES OF OPERATION #### FIFO interrupt mode operation (continued) When the receiver FIFO and receiver interrupts are enabled, receiver FIFO timeout interrupt occurs as follows: - 1. FIFO timeout interrupt occurs when the following conditions exist: - a. At least one character is in the FIFO. - b. The most recent serial character received is longer than four continuous character times ago (when two stop bits are programmed, the second one is included in this time delay). - c. The most recent microprocessor read of the FIFO is longer than four continuous character times ago. This causes a maximum character received to interrupt an issued delay of 160 ms at 300 baud with a 12-bit character. - 2. Character times are calculated by using the RCLK input for a clock signal (makes the delay proportional to the baud rate). - 3. When a timeout interrupt has occurred, it is cleared and the timer is reset when the microprocessor reads one character from the receiver FIFO. - 4. When a timeout interrupt has not occurred, the timeout timer is reset after a new character is received or after the microprocessor reads the receiver FIFO. When the transmit FIFO and transmitter interrupts are enabled (FCR0 = 1, IER1 = 1), transmit interrupts occur as follows: - 1. The transmitter holding register interrupt (02) occurs when the transmit FIFO is empty. It is cleared as soon as the THR is written to (1 to 16 characters may be written to the transmit FIFO while servicing this interrupt) or the IIR is read. - 2. The transmit FIFO empty indications are delayed one character time minus the last stop bit time when the following occurs: THRE = 1 and there have not been at least two bytes at the same time in the transmit FIFO since the last THRE = 1. The first transmitter interrupt after changing FCR0 is immediate when it is enabled. Character timeout and receiver FIFO trigger level interrupts have the same priority as the current received data available interrupt; transmit FIFO empty has the same priority as the current THRE interrupt. #### FIFO polled mode operation When FCR0 is set, clearing IER0, IER1, IER2, IER3, or all four puts the ACE in the FIFO polled mode of operation. Since the receiver and transmitter are controlled separately, either one or both can be in the polled mode of operation. In this mode, the user program checks receiver and transmitter status via the LSR. As stated previously: - LSR0 is set as long as there is one byte in the receiver FIFO. - LSR1 LSR4 specify which error(s) have occurred. Character error status is handled the same way as when in the interrupt mode; the IIR is not affected since IER2 = 0. - LSR5 indicates when the transmit FIFO is empty. - LSR6 indicates that both the transmit FIFO and shift registers are empty. - LSR7 indicates whether there are any errors in the receiver FIFO. There is no trigger level reached or timeout condition indicated in the FIFO polled mode. However, the receiver and transmit FIFOs are still fully capable of holding characters. SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### PRINCIPLES OF OPERATION #### interrupt enable register (IER) The IER enables each of the five types of interrupts (refer to Table 5) and the INTRPT output signal in response to an interrupt generation. The IER can also disable the interrupt system by clearing bits 0 through 3. The contents of this register are summarized in Table 3 and are described in the following bulleted list. - Bit 0: This bit when set enables the received data available interrupt. - Bit 1: This bit when set enables the THRE interrupt. - Bit 2: This bit when set enables the receiver line status interrupt. - Bit 3: This bit when set enables the modern status interrupt. - Bits 4 7: These bits in the IER are not used and are always cleared. #### interrupt identification register (IIR) The ACE has an on-chip interrupt generation and prioritization capability that permits a flexible interface with most popular microprocessors. The ACE provides four prioritized levels of interrupts which are: - Priority 1 Receiver line status (highest priority) - Priority 2 Receiver data ready or receiver character timeout - Priority 3 Transmitter holding register empty - Priority 4-Modem status (lowest priority) When an interrupt is generated, the IIR indicates that an interrupt is pending and the type of that interrupt in its three least significant bits (bits 0, 1, and 2). The contents of this register are summarized in Table 3 and described in Table 4. Detail on each bit are as follows: - Bit 0: This bit can be used either in a hardwire prioritized or polled interrupt system. When this bit is cleared, an interrupt is pending. When bit 0 is set, no interrupt is pending. - Bits 1 and 2: These two bits identify the highest priority interrupt pending, as indicated in Table 5. - Bit 3. This bit is always cleared in the TL16C450 mode. In FIFO mode, this bit is set with bit 2 to indicate that a timeout interrupt is pending. - Bits 4-5: These two bits are not used and are always cleared. - Bits 6 and 7: These two bits are always cleared in the TL16C450 mode. They are set when bit 0 of the FIFO control register is set. SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### PRINCIPLES OF OPERATION #### interrupt identification register (IIR) (continued) **Table 5. Interrupt Control Functions** | I | INTERRUPT<br>IDENTIFICATION<br>REGISTER | | 1 | PRIORITY<br>LEVEL | INTERRUPT TYPE | INTERRUPT SOURCE | INTERRUPT RESET<br>METHOD | |-------|-----------------------------------------|-------|-------|-------------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------| | BIT 3 | BIT 2 | BIT 1 | BIT 0 | | | | | | 0 | 0 | 0 | 1 | None | None | None | None | | 0 | 1 | 1 | 0 | 1 | Receiver line status | Overrun error, parity error, framing error or break interrupt | Reading the line status register | | 0 | 1 | 0 | 0 | 2 | Received data available | Receiver data available in the TL16C450 mode or trigger level reached in the FIFO mode. | Reading the receiver buffer register | | 1 | 1 | 0 | 0 | 2 | Character timeout indication | No characters have been removed from or input to the receiver FIFO during the last four character times, and there is at least one character in it during this time | Reading the receiver buffer register | | 0 | 0 | 1 | 0 | 3 | Transmitter holding register empty | Transmitter holding register-<br>empty | Reading the interrupt identification register (if source of interrupt) or writing into the transmitter holding register | | 0 | 0 | 0 | 0 | 4 | Modem status | Clear to send, data set ready, ring indicator, or data carrier detect | Reading the modem status register | #### line control register (LCR) The system programmer controls the format of the asynchronous data communication exchange through the LCR. In addition, the programmer is able to retrieve, inspect, and modify the contents of the LCR; this eliminates the need for separate storage of the line characteristics in system memory. The contents of this register are summarized in Table 3 and are described in the following bulleted list. Bits 0 and 1: These two bits specify the number of bits in each transmitted or received serial character. These bits are encoded in Table 6. Table 6. Serial Character Word Length | BIT 1 | BIT 0 | WORD LENGTH | |-------|-------|-------------| | 0 | 0 | 5 bits | | 0 | 1 | 6 bits | | 1 | 0 | 7 bits | | 1 | 1 | 8 bits | • Bit 2: This bit specifies either one, one and one-half, or two stop bits in each transmitted character. When bit 2 is cleared, one stop bit is generated in the data. When bit 2 is set, the number of stop bits generated is dependent on the word length selected with bits 0 and 1. The receiver clocks only the first stop bit, regardless of the number of stop bits selected. The number of stop bits generated, in relation to word length and bit 2, is shown in Table 7. SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### PRINCIPLES OF OPERATION #### line control register (LCR) (continued) Table 7. Number of Stop Bits Generated | BIT 2 | WORD LENGTH SELECTED<br>BY BITS 1 AND 2 | NUMBER OF STOP<br>BITS GENERATED | |-------|-----------------------------------------|----------------------------------| | 0 | Any word length | 1 | | 1 | 5 bits | 1 1/2 | | 1 | 6 bits | 2 | | 1 | 7 bits | 2 | | 1 | 8 bits | 2 | - Bit 3: This bit is the parity enable bit. When bit 3 is set, a parity bit is generated in transmitted data between the last data word bit and the first stop bit. In received data, when bit 3 is set, parity is checked. When bit 3 is cleared, no parity is generated or checked. - Bit 4: This bit is the even parity select bit. When parity is enabled (bit 3 is set) and bit 4 is set, even parity (an even number of logic 1s in the data and parity bits) is selected. When parity is enabled and bit 4 is cleared, odd parity (an odd number of logic 1s) is selected. - Bit 5: This is the stick parity bit. When bits 3, 4, and 5 are set, the parity bit is transmitted and checked as cleared. When bits 3 and 5 are set and bit 4 is cleared, the parity bit is transmitted and checked as set. When bit 5 is cleared, stick parity is disabled. - Bit 6: This bit is the break control bit. Bit 6 is set to force a break condition; i.e., a condition where SOUT is forced to the spacing (cleared) state. When bit 6 is cleared, the break condition is disabled and has no affect on the transmitter logic; it only effects the serial output. - Bit 7: This bit is the divisor latch access bit (DLAB). Bit 7 must be set to access the divisor latches of the baud generator during a read or write. Bit 7 must be cleared during a read or write to access the receiver buffer, the THR, or the IER. #### line status register (LSR)† The LSR provides information to the CPU concerning the status of data transfers. The contents of this register are summarized in Table 3 and are described in the following bulleted list. - Bit 0: This bit is the data ready (DR) indicator for the receiver. Bit 0 is set whenever a complete incoming character has been received and transferred into the RBR or the FIFO. Bit 0 is cleared by reading all of the data in the RBR or the FIFO. - Bit 1‡: This bit is the overrun error (OE) indicator. When bit 1 is set, it indicates that before the character in the RBR is read, it is overwritten by the next character transferred into the register. The OE indicator is cleared every time the CPU reads the contents of the LSR. If the FIFO mode data continues to fill the FIFO beyond the trigger level, an overrun error occurs only after the FIFO is full and the next character has been completely received in the shift register. An OE is indicated to the CPU as soon as it happens. The character in the shift register is overwritten, but it is not transferred to the FIFO. <sup>‡</sup> Bits 1 through 4 are the error conditions that produce a receiver line status interrupt. <sup>†</sup> The line status register is intended for read operations only; writing to this register is not recommended outside of a factory testing environment. SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### PRINCIPLES OF OPERATION #### line status register (LSR) (continued)† - Bit 2‡: This bit is the parity error (PE) indicator. When bit 2 is set, it indicates that the parity of the received data character does not match the parity selected in the LCR (bit 4). The PE bit is cleared every time the CPU reads the contents of the LSR. In the FIFO mode, this error is associated with the particular character in the FIFO to which it applies. This error is revealed to the CPU when its associated character is at the top of the FIFO. - Bit 3<sup>‡</sup>: This bit is the framing error (FE) indicator. When bit 3 is set, it indicates that the received character did not have a valid (set) stop bit. The FE bit is cleared every time the CPU reads the contents of the LSR. In the FIFO mode, this error is associated with the particular character in the FIFO to which it applies. This error is revealed to the CPU when its associated character is at the top of the FIFO. The ACE tries to resynchronize after a framing error. To accomplish this, it is assumed that the framing error is due to the next start bit. The ACE samples this start bit twice and then accepts the input data. - Bit 4‡: This bit is the break interrupt (BI) indicator. When bit 4 is set, it indicates that the received data input was held cleared for longer than a full-word transmission time. A full-word transmission time is defined as the total time of the start, data, parity, and stop bits. The BI bit is cleared every time the CPU reads the contents of the LSR. In the FIFO mode, this error is associated with the particular character in the FIFO to which it applies. This error is revealed to the CPU when its associated character is at the top of the FIFO. When a break occurs, only one 0 character is loaded into the FIFO. The next character transfer is enabled after SIN goes to the marking state and receives the next valid start bit. - Bit 5: This bit is the THRE indicator. Bit 5 is set when the THR is empty, indicating that the ACE is ready to accept a new character. If the THRE interrupt is enabled when the THRE bit is set, an interrupt is generated. THRE is set when the contents of the THR are transferred to the transmitted shift register. This bit is cleared concurrent with the loading of the THR by the CPU. In the FIFO mode, this bit is set when the transmit FIFO is empty; it is cleared when at least one byte is written to the transmit FIFO. - Bit 6: This bit is the transmitter empty (TEMT) indicator. Bit 6 is set when the THR and the TSR are both empty. When either the THR or the TSR contains a data character, the TEMT bit is cleared. In the FIFO mode, this bit is set when the transmitter FIFO and shift register are both empty. - Bit 7: In the TL16C550B and the TL16C550BI mode, this bit is always cleared. In the TL16C450 mode, this bit is always cleared. In the FIFO mode, LSR7 is set when there is at least one parity, framing, or break error in the FIFO. It is cleared when the microprocessor reads the LSR and there are no subsequent errors in the FIFO. #### modem control register (MCR) The MCR is an 8-bit register that controls an interface with a modem, data set, or peripheral device that is emulating a modem. The contents of this register are summarized in Table 3 and are described in the following bulleted list. - Bit 0: This bit (DTR) controls the data terminal ready (\overline{DTR}) output. Setting bit 0 forces the \overline{DTR} output to its low state. When bit 0 is cleared, \overline{DTR} goes high. - Bit 1: This bit (RTS) controls the request to send (RTS) output in a manner identical to bit 0's control over the DTR output. - Bit 2: This bit (OUT1) controls the output 1 (OUT1) signal, a user-designated output signal, in a manner identical to bit 0's control over the DTR output. <sup>†</sup> The line status register is intended for read operations only; writing to this register is not recommended outside of a factory testing environment. ‡ Bits 1 through 4 are the error conditions that produce a receiver line status interrupt. SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### PRINCIPLES OF OPERATION #### modem control register (MCR) (continued) - Bit 3: This bit (OUT2) controls the output 2 (OUT2) signal, a user-designated output signal, in a manner identical to bit 0's control over the DTR output. - Bit 4: This bit provides a local loop back feature for diagnostic testing of the ACE. When this bit is set, the following occurs: - The SOUT is set high. - The SIN is disconnected. - The output of the TSR is looped back into the receiver shift register input. - The four modem control inputs (CTS, DSR, DCD, and RI) are disconnected. - The four modem control outputs (DTR, RTS, OUT1, and OUT2) are internally connected to the four modem control inputs. - The four modem control outputs are forced to their inactive (high) states. In the diagnostic mode, data that is transmitted is immediately received. This allows the processor to verify the transmit and receive data paths to the ACE. The receiver and transmitter interrupts are fully operational. The modem control interrupts are also operational, but the modem control interrupt's sources are now the lower four bits of the MCR instead of the four modern control inputs. All interrupts are still controlled by the IER. Bits 5 – 7: These bits are permanently cleared. #### modem status register (MSR) The MSR is an 8-bit register that provides information about the current state of the control lines from the modem, data set, or peripheral device to the CPU. Additionally, four bits of this register provide change information; when a control input from the modem changes state, the appropriate bit is set. All four bits are cleared when the CPU reads the MSR. The contents of this register are summarized in Table 3 and are described in the following bulleted list. - Bit 0: This bit is the change in clear-to-send ( $\Delta$ CTS) indicator. Bit 0 indicates that the $\overline{\text{CTS}}$ input has changed states since the last time it was read by the CPU . When this bit is set and the modem status interrupt is enabled, a modem status interrupt is generated. - Bit 1: This bit is the change in data set ready ( $\Delta$ DSR) indicator. Bit 1 indicates that the $\overline{\rm DSR}$ input has changed states since the last time it was read by the CPU. When this bit is set and the modem status interrupt is enabled, a modem status interrupt is generated. - Bit 2: This bit is the trailing edge of the ring indicator (TERI) detector. Bit 2 indicates that the RI input to the chip has changed from a low to a high state. When this bit is set and the modem status interrupt is enabled, a modem status interrupt is generated. - Bit 3: This bit is the change in data carrier detect ( $\triangle DCD$ ) indicator. Bit 3 indicates that the $\overline{DCD}$ input to the chip has changed states since the last time it was read by the CPU. When this bit is set and the modem status interrupt is enabled, a modem status interrupt is generated. - Bit 4: This bit is the complement of the clear-to-send (CTS) input. When bit 4 (loop) of the MCR is set, bit 4 is equivalent to the MCR bit 1 (RTS). - Bit 5: This bit is the complement of the data set ready (DSR) input. When bit 4 (loop) of the MCR is set, bit 5 is equivalent to the MCR bit 1 (DTR). SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### PRINCIPLES OF OPERATION #### modem status register (MSR) (continued) - Bit 6: This bit is the complement of the ring indicator (RI) input. When bit 4 (loop) of the MCR is set, bit 6 is equivalent to the MCRs bit 2 (OUT1). - Bit 7: This bit is the complement of the data carrier detect (DCD) input. When bit 4 (loop) of the MCR is set, bit 7 is equivalent to the MCRs bit 3 (OUT2). #### programmable baud generator The ACE contains a programmable baud generator that takes a clock input in the range between dc and 8 MHz and divides it by a divisor in the range between 1 and $(2^{16}-1)$ . The output frequency of the baud generator is $16 \times$ the baud rate. The formula for the divisor is: divisor # = XIN frequency input $\div$ (desired baud rate $\times$ 16) Two 8-bit registers, called divisor latches, store the divisor in a 16-bit binary format. These divisor latches must be loaded during initialization of the ACE in order to ensure desired operation of the baud generator. When either of the divisor latches is loaded, a 16-bit baud counter is also loaded to prevent long counts on initial load. Tables 8 and 9 illustrate the use of the baud generator with crystal frequencies of 1.8432 MHz and 3.072 MHz respectively. For baud rates of 38.4 kbit/s and below, the error obtained is very small. The accuracy of the selected baud rate is dependent on the selected crystal frequency. Refer to Figure 16 for examples of typical clock circuits. Table 8. Baud Rates Using a 1.8432-MHz Crystal | DESIRED<br>BAUD RATE | DIVISOR USED<br>TO GENERATE<br>16× CLOCK | PERCENT ERROR DIFFERENCE 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.69 | | 2400 | 48 | | | 3600 | 32 | | | 4800 | 24 | | | 7200 | 16 | | | 9600 | 12 | | | 19200 | 6 | | | 38400 | 3 | | | 56000 | 2 | 2.86 | #### PRINCIPLES OF OPERATION #### programmable baud generator (continued) Table 9. Baud Rates Using a 3.072-MHz Crystal | DESIRED<br>BAUD RATE | DIVISOR USED<br>TO GENERATE<br>16× CLOCK | PERCENT ERROR<br>DIFFERENCE BETWEEN<br>DESIRED AND ACTUAL | |----------------------|------------------------------------------|-----------------------------------------------------------| | 50 | 3840 | | | 75 | 2560 | | | 110 | 1745 | 0.026 | | 134.5 | 1428 | 0.034 | | 150 | 1280 | | | 300 | 640 | | | 600 | 320 | | | 1200 | 160 | | | 1800 | 107 | 0.312 | | 2000 | 96 | 7. 44 | | 2400 | 80 | 23 6 | | 3600 | 53 | 0.628 | | 4800 | 40 | -01 | | 7200 | 27 | 1.23 | | 9600 | 20 | | | 19200 | 10 | | | 38400 | 5 | | TYPICAL CRYSTAL OSCILLATOR NETWORK | CRYSTAL | RP | RX2 | C1 | C2 | |---------|------|--------|----------|----------| | 3.1 MHz | 1 ΜΩ | 1.5 kΩ | 10-30 pF | 40-60 pF | | 1.8 MHz | 1 ΜΩ | 1.5 kΩ | 10-30 pF | 40-60 pF | Figure 16. Typical Clock Circuits SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### PRINCIPLES OF OPERATION #### receiver buffer register (RBR) The ACE receiver section consists of a receiver shift register (RSR) and a RBR. The RBR is actually a 16-byte FIFO. Timing is supplied by the 16× receiver clock (RCLK). Receiver section control is a function of the ACE line control register. The ACE RSR receives serial data from the SIN terminal. The RSR then deserializes the data and moves it into the RBR FIFO. In the TL16C450 mode, when a character is placed in the receiver buffer register and the received data available interrupt is enabled, an interrupt is generated. This interrupt is cleared when the data is read out of the RBR. In the FIFO mode, the interrupts are generated based on the control setup in the FIFO control register. #### scratch register The scratch register is an 8-bit register that is intended for programmer use as a scratchpad in the sense that it temporarily holds the programmer's data without affecting any other ACE operation. #### transmitter holding register (THR) The ACE transmitter section consists of a THR and a transmitter shift register (TSR). The THR is actually a 16-byte FIFO. Timing is supplied by the baud out (BAUDOUT) clock signal. Transmitter section control is a function of the ACE's line control register. The ACE THR receives data off the internal data bus and when the shift register is idle, moves it into the TSR. The TSR serializes the data and outputs it at the SOUT. In the TL16C450 mode, when the THR is empty and the transmitter holding register empty (THRE) interrupt is enabled, an interrupt is generated. This interrupt is cleared when a character is loaded into the register. In the FIFO mode, the interrupts are generated based on the control setup in the FIFO control register. SLLS136B – JANUARY 1994 – REVISED AUGUST 1996 #### **MECHANICAL DATA** ### FN (S-PQCC-J\*\*) #### PLASTIC J-LEADED CHIP CARRIER 4040005/B 03/95 NOTES: A. All linear dimensions are in inches (millimeters). - B. This drawing is subject to change without notice. - C. Falls within JEDEC MS-018 SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### **MECHANICAL DATA** #### N (R-PDIP-T\*\*) #### **24 PIN SHOWN** #### PLASTIC DUAL-IN-LINE PACKAGE NOTES: A. All linear dimensions are in inches (millimeters). - B. This drawing is subject to change without notice. - C. Falls within JEDEC MS-011 - D. Falls within JEDEC MS-015 (32 pin only) SLLS136B - JANUARY 1994 - REVISED AUGUST 1996 #### **MECHANICAL DATA** #### PT (S-PQFP-G48) #### PLASTIC QUAD FLATPACK NOTES: A. All linear dimensions are in millimeters. - B. This drawing is subject to change without notice. - C. Falls within JEDEC MO-136 - D. This may also be a thermally-enhanced plastic package with leads connected to the die pads. #### **IMPORTANT NOTICE** Texas Instruments (TI) reserves the right to make changes to its products or to discontinue any semiconductor product or service without notice, and advises its customers to obtain the latest version of relevant information to verify, before placing orders, that the information being relied on is current and complete. TI warrants performance of its semiconductor products and related software 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, INTENDED, AUTHORIZED, OR WARRANTED TO BE SUITABLE FOR USE IN LIFE-SUPPORT APPLICATIONS, DEVICES OR SYSTEMS OR OTHER CRITICAL APPLICATIONS. Inclusion of TI products in such applications is understood to be fully at the risk of the customer. Use of TI products in such applications requires the written approval of an appropriate TI officer. Questions concerning potential risk applications should be directed to TI through a local SC sales office. In order to minimize risks associated with the customer's applications, adequate design and operating safeguards should be provided by the customer to minimize inherent or procedural hazards. TI assumes no liability for applications assistance, customer product design, software performance, or infringement of patents or services described herein. Nor does TI 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.