1 CPU Scheduling & Deadlock Operating Systems Lecture 4.

Slides:



Advertisements
Similar presentations
Advanced Operating Systems
Advertisements

Chapter 9 Uniprocessor Scheduling Operating Systems: Internals and Design Principles, 6/E William Stallings Patricia Roy Manatee Community College, Venice,
1 Uniprocessor Scheduling Types of scheduling –The aim of processor scheduling is to assign processes to be executed by the processor so as to optimize.
A. Frank - P. Weisberg Operating Systems Advanced 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 9 Uniprocessor Scheduling Operating Systems: Internals and Design Principles, 6/E William Stallings Dave Bremer Otago Polytechnic, N.Z. ©2008,
Chapter 9 Uniprocessor Scheduling Operating Systems: Internals and Design Principles, 6/E William Stallings Dave Bremer Otago Polytechnic, N.Z. ©2008,
Ceng Operating Systems Chapter 2.2 : Process Scheduling Process concept  Process scheduling Interprocess communication Deadlocks Threads.
Day 25 Uniprocessor scheduling. Algorithm: Selection function Selection function – which process among ready processes to select. w – time spent in system,
Chapter 3: CPU Scheduling
Scheduling in Batch Systems
Uniprocessor Scheduling Chapter 9. Aim of Scheduling The key to multiprogramming is scheduling Scheduling is done to meet the goals of –Response time.
6/25/2015Page 1 Process Scheduling B.Ramamurthy. 6/25/2015Page 2 Introduction An important aspect of multiprogramming is scheduling. The resources that.
1 Uniprocessor Scheduling Module CPU Scheduling n We concentrate on the problem of scheduling the usage of a single processor among all the existing.
Chapter 5-CPU Scheduling
1 Uniprocessor Scheduling Chapter 9. 2 Aims of Scheduling Assign processes to be executed by the processor(s) Response time Throughput Processor efficiency.
A. Frank - P. Weisberg Operating Systems CPU Scheduling.
7/12/2015Page 1 Process Scheduling B.Ramamurthy. 7/12/2015Page 2 Introduction An important aspect of multiprogramming is scheduling. The resources that.
1 Lecture 10: Uniprocessor Scheduling. 2 CPU Scheduling n The problem: scheduling the usage of a single processor among all the existing processes in.
1Chapter 05, Fall 2008 CPU Scheduling The CPU scheduler (sometimes called the dispatcher or short-term scheduler): Selects a process from the ready queue.
1 Uniprocessor Scheduling Chapter 9. 2 Aim of Scheduling Main Job: Assign processes to be executed by the processor(s) and processes to be loaded in main.
Uniprocessor Scheduling
CPU Scheduling Chapter 6 Chapter 6.
Chapter 6: CPU Scheduling
Computer Architecture and Operating Systems CS 3230: Operating System Section Lecture OS-3 CPU Scheduling Department of Computer Science and Software Engineering.
10CSE CPU Scheduling Copyrights Lecture Slides adapted from “ Advanced Operating Systems ”, Lecture Notes by Prof. Prof. Daniel Mosse, University Of Pittsburgh,
CS212: OPERATING SYSTEM Lecture 3: Process Scheduling 1.
1 Uniprocessor Scheduling Chapter 9. 2 CPU Scheduling We concentrate on the problem of scheduling the usage of a single processor among all the existing.
Chapter 9 Uniprocessor Scheduling Spring, 2011 School of Computer Science & Engineering Chung-Ang University.
Chapter 9 Uniprocessor Scheduling Operating Systems: Internals and Design Principles, 6/E William Stallings Patricia Roy Manatee Community College, Venice,
Chapter 9 Uniprocessor Scheduling Operating Systems: Internals and Design Principles, 6/E William Stallings Patricia Roy Manatee Community College, Venice,
Chapter 6 CPU SCHEDULING.
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.
Operating System Chapter 9. Uniprocessor Scheduling
Uniprocessor Scheduling Chapter 9. Aim of Scheduling To improve: Response time: time it takes a system to react to a given input Turnaround Time (TAT)
Uniprocessor Scheduling Chapter 9. Aim of Scheduling Minimize response time Maximize throughput Maximize processor efficiency.
1 Our focus  scheduling a single CPU among all the processes in the system  Key Criteria: Maximize CPU utilization Maximize throughput Minimize waiting.
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.
1 Uniprocessor Scheduling Chapter 9. 2 CPU Scheduling n We concentrate on the problem of scheduling the usage of a single processor among all the existing.
Lecture 7: Scheduling preemptive/non-preemptive scheduler CPU bursts
1 Uniprocessor Scheduling Chapter 9. 2 Aim of Scheduling Response time Throughput Processor efficiency.
Uniprocessor Scheduling Chapter 9. Aim of Scheduling Response time Throughput Processor efficiency.
Uniprocessor Scheduling
Uniprocessor Scheduling Chapter 9. Processor Scheduling Processor scheduling determines the assignment of processes to be executed by the processor over.
Chapter 5: Process Scheduling. 5.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Basic Concepts Maximum CPU utilization can be obtained.
Uniprocessor Scheduling Chapter 9. Aim of Scheduling Assign processes to be executed by the processor or processors: –Response time –Throughput –Processor.
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.
Chapter 9 Uniprocessor Scheduling Operating Systems: Internals and Design Principles, 6/E William Stallings Dave Bremer Otago Polytechnic, N.Z. ©2008,
Lecture 4 CPU scheduling. Basic Concepts Single Process  one process at a time Maximum CPU utilization obtained with multiprogramming CPU idle :waiting.
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.
Lecturer 5: Process Scheduling Process Scheduling  Criteria & Objectives Types of Scheduling  Long term  Medium term  Short term CPU Scheduling Algorithms.
1 Chapter 5: CPU Scheduling. 2 Basic Concepts Scheduling Criteria Scheduling Algorithms.
1 Uniprocessor Scheduling Chapter 9. 2 Aim of Scheduling Assign processes to be executed by the processor(s) Response time Throughput Processor efficiency.
Uniprocessor Scheduling
CPU Scheduling Chapter 5.
Uniprocessor Scheduling
Operating Systems CPU Scheduling.
Chapter 6: CPU Scheduling
Uniprocessor Scheduling
Chapter 9 Uniprocessor Scheduling
Uniprocessor Scheduling
Presentation transcript:

1 CPU Scheduling & Deadlock Operating Systems Lecture 4

OS1 - Lecture 2 – Scheduling – Paul Flynn 2 Process Management n Concept of a Process n Context-Change n Process Life Cycle n Process Creation n Process Spawning

OS1 - Lecture 2 – Scheduling – Paul Flynn 3 Process State Diagrams n Three State Model u Ready u Running u Blocked n Five State Model u Ready u Running u Blocked u Ready Suspended u Blocked Suspended

OS1 - Lecture 2 – Scheduling – Paul Flynn 4 CPU Scheduling n Scheduling the processor among all ready processes n The goal is to achieve: u High processor utilization u High throughput F number of processes completed per of unit time u Low response time F time elapsed from the submission of a request until the first response is produced

OS1 - Lecture 2 – Scheduling – Paul Flynn 5 Classification of Scheduling Activity n Long-term: which process to admit? n Medium-term: which process to swap in or out? n Short-term: which ready process to execute next?

OS1 - Lecture 2 – Scheduling – Paul Flynn 6 Queuing Diagram for Scheduling

OS1 - Lecture 2 – Scheduling – Paul Flynn 7 Long-Term Scheduling n Determines which programs are admitted to the system for processing n Controls the degree of multiprogramming n Attempts to keep a balanced mix of processor-bound and I/O-bound processes u CPU usage u System performance

OS1 - Lecture 2 – Scheduling – Paul Flynn 8 Medium-Term Scheduling n Makes swapping decisions based on the current degree of multiprogramming u Controls which remains resident in memory and which jobs must be swapped out to reduce degree of multiprogramming

OS1 - Lecture 2 – Scheduling – Paul Flynn 9 Short-Term Scheduling n Selects from among ready processes in memory which one is to execute next u The selected process is allocated the CPU n It is invoked on events that may lead to choose another process for execution: u Clock interrupts u I/O interrupts u Operating system calls and traps u Signals

OS1 - Lecture 2 – Scheduling – Paul Flynn 10 Characterization of Scheduling Policies n The selection function determines which ready process is selected next for execution n The decision mode specifies the instants in time the selection function is exercised u Nonpreemptive F Once a process is in the running state, it will continue until it terminates or blocks for an I/O u Preemptive F Currently running process may be interrupted and moved to the Ready state by the OS F Prevents one process from monopolizing the processor

OS2 - Lecture 2 – Scheduling – Paul Flynn 11 Short-Term Scheduler Dispatcher n The dispatcher is the module that gives control of the CPU to the process selected by the short-term scheduler n The functions of the dispatcher include: u Switching context u Switching to user mode u Jumping to the location in the user program to restart execution n The dispatch latency must be minimal

OS1 - Lecture 2 – Scheduling – Paul Flynn 12 The CPU-I/O Cycle n Processes require alternate use of processor and I/O in a repetitive fashion n Each cycle consist of a CPU burst followed by an I/O burst u A process terminates on a CPU burst n CPU-bound processes have longer CPU bursts than I/O-bound processes

OS1 - Lecture 2 – Scheduling – Paul Flynn 13 Short-Term Scheduling Criteria n User-oriented criteria u Response Time: Elapsed time between the submission of a request and the receipt of a response u Turnaround Time: Elapsed time between the submission of a process to its completion n System-oriented criteria u Processor utilization u Throughput: number of process completed per unit time u fairness

OS1 - Lecture 2 – Scheduling – Paul Flynn 14 Scheduling Algorithms n First-Come, First-Served Scheduling n Shortest-Job-First Scheduling u Also referred to as Shortest Job Next n Highest Response Ratio Next (HRN) n Shortest Remaining Time (SRT) n Round-Robin Scheduling n Multilevel Feedback Queue Scheduling

OS1 - Lecture 2 – Scheduling – Paul Flynn 15 Process Mix Example Process Arrival Time Service Time Service time = total processor time needed in one (CPU-I/O) cycle Jobs with long service time are CPU-bound jobs and are referred to as “long jobs”

OS1 - Lecture 2 – Scheduling – Paul Flynn 16 First Come First Served (FCFS) n Selection function: the process that has been waiting the longest in the ready queue (hence, FCFS) n Decision mode: non-preemptive u a process runs until it blocks for an I/O

OS1 - Lecture 2 – Scheduling – Paul Flynn 17 FCFS drawbacks n Favors CPU-bound processes u A CPU-bound process monopolizes the processor u I/O-bound processes have to wait until completion of CPU-bound process F I/O-bound processes may have to wait even after their I/Os are completed (poor device utilization) u Better I/O device utilization could be achieved if I/O bound processes had higher priority

OS1 - Lecture 2 – Scheduling – Paul Flynn 18 Shortest Job First ( Shortest Process Next ) n Selection function: the process with the shortest expected CPU burst time u I/O-bound processes will be selected first n Decision mode: non-preemptive n The required processing time, i.e., the CPU burst time, must be estimated for each process

OS1 - Lecture 2 – Scheduling – Paul Flynn 19 SJF / SPN Critique n Possibility of starvation for longer processes n Lack of preemption is not suitable in a time sharing environment n SJF/SPN implicitly incorporates priorities u Shortest jobs are given preferences u CPU bound process have lower priority, but a process doing no I/O could still monopolize the CPU if it is the first to enter the system

OS1 - Lecture 2 – Scheduling – Paul Flynn 20 Highest Response Ratio Next (HRN) n Based on SJF with formula introduced n Priority Based - P n Time Waiting + Run Time / Run Time = P n The process with the HIGHEST Priority will be selected for running n Non-Preemptive n Reduces SJF bias against Short Jobs

OS1 - Lecture 2 – Scheduling – Paul Flynn 21 Priorities n Implemented by having multiple ready queues to represent each level of priority n Scheduler the process of a higher priority over one of lower priority n Lower-priority may suffer starvation n To alleviate starvation allow dynamic priorities u The priority of a process changes based on its age or execution history

OS1 - Lecture 2 – Scheduling – Paul Flynn 22 n Selection function: same as FCFS n Decision mode: preemptive u a process is allowed to run until the time slice period (quantum, typically from 10 to 100 ms) has expired u a clock interrupt occurs and the running process is put on the ready queue Round-Robin

OS1 - Lecture 2 – Scheduling – Paul Flynn 23 RR Time Quantum n Quantum must be substantially larger than the time required to handle the clock interrupt and dispatching n Quantum should be larger then the typical interaction u but not much larger, to avoid penalizing I/O bound processes

OS1 - Lecture 2 – Scheduling – Paul Flynn 24 Round Robin: critique n Still favors CPU-bound processes u An I/O bound process uses the CPU for a time less than the time quantum before it is blocked waiting for an I/O u A CPU-bound process runs for all its time slice and is put back into the ready queue F May unfairly get in front of blocked processes

OS1 - Lecture 2 – Scheduling – Paul Flynn 25 Multilevel Feedback Scheduling n Preemptive scheduling with dynamic priorities n N ready to execute queues with decreasing priorities: n Dispatcher selects a process for execution from RQ i only if RQ i-1 to RQ 0 are empty

OS1 - Lecture 2 – Scheduling – Paul Flynn 26 Multilevel Feedback Scheduling n New process are placed in RQ 0 n After the first quantum, they are moved to RQ 1 after the first quantum, and to RQ 2 after the second quantum, … and to RQ N after the Nth quantum n I/O-bound processes remain in higher priority queues. u CPU-bound jobs drift downward. u Hence, long jobs may starve

OS1 - Lecture 2 – Scheduling – Paul Flynn 27 Multiple Feedback Queues Different RQs may have different quantum values

OS1 - Lecture 2 – Scheduling – Paul Flynn 28 Algorithm Comparison n Which one is the best? n The answer depends on many factors: u the system workload (extremely variable) u hardware support for the dispatcher u relative importance of performance criteria (response time, CPU utilization, throughput...) u The evaluation method used (each has its limitations...)

29 Deadlocks 3.1. Resource 3.2. Introduction to deadlocks 3.3. The ostrich algorithm 3.4. Deadlock detection and recovery 3.5. Deadlock avoidance 3.6. Deadlock prevention 3.7. Other issues

30 Deadlock Recap n Process is deadlocked if it is waiting for an event that will never occur n Most common situation is where two processes are involved on is holding resource required by the other and also looking for resource held by the other process.

31 Deadlock Example n Airline booking example. Alan wants to books seat on flight AB123 so locks this file. Same time Brian wants to book flight on AB456 and locks this file. Alan wants to book return flight on AB456 and Brian wants to book return flight on AB123. No each user as a file locked and is requesting a file locked by the other.

32 Deadlock Example cont n Alan locks AB123 n Brian lock AB456 n Alan requests AB456 n Brian requests AB123

33 Conditions for deadlock n There are 4 conditions necessary for deadlock u Mutual exclusion u Resource holding u No premption u Circular wait

34 Conditions explained n Mutual Exclusion only one process can use a resource at a time n Resource holding process can hold a resource while requesting another n No premption resources cannot be forcibly removed from a process n Circular wait closed circle exists where each process is holding a resource required by another.

35 Dealing with deadlock n Three ways of dealing with deadlocks u Deadlock prevention u Deadlock avoidance u Deadlock detection

36 Deadlock prevention n Prevent any one of the 4 conditions from occuring will prevent deadlock n Mutual exclusion – cannot prevent n Resource holding – to prevent this a process must be allocated all it resources at once called one shot allocation very inefficient. Process may have to wait for resources it might not need. Process may hold resources for long time without using.

37 Deadlock prevention cont n No premption to deny this condition two ways u If a process is holding a resource requests another it could be forces to give up the resource it is holding. u A resources required by a process and held by a second could be forcibly removed from the second. Not possible with serially reusable resources.

38 Deadlock prevention n Circular wait – this condition can be prevented if resources are organsied in a particual order and require that resources follow an order.

39 Deadlock avoidance n Deadlock prevention means that deadlock will not occur due to fact that we deny one of the 4 conditions necessary. Innefficient n Deadlock avoidance attempts to predict the possibility of deadlock as each resources request is made. n Example if process A requests a resource held by process B then make sure that process B is not waiting for resource held by A

40 Bankers Algorithm n The most common method of deadlock avoidance is to use the bankers algorithm. Uses banking anology, banker will only grant loan if he can meet the needs of customers based on their projected future loan requirements. n Example three processes P1,P2 & P3 and 10 resources available. Table shows requirements

41 Example cont. n ProcessMax needCurrent usage P183 P251 P382 Total maximum needs =21 means that allocation cannot be met at one time. We need a sequence of allocations which will allow all processes to finish. If we start with P2 when it is finished it will release 5 resources. Next if we allow P1 to run it will release 8 resources and so P3 will be able to finish.

42 Problems with deadlock avoidance n Each process has to pre-declare its maximum rersource requirements. This is not realistic for interactive systems. n The avoidance algorithm must be executed every time a resource request is made. For a multi-user system with a large number of user processes, the processing overhead would be severe.

43 Deadlock detection n A deadlock detection strategy accepts the risk of deadlock occuring and periodically executes a procedure to detect any in place. n Breaking a deadlock implies that a process must be aborted or resources prempted from processes, either could result in loss of work.