Course
Operating Systems and Systems Programming (DAT320)
The course gives an introduction to operating systems, how to implement them, and how to program against them efficiently, with particular focus on thread programming and synchronization between threads within a program.
Dette er emnebeskrivelsen for studieåret 2025-2026
Fakta
Emnekode
DAT320
Vekting (stp)
10
Semester undervisningsstart
Autumn
Undervisningsspråk
English
Antall semestre
1
Vurderingssemester
Autumn
Content
The course gives an introduction to operating system architectures and mechanisms for resource management in computer systems. Specific topics covered: Virtualization: the process abstraction, processor scheduling, memory management, address spaces, address translation, caching and virtual memory. Concurrency: threads, concurrency, parallelism, synchronized access to shared data, locks, condition variables, semaphores and channel-based synchronization. Persistence and Networking: File systems, networking programming, distributed systems, network file system. Operating System security.
The course includes programming assignments covering the main concepts of the course, such as memory management, scheduling, concurrency, parallelism and synchronization techniques, and tools to analyze and debug various aspects of such applications. The programming language used in this course is primarily Go (golang) along with some C and Python.
Learning outcome
Knowledge:
- How operating system work
- How to protect the operating systems from malicious software
Skills:
- Be capable of programming against the operating system API
- Be capable of programming parts of an operating system
- Be capable of implementing simple mechanisms for resource management
- Know how to program with threads
- Know how to exploit virtualization for resource management
General compentancy:
- Know important general principles for resource management for computer systems.
Forkunnskapskrav
Anbefalte forkunnskaper
Exam
Form of assessment | Weight | Duration | Marks | Aid |
---|---|---|---|---|
Written exam | 1/1 | 4 Hours | Letter grades | None permitted, Approved, basic calculator |
Written digital exam
Vilkår for å gå opp til eksamen/vurdering
Approval requires submitting your solution to our system for automated evaluation, followed by in-lab approval. The students must complete 6 assignments. All programming assignments must be passed to sit for the exam.
If a student fails to pass all the mandatory programming assignments, then the student must redo all assignments again the next time the subject is taught.
Completion of mandatory lab assignments are to be made at the times and in the groups that are assigned. Absence due to illness or for other reasons must be communicated as soon as possible to the laboratory personnel. One cannot expect that provisions for completion of the lab assignments at other times are made unless prior arrangements with the laboratory personnel have been agreed upon.
Failure to complete the assignments on time or not having them approved will result in being barred from sitting for the exam.
Fagperson(er)
Course coordinator:
Nejm SaadallahCourse teacher:
Nejm SaadallahHead of Department:
Tom RyenMethod of work
Overlapping
Emne | Reduksjon (SP) |
---|---|
Operating Systems (BID200_1) , Operating Systems and Systems Programming (DAT320_1) | 5 |