# Výstupní zprává projektu INC

Jméno: Hung Do Login: xdohun00

### Architektura navrženého obvodu

#### Schéma obvodu



### Popis obvodu

Hlavními součástkami obvodu jsou:

FSM pro ukládání stavu UART,

CNT, který si ukládá počet náběžných hran CLK

REG, který si ukládá načtené DIN

BITS, který si ukládá počet načtených bitů.

V první fázi FSM čeká na START\_BIT (log. 0). Po obdržení START\_BITu posílá signál CNT\_ENABLE do CNT a čeká 8 cyklů, aby potvrdil START\_BIT a synchronizoval CLK. Následně nastaví do CNT hodnotu 0001 (kvůli zpoždění signálu) přes RST\_CNT a přepne svůj stav LOAD\_DATA. Každých 16 cyklů posílá CNT signál do REG, který v ten moment přečte hodnotu, která se nachází na DIN, a BITS. Pokud se načetl osmý bit z DIN, posílá BITS signál CNT\_END zpátky do FSM, který již bude čekat jen na STOP\_BIT a poté dá pokyn poslat log. 1 na DOUT\_VLD a povolí čtení z REG na DOUT.

REG je implementován pomocí D-klopných obvodů. Pokud se mu povolí čtení (přes WE port), načtě hodnotu DIN na pozici MSB a posune všechny ostatní bity o jeden bit dolů (původní LSB je tedy odstraněn). Dokud není povolené čtení DOUT (implementace AND hradla každého portu s RE), je na výstupní DOUT vynulován.

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

#### Schéma automatu

#### Legenda:

- Stavy automatu:
  - WAIT\_START\_BIT
  - START CONFIRM
  - o LOAD\_DATA
  - WAIT\_STOP\_BIT
  - o SEND\_DATA
- Vstupní signály: DIN, CNT\_END
- Mealyho výstupy: CNT\_ENABLE, RST\_CNT
- Moorevy výstupy: DOUT\_VLD



#### Popis automatu

V prvním stavu WAIT\_START\_BIT se čeká na DIN=0, poté se přesune do START\_CONFIRM, kde čeká 8 cyklů.

Pokud je stále DIN=0, pak se přesune LOAD\_DATA, jinak se vrací zpátky na WAIT\_START\_BIT. Po načtení 8 bitů pošlě čítač CNT\_END signál a stav se změní na WAIT\_STOP\_BIT, kde automat čeká na DIN=1.

V poslední stavu pošle nastaví automat DOUT\_VLD na log. 1 a tím říká příjemci, že načtená data jsou validní. Ihned poté se vrací zpátky na WAIT\_START\_BIT, kde čeká na novou zprávu. CNT\_ENABLE je nastaven na log. 1 ve stavech START\_CONFIRM a LOAD\_DATA. RST\_CNT pro resetování čítače je jen nastaven po úspěšném START\_CONFIRM.

## Snímek obrazovky ze simulací

