CPU Scheduling (Part II) Amir H. Payberah
[email protected] Amirkabir University of Technology (Tehran Polytechnic) Amir H. Payberah (Tehran Polytechnic) CPU Scheduling 1393/7/28 1 / 58 Motivation Amir H. Payberah (Tehran Polytechnic) CPU Scheduling 1393/7/28 2 / 58 Reminder I CPU scheduling is the basis of multiprogrammed OSs. I By switching the CPU among processes, the OS makes the computer more productive. Amir H. Payberah (Tehran Polytechnic) CPU Scheduling 1393/7/28 3 / 58 Basic Concepts I In a single-processor system, only one process can run at a time. I Others must wait until the CPU is free and can be rescheduled. I The objective of multiprogramming is to have some process running at all times, to maximize CPU utilization. Amir H. Payberah (Tehran Polytechnic) CPU Scheduling 1393/7/28 4 / 58 Scheduling Criteria I CPU utilization I Throughput I Turnaround time I Waiting time I Response time Amir H. Payberah (Tehran Polytechnic) CPU Scheduling 1393/7/28 5 / 58 Process Scheduling Algorithms I First-Come, First-Served Scheduling I Shortest-Job-First Scheduling I Priority Scheduling I Round-Robin Scheduling I Multilevel Queue Scheduling I Multilevel Feedback Queue Scheduling Amir H. Payberah (Tehran Polytechnic) CPU Scheduling 1393/7/28 6 / 58 Thread Scheduling Amir H. Payberah (Tehran Polytechnic) CPU Scheduling 1393/7/28 7 / 58 Thread Scheduling (1/2) I Distinction between user-level and kernel-level threads. I When threads supported by the OS, threads scheduled, not pro- cesses. Amir H. Payberah (Tehran Polytechnic) CPU Scheduling 1393/7/28 8 / 58 I System-Contention Scope (SCS) • In one-to-one model.