====== Compromisso Pedagógico ====== * Disciplina: Sistemas Operacionais * Curso: Engenharia de Computação * Professor: Carlos A. Maziero (http://www.ppgia.pucpr.br/~maziero) ===== Objetivos ===== Estudar arquiteturas e mecanismos dos sistemas operacionais modernos, evidenciando os principais problemas enfrentados na construção de um sistema operacional e as soluções empregadas. Dar ao aluno uma visão clara do sistema operacional, de seus mecanismos internos, suas possibilidades e limitações. ===== Temas de estudo ===== * **Visão geral de sistemas operacionais**: objetivos, tipos, funcionalidades, estrutura interna, arquiteturas, mecanismos de hardware utilizados, visão geral de Unix e Linux. * **Gerência de tarefas**: contextos e processos, threads, escalonamento de tarefas. * **Comunicação entre tarefas**: tipos de comunicação, mecanismos intra- e inter-processos. * **Coordenação entre tarefas**: concorrência, condições de disputa, algoritmos básicos, semáforos, problemas clássicos, impasses. * **Estruturas de memória**: tipos de memória, endereços físicos e lógicos, estrutura interna de um processo, segmentação, paginação, compartilhamento, localidade de referências, memória virtual, algoritmos de substituição de páginas. * **Gerência de arquivos**: o conceito de arquivo, atributos e operações, formatos de arquivos, semânticas de acesso, compartilhamento, nomeação e caminhos, diretórios, sistemas de arquivos, caching, alocação de arquivos, gerência de espaço livre. * **Sistemas de entrada e saída**: dispositivos de entrada/saída, barramentos e interfaces, estratégias de interação, software de entrada/saída, drivers, principais sub-sistemas. ===== Metodologia ===== * **Teoria**: aulas expositivas, com análise e discussão dos temas abordados usando o quadro-negro e textos de apoio. * **Prática**: atividades (trabalhos e projetos) referentes aos temas abordados nas aulas teóricas. Consulte aqui as [[regras das atividades de laboratório]]. ===== Avaliações ===== Cada nota bimestral Bi será calculada a partir de uma prova Pi e das atividades de laboratório Li. As notas bimestrais serão assim calculadas: * Bi = 50% Pi + 50% Li * Média = (B1 + B2 + B3 + B4 ) / 4 A nota final será calculada através de uma prova final e de uma atividade de laboratório final: * Final = 50% PF + 50% LF A nota da prova final (PF) também será usada como **substitutiva** de quaisquer provas Pi que o aluno possa ter perdido ao longo do ano. ===== Recursos ===== * Quadro-negro, bibliografia impressa, Internet e servidor espec.ppgia.pucpr.br. ===== Bibliografia ===== * [[Livro de Sistemas Operacionais]] do professor. * //Sistemas operacionais – Conceitos e Aplicações//. Silberschatz, Galvin & Gane. Editora Campus, 2001. * //Sistemas Operacionais Modernos, 2a edição//. Tanenbaum. Ed. Pearson, 2003. * //C - A Linguagem de Programação Padrão ANSI//. Kerningham, Ritchie. Editora Campus, 1989. * //[[http://www.advancedlinuxprogramming.com|Advanced Linux Programming]]//. Mitchell, Oldham, Samuel. Editora New Riders, 2001. ===== Observações ===== * Podem ocorrer mudanças nesta proposta, com a devida divulgação prévia aos alunos.