CS 378 – Multicore Operating Systems Implementation

Time: Monday and Wednesday, 11am - 12.30pm
Location: GDC 2.506
Instructor: Simon Peter
TA: Cody Littley
Office hours: Wednesday, 2pm - 3pm (Instructor) in GDC 6.430, Tuesday & Thursday, 11.30am - 12.30pm (TA) in GDC 2.506

This course is intended to give students a thorough understanding of design and implementation issues for modern operating systems.

We will cover key design issues in implementing an operating system, such as memory management, inter-core synchronization, scheduling, protection, inter-process communication, device drivers, and file systems, paying particular attention to system designs that differ from the traditional monolithic arrangements of Unix/Linux and Windows.

The goals of the course are:

Prerequisites: This course builds on the computer systems course (CS 439 or equivalent), the contents of which will be assumed knowledge. Proficiency in C programming is assumed.

Project: The course is structured around a significant project which builds up, over the course of the semester, a fairly complete operating system for the ARM-based Pandaboard hardware. The OS is based on the Barrelfish open-source multikernel originally developed at ETH Zurich in collaboration with Microsoft Research.

Lectures: Where practical, lectures will align with project-related material (to provide more background, knowledge, and time in completing the practical work), and also the prior research ideas that have informed the design of the aspects of Barrelfish relevant to the project milestones. They will also provide comparisons between Barrelfish and other systems such as Unix, Windows, and microkernels like L4.

Discussion: Instead of email, we will use Piazza for class and project discussion and Q&A. Please subscribe to Piazza as soon as possible if you're attending this lecture. Click here to go to the enrollment page.

Readings: There is no textbook for this course, as no published book covers the material in sufficient depth. Instead, reading for the course will consist of research papers and system documentation; this will be posted on the Piazza site in due course.

Grading: Grading will be based solely on the project. Throughout the class, students will be working in groups of 3-4 on the project. The project is sub-divided into milestones that are assigned and graded in weekly intervals (some milestones are multi-week). Each milestone will be individually graded and the final grade is a composition of these grades.

Class Schedule: The class schedule is available here.

Independent Inquiry: This course carries the Independent Inquiry flag. Independent Inquiry courses are designed to engage you in the process of inquiry over the course of a semester, providing you with the opportunity for independent investigation of a question, problem, or project related to your major. You should therefore expect a substantial portion of your grade to come from the independent investigation and presentation of your own work.

Students with disabilities may request appropriate academic accommodations from the Division of Diversity and Community Engagement, Services for Students with Disabilities, 512-471-6259, http://www.utexas.edu/diversity/ddce/ssd/.

Resources