

# C16450 Universal Asynchronous Receiver/Transmitter

October 12, 1998

**Product Specification** 



## CAST, Inc.

24 White Birch Drive

Pomona, New York 10907 USA
Phone: +1 914-354-4945
Fax: +1 914-354-0325
E-Mail: info@cast-inc.com
URL: www.cast-inc.com

#### **Features**

- · Full double buffering
- · Asynchronous operation
- Independently controlled Transmit, Line Status, Receive, and Data Set Interrupts
- Programmable data word length (5 8 bit), parity and stop bits
- Parity, overrun and framing error checking
- Supports up to 1.5 Mbps transmission rates
- Programmable Baud Rate Generator allows division of any reference clock by 1 to (2<sup>16</sup>-1) and generates an internal 16 X Clock
- · False start bit detection
- Automatic break generation and detection
- · Internal diagnostic capabilities
- · Peripheral modem control functions

## **Applications**

The C16450 core is used in serial data communications and modem applications.

Figure 1: Core Implementation Data

| CPLD     | Macrocells <sup>2</sup> | Product<br>Terms <sup>2</sup> | <b>I/O</b> ¹      | Performance <sup>2,</sup> (MHz) | Speed<br>Grade |
|----------|-------------------------|-------------------------------|-------------------|---------------------------------|----------------|
| XC9500   | 206                     | 824                           | 41                | 24.3                            | -7             |
| XC9500XL | 194                     | 906                           | 41                | 71.4                            | -5             |
|          | CLBs                    | Global                        |                   | Performance                     | Speed          |
| FPGA     |                         | IOBs                          | IOBs <sup>1</sup> | (MHz)                           | Grade          |
| XC4000XL | 157                     | 4                             | 37                | 77.9                            | -09            |
| Spartan  | 157                     | 4                             | 37                | 41.6                            | -3             |

#### Notes:

- 1. Assuming all core I/O are routed off-chip.
- CPLD figures stated are for speed/density-optimized (Speed90) place and route run through version 1.5 of Xilinx tools.

| AllianceCORE™ Facts      |                                 |  |  |  |  |  |
|--------------------------|---------------------------------|--|--|--|--|--|
| Core Specifics           |                                 |  |  |  |  |  |
| See Table 1              |                                 |  |  |  |  |  |
| Provided with Core       |                                 |  |  |  |  |  |
| Documentation            | Core documentation              |  |  |  |  |  |
| Design File Formats      | .ngo, .XNF Netlist;             |  |  |  |  |  |
|                          | VHDL Source RTL available extra |  |  |  |  |  |
| Constraint Files         | .ncf                            |  |  |  |  |  |
| Verification Tool        | VHDL                            |  |  |  |  |  |
| Schematic Symbols        | Viewlogic                       |  |  |  |  |  |
| Evaluation Model         | None                            |  |  |  |  |  |
| Reference designs &      | None                            |  |  |  |  |  |
| application notes        |                                 |  |  |  |  |  |
| Additional Items         | None                            |  |  |  |  |  |
| Design Tool Requirements |                                 |  |  |  |  |  |
| Xilinx Core Tools        | Alliance/Foundation 1.4         |  |  |  |  |  |
| Entry/Verification       | VHDL RTL                        |  |  |  |  |  |
| Tool                     |                                 |  |  |  |  |  |
| Support                  |                                 |  |  |  |  |  |
| Support provided by C    | Support provided by CAST, Inc.  |  |  |  |  |  |



Figure 1: C16450 Asynchronous Receiver/Transmitter Block Diagram

## **General Description**

The C16450 UART programmable communications interface core provides data formatting and control to a serial communication channel.

The core has select, read/write, interrupt and bus interface logic features that allow data transfers over an 8-bit bi-directional parallel data bus system. With proper formatting and error checking, the core can transmit and receive serial data, supporting asynchronous operation.

## **Functional Description**

The C16450 core is partitioned into modules as shown in Figure 1 and described below.

## Chip Select & R/W Control Logic

The chip select and R/W control logic controls the internal chip addressing.

## **Line Control Register (LCR)**

The Line Control Register is used to specify the data communication format. The break feature, parity, stop bits and word length can be changed by writing to the appropriate bits in LSR.

## Line Status Register (LSR)

This register provides information on the status of data transfers between the C16450 and the CPU.

## Interrupt Enable Register (IER)

The Interrupt Enable Register masks interrupts from the modem status registers, line status, transmitter empty and receiver ready to the INTRPT output pin.

## Modem Status Register (MSR)

This register provides the current state of modem control lines.

## Modem Control (Register & Logic)

This register controls the interface lines with the MODEM (MODEM control logic) and changes the status of the C16450 from normal operating mode and local loop-back mode (diagnostics mode).

## **Transmitter Holding Buffer**

The transmitter section is composed of a Transmit Holding Register (THR) and a Transmit Shift Register (TSR). Writing to THR will transfer the contents of the data bus (DIN 7-0) to the Transmit Holding Register every time that the THR

or TSR is empty. This write operation should be done when Transmit Holding Register Empty (THRE) is set.

#### Receiver Buffer

This register contains the assembled received data. On the falling edge of the start bit, the receiver section starts its operations. The start bit is valid if the RXDATA is still low at the middle sample of Start bit, thus preventing the receiver from assembling a false data character.

#### Interrupt Identification Register (IIR)

The Interrupt Identification Register provides the source of interrupt among four levels of prioritized interrupt conditions in order to minimize the CPU overhead during data transfers.

### **Interrupt Control Logic**

The C16450 contains an interrupt generation and prioritization logic.

When an interrupt is generated the IIR indicates that an interrupt is pending and also the type of interrupt between various available.

The C16450 provides four prioritized levels of interrupt:

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

### Scratchpad Register (SR)

This register stores the temporary byte for variable use.

# Baud Generator, LSB and MSB Divisor Registers

The C16450 contains a programmable baud rate generator that takes any clock input from DC-20MHz and dividing it by any divisor from 1 to (2<sup>16</sup> –1). The output frequency of the Boudoutn is equal to 16X of the transmission baud rate. The two registers divisor MSB and divisor LSB are used to store the divisor in a 16-bit binary format. These divisor latches must be loaded during initialization in order to ensure desired operation of the baud generator.

The formula for the divisor is:

divisor = CLKIN frequency in ÷ (desired baud rate X 16)

## **Core Modifications**

The C16450 core can be customized to include:

- · Removal of internal baud rate generator
- · Different CPU interface

**Table 2: Core Signal Pinout** 

| Signal   | Signal Direction | Description                               |
|----------|------------------|-------------------------------------------|
| CLK      | Input            | Master Clock; uses 1 global IOB pin       |
| A[2:0]   | Input            | Register Select                           |
| ADSn     | Input            | Address Strobe                            |
| CS0      | Input            | Chip Select 0                             |
| CS1      | Input            | Chip Select 1                             |
| CS2n     | Input            | Chip Select 2                             |
| RDn      | Input            | Read Control; uses 1 global IOB pin       |
| WRn      | Input            | Write Control; uses 1 global IOB pin      |
| RESETn   | Input            | External Reset                            |
| DDIS     | Output           | Driver Disable                            |
| CSOUT    | Output           | Chip Select Out                           |
| DIN[7:0] | Input            | Data Input Bus                            |
| D0[7:0]  | Output           | Data Output Bus                           |
| TXDATA   | Output           | Transmit Data                             |
| RTSn     | Output           | Request-to-Send                           |
| DTRn     | Output           | Data Terminal Ready                       |
| OUT1     | Output           | Output 1                                  |
| OUT2     | Output           | Output 2                                  |
| CTSn     | Input            | Clear-to -Send                            |
| DSRn     | Input            | Data Set Ready                            |
| DCDn     | Input            | Data Carrier Detect                       |
| RIn      | Input            | Ring Indicator                            |
| INTRPT   | Output           | Interrupt                                 |
| BOUDOUTn | Output           | Baud Out                                  |
| RXDATA   | Input            | Receive Data                              |
| RCLK     | Input            | Receive Clock; uses 1 glo-<br>bal IOB pin |

Please contact CAST directly for any required modifications.

#### **Pinout**

The pinout of the C16450 core has not been fixed to specific FPGA I/O, allowing flexibility with a users application. Signal names are shown in the block diagram in Figure 1, and in Table 1.

## **Core Assumptions**

- The bi-directional data bus has been split into two separate buses: DIN[7:0] and DO[7:0]
- The 1\_ stop bit mode (for 5 bit word length) is not supported
- Signals rd2, wr2, xin and xout have been eliminated from the interface

#### **Verification Methods**

The C16450 UART core's functionality has been extensively tested with a VHDL testbench and a large number of test patterns.

## **Recommended Design Experience**

The user must be familiar with HDL design methodology as well as instantiation of Xilinx netlists in a hierarchical design environment.

## **Ordering Information**

This product is available from CAST Inc. Please contact CAST Inc. for pricing and more information.

The C16450 core is licensed from Moxsyn S.R.L.

#### **Related Information**

#### **Data Transmission Circuits 1993 Data Book**

Contact:

Texas Instruments
Literature Response Center
P.O. Box 809066
Dallas, Texas 75380-9066
URL: http://www.ti.com

### Xilinx Programmable Logic

For information on Xilinx programmable logic or development system software, contact your local Xilinx sales office, or:

Xilinx, Inc. 2100 Logic Drive San Jose, CA 95124

Phone: +1 408-559-7778
Fax: +1 408-559-7114
URL: www.xilinx.com

For general Xilinx literature, contact:

Phone: +1 800-231-3386 (inside the US)

+1 408-879-5017 (outside the US)

E-mail: literature@xilinx.com

For AllianceCORE™ specific information, contact:

Phone: +1 408-879-5381 E-mail: alliancecore@xilinx.com

URL: www.xilinx.com/products/logicore/alliance/

tblpart.htm