Winter Semester 2021-22

Lecture: Operating Systems

Content

  • Introduction to Operating Systems (OS) – Role, purpose and design issues
  • Processes and Threads – OS structures, process control, abstractions, kernel/user modes and operations, context switching, interrupts
  • Inter-Process Communication – Message passing IPC, RPC, layers, interfaces, hierarchies
  • Coordination: Deadlocks – Process coordination, critical sections, deadlock characterization, deadlock detection and recovery, deadlock avoidance
  • Scheduling/Resource Management – Task ordering, preemptive and non-preemptive scheduling, schedulers and policies, OS implementations
  • Concurrency: Races, Mutual Exclusions – Critical sections, races, spin locks, synchronization
  • Programming Abstractions: Semaphores – Semaphores, Monitors
  • Memory Management – Storage structures, management/replacements approaches, virtual memory, paging, caching, segmentation
  • I/O – Device management, drivers, segmentation, interrupt handling, DMA
  • File systems – File systems requirements, design and implementation, file structures, directories, naming, partitions, virtual file systems
  • Fault Tolerance/Resilience – Fault types, fault handling approaches, reliable message delivery, OS reliability and availability, security issues
  • Embedded/RT OS – Memory/disk/performance management, recovery, fault-tolerances, real-time aspects
  • Distributed OS – Distributed computation and communication abstractions, synchronization, coordination, consistency
  • Virtual Machines – Purpose and types of virtualization, virtual file systems, Hypervisors

Literature

Operating Systems: Three Easy Pieces (v0.92); Remzi H. Arpaci-Dusseau & Andrea C. Arpaci-Dusseau; Arpaci-Dusseau Books

Modern Operating Systems, 4th Edition; Andrew S. Tanenbaum & Herbert Bos; Pearson; ISBN-13: 978-0133591620

Operating System Concepts, 9th Edition; Abraham Silberschatz, Peter B. Galvin, Greg Gagne; John Wiley & Sons; ISBN-13: 978-1118093757

Recommended prerequisite modules:

  • Algorithmen und Datenstrukturen
  • Funktionale und objektorientierte Programmierung
  • Rechnerorganisation

Please check Moodle for more information:

https://moodle.informatik.tu-darmstadt.de/course/view.php?id=968