

# Vysoké učení technické v Brně

## **INC**

Návrh číslicových systémů

| Projekt: UART | • |
|---------------|---|
|               |   |

Autor: Login:

Dmytro Trifonov xtrifo00

# Obsah

| Návrh                                             | 3 |
|---------------------------------------------------|---|
| Návrh FSM                                         | 3 |
| Scháema automatu                                  | 3 |
| Popis funkce:                                     | 4 |
| Architektura navr`zen'eho obvodu (na 'urovni RTL) | 4 |
| Popis funkce:                                     | 4 |
| Scháema obvodu                                    | 5 |
| Snímek obrazovky ze simulací                      | 5 |

## Návrh

#### Návrh FSM

#### Scháema automatu

#### Legenda:

- Typ: Mealy state machine
- Stavy: STAV: IDLE, WAIT\_STATE, RDATA, DATA\_VALID
- Vstupy: DAT, B: DATA\_FLOW\_END, C: CLK\_CNT
- Mealyho výstupy: READ\_EN, CLK\_CNT\_EN, VALID
- Extern signál: End\_bit



#### Popis funkce:

V počátečním stavu (IDLE) jsou signály READ\_EN, CLK\_CNT\_EN a VALID nastaveny na 0. Modul čeká na nízký signál sériových dat, který indikuje počáteční bit přenosu UART. Jakmile je detekován startovací bit, modul přejde do stavu WAIT STATE.

Ve stavu WAIT\_STATE je signál CLK\_CNT\_EN nastaven na 1 a signály READ\_EN a VALID jsou nastaveny na 0. Modul čeká na přijetí koncového bitu přenosu UART. Po zjištění koncového bitu modul přejde do stavu DATA\_VALID. Pokud není koncový bit detekován, modul přejde do stavu RDATA.

Ve stavu RDATA je signál CLK\_CNT\_EN nastaven na 1 a signál READ\_EN je nastaven na 1. Modul čte datové bity přenosu UART a čeká na signál řízení toku dat (DATA\_FLOW\_END), který signalizuje konec přenosu dat. Když signál řízení toku dat indikuje konec přenosu, modul přejde zpět do stavu WAIT STATE.

Ve stavu DATA\_VALID je signál CLK\_CNT\_EN nastaven na 0 a signál READ\_EN na 0. Modul nastaví signál VALID na 1, což znamená, že přijatá data jsou platná. Modul pak přejde zpět do stavu IDLE.

#### Architektura navr zen eho obvodu (na 'urovni RTL)

#### Popis funkce:

UART\_RX má vstupní port pro hodinový signál CLK, resetovací signál RST a vstupní datový signál DIN. Má také výstupní port pro datový výstupní signál DOUT a datový výstupní validní signál DOUT VLD.

Kód inicializuje signály pro povolení čtení (rd\_en), povolení počítání hodin (clk\_cnt\_en), platnost výstupu (out\_vld), počítání hodin (clk\_cnt) a čítač čtení (read\_counter). Entita UART\_RX\_FSM, která představuje konečný stavový stroj pro řízení strany RX, řídí výstupní signály na základě aktuálního stavu.

Procesní blok se stavem rising\_edge(CLK) aktualizuje počet hodin, čítač čtení a výstupní signál dat, když je povolení čtení vysoké a počet hodin se rovná 16. V opačném případě vynuluje počet hodin a čítač čtení. Výstupní signál platných dat je aktualizován na základě aktuálního stavu UART\_RX\_FSM.

#### Scháema obvodu



### Snímek obrazovky ze simulací

