## 1 Výstupní zpráva

• Jméno: Maxim Plička

• Login: xplick04

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

Schéma obvodu:



#### 2.1 Popis funkce

Celý proces začne, jakmile se READ\_EN nastaví na '1', tímto zjistím, že jsem na prvním mid bitu slova. Během toho, co je READ\_EN na '1' počítám cnt (počítačka clock signálů), abych věděl v na jakém bitu slova se nacházím. Následně vypisuju hodnotu DIN na daný DOUT v intervalech po 16 clock signálech. Poprvé se vypíše hodnota DIN hned, jakmile je cnt rovno nule, poté se vypisuje po 16 příchozích clock signálech. Na konci slova se zapne PRINT\_EN, který značí konec slova. Společně s příchodem signálu PRINT\_EN se nastaví DOUT\_VLD na '1' po dobu periody jednoho clock signálu a resetuje se cnt. Poté je "controller"připraven na přichod dalšího slova. V případě RST signálu se resetuje cnt a čeká se než přijde další slovo.

### 3 Návrh automatu (Finite State Machine)

Schéma automatu:



#### 3.1 Popis funkce

Prvotní stav je nastaven na S\_WAIT\_START\_BIT, následně se čeká, než na DIN přijde start bit. Jakmile přijde start bit (DIN = 0), přepne se stav na S\_START\_BIT. Následně se musí cnt (počítačka clock signálů) dostat na 23. Toto značí, že jsem na 24. clocku (mid bit prvního přijímaného bitu slova). Nyní se přepne stav FSM na S\_RECEIVE a vynuluje se cnt. Díky tomu se pošle signál READ\_EN do "controller", takže vím, kdy chci začít načítat vstup na výstup. Teď už chci cnt počítat jen do 15, což bude značit mid bity příchozího slova. Pokaždé, co se cnt rovná 15 vynuluju cnt a přičtu cnt\_bit (značí přečtené bity slova). Pak už jen čekám než se cnt\_bit rovná 7, v tento moment jsem přečetl celé slovo, přepnu word\_in na '1', čím zároveň vyšlu do "conrolleru" signál PRINT\_EN, který značí konec slova. Nyní můžu nastavit všechny hodnoty zpět na nulu a stav na S\_WAIT\_START\_BIT. FSM je pak znovu připraveno na příchod dalšího slova. V případě příchodu RST signálu FSM okamžitě zareaguje a nastaví všechny hodnoty na nulu a stav na S\_WAIT\_START\_BIT.

# 4 Snímek obrazovky ze simulací

