COP4610 is an introductory course to operating systems. Operating systems are an essential part of any computer system. Operating systems vary significantly, but their fundamental principles remain the same. In this course you will be introduced to the basic concepts of operating systems, see how they manage resources such as memory, peripherals, and schedule CPU time, learn how to use the system call interface and how to create processes and synchronize them, learn how applications communicate, understand the memory hierarchy and see how virtual memory is managed, understand how files are managed and stored, and much more.
The following coursework components contribute to your final grade using the weights shown in the table below:
There will be four increasingly challenging projects due during this course. You are expected to work in teams of two persons on these projects. Project descriptions can be downloaded from the schedule.
Homework assignments consist of short-answer questions, essays, or problems. The purpose of these assignments is to prepare you for the exams. Homework assignments can be downloaded from the schedule.
For homework and projects, you must include your name and last four digits of your SSN on each submitted item (electronic or on paper) as well as the name and last four digits of the SSN of your team member (for projects only). Note that copying program listings and homework pages from other persons (besides your team member on projects) is illegal and such abuse will not be tolerated. This includes dishonest practices such as programming-for-hire.
The project and homework assignments, when turned in before or at the due date before midnight will be graded. When turned in late, 10% will be deducted from the grade per day late until the homework has been received, with a maximum extension of five days.
The final exam will be comprehensive.
To receive a passing grade for the overall course, you must earn a passing grade on the final exam and a passing grade on the projects and receive a combined passing grade according to the weight distribution shown in the table above.
The letter grade distribution for the final combined grade score (after roundoff) is shown in the table below:
Your grades for projects, homework, and exams will be accessible via FSU's Blackboard.
You will need an account to log on to the Computer Science department machines. If you dont have one, visit the system info site: http://www.cs.fsu.edu/sysinfo/newstudent.html.
You will also need an ACNS account (i.e., @garnet.fsu.edu) for receiving class emails. If you want, you can forward your garnet email to other accounts (visit https://cars.acns.fsu.edu for more details).
The tentative schedule with PPT lecture notes is shown below (refresh this page if necessary). You are encouraged to download and print the notes as handouts to take to class. Links will be active when new notes have been added.
The schedule will be updated when needed and significant changes will be announced on Blackboard.
Project and homework assignments should be downloaded by selecting the link in the "Assignments due" column. Submit your assignments electronically by email to the TA or turn hard copies of homework in before class. Don't forget to write down your name and four last digits of your SSN.
|Date||Lecture notes||Reading material||Other useful resources||Assignments due|
|1/9||1. Introduction (by Andy Wang)||"The Emperor's Old Clothes"||-||-|
|1/16||MLK Day: no class||-||-||-|
|Syllabus and Chapter 1||-||-|
|1/20||2. OS Structures||Chapter 2 and Resources||-||-|
|1/23||3. Processes||Chapter 3 (3.1-3.4) and Processes||-||Homework 1|
|1/27||4. Threads||Chapter 4 (4.1-4.4)||a. Wikipedia on Pthreads||-|
|1/30||b. Pthreads tutorial||-|
|2/1||5. CPU Scheduling||Chapter 5||a. The Linux 2.6 kernel||-|
|2/6||6. Process Synchronization||Chapter 6 (6.1-6.7)
and class handout
|a. The Little Book of Semaphores||Homework 2|
|2/10||7. Deadlocks||Chapter 7 and Deadlocks||-||Project 1|
|2/15||Review||Chapters 1 to 7||-||Homework 3|
|2/20||8. Main Memory||Chapter 8 and Memory Allocation||-||-|
|2/27||9. Virtual Memory||Chapter 9 (9.1-9.9) and Virtual Memory||-||-|
|3/6-3/10||Spring break: no class||-||-||-|
|3/13||10. File-System Interface||Chapter 10||-||-|
|3/17||11. File-System Implementation||Chapter 11 and File Management||-||-|
|3/22||Project discussion||Chapters 8-11||-||-|
|3/29||12. Mass-Storage Structure||Chapter 12||-||-|
|4/3||13. I/O Systems||Chapter 13 (13.1-13.5)||-||-|
|4/7||16. Distributed System Structures||Chapter 16 (16.1-16.7)||-||Homework 5|
|4/12||17. Distributed File Systems||Chapter 17||-||-|
|4/17||18. Distributed Coordination||Chapter 18 (18.1-18.4.1)||-|
|4/19||Review||Chapters 1-13, 16-18||-||-|
|4/25||Final exam 5:30-7:30 PM||-||-||-|
|4/27||Project 4 due||-||-||Project 4|
Students with disabilities needing academic accommodations should: (1) register with and provide documentation to the Student Disability Resource Center, and (2) bring a letter to the instructor indicating the need for accommodations within the first week of class.
This syllabus and other class materials are available in alternative formats on request.
For more information about services available to FSU students with disabilities, please contact:
Student Disability Resource Center
08 Kellum Hall
Florida State University
Tallahassee, FL 32306-4066
Phone: (850) 644-9566
Copyright: Robert van Engelen, Florida State University, 2006.