Instructor: Jim Teresco, TCL 304, 597-4251
Electronic mail: domain:, username: terescoj
Class Web:
Class Hour: Tuesday/Thursday 9:55-11:10, TCL 206
Lab Meetings: Self-scheduled
Office Hours: Tuesday 8:45-9:45, Wednesday 11:00-12:00, Friday 1:00-2:00


Everything on this syllabus is subject to change. Changes will be announced in class and updated in the online version of the syllabus.

Course Objectives

The course is about the design and implementation of operating systems. We will consider

We will use Unix-like operating systems as a model to help understand operating system concepts and consider other operating systems of historical or modern interest at times as well.



The required text for the course is Operating Systems Concepts, Seventh Edition (John Wiley & Sons, Inc. ISBN 0-471-69466-5) by Silberschatz, Galvin, and Gagne. This is available from Water Street Books. Be sure to get the correct edition, as this is a brand new book. This has the advantage of being very up-to-date, but the disadvantage that few, if any, used copies exist so far.

You may also find it useful to purchase a Unix reference of your choice. Unix references will be available for your use in the lab.


Students are expected to attend class and participate in discussions. Come to class prepared. Assigned readings from the textbook are listed on the lecture and reading schedule. Additional readings may be given occasionally. Lectures will assume you are familiar with the material in the readings.


Labs in this course do not meet formally. You will have lab assignments approximately weekly.

Lab assignments will have a written and/or a programming component. The number of points available will vary with the complexity of the assignment. Most if not all lab programming assignments will be designated as "laboratory programs." See the honor code guidelines at the end of this document for details. Programs will be graded on design, documentation, style, correctness, and efficiency. Answers to questions included in lab assignments are expected to be well-written.

You may develop programs for the lab assignments anywhere (in the lab, your own computers, etc.) but grading will be done using the Computer Science FreeBSD systems unless otherwise specified. It is your responsibility to ensure that your program works on the grading platform. You will have 24-hour access to the lab with your Williams ID.

All assignments and projects are to be submitted electronically using the turnin utility unless otherwise specified. Please submit writtren work in portable formats (plain text where appropriate, PDF or postscript when needed, avoid Word documents). If in doubt about a file format, please check with me first. Keep a copy of all submissions for yourself.

Term Project

In addition to the labs, there will be a term project due near the end of the semester. You will choose your own topics for this project. Some projects will require significant programming, while others will not. All projects must include a formal proposal, a formal research paper, and a brief presentation to the class during the last week of the semester.


There will be a midterm exam and a final exam. Both will be take-home exams. The midterm will take place right after spring break. The final exam will be available from the Registrar's office during reading period and exam week. Details about the exams will be made available later in the semester.


Grades will be based on the labs, the term project, and the two exams. As this is a project course, the majority of the grade is based on labs and the term project.

Breakdown: Scale:
Labs 40% A+ >= 97% A >= 93% A- >= 90%
Midterm Exam 15% B+ >= 87% B >= 83% B- >= 80%
Term Project 25% C+ >= 77% C >= 73% C- >= 70%
Final Exam 20% D+ >= 68% D >= 65%
E < 65%

Grades for individual assignments and exams are not scaled. Any scaling deemed appropriate will take place at the end of the semester by adjusting the above thresholds. Thresholds may be adjusted downward (thereby raising grades) but will never be adjusted upward.

Unless otherwise specified, lab assignments may be turned in with a penalty computed as 1.08h%, where h is the number of hours late. Extensions will only be granted in serious situations and must be arranged through the Dean's office. You can find a C program that prints out a table of the late penalties here. Work turned in after solutions have been made available cannot receive credit.

Computer Science Department Honor Code Guidelines

The Honor Code as it applies to non-programming assignments is outlined in the Student Handbook.

For programming assignments in Computer Science courses, the honor code is interpreted in very specific ways. When a program is assigned, your instructor will identify it as a "practice," "test," "laboratory," or "team" program. The Honor Code applies differently to each with respect to collaboration or assistance from anyone other than the TAs or instructors:

Practice Programs. These are provided to help you gain an understanding of a topic, and are not graded. Guideline: Help on these programs is unrestricted.

Test Programs. Any assignment designated as a test program is to be treated exactly as a take-home, open-book test. You are allowed to read your textbook, class notes, and any other source approved by your instructor. You may not consult anyone other than your instructor. The instructor encourages the asking of questions, but reserves the right not to answer, just as you would expect during an exam. Guideline: Any work that is not your own is considered a violation of the honor code.

Laboratory Programs. Laboratory programs are expected to be the work of the individual student, designed and coded by him or her alone. Help locating errors is allowed, but a student may only receive help in correcting errors of syntax; help in correcting errors of logic is strictly forbidden. Guideline: Assistance from anyone other than the TAs or instructors in the design or coding of program logic will be considered a violation of the honor code.

Team Programs. Team programs are laboratory or test programs to be worked on in teams of two or more students. You are allowed to discuss team programs with your partners, but work with others is otherwise restricted by the appropriate rules above. Guideline: Any work that is not the work of your team is considered a violation of the honor code.

If you do not understand how the honor code applies to a particular assignment, consult your instructor.

Students should be aware of the Computer Ethics outlined in the Student Handbook. Violations (including uninvited access to private information and malicious tampering or theft of computer equipment or software) are subject to disciplinary action.

Guideline: To protect your work dispose of printouts and diskettes carefully, and avoid leaving your programs on hard disks in labs and other public storage areas.

The Department of Computer Science takes the Honor Code seriously. Violations are easy to identify and will be dealt with promptly.