# imall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



## Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China



5 V, 3.3 V and 2.5 V dual UART, 5 Mbit/s (max.) with 32-byte FIFOs, IrDA encoder/decoder, and 68 mode  $\mu$ P interface

Rev. 02 — 2 November 2009

**Product data sheet** 

## 1. General description

The SC68C652B is a 2 channel Universal Asynchronous Receiver and Transmitter (UART) used for serial data communications. Its principal function is to convert parallel data into serial data and vice versa. The UART can handle serial data rates up to 5 Mbit/s. The SC68C652B is pin compatible with the SC68C2550B. The SC68C652B provides enhanced UART functions with 32-byte FIFOs, modem control interface, DMA mode data transfer, and infrared (IrDA) encoder/decoder. The DMA mode data transfer is controlled by the FIFO trigger levels and the TXRDYn and RXRDYn signals. On-board status registers provide the user with error indications and operational status. System interrupts and modem control features may be tailored by software to meet specific user requirements. An internal loopback capability allows on-board diagnostics. Independent programmable baud rate generators are provided to select transmit and receive baud rates.

The SC68C652B operates at 5 V, 3.3 V and 2.5 V and the industrial temperature range, and is available in the plastic LQFP48 package.

## 2. Features

- 2 channel UART with 68 mode (Motorola) μP interface
- 5 V, 3.3 V and 2.5 V operation
- 5 V tolerant on input only pins<sup>1</sup>
- Industrial temperature range (-40 °C to +85 °C)
- Software compatible with industry standard 16C450, 16C550, and SC16C650
- Up to 5 Mbit/s baud rate at 5 V and 3.3 V, and 3 Mbit/s at 2.5 V
- 32-byte transmit FIFO to reduce the bandwidth requirement of the external CPU
- 32-byte receive FIFO with error flags to reduce the bandwidth requirement of the external CPU
- Independent transmit and receive UART control
- Four selectable receive and transmit FIFO interrupt trigger levels
- Automatic software (Xon/Xoff) and hardware (RTSn/CTSn) flow control
- Programmable Xon/Xoff characters
- Software selectable baud rate generator
- Standard modem interface or infrared IrDA encoder/decoder interface
- Supports IrDA version 1.0 (up to 115.2 kbit/s)
- Sleep mode



<sup>1.</sup> For data bus pins D7 to D0, see <u>Table 27 "Limiting values"</u>.

- Standard asynchronous error and framing bits (Start, Stop, and Parity Overrun Break)
- Transmit, Receive, Line Status, and Data Set interrupts independently controlled
- Fully programmable character formatting:
  - 5, 6, 7, or 8-bit characters
  - Even, odd, or no parity formats
  - 1,  $1\frac{1}{2}$ , or 2 stop bit generation
  - Baud generation (DC to 5 Mbit/s)
- False start bit detection
- Complete status reporting capabilities
- 3-state output 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
- Prioritized interrupt system controls
- Modem control functions (CTS, RTS, DSR, DTR, RI, and CD)

## 3. Ordering information

| Table 1. Ordering | g information |                                                                                  |          |
|-------------------|---------------|----------------------------------------------------------------------------------|----------|
| Type number       | Package       |                                                                                  |          |
|                   | Name          | Description                                                                      | Version  |
| SC68C652BIB48     | LQFP48        | plastic low profile quad flat package; 48 leads; body $7 \times 7 \times 1.4$ mm | SOT313-2 |

#### Dual UART with 32-byte FIFOs and IrDA encoder/decoder

## 4. Block diagram



Dual UART with 32-byte FIFOs and IrDA encoder/decoder

## 5. Pinning information

## 5.1 Pinning



## 5.2 Pin description

| Table 2. | Pin des | cription |                                                                                                                                                                                                                 |
|----------|---------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol   | Pin     | Туре     | Description                                                                                                                                                                                                     |
| A0       | 28      | I        | Address 0 select bit. Internal registers address selection.                                                                                                                                                     |
| A1       | 27      | I        | Address 1 select bit. Internal registers address selection.                                                                                                                                                     |
| A2       | 26      | I        | Address 2 select bit. Internal registers address selection.                                                                                                                                                     |
| A3       | 11      | I        | Address 3 select bit. A3 is used to select Channel A or<br>Channel B. A logic LOW selects Channel A, and a logic HIGH<br>selects Channel B. (See <u>Table 3</u> .)                                              |
| CDA      | 40      | I        | Carrier Detect (active LOW). These inputs are associated with                                                                                                                                                   |
| CDB      | 16      | I        | individual UART channels A and B. A logic 0 on these pins indicates that a carrier has been detected by the modem for that channel.                                                                             |
| CS       | 10      | I        | <b>Chip Select (active LOW).</b> This pin enables data transfers between the user CPU and the SC68C652B for the channel(s) addressed. Individual UART sections (A, B) are addressed by A3. See <u>Table 3</u> . |

| Table 2. | Pin desc          | ription . | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|----------|-------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Symbol   | Pin               | Туре      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| CTSA     | 38                | I         | Clear to Send (active LOW). These inputs are associated with                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| CTSB     | 23                | I         | individual UART channels A and B. A logic 0 (LOW) on the CTSn pins indicates the modem or data set is ready to accept transmit data from the SC68C652B. Status can be tested by reading MSR[4]. These pins have no effect on the UART's transmit or receive operation.                                                                                                                                                                                                                                        |  |
| D0       | 44                | I/O       | Data bus (bidirectional). These pins are the 8-bit, 3-state data                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| D1       | 45                | I/O       | bus for transferring information to or from the controlling CPU. D0 is<br>- the least significant bit and the first data bit in a transmit or receive                                                                                                                                                                                                                                                                                                                                                         |  |
| D2       | 46                | I/O       | serial data stream.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| D3       | 47                | I/O       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| D4       | 48                | I/O       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| D5       | 1                 | I/O       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| D6       | 2                 | I/O       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| D7       | 3                 | I/O       | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| DSRA     | 39                | I         | Data Set Ready (active LOW). These inputs are associated with                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| DSRB     | 20                | I         | individual UART channels A and B. A logic 0 (LOW) on these pins<br>indicates the modem or data set is powered-on and is ready for<br>data exchange with the UART. These pins have no effect on the<br>UART's transmit or receive operation.                                                                                                                                                                                                                                                                   |  |
| DTRA     | 34                | 0         | Data Terminal Ready (active LOW). These outputs are                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| DTRB     | 35                | Ο         | associated with individual UART channels A and B. A logic 0<br>(LOW) on these pins indicates that the SC68C652B is powered<br>and ready. These pins can be controlled via the modem control<br>register. Writing a logic 1 to MCR[0] will set the DTRn output pir<br>logic 0 (LOW), enabling the modem. The output of these pins w<br>be a logic 1 after writing a logic 0 to MCR[0], or after a reset. The<br>pins have no effect on the UART's transmit or receive operation                                |  |
| GND      | 17, 24            | I         | Signal and power ground                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| IRQ      | 30                | 0         | <b>Interrupt Request.</b> Interrupts from UART channels A-B are wire-ORed internally to function as a single $\overline{IRQ}$ interrupt. This pin transitions to a logic 0 (if enabled by the interrupt enable register) whenever a UART channel(s) requires service. Individual channel interrupt status can be determined by addressing each channel through its associated internal register, using $\overline{CS}$ and A3. An external pull-up resistor must be connected between this pin and $V_{CC}$ . |  |
| R/W      | 15                | I         | A logic LOW on this pin will transfer the contents of the data bus (D[7:0]) from an external CPU to an internal register that is defined by address bits A[2:0]. A logic HIGH on this pin will load the contents of an internal register defined by address bits A[2:0] on the SC68C652B data bus (D[7:0]) for access by an external CPU.                                                                                                                                                                     |  |
| n.c.     | 12, 25,<br>29, 37 | -         | not connected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| OP2A     | 32                | 0         | Output 2 (user-defined). This function is associated with                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| OP2B     | 9                 | 0         | individual channels A and B. The state of these pins is defined by<br>the user through the software settings of MCR[3]. OP2A/OP2B is a<br>logic 0 when MCR[3] is set to a logic 1. OP2A/OP2B is a logic 1<br>when MCR[3] is set to a logic 0. The output of these two pins is<br>HIGH after reset.                                                                                                                                                                                                            |  |

| Table 2. | Pin desc | ription . | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------|----------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol   | Pin      | Туре      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| RESET    | 36       | I         | <b>Reset (active LOW).</b> This pin will reset the internal registers and all the outputs. The UART transmitter output and the receiver input will be disabled during reset time. See <u>Section 7.11 "SC68C652B</u> external reset condition" for initialization details.                                                                                                                                                                                                                                                  |
| RIA      | 41       | I         | Ring Indicator (active LOW). These inputs are associated with                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| RIB      | 21       | I         | individual UART channels A and B. A logic 0 on these pins<br>indicates the modem has received a ringing signal from the<br>telephone line. A logic 1 transition on these input pins generates an<br>interrupt.                                                                                                                                                                                                                                                                                                              |
| RTSA     | 33       | 0         | Request to Send (active LOW). These outputs are associated                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| RTSB     | 22       | 0         | with individual UART channels, A and B. A logic 0 on the RTSn pin<br>indicates the transmitter has data ready and waiting to send.<br>Writing a logic 1 in the modem control register MCR[1] will set this<br>pin to a logic 0, indicating data is available. After a reset these pins<br>are set to a logic 1. These pins have no effect on the UART's<br>transmit or receive operation.                                                                                                                                   |
| RXA      | 5        | I         | Receive data input. These inputs are associated with individual                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| RXB      | 4        | I         | serial channel data to the SC68C652B receive input circuits A and<br>B. The RXn pin will be a logic 1 during reset, idle (no data), or when<br>the transmitter is disabled. During the local loopback mode, these<br>RXn input pins are disabled and transmit data is connected to the<br>UART receive input internally.                                                                                                                                                                                                    |
| RXRDYA   | 31       | 0         | Receive Ready (active LOW). RXRDYA or RXRDYB goes LOW                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RXRDYB   | 18       | 0         | when the trigger level has been reached or the FIFO has at least one character. It goes HIGH when the receive FIFO is empty.                                                                                                                                                                                                                                                                                                                                                                                                |
| TXA      | 7        | 0         | Transmit data A, B. These outputs are associated with individual                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ТХВ      | 8        | 0         | serial transmit channel data from the SC68C652B. The TXn pin will<br>be a logic 1 during reset, idle (no data), or when the transmitter is<br>disabled. During the local loopback mode, the TXn output pins are<br>disabled and transmit data is internally connected to the UART<br>receive input.                                                                                                                                                                                                                         |
| TXRDYA   | 43       | 0         | Transmit Ready A, B (active LOW). These outputs provide the                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| TXRDYB   | 6        | 0         | transmit FIFO/THR status for individual transmit channels A and B.<br>TXRDYn is primarily intended for monitoring DMA mode 1 transfers<br>for the transmit data FIFOs. An individual channel's TXRDYA,<br>TXRDYB buffer ready status is indicated by logic 0, that is, at least<br>one location is empty and available in the FIFO or THR. This pin<br>goes to a logic 1 (DMA mode 1) when there are no more empty<br>locations in the FIFO or THR. This signal can also be used for<br>single mode transfers (DMA mode 0). |

| Table 2.        | Pin desc | ription . | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|----------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol          | Pin      | Туре      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| V <sub>CC</sub> | 19, 42   | I         | Power supply input.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| XTAL1           | 13       | I         | <b>Crystal or external clock input.</b> Functions as a crystal input or as an external clock input. A crystal can be connected between this pin and XTAL2 to form an internal oscillator circuit (see Figure 3). This configuration requires an external 1 M $\Omega$ resistor between the XTAL1 and XTAL2 pins. Alternatively, an external clock can be connected to this pin to provide custom data rates. See Section 6.8 "Programmable baud rate generator". |
| XTAL2           | 14       | 0         | <b>Output of the crystal oscillator or buffered clock.</b> (See also XTAL1.) XTAL2 is used as a crystal oscillator output or a buffered clock output. Should be left open if an external clock is connected to XTAL1. For extended frequency operation, this pin should be tied to $V_{CC}$ via a 2 k $\Omega$ resistor.                                                                                                                                         |

## 6. Functional description

The SC68C652B UART is pin-compatible with the SC68C2550B UART. It provides more enhanced features. All additional features are provided through a special enhanced feature register.

The UART will perform serial-to-parallel conversion on data characters received from peripheral devices or modems, and parallel-to-parallel conversion on data characters transmitted by the processor. The complete status of each channel of the SC68C652B UART can be read at any time during functional operation by the processor.

The SC68C652B can be placed in an alternate mode (FIFO mode) relieving the processor of excessive software overhead by buffering received/transmitted characters. Both the receiver and transmitter FIFOs can store up to 64 bytes (including three additional bits of error status per byte for the receiver FIFO) and have selectable or programmable trigger levels. Primary outputs RXRDYn and TXRDYn allow signalling of DMA transfers.

The SC68C652B has selectable hardware flow control and software flow control. Hardware flow control significantly reduces software overhead and increases system efficiency by automatically controlling serial data flow using the RTSn output and CTSn input signals. Software flow control automatically controls data flow by using programmable Xon/Xoff characters.

The UART includes a programmable baud rate generator that can divide the timing reference clock input by a divisor between 1 and  $(2^{16} - 1)$ .

### 6.1 UART A-B functions

. ...

The UART provides the user with the capability to bidirectionally transfer information between an external CPU, the SC68C652B package, and an external serial device. A logic 0 on chip select pin  $\overline{CS}$  and A3 (LOW or HIGH) allows the user to configure, send data, and/or receive data via UART channels A and B. Individual channel select functions are shown in Table 3.

| Channel s | election using CS pin |                                                            |
|-----------|-----------------------|------------------------------------------------------------|
| A3        | UART channel          |                                                            |
| -         | none                  |                                                            |
| 0         | channel A             |                                                            |
| 1         | channel B             |                                                            |
|           |                       | A3     UART channel       -     none       0     channel A |

## 6.2 Internal registers

The SC68C652B provides two sets of internal registers (A and B) consisting of 17 registers each for monitoring and controlling the functions of each channel of the UART. These registers are shown in <u>Table 4</u>. The UART registers function as data holding registers (THR/RHR), interrupt status and control registers (IER/ISR), a FIFO control register (FCR), line status and control registers (LCR/LSR), modem status and control registers (MCR/MSR), programmable data rate (clock) control registers (DLL/DLM), and a user accessible scratchpad register (SPR), along with advanced feature registers EFR and Xon1, Xon2, Xoff1 and Xoff2.

| 2    | A1       | <b>A</b> 0 | Read mode                       | Write mode                  |
|------|----------|------------|---------------------------------|-----------------------------|
| iene | ral regi | ister set  | (THR/RHR, IER/ISR, MCR/MSR      | , FCR, LSR, SPR) <u>[1]</u> |
|      | 0        | 0          | Receive Holding Register        | Transmit Holding Register   |
|      | 0        | 1          | Interrupt Enable Register       | Interrupt Enable Register   |
|      | 1        | 0          | Interrupt Status Register       | FIFO Control Register       |
|      | 1        | 1          | Line Control Register           | Line Control Register       |
|      | 0        | 0          | Modem Control Register          | Modem Control Register      |
|      | 0        | 1          | Line Status Register            | n/a                         |
|      | 1        | 0          | Modem Status Register           | n/a                         |
|      | 1        | 1          | Scratchpad Register             | Scratchpad Register         |
| ud   | rate re  | gister s   | et (DLL/DLM)[2]                 |                             |
|      | 0        | 0          | LSB of Divisor Latch            | LSB of Divisor Latch        |
|      | 0        | 1          | MSB of Divisor Latch            | MSB of Divisor Latch        |
| ha   | nced re  | egister s  | set (EFR, Xon1, Xon2, Xoff1, Xo | if2) <u><sup>[3]</sup></u>  |
|      | 1        | 0          | Enhanced Feature Register       | Enhanced Feature Register   |
|      | 0        | 0          | Xon1 word                       | Xon1 word                   |
|      | 0        | 1          | Xon2 word                       | Xon2 word                   |
|      | 1        | 0          | Xoff1 word                      | Xoff1 word                  |
|      | 1        | 1          | Xoff2 word                      | Xoff2 word                  |

#### Table 4. Internal registers decoding

[1] These registers are accessible only when LCR[7] is a logic 0.

[2] These registers are accessible only when LCR[7] is a logic 1.

[3] Enhanced Feature Register, Xon1, Xon2, and Xoff1, Xoff2 are accessible only when the LCR is set to 'BFh'.

## 6.3 FIFO operation

The 32-byte transmit and receive data FIFOs are enabled by the FIFO Control Register bit 0 (FCR[0]). With SC68C2550B devices, the user can set the receive trigger level, but not the transmit trigger level. The SC68C652B provides independent trigger levels for both receiver and transmitter. To remain compatible with SC68C2550B, the transmit interrupt trigger level is set to 16 following a reset. It should be noted that the user can set the transmit trigger levels by writing to the FCR register, but activation will not take place until EFR[4] is set to a logic 1. The receiver FIFO section includes a time-out function to ensure data is delivered to the external CPU. An interrupt is generated whenever the Receive Holding Register (RHR) has not been read following the loading of a character or the receive trigger level has not been reached.

| Table 5. Flow control  | mechanism                 |    |               |               |
|------------------------|---------------------------|----|---------------|---------------|
| Selected trigger level | <b>IRQ</b> pin activation |    | Negate RTS or | Assert RTS or |
| (characters)           | RX                        | ТХ | send Xoff     | send Xon      |
| 8                      | 8                         | 16 | 8             | 0             |
| 16                     | 16                        | 8  | 16            | 7             |
| 24                     | 24                        | 24 | 24            | 15            |
| 28                     | 28                        | 30 | 28            | 23            |

## 6.4 Hardware flow control

When automatic hardware flow control is enabled, the SC68C652B monitors the CTSn pin for a remote buffer overflow indication and controls the RTSn pin for local buffer overflows. Automatic hardware flow control is selected by setting EFR[6] (RTS) and EFR[7] (CTS) to a logic 1. If CTSn transitions from a logic 0 to a logic 1 indicating a flow control request, ISR[5] will be set to a logic 1 (if enabled via IER[6:7]), and the SC68C652B will suspend TXn transmissions as soon as the stop bit of the character in process is shifted out. Transmission is resumed after the CTSn input returns to a logic 0, indicating more data may be sent.

With the auto-RTS function enabled, an interrupt is generated when the receive FIFO reaches the programmed trigger level. The RTSn pin will not be forced to a logic 1 (RTS off), until the receive FIFO reaches the next trigger level. However, the RTSn pin will return to a logic 0 after the data buffer (FIFO) is unloaded to the next trigger level below the programmed trigger level. However, under the above described conditions, the SC68C652B will continue to accept data until the receive FIFO is full.

## 6.5 Software flow control

When software flow control is enabled, the SC68C652B compares one or two sequential receive data characters with the programmed Xon or Xoff character value(s). If received character(s) match the programmed Xoff values, the SC68C652B will halt transmission as soon as the current character(s) has completed transmission. When a match occurs, the receive ready (if enabled via Xoff IER[5]) flags will be set and the interrupt output pin (if receive interrupt is enabled) will be activated. Following a suspension due to a match of the Xoff characters' values, the SC68C652B will monitor the receive data stream for a match to the Xon1/Xon2 character value(s). If a match is found, the SC68C652B will resume operation and clear the flags (ISR[4]).

Reset initially sets the contents of the Xon/Xoff 8-bit flow control registers to a logic 0. Following reset, the user can write any Xon/Xoff value desired for software flow control. Different conditions can be set to detect Xon/Xoff characters and suspend/resume transmissions. When double 8-bit Xon/Xoff characters are selected, the SC68C652B compares two consecutive receive characters with two software flow control 8-bit values (Xon1, Xon2, Xoff1, Xoff2) and controls TXn transmissions accordingly. Under the above described flow control mechanisms, flow control characters are not placed (stacked) in the user accessible receive data buffer or FIFO. When using a software flow control, the Xon/Xoff characters cannot be used for data transfer.

In the event that the receive buffer is overfilling and flow control needs to be executed, the SC68C652B automatically sends an Xoff message (when enabled) via the serial TXn output to the remote modem. The SC68C652B sends the Xoff1/Xoff2 characters as soon

as received data passes the programmed trigger level. To clear this condition, the SC68C652B will transmit the programmed Xon1/Xon2 characters as soon as receive data drops below the programmed trigger level.

### 6.6 Special feature software flow control

A special feature is provided to detect an 8-bit character when EFR[5] is set. When 8-bit character is detected, wit will be placed on the user-accessible data stack along with normal incoming receive data. This condition is selected in conjunction with EFR[3:0]. Note that software flow control should be turned off when using this special mode by setting EFR[3:0] to a logic 0.

The SC68C652B compares each incoming receive character with Xoff2 data. If a match exists, the received data will be transferred to the FIFO, and ISR[4] will be set to indicate detection of a special character. Although <u>Table 9 "SC68C652B internal registers"</u> shows each X-register with eight bits of character information, the actual number of bits is dependent on the programmed word length. Line Control Register bits LCR[1:0] define the number of character bits, that is, either 5 bits, 6 bits, 7 bits or 8 bits. The word length selected by LCR[1:0] also determine the number of bits that will be used for the special character comparison. Bit 0 in the X-registers corresponds with the LSB bit for the receive character.

### 6.7 Hardware/software and time-out interrupts

The interrupts are enabled by IER[3:0]. Care must be taken when handling these interrupts. Following a reset, if Interrupt Enable Register (IER) bit 1 = 1, the SC68C652B will issue a Transmit Holding Register interrupt. This interrupt must be serviced prior to continuing operations. The ISR register provides the current singular highest priority interrupt only. It could be noted that CTS and RTS interrupts have lowest interrupt priority. A condition can exist where a higher priority interrupt may mask the lower priority CTS/RTS interrupt(s). Only after servicing the higher pending interrupt will the lower priority CTS/RTS interrupt(s) be reflected in the status register. Servicing the interrupt without investigating further interrupt conditions can result in data errors.

When two interrupt conditions have the same priority, it is important to service these interrupts correctly. Receive Data Ready and Receive Time-Out have the same interrupt priority (when enabled by IER[0]). The receiver issues an interrupt after the number of characters have reached the programmed trigger level. In this case, the SC68C652B FIFO may hold more characters than the programmed trigger level. Following the removal of a data byte, the user should re-check LSR[0] for additional characters. A Receive Time-Out will not occur if the receive FIFO is empty. The time-out counter is reset at the center of each stop bit received or each time the receive holding register (RHR) is read. The actual time-out value is 4 character time, including data information length, start bit, parity bit, and the size of stop bit, that is,  $1 \times$ ,  $1.5 \times$ , or  $2 \times$  bit times.

### 6.8 Programmable baud rate generator

The SC68C652B supports high speed modem technologies that have increased input data rates by employing data compression schemes. For example, a 33.6 kbit/s modem that employs data compression may require a 115.2 kbit/s input data rate. A 128.0 kbit/s ISDN modem that supports data compression may need an input data rate of 460.8 kbit/s. The SC68C652B can support a standard data rate of 921.6 kbit/s.

A single baud rate generator is provided for the transmitter and receiver, allowing independent transmit/receive channel control. The programmable baud rate generator is capable of operating with a frequency of up to 80 MHz. To obtain maximum data rate, it is necessary to use full rail swing on the clock input. The SC68C652B can be configured for internal or external clock operation. For internal clock oscillator operation, an industry standard microprocessor crystal is connected externally between the XTAL1 and XTAL2 pins. Alternatively, an external clock can be connected to the XTAL1 pin to clock the internal baud rate generator for standard or custom rates (see Table 6).

The generator divides the input 16× clock by any divisor from 1 to  $(2^{16} - 1)$ . The SC68C652B divides the basic external clock by 16. The basic 16× clock provides table rates to support standard and custom applications using the same system design. The rate table is configured via the DLL and DLM internal register functions. Customized baud rates can be achieved by selecting the proper divisor values for the MSB and LSB sections of baud rate generator.

Programming the baud rate generator registers DLM (MSB) and DLL (LSB) provides a user capability for selecting the desired final baud rate. The example in <u>Table 6</u> shows the selectable baud rate table available when using a 1.8432 MHz external clock input.



| Output<br>baud rate | Output<br>16× clock divisor<br>(decimal) | Output<br>16× clock divisor<br>(HEX) | DLM<br>program value<br>(HEX) | DLL<br>program value<br>(HEX) |
|---------------------|------------------------------------------|--------------------------------------|-------------------------------|-------------------------------|
| 50                  | 2304                                     | 900                                  | 09                            | 00                            |
| 75                  | 1536                                     | 600                                  | 06                            | 00                            |
| 110                 | 1047                                     | 417                                  | 04                            | 17                            |
| 150                 | 768                                      | 300                                  | 03                            | 00                            |
| 300                 | 384                                      | 180                                  | 01                            | 80                            |
| 600                 | 192                                      | C0                                   | 00                            | C0                            |
| 1200                | 96                                       | 60                                   | 00                            | 60                            |
| 2400                | 48                                       | 30                                   | 00                            | 30                            |
| 3600                | 32                                       | 20                                   | 00                            | 20                            |
| 4800                | 24                                       | 18                                   | 00                            | 18                            |
| 7200                | 16                                       | 10                                   | 00                            | 10                            |
| 9600                | 12                                       | 0C                                   | 00                            | 0C                            |
| 19.2 k              | 6                                        | 06                                   | 00                            | 06                            |
| 38.4 k              | 3                                        | 03                                   | 00                            | 03                            |
| 57.6 k              | 2                                        | 02                                   | 00                            | 02                            |
| 115.2 k             | 1                                        | 01                                   | 00                            | 01                            |

 Table 6.
 Baud rate generator programming table using a 1.8432 MHz clock

## 6.9 DMA operation

The SC68C652B FIFO trigger level provides additional flexibility to the user for block mode operation. The user can optionally operate the transmit and receive FIFOs in the DMA mode (FCR[3]). The DMA mode affects the state of the RXRDYn and TXRDYn output pins. Table 7 and Table 8 show this.

| Table 7. | Effect of DMA mode on | state of RXRDYn pin |
|----------|-----------------------|---------------------|
|----------|-----------------------|---------------------|

| Non-DMA mode                | DMA mode                                                                 |
|-----------------------------|--------------------------------------------------------------------------|
| 1 = FIFO empty              | 0-to-1 transition when FIFO empties                                      |
| 0 = at least 1 byte in FIFO | 1-to-0 transition when FIFO reaches trigger level,<br>or time-out occurs |

| Table 8. Effect of DMA mode on state of TXRDYn pi |
|---------------------------------------------------|
|---------------------------------------------------|

| Non-DMA mode                | DMA mode                                             |
|-----------------------------|------------------------------------------------------|
| 1 = at least 1 byte in FIFO | 0-to-1 transition when FIFO becomes full             |
| 0 = FIFO empty              | 1-to-0 transition when FIFO goes below trigger level |

## 6.10 Loopback mode

The internal loopback capability allows on-board diagnostics. In the loopback mode, the normal modem interface pins are disconnected and reconfigured for loopback internally (see Figure 4). MCR[3:0] register bits are used for controlling loopback diagnostic testing. In the loopback mode, the transmitter output pin (TXn) and the receiver input pin (RXn) are disconnected from their associated interface pins, and instead are connected together internally. The CTSn, DSRn, CDn, and RIn pins are disconnected from their normal modem control inputs pins, and instead are connected internally to MCR[1]  $\overline{\text{RTS}}$ ,

MCR[0] DTR, MCR[3] (OP2) and MCR[2] (OP1). Loopback test data is entered into the transmit holding register via the user data bus interface, D0 to D7. The transmit UART serializes the data and passes the serial data to the receive UART via the internal loopback connection. The receive UART converts the serial data back into parallel data that is then made available at the user data interface D0 to D7. The user optionally compares the received data to the initial transmitted data for verifying error-free operation of the UART transmit/receive circuits.

In this mode, the receiver and transmitter interrupts are fully operational. The Modem Control Interrupts are also operational.



## 7. Register descriptions

<u>Table 9</u> details the assigned bit functions for the SC68C652B internal registers. The assigned bit functions are more fully defined in Section 7.1 through Section 7.11.

| <b>Fab</b> | le 9.      | S          | C68C652E                 | 3 internal re          | egisters                        |                                 |                                  |                                                           |                                    |                                        |                                              |                                |
|------------|------------|------------|--------------------------|------------------------|---------------------------------|---------------------------------|----------------------------------|-----------------------------------------------------------|------------------------------------|----------------------------------------|----------------------------------------------|--------------------------------|
| A2         | <b>A</b> 1 | <b>A</b> 0 | Register                 | Default <sup>[1]</sup> | Bit 7                           | Bit 6                           | Bit 5                            | Bit 4                                                     | Bit 3                              | Bit 2                                  | Bit 1                                        | Bit 0                          |
| Ger        | neral      | reg        | ister set <sup>[2]</sup> |                        |                                 |                                 |                                  |                                                           |                                    |                                        |                                              |                                |
| 0          | 0          | 0          | RHR                      | XX                     | bit 7                           | bit 6                           | bit 5                            | bit 4                                                     | bit 3                              | bit 2                                  | bit 1                                        | bit 0                          |
| 0          | 0          | 0          | THR                      | XX                     | bit 7                           | bit 6                           | bit 5                            | bit 4                                                     | bit 3                              | bit 2                                  | bit 1                                        | bit 0                          |
| 0          | 0          | 1          | IER                      | 00                     | CTS<br>interrupt<br>[ <u>3]</u> | RTS<br>interrupt<br>[ <u>3]</u> | Xoff<br>interrupt<br>[ <u>3]</u> | Sleep<br>mode <sup>[3]</sup>                              | modem<br>status<br>interrupt<br>RX | receive<br>line<br>status<br>interrupt | transmit<br>holding<br>register<br>interrupt | receive<br>holding<br>register |
| 0          | 1          | 0          | FCR                      | 00                     | RCVR<br>trigger<br>(MSB)        | RCVR<br>trigger<br>(LSB)        | TX<br>trigger<br>(MSB)[3]        | TX<br>trigger<br>(LSB) <mark>[3]</mark>                   | DMA<br>mode<br>select              | XMIT<br>FIFO<br>reset                  | RCVR<br>FIFO<br>reset                        | FIFOs<br>enable                |
| 0          | 1          | 0          | ISR                      | 01                     | FIFOs<br>enabled                | FIFOs<br>enabled                | INT<br>priority<br>bit 4         | INT<br>priority<br>bit 3                                  | INT<br>priority<br>bit 2           | INT<br>priority<br>bit 1               | INT<br>priority<br>bit 0                     | INT<br>status                  |
| 0          | 1          | 1          | LCR                      | 00                     | divisor<br>latch<br>enable      | set break                       | set parity                       | even<br>parity                                            | parity<br>enable                   | stop bits                              | word<br>length<br>bit 1                      | word<br>length<br>bit 0        |
| 1          | 0          | 0          | MCR                      | 00                     | clock<br>select <sup>[3]</sup>  | IRDA<br>enable                  | 0                                | loopback                                                  | OP2<br>control                     | (OP1)                                  | RTS                                          | DTR                            |
| 1          | 0          | 1          | LSR                      | 60                     | FIFO<br>data<br>error           | THR and<br>TSR<br>empty         | THR<br>empty                     | break<br>interrupt                                        | framing<br>error                   | parity<br>error                        | overrun<br>error                             | receive<br>data<br>ready       |
| 1          | 1          | 0          | MSR                      | X0                     | CD                              | RI                              | DSR                              | CTS                                                       | $\Delta \overline{CD}$             | $\Delta \overline{RI}$                 | $\Delta \overline{\text{DSR}}$               | $\Delta \overline{\text{CTS}}$ |
| 1          | 1          | 1          | SPR                      | FF                     | bit 7                           | bit 6                           | bit 5                            | bit 4                                                     | bit 3                              | bit 2                                  | bit 1                                        | bit 0                          |
| Spe        | ecial      | regi       | ster set <sup>[4]</sup>  |                        |                                 |                                 |                                  |                                                           |                                    |                                        |                                              |                                |
| )          | 0          | 0          | DLL                      | XX                     | bit 7                           | bit 6                           | bit 5                            | bit 4                                                     | bit 3                              | bit 2                                  | bit 1                                        | bit 0                          |
| )          | 0          | 1          | DLM                      | XX                     | bit 15                          | bit 14                          | bit 13                           | bit 12                                                    | bit 11                             | bit 10                                 | bit 9                                        | bit 8                          |
| Enł        | nanc       | ed re      | egister set              | [5]                    |                                 |                                 |                                  |                                                           |                                    |                                        |                                              |                                |
| 0          | 1          | 0          | EFR                      | 00                     | Auto-<br>CTS                    | Auto-<br>RTS                    | Special<br>character<br>detect   | Enable<br>IER[4:7],<br>ISR[4:5],<br>FCR[4:5],<br>MCR[5:7] | Cont-3<br>TX, RX<br>Control        | Cont-2<br>TX, RX<br>Control            | Cont-1<br>TX, RX<br>Control                  | Cont-0<br>TX, RX<br>Control    |
| 1          | 0          | 0          | Xon1                     | 00                     | bit 7                           | bit 6                           | bit 5                            | bit 4                                                     | bit 3                              | bit 2                                  | bit 1                                        | bit 0                          |
| 1          | 0          | 1          | Xon2                     | 00                     | bit 15                          | bit 14                          | bit 13                           | bit 12                                                    | bit 11                             | bit 10                                 | bit 9                                        | bit 8                          |
| 1          | 1          | 0          | Xoff1                    | 00                     | bit 7                           | bit 6                           | bit 5                            | bit 4                                                     | bit 3                              | bit 2                                  | bit 1                                        | bit 0                          |
| 1          | 1          | 1          | Xoff2                    | 00                     | bit 15                          | bit 14                          | bit 13                           | bit 12                                                    | bit 11                             | bit 10                                 | bit 9                                        | bit 8                          |

[1] The value shown in represents the register's initialized hexadecimal value; X = not applicable.

[2] Accessible only when LCR[7] is logic 0.

[3] These bits are only accessible when EFR[4] is set.

[4] Baud rate registers accessible only when LCR[7] is logic 1.

[5] Enhanced Feature Register, Xon1/Xon2 and Xoff1/Xoff2 are accessible only when LCR is set to 'BFh'.

## 7.1 Transmit Holding Register (THR) and Receive Holding Register (RHR)

The serial transmitter section consists of an 8-bit Transmit Hold Register (THR) and Transmit Shift Register (TSR). The status of the THR is provided in the Line Status Register (LSR). Writing to the THR transfers the contents of the data bus (D[7:0]) to the TSR and UART via the THR, providing that the THR is empty. The THR empty flag in the LSR register will be set to a logic 1 when the transmitter is empty or when data is transferred to the TSR. Note that a write operation can be performed when the THR empty flag is set (logic 0 = at least one byte in FIFO/THR, logic 1 = FIFO/THR empty).

The serial receive section also contains an 8-bit Receive Holding Register (RHR) and a Receive Serial Shift Register (RSR). Receive data is removed from the SC68C652B and receive FIFO by reading the RHR register. The receive section provides a mechanism to prevent false starts. On the falling edge of a start or false start bit, an internal receiver counter starts counting clocks at the  $16 \times$  clock rate. After  $71/_{2}$  clocks, the start bit time should be shifted to the center of the start bit. At this time the start bit is sampled, and if it is still a logic 0 it is validated. Evaluating the start bit in this manner prevents the receiver from assembling a false character. Receiver status codes will be posted in the LSR.

## 7.2 Interrupt Enable Register (IER)

The Interrupt Enable Register (IER) masks the interrupts from receiver ready, transmitter empty, line status and modem status registers. These interrupts would normally be seen on the IRQ output pin.

| D:+ | Or much as l | Description                                                                                                                                          |
|-----|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Symbol       | Description                                                                                                                                          |
| 7   | IER[7]       | CTS interrupt                                                                                                                                        |
|     |              | logic 0 = disable the CTS interrupt (normal default condition)                                                                                       |
|     |              | logic 1 = enable the CTS interrupt. The SC68C652B issues an interrupt when the $\overline{\text{CTSn}}$ pin transitions from a logic 0 to a logic 1. |
| 6   | IER[6]       | RTS interrupt                                                                                                                                        |
| U   | 1211[0]      | logic $0 =$ disable the RTS interrupt (normal default condition)                                                                                     |
|     |              |                                                                                                                                                      |
|     |              | logic 1 = enable the RTS interrupt. The SC68C652B issues an interrupt when the $\overline{\text{RTSn}}$ pin transitions from a logic 0 to a logic 1. |
| 5   | IER[5]       | Xoff interrupt                                                                                                                                       |
|     |              | logic 0 = disable the software flow control, receive Xoff interrupt (normal default condition)                                                       |
|     |              | logic 1 = enable the software flow control, receive Xoff interrupt                                                                                   |
| 4   | IER[4]       | Sleep mode                                                                                                                                           |
|     |              | logic 0 = disable Sleep mode (normal default condition)                                                                                              |
|     |              | logic 1 = enable Sleep mode                                                                                                                          |
| 3   | IER[3]       | Modem Status Interrupt. This interrupt will be issued whenever there is a modem status change as reflected in MSR[3:0].                              |
|     |              | logic 0 = disable the modem status register interrupt (normal default condition)                                                                     |
|     |              | logic 1 = enable the modem status register interrupt                                                                                                 |

#### Table 10. Interrupt Enable Register bits description

SC68C652B 2

 Table 10.
 Interrupt Enable Register bits description ...continued

| Bit      | Symbol | Description                                                                                                                                                                                                                                                                                               |
|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2        | IER[2] | Receive Line Status interrupt. This interrupt will be issued whenever a receive data error condition exists as reflected in LSR[4:1].                                                                                                                                                                     |
|          |        | logic 0 = disable the receiver line status interrupt (normal default condition)                                                                                                                                                                                                                           |
|          |        | logic 1 = enable the receiver line status interrupt                                                                                                                                                                                                                                                       |
| 1 IER[1] |        | Transmit Holding Register interrupt. In the 16C450 mode, this interrupt will be issued whenever the THR is empty, and is associated with LSR[5]. In the FIFO modes, this interrupt will be issued whenever the FIFO is empty.                                                                             |
|          |        | logic 0 = disable the Transmit Holding Register Empty (TXRDY) interrupt<br>(normal default condition)                                                                                                                                                                                                     |
|          |        | logic 1 = enable the TXRDY (ISR level 3) interrupt                                                                                                                                                                                                                                                        |
| 0 IER[0] |        | Receive Holding Register. In the 16C450 mode, this interrupt will be issued when the RHR has data, or is cleared when the RHR is empty. In the FIFO mode, this interrupt will be issued when the FIFO has reached the programmed trigger level or is cleared when the FIFO drops below the trigger level. |
|          |        | logic 0 = disable the receiver ready (ISR level 2, RXRDY) interrupt (normal default condition)                                                                                                                                                                                                            |
|          |        | logic 1 = enable the RXRDY (ISR level 2) interrupt                                                                                                                                                                                                                                                        |

### 7.2.1 IER versus Transmit/Receive FIFO interrupt mode operation

When the receive FIFO (FCR[0] = logic 1), and receive interrupts (IER[0] = logic 1) are enabled, the receive interrupts and register status will reflect the following:

- The receive RXRDY interrupt (Level 2 ISR interrupt) is issued to the external CPU when the receive FIFO has reached the programmed trigger level. It will be cleared when the receive FIFO drops below the programmed trigger level.
- Receive FIFO status will also be reflected in the user accessible ISR register when the receive FIFO trigger level is reached. Both the ISR register receive status bit and the interrupt will be cleared when the FIFO drops below the trigger level.
- The receive data ready bit (LSR[0]) is set as soon as a character is transferred from the shift register (RSR) to the receive FIFO. It is reset when the FIFO is empty.
- When the Transmit FIFO and interrupts are enabled, an interrupt is generated when the transmit FIFO is empty due to the unloading of the data by the TSR and UART for transmission via the transmission media. The interrupt is cleared either by reading the ISR register, or by loading the THR with new data characters.

SC68C652B 2

### 7.2.2 IER versus Receive/Transmit FIFO polled mode operation

When FCR[0] = logic 1, resetting IER[0:3] enables the SC68C652B in the FIFO polled mode of operation. In this mode, interrupts are not generated and the user must poll the LSR register for transmit and/or receive data status. Since the receiver and transmitter have separate bits in the LSR either or both can be used in the polled mode by selecting respective transmit or receive control bit(s).

- LSR[0] will be a logic 1 as long as there is one byte in the receive FIFO.
- LSR[4:1] will provide the type of receive errors, or a receive break, if encountered.
- LSR[5] will indicate when the transmit FIFO is empty.
- LSR[6] will indicate when both the transmit FIFO and transmit shift register are empty.
- LSR[7] will show if any FIFO data errors occurred.

### 7.3 FIFO Control Register (FCR)

This register is used to enable the FIFOs, clear the FIFOs, set the receive FIFO trigger levels, and select the DMA mode.

#### 7.3.1 DMA mode

#### 7.3.1.1 Mode 0 (FCR bit 3 = 0)

Set and enable the interrupt for each single transmit or receive operation, and is similar to the 16C450 mode. Transmit Ready pin ( $\overline{TXRDYn}$ ) will go to a logic 0 whenever the FIFO (THR, if FIFO is not enabled) is empty. Receive Ready pin ( $\overline{RXRDYn}$ ) will go to a logic 0 whenever the Receive Holding Register (RHR) is loaded with a character.

#### 7.3.1.2 Mode 1 (FCR bit 3 = 1)

Set and enable the interrupt in a block mode operation. The transmit interrupt is set when the transmit FIFO is below the programmed trigger level. The receive interrupt is set when the receive FIFO fills to the programmed trigger level. However, the FIFO continues to fill regardless of the programmed level until the FIFO is full. RXRDYn remains a logic 0 as long as the FIFO fill level is above the programmed trigger level.

SC68C652B 2

### 7.3.2 FIFO mode

| Bit | Symbol   | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6 | FCR[7:6] | RCVR trigger. These bits are used to set the trigger level for the receive FIFO interrupt.                                                                                                                                                                                                                                                                                                                                                |
|     |          | An interrupt is generated when the number of characters in the FIFO equal the programmed trigger level. However, the FIFO will continue to be loaded until it is full. Refer to <u>Table 12</u> .                                                                                                                                                                                                                                         |
| 5:4 | FCR[5:4] | TX trigger. Logic 0 or cleared is the default condition; TX trigger level = 16.                                                                                                                                                                                                                                                                                                                                                           |
|     |          | These bits are used to set the trigger level for the transmit FIFO interrupt.<br>The SC68C652B will issue a transmit empty interrupt when the number of<br>characters in FIFO drops below the selected trigger level. Refer to <u>Table 13</u>                                                                                                                                                                                            |
| 3   | FCR[3]   | DMA mode select                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |          | logic 0 = set DMA mode '0' (normal default condition)                                                                                                                                                                                                                                                                                                                                                                                     |
|     |          | logic 1 = set DMA mode '1'                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |          | <b>Transmit operation in mode '0':</b> When the SC68C652B is in the 16C450 mode (FIFOs disabled; FCR[0] = logic 0) or in the FIFO mode (FIFOs enabled; FCR[0] = logic 1; FCR[3] = logic 0), and when there are no characters in the transmit FIFO or transmit holding register, the TXRDYn pi will be a logic 0. Once active, the TXRDYn pin will go to a logic 1 after the first character is loaded into the transmit holding register. |
|     |          | <b>Receive operation in mode '0':</b> When the SC68C652B is in 16C450 mode or in the FIFO mode (FCR[0] = logic 1; FCR[3] = logic 0) and there is at least one character in the receive FIFO, the $\overrightarrow{RXRDYn}$ pin will be a logic 0. Once active, the $\overrightarrow{RXRDYn}$ pin will go to a logic 1 when there are no more characters in the receiver.                                                                  |
|     |          | <b>Transmit operation in mode '1':</b> When the SC68C652B is in FIFO mode (FCR[0] = logic 1; FCR[3] = logic 1), the TXRDYn pin will be a logic 1 when the transmit FIFO is completely full. It will be a logic 0 when the trigger level has been reached.                                                                                                                                                                                 |
|     |          | <b>Receive operation in mode '1':</b> When the SC68C652B is in FIFO mode (FCR[0] = logic 1; FCR[3] = logic 1) and the trigger level has been reached or a Receive Time-Out has occurred, the RXRDYn pin will go to a logic 0. Once activated, it will go to a logic 1 after there are no more characters in the FIFO.                                                                                                                     |
| 2   | FCR[2]   | XMIT FIFO reset                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |          | logic 0 = no FIFO transmit reset (normal default condition)                                                                                                                                                                                                                                                                                                                                                                               |
|     |          | logic 1 = clears the contents of the transmit FIFO and resets the FIFO counter logic (the transmit shift register is not cleared or altered). This bit will return to a logic 0 after clearing the FIFO.                                                                                                                                                                                                                                  |
| 1   | FCR[1]   | RCVR FIFO reset                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |          | logic 0 = no FIFO receive reset (normal default condition).                                                                                                                                                                                                                                                                                                                                                                               |
|     |          | logic 1 = clears the contents of the receive FIFO and resets the FIFO counter logic (the receive shift register is not cleared or altered). This bit will return to a logic 0 after clearing the FIFO.                                                                                                                                                                                                                                    |
| 0   | FCR[0]   | FIFO enable                                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |          | logic 0 = disable the transmit and receive FIFO (normal default condition                                                                                                                                                                                                                                                                                                                                                                 |
|     |          | logic 1 = enable the transmit and receive FIFO. This bit must be a '1'<br>when other FCR bits are written to, or they will not be programmed                                                                                                                                                                                                                                                                                              |

| Table 12. | RCVR trigger levels |                                    |  |  |
|-----------|---------------------|------------------------------------|--|--|
| FCR[7]    | FCR[6]              | Receive FIFO trigger level (bytes) |  |  |
| 0         | 0                   | 8                                  |  |  |
| 0         | 1                   | 16                                 |  |  |
| 1         | 0                   | 24                                 |  |  |
| 1         | 1                   | 28                                 |  |  |
|           |                     |                                    |  |  |

| Table 13. | TX FIFO trigger levels |                               |  |  |
|-----------|------------------------|-------------------------------|--|--|
| FCR[5]    | FCR[4]                 | TX FIFO trigger level (bytes) |  |  |
| 0         | 0                      | 16                            |  |  |
| 0         | 1                      | 8                             |  |  |
| 1         | 0                      | 24                            |  |  |
| 1         | 1                      | 30                            |  |  |

#### Dual UART with 32-byte FIFOs and IrDA encoder/decoder

## 7.4 Interrupt Status Register (ISR)

The SC68C652B provides six levels of prioritized interrupts to minimize external software interaction. The Interrupt Status Register (ISR) provides the user with six interrupt status bits. Performing a read cycle on the ISR will provide the user with the highest pending interrupt level to be serviced. No other interrupts are acknowledged until the pending interrupt is serviced. A lower level interrupt may be seen after servicing the higher level interrupt and re-reading the interrupt status bits. Table 14 "Interrupt source" shows the data values (bit 0 to bit 5) for the six prioritized interrupt levels and the interrupt sources associated with each of these interrupt levels.

#### Table 14.Interrupt source

| Priority<br>level | ISR[5] | ISR[4] | ISR[3] | ISR[2] | ISR[1] | ISR[0] | Source of the interrupt                            |
|-------------------|--------|--------|--------|--------|--------|--------|----------------------------------------------------|
| 1                 | 0      | 0      | 0      | 1      | 1      | 0      | LSR (Receiver Line Status Register)                |
| 2                 | 0      | 0      | 0      | 1      | 0      | 0      | RXRDY (Received Data Ready)                        |
| 2                 | 0      | 0      | 1      | 1      | 0      | 0      | RXRDY (Receive Data time-out)                      |
| 3                 | 0      | 0      | 0      | 0      | 1      | 0      | TXRDY (Transmitter Holding<br>Register Empty)      |
| 4                 | 0      | 0      | 0      | 0      | 0      | 0      | MSR (Modem Status Register)                        |
| 5                 | 0      | 1      | 0      | 0      | 0      | 0      | RXRDY (received Xoff signal)/<br>special character |
| 6                 | 1      | 0      | 0      | 0      | 0      | 0      | CTS, RTS change-of-state                           |

#### Table 15. Interrupt Status Register bits description

| Bit | Symbol   | Description                                                                                                                                                                                                                                                                                                                                                |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6 | ISR[7:6] | FIFOs enabled. These bits are set to a logic 0 when the FIFOs are not being used in the 16C450 mode. They are set to a logic 1 when the FIFOs are enabled in the SC68C652B mode.                                                                                                                                                                           |
|     |          | logic 0 or cleared = default condition                                                                                                                                                                                                                                                                                                                     |
| 5:4 | ISR[5:4] | INT priority bits 4:3. These bits are enabled when EFR[4] is set to a logic 1. ISR[4] indicates that matching Xoff character(s) have been detected. ISR[5] indicates that CTS, RTS have been generated. Note that once set to a logic 1, the ISR[4] bit will stay a logic 1 until Xon character(s) are received.<br>logic 0 or cleared = default condition |
| 3:1 | ISR[3:1] | INT priority bits 2:0. These bits indicate the source for a pending interrupt at interrupt priority levels 1, 2, and 3 (see <u>Table 14</u> ). logic 0 or cleared = default condition                                                                                                                                                                      |
| 0   | ISR[0]   | INT status<br>logic 0 = an interrupt is pending and the ISR contents may be used<br>as a pointer to the appropriate interrupt service routine<br>logic 1 = no interrupt pending (normal default condition)                                                                                                                                                 |

## 7.5 Line Control Register (LCR)

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

| Table 16. | Line Contro | I Register bits description                                                                                                                                                                                       |
|-----------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit       | Symbol      | Description                                                                                                                                                                                                       |
| 7         | LCR[7]      | Divisor latch enable. The internal baud rate counter latch and Enhanced Feature mode enable.                                                                                                                      |
|           |             | logic 0 = divisor latch disabled (normal default condition)                                                                                                                                                       |
|           |             | logic 1 = divisor latch enabled                                                                                                                                                                                   |
| 6         | LCR[6]      | Set break. When enabled, the Break control bit causes a break condition to be transmitted (the TXn output pin is forced to a logic 0 state). This condition exists until disabled by setting LCR[6] to a logic 0. |
|           |             | logic 0 = no break condition (normal default condition)                                                                                                                                                           |
|           |             | logic 1 = forces the transmitter output pin (TXn) to a logic 0 for alerting the remote receiver to a line break condition                                                                                         |
| 5:3       | LCR[5:3]    | Set parity; even parity; parity enable. Programs the parity conditions (see Table 17).                                                                                                                            |
| 2         | LCR[2]      | Stop bits. The length of stop bit is specified by this bit in conjunction with the programmed word length (see Table 18).                                                                                         |
|           |             | logic 0 or cleared = default condition                                                                                                                                                                            |
| 1:0       | LCR[1:0]    | Word length bits 1, 0. These two bits specify the word length to be transmitted or received (see Table 19).                                                                                                       |
|           |             | logic 0 or cleared = default condition                                                                                                                                                                            |

#### Table 17. LCR[5:3] parity selection

| LCR[5] | LCR[4] | LCR[3] | Parity selection  |
|--------|--------|--------|-------------------|
| Х      | Х      | 0      | no parity         |
| Х      | 0      | 1      | odd parity        |
| 0      | 1      | 1      | even parity       |
| 0      | 0      | 1      | forced parity '1' |
| 1      | 1      | 1      | forced parity '0' |

#### Table 18. LCR[2] stop bit length

| LCR[2] | Word length | Stop bit length (bit times) |
|--------|-------------|-----------------------------|
| 0      | 5, 6, 7, 8  | 1                           |
| 1      | 5           | 11⁄2                        |
| 1      | 6, 7, 8     | 2                           |

#### Table 19. LCR[1:0] word length

| LCR[1] | LCR[0] | Word length |
|--------|--------|-------------|
| 0      | 0      | 5           |
| 0      | 1      | 6           |
| 1      | 0      | 7           |
| 1      | 1      | 8           |

### Dual UART with 32-byte FIFOs and IrDA encoder/decoder

## 7.6 Modem Control Register (MCR)

This register controls the interface with the modem or a peripheral device.

| Bit | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | MCR[7] | Clock select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|     |        | logic 0 = divide-by-1 clock input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |        | logic 1 = divide-by-4 clock input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6   | MCR[6] | IR enable (see Figure 16)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|     |        | logic 0 = enable the standard modem receive and transmit input/output interface (normal default condition)                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |        | logic 1 = enable infrared IrDA receive and transmit inputs/outputs. While<br>in this mode, the TXn/RXn output/inputs are routed to the infrared<br>encoder/decoder. The data input and output levels will conform to the<br>IrDA infrared interface requirement. As such, while in this mode, the<br>infrared TXn output will be a logic 0 during idle data conditions.                                                                                                                                                      |
| 5   | MCR[5] | reserved; set to '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4 M | MCR[4] | Loopback. Enable the local loopback mode (diagnostics). In this mode the transmitter output (TXn) and the receiver input (RXn), CTSn, DSRn, CDn, and Rln pins are disconnected from the SC68C652B I/O pins. Internally the modem data and control pins are connected into a loopback data configuration (see Figure 4). In this mode, the receiver and transmitter interrupts remain fully operational. The Modem Control Interrupts are also operational, but the interrupts continue to be controlled by the IER register. |
|     |        | logic 0 = disable loopback mode (normal default condition)                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |        | logic 1 = enable local loopback mode (diagnostics)                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3   | MCR[3] | OP2 control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |        | logic 0 = forces $\overline{OP2n}$ output pin to HIGH state                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |        | logic 1 = forces OP2n output pin to LOW state. In loopback mode, controls MSR[7].                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2   | MCR[2] | $(\overline{OP1})$ . $\overline{OP1A}/\overline{OP1B}$ are not available as an external signal in the SC68C652B. This bit is instead used in the loopback mode only. In the loopback mode, this bit is used to write the state of the modem $\overline{RIn}$ pin interface signal.                                                                                                                                                                                                                                           |
| 1   | MCR[1] | RTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |        | logic 0 = force $\overline{RTSn}$ output pin to a logic 1 (normal default condition)                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |        | logic 1 = force $\overline{\text{RTSn}}$ output pin to a logic 0                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0   | MCR[0] | DTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |        | logic 0 = force DTRn output pin to a logic 1 (normal default condition)                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|     |        | logic 1 = force $\overline{\text{DTRn}}$ output pin to a logic 0                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

### Dual UART with 32-byte FIFOs and IrDA encoder/decoder

## 7.7 Line Status Register (LSR)

This register provides the status of data transfers between the SC68C652B and the CPU.

| Bit | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | LSR[7] | FIFO data error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|     |        | logic 0 = no error (normal default condition)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |        | logic 1 = at least one parity error, framing error or break indication is in the<br>current FIFO data. This bit is cleared when there are no remaining error flags<br>associated with the remaining data in the FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6   | LSR[6] | THR and TSR empty. This bit is the Transmit Empty indicator. This bit is set to a logic 1 whenever the transmit holding register and the transmit shift register are both empty. It is reset to logic 0 whenever either the THR or TSR contains a data character. In the FIFO mode, this bit is set to '1' whenever the transmit FIFO and transmit shift register are both empty.                                                                                                                                                                                                                                                                               |
| 5   | LSR[5] | THR empty. This bit is the Transmit Holding Register Empty indicator. This bit indicates that the UART is ready to accept a new character for transmission. Ir addition, this bit causes the UART to issue an interrupt to CPU when the THR interrupt enable is set. The THR bit is set to a logic 1 when a character is transferred from the transmit holding register into the transmitter shift register. The bit is reset to a logic 0 concurrently with the loading of the transmitter holding register by the CPU. In the FIFO mode, this bit is set when the transmit FIFO is empty; it is cleared when at least 1 byte is written to the transmit FIFO. |
| 4   | LSR[4] | Break interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|     |        | logic 0 = no break condition (normal default condition)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |        | logic 1 = the receiver received a break signal (RXn pin was a logic 0 for one character frame time). In the FIFO mode, only one break character is loaded into the FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3   | LSR[3] | Framing error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |        | logic 0 = no framing error (normal default condition)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |        | logic 1 = framing error. The receive character did not have a valid stop bit(s)<br>In the FIFO mode, this error is associated with the character at the top of the<br>FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2   | LSR[2] | Parity error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|     |        | logic 0 = no parity error (normal default condition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |        | logic 1 = parity error. The receive character does not have correct parity information and is suspect. In the FIFO mode, this error is associated with the character at the top of the FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1   | LSR[1] | Overrun error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |        | logic 0 = no overrun error (normal default condition)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |        | logic 1 = overrun error. A data overrun error occurred in the receive shift<br>register. This happens when additional data arrives while the FIFO is full. In<br>this case, the previous data in the shift register is overwritten. Note that unde<br>this condition, the data byte in the receive shift register is not transferred into<br>the FIFO, therefore the data in the FIFO is not corrupted by the error.                                                                                                                                                                                                                                            |
| 0   | LSR[0] | Receive data ready                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|     |        | logic 0 = no data in receive holding register or FIFO (normal default condition).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |        | logic 1 = data has been received and is saved in the receive holding registe<br>or FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

## 7.8 Modem Status Register (MSR)

This register provides the current state of the control interface signals from the modem, or other peripheral device to which the SC68C652B is connected. Four bits of this register are used to indicate the changed information. These bits are set to a logic 1 whenever a control input from the modem changes state. These bits are set to a logic 0 whenever the CPU reads this register.

#### Table 22. Modem Status Register bits description

| Bit | Symbol | Description                                                                                                                                                                                       |  |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7   | MSR[7] | CD. During normal operation, this bit is the complement of the $\overline{\text{CDn}}$ input pin. Reading this bit in the loopback mode produces the state of MCR[3] ( $\overline{\text{OP2}}$ ). |  |
| 6   | MSR[6] | RI. During normal operation, this bit is the complement of the $\overline{\text{RIn}}$ input pin. Reading this bit in the loopback mode produces the state of MCR[2] ( $\overline{\text{OP1}}$ ). |  |
| 5   | MSR[5] | DSR. During normal operation, this bit is the complement of the $\overline{\text{DSRn}}$ input pin. During the loopback mode, this bit is equivalent to the state of MCR[0].                      |  |
| 4   | MSR[4] | CTS. During normal operation, this bit is the complement of the $\overline{\text{CTSn}}$ input pin. During the loopback mode, this bit is equivalent to the state of MCR[1].                      |  |
| 3   | MSR[3] |                                                                                                                                                                                                   |  |
|     |        | logic 0 = no change of state on $\overline{\text{CDn}}$ pin (normal default condition)                                                                                                            |  |
|     |        | logic 1 = the $\overline{\text{CDn}}$ input pin to the SC68C652B has changed state since the last time it was read. A modem Status Interrupt will be generated.                                   |  |
| 2   | MSR[2] |                                                                                                                                                                                                   |  |
|     |        | logic 0 = no change of state on $\overline{RIn}$ pin (normal default condition)                                                                                                                   |  |
|     |        | logic 1 = the $\overline{\text{RIn}}$ input pin to the SC68C652B has changed from a logic 0 to a logic 1. A modem Status Interrupt will be generated.                                             |  |
| 1   | MSR[1] |                                                                                                                                                                                                   |  |
|     |        | logic 0 = no change of state on $\overline{\text{DSRn}}$ pin (normal default condition)                                                                                                           |  |
|     |        | logic 1 = the $\overline{\text{DSRn}}$ input pin to the SC68C652B has changed state since the last time it was read. A modem Status Interrupt will be generated.                                  |  |
| 0   | MSR[0] |                                                                                                                                                                                                   |  |
|     |        | logic 0 = no change of state on $\overline{\text{CTSn}}$ pin (normal default condition)                                                                                                           |  |
|     |        | logic 1 = the $\overline{\text{CTSn}}$ input pin to the SC68C652B has changed state since the last time it was read. A modem Status Interrupt will be generated.                                  |  |
|     |        |                                                                                                                                                                                                   |  |

[1] Whenever any MSR bit 3:0 is set to logic 1, a Modem Status Interrupt will be generated.

## 7.9 Scratchpad Register (SPR)

The SC68C652B provides a temporary data register to store 8 bits of user information.