Lecture: | Mon 6:00P - 8:20P Weaver CIWW 101 | |
Instructor: | Hubertus Franke, frankeh@cs.nyu.edu | |
TAs/Graders: |
Salil Kapur,
sk6829@nyu.edu
| |
Office Hours: and TA Assignment |
[0-9] Hubertus Franke: Mon 8:20 - 9:20 PM after class or if private (Room Weaver 320) [A-Z] Salil Kapur: Thu 3:30 - 5:00 PM (13th floor lounge) You can go to any office hour, but grading related stuff you need to talk to your assigned TA. | |
Prerequisites: |
Common CS knowledge and programming skills. Four labs consisting of approximately 500-600 lines of code each (give and take). Expect at least 20hrs per lab, typically spread over 3 weeks. This class is designated as a class to emphasize programming in C/C++ and as most operating systems are written in C this is a perfect opportunity to pick this skill up. As a result all labs will have to be coded in C/C++. Learning how to become proficient in C/C++ is one side goal of this class. Expect to learn C/C++ through self study over the first 3 weeks. If necessary, an extra session will be provide to get you up to speed, which will take place after class ( > 8:20PM ). | |
Text book: |
Author: Andrew Tannenbaum Title: Modern Operating Systems Edition: 4th (you will also survive 3rd) Publisher: Prentice Hall ISBN-13: 978-0-12-3591720 or 978-0-13-6006663-2 ISBN-10: 0-13-359172X or 0-13-600663-9 |
Examples will be from Unix/Linux. Programming assignments will be based on C or C++ as Operatings Systems are implemented that way. You will initially not be required to have C or C++ knowledge, but after the first of four labs you will have to move over to C/C++. Each of the four labs is approximately 600 lines of code.
This course does not assume that you have taken an Operating Systems course as an undergraduate, or that you have had extensive experience working with one. In fact, if you have taken such a course or have a fair amount of practical experience with OS internals, this course is probably too elementary for you. Please take a look at the course schedule to get a sense of the topics that will be covered: if you can explain most of the terms contained there, you are likely looking for a more advanced course. We will NOT be "hacking" on an operating system but will have lab assignments that deal with the fundamental elements such as different process schedulers and memory management algorithms and I/O schedulers. It will allow you to get and experiment with the concept rather than spending endless hours debugging tedious operating system code.Grades are based on the labs, the midterm and final exam, each being important.
The weighting will be:
Lab Assignments | 60% |
Final | 40% |
Date | Topic | Handouts | Readings | Assignments |
5/22 |
Introduction: Computer System Architectures (what does the OS manage) |
Overview Introduction |
Chapter 1 |
Start Learning C/C++ Lab1 |
6/5 |
Introduction: History and Basics and Processes |
Processes and Threads |
Chapter 2 |
|
6/12 |
Processes and Threads |
Processes and Threads |
Chapter 2.1/2.2 |
lab2 |
6/19 |
Scheduling |
Scheduling |
Chapter 2.4 |
|
6/26 |
Concurrency |
Concurrency |
Chapter 2.3 |
|
7/3 |
Memory Management |
Memory Management |
Chapter 3 |
Lab3 |
7/10 |
I/O-1 |
I/O |
Chapter 5 | 7/17 |
I/O-2 |
I/O |
Chapter 5 | Lab 4 |
7/24 |
File Systems |
FileSystems |
Chapter 4 |
7/31 |
Networking/AdvancedTopics/Review |
Networking AdvancedTopics |
No book chapters (only networking in finals) |
8/7 |
FINAL (6:00 - 8:10) |
Several labs (programming assignments) across the semester will provide practical implementations of operating system concepts such as processor scheduling and memory management. These assignments are accepted in C or C++.
You may solve lab assignments on any system you wish, but ...
Good methods for obtaining help include
Graduate cs.nyu.edu courses: | http://cs.nyu.edu/webapps/summer2017/courses |
Graduate cs.nyu.edu schedule: | http://cs.nyu.edu/webapps/summer2017/Graduate/courses |
Academic integrity policy: | http://cs.nyu.edu/web/Academic/Graduate/academic_integrity.html |