

Scuola Politecnica e delle Scienze di Base Corso di Laurea in Ingegneria Informatica

### Elaborato in Architettura dei Sistemi Digitali

### Elaborato finale

Anno Accademico 2024/25

#### Studenti

Filomena Vigliotti matr. M63001734 Ciro Scognamilgio matr. M6300 Antonio Sirignano matr. M63001732

# Indice

| 1 | Pro            | 1.1                                          | 1                                        |    |  |  |  |
|---|----------------|----------------------------------------------|------------------------------------------|----|--|--|--|
|   | 1.1            | Multiplexer 16:1                             |                                          |    |  |  |  |
|   |                | 1.1.1                                        | Progetto e architettura                  | 3  |  |  |  |
|   |                | 1.1.2                                        | Implementazione                          | 8  |  |  |  |
|   |                | 1.1.3                                        | Simulazione                              | 12 |  |  |  |
|   | 1.2            | di interconnessione a 16 ingressi e 4 uscite | 15                                       |    |  |  |  |
|   |                | 1.2.1                                        | Progettazione                            | 15 |  |  |  |
|   |                | 1.2.2                                        | Implementazione                          | 15 |  |  |  |
|   |                | 1.2.3                                        | Simulazione                              | 15 |  |  |  |
|   | 1.3            | Imple                                        | mentazione su board del punto precedente | 15 |  |  |  |
| 2 | Ese            | Esercizio 2 - Sistema ROM+M                  |                                          |    |  |  |  |
| 3 | Tit            | le                                           |                                          | 17 |  |  |  |
|   | 3.1            | Sectio                                       | n                                        | 17 |  |  |  |
| 4 | $\mathbf{Tit}$ |                                              | 21                                       |    |  |  |  |
|   | 4.1            | Sectio                                       | n                                        | 21 |  |  |  |
| 5 | Conclusion     |                                              |                                          |    |  |  |  |

|  |  | INDICE |
|--|--|--------|
|  |  |        |

**26** 

Bibliografia

### Chapter 1

# Problema 1.1

### 1.1 Multiplexer 16:1

Un multiplexer è una **macchina combinatoria**, ovvero una macchina la cui uscita in un determinato istante di tempo dipende solo dall'ingresso nel medesimo istante, e quindi realizza una funzione del tipo:

$$U = f(I)$$

dove I e U rappresentano rispettivamente gli insiemi limitati dei valori di ingresso e di uscita.

Il Multiplexer realizza una connessione n:1, ovvero connette n sorgenti a un'unica destinazione sulla base di segnali di selezione.

Un **Multiplexer lineare** è composto da n segnali in ingresso e n segnali di selezione. Tale dispositivo convoglia uno specifico segnale in ingresso verso l'uscita solo se il corrispondente segnale di selezione è

alto. Uno svantaggio di un dispositivo di questo tipo è il numero eccessivo di fili per i segnali di selezione. Per risolvere ciò si può aggiungere un **Decoder**, un altro dispositivo notevole, che riceve in ingresso una parola codice di n bit e presenta in uscita la sua rappresentazione decodificata di  $2^n$  bit.

Unendo un Multiplexer lineare a un Decoder, l'architettura diventa quella in figura, e si ottiene un componente definito **Multiplexer indirizzabile**, che diversamente da quello lineare, prende solo 2 segnali di selezione in ingresso. Un MUX indirizzabile è a sua volta una macchina notevole, caratterizzata da  $2^n$  ingressi, n ingressi di selezione e un'unica uscita.



Figure 1.1: multiplexer indirizzabile

Si vuole ora progettare un multiplexer indirizzabile 16:1, utilizzando un approccio per composizione, a partire da multiplexer 4:1.

Tale multiplexer è rappresentato di seguito.



Figure 1.2: multiplexer 16:1

### 1.1.1 Progetto e architettura

Dapprima si utilizza un approccio per composizione per realizzare un multiplexer 4:1 con multiplexer 2:1.



Figure 1.3: multiplexer 2:1

Il primo componente che si realizza è un multiplexer 2:1, caratterizzato dalla seguente tabella di verità:

| $\mathbf{s_0}$ | $\mathbf{i}_1$ | $\mathbf{i_0}$ | u             |
|----------------|----------------|----------------|---------------|
| 0              | 0              | 0              | $\mid 1 \mid$ |
| 0              | 0              | 1              | 1             |
| 0              | 1              | 0              | 0             |
| 0              | 1              | 1              | 1             |
| 1              | 0              | 0              | 0             |
| 1              | 0              | 1              | 0             |
| 1              | 1              | 0              | 1             |
| 1              | 1              | 1              | 1             |

Table 1.1: Tabella di verità di un Mux $2{:}1$ 

da cui si ottiene l'equazione:

$$y = (i_0 \text{ AND } \bar{s_0}) \text{ OR } (i_1 \text{ AND } s_0)$$

Il successivo componente da costruire è un multiplexer 4:1.



Figure 1.4: multiplexer 4:1

Per composizione, a partire da 3 multiplexer 2:1, si può ottenere un multiplexer 4:1



Figure 1.5: multiplexer 4:1 per composizione di multiplexer 2:1

I 4 ingressi entrano in due multiplexer 2:1, che prendono due ingressi e producono un'uscita ciascuno; tali uscite vengono immesse nel terzo multiplexer, che produrrà l'unico output finale. Concettualmente, si divide la selezione in ingresso al multiplexer esterno in due parti:

- la parte meno significativa (indicata dal colore verde)  $s_0$ , viene posta in ingresso ai multiplexer del primo stadio e seleziona per ciascuno un filo in uscita;
- la parte più significativa (indicata dal colore viola)  $s_1$  entra nel multiplexer del secondo stadio e decide quale dei due fili, provenienti dai due blocchi precedenti, sarà immessa in uscita.

In maniera analoga si procede con la progettazione del multiplexer 16:1.

Anche in questo caso, sono stati usati dei colori per identificare i collegamenti tra le componenti.



Figure 1.6: multiplexer 16:1 per composizione di multiplexer 4:1

#### 1.1.2 Implementazione

Per l'implementazione si procede con un approccio di tipo strutturale, iniziando quindi dalla codifica del multiplexer 2:1, e, a partire da questo si compongnono dispositivi sempre più complessi fino ad arrivare all'obiettivo del multiplexer 16:1.

Mux 2:1 Di seguito il codice riguardante il Mux 2:1.

```
library IEEE;
    use IEEE.STD_LOGIC_1164.all;
    entity mux_21 is
        port
            i0, i1: in std_logic;
            s0: in std_logic;
            u: out std_logic
        );
10
    end mux_21;
11
12
    architecture rtl of mux 21 is
13
   begin
14
        u \le i0 when s0='0' else
15
            i1 when s0='1' else
16
17
    end rtl;
```

Code 1.1: Multiplexer 2:1 in VHDL

L'interfaccia del componente ha come ingressi i 0 ed i 1, come selezione s 0 e come uscita u.

Al seguito della definizione dell'interfaccia, si definisce il comportamento dell'entità, che risponde alla tabella della verità 1.1.

#### Mux 4:1 Si prosegue con il Mux 4:1.

Come anticipato, viene costruito a partire da tre mux 2:1.

```
library IEEE;
    use IEEE.std_logic_1164.all;
    entity mux_41 is
4
        port
         (
6
             i: in std_logic_vector(0 to 3);
             s: in std_logic_vector(1 downto 0);
             u: out std_logic
        );
10
    end mux_41;
11
12
    architecture structural of mux_41 is
13
        signal u_mid: std_logic_vector(0 to 1);
14
15
        component mux_21 is
16
             port (
                      i0, i1: in std_logic;
                      s0: in std_logic;
19
                      u: out std_logic
                 );
21
        end component;
22
23
        begin
24
             mux0to1: FOR k IN 0 TO 1 GENERATE
25
                 m: mux_21
26
                 port map
27
                      i(k*2),
29
                      i(k*2 + 1),
30
                      s(0),
31
                      u_mid(k)
32
                 );
33
             end GENERATE;
34
35
             mux_2: mux_21
36
                 port map
                  (
                      u_{mid}(0),
39
                      u_{mid}(1),
40
                      s(1),
41
```

Code 1.2: Multiplexer 4:1 in VHDL

In quest'entità, l'interfaccia è dichiarata come segue:

- Il parametro i vettore di 4 elementi, ognuno corrispondente ad un ingresso del mux 4:1.
- Il parametro s vettore di 2 elementi, ognuno corrispondente ad un ingresso di selezione.
- Il parametro u corrispondente all'uscita del multiplexer.

A seguire si definisce la struttura del mux 4:1, utilizzando mux 2:1 come componenti.

Con il ciclo for, vengono stanziati i primi due mux 2:1, i quali riceveranno in ingresso rispettivamente, gli ingressi del mux 4:1 e la loro uscita è il vettore d'appoggio u\_mid, il quale è talvolta l'ingresso del terzo mux 2:1.

Mux 16:1 In maniera analoga si procede con la costruzione del mux 16:1. Il codice è il seguente:

```
library IEEE;
use IEEE.std_logic_1164.all;
entity mux_161 is
```

```
port
5
6
              i: in std_logic_vector(0 to 15);
              s: in std_logic_vector(3 downto 0);
8
              u: out std_logic
         );
10
    end mux_161;
11
12
    architecture structural of mux_161 is
13
14
         signal u_mid: std_logic_vector(0 to 3);
15
16
         component mux_41 is
17
              port
18
              (
19
                   i: in std_logic_vector(0 to 3);
20
                   s: in std_logic_vector(0 to 1);
21
                   u: out std_logic
              );
         end component;
24
25
         begin
26
              mux0to3: FOR k IN 0 TO 3 GENERATE
27
                   m: mux_41
28
                   port map
29
30
                   (
                        i = i((k*4) \text{ to } (k*4 + 3)),
                        s \Rightarrow s(1 \text{ downto } 0),
32
                        u => u_mid(k)
33
                   );
34
              end GENERATE;
35
36
              mux_2: mux_41
37
                   port map
                        i => u_mid
40
                        s \Rightarrow s(3 \text{ downto } 2),
41
                        u \Rightarrow u
42
                   );
43
44
    end structural;
45
```

Code 1.3: Multiplexer 16:1 in VHDL

#### 1.1.3 Simulazione

Per la simulazione, vi è la necessità di un testbench, il quale generiamo in maniera automatica tramite software appositi.

In tale progetto la generazione viene effettuata tramite ChatGPT ed il codice è il seguente:

```
library IEEE;
1
    use IEEE.std_logic_1164.all;
    use IEEE.numeric_std.all; -- Libreria necessaria per `to_unsigned`
    entity tb_mux_161 is
    end tb_mux_161;
    architecture behavior of tb mux 161 is
        -- Component declaration
        component mux_161
10
            port (
11
                 i: in std_logic_vector(0 to 15);
12
                 s: in std_logic_vector(3 downto 0);
13
                 u: out std_logic
14
            );
        end component;
17
        -- Signals for testing
18
        signal i: std_logic_vector(0 to 15);
19
        signal s: std_logic_vector(3 downto 0);
20
        signal u: std_logic;
21
22
23
   begin
        -- Instantiate the unit under test (UUT)
24
        uut: mux_161
            port map (
26
                 i => i,
27
                 s => s
28
                 u => u
29
            );
30
31
        -- Test process
32
33
        stim_proc: process
            variable expected_output: std_logic; -- Variabile per il
                 controllo
```

```
begin
35
             -- Initialize inputs
36
             i <= (others => '0');
37
             s <= "0000";
38
            wait for 10 ns;
39
40
             -- Apply test cases
41
             for sel in 0 to 15 loop
42
                 -- Set the ith bit of i to '1'
43
                 i <= (others => '0');
44
                 i(sel) <= '1';
45
46
                 -- Set the selector
47
                 s <= std_logic_vector(to_unsigned(sel, 4));</pre>
48
49
                 -- Aspetta che l'uscita si stabilizzi
                 wait for 10 ns;
51
                 -- Calcola l'uscita attesa
53
                 expected_output := i(sel);
54
55
                 -- Controlla se l'uscita è corretta
56
                 if u = expected_output then
57
                     report "Test passed for s = " & integer'image(sel) &
58
                             ", u = " & std_logic'image(u);
                 else
                     report "Test failed for s = " & integer'image(sel) &
                             ": expected = " &
62
                              → std_logic'image(expected_output) &
                             ", got = " & std_logic'image(u)
63
                             severity error;
64
                 end if;
65
            end loop;
66
             -- Fine simulazione
             report "All tests completed";
69
            wait;
70
        end process;
71
72
    end behavior;
73
```

Code 1.4: Testbench multiplexer 16:1 in VHDL

Una volta generato ciò, utilizzando i software GHDL e GTKWAVE,

vengono eseguiti i seguenti comandi:



Figure 1.7: Comandi per la simulazione

Con l'esecuzione dell'ultimo comando, vi si apre una nuova finestra che permette la visualizzazione delle onde:



Figure 1.8: Comandi per la simulazione

- 1.2 Rete di interconnessione a 16 ingressi e 4 uscite
- 1.2.1 Progettazione
- 1.2.2 Implementazione
- 1.2.3 Simulazione
- 1.3 Implementazione su board del punto precedente

Chapter 2

Esercizio 2 - Sistema

ROM+M

### Chapter 3

# Title

Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Ut purus elit, vestibulum ut, placerat ac, adipiscing vitae, felis. Curabitur dictum gravida mauris.

#### 3.1 Section ...

Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Ut purus elit, vestibulum ut, placerat ac, adipiscing vitae, felis. Curabitur dictum gravida mauris. Nam arcu libero, nonummy eget, consectetuer id, vulputate a, magna. Donec vehicula augue eu neque. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Mauris ut leo. Cras viverra metus rhoncus sem. Nulla et lectus vestibulum urna fringilla ultrices. Phasellus eu tellus sit amet tortor gravida placerat. Integer sapien est, iaculis in, pretium quis,

viverra ac, nunc. Praesent eget sem vel leo ultrices bibendum. Aenean faucibus. Morbi dolor nulla, malesuada eu, pulvinar at, mollis ac, nulla. Curabitur auctor semper nulla. Donec varius orci eget risus. Duis nibh mi, congue eu, accumsan eleifend, sagittis quis, diam. Duis eget orci sit amet orci dignissim rutrum.

Nam dui ligula, fringilla a, euismod sodales, sollicitudin vel, wisi. Morbi auctor lorem non justo. Nam lacus libero, pretium at, lobortis vitae, ultricies et, tellus. Donec aliquet, tortor sed accumsan bibendum, erat ligula aliquet magna, vitae ornare odio metus a mi. Morbi ac orci et nisl hendrerit mollis. Suspendisse ut massa. Cras nec ante. Pellentesque a nulla. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Aliquam tincidunt urna. Nulla ullamcorper vestibulum turpis. Pellentesque cursus luctus mauris.

Nulla malesuada porttitor diam. Donec felis erat, congue non, volutpat at, tincidunt tristique, libero. Vivamus viverra fermentum felis. Donec nonummy pellentesque ante. Phasellus adipiscing semper elit. Proin fermentum massa ac quam. Sed diam turpis, molestie vitae, placerat a, molestie nec, leo. Maecenas lacinia. Nam ipsum ligula, eleifend at, accumsan nec, suscipit a, ipsum. Morbi blandit ligula feugiat magna. Nunc eleifend consequat lorem. Sed lacinia nulla vitae enim. Pellentesque tincidunt purus vel magna. Integer non enim. Praesent euismod nunc eu purus. Donec bibendum quam in tellus. Nullam cursus pulvinar lectus. Donec et mi. Nam vulputate

metus eu enim. Vestibulum pellentesque felis eu massa.

Quisque ullamcorper placerat ipsum. Cras nibh. Morbi vel justo vitae lacus tincidunt ultrices. Lorem ipsum dolor sit amet, consectetuer adipiscing elit. In hac habitasse platea dictumst. Integer tempus convallis augue. Etiam facilisis. Nunc elementum fermentum wisi. Aenean placerat. Ut imperdiet, enim sed gravida sollicitudin, felis odio placerat quam, ac pulvinar elit purus eget enim. Nunc vitae tortor. Proin tempus nibh sit amet nisl. Vivamus quis tortor vitae risus porta vehicula.

Fusce mauris. Vestibulum luctus nibh at lectus. Sed bibendum, nulla a faucibus semper, leo velit ultricies tellus, ac venenatis arcu wisi vel nisl. Vestibulum diam. Aliquam pellentesque, augue quis sagittis posuere, turpis lacus congue quam, in hendrerit risus eros eget felis. Maecenas eget erat in sapien mattis porttitor. Vestibulum porttitor. Nulla facilisi. Sed a turpis eu lacus commodo facilisis. Morbi fringilla, wisi in dignissim interdum, justo lectus sagittis dui, et vehicula libero dui cursus dui. Mauris tempor ligula sed lacus. Duis cursus enim ut augue. Cras ac magna. Cras nulla. Nulla egestas. Curabitur a leo. Quisque egestas wisi eget nunc. Nam feugiat lacus vel est. Curabitur consectetuer.

Suspendisse vel felis. Ut lorem lorem, interdum eu, tincidunt sit amet, laoreet vitae, arcu. Aenean faucibus pede eu ante. Praesent enim elit, rutrum at, molestie non, nonummy vel, nisl. Ut lectus eros,

malesuada sit amet, fermentum eu, sodales cursus, magna. Donec eu purus. Quisque vehicula, urna sed ultricies auctor, pede lorem egestas dui, et convallis elit erat sed nulla. Donec luctus. Curabitur et nunc. Aliquam dolor odio, commodo pretium, ultricies non, pharetra in, velit. Integer arcu est, nonummy in, fermentum faucibus, egestas vel, odio.

Sed commodo posuere pede. Mauris ut est. Ut quis purus. Sed ac odio. Sed vehicula hendrerit sem. Duis non odio. Morbi ut dui. Sed accumsan risus eget odio. In hac habitasse platea dictumst. Pellentesque non elit. Fusce sed justo eu urna porta tincidunt. Mauris felis odio, sollicitudin sed, volutpat a, ornare ac, erat. Morbi quis dolor. Donec pellentesque, erat ac sagittis semper, nunc dui lobortis purus, quis congue purus metus ultricies tellus. Proin et quam. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos hymenaeos. Praesent sapien turpis, fermentum vel, eleifend faucibus, vehicula eu, lacus.

### Chapter 4

# Title

Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Ut purus elit, vestibulum ut, placerat ac, adipiscing vitae, felis. Curabitur dictum gravida mauris.

#### 4.1 Section ...

Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Ut purus elit, vestibulum ut, placerat ac, adipiscing vitae, felis. Curabitur dictum gravida mauris. Nam arcu libero, nonummy eget, consectetuer id, vulputate a, magna. Donec vehicula augue eu neque. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Mauris ut leo. Cras viverra metus rhoncus sem. Nulla et lectus vestibulum urna fringilla ultrices. Phasellus eu tellus sit amet tortor gravida placerat. Integer sapien est, iaculis in, pretium quis,

viverra ac, nunc. Praesent eget sem vel leo ultrices bibendum. Aenean faucibus. Morbi dolor nulla, malesuada eu, pulvinar at, mollis ac, nulla. Curabitur auctor semper nulla. Donec varius orci eget risus. Duis nibh mi, congue eu, accumsan eleifend, sagittis quis, diam. Duis eget orci sit amet orci dignissim rutrum.

Nam dui ligula, fringilla a, euismod sodales, sollicitudin vel, wisi. Morbi auctor lorem non justo. Nam lacus libero, pretium at, lobortis vitae, ultricies et, tellus. Donec aliquet, tortor sed accumsan bibendum, erat ligula aliquet magna, vitae ornare odio metus a mi. Morbi ac orci et nisl hendrerit mollis. Suspendisse ut massa. Cras nec ante. Pellentesque a nulla. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Aliquam tincidunt urna. Nulla ullamcorper vestibulum turpis. Pellentesque cursus luctus mauris.

Nulla malesuada porttitor diam. Donec felis erat, congue non, volutpat at, tincidunt tristique, libero. Vivamus viverra fermentum felis. Donec nonummy pellentesque ante. Phasellus adipiscing semper elit. Proin fermentum massa ac quam. Sed diam turpis, molestie vitae, placerat a, molestie nec, leo. Maecenas lacinia. Nam ipsum ligula, eleifend at, accumsan nec, suscipit a, ipsum. Morbi blandit ligula feugiat magna. Nunc eleifend consequat lorem. Sed lacinia nulla vitae enim. Pellentesque tincidunt purus vel magna. Integer non enim. Praesent euismod nunc eu purus. Donec bibendum quam in tellus. Nullam cursus pulvinar lectus. Donec et mi. Nam vulputate

metus eu enim. Vestibulum pellentesque felis eu massa.

Quisque ullamcorper placerat ipsum. Cras nibh. Morbi vel justo vitae lacus tincidunt ultrices. Lorem ipsum dolor sit amet, consectetuer adipiscing elit. In hac habitasse platea dictumst. Integer tempus convallis augue. Etiam facilisis. Nunc elementum fermentum wisi. Aenean placerat. Ut imperdiet, enim sed gravida sollicitudin, felis odio placerat quam, ac pulvinar elit purus eget enim. Nunc vitae tortor. Proin tempus nibh sit amet nisl. Vivamus quis tortor vitae risus porta vehicula.

Fusce mauris. Vestibulum luctus nibh at lectus. Sed bibendum, nulla a faucibus semper, leo velit ultricies tellus, ac venenatis arcu wisi vel nisl. Vestibulum diam. Aliquam pellentesque, augue quis sagittis posuere, turpis lacus congue quam, in hendrerit risus eros eget felis. Maecenas eget erat in sapien mattis porttitor. Vestibulum porttitor. Nulla facilisi. Sed a turpis eu lacus commodo facilisis. Morbi fringilla, wisi in dignissim interdum, justo lectus sagittis dui, et vehicula libero dui cursus dui. Mauris tempor ligula sed lacus. Duis cursus enim ut augue. Cras ac magna. Cras nulla. Nulla egestas. Curabitur a leo. Quisque egestas wisi eget nunc. Nam feugiat lacus vel est. Curabitur consectetuer.

Suspendisse vel felis. Ut lorem lorem, interdum eu, tincidunt sit amet, laoreet vitae, arcu. Aenean faucibus pede eu ante. Praesent enim elit, rutrum at, molestie non, nonummy vel, nisl. Ut lectus eros,

malesuada sit amet, fermentum eu, sodales cursus, magna. Donec eu purus. Quisque vehicula, urna sed ultricies auctor, pede lorem egestas dui, et convallis elit erat sed nulla. Donec luctus. Curabitur et nunc. Aliquam dolor odio, commodo pretium, ultricies non, pharetra in, velit. Integer arcu est, nonummy in, fermentum faucibus, egestas vel, odio.

Sed commodo posuere pede. Mauris ut est. Ut quis purus. Sed ac odio. Sed vehicula hendrerit sem. Duis non odio. Morbi ut dui. Sed accumsan risus eget odio. In hac habitasse platea dictumst. Pellentesque non elit. Fusce sed justo eu urna porta tincidunt. Mauris felis odio, sollicitudin sed, volutpat a, ornare ac, erat. Morbi quis dolor. Donec pellentesque, erat ac sagittis semper, nunc dui lobortis purus, quis congue purus metus ultricies tellus. Proin et quam. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos hymenaeos. Praesent sapien turpis, fermentum vel, eleifend faucibus, vehicula eu, lacus.

### Chapter 5

# Conclusion

Donec et nisl id sapien blandit mattis. Aenean dictum odio sit amet risus. Morbi purus. Nulla a est sit amet purus venenatis iaculis. Vivamus viverra purus vel magna. Donec in justo sed odio malesuada dapibus. Nunc ultrices aliquam nunc. Vivamus facilisis pellentesque velit. Nulla nunc velit, vulputate dapibus, vulputate id, mattis ac, justo. Nam mattis elit dapibus purus. Quisque enim risus, congue non, elementum ut, mattis quis, sem. Quisque elit.

# Bibliografia