### Relazione di vhdl

# Verdicchio Giacomo e Zarbo Nicola

### 25 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
- $\bullet\,$ 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



Figura 3: Disegno esplicativo del codificatore convoluzionare

## 3 Risultati sperimentali

### 3.1 Sintesi

(report di sintesi)

1. Slice Logic

-----

| Site Type             | İ | Used | İ | Fixed | i | Available | İ | Util% |
|-----------------------|---|------|---|-------|---|-----------|---|-------|
| Slice LUTs*           | Ī | 84   |   | 0     |   | 134600    | I | 0.06  |
| LUT as Logic          | 1 | 84   | I | 0     | I | 134600    | Ī | 0.06  |
| LUT as Memory         | 1 | 0    | I | 0     | I | 46200     | Ī | 0.00  |
| Slice Registers       | 1 | 97   | I | 0     | I | 269200    | Ī | 0.04  |
| Register as Flip Flop | 1 | 97   | I | 0     | I | 269200    | Ī | 0.04  |
| Register as Latch     | 1 | 0    | I | 0     | I | 269200    | Ī | 0.00  |
| F7 Muxes              | 1 | 0    | I | 0     | Ī | 67300     | Ī | 0.00  |
| F8 Muxes              | 1 | 0    | I | 0     | I | 33650     | I | 0.00  |

## 7. Primitives

\_\_\_\_\_

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

|                     |          |          |                 |                                     |                   |                                     | 0,000.000                                            |
|---------------------|----------|----------|-----------------|-------------------------------------|-------------------|-------------------------------------|------------------------------------------------------|
| Name                | Value    | 0.0 us   | 0.5 us          | 1.0 us                              | 1.5 us            | 2.0 us   2.5 u                      | is  3.0 us                                           |
| 1 tb_done           | 0        |          |                 |                                     |                   |                                     |                                                      |
| ☐ ➡ mem_ad15:0]     | 0        | 0        | X 1 X           | 0 X 1000 X                          | 0 X 1001 X        | 0 X 2 X 0 X 1002                    | . 0 1003 0                                           |
| ₩ tb_rst            | 0        |          |                 |                                     |                   |                                     |                                                      |
|                     | 0        |          |                 |                                     |                   |                                     |                                                      |
| ¼ tb_dk             | 0        |          |                 |                                     |                   |                                     |                                                      |
| mem_o[7:0]          |          | ŒΧ       | X               | 162 X                               | 209 X             | 205 X 76                            | X 247 X 210                                          |
|                     | 210      |          | 0               | (0)(0)                              | 209 (193 )        | 205 (253 245                        | 247 215 211 210                                      |
| enable_wire         | 1        |          |                 |                                     |                   |                                     |                                                      |
| ™ mem_we<br>MODULO1 | 0        |          |                 |                                     |                   |                                     |                                                      |
|                     | sReStart | sheStart | V V V V V V V V |                                     |                   |                                     | sWrO XsCod5 XsCod6 XsCod7 XsCod8 X sWrO XsTerm X sRe |
|                     | 3        | 0 X      | 1               | Jai Ascode Ascode Ascode Aserd Asco | 2                 | rem /swead/scodi/scode/scods/scode/ | Setu Ascodo Ascodo Ascodo Asetu Asterm Asse          |
| ■ M out_addr[15:0]  |          |          | 1000            |                                     | 1001 X            | 1002                                | X 1003 X 1004                                        |
|                     | 75       | <u> </u> | 1000            | ^                                   | 162               | χ 2002                              | 76                                                   |
| TA NU               |          |          |                 |                                     |                   |                                     |                                                      |
| ■ 👫 fr[1:0]         | 0        |          | χ 3             | X 1 X 0 X 1 X                       | X 3 X 0 X 3 X 1 X | 0 X 3 X X                           | 3 X 1 X 0 X 2 X 1 X 0                                |
| CODIFICATORE        |          |          |                 |                                     |                   |                                     |                                                      |
|                     | s00      |          | E00             | (#10 (#01 (#10 (#01                 | ( #00 ( #10 )     | #01 (#00 (#10 (#01 )                | 800 X 810 X 801 X 810 X 811 X 800                    |
| stop_en             | 1        |          |                 |                                     |                   |                                     |                                                      |
|                     |          |          |                 |                                     |                   |                                     |                                                      |



| Design Timing Summary        |           |                              |          |                                          |           |
|------------------------------|-----------|------------------------------|----------|------------------------------------------|-----------|
| Setup                        |           | Hold                         |          | Pulse Width                              |           |
| Worst Negative Slack (WNS):  | 45,744 ns | Worst Hold Slack (WHS):      | 0,142 ns | Worst Pulse Width Slack (WPWS):          | 49,500 ns |
| Total Negative Slack (TNS):  | 0,000 ns  | Total Hold Slack (THS):      | 0,000 ns | Total Pulse Width Negative Slack (TPWS): | 0,000 ns  |
| Number of Failing Endpoints: | 0         | Number of Failing Endpoints: | 0        | Number of Failing Endpoints:             | 0         |
| Total Number of Endpoints:   | 169       | Total Number of Endpoints:   | 169      | Total Number of Endpoints:               | 98        |

All user specified timing constraints are met.

## 1.1 Summary of Registers by Type

-----

| <del></del> | <del></del>  | <del></del>             |          |
|-------------|--------------|-------------------------|----------|
| Total       | Clock Enable | '<br>  Synchronous<br>+ | _        |
| 0           | <br>         | <br>  -                 | - I      |
| I 0         | I            | -                       | Set      |
| I 0         | I            | -                       | Reset    |
| I 0         |              | Set                     | - 1      |
| I 0         | I            | Reset                   | l – I    |
| I 0         | Yes          | <b>-</b>                | - I      |
| I 0         | Yes          | <b>-</b>                | Set      |
| 8           | Yes          | <b>–</b>                | Reset    |
| 1 7         | Yes          | Set                     | -        |
| 82          | Yes          | Reset                   | - 1      |
| <b></b>     | +            | <b>.</b>                | <b>.</b> |

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

### 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 Esempio generico

Eseguo il programma con dei dati in input generici e verifico che tutti i segnali, soprattutto quelli in uscita, siano corretti ponendo particolare attenzione alla gestione dei registri di utilizzati per le operazioni di lettura e scrittura -tb\_done, per verificare la corretta terminazione della macchina -mem\_o\_data, valori in uscita -mem\_i\_data, valori letti -mem\_address, da cui vado a leggere l'indirizzo di memoria da cui leggo

#### 3.2.2 Simulazione max

Riempio la RAM (inserendo 28 valori, cioè 255) e verifico che il programma gestisca correttamente tutti gli input, in particolare verificando con cura che non si realizzi un overflow nel registro di lettura. Segnali e registri particolari che abbiamo analizzato sono stati: -tb\_done, per la terminazione del processo -mem\_o\_data, valori in uscita -mem\_i\_data, valori letti -enable\_wire

#### 3.2.3 Simulazione min

Inserisco solo alcuni zeri per verificare che la memoria li gestisca correttamente, cioè salvando solo zeri, senza elaborare numeri errati. I segnali più sfruttati nel caso particolare sono stati: -tb\_start per poter provare i restart della macchina, -tb\_rst per poter provare i reset, -t......

### 3.2.4 Simulazione reset multipli

Resetto più volte la macchina per verificarne la corretta gestione del reset, sia quando la macchina è già in esecuzione e dei vari registri e sia quando è ferma, nel dettaglio i segnali più sfruttati nel caso particolare sono stati: -tb\_rst, -tb\_done

### 3.2.5 Simulazione start multipli

Pongo a 1 più volte il segnale di start per verificare la corretta gestione e specifico 3 macchine RAM separate gestite separatamente, verificando la corretta gestione dei segnali di terminazione e lo start dei vari blocchi RAM, andando a selezionarli tramite un contatore opportunamente dichiarato ( quindi quando uguale a 1 seleziono la prima RAM, quando a 2 la seconda e così via). I segnali importanti in questo caso sono: -tb\_start

### 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.

### 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 telecomunicazioni, quindi potrebbe essere utilizzato collegando l'uscita ad un componente per trasmettere direttamente il segnale codificato invece di salvarlo su una memoria.