**Progetto di reti Logiche**

Divisore intero con resto

Ergasti Alex

# Introduzione

Si vuole realizzare un circuito che esegue la divisione tramite il metodo della lunga divisione che abbia ingressi e uscite a 32 bit in codifica binaria naturale.

Il circuito deve, forniti in ingresso due valori a(dividendo) e b(divisore), fornire in uscita due valori q (quoziente) e r (resto) tale che: **a=b\*q+r**

### Ipotesi

I valori forniti a e b sono numeri naturali positivi (>=0), è quindi necessario gestire il caso in cui il divisore è uguale a zero tramite opportuni segnali

### Limitazioni

Il metodo della lunga divisione è un’operazione lenta, richiederà quindi almeno 32 colpi di clock per essere eseguita dopo un primo colpo di clock di setup.

# Specifica

## Interfaccia del sistema

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAXMAAACiCAYAAACzry2sAAAGfnRFWHRteGZpbGUAJTNDbXhmaWxlJTIwaG9zdCUzRCUyMmFwcC5kaWFncmFtcy5uZXQlMjIlMjBtb2RpZmllZCUzRCUyMjIwMjEtMDQtMDZUMjAlM0EzMyUzQTE4LjU4N1olMjIlMjBhZ2VudCUzRCUyMjUuMCUyMChXaW5kb3dzJTIwTlQlMjAxMC4wJTNCJTIwV2luNjQlM0IlMjB4NjQpJTIwQXBwbGVXZWJLaXQlMkY1MzcuMzYlMjAoS0hUTUwlMkMlMjBsaWtlJTIwR2Vja28pJTIwQ2hyb21lJTJGODkuMC40Mzg5LjExNCUyMFNhZmFyaSUyRjUzNy4zNiUyMEVkZyUyRjg5LjAuNzc0LjY4JTIyJTIwZXRhZyUzRCUyMkRfc1dxZ3Rnc2Rqc0w1S19ZWVRPJTIyJTIwdmVyc2lvbiUzRCUyMjE0LjUuOCUyMiUzRSUzQ2RpYWdyYW0lMjBpZCUzRCUyMkpfak5nUHlZQ3BXUy1adkN1TG9jJTIyJTIwbmFtZSUzRCUyMlBhZ2UtMSUyMiUzRTdWcExjOXNnRVA0MU9pWWpDV05ieDhSMm1rN1Q2U09IdHFjT0VWaGlJZ2tYNGRqT3J5JTJCeTBCUDVVWHR3TXE1emlWaGdGNzc5Rm5ZWlcyQVVMejl3TkFzJTJGTTB3aXk3WHgwZ0pqeTNVZE1QVGt2MHl5eWlVOVR3a0NUckVhVkFrZTZTdFJRbHRKNXhTVHRERlFNQllKT21zS2ZaWWt4QmNOR2VLY0xackRwaXhxV3AyaGdHaUNSeDlGdXZRSHhTTE1wVU5vViUyRko3UW9Pd3NPellxaWRHeFdDbElnMFJab3RjdEI0REpoWVljY1pFJTJGaFV2UnlUS3dDdHd5UlhkYmVndEY4WkpJdmFaNEM0JTJGQnV3MiUyRmhMTzd2OTh1bk4lMkZUM0UlMkZ2bEphWGxBMFZ4dFdpeFdyQWdITzVna21tUkxiQXJlTGtBcnlPRU4lMkIxcnVRUHBleVVNU1JiRG55VTZralhKRGx4blU2NWU0bGJRaUxpZUFyT1VSTkFIMkZvR0tNMjFQdFJZVyUyRm8lMkZacWgzWHNpNGxJJTJCVHdvZFZld3lBJTJCRnpEJTJCZzVPNUdTWENLa2lCcnZRRkVZTkFCRWRRUmNrMEJCSFlEUkJKOGs4V2piQ1VzSVUxTTVMNzU2cWVpMkxyeEsydGN3Nkk1WHRZN3h5dlZ5cTBRck1Wd0MwbDVhQ0FlRUxITHh6cmlOVVJoQiUyQmNLR1NjUkV2U2x1WXd1bUpXRnI0ektCVllPdFZzT0hiWThsYkk1OTRtYVZRJTJGeXRpTFlVZ1JhaW5JY05FVnJyNWZiUHB3SXZYZE9oTGR5c090NTExN3RiOWp5VXJQWE85VDVSeGd4VEF4NEljWUJ4R2ozR2lIR0RpT0dpZUhvS1FqbzRJWjA0QU42a3NsbGd4VW9va0VpdjMzcFRNS2xJTHRXcWN6ZWJsUkhUREZlWDhxY3BQUVZQYTMxWmJ5WVpmdFo3eERlV25DODdWNVdxYVdhYkpXM2FKMURtem0lMkY4UkszcndFb291QklFbDA1clZPZVRhY3BNZUt1JTJGbDdldWtTeUZtVHdGSkc4M1lqaFNCNW8xQmpURjFtOUpWZ2ppQXd4WVM2UzBWeXdOSzhrTTlXcDRPeVpqRmpFZUVYSWpkRyUyQmZ4WmVGaVlsJTJCbm9XM3UlMkZnbTdFc2ZOanBnRlJ1JTJCenp4YiUyQlc2cnFmajN4WHZ4dkQzTlB3ZkdEcFg4cmRMVUtDRDN6c2wlMkJNVVZXRU4lMkZGREglMkYlMkJVemhiOWQ1SFM4QUolMkJXJTJCODk2ZkFONHFMZWdOdGhabHNyY1BqMDRMSURqQ2lPa0UlMkYlMkZJbWNCQXpRTk5wUTJpRUdqdXNtT2FHJTJGaXd3WWY1NUh0bXc5OTV1VEwyV204Z2dQTk5zVVlPJTJGNDhZOExmeDZ2WFFwcGZjNUdiTkMyJTJGekp1TXVLNlpOUkwlMkJhJTJCa3hqUkJKUCUyRkpFQzd5cm5CU1FOVXIlMkJjdUFicFhnTUtUQk9nT0s0WUQxTlhyelc5ekppaFI1czQlMkZQczA5ZDhsbTlidUkzR0hWcjB2QTVDOCUzRCUzQyUyRmRpYWdyYW0lM0UlM0MlMkZteGZpbGUlM0UN1+KrAAAYWklEQVR4Xu1dT0hdxxeeLC0hG0MICJK6MaIgSBYBddNNsigIdmFAXWUhiVawNZsQ/0MI1EYIKrjoSgV1kXVTaLtQN6EILrpwIxJwEVAoLejSH2f6O7fzru+9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)

### Segnali di ingresso:

* **Dividend**: Indica il dividendo, segnale a 32 bit in codifica binaria naturale\*
* **Divisor**: Indica il divisore, segnale a 32 bit in codifica binaria naturale\*
* **Load**: Segnale di 1 bit attivo alto sincrono, permette al componente di eseguire una fase di “setup” e di configurarsi per operare la divisione
* **Clock**: Clock del sistema

### Segnali di uscita:

* **Quotient**: Indica il quoziente, segnale a 32 bit in codifica binaria naturale\*
* **Remainder**: Indica il resto della divisione, segnale a 32 bit in codifica binaria naturale\*
* **Eoc** (End Of Computation): Segnale di 1 bit attivo alto, se ha valore logico 0 allora il circuito non ha ancora prodotto l’uscita su **Quotient** e **Remainder**, se ha valore logico 1 allora il circuito ha prodotto e fornito su **Quotient** e **Remainder** il risultato.
* **Error**: Segnale di 1 bit, se ha valore logico 0 allora non sono presenti errori e il risultato fornito è considerato valido, se ha valore logico 1 allora gli ingressi non sono validi e l’uscita ha un valore non precisato.

### Utilizzo del componente:

Per utilizzare il componente è necessario posizionare sui segnali di ingresso **dividend e divisor** i segnali su cui si intende operare la divisione e alzare a valore logico alto il segnale di **load**.

Il primo colpo di clock ricevuto dopo aver correttamente configurato gli ingressi permetterà al circuito di configurarsi e portare a valore logico 0 il segnale **Eoc**, a questo punto è obbligatorio abbassare il segnale di **load** a valore logico 0, poiché lasciandolo a valore logico 1 il circuito rimarrebbe continuamente in fase di “setup”, non è invece importante il valore mantenuto sugli ingressi **dividend e divisor** dopo la fase di “setup”

Il circuito fornirà dopo 32 colpi di clock dal colpo di setup il risultato sui segnali di uscita **Quotient** e **Remainder** e alzerà il segnale **Eoc** per segnalare il completamento dell’operazione.

Finchè il segnale **Eoc** non assume valore logico 1 il significato di **Quotient** e **Remainder** non è da considerarsi significativo.

In caso di errore l’uscita **Error** assumerà valore logico 1, sarà 0 invece in tutti gli altri casi

## Architettura del sistema

L’architettura è formata da:

* 2x Parallel to Serial Shifter (32 bit)
* 1x Registro (32 bit)
* 1x Sommatore
* 1x C1 Complement
* 1x Controllore

## Parallel to Serial Shifter

Shifter a 32bit sincrono.

### Segnali di ingresso:

* **LD/**: Se valore logico 1 abilità il caricamento parallelo, se valore logico 0 abilità lo shifting
* **PI (Parellel Input):** segnale a 32 bit utilizzato se **LD/** = 1L
* **SI** **(Serial Input):** segnale ad 1 bit utilizzato se **LD/** = 0L, il bit in ingresso è relativo al LSB
* **Reset** pone il valore di tutti i bit all’interno del registro a 0, ha la precedenza su ogni altro segnale
* **EN** se = 1L lo shifter reagisce ai colpi di clock, se = 0L il registro non reagisce ai colpi di clock

### Segnali di uscita:

* **PO (Parallelo Output):** segnale a 32 bit di uscita parallela del contenuto del registro
* **SO (Serial Output):** segnale ad 1 bit che prende il valore del MSB del valore memorizzato all’interno del registro

### Utilizzo:

Viene utilizzato per due componenti, il NUM\_ParSerialShifter e il REM\_ParSerialShifter

#### NUM\_ParSerialShifter\_32:

Inizialmente contiene il valore del dividendo (segnale **dividend**), shifta verso sinistra (nello schema) facendo uscire da **SO** il MSB e tramite **SI** entra il valore del quoziente, alla fine dei 32 colpi di clock si troverà su questo shifter il valore finale del quoziente (segnale **Quotient**).

#### REM\_ParSerialShifter\_32:

Inizialmente contiene il valore 0, al suo interno viene salvato il risultato parziale del resto e dopo 32 colpi di clock conterrà il resto dell’operazione di divisione.

In base al valore del **COUT** del sommatore viene fatto shiftare oppure prende in ingresso parallelo il risultato della sottrazione.

## C1 Complement

Esegue il complemento ad 1 del segnale in ingresso e lo fornisce sull’uscita

### Segnali di ingresso:

* **In**: Segnale a 32bit

### Segnali di uscita:

* **Out**: Segnale a 32bit pari al valore in ingresso complementato a 1

## Register

Registro a 32 bit sincrono

### Segnali di ingresso:

* **In**: Segnale a 32bit pari al valore da memorizzare all’interno del registro
* **En:** se = 1L il registro reagisce ai colpi di clock, se = 0L il registro non reagisce ai colpi di clock

### Segnali di uscita:

* **Out**: Segnale a 32bit pari al valore memorizzato nel registro

### Utilizzo:

#### DEN\_Register\_32:

Registro a 32 bit che contiene il valore del divisore già complementato

## Adder

Sommatore a 32 bit.

### Segnali di ingresso:

* **A** e **B:** Segnali a 32 bit da sommare
* **CIN**: Riporto in ingresso, sempre a valore 1L nello schema

### Segnali di uscita:

* **Res**: Segnale a 32 bit, risultato della somma a 32 bit dei due addendi
* **COUT:** Segnale ad 1 bit contenente il riporto della somma

### Utilizzo:

Viene utilizzato per eseguire la somma tra il remainder e il dividend, ma, poiché il dividend è in complemento ad 1 e il valore di CIN è sempre posto ad 1 esegue di fatto la sottrazione.

## Controller

Genera i segnali di controllo dell’intera architettura

### Segnali di ingresso:

* **Dividend**: Segnale a 32 bit in codifica C1 contenente il divisore, influisce sul valore di **Error**
* **Load:** Segnale a 1 bit che resetta i segnali di uscita **Eoc** ed **En** rispettivamente a 0L e 1L
* **Carry:** Segnale ad 1 bit, influisce sul valore di uscita di **LD/**

### Segnali di uscita:

* **LD/**: Segnale ad 1 bit per selezionare se il registro “REM\_ParSerialShifter\_32” debba eseguire un’operazione di load oppure di shift, il valore di questo segnale dipende dall’ingresso **Carry**
* **En:** Segnale ad 1 bit che vale 0L se **Eoc** vale 1L, vale 1L durante tutta la fase di computazionee se **Load** vale 1L
* **Eoc:** Segnale ad 1 bit che assume valore logico 1 se l’operazione di divisione è conclusa, 0 altrimenti
* **Error:** Segnale ad 1 bit che assume valore logico 1 se l’operazione di divisione contiene un valore di dividendo (segnale **Dividend**) invalido, 0 altrimenti

# Verifica

## Test-bench

## Casi d’uso