Operating Systems Foundations
Objectives
Know: Services provided by operating systems (OS), their user and programming interfaces; OS abstractions for program execution and resource management; Principles of concurrent programming and process/thread coordination; Principles of design and internal organization of an operating system.
Apply: Relate the theoretical and practical aspects and improve the ability to perform practical laboratory work; Use the environment and tools to support the development and management of program execution; Develop programs that explore, at the operating system interface level (functions calls), different programming models involving concurrency, communication and synchronization between processes or threads.
General characterization
Code
11155
Credits
9.0
Responsible teacher
Paulo Orlando Reis Afonso Lopes, Pedro Abílio Duarte de Medeiros
Hours
Weekly - 6
Total - 67
Teaching language
Português
Prerequisites
It is recommended that students have successfully completed the IP and AC course units.
Bibliography
MAIN reference:
Remzi Arpaci-Dusseau, Andrea Arpaci-Dusseau, Operating Systems: Three Easy Pieces, http://pages.cs.wisc.edu/~remzi/OSTEP/
COMPLEMENTING references:
Modern Operating Systems, 4th Ed, A. Tanenbaum, H. Bos, Pearson, 2014
Computer Systems: A Programmer''s Approach, R.Bryant, D. O´Hallaron, Pearson, 3rd Ed 2015
The C Programming Language, B. W. Kernighan, D. M. Ritchie, 2nd Edition, Prentice Hall, 1988
Teaching method
The lectures present the main topics and discuss the most relevant questions. Students should, preferably before class, study the recommended bibliography.
Lab sessions are intended to enable the student to i) develop applications that use system calls in a controlled environment (virtual machines) where administration privileges are sometimes required and ii) use monitoring tools that require such elevated privileges.
Evaluation method
Grade of Theoretical-Practical Component (CompT)
CompT = 0,5 T1 + 0,5 T2
To succeed with mid-term tests or exam: CompT ≥ 8,5
3 individual small-sized work assignments; 1 group Project (P) for 2 students
Grade of the Laboratory Component : CompL = 0,4*(NTP1+NTP2+NTP3)/3 + 0,6*NP
To succeed: CompL ≥ 8,5
Subject matter
1. Introduction to operating systems (OS): System services: file and process as the main abstractions, system calls.
2. CPU management: support of process abstraction by the OS; lightweight processes: CPU scheduling algorithms.
3. Memory management: process address space; transformation of virtual addresses into real addresses using pages; virtual memory using pagination; page replacement algorithms.
4. Concurrent programming: fundamentals, communication and synchronization in shared memory and distributed memory. Lightweight Processes - pthreads API.
5. Input / output files and devices: file system organization and operations; characteristics of devices that support file systems; file system consistency. Management of input / output devices. Structure of a device driver.
6. Virtual Machines and Containers