# Core16550 v3.3

HandBook





# **Table of Contents**

|   | Introduction                                                                                                                                                                                                                                                                 | 4<br>4                           |
|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| 1 | Functional Block Description         Elements of the Internal Block Diagram         Software Interface                                                                                                                                                                       | 5                                |
| 2 | Tool Flows       1         Licenses       1         SmartDesign       1         Simulation Flows       1                                                                                                                                                                     | 15<br>15                         |
| 3 | Core16550         1           Parameters         1                                                                                                                                                                                                                           |                                  |
| 4 | Core Interfaces.       1         I/O Signal Description       1                                                                                                                                                                                                              |                                  |
| 5 | Timing Diagrams       2         Data Write Cycle and Data Read Cycle       2         Receiver Synchronization       2                                                                                                                                                        | 21                               |
| 6 | Testbench Operation       2         User Testbench       2                                                                                                                                                                                                                   |                                  |
| 7 | List of Changes 2                                                                                                                                                                                                                                                            | 25                               |
| 8 | Product Support       2         Customer Service       2         Customer Technical Support Center       2         Technical Support       2         Website       2         Contacting the Customer Technical Support Center       2         ITAR Technical Support       2 | 27<br>27<br>27<br>27<br>27<br>27 |
|   | Index                                                                                                                                                                                                                                                                        | 29                               |



# Introduction

Core16550 is a standard UART providing software compatibility with the popular 16550 device. It performs serial-to-parallel conversion on data originating from modems or other serial devices, and performs parallel-to-serial conversion on data from a CPU to these devices. When transmitting, the data is written in parallel into the transmit FIFO of the UART. The data is then transmitted in serial form. When receiving data, the UART transforms the serial input data into a parallel form to facilitate reading by the processor. A typical 16550 application is shown in Figure 1.



Figure 1 • Typical 16550 Application



# **Supported Device Families**

Fusion IGLOO® IGLOOe ProASIC®3L ProASIC3 ProASIC3E SmartFusion® SmartFusion®2 IGLOO®2 RTG4™

## **Core Version**

This handbook applies to Core16550 v3.3. The release notes provided with the core list known discrepancies between this handbook and the core release associated with the release notes.

# **Device Utilization and Performance**

Core16550 utilization and performance data are summarized in Table 1.

| Family                    |            | Cell or Tiles | RAM   | Utilization |                          |       |
|---------------------------|------------|---------------|-------|-------------|--------------------------|-------|
| Failiny                   | Sequential | Combinatorial | Total | Blocks      | Device                   | Total |
| RTG4™                     | 349        | 874           | 1,223 | 2           | RT4G150-<br>1CG1657M     | 0.8%  |
| IGLOO®2                   | 271        | 754           | 1,021 | 2           | M2GL050TFBGA8<br>96STD   | 1.82% |
| SmartFusion®2             | 271        | 754           | 1,021 | 2           | M2S050TFBGA89<br>6STD    | 1.82% |
| SmartFusion®              | 243        | 1,163         | 1,406 | 2           | A2F500M3G-STD            | 12%   |
| IGLOO™/IGLOOE             | 237        | 1,010         | 1,247 | 2           | AGL600-<br>STD/AGLE600V2 | 9%    |
| Fusion                    | 237        | 1,010         | 1,247 | 2           | AFS600-STD               | 9%    |
| ProASIC®3/E               | 237        | 1,010         | 1,247 | 2           | A3P600-STD               | 9%    |
| ProASIC <sup>PLUS</sup> ® | 233        | 1,209         | 1,442 | 2           | APA075-STD               | 47%   |
| RTAX-S                    | 229        | 608           | 837   | 2           | RTAX250S-STD             | 20%   |
| Axcelerator®              | 229        | 608           | 837   | 2           | AX125-STD                | 42%   |



# 1 – Functional Block Description

This section provides a short description for each element of the internal block diagram in Figure 1-1.



Figure 1-1 • Core16550 Block Diagram

# **Elements of the Internal Block Diagram**

### **RWControl**

The RWControl block is responsible for handling the communications with the processor (parallel) side of the system. All writing and reading of internal registers is accomplished through this block.

### UART\_Reg

The UART\_Reg block holds all of the device internal registers.

### **RXBlock**

This is the Receiver block. RXBlock receives the incoming serial word. It is programmable to recognize data widths, such as 5, 6, 7, or 8 bits; various parity settings, such as even, odd, or no-parity; and different stop bits, such as 1, 1½, and 2 bits. RXBlock checks for errors in the input data stream, such as overrun errors, frame errors, parity errors, and break errors. If the incoming word has no problems, it is placed in the Receiver FIFO.



### **Interrupt Control**

The Interrupt Control block sends an interrupt signal back to the processor, depending on the state of the FIFO and its received and transmitted data. The Interrupt Identification Register provides the level of the interrupt. Interrupts are sent for empty transmission/receipt buffers (or FIFOs), an error in receiving a character, or other conditions requiring the attention of the processor.

### **Baud Rate Generator**

This block takes the input PCLK and divides it by a programmed value (from 1 to  $2^{16} - 1$ ). The result is divided by 16 to create the transmission clock (BAUDOUT).

### **TXBlock**

The Transmit block handles the transmission of data written to the Transmit FIFO. It adds the required start, parity, and stop bits to the data being transmitted so the receiving device can do the proper error handling and receiving.

## **Software Interface**

The Core16550 register definitions and address mappings are described in this section. The Core16550 register summary is shown in Table 1-1.

| PADDR[4:0]<br>(Address) | Divisor Latch<br>Access Bit*<br>(DLAB) | Name                                 | Symbol | Default (reset)<br>Value | No. of<br>Bits | Read/Write |
|-------------------------|----------------------------------------|--------------------------------------|--------|--------------------------|----------------|------------|
| 00                      | 0                                      | Receiver Buffer Register             | RBR    | XX                       | 8              | R          |
| 00                      | 0                                      | Transmitter Holding Register         | THR    | XX                       | 8              | W          |
| 00                      | 1                                      | Divisor Latch (LSB)                  | DLR    | 01h                      | 8              | R/W        |
| 04                      | 1                                      | Divisor Latch (MSB)                  | DMR    | 00h                      | 8              | R/W        |
| 04                      | 0                                      | Interrupt Enable Register            | IER    | 00h                      | 8              | R/W        |
| 08                      | х                                      | Interrupt Identification<br>Register | IIR    | C1h                      | 8              | R          |
| 08                      | Х                                      | FIFO Control Register                | FCR    | 01h                      | 8              | W          |
| 0C                      | Х                                      | Line Control Register                | LCR    | 00h                      | 8              | R/W        |
| 10                      | Х                                      | Modem Control Register               | MCR    | 00h                      | 8              | R/W        |
| 14                      | Х                                      | Line Status Register                 | LSR    | 60h                      | 8              | R          |
| 18                      | Х                                      | Modem Status Register                | MSR    | 00h                      | 8              | R          |
| 1C                      | Х                                      | Scratch Register                     | SR     | 00h                      | 8              | R/W        |

Table 1-1 • Core16550 Register Summary

Note: \*DLAB is the MSB of the Line Control Register (LCR bit 7).



### **Receiver Buffer Register**

The Receiver Buffer Register is defined in Table 1-2.

### Table 1-2 • Receiver Buffer Register (read only) - Address 0 DLAB 0

| Bits | Name | Default State | Valid States | Function                                                             |
|------|------|---------------|--------------|----------------------------------------------------------------------|
| 70   | RBR  | XX            | 0FFh         | Received data bits. Bit 0 is the LSB, and is the first received bit. |

### **Transmitter Holding Register**

The Transmitter Holding Register is defined in Table 1-3.

### Table 1-3 • Transmitter Holding Register (write only)

| Bits | Name | Default State | Valid States | Function                                                                 |
|------|------|---------------|--------------|--------------------------------------------------------------------------|
| 70   | THR  | XX            | 0FFh         | Data bits to be transmitted. Bit 0 is the LSB, and is transmitted first. |

### **FIFO Control Register**

The FIFO Control Register is defined in Table 1-4.

| Table 1-4 • FIFO Control Register (write only) |
|------------------------------------------------|
|------------------------------------------------|

| Bits (7:0) | Default State | Valid States | Function                                                                                                                                                                                        |  |  |
|------------|---------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0          | 1             | 0, 1         | Enables both the TX and RX FIFOs. This bit must be set to 1 when other FCR bits are written to or they will not be programmed.<br>0 – Disabled<br>1 – Enabled                                   |  |  |
| 1          | 0             | 0, 1         | Clears all bytes in the RX FIFO and resets its counter logic. The shift<br>egister is not cleared.<br>) – Disabled<br>I – Enabled                                                               |  |  |
| 2          | 0             | 0, 1         | Clears all bytes in the TX FIFO and resets its counter logic. The shift register is not cleared.<br>0 – Disabled<br>1 – Enabled                                                                 |  |  |
| 3          | 0             | 0, 1         | 0 – Single transfer DMA:Transfer made between CPU bus cycles<br>1 – Multi-transfer DMA:Transfers made until RCVR FIFO empty or XMIT<br>FIFO filled. FCR[0] must be set to 1 to set FCR[3] to 1. |  |  |
| 4, 5       | 0             | 0, 1         | Reserved for future use.                                                                                                                                                                        |  |  |
| 6, 7       | 0             | 0, 1         | These bits are used to set the trigger level for the RX FIFO interrupt.76RX FIFO Trigger Level (bytes)0001010410081114                                                                          |  |  |



## The Divisor Control Registers

The baud rate (BR) clock is generated by dividing the input reference clock (PCLK) by 16 and the Divisor value. The exact formula is shown in EQ 1-1:

$$BR = \frac{PCLK}{16 \cdot DivisorValue}$$

EQ 1-1

Table 1-5 gives an example of divisor values for desired baud rates when using an 18.432 MHz reference clock.

| Table 1-5 • Divisor Latch | (LS), | (MS) |
|---------------------------|-------|------|
|---------------------------|-------|------|

| Bits | Name | Default State | Valid States | Function                 |
|------|------|---------------|--------------|--------------------------|
| 70   | DLR  | 01h           | 01FFh        | The LSB of Divisor value |
| 70   | DMR  | 00h           | 00FFh        | The MSB of Divisor value |

#### Table 1-6 • Baud Rates and Divisor Values for 18.432 MHz Reference Clock

| Baud Rate | Decimal Divisor (Divisor Value) | Percent Error |
|-----------|---------------------------------|---------------|
| 50        | 23,040                          | 0.0000%       |
| 75        | 15,360                          | 0.0000%       |
| 110       | 10,473                          | -0.2865%      |
| 134.5     | 8,565                           | 0.0876%       |
| 150       | 7,680                           | 0.0000%       |
| 300       | 3,840                           | 0.0000%       |
| 600       | 1,920                           | 0.0000%       |
| 1,200     | 920                             | 4.3478%       |
| 1,800     | 640                             | 0.0000%       |
| 2,000     | 576                             | 0.0000%       |
| 2,400     | 480                             | 0.0000%       |
| 3,600     | 320                             | 0.0000%       |
| 4,800     | 240                             | 0.0000%       |
| 7,200     | 160                             | 0.0000%       |
| 9,600     | 120                             | 0.0000%       |
| 19,200    | 60                              | 0.0000%       |
| 38,400    | 30                              | 0.0000%       |
| 56,000    | 21                              | -2.0408%      |



### **Interrupt Enable Register**

The Interrupt Enable Register is defined in Table 1-7.

| Bits | Name     | Default State | Valid State | Function                                                 |
|------|----------|---------------|-------------|----------------------------------------------------------|
|      |          |               |             | Enables Received Data Available Interrupt                |
| 0    | ERBFI    | 0             | 0, 1        | 0 – Disabled<br>1 – Enabled                              |
|      |          |               |             | Enables the Transmitter Holding Register Empty Interrupt |
| 1    | ETBEI    | 0             | 0, 1        | 0 – Disabled<br>1 – Enabled                              |
|      |          |               |             | Enables the Receiver Line Status Interrupt               |
| 2    | ELSI     | 0             | 0, 1        | 0 – Disabled<br>1 – Enabled                              |
|      |          |               |             | Enables the Modem Status Interrupt                       |
| 3    | EDSSI    | 0             | 0, 1        | 0 – Disabled<br>1 – Enabled                              |
| 74   | Reserved | 0             | 0           | Always 0                                                 |

### **Interrupt Identification Register**

The Interrupt Identification Register is defined in Table 1-8.

| Bits | Name     | Default State | Valid States | Function                                               |
|------|----------|---------------|--------------|--------------------------------------------------------|
| 30   | IIR      | 1h            | 0Ch          | Interrupt Identification bits. Described in Table 1-9. |
| 54   | Reserved | 00            | 00           | Always 00                                              |
| 76   | Mode     | 11            | 11           | 11 – FIFO mode                                         |



The Interrupt Identification Register field is defined in Table 1-9.

| Table 1-9 • Inter | rrupt Identification  | Register Field  |        |
|-------------------|-----------------------|-----------------|--------|
|                   | in upt identification | Register i leiu | (IIIX) |

| IIR Value[3:0)] | Priority Level      | Interrupt Type                           | Interrupt Source                                                                                                                                            | Interrupt Reset Control                                                                 |
|-----------------|---------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| 0110            | Highest             | Receiver Line<br>Status                  | Overrun error, parity error,<br>framing error, or break interrupt                                                                                           | Reading the Line Status<br>Register                                                     |
| 0100            | Second              | Received Data<br>Available               | Receiver Data Available                                                                                                                                     | Reading the Receiver<br>Buffer Register or the<br>FIFO drops below the<br>trigger level |
| 1100            | Second              | Character<br>Timeout<br>Indication       | No characters have been read<br>from the RX FIFO during the last<br>four character times and there<br>was at least one character in it<br>during this time. | Reading the Receiver<br>Buffer Register                                                 |
| 0010            | Third               | Transmitter<br>Holding Register<br>Empty | Transmitter Holding Register<br>Empty                                                                                                                       | Reading the IIR or writing<br>into the Transmitter<br>Holding Register                  |
| 0000            | Fourth Modem Status |                                          | Clear to Send, Data Set Ready,<br>Ring Indicator, or Data Carrier<br>Detect                                                                                 | Reading the modern<br>Status Register                                                   |

### Line Control Register

The Line Control Register is defined in Table 1-10.

| Bits | Name | Default State | Valid States | Function                                                    |
|------|------|---------------|--------------|-------------------------------------------------------------|
|      |      | 0             | 03h          | Word Length Select                                          |
|      |      |               |              | 00 – 5 bits                                                 |
| 10   | WLS  |               |              | 01 - 6 bits                                                 |
|      |      |               |              | 10 – 7 bits                                                 |
|      |      |               |              | 11 – 8 bits                                                 |
|      | STB  | 0             | 0, 1         | Number of Stop Bits                                         |
| 2    |      |               |              | 0 – 1 stop bit                                              |
| 2    |      |               |              | $1 - 1\frac{1}{2}$ stop bits when WLS = 00                  |
|      |      |               |              | 2 stop bits in other cases                                  |
|      |      | 0             | 0, 1         | Parity Enable                                               |
| 3    | PEN  |               |              | 0 – Disabled                                                |
| Ŭ    |      |               |              | 1 – Enabled. Parity is added in transmission and checked in |
|      |      |               |              | receiving.                                                  |
|      | EPS  | 0             | 0, 1         | Even Parity Select                                          |
| 4    |      |               |              | 0 – Odd parity                                              |
|      |      |               |              | 1 – Even parity                                             |



### Table 1-10 • Line Control Register (continued)

|   |      |   |      | Stick Parity                                                                                                                           |
|---|------|---|------|----------------------------------------------------------------------------------------------------------------------------------------|
|   |      |   |      | 0 – Disabled                                                                                                                           |
|   |      |   |      | 1 – Enabled                                                                                                                            |
| 5 | SP   | 0 | 0, 1 | When stick parity is enabled, it works as follows:                                                                                     |
|   |      |   |      | Bits 43                                                                                                                                |
|   |      |   |      | 11 – 0 will be sent as a parity bit, and checked in receiving.                                                                         |
|   |      |   |      | 01 – 1 will be sent as a parity bit, and checked in receiving.                                                                         |
|   | SB   | 0 | 0, 1 | Set Break                                                                                                                              |
| 6 |      |   |      | 0 – Disabled                                                                                                                           |
| Ŭ | 0D   |   |      | 1 – Set break. SOUT is forced to 0. This does not have any effect on transmitter logic. The break is disabled by setting the bit to 0. |
|   |      | 0 | 0, 1 | Divisor Latch Access Bit                                                                                                               |
| 7 | DLAB |   |      | 0 – Disabled. Normal addressing mode in use                                                                                            |
|   | DEAD |   |      | 1 – Enabled. Enables access to the Divisor Latch registers during read or write operation to addresses 0 and 1.                        |

# Modem Control Register

The Modem Control Register is defined in Table 1-11.

| Bits | Name | Default<br>State | Valid<br>States | Function                                                                          |
|------|------|------------------|-----------------|-----------------------------------------------------------------------------------|
| 0    | DTR  | 0                | 0, 1            | Controls the Data Terminal Ready (DTRn) output.<br>0 – DTRn <= 1<br>1 – DTRn <= 0 |
| 1    | RTS  | 0                | 0, 1            | Controls the Request to Send (RTSn) output.<br>0 – RTSn <= 1<br>1 – RTSn <= 0     |
| 2    | Out1 | 0                | 0, 1            | Controls the Output1 (OUT1n) signal.<br>0 – OUT1n <= 1<br>1 – OUT1n <= 0          |
| 3    | Out2 | 0                | 0, 1            | Controls the Output2 (OUT2n) signal.<br>0 – OUT2n <=1<br>1 – OUT2n <=0            |



### Table 1-11 • Modem Control Register

| 4  | Loop         | 0  | 0, 1 | Loop enable bit<br>0 – Disabled<br>1 – Enabled. The following happens in loop mode:<br>SOUT is set to 1. The SIN, DSRn, CTSn, RIn, and DCDn inputs are<br>disconnected. The output of the Transmitter Shift Register is looped back into<br>the Receiver Shift Register. The modem control outputs (DTRn, RTSn,<br>OUT1n, and OUT2n) are connected internally to the modem control inputs,<br>and the modem control output pins are set at 1. In loopback mode, the<br>transmitted data is immediately received, allowing the CPU to check the<br>operation of the UART. The interrupts are operating in loop mode. |
|----|--------------|----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 74 | Reserve<br>d | 0h | 0    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

### Line Status Register

The Line Status Register is defined in Table 1-12.

 Table 1-12 • Line Status Register (read only)

| Bits | Name | Default<br>State | Valid States | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | DR   | 0                | 0, 1         | Data Ready indicator<br>1 when a data byte has been received and stored in the receive buffer<br>or the FIFO. DR is cleared to 0 when the CPU reads the data from the<br>receive buffer or the FIFO.                                                                                                                                                                                                                                                                                                                                             |
| 1    | OE   | 0                | 0, 1         | Overrun Error indicator<br>Indicates that the new byte was received before the CPU read the<br>byte from the receive buffer, and that the earlier data byte was<br>destroyed. OE is cleared when the CPU reads the Line Status<br>Register. If the data continues to fill the FIFO beyond the trigger level,<br>an overrun error will occur once the FIFO is full and the next<br>character has been completely received in the shift register. The<br>character in the shift register is overwritten, but it is not transferred to<br>the FIFO. |
| 2    | PE   | 0                | 0, 1         | Parity Error indicator<br>Indicates that the received byte had a parity error. PE is cleared when<br>the CPU reads the Line Status Register. This error is revealed to the<br>CPU when its associated character is at the top of the FIFO.                                                                                                                                                                                                                                                                                                       |
| 3    | FE   | 0                | 0, 1         | Framing Error indicator<br>Indicates that the received byte did not have a valid Stop bit. FE is<br>cleared when the CPU reads the Line Status Register. The UART will<br>try to resynchronize after a framing error. To do this, it assumes that<br>the framing error was due to the next start bit, so it samples this start<br>bit twice, and then starts receiving the data. This error is revealed to<br>the CPU when its associated character is at the top of the FIFO.                                                                   |



| 4 | BI   | 0 | 0, 1 | Break Interrupt indicator<br>Indicates that the received data is at 0 longer than a full word<br>transmission time (start bit + data bits + parity + stop bits). BI is<br>cleared when the CPU reads the Line Status Register. This error is<br>revealed to the CPU when its associated character is at the top of the<br>FIFO. When break occurs, only one zero character is loaded into the<br>FIFO. |
|---|------|---|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 | THRE | 1 | 0, 1 | Transmitter Holding Register Empty indicator<br>Indicates that the UART is ready to transmit a new data byte. THRE<br>causes an interrupt to the CPU when bit 1 (ETBEI) in the Interrupt<br>Enable Register is 1. This bit is set when the TX FIFO is empty. It is<br>cleared when at least one byte is written to the TX FIFO.                                                                        |
| 6 | TEMT | 1 | 0, 1 | Transmitter Empty indicator<br>This bit is set to 1 when both the transmitter FIFO and shift registers<br>are empty.                                                                                                                                                                                                                                                                                   |
| 7 | FIER | 0 | 1    | This bit is set when there is at least one parity error, framing error, or break indication in the FIFO. FIER is cleared when the CPU reads the LSR if there are no subsequent errors in the FIFO.                                                                                                                                                                                                     |

# Modem Status Register

The Modem Status Register is defined in Table 1-13.

| Bits | Name | Default State | Valid States | Function                                                                                                                                                                      |
|------|------|---------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | DCTS | 0             | 0, 1         | Delta Clear to Send indicator.<br>Indicates that the CTSn input has changed state since the last time it was<br>read by the CPU.                                              |
| 1    | DDSR | 0             | 0, 1         | Delta Data Set Ready indicator<br>Indicates that the DSRn input has changed state since the last time it was<br>read by the CPU.                                              |
| 2    | TERI | 0             | 0, 1         | Trailing Edge of Ring Indicator detector.<br>Indicates that RI input has changed from 0 to 1.                                                                                 |
| 3    | DDCD | 0             | 0, 1         | Delta Data Carrier Detect indicator<br>Indicates that DCD input has changed state.<br>NOTE: Whenever bit 0, 1, 2, or 3 is set to 1, a Modem Status Interrupt is<br>generated. |
| 4    | CTS  | 0             | 0, 1         | Clear to Send<br>The complement of the CTSn input. When bit 4 of the Modem Control<br>Register (MCR) is set to 1 (loop), this bit is equivalent to DTR in the MCR.            |



### Table 1-13 • Modem Status Register (read only)

| 5 | DSR | 0 | 0, 1 | Data Set Ready<br>The complement of the DSR input. When bit 4 of the MCR is set to 1<br>(loop), this bit is equivalent to RTSn in the MCR.   |
|---|-----|---|------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 6 | RI  | 0 | 0, 1 | Ring Indicator<br>The complement of the RIn input. When bit 4 of the MCR is set to 1 (loop),<br>this bit is equivalent to OUT1 in the MCR.   |
| 7 | DCD | 0 | 0, 1 | Data Carrier Detect<br>The complement of DCDn input. When bit 4 of the MCR is set to 1 (loop),<br>this bit is equivalent to OUT2 in the MCR. |

### **Scratch Register**

The Scratch Register is defined in Table 1-14.

### Table 1-14 • Scratch Register

| Bits | Name | Default State | Function                                                   |
|------|------|---------------|------------------------------------------------------------|
| 70   | SCR  | 00h           | Read/write register for CPU. No effects on UART operation. |



# 2 – Tool Flows

## Licenses

Core16550 is licensed in two ways. Depending on your license, tool flow functionality may be limited.

### **Obfuscated**

Complete RTL code is provided for the core, enabling the core to be instantiated with Libero SoC. Simulation, Synthesis, and Layout can be performed with Libero SoC. The RTL code for the core is obfuscated, and some of the testbench source files are not provided. They are pre-compiled into the compiled simulation library instead.

### RTL

Complete RTL source code is provided for the core and testbenches.

# **SmartDesign**

Core16550 is available for download in the SmartDesign IP deployment design environment. The core can be configured using the configuration GUI within SmartDesign, as shown in Figure 2-1.

For more information on using SmartDesign to instantiate and generate cores, refer to the *Using DirectCore in Libero SoC User's Guide*.

| Configuration |              |
|---------------|--------------|
| Testbench:    | User 👻       |
| License:      | None<br>User |
| © Obf         | fuscated     |

Figure 2-1 • Core16550 Configuration



# **Simulation Flows**

The user testbench for Core16550 is included in all releases.

To run simulations, select the user testbench flow within SmartDesign and click **Generate Design** under the SmartDesign menu. The user testbench is selected through the Core Testbench Configuration GUI.

When SmartDesign generates the Libero SoC project, it will install the user testbench files.

To run the user testbench, set the design root to the Core16550 instantiation in the Libero SoC **Design Hierarchy** pane and click the **Simulation** icon in the SoC Design Flow window. This will invoke ModelSim® and automatically run the simulation.

### Synthesis in Libero SoC

Click the **Synthesis** icon in Libero SoC. The Synthesis window appears, displaying the Synplify® project. Set Synplify to use the Verilog 2001 standard if Verilog is being used. To run Synthesis, click the **Run** icon.

### Place-and-Route in Libero SoC

Having set the design route appropriately and run Synthesis, click the **Layout** icon in Libero SoC to invoke Designer. Core16550 requires no special place-and-route settings.



# 3 – Core16550

## **Parameters**

E.

Core16550 has a top-level parameter/generic that is used to select the device family (Table 3-1).

| Parameter<br>Name | Description                                     | Allowed<br>Values | Default |
|-------------------|-------------------------------------------------|-------------------|---------|
|                   | Must be set to match the supported FPGA family. |                   |         |
|                   | 11 – Axcelerator                                |                   |         |
|                   | 12 – RTAX-S                                     |                   |         |
|                   | 14 – ProASIC <sup>PLUS</sup>                    |                   |         |
|                   | 15 – ProASIC3                                   |                   |         |
|                   | 16 – ProASIC3E                                  |                   |         |
| FAMILY            | 17 – Fusion                                     | 11 to 25          | 15      |
|                   | 18 – SmartFusion                                |                   |         |
|                   | 19 – SmartFusion2                               |                   |         |
|                   | 20 – IGLOO                                      |                   |         |
|                   | 21 – IGLOOe                                     |                   |         |
|                   | 24 – IGLOO2                                     |                   |         |
|                   | 25 – RTG4                                       |                   |         |

### Table 3-1 • Core Parameters





# 4 – Core Interfaces

# **I/O Signal Description**

Core16550 I/O definitions are given in Table 4-1.

| Table 4-1 | • I/O Signa | al Summary |
|-----------|-------------|------------|
|-----------|-------------|------------|

| Name        | Туре | Polarity | Description                                                                                                                                                                                                                                                                                                 |  |
|-------------|------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| PRESETN     | In   | LOW      | Master reset                                                                                                                                                                                                                                                                                                |  |
|             |      |          | Master clock                                                                                                                                                                                                                                                                                                |  |
| PCLK        | In   | -        | PCLK is divided by the value of the Divisor Registers. The result is then divided again by 16 to produce the baud rate. The resultant signal is the BAUDOUT signal. The rising edge of this pin is used to strobe all input and output signals.                                                             |  |
|             |      |          | APB write/read enable, active high                                                                                                                                                                                                                                                                          |  |
| PWRITE      | In   | HIGH     | When HIGH, data is written to the specified address location. When LOW, data is read from the specified address location.                                                                                                                                                                                   |  |
|             |      |          | APB Address                                                                                                                                                                                                                                                                                                 |  |
| PADDR[4:0]  | In   |          | This bus provides the link for the CPU to the address of the register of Core16550 to be read from or written to.                                                                                                                                                                                           |  |
|             |      |          | APB select                                                                                                                                                                                                                                                                                                  |  |
| PSEL        | In   | HIGH     | When this is HIGH along with PENABLE, reading and writing to Core16550 is enabled.                                                                                                                                                                                                                          |  |
|             |      |          | Data input bus                                                                                                                                                                                                                                                                                              |  |
| PWDATA[7:0] | In   | -        | Data on this bus will be written into the addressed register during a write cycle.                                                                                                                                                                                                                          |  |
|             |      |          | APB enable                                                                                                                                                                                                                                                                                                  |  |
| PENABLE     | In   | HIGH     | When this is HIGH along with PSEL, reading and writing to Core16550 is enabled.                                                                                                                                                                                                                             |  |
|             |      |          | Data output bus                                                                                                                                                                                                                                                                                             |  |
| PRDATA[7:0] | Out  | -        | This bus will hold the value of the addressed register during a read cycle.                                                                                                                                                                                                                                 |  |
|             |      |          | Clear to Send                                                                                                                                                                                                                                                                                               |  |
| CTSn        | In   | LOW      | This active low signal is an input showing when the attached device (modem) is ready to accept data. Core16550 passes this information to the CPU via the Modem Status register. This register also indicates if the CTSn signal has changed since the last time the register was read.                     |  |
|             |      |          | Data Set Ready                                                                                                                                                                                                                                                                                              |  |
| DSRn        | In   | LOW      | This active low signal is an input indicating when the attached device (modem) is ready to set up a link with Core16550. Core16550 passes this information to the CPU via the Modem Status Register. This register also indicates if the DSRn signal has changed since the last time the register was read. |  |
|             |      |          | Data Carrier Detect                                                                                                                                                                                                                                                                                         |  |
| DCDn        | In   | LOW      | This active low signal is an input indicating when the attached device (modem) has detected a carrier. Core16550 passes this information to the CPU via the Modem Status Register. This register also indicates if the DCDn signal has changed since the last time the register was read.                   |  |



Core Interfaces

### Table 4-1 • I/O Signal Summary (continued)

| Name         | Туре  | Polarity | Description                                                                                                                                                                                                                                                                                                     |
|--------------|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |       |          | Serial Input Data                                                                                                                                                                                                                                                                                               |
| SIN          | In    | -        | This is the data that will be transmitted into Core16550. It is synchronized with the PCLK input pin.                                                                                                                                                                                                           |
|              |       |          | Ring Indicator                                                                                                                                                                                                                                                                                                  |
| RIn          | In    | LOW      | This active low signal is an input showing when the attached device (modem) has sensed a ring signal on the telephone line. Core16550 passes this information to the CPU via the Modem Status Register. This register also indicates when the RIn trailing edge was sensed.                                     |
|              |       |          | Serial output data                                                                                                                                                                                                                                                                                              |
| SOUT         | Out   | _        | This is the data that will be transmitted from Core16550. It is synchronized with the BAUDOUT output pin.                                                                                                                                                                                                       |
|              |       |          | Request to Send                                                                                                                                                                                                                                                                                                 |
| RTSn         | Out   | LOW      | This active low output signal is used to inform the attached device (modem) that Core16550 is ready to send data. It is programmed by the CPU via the Modem Control Register.                                                                                                                                   |
|              |       |          | Data Terminal Ready                                                                                                                                                                                                                                                                                             |
| DTRn         | Out   | LOW      | This active low output signal informs the attached device (modem) that<br>Core16550 is ready to establish a communications link. It is<br>programmed by the CPU via the Modem Control Register.                                                                                                                 |
|              |       |          | Output 1                                                                                                                                                                                                                                                                                                        |
| OUT1n        | Out   | LOW      | This active low output is a user-defined signal. It is programmed by the CPU via the Modem Control Register and is set to the opposite value. programmed.                                                                                                                                                       |
|              |       |          | Output 2                                                                                                                                                                                                                                                                                                        |
| OUT2n        | Out   | LOW      | This active low output signal is a user-defined signal. It is programmed<br>by the CPU via the Modem Control Register and is set to the opposite<br>value. programmed.                                                                                                                                          |
|              |       |          | Interrupt Pending                                                                                                                                                                                                                                                                                               |
| INTR         | Out   | HIGH     | This active high output signal is the interrupt output signal from<br>Core16550. It can be programmed to become active on certain events,<br>informing the CPU that such an event has occurred (see "Interrupt<br>Identification Register" on page 9 for details). The CPU can then take<br>appropriate action. |
|              |       |          | Baud out                                                                                                                                                                                                                                                                                                        |
| BAUDOUTn     | Out   | LOW      | This is an output clock signal derived from the input clock (see PCLK description) for synchronizing the data output stream from SOUT.                                                                                                                                                                          |
|              |       |          | Receiver ready to receive transmissions                                                                                                                                                                                                                                                                         |
| RXRDYN       | Out   | LOW      | This active low output signal indicates to the CPU that the receiver section of Core16550 is available for data to be read.                                                                                                                                                                                     |
|              |       |          | Transmitter ready to transmit data                                                                                                                                                                                                                                                                              |
| TXRDYN       | Out   | LOW      | This active low signal indicates to the CPU that the transmitter section of Core16550 has space to write data for transmission.                                                                                                                                                                                 |
| rxfifo_empty | Out   | High     | Receive FIFO empty                                                                                                                                                                                                                                                                                              |
|              | - Cur |          | This signal goes HIGH when the receive FIFO is empty.                                                                                                                                                                                                                                                           |
| rxfifo_full  | Out   | High     | Receive FIFO full                                                                                                                                                                                                                                                                                               |
| _            |       | Ŭ        | This signal goes HIGH when the receive FIFO is full.                                                                                                                                                                                                                                                            |



# 5 – Timing Diagrams

# Data Write Cycle and Data Read Cycle

Figure 5-1 and Figure 5-2 depict write cycle and read cycle timing relationships relative to the APB system clock, PCLK.

### **Register Write**

As shown in Figure 5-1, the Address, Select, and Enable signals are latched and must be valid prior to the rising edge of PCLK. Writing occurs at the rising edge of the PCLK signal.



Figure 5-1 • Data Write Cycle

### **Register Read**

As shown in Figure 5-2, the Address, Select, and Enable signals are latched and must be valid prior to the rising edge of PCLK. Reading occurs at the rising edge of the PCLK signal.



### Figure 5-2 • Data Read Cycle

More detailed descriptions and timing waveforms can be found in the AMBA specification: http://www.amba.com/products/solutions/AMBA\_Spec.html.



# **Receiver Synchronization**

When the Receiver detects a LOW state in the incoming data stream, it will synchronize to it. After the start edge, the UART will wait  $1.5 \times$  (the normal bit length). This causes each subsequent bit to be read at the middle of its width. Figure 5-3 depicts this synchronization process.



*Figure 5-3* • Receiver Synchronization



# 6 – Testbench Operation

Two testbenches are provided with Core16550:

- VHDL user testbench: Simple-to-use testbench written in VHDL. This testbench is intended for customer modification.
- Verilog user testbench: Simple-to-use testbench written in Verilog. This testbench is intended for customer modification.

## **User Testbench**

A block diagram of the example user design and testbench is shown in Figure 6-1.



#### Figure 6-1 • Core16550 User Testbench

The user testbench includes a simple example design that serves as a reference for users who want to implement their own designs.

The testbench for the example user design implements a subset of the functionality tested in the verification testbench, described in "User Testbench" on page 23. Conceptually, as shown in Figure 6-1, instantiation of Core16550 is simulated using a behavioral microcontroller and a simulated loopback connection. Example transmit and receive by the same Core16550 unit are demonstrated by the user testbench so you can gain a basic understanding of how to use this core.

The user testbench demonstrates the basic setup, transmit, and receive operations of Core16550. The user testbench exercises the following:

- 1. Write to the control registers.
- 2. Read the control registers.
- 3. Turn on transmit and receive.
- 4. Transmit and receive one byte.
- 5. Check received data.



# 7 – List of Changes

The following table lists critical changes that were made in each revision of the chapter.

| Date             | Changes                                                                                                                                                             | Page   |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 50200110-4/2.15  | Added 'IGLOO2' and 'RTG4' to the "Supported Device Families" section and to Table 1 in the "Device Utilization and Performance" section.                            | 4      |
| 50200110-3/12.12 | Added 'SmartFusion2' to the "Supported Device Families" section and to Table 1 in the "Device Utilization and Performance" section (SAR 43254).                     | 4      |
| 50200110-2/4.12  | Added 'SmartFusion' to the "Supported Device Families" section and to Table 1 in the "Device Utilization and Performance" section (SAR 36238).                      |        |
|                  | Added 'AGLE600V2' to Table 1 in the "Device Utilization and Performance" section, as also modified the ' <b>Cell or Tiles</b> ' values for SmartFusion (SAR 11944). | 4      |
|                  | Updated Default (reset) Value for IIR and FCR in Table 1-1, <b>Core16550 Register Summary</b> (SAR 37805).                                                          | 6      |
|                  | Updated FCR[3] definition in Table 1-4 (SAR 22657).                                                                                                                 |        |
|                  | Updated <b>Default State</b> for 76 Bit definition in Table 1-8 (SAR 36238).                                                                                        |        |
|                  | Replaced Figure 2-1 with a new image (SAR 36238).                                                                                                                   | 15     |
|                  | Deleted the 'Evaluation' section and modified the Obfuscated section (SAR 36238).                                                                                   | 15     |
|                  | Added references to Libero SoC, and the SmartDesign and Simulation Flows sections (SAR 36238).                                                                      | 15, 16 |
|                  | Removed all references to CoreConsole and Libero IDE, deleted the 'CoreConsole' and 'Importing into Libero IDE' sections (SAR 36238).                               | 15, 16 |
|                  | Renamed the Place-and-Route in Libero IDE section to "Place-and-Route in Libero SoC" section(SAR 36238).                                                            | 16     |
|                  | Added 'SmartFusion' Core Parameter to the Table 3-1 (SAR 36238).                                                                                                    | 17     |
|                  | Deleted the 'Verification Testbench' section (SAR 37805). Evaluation license/RTL no longer relevant as Obfuscated licenses are available free.                      | 23     |
| 50200110-1/1.08  | The "Supported Device Families" section was added in v2.1.                                                                                                          | 4      |

*Note:* \*The part number is located on the last page of the document. The digits following the slash indicate the month and year of publication.





# 8 – Product Support

Microsemi SoC Products Group backs its products with various support services, including Customer Service, Customer Technical Support Center, a website, electronic mail, and worldwide sales offices. This appendix contains information about contacting Microsemi SoC Products Group and using these support services.

## **Customer Service**

Contact Customer Service for non-technical product support, such as product pricing, product upgrades, update information, order status, and authorization.

From North America, call 800.262.1060 From the rest of the world, call 650.318.4460 Fax, from anywhere in the world, 650.318.8044

## **Customer Technical Support Center**

Microsemi SoC Products Group staffs its Customer Technical Support Center with highly skilled engineers who can help answer your hardware, software, and design questions about Microsemi SoC Products. The Customer Technical Support Center spends a great deal of time creating application notes, answers to common design cycle questions, documentation of known issues, and various FAQs. So, before you contact us, please visit our online resources. It is very likely we have already answered your questions.

## **Technical Support**

For Microsemi Technical Support, visit http://www.microsemi.com/design-support/technical-support.

## Website

You can browse a variety of technical and non-technical information on the SoC home page, at www.microsemi.com/soc.

## **Contacting the Customer Technical Support Center**

Highly skilled engineers staff the Technical Support Center. The Technical Support Center can be contacted by email or through the Microsemi SoC Products Group website.

### Email

You can communicate your technical questions to our email address and receive answers back by email, fax, or phone. Also, if you have design problems, you can email your design files to receive assistance. We constantly monitor the email account throughout the day. When sending your request to us, please be sure to include your full name, company name, and your contact information for efficient processing of your request.

The technical support email address is soc\_tech@microsemi.com.



### My Cases

Microsemi SoC Products Group customers may submit and track technical cases online by going to My Cases.

### Outside the U.S.

Customers needing assistance outside the US time zones can either contact technical support via email (soc\_tech@microsemi.com) or contact a local sales office. Sales office listings can be found at www.microsemi.com/soc/company/contact/default.aspx.

## **ITAR Technical Support**

For technical support on RH and RT FPGAs that are regulated by International Traffic in Arms Regulations (ITAR), contact us via soc\_tech\_itar@microsemi.com. Alternatively, within My Cases, select **Yes** in the ITAR drop-down list. For a complete list of ITAR-regulated Microsemi FPGAs, visit the ITAR web page.



# Index

### В

baud rate generator 6 blocks Baudrate Generator 6 Interrupt Control 6 RWControl 5 RXBlock 5 Transmit 6 UART\_Reg 5

### С

contacting Microsemi SoC Products Group customer service 29 email 29 web-based technical support 29 core interfaces 19 version 4 Core16550 typical application 3 version 4 CoreConsole 15 customer service 29

### D

description 3 device utilization and performance 4 Divisor Control Registers 8

### F

FIFO Control Register 7 functional block description 5

### G

generics 17

### I

I/O signal descriptions 19 interrupt control 6 Interrupt Enable Register 9 Interrupt Identification Register 9

### L

licenses 15 Obfuscated 15 RTL 15 Line Control Register 10 Line Status Register 12

### Μ

Microsemi SoC Products Group email 29 web-based technical support 29 website 29 Modem Control Register 11 Modem Status Register 13

### Ρ

parameters 17 top-level 17 performance 4 product support customer service 29 email 29 My Cases 30 outside the U.S. 30 technical support 29 website 29

### R

Receiver Buffer Register 7 receiver synchronization 22 register read 21 write 21 RWControl 5 RXBlock 5

### S

Scratch Register 14 simulation flows 16 software interface 6

### Т

tech support ITAR 30 My Cases 30 outside the U.S. 30 technical support 29 timing diagrams 21 tool flows 15 transmitter holding register 7 TXBlock 6

### U

UART\_Reg 5 user testbench 24 utilization 4



Index

V verification testbench 23 W web-based technical support 27



#### Microsemi Corporate Headquarters One Enterprise, Aliso Viejo, CA 92656 USA

Within the USA: +1 (800) 713-4113 Outside the USA: +1 (949) 380-6100 Sales: +1 (949) 380-6136 Fax: +1 (949) 215-4996

#### E-mail: sales.support@microsemi.com

© 2015 Microsemi Corporation. All rights reserved. Microsemi and the Microsemi logo are trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners.

Microsemi Corporation (Nasdaq: MSCC) offers a comprehensive portfolio of semiconductor and system solutions for communications, defense & security, aerospace and industrial markets. Products include high-performance and radiation-hardened analog mixed-signal integrated circuits, FPGAs, SoCs and ASICs; power management products; timing and synchronization devices and precise time solutions, setting the world's standard for time; voice processing devices; RF solutions; discrete components; security technologies and scalable anti-tamper products; Power-over-Ethernet ICs and midspans; as well as custom design capabilities and services. Microsemi is headquartered in Aliso Viejo, Calif., and has approximately 3,400 employees globally. Learn more at **www.microsemi.com**.

Microsemi makes no warranty, representation, or guarantee regarding the information contained herein or the suitability of its products and services for any particular purpose, nor does Microsemi assume any liability whatsoever arising out of the application or use of any product or circuit. The products sold hereunder and any other products sold by Microsemi have been subject to limited testing and should not be used in conjunction with mission-critical equipment or applications. Any performance specifications are believed to be reliable but are not verified, and Buyer must conduct and complete all performance and other testing of the products, alone and together with, or installed in, any end-products. Buyer shall not rely on any data and performance specifications or parameters provided by Microsemi. It is the Buyer's responsibility to independently determine suitability of any products and to test and verify the same. The information provided by Microsemi hereunder is provided "as is, where is" and with all faults, and the entire risk associated with such information is entirely with the Buyer. Microsemi does not grant, explicitly or implicitly, to any party any patent rights, licenses, or any other IP rights, whether with regard to such information itself or anything described by such information. Information provided in this document is proprietary to Microsemi, and Microsemi reserves the right to make any changes to the information in this document or to any products and services at any time without notice.