Jméno: Přibyl Ondřej Login: xpriby20

## Architektura navrženého obvodu (na úrovni RTL)

#### Schéma obvodu



## Popis funkce obvodu

Obvod pracuje pomocí finite state machine (FSM] s vstupními daty (v obrázku popsané DATA\_IN) a dle stavu FSM tyto data: nuluje, zapisuje do svých registrů nebo vysílá na výstup DOUT společně s zapnutým výstupem DOUT\_VLD ve stavu logické 1. V případě přepnutí z výchozího stavu na čekací stav ve kterém se obvod připravuje příjimat data je zapnut counter pomocí FSM výstupu CLK\_ON (v obrázku označený jako CLK\_CNT), který svůj výstup vrací zpět do vstupu finite state machine. V případě že se FSM přepne do stavu kdy je obvod připraven

příjimat data je zapnut FSM výstup READ, který povolí zápis do registru, který je vybrán dle counteru (BIT\_CNT) demultiplexorem každý 16 clock. Registry jsou vymazány pomocí RST pinu pokud je FSM ve stavu kdy čeká na START BIT.

#### Schéma automatu

- Vstupy: DATA\_IN=D, CLK\_CNT=C, BIT\_CNT=B

- Stavy automatu: WAITING, WAIT\_1STBIT, READING, WAIT\_END, VALID OUTPUT

- Moorovy výstupy: XX\_ = CLK\_ON, X\_X = READ\_EN, \_XX = VALID



### Popis funkce konečného automatu

FSM (Konečný automat) začíná ve stavu WAITING kdy jsou všechny výstupy v poloze logické 1. Jakmile FSM obdrží logickou 0 na vstupu DATA\_IN která reprezentuje START\_BIT a přepíná se do stavu WAIT\_1STBIT. Ve stavu WAIT\_1STBIT čeká do doby kdy má vstup CLK\_CNT hodnotu 24. V tomto čase je nastaven pouze výstup CLK\_ON na logickou 1. Po dosažení hodnoty 24 na vstupu CLK\_CNT se automat přepne do stavu READING kdy jsou přepnuty výstupy READ\_EN a CLK\_ON na logickou 1. Po dosažení hodnoty 7 na vstupu BIT\_CNT se automat přepíná do stavu WAIT\_END ve kterém jsou všechny výstupy CLK\_ON, READ\_EN a VALID nastaveny na logickou 1 a automat v tomto stavu setrvá do doby dosažení hodnoty 16 na vstupu CLK\_CNT. Poté se přepne do stavu VALID\_OUTPUT kdy jsou výstupy VALID a CLK\_ON nastaveny na logickou 1. V tomto stavu setrvá pouze do doby kdy je vstup CLK\_CNT nastaven na 1 a poté se vrací do původního stavu WAITING.

# Snímek obrazovky ze simulací

