**Technion**

*Electrical Engineering Department*

High Speed Digital System Lab

UART

Documentation

**Version**: 2.0

**Last update**: 18.03.2011

**Written By**: Beeri Schreiber and Alon Yavich

Table of content

[Table of Changes 3](#_Toc293164660)

[1 Scope 3](#_Toc293164661)

[2 Abbreviations 3](#_Toc293164662)

[3 General Description 3](#_Toc293164663)

[3.1 UART Transmitter and Receiver 3](#_Toc293164664)

[3.2 UART Characteristics 3](#_Toc293164665)

[3.3 Pinout 4](#_Toc293164666)

[3.4 UART RX Generic Parameters 4](#_Toc293164667)

[4 Basic features and function description 5](#_Toc293164668)

[4.1 FSM Diagram 6](#_Toc293164669)

[4.2 RX Operation 7](#_Toc293164670)

[5 UART TX Pinout 7](#_Toc293164671)

[5.1 UART TX Generic Parameters 7](#_Toc293164672)

[6 Basic features and function description 8](#_Toc293164673)

[6.1 FSM Diagram 9](#_Toc293164674)

[6.2 TX Operation 9](#_Toc293164675)

[6.3 Resources 10](#_Toc293164676)

[6.3.1 RX 10](#_Toc293164677)

[6.3.2 TX 10](#_Toc293164678)

[6.4 UART Simulation Tests 11](#_Toc293164679)

Table of Tables

[Table 1 – Table of changes 3](#_Toc275835884)

Table 2 – UART RX Pinout 4

Table 3 – UART RX Generic Pinout 4

[Table 4 – UART TX Pinout 7](#_Toc275835884)

Table 5 – UART TX Generic Pinout 7

Table 6 – UART Simulation test 11

Table of Figures

[Figure 1 – UART RX Pinout 4](#_Toc275754778)

[Figure 2 – Middle bit sampling 5](#_Toc275754778)

[Figure 3 – UART RX FSM Diagram 6](#_Toc275754779)

[Figure 4 – UART RX Operation 7](#_Toc275754780)

[Figure 5 – UART TX Pinout 7](#_UART_TX_Pinout)

[Figure 6 – UART TX FSM Diagram 9](#_FSM_Diagram)

[Figure 7 – UART TX Operation 9](#_TX_Operation)

# Table of Changes

|  |  |  |
| --- | --- | --- |
| Version | Date of Change | Description |
| 1.0 | 26.02.2011 | Creation of documentation |
| 2.0 | 18.03.2011 | Modifications |

Table 1 – Table of Changes

# Scope

This document aims to describe the UART (Universal Asynchronous Receiver Transmitter), together with an example environment of how to use it.

# Abbreviations

1. UART - Universal Asynchronous Receiver Transmitter
2. UART RX – UART Receiver
3. UART TX – UART Transmitter
4. TB – Test bench

# General Description

## UART Transmitter and Receiver

This component is used for asynchronous serial data channel.

The receiver converts serial start bit, data, parity and stop bit to parallel data.

The transmitter converts parallel data into serial form and automatically adds start bit, parity and stop bit.

The data word length can be 5-8 bits, according to generic parameter. Parity bit can be odd or even or if decided can be inhibited, according to generic parameters.

All inputs and outputs are synchronized with the positive edge of the clock.

Any system clock and any baud rate are supported, according to generic parameter.

## UART Characteristics

The UART is implemented with 2 components:

1. UART RX – UART Receiver
2. UART TX – UART Transmitter

Both of the components are based on the same characteristics, the parameters are generics:

1. **Start bit**: '1' or '0' according to user's choice (*uart\_idle\_g*).
2. **Data length**: 5-8 data bits (between Start and stop bit).
3. **Parity bit**: can be added after the data bits frame, include 3 generic options:
   1. Odd - a bit will be added so the total '1' bits will be odd.
   2. Even - a bit will be added so the total '1' bits will be even.
   3. Inhibited.
4. **Stop bit**: opposite of Start bit, 1 bit in length.
5. **Reset**: Reset polarity can be chosen.
6. **Baud Rate**: Transmission rate.
7. **System Clock:** 133MHzUART RX

## Pinout

![](data:image/png;base64,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)

Figure 1 – UART RX Pinout

| Pin Name | Direction | Description |
| --- | --- | --- |
| Clk | In | Input clock. |
| Reset | In | Reset. Reset polarity will be set according to the generic parameter *'reset\_polarity\_g'*. |
| Din | In | Serial data in. |
| Parity\_err | Out | '1' when there is an error in parity bit. |
| Stop\_bit\_err | Out | '1' when there is an error in stop bit. |
| Valid | Out | '1' when Parallel data valid. |
| Dout[7..0] | Out | Parallel data out. |

Table 2 – UART RX Pinout

## UART RX Generic Parameters

| Generic Parameter | Default Value | Description |
| --- | --- | --- |
| Parity\_en\_g | '0' | '1' when Parity bit enabled. |
| Parity\_odd\_g | False | False – parity EVEN, true – parity ODD. |
| uart\_idle\_g | '1' | IDLE state line value. |
| baudrate\_g | 115200 | UART's baudrate [Hz]. |
| Clkrate\_g | 133333333 | System clock [Hz]. |
| Databits\_g | 8 | Number of data bits. |
| Reset\_polarity\_g | '0' | '0' – reset is 'Active Low'. |

Table 3 – UART RX Generic Pinout

# Basic features and function description

UART RX is implemented with a FSM as its main process. It is synchronized with the system clock, and responds in any time to a Reset input with the return to IDLE state and zeroes all relevant signals. The FSM is based on a serial data flowing in, as the machine characterizes each bit as the protocol compels. Each bit which enters to the UART RX component is sampled 5 times in its middle (as shown in the wave) so there will not be any mistakes about its value, in case of lines spikes.

Figure 2 – Middle bit sampling

Another process takes place in the beginning and prevents metastability. It does so with the data in goes through two FF. where the first FF is probably in metastabiliy state but the chance that the metastability will pass beyond the second FF is almost zero.

The output is a parallel data implemented with a shift register.

An important internal constant helps us to count the period time for each bit:

* + - *Clk\_div\_factor* – is an internal constant in the FSM that represents the ratio between the system clock and the UART baud rate. This ratio is exactly the period length of one bit in the incoming data.
    - ![](data:image/x-wmf;base64,183GmgAAAAAAAMARIAQACQAAAADxSwEACQAAA+8CAAAEANcAAAAAAAUAAAACAQEAAAAFAAAAAQL///8ABQAAAC4BGQAAAAUAAAALAgAAAAAFAAAADAIgBMARCwAAACYGDwAMAE1hdGhUeXBlAADgABIAAAAmBg8AGgD/////AAAQAAAAwP///7j///+AEQAA2AMAAAgAAAD6AgAAEwAAAAAAAAIEAAAALQEAAAUAAAAUAgACngoFAAAAEwIAAmkRBQAAAAkCAAAAAgUAAAAUAm4BLQ8cAAAA+wLA/gAAAAAAAJABAAAAAAACABBUaW1lcyBOZXcgUm9tYW4A1NgSAHlIFHVAkRd16yNmlwQAAAAtAQEACQAAADIKAAAAAAEAAABfeYACBQAAABQCYAJKAhwAAAD7AsD+AAAAAAAAkAEAAAAAAAIAEFRpbWVzIE5ldyBSb21hbgDU2BIAeUgUdUCRF3XrI2aXBAAAAC0BAgAEAAAA8AEBAAoAAAAyCgAAAAACAAAAX1+2AoACBQAAABQCjAOqDxwAAAD7AsD+AAAAAAAAkAEAAAAAAAIAEFRpbWVzIE5ldyBSb21hbgDU2BIAeUgUdUCRF3XrI2aXBAAAAC0BAQAEAAAA8AECAAkAAAAyCgAAAAABAAAAX1+AAgUAAAAUAm4BKgscAAAA+wLA/gAAAAAAAJABAQAAAAACABBUaW1lcyBOZXcgUm9tYW4A1NgSAHlIFHVAkRd16yNmlwQAAAAtAQIABAAAAPABAQATAAAAMgoAAAAACAAAAENsa3JhdGVn1wBaAIwAfQCgAFoAxgGAAgUAAAAUAmACMQAcAAAA+wLA/gAAAAAAAJABAQAAAAACABBUaW1lcyBOZXcgUm9tYW4A1NgSAHlIFHVAkRd16yNmlwQAAAAtAQEABAAAAPABAgAZAAAAMgoAAAAADAAAAENsa2RpdmZhY3RvctcAWgDQAaAAWgD4AVoAoACMAFoAoACAAgUAAAAUAowDwQocAAAA+wLA/gAAAAAAAJABAQAAAAACABBUaW1lcyBOZXcgUm9tYW4A1NgSAHlIFHVAkRd16yNmlwQAAAAtAQIABAAAAPABAQAVAAAAMgoAAAAACQAAAEJhdWRyYXRlZwDDAKAAoACgAH0AoABaAMYBgAIFAAAAFAJgAo0JHAAAAPsCwP4AAAAAAACQAQAAAAEAAgAQU3ltYm9sAHU1IgpvMEcyANTYEgB5SBR1QJEXdesjZpcEAAAALQEBAAQAAADwAQIACQAAADIKAAAAAAEAAAA9X4AC1wAAACYGDwCkAUFwcHNNRkNDAQB9AQAAfQEAAERlc2lnbiBTY2llbmNlLCBJbmMuAAUBAAYHRFNNVDYAARNXaW5BbGxCYXNpY0NvZGVQYWdlcwARBVRpbWVzIE5ldyBSb21hbgARA1N5bWJvbAARBUNvdXJpZXIgTmV3ABEETVQgRXh0cmEAEgAIIS9Fj0QvQVD0EA9HX0FQ8h8eQVD0FQ9BAPRF9CX0j0JfQQD0EA9DX0EA9I9F9CpfSPSPQQD0EA9A9I9Bf0j0EA9BKl9EX0X0X0X0X0EPDAEAAQABAgICAgACAAEBAQADAAEABAAACQBAAQACAINDAAIAg2wAAgCDawACAIJfAAIAg2QAAgCDaQACAIN2AAIAgl8AAgCDZgACAINhAAIAg2MAAgCDdAACAINvAAIAg3IAAgSGPQA9AwALAAABAAIAg0MAAgCDbAACAINrAAIAg3IAAgCDYQACAIN0AAIAg2UAAgCCXwACAINnAAABAAIAg0IAAgCDYQACAIN1AAIAg2QAAgCDcgACAINhAAIAg3QAAgCDZQACAIJfAAIAg2cAAAAAAAoAAAAmBg8ACgD/////AQAAAAAACAAAAPoCAAAAAAAAAAAAAAQAAAAtAQIAHAAAAPsCEAAHAAAAAAC8AgAAALEBAgIiU3lzdGVtAADrI2aXAAAKADgAigEAAAAA/////wjjEgAEAAAALQEDAAQAAADwAQEAAwAAAAAA)

Each data bit that enters the machine is being sampled 5 times at its middle so it will be absolutely clear what is the value of the data sampled, i.e. need at least 3 samples of the same value to deiced the data value. The most important place this sampling takes place is when start bit is being detected – in this case we can avoid spikes and making the implementation noise proof.

The FSM has 5 states:

1. IDLE

The state waits for start bit (shown when inversion in *uart\_idle\_g* is being detected).

An internal counter counts until reaches to half the *clk\_div\_factor* (Middle of the bit) and then moves on to the next state.

1. STARTBIT

This state makes sure we received the start bit (with the sampler) then moves on to the next state.

* + - From now each state will advance to the next suitable state only when Clk\_div\_factor is reached.

1. RX

This state sampling each of the data bits (5-8 bits according to user's choice) while using a shift register to place the data in *dout* (represents parallel data). In case there is a parity bit (defined by the user) the FSM goes to PARITY states or straight to STOPBIT state when parity bit is inhibited.

In addition, parity value is being calculated for checking with the real parity entered later.

Calculation is according to user's choice of odd / even parity bit.

1. PARITY

The Parity that has been calculated in the RX state is now being compared with the parity bit entered, if equals going to next state (STOPBIT), if not raising a parity error flag.

1. STOPBIT

Stop bit received should be the same as *uart\_idle\_g* if not flag is rises (*stopbit\_err*).

While waiting for end of clock counter or the beginning of the next bit, valid flag is in high level to indicate that a word has been received properly.

Machine returns to IDLE state.

## FSM Diagram

Figure 3 – UART RX FSM

## RX Operation

Figure 4 – Uart RX Operation

This simulation shows the RX operation in all its stages. Detecting the start bit afterwards 8 data bits and a stop bit. Valid flag rises to high level when whole word received and *dout* has the relevant parallel data.

# UART TX Pinout

![](data:image/png;base64,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)

Figure 5 – UART TX Pinout

| Pin Name | Direction | Description |
| --- | --- | --- |
| Clk | In | Input clock |
| Reset | In | Reset. Reset polarity will be set according to the generic parameter 'reset\_polarity\_g'. |
| Din[7..0] | In | Parallel data in. |
| fifo\_empty | In | '1' when FIFO is empty . |
| fifo\_valid | in | '1' when FIFO data is valid. |
| fifo\_rd\_en | Out | '1' for FIFO's rd\_en line – data can be read from FIFO. |
| Dout | Out | Serial data out. |

Table 4 – UART TX Pinout

## UART TX Generic Parameters

| Generic Parameter | Default Value | Description |
| --- | --- | --- |
| Parity\_en\_g | '0' | '1' when Parity bit enabled. |
| Parity\_odd\_g | false | false – parity EVEN, true – parity ODD. |
| uart\_idle\_g | '1' | IDLE state line value. |
| baudrate\_g | 115200 | UART's baudrate [Hz]. |
| Clkrate\_g | 133333333 | System clock [Hz]. |
| Databits\_g | 8 | Number of data bits. |
| Reset\_polarity\_g | '0' | '0' – reset is 'Active Low'. |

Table 5 – UART TX Generic Pinout

# Basic features and function description

UART TX is implemented with a FSM as its main process. A secondary process is implementing and functions as a Shift register that also calculating the parity bit. The processes are synchronized with the system clock, and respond in any time to a Reset request with the return to IDLE state and zero all relevant signals.

The FSM is based on a parallel data flowing from a FIFO and then into the Shift register. Start bit and stop bit is being positioned in the LSB and MSB palaces in the Shift register. Every bit transmission the register is being shifted to the Right (UART's standard is LSB first) so the next bit will be ready for transmission, this way we receive Serial data in the output.

TX FSM has 3 states:

* + - Each state will advance to the next suitable state only when *Clk\_div\_factor* is reached.

1. IDLE

In this state, the machine waits for FIFO not to be empty for going to the next state, when this happens *fifo\_rd\_en* flag rises and indicates that TX unit is ready to receive data from the FIFO.

1. REGDATA

Intermediate state that waits for FIFO validation so the parallel data from FIFO could be pulled into the shift register in TX\_ST.

Start and Stop bits are being positioned inside the shift register according to LSB first configuration, Parity bit is also being calculated according to user's odd/even choice.

The data itself from the FIFO is being positioned in the shift register.

1. TX

Data bits are being pulled out from Shift register that is shifting right after each bit is transmitted. In case there is a parity bit (defined by the user) the calculated parity bit will also be transmitted. After all bits where transmitted, FSM goes back to IDLE state.

* Each step in the shift register will take place only when *Clk\_div\_factor* is reached.

## FSM Diagram

Figure 6 – UART TX FSM

## TX Operation

Figure 7 – Uart TX Operation

This simulation shows the TX operation in all its stages. Generating the start bit and after FIFO Valid flag is in a high level transmitting the data itself, At the end generating parity bit ( if needed ) and stop bit.

## Resources

### RX

* 6 AND gates
* 6 OR gate
* 41 DFF
* 123 MUX
* 1 State machine
* 4 additional operators
* 7 'Less Then' operators
* 24 selector operators
* 4 Equal operators

Maximum Frequency: 160MHz

### TX

* 1 AND gates
* 28 DFF
* 66 MUX
* 1 State machine
* 2 additional operators
* 2 Equal operators

 Maximum Frequency: 300 MHz

## UART Simulation Tests

Macro ( Do ) files had been created so multiple simulations could be execute more easily.

The variable parameters include TX and RX baud rate, Parity bit and Odd/Even parity.

Validation against expected data indicates if test had passed or not.

One Kbyte of data transfer has been simulated.

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Pass/Fail** | **Description** | | | | | | **Test Num** |
|  | ODD/EVEN | PARITY | Deviation % | RX BAUD. | TX BAUD. | CLK MHz |  |
| Pass | x | x | 0 | 115200 | 115200 | 133 | 1 |
| Pass | x | x | -4 | 115200 | 110592 | 133 | 2 |
| Pass | x | x | +5 | 115200 | 120960 | 133 | 3 |
| Fail | x | x | -5 | 115200 | 109440 | 133 | 4 |
| Pass | ODD | V | 0 | 115200 | 115200 | 133 | 5 |
| Pass | ODD | V | -5 | 115200 | 109440 | 133 | 6 |
| Pass | ODD | V | +5 | 115200 | 120960 | 133 | 7 |
| Pass | EVEN | V | 0 | 115200 | 115200 | 133 | 8 |
| Pass | EVEN | V | -4 | 115200 | 110592 | 133 | 9 |
| Pass | EVEN | V | +5 | 115200 | 120960 | 133 | 10 |
| Pass | x | x | 0 | 115200 | 115200 | 33 | 11 |
| Pass | x | x | -5 | 115200 | 109440 | 33 | 12 |
| Pass | x | x | +5 | 115200 | 120960 | 33 | 13 |
| Fail | x | x | -6 | 115200 | 108288 | 33 | 14 |
| Pass | ODD | V | 0 | 115200 | 115200 | 33 | 15 |
| Pass | ODD | V | -5 | 115200 | 109440 | 33 | 16 |
| Pass | ODD | V | +5 | 115200 | 120960 | 33 | 17 |
| Pass | EVEN | V | 0 | 115200 | 115200 | 33 | 18 |
| Pass | EVEN | V | -5 | 115200 | 109440 | 33 | 19 |
| Pass | EVEN | V | +5 | 115200 | 120960 | 33 | 20 |

Table 6 – UART Simulation Test