CSE 120: Principles of Computer Operating Systems (2025)

Fall 2022

Instructor
Geoffrey M. Voelker(voelker@cs.ucsd.edu)
Lectures
Tu/Th 8–9:20am
Warren Lecture Hall 2001
TAs and Tutors
Jefferson Chien Yucheng Huang
Rajdeep Pinge Shuhua Xie
Eric Van Grinsven Manshi Yang
Kaiyuan Wang
Steven Wu
Discussion Sections
Fri 4–4:50am inSolis 107
Office Hours
Voelker (All Topics): Mon 3–4pm, Wed 4–5pm (CSE 3108)
Labs
CSE basement
Discussion Board
Piazza
Lab Hours
TBD
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 schedule for the course. We willupdate it as the quarter progresses.

DateLectureReadingsOptionalHomeworkProject
9/22Course IntroCH. 1, CH. 2
9/27Architectural SupportCH. 6Hardware events HW 1: Out PR 0: Out
9/29Processes CH. 3, CH. 4, CH. 5Linux context switch
9/30(Friday)PR 0: Due
10/4ThreadsCH. 26, CH. 27 PR 1: Out
10/6SynchronizationCH. 28, CH. 29HW 1: Due
HW 2: Out
10/11Semaphores and MonitorsCH. 30, CH. 31Languages and CVs
10/13Semaphores and MonitorsCH. 30, CH. 31Languages and CVs
10/18(No lecture, work on project)
10/20Scheduling and DeadlockCH. 7, CH. 8, CH. 32
10/21(Friday)PR 1: Due
10/22(Saturday)HW 2: Due
10/24Midterm Review5-6:20pm PCYNH 109
10/25Midterm Exam
10/26(Wednesday)HW 3: OutPR 2: Out
10/27Memory ManagementCH. 15,CH. 16,CH. 18
11/1PagingCH. 19,CH. 20
11/3Paging (cont'd)CH. 19,CH. 20
11/8Page ReplacementCH. 21,CH. 22,CH. 23
11/10File SystemsCH. 37,CH. 39Interesting behaviors
11/12(Saturday)PR 2: Due
11/14(Monday) HW 3: Due PR 3: Out
11/15File System ImplementationCH. 40Interesting behaviors
11/17ProtectionCH. 53,CH. 55 HW 4: Out
11/22Virtual Machines Appendix B
11/24Thanksgiving HolidayThanksgivingFood. Lots of it.Sleep. Lots of it.
11/29 Research Talk
11/30(Wednesday)HW 4: Due
12/1
12/2(Friday)PR 3: Due
12/6 Final Exam 8–11am WLH 2001

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, 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. You can use both sides of one 8.5x11" page of notes toassist you during the exams.

Homeworks

The course will have four homeworks, and I will post them as the quarter progresses. You may type or handwrite your answers, and we will use gradesource for submitting homeworks. To encourage timeliness, we will reduce homework grades by 20% foreach day that they are late. But if you run into a difficultsituation, let me know.

  • Homework 1 (Due 10/6)
  • Homework 2 (Due 10/22)
  • Synchronization Practice (Optional)
  • Homework 3 (Due 11/14)
  • Homework 4 (Due 11/30)

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 thematerial for the entire quarter. Below are sample exams to help youstudy.
  • Sample Midterm [Solutions]
  • Sample Final [Solutions]

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 and final exams, and the three projects using thefollowing weights:

  • Homeworks: 6%
  • Midterm: 28%
  • Final: 33%
  • Projects: 33%

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 circumstances that you feelcompel you to cheat, come to me first before you do so.

Supplemental Reading

The supplemental 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.

voelker@cs.ucsd.edu

CSE 120: Principles of Computer Operating Systems (2025)

FAQs

What are the principles of operating systems CSE 120? ›

CSE 120 Syllabus. This course covers the principles of operating systems. It emphasizes the basic concepts of OS kernel organization and structure, processes and threads, concurrency and synchronization, memory management, file systems, and communication.

What is CSE 120? ›

Introduction to computer architecture including examples of current approaches and the effect of technology and software.

What are the principles of computer operating systems? ›

Operating systems' five core functions are process management, memory management, file system management, device management, and security and access control.

What is operating system in CSE? ›

An operating system, or OS, is software that acts as the bridge between hardware and other software applications. They communicate with hardware via device drivers. Computer operating systems also act as coordinators of resources, enabling multitasking and keeping the system up and running.

What are the 5 principles of computer operation? ›

There are five basic types of computer operations: inputting, processing, outputting, storing and controlling. Computer operations are executed by the five primary functional units that make up a computer system.

What is CSE systems? ›

Computer Science Engineering (CSE)

It is a comprehensive study of computer systems, including software development, algorithm design, data structuring, and hardware systems.

What are the basic principles of computer system? ›

Ans. The basic working principle of a computer involves three main components: input, processing, and output. The computer receives data and instructions through input devices, processes the data using the CPU (Central Processing Unit), and then produces the results through output devices.

What is the basic concept of operating system in OS? ›

An operating system (OS) is the program that, after being initially loaded into the computer by a boot program, manages all of the other application programs in a computer. The application programs make use of the operating system by making requests for services through a defined application program interface (API).

What are the basics of OS computer system operation? ›

Main functions of operating system – booting the computer, managing system resources (CPU, memory, storage devices, printer, etc.), managing files, handling input and output, executing and providing services for application software, etc.

What are the 4 types of computer operating system? ›

Major types of OS are:
  • Simple Batch OS.
  • Multitasking/Time-shared OS.
  • Distributed OS.
  • Network OS.
  • Real-Time OS.

How to learn computer operating system? ›

What are some effective ways to learn operating system concepts and technologies?
  1. Choose a suitable operating system. ...
  2. Use online resources and courses. ...
  3. Practice with virtual machines and emulators. ...
  4. Join online communities and groups. ...
  5. Work on personal projects and challenges. ...
  6. Review and update your knowledge.
Sep 26, 2023

What are the operating principles? ›

Operating Principles, or as they are often referred to, a company's operating system, are essentially the way that organizations put their values into practice and get things done. Many companies rely on operating principles to get things done faster. They also influence culture and values.

What are the principles of CS? ›

These principles fall into seven categories: computation, communication, coordination, recollection, automation, evaluation and design (see the table at right for examples). Each category is a perspective on computing, a window into the knowledge space of computing. The categories are not mutually exclusive.

What are the principles of information security systems engineering? ›

Security engineering principles include, for example: (i) developing layered protections; (ii) establishing sound security policy, architecture, and controls as the foundation for design; (iii) incorporating security requirements into the system development life cycle; (iv) delineating physical and logical security ...

What are the principles of the computer system? ›

Ans. The basic working principle of a computer involves three main components: input, processing, and output. The computer receives data and instructions through input devices, processes the data using the CPU (Central Processing Unit), and then produces the results through output devices.

References

Top Articles
Latest Posts
Recommended Articles
Article information

Author: Dan Stracke

Last Updated:

Views: 6245

Rating: 4.2 / 5 (63 voted)

Reviews: 94% of readers found this page helpful

Author information

Name: Dan Stracke

Birthday: 1992-08-25

Address: 2253 Brown Springs, East Alla, OH 38634-0309

Phone: +398735162064

Job: Investor Government Associate

Hobby: Shopping, LARPing, Scrapbooking, Surfing, Slacklining, Dance, Glassblowing

Introduction: My name is Dan Stracke, I am a homely, gleaming, glamorous, inquisitive, homely, gorgeous, light person who loves writing and wants to share my knowledge and understanding with you.