### ESTRUTURA DA MEMÓRIA

TeSP de Aplicações Móveis André Martins Pereira



#### ESTRUTURA DA MEMÓRIA

- Funções
  - Armazenar temporáriamente/permanentemente programas e dados
  - Manipulada por instruções específicas
- Ligada ao CPU por barramentos
  - o Barramento de endereços
  - Barramento de dados
  - o Barramento de controlo





#### TIPOS DE MEMÓRIA

- Mas a memória é só RAM?
- No CPU (volátil)
  - Registos
  - Vários níveis de cache
- Exterior
  - o RAM (volátil)
  - ROM (permanente)
  - o Discos rígidos
  - Cassetes
  - 0 ...



#### HIERARQUIA DE MEMÓRIA





## HIERARQUIA DE MEMÓRIA



#### 32 VS 64 BITS

- O meu CPU e sistema operativos são de 32 bits
  - O que é que isto significa?
- Quantidade de bits que podem ser usados para endereçamento
  - o CPUs recentes suportam 64 bits
  - o Depende da versão de sistema operativo
  - o Se uma célula contém 1 byte, quantos GB é possível com:
    - > 32 bits
    - > 64 bits



## ORGANIZAÇÃO DA CACHE

- 3 níveis de cache, na Intel:
  - o 32KB L1 para dados e 32KB L1 para instruções por core
  - o 256KB L2 por core
  - L3 partilhada entre os vários cores
- Os dados estão sempre replicados
  - o L1 contém substracto de dados da L2, L2 da L3, L3 da RAM e RAM do disco rígido
  - o Registos são preenchidos com dados da L1
  - Alteração da L1 tem de ser propagada até ao disco...



## ORGANIZAÇÃO DA CACHE

- E se os dados não estão na L1?
  - o É preciso transferir da L2
  - o E se não estão na L2?
- Cache hit
  - Quando se pede um dado X e está no nível de cache acedido
- Cache miss
  - Quando se pede um dado X e não está no nível de cache acedido
- Cache miss rate
  - o Rácio entre cache hits e misses para um dado nível



## ORGANIZAÇÃO DA CACHE

- Cache miss penalty
  - Penalização (em tempo ou ciclos de clock) de ter de recorrer ao nível seguinte de cache
- Calcule o tempo de execução de um programa
  - o CPU freq. 1 GHz, L1 5ns, L2 30ns e RAM 100ns de acesso
  - o 100000 instruções
  - o 5 CPI médio
  - 20% miss rate na L1 e 40% na L2
  - o Dados necessários em RAM



# EXECUÇÃO DE UM PROGRAMA EM MEMÓRIA

- Instruções
- Dados
- Variáveis globais
- Variáveis locais
- Stack

Ox230
Instruções
Vars. Globais
Heap
...
Stack

0xFD2



# EXECUÇÃO DE UM PROGRAMA EM MEMÓRIA

- Heap
  - o Cresce "de cima para baixo"
  - o Guarda o estado de cada função
- Stack
  - o Cresce "de baixo para cima"
  - Guarda o estado global do programa
  - o Usado para a transferência de parâmetros entre funções

