UFPR · DELT · Contact
Sistemas Operacionais Embarcados TE244

Avisos
  1. Bem vindo à página da disciplina TE244 Sistemas Operacionais Embarcados / Segundo semestre de 2015.
  2. Notas parciais (prova1, trabalho1)
  3. Notas da prova 1 considerando as duas novas avaliações realizadas.
  4. Notas da prova 2.
  5. Notas finais (antes do exame).
  6. Notas finais com exame. Boas férias!

Lista de Temas Tratados nas Aulas
  1. Arquitetura básica de computadores. Processador. Barramento. Interrupções. Memória. Dispositivos de E/S.
  2. Organização básica do sistema operacional. Histórico de evolução dos sistemas operacionais e hardware.
  3. Escalonamento de processos. Sistemas batch. Sistemas de tempo compartilhado. Algoritmos de escalonamento. Princípios de escalonamento em sistemas de tempo real.
  4. Visualização de processos e comandos do sistema Unix.
  5. Concorrência e sincronização de processos. Problemas de concorrência. Alocação de recursos e deadlocks.
  6. Semáforos. Implementação em sistemas Unix.
  7. Gerência de Memória.
  8. Sistema de arquivos:
    1. Hardware de disco, bloco, cilindro, cabeças de leitura.
    2. Atributos de arquivos em sistemas Unix e Windows
    3. FAT - File Alocation Table
    4. Implementação com Nós I
    5. NTFS (NT File System)
    6. Cluster vs. bloco físico, algoritmo do elevador.
  9. Segurança: princípios de criptografia. Armazenamento de senhas.
  10. Sistema Embarcado Android

Critérios de avaliação

Média do semestre:
(P1+P2+T)/3
P1- Prova1, P2- Prova2, T- Média nos Trabalhos


Datas de provas

Especificação de trabalhos
  • Trabalho 1. Data de entrega: 24/09/2015 remarcado para: 28/9/2015. Padrão para o relatório (PDF). e respectivo fonte em Latex.
  • Trabalho 2. Data de entrega: 30/11/2015 .

  • Exemplos apresentados em aula
    1. Principais comandos Unix relacionados à processos
    2. Programa consumidor de CPU
    3. Exemplo Fork
    4. Programa consumidor de CPU versão multi-thread
    5. Comandos Unix - Processos
    6. Exemplo1: problema com condições de corrida. Para compilar, use gcc -o ex1 ex1.c -pthread
    7. Exemplo1: solução utilizando semáforo. Para compilar, use gcc -o ex1-solucao ex1-solucao.c -pthread -lrt
    8. Exemplo2: problema com condições de corrida. Para compilar, use gcc -o ex1 ex1.c -pthread
    9. Exemplo2: solução ineficiente utilizando semáforo. Para compilar, use gcc -o ex1-solucao ex1-solucao.c -pthread -lrt
    10. Simulação do problema produtor-consumidor. Neste exemplo, 2 produtores e 1 consumidor.
    11. Solução para o problema acima utilizando semáforos. Para compilar, use gcc -o produtor-consumidor produtor-consumidor.c -pthread -lrt
    12. Simulação do problema do jantar dos filósofos. A simulação usa semáforos para representar os garfos.

    Listas de Exercícios
    1. Lista 1
    2. Filas: resumo e exercícios

    Referências
    1. TANENBAUM, A. S. Sistemas Operacionais Modernos. Ed. Pearson Prentice-Hall.
    2. SILBERCHATZ, A., J. L. Peterson. Sistemas Operacionais . Ed. Pearson Prentice-Hall.
    3. TANENBAUM, A. S. e A.S. Woodhull. Sistemas Operacionais - Projeto e Implementação. Ed. Bookman.
    4. DAVIS, W. S. Sistemas Operacionais. Ed. Campus.
    5. SHAY, W. A. Sistemas Operacionais. Ed. Makron Books
    6. MAZIERO, C. Sistemas Operacionais. On line: http://dainf.ct.utfpr.edu.br/~maziero/doku.php/so:livro_de_sistemas_operacionais

    Links
    1. Livro: COMPUTER ORGANIZATION AND. DESIGN FUNDAMENTALS. Examining Computer Hardware from the Bottom to the Top. David Tarnoff.
    2. Simulador de conceitos fundamentais de sistemas operacionais: http://sourceforge.net/projects/oscsimulator/.
    3. Programa simulador de arquiteturas de computadores, desenvolvido para ensino: http://www.cs.colby.edu/djskrien/CPUSim/.
    4. Escalonamento de processos no Linux 1. Escalonamento de processos no Linux 2. Escalonamento de processos no Linux 3.
    5. Escalonamento de processos no Windows.
    6. Padrão POSIX.
    7. Transição para discos rígidos de formato avançado com setores de 4K.
    8. Design and Implementation of the Second Extended Filesystem
    9. Linux File System (EXT2)
    10. Organização de diretórios no Unix.
    11. Microsoft TechNet: How NTFS works.
    12. Microsoft TechNet: How FAT works.
    13. Métodos de criptografia clássica.

    Curiosidades
    1. Artigo original com a proposta do algoritmo de escalonamento Rate Monotonic: Scheduling Algorithms for Multiprogramming in a Hard-Real-Time Environment (1973).
    2. Agora hackers estão invadindo software embarcado - o último caso foi um Jeep Cherokee (junho de 2015). Os hackers invadiram o sistema via uma conexão Wifi, acionaram o ar-condicionado, rádio e o limpador de para-brisa. Depois, o carro foi desligado na Interstate 64 (US) - a invasão foi um teste combinado - veja mais em http://www.wired.com/2015/07/hackers-remotely-kill-jeep-highway/. Ainda este ano, um homem foi preso pelo FBI por supostamente enviar comandos para os motores a partir do sistema de entretenimento de certas aeronaves frabricadas pela Boing e Airbus (veja em http://edition.cnn.com/2015/05/17/us/fbi-hacker-flight-computer-systems/. Boing e Airbus negam problemas.
    3. Interessante vídeo de um acidente com um caça JAS 39 Gripen, em 1993, com causa atribuída a falha no software de controle: hhttps://www.youtube.com/watch?v=4iToQ2FykoI
    4. Em 1998 a NASA lançou a missão Mars Climate Orbiter, que deveria estudar a atmosfera, o clima e as alterações na superfície de Marte, assim como agir como relay na comunicação com um módulo de superfície. Em 23 de setembro de 1999 a sonda deveria entrar em órbita do planeta vermelho. No entanto, o computador de bordo comandou uma órbita muito baixa que mergulhou a sonda na atmosfera, resultando na destruição da sonda. O responsável pelo desastre foi uma interface entre dois sistemas: um produziu uma saída com unidades compatíveis com o SI (Sistema International), em libras-segundo e os dados foram alimentados como entrada em outro sistem que utilizava o sistema internacional em Newtons-segundo.
    5. O primeiro lançamento do foguete Ariane 5 foi realizado em 4 de junho de 1996, com uma carga de 500 milhões de dólares. Após 37 segundos de vôo o foguete teve que ser destruido devido a completa perda de controle. Os projetistas de software reusaram porções do código do Ariane 4. Em uma operação de conversão de ponto flutuante, especificamente um número de 64 bits que representava a velocidade horizontal do foguete em relação à plataforma, convertido em um número de 16 bits. Esta conversão funcionou no Ariane 4, mas a velocidade do Ariane 5 era maior, o que levou os dois computadores responsáveis pela guiagem do foguete a travarem. Depois disso, o computador de bordo (que não deveria tormar decisões nesta fase do lançamento) começou a tentar controlar o foguete e o tirou do curso. Veja um artigo em http://www.around.com/ariane.html
    6. Em 1997 pousou em Marte uma sonda da NASA, na missão chamada Mars Pathfinder. Inicialmente, tudo parecia bem até que o sistema embarcado começar a apresentar problemas. O watch dog do sistema detectava problemas e produzia uma reinicialização geral de tempos em tempos. O problema foi debugado e solucionado. A questão central foi um problema de inversão de prioridades, levando a resultados inesperados e perda de deadlines das tarefa no escalonamento de tarefas pelo sistema operacional embarcado. Para obter mais informações: http://research.microsoft.com/en-us/um/people/mbj/Mars_Pathfinder/Mars_Pathfinder.html e http://en.wikipedia.org/wiki/Priority_inversion