# Elaborato SIS – Laboratorio Architettura degli Elaboratori

UniVR - Dipartimento di Informatica

Titolo del progetto

Mattia Arganetto - VR000000 Fabio Irimie - VR501504

1° Semestre 2023/2024

## Indice

| 1 | Specifiche                                              | 2              |  |  |  |  |  |  |
|---|---------------------------------------------------------|----------------|--|--|--|--|--|--|
| 2 | Architettura generale                                   |                |  |  |  |  |  |  |
| 3 | Diagramma degli stati del controllore                   |                |  |  |  |  |  |  |
| 4 | Architettura del datapath                               |                |  |  |  |  |  |  |
| 5 | Simulazioni 10                                          |                |  |  |  |  |  |  |
| 3 | Statistiche del circuito 6.1 Prima della minimizzazione | 11             |  |  |  |  |  |  |
| 7 | Numero di gate e ritardo 7.1 Prima della minimizzazione | 12<br>12<br>13 |  |  |  |  |  |  |
| 3 | Scelte progettuali           8.1 FSM                    | 13             |  |  |  |  |  |  |
|   | 8.2.2 Componenti riutilizzati                           | 13             |  |  |  |  |  |  |

## 1 Specifiche

Si progetti un dispositivo per la gestione di partite di **Morra Cinese**, conosciuta anche come "sasso-carta-forbici". Il dispositivo dovrà essere modellato come un circuito sequenziale FSMD (Finite State Machine + Datapath) in Sis e Verilog. Si considerino due giocatori che inseriscono una mossa che può essere sasso, carta o forbici. Ad ogni manche, il giocatore vincente è decretato dalle seguenti regole:

- Sasso batte Forbici
- Forbici batte Carta
- Carta batte Sasso

Nell'eventualità che i due giocatori scelgano la stessa mossa verrà decretato un pareggio. In aggiunta, ogni partita di **Morra Cinese** si articola su più manche, con le seguenti regole:

- 1. Si devono giocare un minimo di quattro manche;
- 2. Si possono giocare un **massimio** di **diciannove manche**. Il numero delle stesse viene settato al ciclo di clock in cui viene iniziata la partita;
- Vince il primo giocatore che riesce a vincere due manche in più del proprio avversario (avendo giocato le quattro manche minime);
- 4. Ad ogni manche, il giocatore vincente della manche precedente è tenuto a non ripetere l'ultima mossa utilizzata. Nel caso lo facesse (indipendentemente dal risultato della manche attuale) la manche non sarebbe valida (non sarebbe conteggiata nel mancheIdx) e andrebbe quindi ripetuta;
- 5. Ad ogni manche, in caso di pareggio essa **viene conteggiata**. Alla manche successiva entrambi i giocatori possono usare **tutte le mosse**;

#### Il circuito ha **tre ingressi**:

- PRIMO [2 bit]: mossa selezionata dal primo giocatore. Le mosse hanno i seguenti codici:
  - 00: Nessuna mossa utilizzata;
  - 01: Sasso:
  - **10**: Carta;
  - 11: Forbici;
- **SECONDO** [2 bit]: mossa selezionata dal secondo giocatore. Le mosse hanno codici identici a quelli del primo giocatore.
- INIZIA [1 bit]: quando il valore è uguale ad 1, riporta il sistema alla configurazione iniziale. Inoltre, la concatenazione degli ingressi PRIMO e SECONDO viene utilizzata per stabilire il numero massimo di manche (le quattro manche obbligatorie sommate al valore concatenato di PRIMO e SECONDO). Per fare un esempio inserendo i valori PRIMO

=01e SECONDO =10si dovrà sommare il numero  $\bf quattro$  (in base due) al numero  $\bf 0110$  ottenendo un massimo di  $\bf dieci$  manche per tale partita.

#### Il circuito ha due uscite:

- MANCHE [2 bit]: fornisce in output il risultato dell'ultima manche giocata con la seguente codifica:
  - **00**: manche non valida;
  - **01**: manche vinta dal giocatore 1;
  - 10: manche vinta dal giocatore 2;
  - 11: manche pareggiata;
- PARTITA [2 bit]: fornisce in output il risultato della partita con la seguente codifica:
  - **00**: la partita non è ancora terminata;
  - 01: la partita è terminata, vittoria del **giocatore 1**;
  - 10: la partita è terminata, vittoria del giocatore 2;
  - 11: la partita è terminata in pareggio;

## 2 Architettura generale

Il circuito è costituito da FSM (Controllore) e Datapath (elaboratore). I due file che racchiudono la rappresentazione di tali componenti sono presenti nella cartella sis. I due componenti sono collegati tra di loro in un unico circuito sequenziale chiamato FSMD.blif.

Nella figura 1 è rappresentata l'architettura generale del circuito che prende in input i segnali **primo**, **secondo** e **inizia** condivisi tra FSM e Datapath e restituisce in output i segnali **manche** (dalla FSM) e **partita** (dal Datapath). Il segnale di clock è lo stesso per entrambi i componenti.



Figura 1: Architettura generale della FSMD

## 3 Diagramma degli stati del controllore

È riportata nella tabella 1 la State Transition Table del controllore con la rappresentazione di Mealy. Gli ingressi sono codificati nel seguente modo per agevolare la lettura della tabella:

• Nessuna scelta: N = 00

• Sasso: S = 01

• Carta: C = 10

• Forbice: F = 11

e gli stati codificati nel seguente modo:

• Par: Pareggio

• PrS: Primo giocatore vince con sasso

• PrC: Primo giocatore vince con carta

• PrF: Primo giocatore vince con forbice

• SeS: Secondo giocatore vince con sasso

 $\bullet$   ${\bf SeC}:$  Secondo giocatore vince con carta

• SeF: Secondo giocatore vince con forbice

Dato l'elevato numero di ingressi nella seguente tabella è stato deciso di mettere in riga gli stati e in colonna gli ingressi per una migliore leggibilità.

|      | Par    | PrS    | PrC    | PrF    | SeS    | SeC    | $\operatorname{SeF}$ |
|------|--------|--------|--------|--------|--------|--------|----------------------|
| 1    | Par/00               |
| N-0  | Par/00 | PrS/00 | PrC/00 | PrF/00 | SeS/00 | SeC/00 | SeF/00               |
| -N0  | Par/00 | PrS/00 | PrC/00 | PrF/00 | SeS/00 | SeC/00 | SeF/00               |
| SS 0 | Par/11 | PrS/00 | Par/11 | Par/11 | SeS/00 | Par/11 | Par/11               |
| SC 0 | SeC/10 | PrS/00 | SeC/10 | SeC/10 | SeC/10 | SeC/00 | SeC/10               |
| SF 0 | PrS/01 | PrS/00 | PrS/01 | PrS/01 | PrS/01 | Prs/01 | SeF/00               |
| CS 0 | PrC/01 | PrC/01 | PrC/00 | PrC/01 | SeS/00 | PrC/01 | PrC/01               |
| CC0  | Par/11 | Par/11 | PrC/00 | Par/11 | Par/11 | SeC/00 | Par/11               |
| CF0  | SeF/10 | SeF/10 | PrC/00 | SeF/10 | SeF/10 | SeF/10 | SeF/00               |
| FS 0 | SeS/10 | SeS/10 | SeS/10 | PrF/00 | SeS/00 | SeS/10 | SeS/10               |
| FC0  | PrF/01 | PrF/01 | PrF/01 | PrF/00 | PrF/01 | SeC/00 | PrF/01               |
| FF 0 | Par/11 | Par/11 | Par/11 | PrF/00 | Par/11 | Par/11 | SeF/00               |

Tabella 1: State Transition Table del controllore (Mealy)

Nella figura 2 è rappresentato il State Transition Graph del controllore. Per una migliore leggibilità sono stati omessi gli archi che portano da uno stato in cui vince uno dei due giocatori a tutti gli altri stati in cui avrebbe vinto un giocatore, si è deciso invece di riportare il nome dello stato prossimo una seconda volta.



Figura 2: State Transition Graph del controllore

## 4 Architettura del datapath

I componenti che sono stati utilizzati per l'elaborazione del circuito sono i seguenti, presentati sottoforma di Nome Componente e Numero di Occorrenze.

#### • Registro a 5 bit: 2

Utilizzati per salvare in memoria i valori di:

- mancheIdx: Indice della manche corrente;
- maxManche: Numero massimo di manche che possono essere giocate in una singola partita;

#### • Registro a 4 bit: 1

Utilizzato per salvare in memoria il valore di **vangaggio**. Il vantaggio è codificato in complemento a 2 in modo da poter calcolare il vantaggio di entrambi i giocatori con un singolo registro. Quando il vantaggio assume valori positivi è il giocatore 1 ad avere il vantaggio, quando assume valori negativi è il giocatore 2 ad avercelo.

#### • Mux a 4 Ingressi da 5 bit: 1

Utilizzato per incrementare il **mancheIdx** durante la partita solo nel caso la manche risulti valida. Il Mux dà in output 00001 se la manche è valida, 00000 altrimenti.

#### • Mux a 4 Ingressi da 4 bit: 1

Utilizzato per incrementare o decrementare il valore di **vantaggio**. Il Mux dà in output 0001 se il giocatore 1 ha vinto la manche, 1111 se il giocatore 2 ha vinto la manche, 0000 altrimenti. Visto che vantaggio è codificato in complemento a 2, il valore 1111 equivale a  $-1_{10}$ .

#### • Mux a 2 Ingressi da 5 bit: 2

Utilizzati per decidere quale valore inserire all'interno dei registri di mancheIdx e maxManche. Il Mux inizializza i registri con il valore 00000 se il valore di inizia è uguale a 1, altrimenti inserisce il nuovo valore di mancheIdx e maxManche in input.

#### • Mux a 2 Ingressi da 4 bit: 1

Utilizzato per decidere quale valore inserire all'interno del registro di vangaggio. Il Mux inizializza il registro con il valore 0000 se il valore di inizia è uguale a 1, altrimenti inserisce il nuovo valore di vangaggio in input.

#### • Mux a 2 Ingressi da 2 bit: 2

Utilizzati nel componente **Partita**. I due Mux insieme determinano quale valore di **partita** dovrà essere stampato in **output**.

#### • Sommatore a 5 bit: 3

Utilizzati per sommare 2 numeri e fornire in output un numero a 5 bit. Il loro scopo è determinare e modificare il valore di **maxManche** e **mancheIdx**.

#### • Sommatore a 4 bit: 1

Utilizzato per sommare 2 numeri e fornire in output un numero a 4 bit. La sua funzione è modificare il valore di **vangaggio**.

#### • **And**: 2

Utilizzati per verificare se due condizioni sono vere allo stesso tempo. Si trovano nel componente **partita** del Datapath.

#### • Maggiore uguale da 5 bit: 2

Utilizzati rispettivamente per confrontare il valore di **mancheIdx** e **max-Manche**, e per controllare se il valore di **mancheIdx** è maggiore o uguale a 4.

#### • Maggiore uguale da 4 bit: 4

Utilizzati per comparare il valore di vangaggio con alcune Costanti. Questo componente è stato progettato per tenere in considerazione la codifica in complemento a 2 di vangaggio.

#### • Concatenatore a 2 ingressi da 2 bit con uscita a 5 bit: 1

Utilizzato per concatenare il valore di **primo** e **secondo** in modo da poter avere un unico valore a 5 bit per poter calcolare **maxManche**.

#### • Concatenatore a 2 ingressi da 1 bit con uscita a 2 bit: 2

Utilizzati per concatenare i valori di controllo per determinare il vincitore della partita.

Nella figura 3 è rappresentato il Datapath del circuito.



Figura 3: Architettura del datapath

Per una maggiore leggibilità del circuito è stata modellata una parte all'interno del componente **Partita** che riceve in input:

- vantaggio;
- mancheIdx;
- maxManche;
- inizia;

e fornisce in output:

 $\bullet$  partita.

Nella figura 4 è rappresentato il componente  $\bf Partita$ .



Figura 4: Componente Partita

Nella figura 5 è rappresentato il datapath del componente  $\bf Partita.$ 



Figura 5: Architettura del componente Partita

## 5 Simulazioni

Gli ingressi sono: primo[1], primo[0], secondo[1], secondo[0], inizia. Le uscite sono: manche[1], manche[0], partita[1], partita[0].

Abbiamo svolto una singola simulazione prendendo in considerazione **Quattro Partite**, ognuna con un diverso numero di **Manche massime** e di svolgimento delle manche stesse. Questa simulazione è stata generata dal testbench in verilog in modo da verificare che gli output fossero identici tra il modello in verilog e quello in sis.

#### testbench.script:

#### output\_sis.txt:

| testbencn.script:              | output_sis.txt:  |  |  |  |  |
|--------------------------------|------------------|--|--|--|--|
|                                |                  |  |  |  |  |
| <pre>read_blif FSMD.blif</pre> |                  |  |  |  |  |
| simulate 0 0 1 0 1             | Outputs: 0 0 0 0 |  |  |  |  |
| simulate 0 1 1 0 0             | Outputs: 1 0 0 0 |  |  |  |  |
| simulate 1 1 1 0 0             | Outputs: 0 0 0 0 |  |  |  |  |
| simulate 0 1 1 1 0             | Outputs: 0 1 0 0 |  |  |  |  |
| simulate 1 1 1 1 0             | Outputs: 1 1 0 0 |  |  |  |  |
| simulate 1 1 1 0 0             | Outputs: 0 1 0 0 |  |  |  |  |
| simulate 0 1 1 0 0             | Outputs: 1 0 0 0 |  |  |  |  |
| simulate 1 1 1 1 0             | Outputs: 1 1 1 1 |  |  |  |  |
| simulate 0 0 0 1 1             | Outputs: 0 0 0 0 |  |  |  |  |
| simulate 0 1 1 1 0             | Outputs: 0 1 0 0 |  |  |  |  |
| simulate 1 0 0 1 0             | Outputs: 0 1 0 0 |  |  |  |  |
| simulate 0 1 1 0 0             | Outputs: 1 0 0 0 |  |  |  |  |
| simulate 1 0 1 1 0             | Outputs: 1 0 0 0 |  |  |  |  |
| simulate 1 1 0 1 0             | Outputs: 1 0 1 0 |  |  |  |  |
| simulate 1 1 1 1 1             | Outputs: 0 0 0 0 |  |  |  |  |
| simulate 0 1 1 1 0             | Outputs: 0 1 0 0 |  |  |  |  |
| simulate 1 0 0 1 0             | Outputs: 0 1 0 0 |  |  |  |  |
| simulate 1 1 1 0 0             | Outputs: 0 1 0 0 |  |  |  |  |
| simulate 1 1 0 1 0             | Outputs: 0 0 0 0 |  |  |  |  |
| simulate 0 1 1 0 0             | Outputs: 1 0 0 1 |  |  |  |  |
| simulate 0 1 0 1 1             | Outputs: 0 0 0 0 |  |  |  |  |
| simulate 0 1 1 1 0             | Outputs: 0 1 0 0 |  |  |  |  |
| simulate 1 0 0 1 0             | Outputs: 0 1 0 0 |  |  |  |  |
| simulate 1 1 0 1 0             | Outputs: 1 0 0 0 |  |  |  |  |
| simulate 1 0 1 0 0             | Outputs: 1 1 0 0 |  |  |  |  |
| simulate 1 1 0 1 0             | Outputs: 1 0 0 0 |  |  |  |  |
| simulate 0 1 1 1 0             | Outputs: 0 1 0 0 |  |  |  |  |
| simulate 0 1 1 0 0             | Outputs: 0 0 0 0 |  |  |  |  |
| simulate 0 0 1 1 0             | Outputs: 0 0 0 0 |  |  |  |  |
| simulate 0 1 1 1 0             | Outputs: 0 0 0 0 |  |  |  |  |
| simulate 1 1 1 1 0             | Outputs: 1 1 0 0 |  |  |  |  |
| simulate 1 0 0 1 0             | Outputs: 0 1 0 1 |  |  |  |  |
| quit                           |                  |  |  |  |  |
|                                |                  |  |  |  |  |

Sono state simulate 4 partite con le seguenti caratteristiche:

1. Partita da 6 manche finita in pareggio;

- 2. Partita da 5 manche vinta dal giocatore 2 con vantaggio -1;
- 3. Partita da 19 manche vinta dal giocatore 1 con vantaggio +2;
- 4. Partita da 9 manche vinta dal giocatore 1 con vantaggio +2;

### 6 Statistiche del circuito

Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim. Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa duis.

#### 6.1 Prima della minimizzazione

Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim. Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa duis.

#### 6.2 Dopo la minimizzazione

Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim. Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa duis.

#### 6.2.1 Minimizzazione degli stati

Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem

est aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim. Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa duis.

#### 6.2.2 Minimizzazione per area

Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim. Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa duis.

## 7 Numero di gate e ritardo

Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim. Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa duis.

#### 7.1 Prima della minimizzazione

Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim. Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa duis.

#### 7.2 Dopo la minimizzazione per area

Lorem ipsum dolor sit amet, officia excepteur ex fugiat reprehenderit enim labore culpa sint ad nisi Lorem pariatur mollit ex esse exercitation amet. Nisi anim cupidatat excepteur officia. Reprehenderit nostrud nostrud ipsum Lorem est aliquip amet voluptate voluptate dolor minim nulla est proident. Nostrud officia pariatur ut officia. Sit irure elit esse ea nulla sunt ex occaecat reprehenderit commodo officia dolor Lorem duis laboris cupidatat officia voluptate. Culpa proident adipisicing id nulla nisi laboris ex in Lorem sunt duis officia eiusmod. Aliqua reprehenderit commodo ex non excepteur duis sunt velit enim. Voluptate laboris sint cupidatat ullamco ut ea consectetur et est culpa et culpa duis.

## 8 Scelte progettuali

#### 8.1 FSM

Nello sviluppo di questo circuito abbiamo pensato di implementare il calcolo della manche all'interno della FSM in modo da avere un circuito più semplice e con meno componenti, risparmiandoci così di memorizzare il vincitore della manche precedente e la mossa che ha usato per vincere.

#### 8.2 Datapath

#### 8.2.1 Concatenatori

I componenti dei concatenatori sono stati inseriti nel datapath a scopo puramente illustrativo, in quanto non sono stati utilizzati per la realizzazione del circuito siccome in sis è possibile gestire i bit singolarmente e quindi inserirli direttamente nei componenti che li utilizzano nell'ordine desiderato. In verilog, invece, è possibile utilizzare l'operatore di concatenazione.

#### 8.2.2 Componenti riutilizzati

Per la realizzazione del datapath abbiamo cercato di riutilizzare i componenti già realizzati per il circuito evitando di crearne di nuovi, ad esempio abbiamo utilizzato solo il componente **Maggiore Uguale** per tutti i controlli necessari all'interno del componente **Partita**.

Per quanto riguarda il resto dei componenti abbiamo dovuto crearne di nuovi in quanto il numero di bit del registro **vantaggio** e il numero di bit dei registri **mancheIdx** e **maxManche** sono diversi. Avremmo potuto considerare **vantaggio** da 5 bit per poter riutilizzare componenti già presenti, ma abbiamo preferito ottimizzare il circuito scegliendo il minor numero di bit necessari per ogni componente.