# VÝSTUPNÍ ZPRÁVA

Jméno: Lucie Svobodová

xlogin: xsvobo1x Datum: 30. 04. 2021 FIT VUT, INC 2021

## ARCHITEKTURA NAVRŽENÉHO OBVODU (na úrovni RTL)

### SCHÉMA OBVODU



#### POPIS FUNKCE

Navržený obvod má vstupy CLK, RST a DIN a výstupy DOUT a DOUT\_VLD.

K ošetření asynchronního vstupu do synchronní sítě obvodu UART\_RX jsem využila klopné obvody typu D, a to konkétně 2 klopné obvody typu D zapojené za sebe pro synchronizaci vstupního signálu RST (synchronizovaný signál má název rst\_syn) a 2 další klopné obvody zapojené za sebe pro synchronizaci signálu DIN (synchronizovaný signál se din\_syn). Toto ošetření způsobí zpoždění o 2 hodinové takty, ale díky tomu jsou redukovány metastabilní stavy, které by mohly bez synchronizace nastat.

Další částí obvodu je konečný automat, jehož popis je ve druhé části této zprávy. Do obvodu je dále zapojen čítač CLK\_CNT, který počítá hodinový signál. Aktivní je, pokud je výstupní signál FSM clk\_cnt\_en = 1. Čítač bit\_cnt počítá bity. Je aktivní pouze ve stavu dread = 1, jinak je nastaven na hodnotu "0000".

Pokud je FSM ve stavu DATA\_READ, je nastaven signál dread = 1. V tomto stavu je aktivní i clk\_cnt a bit\_cnt. Pokud clk\_cnt(4) = 1, je zapsán jeden bit na výstup pomocí dekodéru 3-8 a je inkrementován bit\_cnt. clk\_cnt je vynulován a pokud bit\_cnt != "1000", čte se další bit. Po přečtení osmi bitů se automat přepne na stav čekání na stop bit a nastaví tak signál stop\_bit\_w. V tomto stavu se čeká na přijmutí log. 1 na signálu din\_syn (synchronizovaný DIN). Poté je signál stop\_bit\_en nastaven na hodnotu log. 1, automat se přepne do stavu DVALID, který registrujeme tak, že je nastaven signál dvalid = 1. V tomto stavu je na DOUT\_VLD vyslána hodnota log. 1 po dobu jednoho hodinového signálu.

### **NÁVRH AUTOMATU (Finite State Machine)**

### SCHÉMA AUTOMATU

#### Legenda

- stavy automatu: WAIT FOR START, WAIT FOR FIRST, DATA READ, WAIT FOR STOP, DVALID
- vstupy: CLK, RST, DIN, CLK\_CNT, BIT\_CNT, STOP\_BIT\_EN
- Moorovy výstupy: DREAD, CLK\_CNT\_EN, STOP\_BIT\_W, D\_VALID



#### POPIS FUNKCE

V projektu použitý konečný stavový automat je typu Moore a má 5 stavů: WAIT\_FOR\_START, WAIT\_FOR\_FIRST, DATA\_READ, WAIT\_FOR\_STOP, DVALID.

Jeho vstupy tvoří CLK - hodinový signál, RST - resetovací signál, DIN - vstupní data, CLK\_CNT, který reprezentuje čítač hodinových signálů, BIT\_CNT - čítač bitů a STOP\_BIT\_EN, který je nastaven na hodnotu log. 1, pokud byl detekován STOP bit. Výstupy automatu jsou DREAD, což je signál, který indikuje, že je automat ve stavu čtení dat, dále CLK\_CNT\_EN - indikace pracujícího čítače hodinových signálů, STOP\_BIT\_W - indikace stavu čekání na přijetí STOP bitu a D\_VALID - signál indikující, že je automat ve stavu DVALID a v další komponentě obvodu tak může být nastaven výstup DOUT VLD.

Automat může být nastaven na počáteční stav nastavením signálu RST na hodnotu log. 1. Pokud je signál RST nastaven na hodnotu log. 0, automat reaguje na náběžnou hranu hodinového signálu CLK a dalších podmínek změnou svého stavu na následující stav.

Počátečním stavem tohoto konečného automatu je stav WAIT\_FOR\_START. V tomto stavu jsou všechny výstupní signály nastaveny na hodnotu 0. V tomto stavu se čeká na detekci START bitu, tedy na hodnotu log. 0 vstupu DIN. Pokud DIN je roven log. 1, automat zůstává v tomto stavu i nadále. V opačném případě je stav změněn na stav WAIT\_FOR\_FIRST. V tomto stavu automat kontroluje hodnotu CLK\_CNT a čeká, dokud se nerovná hodnotě "10100". (dokud neprojde start bit a polovina prvního bitu). Poté se přepne na stav DATA\_READ. V tomto stavu je kontrolována hodnota vstupu BIT\_CNT. Pokud je rovna hodnotě "1000", je načteno 8 bitů a automat se přepne do stavu WAIT\_FOR\_STOP. V tomto stavu čeká na přijetí hodnoty log. 1 na vstupu STOP\_BIT\_EN. Pokud ji detekuje, přepne se do následujícího stavu, tedy stavu DVALID. V tomto stavu setrvá pouze po dobu jednoho hodinového taktu a přepne se do počátečního stavu, tedy do stavu WAIT\_FOR\_START.

## SNÍMEK OBRAZOVKY ZE SIMULACÍ

