

## SINTESI SEQUENZIALE SINCRONIZZATA

- IL DISPOSITIVO HA MEMORIA DEGLI EVENTI PASSATI (IN UN ARCO TEMPORALE FINITO) E SI BASE ALCHE SU DI QUESTI PER DETERMINARE GLI STATI SUCCESSIVI.

SI PROGETTANO COSÌ MACHINES A STATI FINITI DETERMINISTICHE.  
LE F.S.P. SONO CARATTERIZZATE DA:

- FISICA REALIZZABILITÀ (STATI FINITI E NON DIPENDONO DA EVENTI FUORI)
- DA DUE UNO STATO È UNA CONFIGURAZIONE, IL NUOVO STATO È IDENTIFICATO UNIVOCAMENTE.

UNA F.S.P. È DEFINITA DA:

- $I$  : ALFABETO IN INGRESSO
- $U$  : ALFABETO D'USCITA
- $S$  : INSIEME DEGLI STATI
- $\delta$  : FUNZIONE STATO PROSSIMO
- $\lambda$  : FUNZIONE D'USCITA.

## MACHINA DI TURING:

- A COSTRUISCER LA RISPOSTA DELLA MACHINA OTTENDO, TRAMANDANDO IN UN CERTO STATO PRESENTE, RICEVENDO UN SIMBOLO IN INGRESSO
- L'USCITA SI PRESENTA OTTOGGI LA MACHINA CAMBIA STATO

## MACHINA DI BOOLE:

- A COSTRUIRE CA DISPOSIZIONE DELLA MACHINA STANTE, ACCORDO STATO IN CUI SI TROVA
- L'USCITA VIENE DATA QUANDO LA MACHINA È IN UN DETERMINATO STATO.

È POSSIBILE CONVERGIRE UNA MACHINA DI TURING IN UNA MACHINA DI BOOLE E VICE-VERSA.

## SINTesi DI UNA FSI

- IDENTIFICA BLOCCHI DEI FUNZIONAMENTI DI ESTATE
- SINTesi DELLE RETI COMBINATORIE CON IL REAZZATO.

LA SINTesi DELLE FUNZIONI È DIPENDENTE DAL FLIP-FLOP UTILIZZATO

LA FSI POSSÈ ESSERE DESCRITA TRAMITE UNA TABE:

|         | $i_1$           | $i_2$           | ... |
|---------|-----------------|-----------------|-----|
| $s_1^t$ | $s_1^{t+1}/u_1$ | $s_2^{t+1}/u_2$ | ... |
| $s_2^t$ | $s_m^{t+1}/u_m$ | $s_k^{t+1}/u_k$ | ... |
| ...     | ...             | ...             | ... |

PER LA RACCOLTA DI REAZ.

|         | $i_1$       | $i_2$       | ... |
|---------|-------------|-------------|-----|
| $s_1^t$ | $s_1^{t+1}$ | $s_2^{t+1}$ | ... |
| $s_2^t$ | $s_m^{t+1}$ | $s_l^{t+1}$ | ... |
| ...     | ...         | ...         | ... |

PER LA RACCOLTA DI PROD.

Oltre alla tabella degli stati, è possibile realizzare un diagramma degli stati, ad essa equivalente.

MOTIV



|       | 0       | 1       |
|-------|---------|---------|
| $s_0$ | $s_1/1$ | $s_2/1$ |
| $s_1$ | $s_3/0$ | $s_2/1$ |
| $s_2$ | $s_1/1$ | $s_3/0$ |
| $s_3$ | $s_3/0$ | $s_0/0$ |

MOOP



|       | 0     | 1     | U  |
|-------|-------|-------|----|
| $s_0$ | $s_1$ | $s_2$ | 00 |
| $s_1$ | $s_3$ | $s_2$ | 01 |
| $s_2$ | $s_1$ | $s_3$ | 10 |
| $s_3$ | $s_3$ | $s_0$ | 11 |

## SINTESI DI UNA FSN: 2

DALLA TABECCA DEGLI STATI SI COSTRUISE LA TABECCA DEGLI  
TRANSIZIONI, ASSEGNAANDO UNA CODIFICA AGLI STATI.

$$\begin{aligned} S_0 &= 00 \\ S_1 &= 01 \\ S_2 &= 10 \\ S_3 &= 11 \end{aligned}$$

$\Rightarrow$

|    | 0  | 1  | U  |
|----|----|----|----|
| 00 | 01 | 10 | 00 |
| 01 | 11 | 10 | 01 |
| 10 | 01 | 11 | 10 |
| 11 | 11 | 10 | 11 |

Y<sub>41</sub>

DATI LA TABECCA DELLE TRANSIZIONI, SCEGLI GLI ELEMENTI DI  
MEMORIA, SI PASSA ALLA TABECCA DELLE ECUAZIONI



## BISTABILI (ELEMENTI DI MEMORIA)

SET-PRESET (BISTABILE ASINCRONO)



SET-PRESET CON CLOC (BISTABILE SINCRONO)



## D-LATCH



(SINCRONIZZO)

IL LATCH RISPOSTA A D  
QUANDO IL CLOCK È  
ACTO.

## D-MASTER/SLAVE

S-R E D HANNO IL PROBLEMA DI UNA TRANSPARENZA DELLE USCITE QUANDO IL CLOCK È ACTIVO.

QUESTO PROBLEMA È RISOLTO DAL D-MASTER/SLAVE CHE FA USO DI DUE CIRCUITI D.



D-MASTER/SLAVE

## SET DI OPERATORI FUNZIONALI PER COMBINATORI

- AND, OR, NOT
- AND, NOT
- OR, NOT
- NAND
- NOR

### DE MORGAN

$$\overline{(A+B)} = A \times B$$

$$\overline{A+B} = \overline{A} \times \overline{B}$$

### FORMA CANONICA

- 1<sup>a</sup> FORMA CANONICA: SOMMA (OR) DI PRODOTTI (DEI TERMINI) CHE RISULTANO 1

| A | B | y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

$$\overline{A} \cdot \overline{B} + A \cdot B \quad \text{1<sup>a</sup> FORMA}$$

SOP

- 2<sup>a</sup> FORMA CANONICA: PRODOTTO DI SOMME (DEI TERMINI CHE RISULTANO 0) → PRODOTTO DI MAXTERM.

| A | B | y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

$$(\overline{A} \cdot \overline{B}) \times (\overline{A} \cdot B) \quad \text{2<sup>a</sup> FORMA}$$

POS

### KARNAUGH → ORDINIZZA LE CARDINALITÀ DELL'ESITO A DUE VIVELLI (SOP)

- FORMULA  $a \cdot z + a' \cdot z = (a + a') \cdot z = z$

- METODO ESATTO

- APPLICAZIONE DIFFERENTI LA FORMULA NON È SEMPRE IL MEGLIO POSSIBILE.

AD ESEMPIO

| A | B | y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 1 |

$$y(A, B) = \overline{A} \cdot B + \overline{B} \cdot A + A \cdot B$$

$$= B(\overline{A} + A) + A\overline{B}$$

$$= B + A\overline{B}$$

PER NON ESSERE FONTE DI ERRORE!

REPLICA BOLLE

$$\overline{A} \cdot B + B \cdot \overline{A} + A \cdot B + A \cdot \overline{B} \rightarrow A(B + \overline{B}) + B(A + \overline{A}) = A + B$$

$$\uparrow \downarrow x = x + x \Rightarrow x \neq x \neq x$$

## MAPPF DI KARNAUGH!

- CONSIDERANDO DI IDENTIFICARE CON PUÒ (PERDITA DI ZONA) SIA IL CIRCUITO DA RIDURRE CHE TENERE DA RIPPLICARE.

- APPLICABILE PENO A 4 VARIABILI

| CD | 00 | 01 | 11 | 10 |                     |
|----|----|----|----|----|---------------------|
| 00 | 1  | 1  |    |    | $\bar{B}\bar{C}A +$ |
| 01 | 1  | 1  | 1  | 1  | $A\bar{D}$          |
| 11 |    |    | 1  | 1  | $\bar{B}C\bar{D}$   |
| 10 | 1  |    |    | 1  |                     |

## METODO DI QUINN-MCCLUSKEY: PRIMA FASE

0001 1      -000 1,3 ESSENZALE

|         |            |
|---------|------------|
| 1001 9  | 10-1 9,11  |
| 1100 12 | 1-01 9,13  |
| 1011 11 | 110- 12,13 |
| 1101 13 | 11-0 12,14 |
| 1110 14 | 1-11 11,15 |
| 1111 15 | 11-1 13,15 |
| 1111 15 | 111- 14,15 |

SI CONFRONTO  
I RISULTATI  
CHE DIFFERISCONO  
DI UN UNO.

1--1 9,11,13,15  
11-- 12,13,14,15

SI CONFRONTO  
I RISULTATI  
CON DOPPIAMENTO  
MOLTI SESSI POSS.

## METODO DI QUINN-MCCLUSKEY: SECONDA FASE

SI UTILIZZA LA TABELLA DI COPERTURA.

- SI RIDUCE LA TABELLA TRAPPOLE CRITICHE DI ESSENZALE E DOPPIAMENTO.
- A TABELLA INDUCIBILE SI SPOSTANO CRITERI DI BRANCHE MOLTI BOUND.

## ISTRUZIONI DFL RIPS

| OP CODE | SOURCE REGISTER | TARGET REGISTER | DESTINATION REGISTER | SHIFT AMOUNT | FUNC |
|---------|-----------------|-----------------|----------------------|--------------|------|
| 31      | 26 25           | 21 20           | 16 15                | 14 13        | 6 5  |

R ?

| OP. CODE | SOURCE REGISTER | TARGET REG | ADDRESS |
|----------|-----------------|------------|---------|
| 31       | 26 25           | 21 20      | 16 15   |

I (LOAD/STORE)

| OP. CODE | ADDRESS |
|----------|---------|
| 31       | 26      |

J UNP

## ISTRUZIONI DI TIPO R

LE ISTRUZIONI DI TIPO R, AMMETTONO - LOCALI, VENGONO ESEGUITE IN 4 PASSI:

- PRELIEVO ISTRUZIONE E INCREMENTO DFL P.C.
- CARICAMENTO DATI DAL REGISTRO SORANTE
- ALU
- SWINGAR NEL REGISTRO DFL RISULTATO

## ISTRUZIONI DI TIPO I (LOAD/STORE)

LE ISTRUZIONI DI LOAD/STORE, DI TIPO I, VENGONO ESEGUITE IN 5 PASSI:

- PRELIEVO ISTRUZIONE E INCREMENTO DFL P.C.
- LETTURA REGISTRO BASE
- OP ALU (BASE + OFFSET)
- PRELIEVO DATO DALLA MEMORIA
- SCRITTURA DATO IN UN REGISTRO DESTINA ZIONE.

## OPERAZIONI A RISERVA CON INCREMENTO (TIPO I)

- PRELIEVO ISRUZIONE E INCREMENTO P.C.
- LETTURA DAL REGISTRO SORPASSO
- OPERAZIONE A.L.V.
- SCRITTURA NEL REGISTRO DESTINAZIONE

## ISCRIZIONI DI SALVAGUARDIA CONDIZIONATE (TIPO I)

- PRELIEVO ISRUZIONE E INCREMENTO P.C.
- LETTURA DEL DUE REGISTRI SORPASSO
- OP ALW  $(\$X - \$Y) \& (PC + G + \text{OFFSET})$ ,  
ALU PRINC. ADDER PC.
- SCRITTURA NEL P.C.

## PIPELINING

NON PRODUCE IL TEMPO PFR ISOLAZIONE, MA AUMENTA IL TIRATURA PUT.



NON TUTTI GLI ISOLAZIONI POSSONO DIRETTAMENTE ESSERE ESEGUITI. ANZI, ESCLUSIVAMENTE UN LOAD NECESSITA DI 5 PASSI. QUESTO PERCHÉ AD UN INEVITABILE PERIODICO DI PRESSIONE NEL TEMPO DI GSFCUZIONE DI UNA SIMOLA ISOLAZIONE. DI CONSEGUENZA, IL THROTTLE PUT SI DIVIDIPUTA IN UN PIPELINE A 5 STADI.

SI INTRODUCONO I REGISTRI DI PIPELINING CHE CONTROLLANO LO SCAMBIO DI DATI TRA LE COMPONENTI HANDICAPPE CONVOLGE AL DIVERSI STADI. CASO SPECIALE È QUELLO DEI SEGNALI DI CONTROLLO. ANCHE QUI VENGONO TRASFERITI TRA I VARI STADI HARDWARE.

## Pipeline Hazards

SI POSSONO SVILUPPARE 3 TIPI DI CONFLITTI IN UN SISTEMA CON PIPELINE:

- CONFLITTI SINTATTICI: IL SISTEMA CORRE DI USARE LA STESSA RISORSA PEL PIÙ ISOLATAMENTE (IF e ID ATTRAVERSAMENTE, SE CE SONO DUE INSTRUZIONI E DATI NON FASCONO DISARME)
- CONFLITTI SUI DATI: IL SISTEMA NECESSITA DI UN DATO CHE NON È ANCORA STATO ELABORATO DALLA PIPELINE
- CONFLITTI SUL CONTROLLO: SALVI CON DISCONNETTI.

NELL'ARCHITETTURA RIPS NON SI PRESENTANO CONFLITTI SINTATTICI, DATI CHE SEPARAZIONE DELLA MEMORIA ISOLAZIONE DATI TRA DATI E L'ACCESO CONCERNE AL BANCO DEI REGISTRI.

## Conflitti di dati

|                      |                              |
|----------------------|------------------------------|
| add \$50, \$t0, \$t1 | [ IF   ID   EX   RFN   WB ]  |
| sub \$t2, \$50, \$t3 | [ (F)   ID   EX   RFN   WR ] |

↓ PROPAGAZIONE

SI USA LA PROTEZIONE DA OVERWRITE  
TRA EX/RFN DELLA ADD E  
ID/EX DELLA SUB.

NECESSITA DI \$50 PRIMA CHE  
SIA SCRITO NEL REG.

NEL CASO DI UNA LOAD + OPERAZIONE NON È POSSIBILE PROPAGARE IL DATO, PERCHÉ QUESTO DIVENTA DISPONIBILE NELLO STADIO RFN/WB.  
IN QUESTO CASO SI INSERISCE UNA BOLTA, O NOP, PER RIARREDARE UN'ISTRUZIONE SUCCESSIVA, E RENDERE POSSIBILE LA PROPAGAZIONE.

## Conflitti del controllo

bey afnem confrin → BRANCH PROTECTION: SE LA PREDIZIONE È SBAGLIATA, PUSH DELTA PIPELINE

→ PROPAGAZIONE DEGLI OPERANDI A UN COMPARATORE  
SEPARATO DAL MIOLO SINTETICO ID

## PARTIZIONE DELLA MEMORIA



## DICHIARAZIONI DI VAR GLOBALI

```

• .idata <addr> // LA MEMORIA PIANIFICA
    ADDR
• .ascii "str"   // STRINGA CON \0
• .ascii "str"   // STRINGA SENZA \0
• .byte b1,b2...bn // TUTTI DI BYZE INITIAL.
    A b1,b2,bn
• .WORD w1,...wm // ARRAY DI WORDS
• .SPACE n       // RUOCA N BYZE
• .text <addr> // RICONOSCE ISOLAMENTO
• .globl gyn    // DECLARA SIMBOLO
• .eyv           // CORRE #DEFINE IN C

```

## SYSTEM CALL

È POSSIBILE EFFETTUARE CHIAMATE DI SISTEMA, RETTENENDO IL CODICE DELLA CHIAMATA NEL REGISTRO \$V0 E CHIAMANDO IL COMANDO 'syscall'.

| CODICE DRIV  | SYS CALL | COD      | ARG  | RPS |
|--------------|----------|----------|------|-----|
| MORE         |          |          |      |     |
| print_int    | 1        | \$a0     | /    |     |
| print_float  | 2        | \$f12    | /    |     |
| print_double | 3        | \$fir    | /    |     |
| print_string | 4        | \$a0     | /    |     |
| read_int     | 5        | /        | \$v0 |     |
| read_float   | 6        | /        | \$f0 |     |
| read_double  | 7        | /        | \$f0 |     |
| read_string  | 8        | \$a0,buf | /    |     |
| strlen       | 9        | \$a0     | \$v0 |     |
|              | 10       | /        | /    |     |

→ \$a0 È UN BUFFER DI LUNGHEZZA  
SPECIFICATA DA \$a1



## MEMORIE CACHE

### CACHE DIRECT - RAPPFD

SE CA CACHE PUÒ CONTENERE  $N_b$  BLOCCI,  $\log_2 N_b$  È IL  
NUMERO DI BIT PER INDIZZARLI.



Ogni blocco di cache contiene:

- 1 bit di validità
- un campo esecutiva
- un campo contenuto (dati)

Il blocco di cache contiene tipicamente 8-16 parole.

## SCUTTURA

SI POSSONO ADOTTARE DIVERSE SOLUZIONI PER RISOLVERE LA SINTAGMA  
TRA CACHE E RAM:

- WRITE THROUGH: TUTTE LE SCRIZIONI VENGONO EFFETTUATE SULLA MEMORIA SIA IN CACHE CHE IN RAM. QUESTO APPROCCIO È LENTO.
- WRITE BUFFER: CACHE È WRITE BUFFER RICEVENDO SCRIZIONI DA SCRITURA, IL CONTROLLORE DEL WRITE BUFFER PROPAGA POI SA MODIFICHE IN RAM, INDIPENDENTEMENTE DATI CPU. I-8 POSIZIONI
- WRITE BACK: IL BLOCCO MODIFICATO VENDE SCRITTO IN RAM SOLO QUANDO DEVE ESSERE SCRISSO.
- WRITE BACK CON DIRTY BIT: SI TIENE UN BIT DI "DIRTY" CHE INDICA SE IL BLOCCO È STATO MODIFICATO. SE NON È STATO MODIFICATO, NON C'È BISOGNO DI SCRIVERLO IN RAM.

## ALCUNE SOLUZIONI CACHE

### CACHE TOTAL RELOAD ASSOCIAZIONE:

- QUALSiasi blocco può andare ovunque.
- Il tag è l'indirizzo indirezionale del blocco
- NECESSITA DI UNA POLIZIA PER SOSTITUIRE. TIPI CAPANNI  
SI USA IL LRU (LEAST RECENTLY USED)

### CACHE SET-ASSOCIAZIONE:

- CORRISPONDE TRA LA DIRECT MAPPING E LA TOTAL RELOAD ASSOCIAZIONE
- SI TRATTA DI SET ASSOCIAZIONE DI CACHE DIRECT CON VALUE CACHE DISTINTE E PARALLELE PER OGNI TAG.

## MEMORIA VIRTUALE

- PIÙ PROGRAMMI IN ESECUZIONE SIMULTANEAEMENTE SONO IN AFFERISCI SPAZI DI INDIRIZZAMENTO DISTINTI (PROTEZIONE)
- LA MEMORIA VIRTUALE FA CIO CHE C'È UNA CARICA C'È UNA DISCARICA PROGRAMMA E RAM.
- UN SINGOLO PROGRAMMA PUÒ OCUPARE PIÙ RAMA PRINCIPALE DI QUELLA DISPONIBILE.

LA MEMORIA PRINCIPALE È CHIAMATA MEMORIA FISICA, E I SUOI INDIRIZZI SONO CHIAMATI INDIRIZZI FISICI

LA MEMORIA VIRTUALE HA INDIRIZZI RICLOCABILI (PARATO DA 0) E CO SPAZIO DI INDIRIZZAMENTO È DEFINITO DAL M° B17 DEL IMP.

C'È UN MECCANISMO AUTOMATICO DI TRADUZIONE TRA MEM. VIRTUALE E INDIRIZZI FISICI. (RICLOCABILE DIMENTICA)  
QUESTO SISTEMA È TRANSPARENTE AL PROGRAMMATORE, AL CORRISPONDENTE E AL LIVELLO.

LA MEMORIA VIRTUALE È ORGANIZZATA IN PAGINE.

SI POSSONO VERIFICARE PAGE FAULT

INDIRIZZO VIRTUALE:

| NUMERO PAG. VIRTUALE | OFFSET NELLA PAGINA |
|----------------------|---------------------|
| ↓ TROVATO            | ↓ IDENZICO          |
| NUMERO PAG. FISICA   | OFFSET              |

→ LA DIFFERENZA DEI GRUPPI DI PAGINE DATA GRANDEZZA DELLA PAG.



TOTALEMENTE ASSOCIAZIONE + CASO  $\checkmark$  USATO RULE PER LA SOSTITUZIONE  
NELL'SI POSSONO ANCHE USARE ALGORITMI COMPLESSI, A CARICO DEL S.O. E LI POSSONO DURARE LUNGH

PTR TRA DIREZIONE DA N° PAG. VIRT A N° PAG. FIS. SI USA UNA TABELLA DELLE RICARICHE

## TABELLA DEGLI PAGINI

SI USA UNA TABELLA DEGLI PAGINI PER OGNI PROCESSO.

IL NPU PUÒ QUINDI ESSERE USATO COME INDICE PER DI RECUPERARE IL NPF.

PAGINA REALE È IMPOSSIBILE SPIARE UN'ALTRA VIBELLA NELLA RAMMA FISICA. ANCHE LE VIBELLE SONO SOGGETTE A PAGINA FUORI.

## MEMORY MANAGEMENT UNIT

DISPOSITIVO HARDWARE CHE HA IN CAMPO LA GESTIONE DEGLI PAGINI DI RAMMA.

IN PARTICOLARE, CONTIENE UNA TABELLA "TLB" IN CUI ASSOCIA  $PI\oplus + NPU \Leftrightarrow NPF$ .

SE LA PAGINA NON È TROVATA NEL TLB, LA RICERCA VIENE EFFETTUATA NELLA TABELLA DEGLI PAGINI. SE NEANCHE VI È PRESENTE, SI GENERA UN PAGE FAULT.