====== CI-1215 - Cronograma 2023/1 ======
* As atividades indicadas com :!: serão avaliadas.
* Os projetos são **individuais**.
* Os projetos devem ser entregues usando o [[http://moodle.c3sl.ufpr.br|Moodle]].
* Entrega em ± **2 semanas** (confira os prazos no Moodle).
* Somente projetos defendidos serão considerados.
* Leia com atenção as [[teaching:Regras das Atividades de Laboratório]].
=== Links úteis ===
* [[https://bbb.c3sl.ufpr.br/b/car-chu-evg|Sala online]] (BBB do DINF/UFPR)
* [[socm:start|Livro-texto da disciplina]]
=== Regras de avaliação ===
A média final da disciplina é calculada com as notas das provas e dos projetos solicitados (entre 0 e 100), da seguinte forma:
Mprova = (Pv1 + Pv2) / 2
Mproj = (P0 + P4 + P6 + P9 + P12 + P13) / 5 // sim, é sobre 5 e não sobre 6
Media = (Mprova + Mproj) / 2
----
=== 21/3: Aula 1 ===
Conteúdo teórico:
* Apresentação da disciplina
* Conceitos básicos
=== 23/3: Aula 2 ===
Conteúdo teórico:
* Estrutura de um SO
Projeto:
* Visão geral do [[PingPongOS]]
* :!: P0: [[Biblioteca de filas]]
=== 28/3: Aula 3 ===
Conteúdo teórico:
* Arquiteturas de SOs
Leitura complementar:
* [[http://www.minix3.org/docs/login-2007.pdf|Minix 3 (microkernel)]]
* [[http://queue.acm.org/detail.cfm?id=2566628|Unikernels]] (exemplos: [[https://mirage.io/|MirageOS]] e [[https://osv.io/|OSv]])
=== 30/3: Aula 4 ===
Conteúdo teórico:
* O conceito de tarefa
Projeto:
* P1: [[Trocas de contexto]]
* P2: [[Gestão de tarefas]]
=== 04/4: Aula 5 ===
Conteúdo teórico:
* Implementação de tarefas - processos
* Exemplos: [[Criação de processos]]
* [[unix:Gestão de processos]]
=== 06/4: Aula 6 ===
Conteúdo teórico:
* Implementação de tarefas - threads
* Exemplos: [[Criação de threads]]
Projeto:
* P3: [[Dispatcher]]
=== 11/4: Aula 7 ===
Conteúdo teórico:
* Escalonamento de tarefas
=== 13/4: Aula 8 ===
Conteúdo teórico:
* Escalonamento de tarefas (cont.)
* Comunicação entre tarefas
Projeto:
* :!: P4: [[Escalonador por prioridades]]
Leitura complementar:
* [[https://man7.org/linux/man-pages/man7/sched.7.html|Manpage de escalonamento do Linux]]
* [[https://www.trustedreviews.com/news/what-is-the-intel-thread-director-4158842|Intel Thread Director]]
=== 18/4: Aula 9 ===
Conteúdo teórico:
* Mecanismos de comunicação
* Exemplos: {{:so:mqrecv.c|}}, {{:so:mqsend.c|}}, {{:so:shm.c|}}
Leitura complementar:
* [[https://docs.microsoft.com/en-us/windows/win32/winmsg/messages-and-message-queues|Windows messaging]]
Projeto:
* P5: [[Preempção por tempo]]
=== 20/4: Aula 10 ===
Conteúdo teórico:
* Coordenação entre tarefas
* O problema da [[exclusão mútua]]
=== 25/4: Aula 11 ===
Conteúdo teórico:
* Mecanismos de coordenação
Leitura complementar:
* [[https://docs.microsoft.com/en-us/windows/win32/sync/using-semaphore-objects|Semáforos em Windows]]
* [[https://docs.oracle.com/javase/7/docs/api/java/util/concurrent/Semaphore.html|Semáforos em Java]]
=== 27/4: Aula 12 ===
Conteúdo teórico:
* Problemas clássicos
* Exemplos: {{ :so:filosofos.c |}}
Leitura complementar:
* Exercícios sobre concorrência do [[http://greenteapress.com/wp/semaphores|Pequeno Livro de Semáforos]]
* //Reader/Writer locks// em [[https://pubs.opengroup.org/onlinepubs/009695399/functions/pthread_rwlock_init.html|POSIX]], [[https://docs.microsoft.com/en-us/windows/win32/sync/slim-reader-writer--srw--locks|Windows]] e [[https://docs.oracle.com/javase/10/docs/api/java/util/concurrent/locks/ReadWriteLock.html|Java]]
=== 2/5: Aula 13 ===
Conteúdo teórico:
* Impasses
Projeto:
* :!: P6: [[Contabilização]]
=== 4/5: Aula 14 ===
Laboratório:
* [[Exercícios de coordenação]] (aula prática no Lab 1-2)
=== 9/5: Aula 15 ===
Conteúdo teórico:
* Hardware de entrada/saída
Leitura complementar:
* Exemplo de I/O: [[https://wiki.osdev.org/CMOS#Getting_Current_Date_and_Time_from_RTC|Leitura do RTC (Real-Time Clock)]]
Projeto:
* P7: [[Tarefa main]] (obsoleto, não fazer)
* P8: [[Tarefas suspensas]]
=== 11/5: Aula 16 ===
* :!: Prova 1 (introdução, gestão de tarefas, interação entre tarefas, PingPongOS)
=== 16/5: Aula 17 ===
Conteúdo teórico:
* Software de entrada/saída (capítulo 20 do livro-texto, assistir vídeo)
=== 18/5: Aula 18 ===
Conteúdo teórico:
* Discos (capítulo 21 do livro-texto, assistir vídeo)
Leitura complementar:
* [[https://youtu.be/wtdnatmVdIg|How do Hard Disk Drives Work?]] (vídeo)
Projeto:
* :!: P9: [[Tarefas dormindo]]
=== 23/5: Aula 19 ===
Conteúdo teórico:
* O conceito de arquivo
=== 25/5: Aula 20 ===
Conteúdo teórico:
* Uso de arquivos
Leitura complementar:
* [[https://gavv.net/articles/file-locks/|File locks in Linux]]
* [[https://learn.microsoft.com/en-us/windows/win32/fileio/locking-and-unlocking-byte-ranges-in-files|File locks in Windows]]
* Exemplo: acesso a arquivo por mapeamento em memória: {{ :so:fread-mmap.zip |}}
Projeto:
* P10: [[Semáforos]]
* P11: [[Uso de semáforos]]
=== 30/5: Aula 21 ===
Conteúdo teórico:
* Sistemas de arquivos
=== 1º/6: Aula 22 ===
Conteúdo teórico:
* Sistemas de arquivos (cont.)
Projeto:
* :!: P12: [[Filas de mensagens]]
=== 6/6: Aula 23 ===
Conteúdo teórico:
* Diretórios e atalhos
=== 8/6: recesso (feriado) ===
=== 13/6: Aula 24 ===
Conteúdo teórico:
* Hardware de memória
Projeto:
* :!: P13: [[Gerente de disco]]
=== 15/6: Aula 25 ===
Conteúdo teórico:
* Hardware de memória (cont.)
* Exemplos de localidade de referência: {{so:tlb-lin.c}}, {{so:tlb-col.c}}
* Uso da memória
=== 20/6: Aula 26 ===
Conteúdo teórico:
* Uso da memória (cont.)
* Localização de variáveis e constantes: {{:so:variaveis.c|}}
* Alocação de memória
Leitura complementar:
* [[https://blog.nsogroup.com/a-tale-of-two-mallocs-on-android-libc-allocators-part-1-dlmalloc|Funcionamento do alocador DLMalloc]]
=== 22/6: Aula 27 ===
Conteúdo teórico:
* Paginação em disco
=== 27/6: Aula 28 ===
Conteúdo teórico:
* Paginação em disco (cont.)
* Tópicos em gerência de memória
* Exemplo de //thrashing//: {{so:thrash.c}}
=== 29/6: Aula 29 ===
* :!: Prova 2 (gestão de entrada/saída, gestão de arquivos, gestão da memória, PingPongOS)
=== 6/7: Exame final ===
* :!: Mesmo conteúdo das provas 1 e 2