## INC projekt 1

# Technická správa

meno a priezvisko: Simona Jánošíková

login: xjanos19

## Architektúra navrhnutého obvodu UART\_RX na úrovni RTL

#### Schéma



## **Popis**

Navrhnutý UART\_RX obvod sa skladá z FSM automatu, dvoch counterov (CNT\_DATA, CNT\_READ), komparátora, AND hradla, komponenty DMX a z dvoch registrov(DOUT, DOUT\_VLD).

Automat FSM mení 4 stavy, ktoré som definovala nižšie. Podľa týchto stavov automat vysiela signály ST\_DATA, ST\_WAIT a signál VLD\_OUT. Prijíma výstupy CNR\_DATA a CNT\_READ, ktoré vysielajú countere. Taktiež vysiela vstup DIN. Podľa toho, ako FSM vyhodnotil stav, sa môžeme dostať do countera CNT\_DATA, ktorý počíta počet načítaných dát(načítavanie ôsmich bitov) a svoj output odosiela do FSM a do komponenty DMX; alebo do countera CNT\_READ, ktorý počíta clock hodinové signály, kým sa dostaneme do tzv. MID\_bitu, output odosiela do FSM a do hradla AND. Následne sa outputy counterov odošlú a komponenta DMX prijme vstupy CNT\_DATA, DIN, výstupný vektor hradla AND CMP\_IN a jednotlivých 8 bitov, ktoré sa pomocou DMX uložia do registra DOUT. Keď sa do

registra uloží výstupných 8 bitov, tak sa do registra DOUT\_VLD uloží príznak 1 a na výstupe DOUT máme výsledné dáta.

#### Návrh automatu Finite State Machine

#### Schéma

#### legenda:

stavy: START, WAIT\_C, READ, STOP

vstupy: DIN, CNT\_DATA, CNT\_READ

výstupy: ST\_WAIT, ST\_DATA, VLD\_OUT



### **Popis**

Automat má možnosť nadobudnúť 4 stavy. V stave START automat čaká, kým START\_bit nadobudne hodnotu logickej 0 (log. 0 značí stav začiatku cyklu), tým pádom signál DIN sa nastaví na 0, signál ST\_WAIT sa nastaví na 1, spustí sa tým counter hodinového signálu a prechádza sa do ďalšieho stavu. V stave WAIT\_C counter CNT\_READ počíta, kým sa nedostane do tzv. MID\_bitu . Counter CNT\_READ počíta do 24(11000), pretože sa potrebujeme dostať na hodnotu MID\_bitu. Zmena stavu nastáva, keď CNT\_READ sa rovná 24 a prechodom sa nadstaví signál ST\_DATA na 1, čo značí stav spustenia načítavania dát. V stave READ counter CNT\_DATA počíta do 8(1000), pretože potrebujeme načítať 8 bitov. Keď sa všetkých 8 bitov načíta, tak sa nastavia signály ST\_WAIT a ST\_DATA na 0 a prechádza sa do ďalšieho stavu. V stave STOP čítame ďalšie bity a čakáme, kým nenadobudnú postupnú hodnotu 1 → 0, čo nám naznačuje START ďalšieho cyklu tohto automatu.

# Snímka obrazovky programu ModelSim s ukážkou časových priebehov simulácie

