Operating System Concepts Ku-Yaw Chang Assistant Professor, Department of Computer Science and Information Engineering Da-Yeh University.

Slides:



Advertisements
Similar presentations
CPU Scheduling.
Advertisements

Silberschatz, Galvin and Gagne ©2013 Operating System Concepts Essentials – 2 nd Edition Chapter 6a: CPU Scheduling.
 Basic Concepts  Scheduling Criteria  Scheduling Algorithms.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Chapter 5: CPU Scheduling.
Chap 5 Process Scheduling. Basic Concepts Maximum CPU utilization obtained with multiprogramming CPU–I/O Burst Cycle – Process execution consists of a.
Chapter 5 CPU Scheduling. CPU Scheduling Topics: Basic Concepts Scheduling Criteria Scheduling Algorithms Multiple-Processor Scheduling Real-Time Scheduling.
CPU Scheduling CS 3100 CPU Scheduling1. Objectives To introduce CPU scheduling, which is the basis for multiprogrammed operating systems To describe various.
Chapter 3: CPU Scheduling
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 6: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 5: CPU Scheduling.
CS 311 – Lecture 23 Outline Kernel – Process subsystem Process scheduling Scheduling algorithms User mode and kernel mode Lecture 231CS Operating.
Scheduling in Batch Systems
Chapter 6: CPU Scheduling. 5.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts – 7 th Edition, Feb 2, 2005 Chapter 6: CPU Scheduling Basic.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 6: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms.
What we will cover…  CPU Scheduling  Basic Concepts  Scheduling Criteria  Scheduling Algorithms  Evaluations 1-1 Lecture 4.
Chapter 5-CPU Scheduling
Operating System Concepts with Java – 7 th Edition, Nov 15, 2006 Silberschatz, Galvin and Gagne ©2007 Chapter 5: CPU Scheduling.
Chapter 5: Process Scheduling. 5.2 Silberschatz, Galvin and Gagne ©2005 Operating System Principles Objectives To introduce CPU scheduling To describe.
02/11/2004CSCI 315 Operating Systems Design1 CPU Scheduling Algorithms Notice: The slides for this lecture have been largely based on those accompanying.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 6: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms.
Chapter 5: CPU Scheduling. 5.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts – 7 th Edition, Feb 2, 2005 Basic Concepts Maximum CPU utilization.
Chapter 6: CPU Scheduling
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 6: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms.
Silberschatz, Galvin, and Gagne  Applied Operating System Concepts Module 6: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms.
CS212: OPERATING SYSTEM Lecture 3: Process Scheduling 1.
Operating System Principles Ku-Yaw Chang Assistant Professor, Department of Computer Science and Information Engineering Da-Yeh.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 6: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms.
Scheduling. Alternating Sequence of CPU And I/O Bursts.
Silberschatz and Galvin  Operating System Concepts Module 5: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms Multiple-Processor.
Alternating Sequence of CPU And I/O Bursts. Histogram of CPU-burst Times.
CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms Thread Scheduling Multiple-Processor Scheduling Operating Systems Examples Algorithm.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 5: CPU Scheduling.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 6: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms.
Chapter 5: CPU Scheduling. 5.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Chapter 5: CPU Scheduling Basic Concepts Scheduling Criteria.
CMSC 421 Spring 2004 Section 0202 Part II: Process Management Chapter 6 CPU Scheduling.
Chapter 5: Process Scheduling. 5.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Basic Concepts Maximum CPU utilization can be obtained.
Chapter 5: CPU Scheduling. 5.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Chapter 5: CPU Scheduling Basic Concepts Scheduling Criteria.
1 11/29/2015 Chapter 6: CPU Scheduling l Basic Concepts l Scheduling Criteria l Scheduling Algorithms l Multiple-Processor Scheduling l Real-Time Scheduling.
Chapter 5: CPU Scheduling. 5.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts – 7 th Edition, Feb 2, 2005 Chapter 5: CPU Scheduling Basic.
Silberschatz and Galvin  Operating System Concepts Module 5: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms Multiple-Processor.
1 CS.217 Operating System By Ajarn..Sutapart Sappajak,METC,MSIT Chapter 5 CPU Scheduling Slide 1 Chapter 5 CPU Scheduling.
6.1 CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms Multiple-Processor Scheduling Real-Time Scheduling Algorithm Evaluation.
1 CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms Multiple-Processor Scheduling Real-Time Scheduling.
1 Uniprocessor Scheduling Chapter 3. 2 Alternating Sequence of CPU And I/O Bursts.
Chapter 4 CPU Scheduling. 2 Basic Concepts Scheduling Criteria Scheduling Algorithms Multiple-Processor Scheduling Real-Time Scheduling Algorithm Evaluation.
Lecture 4 CPU scheduling. Basic Concepts Single Process  one process at a time Maximum CPU utilization obtained with multiprogramming CPU idle :waiting.
CPU Scheduling G.Anuradha Reference : Galvin. CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms Multiple-Processor Scheduling Real-Time.
CPU scheduling.  Single Process  one process at a time  Maximum CPU utilization obtained with multiprogramming  CPU idle :waiting time is wasted 2.
1 Module 5: Scheduling CPU Scheduling Scheduling Algorithms Reading: Chapter
Basic Concepts Maximum CPU utilization obtained with multiprogramming
1 Lecture 5: CPU Scheduling Operating System Fall 2006.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Chapter 5: CPU Scheduling.
Chapter 5: CPU Scheduling. 5.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Chapter 5: CPU Scheduling Basic Concepts Scheduling Criteria.
1 Chapter 5: CPU Scheduling. 2 Basic Concepts Scheduling Criteria Scheduling Algorithms.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 6: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms.
Chapter 6: CPU Scheduling
CPU Scheduling G.Anuradha
Chapter 6: CPU Scheduling
Module 5: CPU Scheduling
Chapter 5: CPU Scheduling
3: CPU Scheduling Basic Concepts Scheduling Criteria
Chapter5: CPU Scheduling
Chapter 5: CPU Scheduling
Chapter 6: CPU Scheduling
Chapter 5: CPU Scheduling
Chapter 6: CPU Scheduling
Module 5: CPU Scheduling
Chapter 6: CPU Scheduling
CPU Scheduling: Basic Concepts
Module 5: CPU Scheduling
Presentation transcript:

Operating System Concepts Ku-Yaw Chang Assistant Professor, Department of Computer Science and Information Engineering Da-Yeh University

2Ku-Yaw ChangChapter 6 CPU Scheduling CPU scheduling The basis of multiprogrammed OSs The basis of multiprogrammed OSs Make the computer more production Make the computer more production Switch the CPU among processes We introduce The basic scheduling concepts The basic scheduling concepts Several different CPU-scheduling algorithms Several different CPU-scheduling algorithms Selecting an algorithm for a particular system

3Ku-Yaw ChangChapter 6 CPU Scheduling 1.Basic Concepts 2.Scheduling Criteria 3.Scheduling Algorithms 4.Multiple-Processor Scheduling 5.Real-Time Scheduling 6.Algorithm Evaluation 7.Process Scheduling Models 8.Summary 9.Exercises

4Ku-Yaw ChangChapter 6 CPU Scheduling 6.1 Basic Concepts Several processes are kept in memory at one time When a process has to wait, the OS takes the CPU away from that process, and gives the CPU to another process. When a process has to wait, the OS takes the CPU away from that process, and gives the CPU to another process. Almost all computer resources are scheduled before use.

5Ku-Yaw ChangChapter 6 CPU Scheduling CPU-I/O Burst Cycle Observed property of processes Process execution consists of a cycle of Process execution consists of a cycle of CPU execution I/O wait Process execution begins with a CPU burst. That is followed by an I/O burst, then another CPU burst, then another I/O burst, and so on. That is followed by an I/O burst, then another CPU burst, then another I/O burst, and so on.

6Ku-Yaw ChangChapter 6 CPU Scheduling Alternating sequence of CPU and I/O bursts

7Ku-Yaw ChangChapter 6 CPU Scheduling Histogram of CPU-burst times

8Ku-Yaw ChangChapter 6 CPU Scheduling CPU-I/O Burst Cycle Measure CPU bursts An I/O bound program An I/O bound program Many short CPU bursts A CPU bound program A CPU bound program A few very long CPU bursts Help select an appropriate CPU- scheduling algorithm

9Ku-Yaw ChangChapter 6 CPU Scheduling CPU Scheduler Whenever the CPU becomes idle Select one of the processes in the ready queue to be executed Select one of the processes in the ready queue to be executed Carried out by the short-term scheduler, also called CPU scheduler A ready queue may be implemented as A FIFO queue A FIFO queue A priority queue A priority queue A tree A tree An unordered linked list An unordered linked list

10Ku-Yaw ChangChapter 6 CPU Scheduling Preemptive Scheduling CPU scheduling decisions take place when a process Switches from running to waiting state Switches from running to waiting state Switches from running to ready state Switches from running to ready state Switches from waiting to ready Switches from waiting to ready Terminates Terminates Scheduling only under 1 and 4 is nonpreemptive Otherwise is preemptive Otherwise is preemptive Incur a cost

11Ku-Yaw ChangChapter 6 CPU Scheduling Dispatcher Dispatcher module gives control of the CPU to the process selected by the short-term scheduler; switching context switching context switching to user mode switching to user mode jumping to the proper location in the user program to restart that program jumping to the proper location in the user program to restart that program Dispatch latency time it takes for the dispatcher to stop one process and start another running. time it takes for the dispatcher to stop one process and start another running.

12Ku-Yaw ChangChapter 6 CPU Scheduling 1.Basic Concepts 2.Scheduling Criteria 3.Scheduling Algorithms 4.Multiple-Processor Scheduling 5.Real-Time Scheduling 6.Algorithm Evaluation 7.Process Scheduling Models 8.Summary 9.Exercises

13Ku-Yaw ChangChapter 6 CPU Scheduling 6.2 Scheduling Criteria CPU utilization (max) keep the CPU as busy as possible keep the CPU as busy as possible Throughput (max) number of processes that complete their execution per time unit number of processes that complete their execution per time unit Turnaround time (min) amount of time to execute a particular process amount of time to execute a particular process Waiting time (min) amount of time a process has been waiting in the ready queue amount of time a process has been waiting in the ready queue Response time (min) amount of time it takes from when a request was submitted until the first response is produced, not output (for time-sharing environment) amount of time it takes from when a request was submitted until the first response is produced, not output (for time-sharing environment)

14Ku-Yaw ChangChapter 6 CPU Scheduling 1.Basic Concepts 2.Scheduling Criteria 3.Scheduling Algorithms 4.Multiple-Processor Scheduling 5.Real-Time Scheduling 6.Algorithm Evaluation 7.Process Scheduling Models 8.Summary 9.Exercises

15Ku-Yaw ChangChapter 6 CPU Scheduling 6.3 Scheduling Algorithms Dealing the problem of deciding which of the processes in the ready queue to be allocated the CPU First-Come, First-Served Scheduling First-Come, First-Served Scheduling Shortest-Job-First Scheduling Shortest-Job-First Scheduling Priority Scheduling Priority Scheduling Round-Robin Scheduling Round-Robin Scheduling Multilevel Queue Scheduling Multilevel Queue Scheduling Multilevel Feedback Queue Scheduling Multilevel Feedback Queue Scheduling

16Ku-Yaw ChangChapter 6 CPU Scheduling First-Come, First-Served Scheduling The process that requests the CPU first is allocated the CPU first. The simplest CPU-scheduling algorithm The simplest CPU-scheduling algorithm Implementation with a FIFO queue Implementation with a FIFO queue Add to the tail of the queue Remove from the head to the queue The code is simple to write and understand The code is simple to write and understand Average waiting time is often quite long.

17Ku-Yaw ChangChapter 6 CPU Scheduling ProcessBurst Time P 1 24 P 2 3 P 2 3 P 3 3 P 3 3 Suppose that the processes arrive in the order: P 1, P 2, P 3 The Gantt Chart for the schedule is: Waiting time for P 1 = 0; P 2 = 24; P 3 = 27 Average waiting time: ( )/3 = 17 P1P1 P2P2 P3P First-Come, First-Served Scheduling

18Ku-Yaw ChangChapter 6 CPU Scheduling First-Come, First-Served Scheduling Suppose that the processes arrive in the order Suppose that the processes arrive in the order P2, P3, P1 P2, P3, P1 The Gantt chart for the schedule is: Waiting time for P1 = 6; P2 = 0; P3 = 3 Average waiting time: ( )/3 = 3 Much better than previous case. P1P1 P3P3 P2P

19Ku-Yaw ChangChapter 6 CPU Scheduling First-Come, First-Served Scheduling Convoy effect All the other processes wait for one big process to get off the CPU All the other processes wait for one big process to get off the CPU Results in lower CPU and device utilization Results in lower CPU and device utilization If the shorter processes were allowed to go first FCFS is non-preemptive Once the CPU has been allocated to a process, that process keeps the CPU until it releases the CPU. Once the CPU has been allocated to a process, that process keeps the CPU until it releases the CPU. Particular troublesome in time-sharing system Particular troublesome in time-sharing system Each user needs to get a share of the CPU at regular intervals

20Ku-Yaw ChangChapter 6 CPU Scheduling Shortest-Job-First Scheduling When the CPU is available, it is assigned to the process that has the smallest next CPU burst. Associate each process with the length of the latter’s next CPU burst Associate each process with the length of the latter’s next CPU burst Not its total length Another term – shortest next CPU burst Another term – shortest next CPU burst FCFS scheduling is used to break the tie FCFS scheduling is used to break the tie Provably optimal Minimum average waiting time for a given set of processes Minimum average waiting time for a given set of processes Real difficulty Knowing the length of the next CPU burst Knowing the length of the next CPU burst Used frequently in long-term scheduling Used frequently in long-term scheduling

21Ku-Yaw ChangChapter 6 CPU Scheduling ProcessBurst Time P 1 6 P 2 8 P 2 8 P 3 7 P 3 7 P 4 3 P 4 3 The Gantt Chart for the schedule is: The Gantt Chart for the schedule is: Waiting time for P 1 = 3; P 2 = 16; P 3 = 9; P 4 = 0 Average waiting time: ( ) / 4 = 7 Using FCFS scheme : ( ) / 4 = Shortest-Job-First Scheduling P4P4 P1P1 P3P P2P2 9

22Ku-Yaw ChangChapter 6 CPU Scheduling Shortest-Job-First Scheduling To approximate SJF scheduling To predict its value To predict its value Use the length of previous CPU bursts Use the length of previous CPU bursts exponential average

23Ku-Yaw ChangChapter 6 CPU Scheduling Prediction of the length of the next CPU burst

24Ku-Yaw ChangChapter 6 CPU Scheduling Examples of Exponential Averaging  = 0  n+1 =  n  n+1 =  n Recent history does not count. Recent history does not count.  = 1  n+1 = t n  n+1 = t n Only the actual last CPU burst counts. Only the actual last CPU burst counts. If we expand the formula, we get:  n+1 =  t n +(1 -  )  t n -1 + … +(1 -  ) j  t n -1 + … +(1 -  ) j  t n -1 + … +(1 -  ) n+1 t n  0 +(1 -  ) n+1 t n  0 Since both  and (1 -  ) are less than or equal to 1, each successive term has less weight than its predecessor.

25Ku-Yaw ChangChapter 6 CPU Scheduling Shortest-Job-First Scheduling Two schemes Nonpreemptive Nonpreemptive Allow the current running process to finish its CPU burst Preemptive Preemptive If a new process arrives with CPU burst length less than remaining time of current executing process, preempt. Called as Shortest-Remaining-Time-First (SRTF).

26Ku-Yaw ChangChapter 6 CPU Scheduling ProcessArrival TimeBurst Time P 1 08 P 2 14 P 2 14 P 3 29 P 3 29 P 4 35 P 4 35 Preemptive SJF Average waiting time = ( (10-1) + (1-1) + (17-2) + (5-3)) / 4 = 6.5 Example of Preemptive SJF P1P1 P3P3 P2P P4P P1P1

27Ku-Yaw ChangChapter 6 CPU Scheduling Priority Scheduling The CPU is allocated to the process with the highest priority. A priority is associated with each process A priority is associated with each process Fixed range of number, such as 0 to 7 We use low numbers to represent high priority Equal-priority processes are scheduled in FCFS order Equal-priority processes are scheduled in FCFS order SJF is a special case of the general priority- scheduling algorithm SJF is a special case of the general priority- scheduling algorithm The priority is the inverse of the predicted next CPU burst

28Ku-Yaw ChangChapter 6 CPU Scheduling ProcessBurst TimePriority P P P 2 11 P 2 11 P 3 24 P 3 24 P 4 15 P 4 15 P 5 52 P 5 52 Priority scheduling Average waiting time = ( ) / 5 = 8.2 Example of priority scheduling P3P3 P4P4 P5P P1P P2P2

29Ku-Yaw ChangChapter 6 CPU Scheduling Priority Scheduling Priorities can be defined Internally Internally Use some measurable quantity Time limits, memory requirements… Time limits, memory requirements… Externally Externally Set by criteria external to OS importance, political factors importance, political factors Priority scheduling can be Preemptive Preemptive Nonpreemptive Nonpreemptive Major problem Indefinite blocking or starvation Indefinite blocking or starvation Solution: aging Solution: aging Gradually increase the priority of processes that wait for a long time

30Ku-Yaw ChangChapter 6 CPU Scheduling Round-Robin Scheduling A small unit of time, called a time quantum ( or time slice) is defined. Generally from 10 to 100 milliseconds Generally from 10 to 100 milliseconds The ready queue is treated as a circular, FIFO queue. The CPU scheduler goes around the ready queue Allocate the CPU to each process for a time interval of up to 1 time quantum. Allocate the CPU to each process for a time interval of up to 1 time quantum. Designed especially for time-sharing systems Designed especially for time-sharing systems Two cases CPU burst less than 1 time quantum CPU burst less than 1 time quantum The process release the CPU voluntarily CPU burst longer than 1 time quantum CPU burst longer than 1 time quantum Context switch will be executed

31Ku-Yaw ChangChapter 6 CPU Scheduling ProcessBurst Time P 1 24 P 1 24 P 2 3 P 2 3 P 3 3 P 3 3 Round-robin scheduling A time-quantum of 4 milliseconds A time-quantum of 4 milliseconds Average waiting time = ( ) / 3 = 5.66 Often quite long Often quite long RR scheduling is preemptive. Example of round-robin scheduling P3P3 P1P1 P2P P1P P1P1 P1P1 P1P1 P1P

32Ku-Yaw ChangChapter 6 CPU Scheduling Round-Robin Scheduling n processes in the ready queue and the time quantum is q Each process gets 1/n of the CPU time in chunks of at most q time units at once Each process gets 1/n of the CPU time in chunks of at most q time units at once No process waits more than (n-1)q time units No process waits more than (n-1)q time unitsPerformance Depend heavily on the size of the time quantum Depend heavily on the size of the time quantum q is very large : the same as the FCFS policy q is very small : called processor sharing q must be large with respect to context switch, otherwise overhead is too high. q must be large with respect to context switch, otherwise overhead is too high.

33Ku-Yaw ChangChapter 6 CPU Scheduling A smaller time quantum increases context switches

34Ku-Yaw ChangChapter 6 CPU Scheduling Round-Robin Scheduling Turnaround time also depends on the size of the time quantum. Rule of thumb 80 percent of the CPU burst should be shorter than the time quantum 80 percent of the CPU burst should be shorter than the time quantum

35Ku-Yaw ChangChapter 6 CPU Scheduling Multilevel Queue Scheduling Processes are classified into different groups Foreground (or interactive) processes Foreground (or interactive) processes Background (or batch) processes Background (or batch) processes Multilevel queue-scheduling algorithm Partition the ready queue into several separate groups Partition the ready queue into several separate groups Each group has its own scheduling algorithm Each group has its own scheduling algorithm Scheduling among the queues Scheduling among the queues Fixed-priority preemptive scheduling Possibility of starvation Possibility of starvation Time-slice between the queues A certain portion of the CPU time A certain portion of the CPU time

36Ku-Yaw ChangChapter 6 CPU Scheduling Multilevel Queue Scheduling

37Ku-Yaw ChangChapter 6 CPU Scheduling Multilevel Feedback Queue A process can move between the various queues Use too much CPU time : move to a lower-priority queue Use too much CPU time : move to a lower-priority queue Wait too long : move to a higher-priority queue Wait too long : move to a higher-priority queue This form of aging prevents starvation Multilevel-feedback-queue scheduler defined by : number of queues number of queues scheduling algorithms for each queue scheduling algorithms for each queue method used to determine when to upgrade a process method used to determine when to upgrade a process method used to determine when to demote a process method used to determine when to demote a process method used to determine which queue a process will enter when that process needs service method used to determine which queue a process will enter when that process needs service

38Ku-Yaw ChangChapter 6 CPU Scheduling Three queues: Q 0 – time quantum 8 milliseconds Q 0 – time quantum 8 milliseconds Q 1 – time quantum 16 milliseconds Q 1 – time quantum 16 milliseconds Q 2 – FCFS Q 2 – FCFSScheduling A new job enters queue Q 0 which is served FCFS. When it gains CPU, job receives 8 milliseconds. If it does not finish in 8 milliseconds, job is moved to queue Q 1. A new job enters queue Q 0 which is served FCFS. When it gains CPU, job receives 8 milliseconds. If it does not finish in 8 milliseconds, job is moved to queue Q 1. At Q 1 job is again served FCFS and receives 16 additional milliseconds. If it still does not complete, it is preempted and moved to queue Q 2. At Q 1 job is again served FCFS and receives 16 additional milliseconds. If it still does not complete, it is preempted and moved to queue Q 2. Example of Multilevel Feedback Queue

39Ku-Yaw ChangChapter 6 CPU Scheduling Multilevel feedback queues The most general and complex scheme Q0Q0 Q1Q1 Q2Q2

40Ku-Yaw ChangChapter 6 CPU Scheduling 1.Basic Concepts 2.Scheduling Criteria 3.Scheduling Algorithms 4.Multiple-Processor Scheduling 5.Real-Time Scheduling 6.Algorithm Evaluation 7.Process Scheduling Models 8.Summary 9.Exercises

41Ku-Yaw ChangChapter 6 CPU Scheduling 6.4 Multiple-Processor Scheduling CPU scheduling is more complex when multiple CPUs are available Homogeneous system Identical processors Identical processors Load sharing can occur Load sharing can occur Separate queue Common queue Self-scheduling Self-scheduling Master-slave structure Master-slave structure Heterogeneous system Different processors Different processors

42Ku-Yaw ChangChapter 6 CPU Scheduling 1.Basic Concepts 2.Scheduling Criteria 3.Scheduling Algorithms 4.Multiple-Processor Scheduling 5.Real-Time Scheduling 6.Algorithm Evaluation 7.Process Scheduling Models 8.Summary 9.Exercises

43Ku-Yaw ChangChapter 6 CPU Scheduling 6.5 Real-Time Scheduling Hard real-time systems complete a critical task within a guaranteed amount of time. complete a critical task within a guaranteed amount of time. Special-purpose software running on dedicated hardware Special-purpose software running on dedicated hardware Lack the full functionality of modern computers and operating systems Lack the full functionality of modern computers and operating systems Soft real-time computing Critical processes receive priority over less fortunate ones Critical processes receive priority over less fortunate ones May cause unfair allocation of resources May cause unfair allocation of resources A general-purpose system can also support special tasks A general-purpose system can also support special tasks

44Ku-Yaw ChangChapter 6 CPU Scheduling 6.5 Real-Time Scheduling Soft real-time computing Priority scheduling Priority scheduling Real-time process must have the highest priority The dispatch latency must be small The dispatch latency must be small OSs are forced to wait for a system call to complete or an I/O block to take place before doing a context switch Solution: system calls must be preemptible Insert preemption points Insert preemption points Make the entire kernel preemptible Make the entire kernel preemptible Effective and complex method Solaris 2 Over 100 ms v.s. 2 ms Over 100 ms v.s. 2 ms

45Ku-Yaw ChangChapter 6 CPU Scheduling Dispatch Latency

46Ku-Yaw ChangChapter 6 CPU Scheduling 1.Basic Concepts 2.Scheduling Criteria 3.Scheduling Algorithms 4.Multiple-Processor Scheduling 5.Real-Time Scheduling 6.Algorithm Evaluation 7.Process Scheduling Models 8.Summary 9.Exercises

47Ku-Yaw ChangChapter 6 CPU Scheduling 6.6 Algorithm Evaluation How to select a CPU-scheduling algorithm for a particular system? Define the criteria Define the criteria CPU utilization Response time Throughput A criteria may include several measures A criteria may include several measures Maximize CPU utilization under the constraint that the maximum response time is 1 second. Maximize throughput such that turnaround time is linearly proportional to total execution time.

48Ku-Yaw ChangChapter 6 CPU Scheduling Deterministic Modeling Take a particular predetermined workload and defines the performance of each algorithm for that workload Example Assume five processes arrive at time 0, in the order given, with the length of the CPU-burst time given in milliseconds: Assume five processes arrive at time 0, in the order given, with the length of the CPU-burst time given in milliseconds: ProcessBurst TimePriority P P P P P P P P P P Consider the FCFS, SJF, and RR(quantum=10 milliseconds) scheduling algorithms for this set of processes. Consider the FCFS, SJF, and RR(quantum=10 milliseconds) scheduling algorithms for this set of processes. Which gives the minimum average waiting time? Which gives the minimum average waiting time?

49Ku-Yaw ChangChapter 6 CPU Scheduling Deterministic Modeling Advantage Simple and fast Simple and fast Exact numbers Disadvantage Too specific, and require too much exact knowledge, to be useful Too specific, and require too much exact knowledge, to be useful Main use Describing scheduling algorithms and providing examples Describing scheduling algorithms and providing examples

50Ku-Yaw ChangChapter 6 CPU Scheduling Queueing Models No static set of processes (and times) What can be determined The distribution of CPU and I/O bursts The distribution of CPU and I/O bursts Measured and approximated by mathematical formulas Queueing-network analysis CPU is a server with its ready queue CPU is a server with its ready queue I/O system is a server with its device queue I/O system is a server with its device queue Knowing arrival rates and service rates Knowing arrival rates and service rates Utilization, average queue length, average wait time

51Ku-Yaw ChangChapter 6 CPU Scheduling Queueing Models Little’s formula : n = * W n: average queue length n: average queue length W : average waiting time W : average waiting time : average arrival rate for new processes : average arrival rate for new processesAdvantage Useful in comparing scheduling algorithms Useful in comparing scheduling algorithmsDisadvantage Approximation only Approximation only Fairly limited applicability Fairly limited applicability

52Ku-Yaw ChangChapter 6 CPU Scheduling Simulations Programming a model of the computer system Simulator A variable representing a clock A variable representing a clock Modify the system state to reflect the activities of the devices, the processes, and the scheduler Modify the system state to reflect the activities of the devices, the processes, and the scheduler Data generation Data generationRandom-number Probability distribution Probability distribution Empirically Empirically Trace tapes Monitor the real system Monitor the real system Expensive Expensive More detailed simulation provides more accurate results

53Ku-Yaw ChangChapter 6 CPU Scheduling Evaluation of CPU schedulers by simulation

54Ku-Yaw ChangChapter 6 CPU Scheduling Implementation A simulation is of limited accuracy. The only completely accurate way code it code it put it in the OS put it in the OS see how it work see how it work The cost is high In coding In coding In the reaction of users In the reaction of users

55Ku-Yaw ChangChapter 6 CPU Scheduling 1.Basic Concepts 2.Scheduling Criteria 3.Scheduling Algorithms 4.Multiple-Processor Scheduling 5.Real-Time Scheduling 6.Algorithm Evaluation 7.Process Scheduling Models 8.Summary 9.Exercises

56Ku-Yaw ChangChapter 6 CPU Scheduling 6.7 Process Scheduling Models User-level threads Managed by a thread library Managed by a thread library Kernel is unaware of them Kernel is unaware of them Process local scheduling Thread scheduling is done local to the application Thread scheduling is done local to the application System global scheduling Decide which kernel thread to schedule Decide which kernel thread to schedule Case study Solaris 2 Solaris 2 Windows 2000 Windows 2000 Linux Linux

57Ku-Yaw ChangChapter 6 CPU Scheduling 1.Basic Concepts 2.Scheduling Criteria 3.Scheduling Algorithms 4.Multiple-Processor Scheduling 5.Real-Time Scheduling 6.Algorithm Evaluation 7.Process Scheduling Models 8.Summary 9.Exercises

58Ku-Yaw ChangChapter 6 CPU Scheduling Summary P.184 to 185

59Ku-Yaw ChangChapter 6 CPU Scheduling 1.Basic Concepts 2.Scheduling Criteria 3.Scheduling Algorithms 4.Multiple-Processor Scheduling 5.Real-Time Scheduling 6.Algorithm Evaluation 7.Process Scheduling Models 8.Summary 9.Exercises

60Ku-Yaw ChangChapter 6 CPU Scheduling Exercises

The End