Prof. Giovanni Giuffrida - Dipartimento di Matematica e...

Post on 14-Feb-2019

215 views 0 download

transcript

MODULO 2ARCHITETTURA DEI CALCOLATORI

COMPONENTI HARDWARE E LORO SCHEMA FUNZIONALE

Corso di Informatica IProf. Giovanni Giuffrida

2

ARCHITETTURA DEI COMPUTER

In un computer possiamo distinguere tre unità funzionali:

Processore

– fornisce la capacità di elaborazione delle informazioni,

Memoria (centrale e di massa),

Dispositivi di input/output,

che comunicano attraverso un canale detto BUS

– costituito da un insieme di linee elettriche digitali.

3

SCHEMA A BLOCCHI DI UN ELABORATORE

Processore

Unità diinput

Unità dioutput

Memoria

DATISTATO

COMANDI

4

PROGRAMMA ED ISTRUZIONI

• Programma: specifica univoca di una serie di operazioni che l’elaboratore deve svolgere.

• E' costituito da una sequenza ordinata di istruzioni macchina.

• Scritto in codice macchina.

5

LE ISTRUZIONI ED IL CODICE MACCHINA

Istruzione macchina:

Specifica un’istruzione elementare che il processore è in grado di svolgere.

È composta da:

–Codice operazione (indica cosa fare),

–Uno o due operandi (su cosa operare),

–Destinazione del risultato (dove memorizzarlo).

Codice macchina:

Codice binario usato per specificare le istruzioni macchina

6

PROCESSORE• Composto da blocchi con funzionalità diverse:

• CPU (Central Processing Unit),

• FPU (Floating Point Unit),

• Cache,

• Interfacce varie.

• Se integrato su un unico chip prende il nome di microprocessore.

Cache

Cache

Interf CPU FPU

7

CENTRAL PROCESSING UNIT (CPU)

• Svolge tutte le operazioni di:

• elaborazione numerica,

• controllo e coordinamento di tutte le attività.

• Si suddivide in:

• Unità logico-aritmetica (ALU).

• Unità di controllo (CU).

8

COMPONENTI DELLA CPU

Unità di controllo

Unitàaritmetico

logica

REGISTRI

Program Counter (PC)

Program Status Word (PSW)

Registro Istruzioni (IR)

Registro Indirizzi Memoria (MAR)

Registri Generali (8 o 16)

Registro Dati Memoria (MDR)

Registro di Controllo (CR)

Businterno

9

ARITHMETIC LOGIC UNIT (ALU)

Svolge tutti i calcoli logici ed aritmetici (complementazione, somma intera, confronto, etc). Opera direttamente sui registri generali.

E’ costituita da circuiti elettronici in grado di eseguire la somma di due numeri binari contenuti in due registri oppure di eseguire il confronto tra due numeri.

10

REGISTRI

Memoria locale usata per memorizzare:

dati acquisiti dalla memoria centrale o dalla unità di input,

risultati delle operazioni eseguite dall’ ALU.

Numero limitato: tipicamente da 8 a 256.

Unità di memoria estremamente veloci.

Le dimensioni di un registro sono una caratteristica fondamentale del processore: 16, 32, 64 bit.

11

REGISTRI (CONT.)

I registri contengono dati ed informazioni che vengono immediatamente elaborate.

Esistono due tipi di registri:

i registri speciali utilizzati dalla CU per scopi particolari,

i registri di uso generale (registri aritmetici).

12

IL CLOCKOgni elaboratore contiene un circuito di temporizzazione

(clock) che genera un riferimento temporale comune per tutti gli elementi del sistema.

T = periodo di clock

f = frequenza di clock ( = 1/T )

Frequenze tipiche delle ultime generazioni:

f > 1000 MHz, T < 10-9 secondi.

tT

13

TEMPISTICA DELLE ISTRUZIONI

Un ciclo-macchina è il tempo richiesto per svolgere un’operazione elementare.

È un multiplo del periodo del clock.

Un’istruzione macchina è ottenuta da una sequenza di operazioni elementari.

Dunque, l’esecuzione di un’istruzione macchina richiede un numero intero di cicli macchina, variabile a seconda del tipo di istruzione.

14

VELOCITÀ DEL MICROPROCESSORE

La velocità di elaborazione di un processore dipende dalla frequenza del clock.

I processori attuali hanno valori di frequenza di clock che varia tra gli 8 MHz ed i 2500 MHz.

15

MEMORIA

Viene utilizzata per conservare dati e programmi.

Si suddivide in:

Memoria di lavoro (memoria principale).

–Memoria in grado di conservare dinamicamente dati e programmi che il processore sta utilizzando.

Memoria magazzino (memoria di massa).

16

ORGANIZZAZIONE DELLA MEMORIA PRINCIPALE

• La memoria è organizzata funzionalmente in celle indipendenti.

• Ad ogni cella è associato un indirizzo

• cioè, un numero progressivo a partire da 0.

1936,27

12.360

Y

M

O

R

A

012345678

Load 2, 5

17

SCHEMA FUNZIONALE (GENERICO)

1. Programma e dati sono caricati in memoria.

2. La CU preleva la prima istruzione del programma dalla memoria.

3. L’istruzione viene decodificata ed eseguita.

4. La CU passa all'istruzione successiva.

18

SCHEMA FUNZIONALE

ALU

REG

ISTRI

Businterno

IRPC CU

CPU

BUS

Memoria

19

TIPI DI PROCESSORE

• Ogni processore possiede un “set” di istruzioni macchina che costituiscono i programmi.

• Una distinzione fondamentale fra i processori è quella che li differenzia in:

• CISC: Complex Instructions Set Computer.

• RISC: Reduced Instructions Set Computer.

20

TIPI DI PROCESSORE (CONT.)

• La differenza è nel set di istruzioni.

• I CISC hanno un linguaggio macchina formato da un numero elevato di istruzioni, anche complesse.

• Es.: Intel x86, Motorola 68000.

• I RISC sono dotati di istruzioni più semplici e in numero minore.

• Es.: PowerPC, Sparc.

ARCHITETTURA DEI CALCOLATORI( PARTE II )

GERARCHIA DI MEMORIE, PERIFERICHE, VALUTAZIONE DELLE PRESTAZIONI

22

RANDOM ACCESS MEMORY (RAM)

È una memoria volatile basata su circuiti digitali.

Il tempo di accesso è il tempo necessario per leggere o scrivere l’informazione in una Word.

Accesso casuale: ogni cella ha lo stesso tempo di accesso delle altre (indipendentemente dall’indirizzo).

23

CARATTERISTICHE DELLA RAM

La dimensione di una RAM varia a seconda del tipo di computer e viene espressa in MB.

Le dimensioni tipiche della RAM di un Personal computer vanno da 64 MB a 512 MB.

La RAM di un Server varia in genere da 512 MB a 2 GB.

Veloce.

Il tempo di accesso è dell'ordine di poche decine di nano-secondi (10-9 sec).

24

READ ONLY MEMORY (ROM)

• È una memoria di sola lettura che viene scritta direttamente dal produttore del computer su circuiti appositi.

• Viene utilizzata per contenere le informazioni di inizializzazione usate ogni volta che si accende l'elaboratore.

25

INIZIALIZZAZIONE

Cosa succede all’accensione di un calcolatore?

Nel PC viene forzato l’indirizzo della cella di memoria ove inizia il primo programma da eseguire (programma di bootstrap).

–Questo programma iniziale risiede in ROM.

Non è modificabile!!!!

26

MEMORIA CACHE

• Per migliorare le prestazioni di un computer si inserisce una memoria intermedia tra CPU e memoria centrale detta Cache:

• In genere è interna al processore.

• Più veloce della RAM: TCache~ 1/5 TRAM

• Di gran lunga più costosa della RAM: ~250 Euro/MB (anche più di 100 volte).

27

MEMORIA CACHE (CONT.)

• I dati e le istruzioni più frequentemente richiesti vengono memorizzati nella cache, in modo da diminuire il tempo di accesso ed aumentare quindi le prestazioni medie.

• Diventa cruciale il metodo per selezionare i dati e le istruzioni da inserire nella cache.

• Dimensioni tipiche:

• da 256 KB ad 1 MB di cache.

28

MEMORIA CACHE (CONT.)

• Senza cache:

• Tempo di accesso = tempo di accesso alla memoria.

• Con cache:

• Se il dato/istruzione è in cache, esso viene prelevato in un tempo minore.

CPUMemoria

RAM

cache

CPU MemoriaRAM

29

MEMORIA SECONDARIA

La memoria secondaria (o di massa) è utilizzata per memorizzare in modo permanente le informazioni.

Essa è di grande capacità ed è principalmente costituita da dischi magnetici, CD-ROM, DVD, nastri, …

Quando si vuole eseguire un programma, esso viene sempre caricato dalla memoria di massa alla memoria principale.

30

MEMORIA SECONDARIA Due tecnologie possibili:

Magnetica

–Dischi magnetici (Floppy-disk, Hard-disk, Disk-pack)

Accesso casuale

Operazioni di Lettura/Scrittura

–Nastri magnetici

Accesso sequenziale (legato alla posizione del dato)

Operazioni di Lettura/Scrittura

Ottica

31

ORGANIZZAZIONE FISICA DEIDATI NEI DISCHI

• I dischi sono suddivisi in tracce concentriche e settori.

• Ogni settore è una “fetta” di disco.

• I settori suddividono ogni traccia in porzioni di circonferenza dette blocchi.

• La suddivisione di un disco in tracce e settori viene indicata con il termine “formattazione”.

32

ORGANIZZAZIONE FISICA DEI

DATI NEI DISCHI (CONT.)• Per effettuare un’operazione di lettura (scrittura) su

un blocco è necessario che la testina raggiunga il blocco desiderato.

• Single-sided.

• Double-sided.

• Il tempo di accesso alle informazioni (access time) dipende da tre fattori fondamentali.

33

ORGANIZZAZIONE FISICA DEIDATI NEI DISCHI (CONT.)

• Seek time.

• La testina si sposta in senso radiale fino a raggiungere la traccia desiderata.

• Latency time.

• Il settore desiderato passa sotto la testina.

• La velocità di rotazione è espressa in rpm (round per minute).

• Transfer time.

• Tempo di lettura vero e proprio.

34

DISCHI MAGNETICI

• Hanno una grande capacità di memorizzazione.

• I floppy-disks che siamo abituati a vedere hanno una capacità di 1,44 MB.

• Zip-Disk.

• Un disco fisso in genere ha la capacità di 20 GB.

• Sono molto più lenti delle memorie primarie.

• Tempo di accesso nell’ordine dei milli-secondi, 10-3 sec.

• Sono molto economici ( 0.01 Euro/MB).

35

DISCHI OTTICI

Un disco CD-ROM (memoria ottica) ha la capacià di circa 640 MB.

Con i moderni DVD la capacità è aumentata parecchio.

Nei DVD la tecnica usata è quella del multistrato.

Inoltre, per pollice quadrato, è possibile immagazzinare molti più dati grazie alla maggior precisione del fascio laser.

36

NASTRI MAGNETICI.

• Sono stati molto utilizzati nei primi calcolatori.

• Oggi vengono soprattutto utilizzati come unità di backup, data la loro grande capacità di memorizzazione ed economicità.

37

GERARCHIA DI MEMORIE

velocità capacità

registri

cache

centrale

dischicosto

nastri

38

DISPOSITIVI DI INPUT/OUTPUT

• I dispositivi di I/O, detti anche periferiche, permettono di realizzare l’interazione uomo/macchina.

• La loro funzione principale è quella di consentire l’ingresso e l’uscita delle informazioni elaborate.

• Il controllo è eseguito da un software di gestione, detto “driver”, che ne gestisce le funzionalità.

39

DISPOSITIVI DI I/O (CONT.)

Terminali.

Tastiera.

Video.

Dispositivi di puntamento.

Mouse.

Trackball.

Penna luminose.

Schermo sensibile (Touch Screen).

40

DISPOSITIVI DI I/O (CONT.)

• Stampanti.

• A margherita.

• Ad aghi.

• Ink jet.

• Laser.

• Scanner, modem, plotter, scheda audio…

41

CLASSI DI ELABORATORI• Personal Computer:

• Computer che possono essere usati da un utente alla volta con capacità di elaborazione e memorizzazione autonoma.

• Portatili• Laptop: computer portatili con peso inferiore ai 5 kg. Molto costosi rispetto alle performance

offerte.

• Notebook: computer dalle dimensioni ridotte ma con potenza di calcolo buona. Più costosi dei PC.

• Palmari e PDA (Personal Digital Assistant)• Computer di dimensioni ridotte dai 10-18cm peso 300-400gr, prestazioni ridotte rispetto ai

portatili ma molto comodi.

• Micro e Minicomputer:

• Computer di media-alta potenza che possono gestire fino ad un centinaio di utenti che lavorano contemporaneamente, collegati attraverso i terminali.

• Workstations:• Terminali dei minicomputer.

• Mainframes:• Computer di grandi dimensioni molto costosi a cui sono collegati simultaneamente molti utenti

(anche migliaia).

42

I TERMINALI

• Postazioni di lavoro costituiti da un monitor ed una tastiera.

• Si classificano in

• Stupidi: utilizzano la CPU e l’hd del computer al quali sono connessi. Non sono in grado di effettuare nessun calcolo.

• Intelligenti: hanno capacità di calcolo e sono in grado di svolgere operazioni a livello locale anche se non dotati di memoria di massa.

43

UNITÀ DI INPUT

• Tastiera:

• La tastiera (o keyboard) (ridotta, con 86 tasti, oppure avanzata o espansa, con almeno 102 tasti).

• Si distinguono i seguenti elementi:

• la tastiera alfanumerica,

• i tasti funzione,

• la tastiera numerica,

• i tasti di controllo, posti tra la tastiera alfanumerica e quella numerica. Fra i tasti presenti ricordiamo:

• STAMP, talvolta utilizzabile per stampare il contenuto dello schermo su carta;

• CANC (o DEL), per cancellare il carattere su cui è collocato il puntatore;

• (HOME) e (End), utilizzati nei WORD PROCESSOR per posizionarsi rapidamente all'inizio o alla fine della riga;

• (PagUp) e (PagDn), per spostarsi rapidamente una videata in su o in giù;

• TASTI FRECCIA, per spostarsi rapidamente in alto, in basso, a destra o a sinistra;

44

UNITÀ DI INPUT (CONT.)

• Mouse.

• Trackball.

• Touchpad (sostituisce il mouse nei portatili).

• Joystick.

• Penna ottica.

• Scanner:• Manuali;

• Piani.

• Fotocamere e videocamere.

• Microfono.

45

UNITÀ DI OUTPUT

• Monitor:• CRT (tubo a raggi catodici), utilizza la tecnologia simile a quella usata nei televisori.

• LCD (schermo a cristalli liquidi, al plasma).

• Pollici: unità di misura del monitor (calcolata sulla diagonale dello schermo). Equivale a 2,54cm.

• Pixel: • Il monitor può essere pensato come una griglia composta da migliaia di quadratini detti

pixel. Maggiore è il numero di pixel più definita è l’immagine nel video.

• Risoluzione del monitor:• Si esprime in pixel e indica il numero di punti in orizzontale e in verticale sullo schermo

(es. 640x480).

46

UNITÀ DI OUTPUT (CONT.)

• Stampante:• A impatto

• Ad aghi.

• A non impatto• A getto di inchiostro.

• Laser.

• Plotter:• Simile al tecnigrafo e viene utilizzato principalmente per stampare su modulo continuo

disegni di grandi dimensioni.

• Microfilm:• Consentono l’archiviazione di grandi quantità di dati sotto forma di immagine.

• Altoparlanti

47

LA COMUNICAZIONE TRA LE COMPONENTI

• Le componenti hardware comunicano seguendo certe regole codificate che si chiamano:

PROTOCOLLI

48

PRESTAZIONI DI UN ELABORATORE

Valutazione molto difficile perchè dipende pesantemente dal:

programma eseguito,

tipo di dati,

architettura dell’elaboratore (istruzioni macchina, cache, ...).

Soluzioni impiegate:

MIPS,

MFLOPS,

Benchmark.

49

PRESTAZIONI DI UN ELABORATORE (CONT.)

MIPS - Millions of Instructions Per Second Istruzione: un’operazione in codice macchina. Poco indicativo.

MFLOPS -Millions of FLoating Operations Per Second Operazione: operazione numerica su reali.

Benchmark Tempo richiesto per eseguire una suite di programmi

applicativi con calcoli reali/interi.–Viene restituito un indice (valore numerico) delle prestazioni.

50

PRESTAZIONI DI UN ELABORATORE (CONT.)

In pratica:Un PC moderno è in grado di eseguire circa 1000

milioni di operazioni reali in un secondo (1000 MFLOPS)!

Il computer più potente ha superato la barriera dei TeraFLOPS (1012 FLOPS = 1000 miliardi di FLOPS)!

51

LE PORTE.

• Seriale.

• Trasmette un bit alla volta (ha 9 o 25 pin)

• Parallela.

• 8 bit alla volta, 25 pin, LPT line printer.

• SCSI.

• 8, 16, 32 bit.

• USB (universal serial bus)

• IRDA (infrared data association).

52

FINEARCHITETTURA DEGLI

ELABORATORI