



# Architettura degli Elaboratori I

Corso di Laurea Triennale in Informatica

Università degli Studi di Milano

Dipartimento di Informatica “Giovanni Degli Antoni”

Edizione 2 (Cognomi H-Z), A.A. 2024-2025, Nicola.Basilico@unimi.it

# Introduzione

# Di cosa si occupa questo insegnamento?

Cerchiamo il significato di «architettura» nel [dizionario](#):

- *arte e tecnica del progettare, disegnare, realizzare edifici o altre grandi opere, basandosi su principi estetici e ingegneristici*

La «grande opera» che ci proponiamo di studiare si chiama **elaboratore**

Sempre dal dizionario:

- *(in informatica) struttura dei componenti di un sistema di elaborazione*

# Obiettivi

- Comprendere i principi fondamentali alla base della realizzazione di un elaboratore digitale
  - Studieremo come l'informazione viene rappresentata dentro un elaboratore e secondo quali principi essa può essere manipolata
  - Analizzeremo i componenti fondamentali che permettono di far eseguire allo hardware operazioni elementari
  - Combineremo tali componenti per realizzare elaborazioni sempre più complesse fino a ottenere ...
  - ... il componente centrale di un elaboratore: la CPU
- 
- Complessità  
degli argomenti

# Il programma che seguiremo

## Teoria:

- introduzione
- rappresentazione ed elaborazione logica dell'informazione: codifiche binarie per numeri naturali, interi e reali, funzioni logiche e algebra di Boole;
- rappresentazione ed elaborazione fisica dell'informazione: porte logiche e tabelle di verità;
- sintesi di funzioni logiche con circuiti combinatori, realizzazione dell'unità aritmetico-logica (ALU);
- memorizzazione dell'informazione: elementi di logica sequenziale (bistabili, latch, sincronizzazione tramite clock);
- sintesi di circuiti sequenziali, macchine a stati finiti;
- progetto di una CPU singolo-ciclo e cenni al caso multi-ciclo;

## Laboratorio

- codifica binaria;
- logica combinatoria (forme canoniche, cammino critico);
- logica combinatoria avanzata (moltiplicazione, ALU);
- logica sequenziale (memorie, macchine a stati finiti);



*logisim*

# L'elaboratore

Ci sono molte definizioni possibili, proviamo a darne una:

*un elaboratore è una macchina capace di rappresentare, memorizzare e manipolare delle informazioni date in input per produrne delle altre in output*

Esempio: una macchina che riceve in input 10 numeri interi, li ordina e salva il risultato in memoria

Il concetto stesso di elaborazione è intimamente connesso a quello di macchina che la esegue

Il modello matematico più noto dell'elaborazione si chiama: **Macchina di Turing** (1936), è un elaboratore teorico in grado di eseguire qualsiasi algoritmo



# Breve storia dell'elaboratore

- Era pre-elettronica: calcolatori meccanici e elettromeccanici (1623-1945)
- **Calcolatori elettronici** (salti generazionali associati ad importanti innovazioni tecnologiche):
  - Prima generazione (1946-1955): utilizzo di valvole, diodi e triodi, prestazioni migliorate di 1000 volte. ENIAC, programmi realizzati cambiando il cablaggio della macchina manualmente
  - Seconda generazione (1952-1963): introduzione dell'elettronica allo stato solido (semiconduttori) e delle memorie ferromagnetiche, primo super-calcolatore CDC, invenzione del Fortran, il primo linguaggio di alto livello
  - Terza generazione (1964-1971): avvento dei circuiti integrati, IBM 360 prima famiglia di calcolatori
  - Quarta generazione (1971-1977), miniaturizzazione in larga scala (VLSI), introduzione del microprocessore, memorie a semiconduttori, Apple II (1977)
  - Quinta generazione (1978-2003): avvento dei Personal Computer, PC come workstation
  - Futuro: quantum computers, molecular computers, ...



L' Analytical Engine  
progettato da Charles  
Babbage (1837)



ENIAC (1946), primo  
computer general  
purpose, Università  
della Pennsylvania



IBM 7090 (1959) usa  
transistor anziché  
valvole



IBM 360 (1964), la  
prima famiglia di  
calcolatori



Apple II (1977), primo  
home computer su larga  
scala



MS DOS (1982)

# Moore's law



- L'evoluzione di alcuni di questi principi fu intuita già nel 1965 da Gordon Moore
- **Legge di Moore:** *la complessità di un circuito integrato raddoppia ogni circa 18 mesi*  
Ha descritto lo sforzo ingegneristico nell'evoluzione degli elaboratori digitali **negli ultimi 50 anni**.
- Attenzione! Sta giungendo al termine

# Architettura di un elaboratore

- L'architettura di un elaboratore è una descrizione di come è fatta una macchina in grado di svolgere elaborazione automatica dell'informazione



- Il vantaggio dell'astrazione: ogni livello si avvale degli elementi definiti nel livello sottostante trascurando come questi sono fatti all'interno
- In questo corso seguiamo un approccio bottom-up

# Hardware

- È l'insieme dei componenti fisici che compongono un elaboratore (la «ferramenta»), ciascuno adibito ad una particolare funzione



*Motherboard*



*Memoria*

# Organizzazione

- L'organizzazione della maggior parte degli elaboratori oggi segue un modello chiamato **Architettura di Von Neumann** o anche Macchina di Von Neumann



- Vediamo una panoramica generale che approfondiremo poi in questo e nel corso di Architettura II

# Von Neumann Architecture (1)



- La **CPU** ha il compito di eseguire delle istruzioni in sequenza (ad esempio somme, moltiplicazioni, test di disuguaglianza, accesso a memoria, ...)
- Per fare questo si avvale di
  - **UC**: supervisore dell'esecuzione
  - **ALU**: esecutore di calcoli logici o aritmetici
  - **Registri**: memoria interna, il banco di lavoro

# Von Neumann Architecture (2)



- La **Memoria** ha il compito immagazzinare
  - **Il programma** (detto anche «testo»): la sequenza di istruzioni che deve eseguire la CPU
  - **I dati**: valori su cui le istruzioni lavorano o che rappresentano i loro risultati
- La CPU può accedervi in lettura o in scrittura attraverso un canale di comunicazione detto **bus**
- È strutturata in parole, ogni parola ha un indirizzo. Per leggere/scrivere un dato da/in una parola è necessario specificare l'indirizzo di tale parola

# Von Neumann Architecture (3)



- Un elaboratore deve poter comunicare con il mondo esterno, ad esempio per chiedere un dato all'utente o visualizzare il risultato di un'operazione su di un terminale:
  - **Periferiche di input:** acquisizione un dato (tastiera, mouse, dischi, ...)
  - **Periferiche di output:** visualizzare il dato (display, dischi, ...)

# Von Neumann Architecture (4)



- Limiti di questo modello: **Bottleneck** (collo di bottiglia)



L'evoluzione delle CPU (cfr. legge di Moore) ha portato ad un drammatico aumento delle performance (velocità di esecuzione)

Le memorie, d'altro canto, si sono evolute principalmente in densità e affidabilità (anche in velocità ma non quanto le CPU!)



**Risultato:** la CPU non fa altro che aspettare!

Soluzione? Pensare ad una architettura più «complicata» (vedremo più avanti)

# Ciclo di esecuzione

- I componenti della Architettura di Von Neumann che abbiamo introdotto svolgono ciascuno, in modo complementare, una particolare funzione
- Interagendo e coordinandosi tra di loro, questi componenti collaborano all'esecuzione di un programma, istruzione dopo istruzione
- L'esecuzione di ciascuna istruzione attraversa **5 fasi** che, ripetute per ogni istruzione, costituiscono il **ciclo di esecuzione**



# Instruction Set

|                    |                    |                      |                     |                    |                     |                   |                    |                    |                        |                    |                        |                     |
|--------------------|--------------------|----------------------|---------------------|--------------------|---------------------|-------------------|--------------------|--------------------|------------------------|--------------------|------------------------|---------------------|
| ADD<br>Eb Gb<br>00 | ADD<br>Ev Gv<br>01 | ADD<br>Gb Eb<br>02   | ADD<br>Gv Ev<br>03  | ADD<br>AL Ib<br>04 | ADD<br>eAX Iv<br>05 | PUSH<br>ES 06     | POP<br>SS 07       | OR<br>Eb Gb<br>08  | OR<br>Ev Gv<br>09      | OR<br>Gb Eb<br>0A  | OR<br>Gv Ev<br>0B      | OR<br>AL Ib<br>0C   |
| ADC<br>Eb Gb<br>10 | ADC<br>Ev Gv<br>11 | ADC<br>Gb Eb<br>12   | ADC<br>Gv Ev<br>13  | ADC<br>AL Ib<br>14 | ADC<br>eAX Iv<br>15 | PUSH<br>SS 17     | SBB<br>Eb Gb<br>18 | SBB<br>Ev Gv<br>19 | SBB<br>Gb Eb<br>1A     | SBB<br>Gv Ev<br>1B | SBB<br>AL Ib<br>1C     |                     |
| AND<br>Eb Gb<br>20 | AND<br>Ev Gv<br>21 | AND<br>Gb Eb<br>22   | AND<br>Gv Ev<br>23  | AND<br>AL Ib<br>24 | AND<br>eAX Iv<br>25 | ES:<br>26         | DAA<br>Eb Gb<br>28 | SUB<br>Eb Gb<br>29 | SUB<br>Gb Eb<br>2A     | SUB<br>Gv Ev<br>2B | SUB<br>AL Ib<br>2C     |                     |
| XOR<br>Eb Gb<br>30 | XOR<br>Ev Gv<br>31 | XOR<br>Gb Eb<br>32   | XOR<br>Gv Ev<br>33  | XOR<br>AL Ib<br>34 | XOR<br>eAX Iv<br>35 | SS:<br>36         | AAA<br>37          | CMP<br>Eb Gb<br>38 | CMP<br>Ev Gv<br>39     | CMP<br>Gb Eb<br>3A | CMP<br>Gv Ev<br>3B     | CMP<br>AL Ib<br>3C  |
| INC<br>eAX<br>40   | INC<br>eCX<br>41   | INC<br>eDX<br>42     | INC<br>eBX<br>43    | INC<br>eSP<br>44   | INC<br>eBP<br>45    | INC<br>eSI<br>46  | DEC<br>eAX<br>47   | DEC<br>eCX<br>49   | DEC<br>eDX<br>4A       | DEC<br>eBX<br>4B   | DEC<br>eSP<br>4C       |                     |
| PUSH<br>eAX<br>50  | PUSH<br>eCX<br>51  | PUSH<br>eDX<br>52    | PUSH<br>eBX<br>53   | PUSH<br>eSP<br>54  | PUSH<br>eBP<br>55   | PUSH<br>eDI<br>56 | POP<br>eAX<br>57   | POP<br>eCX<br>59   | POP<br>eDX<br>5A       | POP<br>eBX<br>5B   | POP<br>eSP<br>5C       |                     |
| PUSHA<br>60        | POPA<br>61         | BOUND<br>Gv Ma<br>62 | ARPL<br>Ev Gw<br>63 | FS:<br>64          | GS:<br>65           | OPSIZE:<br>66     | ADSIZE:<br>67      | PUSH<br>Iv<br>68   | IMUL<br>Gv Ev Iv<br>69 | PUSH<br>Ib<br>6A   | IMUL<br>Gv Ev Ib<br>6B | INSB<br>Yb DX<br>6C |
| JO<br>Jb<br>70     | JNO<br>Jb<br>71    | JB<br>Jb<br>72       | JNB<br>Jb<br>73     | JZ<br>Jb<br>74     | JNZ<br>Jb<br>75     | JBE<br>Jb<br>76   | JA<br>Jb<br>77     | JS<br>Jb<br>78     | JNS<br>Jb<br>79        | JP<br>Jb<br>7A     | JNP<br>Jb<br>7B        | JL<br>Jb<br>7C      |
| ADD<br>Eb Ib       | ADD<br>Ev Iv       | SUB<br>Eb Ib         | SUB<br>Ev Ib        | TEST<br>Eb Gb      | TEST<br>Ev Gv       | XCHG<br>Eb Gb     | XCHG<br>Ev Gv      | MOV<br>Eb Gb       | MOV<br>Ev Gv           | MOV<br>Gb Eb       | MOV<br>Gv Ev           | MOV<br>Ew Sw        |

- L'instruction set è l'insieme delle istruzioni che la macchina è in grado di eseguire (esempio, *add*, *load*, *and*, ...)
- Sono espresse in linguaggio macchina: sequenze di bit (per noi saranno 32) che la UC è in grado di riconoscere come istruzione (decodifica)
- Conoscere l'Instruction set di una macchina ci permette di scrivere programmi per quella macchina senza dover considerare i dettagli hardware (astrazione). Ad esempio potremmo scrivere un compilatore!

- È il primo livello di astrazione sull'hardware: **l'inizio del software**
- Così importante da essere chiamato «**Instruction Set Architecture**» (ISA) e a volte anche semplicemente «Architecture»
- Macchine diverse possono implementare la stessa ISA (eseguono gli stessi programmi) ma con hardware diverso (e quindi diverse prestazioni e costi)
- ISA RISC** (Reduced Instruction Set Computer): istruzioni semplici e regolari, ciascuna richiede all'hardware poco lavoro per essere eseguita
- ISA CISC** (Complex Instruction Set Computer): istruzioni complesse ciascuna può svolgere diversi task e richiede più lavoro all'hardware



# RISC e CISC (1)

## RISC

- **Vantaggi:**

- **Semplicità:** istruzioni semplici e regolari, più facili da progettare, ma anche decodificare ed eseguire.
- **Prestazioni:** istruzioni più semplici possono eseguire più rapidamente, si possono ottenere alte prestazioni in task di calcolo che richiedono molte operazioni aritmetico/logiche.
- **Efficienza:** istruzioni più semplici comportano un consumo di energia più basso e una minore emissione di calore, sono quindi adatte per dispositivi mobili e sistemi embedded.
- **Facilità per il compilatore:** più facili da compilare.

- **Svantaggi**

- **Aumento della quantità del codice:** per fare cose complesse servono tantissime istruzioni
- **Accessi più frequenti alla memoria:** quindi tempi di attesa

## CISC

- **Vantaggi:**

- **Codice compatto:** una singola istruzione può corrispondere a più operazioni
- **Set di istruzioni molto ricco:** maggiore flessibilità
- **Meno accessi a memoria:** meno attese

- **Svantaggi**

- **Complessità:** è richiesta una architettura più complessa, più difficile da progettare e con consumi energetici più elevati
- **Difficoltà per il compilatore:** generare codice efficiente è un task molto più difficile
- **Obsolescenza:** la specificità di un'istruzione può portare ad un suo abbandono nel tempo

# RISC e CISC (2)

- Le architetture RISC sono usate nei dispositivi embedded (NAS, stampanti, router, TV, ...), device mobili (come gli smartphone) e nei componenti IoT
  - PowerPC: usata in alcuni PC (in passato anche da Apple), ora per lo più in processori integrati (e.g., Wii U)
  - ARM: smartphone, raspberry pi, ...
  - RISC V: Open source, percepita come concorrente di ARM
  - **MIPS**: quella che studieremo noi!
  - Una istruzione «molto RISC» (MIPS): `lw $9 8($6)` *#copia la parola di memoria all'indirizzo \$6+8 nel registro \$9*
- Le architetture CISC sono usate spesso nelle macchine general purpose (come i PC Desktop) e i server
  - Intel X86 (e sua estensione X64)
  - AMD 64
  - Una istruzione «molto CISC» (x86): `rep movsb` *#copia il byte all'indirizzo SI nel byte di indirizzo DI, incrementa SI e DI, decrementa CX, se CX non è 0 ripeti*

# MIPS



- L'architettura di riferimento per questo corso è il **MIPS** (Multiprocessor without Interlocked Pipeline Stages) che implementa un'ISA di tipo **RISC**
- Nasce a metà anni '80 come architettura *general purpose*
- Inizialmente è un progetto accademico (Stanford), poco dopo diventa commerciale
- Oggi è impiegata prevalentemente nell'ambito dei *sistemi embedded*
- È adottata nella maggior parte dei corsi accademici per la sua semplicità (nel corso di Architettura II approfondiremo questa sua caratteristica)

# MIPS timeline

