CSE 120: Principles of Computer Operating Systems (2024)

Fall 2021

Lectures
Tu/Th 2–3:20pm (Zoom)
Discussion Session
Fri 4–4:50pm (Zoom)
Instructor
Yiying Zhang(yiying@ucsd.edu)
Office Hours: Wed 1:30pm - 3:30pm (Zoom)
TAs and Tutors
Jefferson Chien (TA) jkchien@ucsd.edu
Max Gao (TA) magao@ucsd.edu
Ruohan Hu(TA) r8hu@ucsd.edu
Yizhou Shan (TA) ys@ucsd.edu
Muyuan Chi (TA) muchi@ucsd.edu
Grant Jiang (Tutor) gjiang@ucsd.edu
Patrick Lin (Tutor) p9lin@ucsd.edu
Joshua Narezo (Tutor) jnarezo@ucsd.edu
Kyle Wang (Tutor) k5wang@ucsd.edu
Fengyuan Wu (Tutor) fwu@ucsd.edu
TA/Tutor Lab Hours
Calendar (Zoom and in-person)
Discussion Board
Piazza
Textbook
CSE 120: Principles of Computer Operating Systems (1)Remzi H. Arpaci-Dusseau and Andrea C. Arpaci-Dusseau
Operating Systems: Three Easy Pieces
Version 1.00 (Available free online!)

Course Objectives

This course covers the principles of operating systems. Itemphasizes the basic concepts of OS kernel organization and structure,processes and threads, concurrency and synchronization, memorymanagement, file systems, and communication. It is also a projectcourse, providing essential experience in programming withconcurrency, implementing and unmasking abstractions, working withinan existing complex system, and collaborating with other students in agroup effort.

Course Schedule

The following table outlines the tentative schedule for the course. We willupdate it as the quarter progresses.The optional readings include primary sources and in-depthsupplements for concepts in the class. Supplemental reading is foryour own interest — the readings are not required, nor will you betested on the material. Note that some of the links to the documentspoint to the ACM Digital Library. UCSD has a subscription to the ACMDigital Library, so you will need to use a web browser on campus toaccess them.

DateLectureReadingsOptionalHomeworkProject
9/23Course IntroCH. 1, CH. 2The Structure of the 'THE'-Multiprogramming System
The UNIX Time-Sharing System
HW 1: Out PR 0: Out
9/28Interaction between hardware, OS, and applicationsCH. 6Linux context switch
A Case Against (Most) Context Switches (HotOS'21)
9/30ProcessesCH. 4, CH. 5A fork() in the road (HotOS'19)
10/5ThreadsCH. 26, CH. 27POSIX Threads Programming
Illustrated Tales of Go Runtime Scheduler
C++ Coroutine Tutorial
PR 1: Out
10/7SynchronizationCH. 28, CH. 29RCU Usage In the Linux Kernel: One Decade Later (Linux RCU lock)HW 1: Due
HW 2: Out
PR 0: Due
10/12SemaphoresCH. 31
10/14Conditional Variables, Concurrency BugsCH. 30, CH. 32Monitors: An Operating System Structuring Concept
Understanding Real-World Concurrency Bugs in Go (ASPLOS'19)
10/19CPU SchedulingCH. 7, CH. 8Lottery Scheduling (OSDI'94)
Shenango: Achieving High CPU Efficiency for Latency-sensitive Datacenter Workloads (NSDI'19)
10/21Midterm ReviewPR 2: Out
10/22PR 1: Due
10/26Midterm Exam
10/28Memory Management OverviewCH. 15,CH. 16,HW 2: Due
HW 3: Out
11/2Paging (Annotated Slides)CH. 18,CH. 19,CH. 20
11/4TLB, Swapping (Annotated Slides)CH. 21,
11/9Swapping ctd, Memory Allocation (Annotated Slides)CH. 21,
11/11Veteran's Day. No Class.PR 3: Out
11/16Page Replacement (Annotated Slides)CH. 22,
11/18Storage Devices, File System Interface (Annotated Slides)CH. 37,CH. 39,A File is Not A File (SOSP'11)HW 4: Out
11/19PR 2: Due
11/23Disk Layout (Annotated Slides)CH. 40HW 3: Due
12/2File System Implementation and Reliability (Annotated Slides)CH. 41CH. 42IRON File System (SOSP'05)
12/3 (Annotated Slides)
12/7Data Centers and Clouds (not in exam!) (Annotated Slides) CH. 48Berkeley View of Cloud Computing HW 4: Due
PR 3: Due
12/9 Final Exam 3pm - 6pm

Course Organization

The course is organized as a series of lectures by the instructor,discussion sections by the TAs, reading, homework, and projectassignments, and exams:

  • Lectures: The lectures present the core of the material.
  • Sections: The discussion sections aregiven by the TAs to answer questions about the lecture, textbookreadings, homework assignments, and project assignments.
  • Readings: The readings in the textbook provide preparationand a reference for the lectures. Note, however, that they arenot a substitute for the lectures.
  • Homeworks: There are approximately four homework assignments withquestions taken from the textbook and other materials. The homework assignments reinforce the readings and lectures.
  • Projects: There are three programming projects (one of them is optional), all usingthe Nachos instructional operating system.
  • Exams: There are two exams, a midterm exam in the middle ofthe quarter and a final exam at the end of the quarter. The examswill cover the material presented in lecture, the homeworks, and theprojects.

Homework

The course will have four homeworks. I will post them as the quarter progresses. You will submit all your homework electronically via Canvas. We will reduce homework grades by 20% for each day that they are late.

Due to extensive copying on homeworks in the past, I have changed how homeworks are graded. As long as you submit a technical answer related to the question, you will get full credit for the question. The goal of the homeworks is to give you practice learning the material. The homework questions both supplement and complement the material from lecture and in the project, and you will also find the homework questions to be useful for practicing for the exams. We will post solutions to all homeworks after they are submitted, and you can use them for studying as well. But, even with the solutions, the amount you learn from the homeworks will be directly correlated with your effort working on them.

I encourage you to collaborate on the homeworks: You can learn alot from your fellow students. Collaboration consists of discussingproblems with other students and independently writing your ownanswers to the problems based upon those discussions. As a rule ofthumb, you should be able to discuss a homework problem in the hallwith others, go home, and then write up your answer to the problem onyour own.

Projects

The course has one tutorial project and three programming projectsusing the Nachos instructional operating system.

  • Project page

Exams

The course has two exams, a midterm and a final. The midterm willcover the first half of the class, and the final will cover thesecond half of the class.

Discussion Sections

Discussion sections answer questions about the lectures,homeworks, projects, and programming environment. They may alsosupplement the lectures with additional material.

Grading

Your grade for the course will be based on your performance on thehomeworks, midterm exam, final exam, and projects with one of the following two calculations. You can decide which of them to choose towards the end of the quarter.

If you choose to do only the first two projects:

  • Homeworks: 6%
  • Midterm: 25%
  • Final: 35%
  • Projects: 34%
If you choose to do all the three projects:
  • Homeworks: 6%
  • Midterm: 20%
  • Final: 30%
  • Projects: 44%

The academichonesty guidelines outlined by Charles Elkan apply to this course.I urge you to resist any temptation to cheat, no matter how desperatethe situation may seem. If you are in circ*mstances that you feelcompel you to cheat, come to me first before you do so.

yiying@ucsd.edu

CSE 120: Principles of Computer Operating Systems (2024)

References

Top Articles
Latest Posts
Article information

Author: Prof. Nancy Dach

Last Updated:

Views: 6237

Rating: 4.7 / 5 (57 voted)

Reviews: 88% of readers found this page helpful

Author information

Name: Prof. Nancy Dach

Birthday: 1993-08-23

Address: 569 Waelchi Ports, South Blainebury, LA 11589

Phone: +9958996486049

Job: Sales Manager

Hobby: Web surfing, Scuba diving, Mountaineering, Writing, Sailing, Dance, Blacksmithing

Introduction: My name is Prof. Nancy Dach, I am a lively, joyous, courageous, lovely, tender, charming, open person who loves writing and wants to share my knowledge and understanding with you.