## Relazione di vhdl

# Verdicchio Giacomo e Zarbo Nicola

24 marzo 2022

## 1 Introduzione

///////da inserire fatto da Nicola Zarbo e Giacomo Verdicchio

## 2 Architettura

Architettura: L'obiettivo è quello di riportare un schema funzionale (lo schema in moduli... un bel disegno chiaro... i segnali i bus, il/i clock, reset... );

### 2.1 Modulo 1



Figura 1: Schematico ad alto livello della composizione generale del modulo, senza entrare troppo nello specifico di tutti i segnali, ma solo mostrando il flusso di esecuzione

Il modulo gestisce la lettura e scrittura da memoria e i segnali del modulo 2 'codificatore convoluzionale'.

### 2.1.1 Segnali

• i\_clk : segnale di clock

• i\_rst : segnale di reset asincrono

• i\_start : segnale di enable '1'=> operativo,'0' => fermo (quindi il modulo viene resettato)

• i\_data : bus 8 bit, dati di lettura da ram

- o\_address: bus 16 bit, comunica alla ram l'indirizzo su cui eseguire lettura/scrittura
- o\_done : seganale di finita elaborazione '1' => flusso elaborato/scritto in memoria
- o\_en : segnale di enable per ram
- o\_we : segnale per comunicare alla ram quale operazione svolgere, '0'=> read, '1' => write
- o\_data : bus 8 bit, dati in scritttura per ram

### 2.1.2 Registri

- stato\_att, st\_prox (8 bit): registri di stato per fsm
- in\_value (4 bit): dove viene copiato la parola di 8 bit letta da i\_data
- out\_value\_buffer (8 bit) : dove viene scritta la parola da scrivere, collegato a o\_data
- in\_addr (16 bit): per mantenere address per lettura e per controllo terminazione codifica
- in\_a\_prox (16 bit): per incrementare l'address per l'operazione di read
- out\_addr, out\_a\_prox (16 bit):registri per mantenere e incrementare address per write
- nTerminazione (9 bit): usato per controllo terminazione, mantiene il valore della cella ram '0000' incrementato di 1

### 2.1.3 Segnali per componente interno

- fU : flusso di bit in lettura da codificare
- fY : flusso di 2 bit in uscita da codificatore
- stop\_en : segnale per fermare la macchina a stati del codificatore al di fuori dei clock di codifica

#### 2.1.4 FSM



Figura 2: Disegno esplicativo della FSM

Descrizione stati:

• sReStart : stato di reset, viene letto la cella all'indirizzo '0000' e il suo valore incrementato di uno viene salvato in nTerminazione

- sCuscino: stato attraversato solo una volta in tutta l'operzione di codifica, serve per consentire funzionamento con n di parole nullo (per ulteriori info vedere test seq.min)
- sTerm : controllo terminazione codifica, confronta il numero totale di parole da leggere (+ 1) con il prossim indirizzo di lettura
- sRead : stato di lettura, fornisce alla ram i segnali per leggere la prossima parola da elaborare
- sCod1 : codificatore in funzionamento, viene salvata la parola appena letta da i\_data nel registro in\_value, viene inserito in fU il primo bit dalla parola letta
- sCod2 to sCod4 : inserito in fU il nuovo bit da leggere preso da in\_value, bit codificati da fY salvati in out\_value\_buffer nell'apposita posizione
- sWrite1 : inseriti bit da fY negli ultimi due bit del registro out\_value\_buffer, forniti segnali alla ram per scrivere la parola appena codificata, codificatore bloccato
- sCod5 to sCod8 : codificatore in funzionamento, funzionamento equivalente a sCod1-sCod4, usando gli utlimi 4 bit di in\_value
- sWrite2 : equivalente a sWrite1

### 2.2 Modulo 2 : Codificatore Convoluzionale

Il codificatore convoluzionare è il modulo che si occupa dell'effettiva codifica dei dati in ingresso

#### 2.2.1 Segnali

- i\_U : flusso di bit in ingresso
- i\_start : segnale di enable del componente, se off il componente viene resettato
- i\_rst : segnale di reset asincrono
- stop\_en: segnale di enable del componente, se off viene mantenuto in standby
- o\_Y : flusso di 2 bit da codifica in uscita

### 2.2.2 Registri

st\_att, s\_pros : regsitri per stati della fsm di mealy

### 2.2.3 FSM

## 3 Risultati sperimentali

### 3.1 Sintesi

(report di sintesi)

### 3.2 Simulazioni

Le simulazioni che abbiamo creato servono a testare i casi limite che potrebbero mandare in loop, blocco o crash la macchina a stati da noi svilupata

#### 3.2.1 Simulazione max

test bench 1 (cosa fa e perchè lo fa e cosa verifica; per esempio, controlla una condizione limite)

### 3.2.2 Simulazione min

test bench 2 (cosa fa e perchè lo fa e cosa verifica; per esempio, controlla una condizione limite)



Figura 3: Disegno esplicativo del codificatore convoluzionare

| 1. Slice Logic        |   |      |   |   |   |           |    |      |
|-----------------------|---|------|---|---|---|-----------|----|------|
| +<br>  Site Type<br>+ | 1 | Used |   |   | • | Available |    |      |
| Slice LUTs*           | i | 84   | i | 0 | i | 134600    | i  | 0.06 |
| LUT as Logic          | Ī | 84   | Ī | 0 | ı | 134600    | Ī  | 0.06 |
| LUT as Memory         | I | 0    | Ī | 0 | Ī | 46200     | ī  | 0.00 |
| Slice Registers       | I | 97   | I | 0 | I | 269200    | Ī  | 0.04 |
| Register as Flip Flop | I | 97   | I | 0 | I | 269200    | Ī  | 0.04 |
| Register as Latch     | I | 0    | I | 0 | I | 269200    | Ī  | 0.00 |
| F7 Muxes              | Ī | 0    | I | 0 | I | 67300     | Ī  | 0.00 |
| F8 Muxes              | I | 0    | I | 0 | I | 33650     | Ī  | 0.00 |
| +                     | + |      | + |   | + |           | +- | +    |

### 3.2.3 Simulazione reset multipli

### 3.2.4 Simulazione start multipli

## 4 Conclusione

leggibilità over velocità

tutto facilmente moidificabile e leggibile

## 4.1 note particolari modulo 1

La fsm usa molti stati equivalenti, scelta adottata per favorire la comprensibilità usando un approccio simile agli automi a stati finiti, evitando quindi il più possibile dei controlli per la scelta del prossimo stato, tranne ovviamente in sTerm, dove viene verificata la terminazione della codifica.

# Primitives

\_\_\_\_\_

|             | ĺ | Used |   | Functional Category |
|-------------|---|------|---|---------------------|
| +<br>  FDRE |   | 82   | • | Flop & Latch        |
| LUT1        |   | 35   | Ī | LUT                 |
| LUT6        |   | 34   |   | LUT                 |
| OBUF        |   | 27   | Ī | IO                  |
| IBUF        |   | 11   | I | IO                  |
| LUT4        |   | 10   |   | LUT                 |
| CARRY4      |   | 10   |   | CarryLogic          |
| FDCE        |   | 8    |   | Flop & Latch        |
| FDSE        |   | 7    |   | Flop & Latch        |
| LUT3        |   | 4    |   | LUT                 |
| LUT2        |   | 4    | 1 | LUT                 |
| LUT5        |   | 1    | Ī | LUT                 |
| BUFG        |   | 1    | I | Clock               |
| +           | + |      | + |                     |



## 4.2 note particolari modulo 2

La codifica avviene tramite questo componente, pensato per rispecchiare il più possibile quello descritto dalla specifica e per essere facilmente utilizzabile in contesti diversi senza bisogno del Modulo 1. Questo tipo di codificatori sono usati nelle



All user specified timing constraints are met.

# 1.1 Summary of Registers by Type

telecomunicazioni, quindi potrebbe essere utilizzato collegando l'uscita ad un componente per trasmettere direttamente il segnale codificato invece di salvarlo su una memoria.

```
Hierarchical RTL Component report
Module project reti logiche
Detailed RTL Component Info :
+---Adders :
      2 Input
                  16 Bit
                            Adders := 2
                 9 Bit
                             Adders := 1
      2 Input
+---Registers :
                  16 Bit Registers := 2
                   4 Bit Registers := 1
+---Muxes :
      2 Input 16 Bit
                               Muxes := 2
                 8 Bit
      2 Input
                              Muxes := 3
      2 Input
                  4 Bit
                              Muxes := 1
     17 Input
                  4 Bit
                              Muxes := 1
                   1 Bit
      2 Input
                               Muxes := 5
Module codificatore convoluzionale
Detailed RTL Component Info :
+---Registers :
                   2 Bit
                           Registers := 2
+---Muxes :
      6 Input
                 2 Bit
                               Muxes := 1
      4 Input 1 Bit
                           Muxes := 2
```