Printed December 17, 1996 ## DUAL UNIVERSAL ASYNCHRONOUSRECEIVER/TRANSMITTER ### **DESCRIPTION** The ST16C2450 is a dual universal asynchronous receiver and transmitter. Independent programmable baud rate generators are provided to select transmit and receive clock rates from 50Hz to 1.5 MHz for each UART section. The ST16C2450 is an improved version of the NS16C450 UART with higher operating speed and lower access time. The ST16C2450 on board status registers provides the error conditions, type and status of the transfer operation being performed. Included is complete MODEM control capability, and a processor interrupt system that may be software tailored to the user's requirements. The ST16C2450 provides internal loop-back capability for on board diagnostic testing. The ST16C2450 is fabricated in an advanced $0.6\mu$ CMOS process to achieve low drain power and high speed requirements. ### **FEATURES** - Functional compatible to NS16450, TI16C450 - Modem control signals (CTS\*, RTS\*, DSR\*, DTR\*, RI\*, CD\*) - Programmable character lengths (5, 6, 7, 8) - Even, odd, or no parity bit generation and detection - · Status report register - Independent transmit and receive control - TTL compatible inputs, outputs - 460.8 kHz transmit/receive operation with 7.372 MHz crystal or external clock source ### ORDERING INFORMATION | Part number | Package ( | Operating temperature | |---------------|-------------|-----------------------------------| | ST16C2450CP40 | Plastic-DIP | 0° C to + 70° C | | ST16C2450CJ44 | PLCC | $0^{\circ}$ C to + $70^{\circ}$ C | | ST16C2450CQ48 | TQFP | 0° C to + 70° C | | ST16C2450IQ48 | TOFP | -40° C to + 85° C | ## **PLCC Package** ## **Plastic-DIP Package** ## **BLOCK DIAGRAM** # **SYMBOL DESCRIPTION** | Symbol | P<br>40 | in<br>44 | Signal Type | Pin Description | |---------|---------|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D0-D7 | 1-8 | 2-9 | I/O | Bi-directional data bus. Eight bit, three state data bus to transfer information to or from the CPU. D0 is the least significant bit of the data bus and the first serial data bit to be received or transmitted. | | RX A/B | 10,9 | 11,10 | I | Serial data input A/B. The serial information (data) received from serial port to ST16C2450 receive input circuit. A mark (high) is logic one and a space (low) is logic zero. During the local loopback mode the RX input is disabled from external connection and connected to the TX output internally. | | TX A/B | 11,12 | 13,14 | 0 | Serial data output A/B. The serial data is transmitted via this pin with additional start, stop and parity bits. The TX will be held in mark (high) state during reset, local loopback mode or when the transmitter is disabled. | | CS* A/B | 14,15 | 16,17 | I | Chip select A/B. (active low) A low at this pin enables the ST16C2450 / CPU data transfer operation. | | XTAL1 | 16 | 18 | I | Crystal input 1 or external clock input. A crystal can be connected to this pin and XTAL2 pin to utilize the internal oscillator circuit. An external clock can be used to clock internal circuit and baud rate generator for custom transmission rates. | | XTAL2 | 17 | 19 | 0 | Crystal input 2 or buffered clock output. See XTAL1. | | IOW* | 18 | 20 | I | Write strobe. (active low) A low on this pin will transfer the contents of the CPU data bus to the addressed register. | | IOR* | 21 | 24 | I | Read strobe. (active low) A low level on this pin transfers the contents of the ST16C2450 data bus to the CPU. | | A0-A2 | 28-26 | 31-29 | I | Address select lines. To select internal registers. | | INT A/B | 30,29 | 33,32 | Ο | Interrupt output A/B. (active high) This pin goes high (when enabled by the interrupt enable register) whenever a receiver error, receiver data available, transmitter empty, or modem status condition flag is detected. | # **SYMBOL DESCRIPTION** | Symbol | 40 | in<br>44 | Signal Type | Pin Description | |----------|-------|----------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OP*A/B | 31,13 | 35,15 | 0 | Interrupt enable output (active low). This pin stays high when INT out pin is set to three state mode and goes low when INT pin is enabled via OP2*. See bit-3 modem control register (MCR bit-3). | | RTS* A/B | 32,24 | 36,27 | Ο | Request to send A/B (active low). To indicate that the transmitter has data ready to send. Writing a "1" in the modem control register (MCR bit-1) will set this pin to a low state. After the reset this pin will be set to high. Note that this pin does not have any effect on the transmit or receive operation. | | DTR* A/B | 33,34 | 37,38 | 0 | Data terminal ready A/B (active low). To indicate that ST16C2450 is ready to receive data. This pin can be controlled via the modem control register (MCR bit-0). Writing a "1" at the MCR bit-0 will set the DTR* output to low. This pin will be set to high state after writing a "0" to that register or after the reset. Note that this pin does not have any effect on the transmit or receive operation. | | RESET | 35 | 39 | I | Master reset. (active high) A high on this pin will reset all the outputs and internal registers. The transmitter output and the receiver input will be disabled during reset time. | | CTS* A/B | 36,25 | 40,28 | I | Clear to send A/B (active low). The CTS* signal is a MODEM control function input whose conditions can be tested by reading the MSR BIT-4. CTS* has no effect on the transmit or receive operation. | | DSR* A/B | 37,22 | 41,25 | I | Data set ready A/B (active low). A low on this pin indicates the MODEM is ready to exchange data with UART. This pin does not have any effect on the transmit or receive operation. | | CD* A/B | 38,19 | 42,21 | I | Carrier detect A/B (active low). A low on this pin indicates the carrier has been detected by the modem. | | RI* A/B | 39,23 | 43,26 | I | Ring detect indicator A/B (active low). A low on this pin indicates the modem has received a ringing signal from telephone line. | ## **SYMBOL DESCRIPTION** | Symbol | P<br>40 | in<br>44 | Signal Type | Pin Description | | |--------|---------|----------|-------------|--------------------------|--| | vcc | 40 | 44 | I | Power supply input. | | | GND | 20 | 22 | 0 | Signal and power ground. | | # **PROGRAMMING TABLE** | A2 | A1 | A0 | READ MODE | WRITE MODE | |----|----|-------|---------------------------|---------------------------| | 0 | 0 | 0 | Receive Holding Register | Transmit Holding Register | | 0 | 0 | 1 | | Interrupt Enable Register | | 0 | 1 | 0 | Interrupt Status Register | | | 0 | 1 | 1 | | Line Control Register | | 1 | 0 | 0 | | Modem Control Register | | 1 | 0 | 1 1 | Line Status Register | · · | | 1 | 1 | l o l | Modem Status Register | | | 1 | 1 | 1 1 | Scratchpad Register | Scratchpad Register | | 0 | 0 | 0 | . 0 | LSB of Divisor Latch | | 0 | 0 | 1 1 | | MSB of Divisor Latch | # ST16C2450 ACCESSIBLE REGISTERS A/B | A2 A1 A0 | Register | BIT-7 | BIT-6 | BIT-5 | BIT-4 | BIT-3 | BIT-2 | BIT-1 | BIT-0 | |----------|----------|----------------------------|-----------------|----------------------------|--------------------|------------------------------|----------------------------------------|---------------------------------|--------------------------------| | 0 0 0 | RHR | bit-7 | bit-6 | bit-5 | bit-4 | bit-3 | bit-2 | bit-1 | bit-0 | | 0 0 0 | THR | bit-7 | bit-6 | bit-5 | bit-4 | bit-3 | bit-2 | bit-1 | bit-0 | | 0 0 1 | IER | 0 | 0 | 0 | 0 | modem<br>status<br>interrupt | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register | receive<br>holding<br>register | | 0 1 0 | ISR | 0 | 0 | 0 | 0 | 0 | int<br>priority<br>bit-1 | int<br>priority<br>bit-0 | int<br>status | | 0 1 1 | LCR | divisor<br>latch<br>enable | set<br>break | set<br>parity | even<br>parity | parity<br>enable | stop<br>bits | word<br>length<br>bit-1 | word<br>length<br>bit-0 | | 1 0 0 | MCR | 0 | 0 | 0 | loop<br>back | OP2/<br>INT<br>enable | Not<br>used | RTS* | DTR* | | 1 0 1 | LSR | 0 | trans.<br>empty | trans.<br>holding<br>empty | break<br>interrupt | framing<br>error | parity<br>error | overrun<br>error | receive<br>data<br>ready | | 1 1 0 | MSR | CD | RI | DSR | CTS | delta<br>CD* | delta<br>RI* | delta<br>DSR* | delta<br>CTS* | | 1 1 1 | SPR | bit-7 | bit-6 | bit-5 | bit-4 | bit-3 | bit-2 | bit-1 | bit-0 | | 0 0 0 | DLL | bit-7 | bit-6 | bit-5 | bit-4 | bit-3 | bit-2 | bit-1 | bit-0 | | 0 0 1 | DLM | bit-15 | bit-14 | bit-13 | bit-12 | bit-11 | bit-10 | bit-9 | bit-8 | DLL and DLM are accessible only when LCR bit-7 is set to "1". ### **REGISTER FUNCTIONAL DESCRIPTIONS A/B** #### TRANSMIT AND RECEIVE HOLDING REGISTER The serial transmitter section consists of a Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the transmit hold register is provided in the Line Status Register (LSR). Writing to this register (THR) will transfer the contents of data bus (D7-D0) to the Transmit holding register whenever the transmitter holding register or transmitter shift register is empty. The transmit holding register empty flag will be set to "1" when the transmitter is empty or data is transferred to the transmit shift register. Note that a write operation should be performed when the transmit holding register empty flag is set. On the falling edge of the start bit, the receiver internal counter will start to count 7 1/2 clocks (16x clock) which is the center of the start bit. The start bit is valid if the RX is still low at the mid-bit sample of the start bit. Verifying the start bit prevents the receiver from assembling a false data character due to a low going noise spike on the RX input. Receiver status codes will be posted in the Line Status Register. #### PROGRAMMABLE BAUD RATE GENERATOR The ST16C2450 contains a programmable Baud Rate Generator that is capable of taking any clock input from DC-24 MHz and dividing it by any divisor from 1 to 2<sup>16</sup> -1. The output frequency of the Baudout\* is equal to 16X of transmission baud rate (Baudout\*=16 x Baud Rate). Customize Baud Rates can be achieved by selecting proper divisor values for MSB and LSB of baud rate generator. #### **INTERRUPT ENABLE REGISTER (IER)** The Interrupt Enable Register (IER) masks the incoming interrupts from receiver ready, transmitter empty, line status and modem status registers to the INT output pin. #### IER BIT-0: 0=disable the receiver ready interrupt. 1=enable the receiver ready interrupt. ### IER BIT-1: 0=disable the transmitter empty interrupt. 1=enable the transmitter empty interrupt. #### IER BIT-2: 0=disable the receiver line status interrupt. 1=enable the receiver line status interrupt. ### IER BIT-3: 0=disable the modem status register interrupt. 1=enable the modem status register interrupt. #### **IER BIT 4-7:** All these bits are set to logic zero. #### **INTERRUPT STATUS REGISTER (ISR)** The ST16C2450 provides four level prioritized interrupt conditions to minimize software overhead during data character transfers. The Interrupt Status Register (ISR) provides the source of the interrupt in prioritized matter. During the read cycle the ST16C2450 provides the highest interrupt level to be serviced by CPU. No other interrupts are acknowledged until the particular interrupt is serviced. The following are the prioritized interrupt levels: #### **Priority level** | Р | D2 | D1 | D0 | Source of the interrupt | |---|----|----|----|-----------------------------------------------| | 1 | 1 | 1 | 0 | LSR (Receiver Line Status<br>Register) | | 2 | 1 | 0 | 0 | RXRDY (Received Data<br>Ready) | | 3 | 0 | 1 | 0 | TXRDY( Transmitter Holding<br>Register Empty) | | 4 | 0 | 0 | 0 | MSR (Modem Status Register) | #### ISR BIT-0: 0=an interrupt is pending and the ISR contents may be used as a pointer to the appropriate interrupt service routine. 1=no interrupt pending. #### **ISR BIT 1-2:** Logical combination of these bits, provides the highest priority interrupt pending. ## **ISR BIT 3-7:** These bits are not used and are set to "0". #### LINE CONTROL REGISTER (LCR) The Line Control Register is used to specify the asynchronous data communication format. The number of the word length, stop bits, and parity can be selected by writing appropriate bits in this register. #### LCR BIT1-0: These two bits specify the word length to be transmitted or received. | BIT-1 | BIT-0 | Word length | |-------|-------|-------------| | 0 | 0 | 5 | | 0 | 1 | 6 | | 1 | 0 | 7 | | 1 | 1 | 8 | ## LCR BIT-2: The number of stop bits can be specified by this bit. | BIT-2 | Word length | Stop bit(s) | |-------|-------------|-------------| | 0 | 5,6,7,8 | 1 | | 1 | 5 | 1-1/2 | | 1 | 6,7,8 | 2 | ### LCR BIT-3: Parity or no parity can be selected via this bit. 0=no parity 1=a parity bit is generated during the transmission, receiver also checks for received parity. #### LCR BIT-4: If the parity bit is enabled, LCR BIT-4 selects the even or odd parity format. 0=ODD parity is generated by forcing an odd number of 1's in the transmitted data, receiver also checks for same format. 1= EVEN parity bit is generated by forcing an even the number of 1's in the transmitted data, receiver also checks for same format #### LCR BIT-5: If the parity bit is enabled, LCR BIT-5 selects the forced parity format. LCR BIT-5=1 and LCR BIT-4=0, parity bit is forced to "1" in the transmitted and received data. LCR BIT-5=1 and LCR BIT-4=1, parity bit is forced to "0" in the transmitted and received data. #### LCR BIT-6: Break control bit. It causes a break condition to be transmitted (the TX is forced to low state). 0=normal operating condition. 1=forces the transmitter output (TX) to go low to alert the communication terminal. #### LCR BIT-7: The internal baud rate counter latch enable (DLEN). 0=normal operation. 1=select divisor latch register. #### **MODEM CONTROL REGISTER (MCR)** This register controls the interface with the MODEM or a peripheral device (RS232). #### MCR BIT-0: 0=force DTR\* output to high. 1=force DTR\* output to low. #### MCR BIT-1: 0=force RTS\* output to high. 1=force RTS\* output to low. #### MCR BIT-2: not used except in local loop-back mode. #### MCR BIT-3: 0=set INT output pin to three state mode and OP2\* output to high. 1=set INT output pin to normal operating mode and OP2\* output to low. #### MCR BIT-4: 0=normal operating mode. 1=enable local loop-back mode (diagnostics). The transmitter output (TX) is set high (Mark condition), the receiver input (RX), CTS\*, DSR\*, CD\*, and RI\* are disabled. Internally the transmitter output is connected to the receiver input and DTR\*, RTS\*, MCR bit-2 and OP2\*/INT enable are connected to modem control inputs. In this mode , the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational, but the interrupts sources are now the lower four bits of the Modem Control Register instead of the four Modem Control inputs. The interrupts are still controlled by the IER . #### **MCR BIT 5-7:** Not used. Are set to zero permanently. ### LINE STATUS REGISTER (LSR) This register provides the status of data transfer to CPU. ## LSR BIT-0: 0=no data in receive holding register 1=data has been received and saved in the receive holding register. #### LSR BIT-1: 0=no overrun error (normal). 1=overrun error, next character arrived before receive holding register was emptied. #### LSR BIT-2: 0=no parity error (normal). 1=parity error, received data does not have correct parity information. #### LSR BIT-3: 0=no framing error (normal). 1=framing error received, received data did not have a valid stop bit. In #### LSR BIT-4: 0=no break condition (normal). 1=receiver received a break signal (RX was low for one character time frame). #### LSR BIT-5: 0=transmit holding register is full. ST16C2450 will not accept any data for transmission. 1=transmit holding register is empty. CPU can load the next character. #### LSR BIT-6: 0=transmitter holding and shift registers are full. 1=transmitter holding and shift registers are empty. ### LSR BIT-7: Not used. Set to "0". ### MODEM STATUS REGISTER (MSR) This register provides the current state of the control lines from the modem or peripheral to the CPU. Four bits of this register are used to indicate the changed information. These bits are set to "1" whenever a control input from the MODEM changes state. They are set to "0" whenever the CPU reads this register. #### MSR BIT-0: Indicates that the CTS\* input to the ST16C2450 has changed state since the last time it was read. #### MSR BIT-1: Indicates that the DSR\* input to the ST16C2450 has changed state since the last time it was read. #### MSR BIT-2: Indicates that the RI\* input to the ST16C2450 has changed from a low to a high state. #### MSR BIT-3: Indicates that the CD\* input to the ST16C2450 has changed state since the last time it was read. #### MSR BIT-4: This bit is equivalent to RTS in the MCR during local loop-back mode. It is the compliment of the CTS\* input. #### MSR BIT-5: This bit is equivalent to DTR in the MCR during local loop-back mode. It is the compliment of the DSR\* input. ### MSR BIT-6: This bit is equivalent to MCR bit-2 during local loop-back mode. It is the compliment of the RI\* input. #### MSR BIT-7: This bit is equivalent to OP2\*/INT enable in the MCR during local loop-back mode. It is the compliment to the CD\* input. Note: Whenever MSR BIT3-0: is set to logic "1", a MODEM Status Interrupt is generated. | SIGNALS | RESET STATE | |---------|------------------| | TX | High | | OP2* | High | | RTS* | High | | DTR* | High | | INT | Three state mode | ## SCRATCHPAD REGISTER (SR) ST16C2450 provides a temporary data register to store 8 bits of information for variable use. # BAUD RATE GENERATOR PROGRAMMING TABLE (1.8432 MHz CLOCK): | BAUD RATE | 16 x CLOCK<br>DIVISOR | % ERROR | |-----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|----------------| | 50<br>75<br>110<br>134.5<br>150<br>300<br>600<br>1200<br>2400<br>3600<br>4800<br>7200<br>9600 | 2304<br>1536<br>1047<br>857<br>768<br>384<br>192<br>96<br>48<br>32<br>24<br>16 | 0.026<br>0.058 | | 19.2K<br>38.4K<br>56K<br>115.2K | 6<br>3<br>2<br>1 | 2.77 | #### ST16C2450 EXTERNAL RESET CONDITION | REGISTERS | RESET STATE | |-----------|-----------------------------| | IER | IER BITS 0-7=0 | | ISR | ISR BIT-0=1, ISR BITS 1-7=0 | | LCR | LCR BITS 0-7=0 | | MCR | MCR BITS 0-7=0 | | LSR | LSR BITS 0-4=0, | | | LSR BITS 5-6=1 LSR, BIT 7=0 | | MSR | MSR BITS 0-3=0, | | | MSR BITS 4-7=input signal | # **AC ELECTRICAL CHARACTERISTICS** $T_A=0^{\circ}$ - 70° C ( -40° - +85° C for IP, IJ,IQ packages), Vcc=3.3 - 5.0 V ± 10% unless otherwise specified. | Symbol | Parameter | Limits | | | Units | Conditions | |----------------------------------------------------------|----------------------------------------------|--------|-----|-------------------|-------|-------------| | | | Min | Тур | Max | | | | Т | Clock high pulse duration | 20 | | | ns | | | T <sup>1</sup> | Clock low pulse duration | 20 | | | ns | | | $egin{array}{c} T_1 \ T_2 \ T_3 \ T_8 \ T_9 \end{array}$ | Clock rise/fall time | | | 10 | ns | | | T <sub>-</sub> | Chip select setup time | 0 | | . 0 | ns | | | T. | Chip select hold time | Ö | | | ns | | | T <sub>12</sub> | Data set up time | 15 | | | ns | | | T <sub>13</sub> | Data hold time | 15 | | | ns | | | T <sub>14</sub> | IOW* delay from chip select | 10 | | | ns | | | T <sub>15</sub> | IOW* strobe width | 50 | | | ns | | | T <sub>16</sub> | Chip select hold time from IOW* | 0 | | | ns | | | T <sub>17</sub> | Write cycle delay | 55 | | | ns | | | Tw | Write cycle=T <sub>15</sub> +T <sub>17</sub> | 105 | | | ns | | | T <sub>19</sub> | Data hold time | 15 | | | ns | | | T <sub>21</sub> | IOR* delay from chip select | 10 | | | ns | | | T <sub>23</sub> | IOR* strobe width | 65 | | | ns | | | T <sub>24</sub> | Chip select hold time from IOR* | 0 | | | ns | | | T <sub>25</sub> | Read cycle delay | 55 | | | ns | | | Tr | Read cycle=T <sub>23</sub> +T <sub>25</sub> | 115 | | | ns | | | T <sub>26</sub> | Delay from IOR* to data | | | 35 | ns | 100 pF load | | T <sub>28</sub> | Delay from IOW* to output | | | 50 | ns | 100 pF load | | T <sub>29</sub> | Delay to set interrupt from MODEM | | | 70 | ns | 100 pF load | | 29 | input | | | | | , | | T <sub>30</sub> | Delay to reset interrupt from IOR* | | | 70 | ns | 100 pF load | | T <sub>31</sub> | Delay from stop to set interrupt | | | 1 <sub>Rclk</sub> | ns | 100 pF load | | T <sub>32</sub> | Delay from IOR* to reset interrupt | | | 200 | ns | 100 pF load | | T <sub>33</sub> | Delay from initial INT reset to transmit | 8 | | 24 | * | , | | 33 | start | | | | | | | T <sub>34</sub> | Delay from stop to interrupt | | | 100 | ns | | | T <sub>35</sub> | Delay from IOW* to reset interrupt | | | 175 | ns | | | $T_R^{\mathfrak{S}}$ | Reset pulse width | 10 | | | ns | | | N | Baud rate devisor | 1 | | 216-1 | | | Note 1: \* = Baudout\* cycle ## **ABSOLUTE MAXIMUM RATINGS** Supply range Voltage at any pin Operating temperature Storage temperature Package dissipation 7 Volts GND-0.3 V to VCC+0.3 V 0° C to +70° C -40° C to +150° C 500 mW ## DC ELECTRICAL CHARACTERISTICS $T_{\Delta}=0^{\circ}$ - 70° C ( -40° - +85° C for IP, IJ, IQ packages), Vcc=3.3 - 5.0 V ± 10% unless otherwise specified. | Symbol | Parameter | Min | Limits<br>Typ | Max | Units | Conditions | |---------------------------------|---------------------------------|------|---------------|-----|-------|----------------------------------| | $V_{_{ILCK}}$ | Clock input low level | -0.5 | | 0.6 | V | | | $V_{\text{IHCK}}$ | Clock input high level | 3.0 | | VCC | V | | | V <sub>IL</sub> | Input low level | -0.5 | | 8.0 | V | | | $V_{{}_{\hspace{1em} \mapsto}}$ | Input high level | 2.2 | | VCC | V | | | V | Output low level on all outputs | | | 0.4 | V | I <sub>OI</sub> = 6 mA | | V <sub>OH</sub> | Output high level | 2.4 | | | V | I <sub>OH</sub> = -6 mA | | I <sub>cc</sub> | Avg. power supply current | | 2 | 2.5 | mA | On | | I | Input leakage | | | ±10 | μΑ | | | I <sub>CL</sub> | Clock leakage | | | ±10 | μA | | | $V_{_{ILCK}}$ | Clock input low level | -0.3 | | 0.8 | V | Vcc=3.0 V | | VIHCK | Clock input high level | 2.4 | | VCC | V | Vcc=3.0 V | | VIL | Input low level | -0.3 | | 8.0 | V | Vcc=3.0 V | | V <sub>IH</sub> | Input high level | 2.0 | | VCC | V | Vcc=3.0 V | | V <sub>ol</sub> | Output low level on all outputs | | | 0.4 | V | Vcc=3.0 V, I <sub>OI</sub> = 4.2 | | OL | | | | | | mA OL | | $V_{OH}$ | Output high level | 2.0 | | | l v | Vcc=3.0 V, I <sub>OH</sub> = -1 | | Оп | . 5 | | | | | mA | | I <sub>cc</sub> | Avg power supply current | | 0.6 | 0.8 | mA | Vcc=3.0 V | ## **GENERAL READ TIMING** ## **GENERAL WRITE TIMING** ## MODEM TIMING # TRANSMIT TIMING