1 / 22

SSC 140 - SISTEMAS OPERACIONAIS I Turmas A e B Aula 12 – Gerenciamento de Memória 3

Universidade de São Paulo Instituto de Ciências Matemáticas e de Computação Departamento de Sistemas de Computação. SSC 140 - SISTEMAS OPERACIONAIS I Turmas A e B Aula 12 – Gerenciamento de Memória 3 Profa. Sarita Mazzini Bruschi Regina Helena Carlucci Santana Marcos José Santana

kimn
Download Presentation

SSC 140 - SISTEMAS OPERACIONAIS I Turmas A e B Aula 12 – Gerenciamento de Memória 3

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Universidade de São PauloInstituto de Ciências Matemáticas e de ComputaçãoDepartamento de Sistemas de Computação SSC 140 - SISTEMAS OPERACIONAIS I Turmas A e B Aula 12 – Gerenciamento de Memória 3 Profa. Sarita Mazzini Bruschi Regina Helena Carlucci Santana Marcos José Santana Slides adaptados de Luciana A. F. Martimiano baseados nos livros Sistemas Operacionais Modernos de A. Tanenbaum

  2. Programa • Introdução aos Sistemas Operacionais • Processos • Gerência de Memória • Memória virtual • Paginação • Segmentação • Sistemas de Arquivos • Entrada/saída • Segurança • Exemplos de Sistemas Operacionais

  3. Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmos vistos: • Ótimo; • NRU; • FIFO; • Segunda Chance; • Relógio; • Hoje: • LRU; • Working set; • WSClock;

  4. Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmo Least Recently Used Page Replacement (LRU) ou Menos Recentemente Usada (MRU) • Troca a página menos referenciada/modificada recentemente; • Alto custo • Lista encadeada com as páginas que estão na memória, com as mais recentemente utilizadas no início e as menos utilizadas no final; • A lista deve ser atualizada a cada referência da memória;

  5. Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmo Least Recently Used Page Replacement (LRU) • Pode ser implementado tanto por hardware quanto por software: • Hardware: MMU deve suportar a implementação LRU; • 1a. opção • Contador em hardware (64 bits) – conta instruções executadas; • Após cada referência à memória, o valor do contador é armazenado na entrada da tabela de páginas referente à página acessada; • Quando ocorre falta de página, o SO examina todos os contadores e escolhe a página que tem o menor valor

  6. Gerenciamento de Memória Troca de Páginas - Paginação • LRU – Hardware - 2a. Opção • Matriz nxn bits • Referencia a página k -> linha k=1 e coluna k=0 0,1,2,3,2,1,0,3,2,3

  7. Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmo Least Recently Used Page Replacement (LRU) • Pode ser implementado tanto por hardware quanto por software: • Software: duas maneiras • NFU (Not frequently used) ou LFU (least frequently used); • Aging (Envelhecimento);

  8. Gerenciamento de Memória Troca de Páginas - Paginação • Software: NFU ou LFU (least) • Para cada página existe um contador  iniciado com zero e incrementado a cada referência à pagina; • Página com menor valor do contador é candidata a troca; • Esse algoritmo não se esquece de nada • Problema: pode retirar páginas que estão sendo referenciadas com freqüência; • Compilador com vários passos: passo 1 tem mais tempo de execução que os outros passos  páginas do passo 1 terão mais referências armazenadas;

  9. Gerenciamento de Memória Troca de Páginas - Paginação • Software: Algoritmo aging (envelhecimento) • Modificação do NFU, resolvendo o problema descrito anteriormente; • Além de saber quantasvezes a página foi referenciada, também controla quando ela foi referenciada;

  10. Bits R para páginas 0-5 clocktick 0 clocktick 2 clocktick 1 clocktick 3 clocktick 4 0 1 1 1 1 1 0 1 0 1 1 1 0 0 0 0 0 0 1 0 0 1 0 1 1 1 0 0 1 0 Contadores 0 10000000 11100000 11000000 11110000 01111000 1 00000000 10110000 01100000 10000000 11000000 2 10000000 00100000 00100000 10001000 01000000 3 00000000 10000000 01000000 00100000 00000000 4 10000000 01011000 01100000 11000000 10110000 5 10000000 00101000 01000000 01010000 10100000 a) c) e) b) d) Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmo aging

  11. WS P1 P3 P4 P7 P8 P4 tempo t1 t2 Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmo Working Set (WS): • Paginação por demanda páginas são carregadas na memória somente quando são necessárias; • Pré-paginação Working set • Carregar um conjunto de páginas que um processo está efetivamente utilizando (referenciando) em um determinado tempo t antes de ele ser posto em execução; w(k,t)

  12. Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmo Working Set (WS): • Objetivo principal: reduzir a falta de páginas • Um processo só é executado quando todas as páginas necessárias no tempo t estão carregadas na memória; • SO gerencia quais páginas estão no Working Set; • Para simplificar  oworking set pode ser visto como o conjunto de páginas que o processo referenciou durante os últimos t segundos de tempo; • Utiliza bit R e o tempo de relógio (tempo virtual) da última vez que a página foi referenciada;

  13. Tempo virtual atual (CVT): 2204 age = CVT – TLU (Ex.: 2204-2084 = 120) τ = múltiplos clock ticks 2014 2032 2020 2003 1980 1620 1213 2084 1 0 1 1 1 1 1 0 Tabela de Páginas Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmo WorkingSet: Bit R Tempo do último Uso (TLU) Percorrer as páginas examinando bit R; Se (R==1)* página foi referenciada; faz TLU da página igual ao CVT; Se (R==0 e age > τ) página não está no working set; remove a página; Se (R==0 e age <= τ) ** página está no working set; guarda página com maior age; * Se todas as páginas estiverem com R=1, uma página é escolhida aleatoriamente; ** Se todas as páginas estiverem no WS, a página mais velha com R=0 é escolhida;

  14. Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmo WSClock: • Clock + WorkingSet; • Lista circular de molduras de páginas formando um anel a cada página carregada na memória; • Utiliza bitR e o tempo da última vez que a página foi referenciada; • Bit M utilizado para agendar escrita em disco;

  15. 2003 2020 1213 2003 2084 1620 2084 2032 1980 1213 2032 2014 2014 2020 1620 1980 1 0 1 1 1 0 1 0 0 1 1 0 1 1 1 1 Bit R Tempo do último uso b) a) Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmo WSClock: Tempo virtual atual: 2204 Se R==1 Então R=0 e ponteiro avança

  16. 2020 2084 1620 2003 2032 1980 1213 2014 2020 1620 2032 2003 1980 2204 2014 2084 1 1 0 0 1 1 1 0 1 1 1 1 1 1 0 0 Bit R Tempo do último uso d) c) Nova página Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmo WSClock: Tempo virtual atual: 2204 Se R==0 e age>t Então M==0 (não agenda escrita)  troca

  17. 2014 2003 2020 2003 1980 1620 2084 2032 2084 1980 2032 1213 1213 2204 2020 2014 1 0 1 0 1 1 0 1 0 0 1 1 0 1 0 0 Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmo WSClock: Tempo virtual atual: 2204 Nova página d) c) R==0 e age>t M==1 (agenda escrita e continua procura)

  18. Gerenciamento de Memória Troca de Páginas • Política de Substituição Local: páginas dos próprios processos são utilizadas na troca; • Dificuldade: definir quantas páginas cada processo pode utilizar; • Política de Substituição Global: páginas de todos os processos são utilizadas na troca; • Problema: processos com menor prioridade podem ter um número muito reduzido de páginas, e com isso, acontecem muitas faltas de páginas;

  19. Gerenciamento de Memória Troca de Páginas Falta de Página no Processo A Configuração inicial Alocação local Alocação global

  20. Gerenciamento de Memória Troca de Páginas • Política de alocação local (número fixo de páginas/processo) permite somente política de substituição local de páginas • Política de alocação global (número variável de páginas/processo) permite tanto a política de substituição de páginas local quanto global

  21. Gerenciamento de Memória Troca de Páginas - Paginação • Algoritmos de substituição local: • Working Set; • WSClock; • Algoritmos de substituição local/global: • Ótimo; • NRU; • FIFO; • Segunda Chance; • LRU; • Relógio;

  22. Gerenciamento de Memória Troca de Páginas - Paginação Prova – até aqui!!!!! Próxima aula..... • Memória virtual • Paginação • Implementação • Tabela de Páginas Invertida • Segmentação

More Related