Applied Operating System (3-0-3)
Evaluation:
Theory Practical Total
Sessiona 30 20 50
l
Final 50 - 50
Total 80 20 100
Course Objectives:
1. To introduce and apply the fundamentals of computer operating systems concepts including
Process Management, Memory and I/O Management, Processor Scheduling,
Synchronization, File System etc.
2. To familiarize the students with the design and implementation aspect of an Operating
system.
Course Contents:
1. Operating Systems Types and Structure (5 hrs)
1.1 Introduction
1.1.1 Batch Systems
1.1.2 Time-Sharing Systems
1.1.3 Personal-Computer Systems
1.1.4 Parallel Systems
1.1.5 Real-Time Systems
1.1.6 Distributed Systems
1.2 Operating-System Structures
1.2.1 System Components
1.2.2 OS Services
1.2.3 System Calls
1.2.4 System Programs
1.2.5 System Structure
1.2.6 System Design and Implementation
1.2.7 System Generation.
2. Process/Thread Management (15 hrs)
2.1 Processes
2.1.1 Concept and Scheduling
2.1.2 Operations on Processes
2.1.3 Cooperating Processes
2.1.4 Inter process Communication
2.2 Threads
2.2.1 Overview
2.2.2 Benefits of Threads
2.2.3 User and Kernel Threads
2.2.4 Multithreading Models
2.3 Processor Scheduling
2.3.1 Concepts
2.3.2 Scheduling Criteria
2.3.3 Scheduling Algorithms
2.3.3.1 First Come First Served Scheduling (FCFS)
2.3.3.2 Optimal Scheduling
2.3.3.3 Round Robin Scheduling
2.3.3.4 Shortest Job First (SJF)
2.3.3.5 Shortest-Remaining-Time First scheduling (STRF)
2.3.3.6 Priority Scheduling
2.3.3.6 Multiple Queue Scheduling
2.3.3.7 Multilevel Feedback Queue Scheduling
2.3.4 Thread Scheduling
2.4 Process Synchronization
2.4.1 Background
2.4.2 Critical-Section Problem
2.4.3 Two-Tasks Solutions
2.4.4 Synchronization Hardware
2.4.5 Semaphores
2.4.6 Classical Synchronization
2.4.8 OS Synchronization
2.5 Deadlocks
2.5.1 Model of Deadlocks
2.5.2 Deadlock Characterization
2.5.3 Deadlock Handling Methods
2.5.3.1 Deadlock Prevention
2.5.3.2 Deadlock Avoidance
2.5.3.3 Deadlock Detection
2.5.3.4 Recovery from Deadlock
3. Memory Management (8 hrs)
3.1 Memory Management
3.1.1 Concept
3.1.2 Swapping
3.1.3 Contiguous Memory Allocation
3.1.4 Paging
3.1.5 Segmentation
3.1.6 Segmentation with Paging
3.2 Virtual Memory
3.2.1 Concept
3.2.2 Demand Paging
3.2.3 Page Replacement
3.2.4 Allocation of Frames
3.2.5 Thrashing
4. I/O Management (12 hrs)
4.1 I/O Sub-Systems
4.1.1 Concept
4.1.2 Application I/O Interface
4.2.2 Kernel I/O Subsystem
4.2.3 I/O Requests Handling
4.3.4 Performance
4.2 Mass-Storage Device
4.2.1 Disk Structure and Data Organization on Disk
4.2.2 Disk Scheduling
4.2.3 Disk Management
4.3.4 Swap-Space Management
4.3.5 Stable-Storage Implementation
4.3.6 Tertiary-Storage Structure
4.3.7 I/O in UNIX
5. File Systems (5 hrs)
5.1 Concept
5.2 File Access Methods
5.3 Writing and Seeking
5.4 Directory Structure
5.5 Protection
5.6 File-System Structure
5.7 Methods of Allocation
5.8 Free-Space Management
5.9 Directory Implementation
5.10 Recovery
Laboratory:
The laboratory work shall focus on the implementation aspect of the concepts covered in the
lecture class using Java programming language and a particular platform/OS (e.g. Linux)
These include implementation of Threads, Scheduling of Threads, Synchronization, Deadlock
handling in Java. Implementation of Memory, I/O and Resource Management schemes of an
Operating System.
Text Book:
Silberschatz, A., Galvin, P.B., Gagne, G., Applied Operating Systems Concepts, 1st Edition, John
Wiley & Sons, 2000, ISBN: 9971-51-284-X
Reference:
Silberschatz, A., Galvin, P.B., Operating Systems Concepts, 5th Edn., John Wiley & Sons, 1999,
ISBN: 9971-51-275-0