# Progetto finale di Reti Logiche

## Weger Marco - Matricola n° 888201

### Anno Accademico 2019/2020

# Contenuto

| 1        | Introduzione                 | 1 |
|----------|------------------------------|---|
|          | 1.1 Obiettivi aggiuntivi     | 1 |
|          | 1.2 Funzionamento in sintesi | 1 |
| <b>2</b> | Architettura                 | 2 |
| 3        | Sintesi                      | 2 |
| 4        | Simulazioni                  | 2 |
| 5        | Conclusione                  | 2 |

### 1 Introduzione

Per questo progetto mi sono posto l'obiettivo di descrivere un componente che rispetti le specifiche sia pre sintesi che in post sintesi. Ho voluto scrivere del codice di facile lettura e che si adatti in modo semplice e rapido a qualsiasi tipo di modifica del pattern e/o della dimensione della memoria e del suo contenuto (più dettagli in seguito). La FPGA consigliata non ci pone particolari vincoli di area quindi ho voluto dare particolare riguardo ai tempi di esecuzione. Per quanto riguarda la frequenza di clock non sono andato alla ricerca di una massimizzazione in quanto la specifica fissa il periodo di clock a 100 ns.

### 1.1 Obiettivi aggiuntivi

Una volta rispettate le richieste della specifica fornita mi sono posto i seguenti obiettivi:

- 1. Minimizzare il tempo trascorso dal momento che il segnale di start viene ricevuto al momento di invio del segnale di done;
- 2. Disattivare il segnale di enable della memoria tra le varie esecuzioni;
- 3. Rendere il componente adattabile ad un'eventuale modifica della lunghezza dell'indirizzo della cella di memoria tramite una costante;
- 4. Rendere il componente adattabile ad un'eventuale modifica della dimensione di una singola cella di memoria tramite una costante (ADDR);
- 5. Rendere il componente adattabile ad un'eventuale modifica del numero di elementi in una working-zone tramite una costante (WZ OFFSET);
- 6. Rendere il componente adattabile ad un'eventuale modifica del numero di working-zone tramite una costante (WZ NUM).

Al fine di raggiungere i sopracitati obiettivi ho assunto che l'indirizzo da codificare e l'indirizzo codificato vengano sempre salvati in successione in celle immediatamente consecutive all'ultimo indirizzo di working-zone (es. se ci fosse 16 working-zone RAM(16) conterrebbe l'indirizzo da codificare e RAM(17) l'indirizzo codificato). Tutte le ottimizzazioni descritte in seguito sono state valutate sulla base dei dati forniti dalla specifica e non tengono conto dell'eventuale crescita sproposita delle costanti sopracitate.

#### 1.2 Funzionamento in sintesi

Una soluzione che memorizza tramite registri i valori delle working-zone non avrebbe migliorato in modo significativo i tempi di esecuzione peggiorando però l'area occupata pertando ho optato per la in memoria a ogni esecuzione. La singola esecuzione di una codifica può essere descritta attraverso un numero finito di step (che poi diventeranno una macchina a stati finiti):

- 1. Reset ed attesa del segnale di start (*i\_start=1*);
- 2. Abilitazione della memoria e richiesta dell'indirizo da codificare (salvato in un registro);
- 3. Richiesta della i-esima working-zone e confronto con l'indirizzo salvato, eventuale codifica e passaggio a step successivo (passo ripetuto per i compreso tra 0 e il numero di working-zone);
- 4. Scrittura dell'indirizzo codificato in memoria;
- 5. Invio segnale di elaborazione completata (o\_done=1) e attesa feedback (i\_start=0), il dato è disponibile fin dal momento in cui o\_done viene portato a 1;
- 2 Architettura
- 3 Sintesi
- 4 Simulazioni
- 5 Conclusione