Sistemas Operacionais Embarcados TE355
Avisos
- Bem vindo à página da disciplina TE355 Sistemas Operacionais Embarcados / Primeiro semestre de 2019.
- Notas Finais.
Lista de Temas Tratados nas Aulas
Ficha 1.
Ficha 2
- Arquitetura básica de computadores. Processador. Barramento. Interrupções. Memória. Dispositivos de E/S.
- Organização básica do sistema operacional. Histórico de evolução dos sistemas operacionais e hardware.
- Escalonamento de processos. Sistemas batch. Sistemas de tempo compartilhado. Algoritmos de escalonamento. Princípios de escalonamento em sistemas de tempo real.
- Visualização de processos e comandos do sistema Unix.
- Concorrência e sincronização de processos. Problemas de concorrência. Alocação de recursos e deadlocks.
- Semáforos. Implementação em sistemas Unix.
- Gerência de Memória.
- Sistema de arquivos:
- Hardware de disco, bloco, cilindro, cabeças de leitura.
- Atributos de arquivos em sistemas Unix e Windows
- FAT - File Alocation Table
- Implementação com Nós I
- NTFS (NT File System)
- Cluster vs. bloco físico, algoritmo do elevador.
- Segurança: princípios de criptografia. Armazenamento de senhas.
- 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
- Prova 1: 01/10
- Prova 2: 26/11
- Exame Final: 10/12
Especificação de trabalhos
Desafio !!!!
Considere a seguinte mensagem criptografada utilizando Cifras Polialfabéticas (em hexadecimal):
AA D8 ED C2 D5 AE BB 76 76 81 CE DC 8E E3 B6 AA 76 B8 C3 D7 D8 C2 9B AE BC B9 A6 B7 D2 D5 CD 9B B7 B8 BB B9 B9 96 D5 CE D3 BB B2 AC A6 C2 CA A1 CD CF B7 C F0 A6 B8 CA A1 C2 DD 76 AE BC B5 B5 2C 1B D0 9B AE B6 76 7A 81 CD D9 8E E1 AE BD AE B2 B6 DB E3 8E D2 AE 76 7A 7E 8B A0 A1 D1 CF BB AA 76 AA C7 DD E9 C5 CF BB 76 93 BA C4 D2 E8 C6 E0 76 AE 76 98 B5 DD E9 D3 DC B8 76 B9 B7 C3 DC E7 C6 D5 BE B2 B7 A9 C3 96 D9 8E DE B8 BC BD AA C6 D2 E3 D3 DB AE B7 BD AA 81 D9 D5 D3 CF 76 B8 76 AA C7 D9 D5 24 15 B8 76 B2 B3 C8 CE E6 C6 E1 BD AE B5 A6 C6 97 A1 A6 DB 76 7B 79 72 B8 CE A1 CF DD BF AE B6 A7 C6 D8 A1 C5 D3 76 7B 79 76 8D 95 A1 C2 9B BC B8 B7 A9 B5 96 E7 D0 DB B8 BE 76 79 86 96 D5 CF DD BC 75 76 77 81 D6 D9 D4 D3 BC 76 AE 72 85 9E A1 C5 D7 AA BC 76 AA C1 96 E3 D1 D3 BB AA C EC B5 D8 A2
Quem descobrir a mensagem e a chave terá 20 pontos na média. Deve apresentar a estratégia usada diretemente para o professor até 13/12/2019.
Exemplos apresentados em aula
Listas de Exercícios
Referências
- TANENBAUM, A. S. Sistemas Operacionais Modernos. Ed. Pearson Prentice-Hall.
- SILBERCHATZ, A., J. L. Peterson. Sistemas Operacionais . Ed. Pearson Prentice-Hall.
- TANENBAUM, A. S. e A.S. Woodhull. Sistemas Operacionais - Projeto e Implementação. Ed. Bookman.
- DAVIS, W. S. Sistemas Operacionais. Ed. Campus.
- SHAY, W. A. Sistemas Operacionais. Ed. Makron Books
- MAZIERO, C. Sistemas Operacionais. On line: http://dainf.ct.utfpr.edu.br/~maziero/doku.php/so:livro_de_sistemas_operacionais
Links
Curiosidades
- Primeiro acidente fatal em carro com sistema semiautônomo.
- Agora hackers estão invadindo software embarcado - o último caso foi um Jeep Cherokee (junho de 2017). 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/2017/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/2017/05/17/us/fbi-hacker-flight-computer-systems/. Boing e Airbus negam problemas.
- 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
- 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.
- 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
- 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
- Artigo original com a proposta do algoritmo de escalonamento Rate Monotonic: Scheduling Algorithms for Multiprogramming in a Hard-Real-Time Environment (1973).