## Výstupní zpráva projektu INC – Návrh číslicových systémů

Jméno: Kryštof Paulík

Login: xpauli08

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

Schéma obvodu



### Popis funkce

FSM na základě hodnoty obdržené z DIN nastavuje příslušné hodnoty na své výstupy. CLK\_CNT počítá hodinové signály a BIT\_CNT počítá načtené bity. Když je READ\_DATA nastaveno na 1 a CLK\_CNT dosáhne hodnoty 16 (nebo CLK\_CNT dosáhne hodnoty 24), stane se následující: BIT\_CNT se inkrementuje, vstup EN (enable) demultiplexoru se nastaví na 1, demultiplexor přiřadí hodnotu DIN do příslušného registru určeného hodnotou BIT\_CNT a CLK\_CNT se resetuje. Jakmile je načteno všech 8 bitů, počká se na konec stop bitu a DOUT\_VLD se nastaví na 1, čímž zároveň resetuje BIT\_CNT.

## Návrh automatu (Finite State Machine)

#### Schéma automatu

#### Legenda

- Stavy automatu: WAIT\_START\_BIT, WAIT\_FIRST\_BIT, READ\_DATA, WAIT\_STOP\_BIT,
  OUT\_VALID
- Vstupní signály: DIN, BIT\_CNT, CLK\_CNT
- Moorovy výstupy: READ DATA, CNT EN, OUT VLD



#### Popis funkce

Automat čeká na start bit ve stavu WAIT\_START\_BIT. Jakmile signál DIN změní hodnotu z 1 na 0, přechází automat do stavu WAIT\_FIRST\_BIT, kde čeká na první bit. Po potřebném počtu taktů hodinového cyklu poté přechází do stavu READ\_DATA. V tomto stavu automat setrvává, dokud nepřečte všech 8 bitů. Jakmile je BIT\_CNT roven 8, přechází automat do stavu WAIT\_STOP\_BIT, kde čeká 16 taktů hodinového cyklu (než skončí stop bit) a poté přejde do stavu OUT\_VALID. Ve stavu OUT\_VALID automat pouze nastaví OUT\_VLD na 1 a přechází do počátečního stavu.

# Snímek obrazovky ze simulací

