



Arnau\_FIB  
[www.wuolah.com/student/Arnau\\_FIB](http://www.wuolah.com/student/Arnau_FIB)

★ 21811

## EC RESUM TEMES 6-8

EC RESUM TEMES 6-8



1º Estructura de Computadores



Grado en Ingeniería Informática



Facultad de Informática de Barcelona (FIB)  
Universidad Politécnica de Catalunya

**WUOLAH + #QuédateEnCasa**

#KeepCalm #EstudiaUnPoquito

Enhorabuena, por ponerte a estudiar te **regalamos un cartel** incluído entre estos apuntes para estos días.

## TEMA 6 : MEMÒRIA CACHÉ

El cost d'accendir a la memòria és molt alt. Per això és molt útil la memòria caché, una memòria petita i molt ràpida que permet emmagatzemar una còpia d'una part de la mem. general perquè sigui de més fàcil accés. S'ha d'aprofitar:

- Localitat temporal: tornar a accedir a adreces de mem. (per ex: en bucles).
- Localitat espacial: accedir a adreces de memòria propers (p.e: les instruccions dels programes, dades de vectors)



Depén del tipus de M.C. en ferà còpia a la M.C. o no (en cas de miss)

$$\text{taxa d'ençert } h = \frac{\text{nº ençerts}}{\text{nº referències}}$$

$$\text{Taxa fallades } m = \frac{\text{nº fallades}}{\text{nº referències}}$$

$$\hookrightarrow t_h = \text{comprovar si està la dada} + \hookrightarrow t_m = t_h + t_{\text{penalitzacions}} \\ \text{returna la dada}$$

## ALGORISMES D'EMPLAÇAMENT

### 1) correspondència directa

Cada bloc va a una única línia de la caché.

$$\text{index} = @\text{bloc} \% \text{ num\_linies}$$

$$@ = \boxed{@\text{bloc} \mid \text{off}}_n \rightarrow \text{mida\_bloc} = 2^n$$

$$@\text{bloc} = \boxed{\text{index}}_m \rightarrow \text{num\_linies} = 2^m$$

Caldrà afegir un bit de validesa: (Ex: caché 4 blocs/linies)

| nolíq v etiq |   | bloc |     |
|--------------|---|------|-----|
| 0            | 0 | -    | -   |
| 1            | 1 | 1200 | ... |
| 2            | 0 | -    | -   |
| 3            | 0 | -    | -   |

$$\left. \begin{array}{l} @ = \boxed{\text{etiq} \mid \text{index} \mid \text{offset}}_m \\ \text{index } n \end{array} \right\}$$

$$v = \begin{cases} 1 & \text{línia plena} \\ 0 & \text{línia buida} \end{cases}$$

### 2) Emplaçament Associatiu

Un bloc es pot guardar a qualsevol línia. Hi ha algorismes com LRU (Least Recently Used) o Random que decideixen quin bloc substituir.

3) Emplaçament associatiu de grau A

La caché s'organitza amb conjunts, on cada conjunt té A blocs.

Index-conj = @ bloc % num-conjunts

És una caché barreja entre corr. directa i associativa



Cal afegir bits de validesa per cada bloc.

$@ = \begin{array}{|c|c|c|} \hline \text{etiq} & \text{index} & \text{offset} \\ \hline m & n & \\ \hline \end{array}$

$2^n = \text{mida-bloc}$   
 $2^m = \text{num-conj}$

## POLÍTIQUES D'ESCRIPURA

### 1) Escriptura immediata (MIPS: E.I. amb Assignació)

En cas de hit, s'escriu tant a la M.P. com a la M.C.

En cas de miss, { Amb amig: Copia el bloc de MP a MC.  
→ la següent consulta serà hit. Més lent.

Sense amig: No es fa la còpia a M.C.  
→ la següent consulta serà miss. Més ràpid.

Problema: És molt lenta la escriptura. Solució: Introduir un Write-Buffer, on escriurem i el W.B. ja escriurà a M.P. quan pugui.

(A E.C. suposem un W.B. de cap infinita i que no provocarà errors)

### 2) Escriptura retardada

En cas de hit, s'escriu únicament a M.C.

En cas de miss, igual que amb E.I. Però, si s'ha escrit en el bloc que hem de reemplaçar, s'ha de portar aqueut bloc a memòria. Aquest se diu bit D (Dirty)

## TEMPS D'ACCÉS A MEMÒRIA

$$tam = t_h + m \cdot t_p$$

| tp:           | Escriptura immediata amb assig. | Escriptura immediata sense amigau | Retardada amig.                                                                |
|---------------|---------------------------------|-----------------------------------|--------------------------------------------------------------------------------|
| miss lect.    | $t_{block} + t_h$               | $t_{block} + t_h$                 | $D=1 \rightarrow 2 \cdot t_{block} + t_h$<br>$D=0 \rightarrow t_{block} + t_h$ |
| miss escripc. | $t_{block} + t_h$               | 0                                 | $D=1 \rightarrow 2t_{block} + t_h$<br>$D=0 \rightarrow t_{block} + t_h$        |

$$teje = t_c \cdot (n_{ins} \cdot CPI_{ideal} + n_{fallas} \cdot t_p)$$

$$CPI_{real} = CPI_{ideal} + (n_{fallas} \cdot t_p) / n_{ins}$$

$$teje = t_c \cdot n_{ins} \cdot CPI_{real}$$

\* Un pas més enllà és introduir dues cache en lloc d'una, per reduir així la taxa de fallades:



## JERARQUIA DE MEMÒRIA



## TIPOLOGIA DE FALLADES

- Cold-Start: Deguder al primer accés a cada bloc
- conflicte: Deguder al "mapeig" de dos blocs diferents a la mateixa línia de la cache (quan es vol accedir primer a un bloc i després al altre, i així continuament, es produeixen sempre misses). Es soluciona amb una associativitat suficient.
- capacitat: Dades que ja han estat accedites un cop, es reemplacen degut que el "conjunt de treball" no hi cap a la cache. (El tamañ de bloc no es suficientment gran i es torna a produir error quan pones "d'un bloc a un altre")

WUOLAH

INFO!

## Gana dinerito extra.

Recomienda a tus negocios favoritos que se anuncien en Wuolah y llévate 50€.

Te daremos un código promocional para que puedan anunciarse desde 99€.

- 1 Ve a tu negocio favorito
- 2 Dales tu código de promo
- 3 Diles que nos llamen o nos escriban.



### TEMA 7: MEMÒRIA VIRTUAL

Per evitar problemes durant l'execució de diferents programes en fa servir la memòria virtual, que permet que la memòria del computador sigui compartida per diferents programes, permet excedir la capacitat de la M.P. (RAM).

Direccions lògiques (virtuals): Els programes utilitzen un espai de direccions lògiques, exclusiu per a cada programa.

Direccions físiques: Direccions reals de la M.P. S'ha d'implementar un mode de passar d'adreces lògiques a físiques.

#### TRA DUCCIÓ D'ADRECES PER PÀGINACIÓ

La encarregada de passar de VPN (Virtual Page Number) a PPN (Physical Page Number) és la MMU (Memory Management Unit)

\* Una pàgina és un espai de memòria, com si fos un bloc.



$$@V = \boxed{\begin{array}{c|c} \text{VPN} & \text{offset} \\ \hline 20 & 12 \end{array}}$$

si mida-pàgina =  $2^{12}$  bytes  $\rightarrow$  offset = 12 bits

Per saber a quina direcció de M.F. ha de correspondre les pàgines de la M.V. cada programa té una taula de pàgines



D { 1 → Pàgina modificada per algun store  
0 → Pàgina consistent amb l'original del disc

Canvi de context: Passar d'executar les instruccions d'un programa a un altre. Caldrà salvar tots els registres i l'estat de la taula de pàgines.

653  
811  
910

WUOLAH

## POLÍTICA D'ESCRIPURA: Escriptura retardada amb assignació

En cas de hit, s'escriu a la M.F.

En cas de miss, copiar la pàgina del disc a M.F.

Quan una pàgina sigui reemplaçada, s'haurà de portar a escriure al disc quan el bit dirty sigui 1.

Reexecutar instrucció

### Gestió de fallada de pàgina



Problema! Cada load/store necessita 2 accessos a memòria, un a la T.P. per traduir la direcció i un per llegir/escrivir la dada. Sol? TLB

### TRADUCCIÓ RÀPIDA AMB TLB (Translation-Lookaside Buffer)

El TLB és una caché de traduccions (guardar les més recentment accedides).

Es busca al TLB el VPN:

Si es troba, tenim hit de TLB  $\begin{cases} V = 1 & \text{Perfecte} \\ V = 0 & \rightarrow \text{Fallada de pàgina} \end{cases}$

Si no, fallada de TLB:

- Copiar la taula de pàgines al TLB
- Si hi ha entrades, utilitzarà una. Si no, reemplaçar (si  $D = 1$ , caldrà fer còpia de la reemplaçada)
- Si el bit  $P$  de la T.P. és 0, el bit  $V$  del T.L.B serà 0



## Gestió de fallada de T.L.B.

Reintentar accés a mem



(Esquema ja fet)

## PROTECCIÓ

### Amb memòria virtual

- El mecanisme de traducció fa que sigui impossible que un procés accedeixi a pàgines fisiques d'un altre procés.
- Les taules de pàgines es guarden en un espai reservat al S.O.  
Es crea un bit de mode d'usuari { Mode Sistema: Accés a dades i codi del S.O., a dispositius físics (M.F., MMU, E/S, etc.), i pot
- Només es podrà modificar la T.P en M. sistema. executar instr. privilegiades.

### contra encriptura

És convenient prohibir la encriptura en certes pàgines de la T.P. Per això s'afegeix un bit de permís d'encriptura E en cada entrada de la T.P. i del TLB, i si  $E = 0$  i s'intenta escriure, excepció!

## COMPARTICIÓ

Assignar el mateix espai de M.F. a dos programes diferents per incrementar la eficiència mitjançant el paralellisme de tasques.

## INTEGRACIÓ DE CÀCHÉ I TLB



### Memòria càché física

És una solució simple però amb un temps d'accés elevat.

$t_h = \text{traduir} + \text{comprovar etiq} + \text{transfent dada.}$

## TEMA 8: EXCEPCIONS I INTERRUPTIONS

Les excepcions i les interruptions són mecanismes del processador que alteren el flux normal d'un programa.

Excepcions: Events interns causats per la execució d'una instrucció, per exemple una fallada de pàgina, accés a memòria no alineat, etc.

Interrupcions: Events externs produïts per dispositius d'entrada/s sortida.

### RUTINA DE SERVEI D'EXCEPCIONS (RSE)

Codi del S.O. que s'en carrega de gestionar les excepcions.

#### Tipus d'excepcions i interruptions:

- Excepcions produïda per una instrucció que viola alguna restricció:
  - L'instr. s'interrump sense escriure en registres ni en memòria.
  - Normalment s'aborta el programa, tot i que hi ha casos on es soluciona.
- Excepcions de fallo de pàgina i de TLB:
  - Si es fallo de TLB: RSE copia la entrada de la T.P. a la TLB.
  - Si es fallo de pàgina: RSE copia la pàgina del disc a un marc de pàgina lliure i s'actualitzen T.P. i el TLB.
  - La RSE acaba saltant a la instrucció que causa l'excepcions.
- Interrupcions: (causades per dispositius E/S)
  - No s'atenen immediatament
  - La RSE sol transferir els dades entre la CPU i el dispositiu E/S
  - La RSE salta a la següent instrucció del programa interruptut.

### COPROCESSADOR DEL SISTEMA (CPO)

Banc de Registres específic

mfc0 rt, co\_rd rt+co\_rd  
mtc0 rt, co\_rd co\_rd+rt

### Registre EPC (Exception Program Counter, \$14)

Serveix per guardar el PC (el de la inst. actual o el de la següent)

### Registre Status (\$12)

- Bit EXL (Exception Level) {
 

|   |                                              |
|---|----------------------------------------------|
| 0 | → Mode User                                  |
| 1 | → Mode Sistema → Interrupcions desabilitades |

}
- 8 bits de IM (Interrupt Mask): 1 bit per cada tipus d'interrupció, si el bit està a 1 → Interrupció habilitada

### Registre Cause (\$13)

- 5 bits de Ex Code: processador guarda aquí la causa de la Ex.
- 8 bits de IPC (Interrupt Pending): només lectura, per cada tipus d'interrupció. Si un bit val 1, vol dir que un dispositiu d'entrada/s sortida solicita l'interrupció.



## Gana dinerito extra.

Recomienda a tus negocios favoritos que se anuncien en Wuolah y llévate 50€.

Te daremos un código promocional para que puedan anunciarse desde 99€.

1 Ve a tu negocio favorito • 2 Dales tu código de promo • 3 Diles que nos llamen o nos escriban. ☎️

### ACCIONS DE HARDWARE EN CAS D'EXCEPCIÓ / INTERRUPCIÓ

Excepció → S'aborta instr. i no s'escriu ni es registra ni en memòria.

Interrupció → Es finalitza instr., es comprova que l'E/S estigui habilitada  
(IP<sub>i</sub> = 1 i EXL = 0 IM<sub>i</sub> = 1)

Es guarda el PC a EPC

S'escriu la causa de l'excepció al camp ExCode

Es posa a 1 el bit EXL del Status

El processador escriu al PC la direcció base de RSE

RSE (genèric) = 0x 8000 0180 } Estan al espai de

TLB miss (fallos TLB) = 0x 8000 0000 } mem reservat al S.O.

### FALLADA DE PÀGINA

Rutina especial TLBmiss. Utilitza dos registres \$K0, \$K1

context: 

|         |  |  |  |
|---------|--|--|--|
| @P.T.E. |  |  |  |
|---------|--|--|--|

TLBmiss: mfco \$K1, \$4 (context)

Entrylo: 

|     |    |  |  |
|-----|----|--|--|
| VPN |    |  |  |
| 81  | 12 |  |  |

lw \$K1, 0 (\$K1)

Salvar PC: EPC ← PC

mtco \$K1, \$2 (Entryhi)

Activar EXL: EXL ← 1

tlbwr (write to TLB random)

Saltar a @TLBmiss: PC ← 0x 8000 0000

eret (PC ← EPC, EXL ← 0)

Entryhi: 

|     |   |
|-----|---|
| PPN |   |
| 29  | 6 |

, bit 1: Validesa  
bit 2: Dirty

### CANVI DE MODE

Els canvis de mode User a mode Sistema només es produeixen quan hi ha una excepció o amb la instrucció syscall.

La instrucció syscall es pot fer servir per utilitzar dispositius d'E/S.

Per exemple: "print\_string"

.data

s: .ascii "Hola"

.text

.globl main

main:

...

move \$v0, 4

la \$a0, s

syscall

...

jr \$ra

} El codi 4 és el que permet imprimir un string. La adreça de la dada a imprimir es posa al \$a0. (El codi al \$v0)



653  
811  
910

WUOLAH

WUOLAH