# Výstupná správa

Meno: Adam Veselý

Login: xvesela00

# Architektúra navrhnutého obvodu (RTL)

#### Schéma obvodu:



### **Popis funkcie**

#### Komponenty

**FSM** – riadi chovanie obvodu, má 5 definovaných stavov, ktoré se menia na základe vstupov.

CLK \_CNT – čítač, ktorý počítá hodinové cykly
BIT\_CNT – čítač, ktorý počítá počet přijatých bitov (8 bitový)
DEMULTIPLEXOR – do konkrétných registrov posiela hodnoty DIN,
ktoré sú potom spojené do výstupu DOUT

#### **Funkcionalita**

Obvod je zložený z konečného automatu (FSM), čítača hodinových cyklov (CLK \_CNT), čítača bitov (BIT\_CNT) a demultiplexoru. Príchodom start-bitu (logická 0) sa obvod prepne do aktivného stavu (WAIT\_FOR\_FIRST\_BIT), v kterom počká 23 clock cyklov. Potom je DATA\_RECIEVE ACTIVE nastavený na 1. Postupne sa začne príjmať 8 bitov dat. Medzi prenosem každého bitu ubehne 16 clock cyklov. Pri každom prenosu je BIT\_CNT zvýšený o 1. Demultiplexor pomocou selektoru (SEL) pošle datový vstup (DIN) na jeden z osem výstupných registrov. Registry sú potom zobrazené na výstup DOUT. To, že validácia prebehla správne, určuje "DOUT\_VLD", ktorý je nastavený na hodnotu 1, akonáhle nahrajeme hodnotu posledného bitu.

### Návrh automatu (FSM)



## **Popis funkcie**

#### Moorové výstupy

**CLK \_ACTIVE** – hodinový čítač, aktivný v stavoch WAIT\_FOR\_FIRST\_BIT, READ DATA a WAIT FOR STOP BIT.

**DATA\_VALIDATE\_ACTIVE** – validácia prijatých dat, aktivný v stavu VALIDATE DATA.

**DATA\_RECIEVE\_ACTIVE** – prijmanie dat, aktivný v stavu READ\_DATA. **Stavv** 

**NOT\_ACTIVE** – obvod je v neaktivnom stave.

WAIT\_FOR\_FIRST\_BIT – obvod je aktivovaný, čaká sa na prvý bit.

**READ DATA** – data sú prijaté v podobe bitov.

**WAIT\_FOR\_STOP\_BIT** – data sú prijaté.

**VALIDATE\_DATA** – validácia dat.

#### **Funkcionalita**

Zo začiatku je obvod v stavu NOT\_ACTIVE a čaká, kým dostane na vstup start-bit. Po príchodu logickej 0 prechádza do stavu WAIT\_FOR\_FIRST\_BIT. V tomto stavu je 23 clock cyklov, kým prejde do stavu READ\_DATA. Postupne je načítaných 8 bitov dat a stav následne zmenený na WAIT\_FOR\_STOP\_BIT. Posledný stav VALIDATE\_DATA začína, akonáhle na vstup príde stop-bit a CLK \_COUNTER má hodnote 15. V tomto stavu prebehne validácia dat a schéma sa vrátí späť na začiatok do defaultného stavu NOT\_ACTIVE.

### Snímok obrazovky zo simulacií

