Deadlock Avoidance CSCI 3753 Operating Systems Spring 2005 Prof. Rick Han.

Slides:



Advertisements
Similar presentations
Chapter 7: Deadlocks.
Advertisements

Deadlock 2.
Chapter 7: Deadlocks.
Chapter 81 Deadlock is:  A set of blocked processes each holding a resource and waiting to acquire a resource held by another process in the set.  Example.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Chapter 7: Deadlocks.
Silberschatz, Galvin and Gagne  2002 Modified for CSCI 399, Royden, Operating System Concepts Operating Systems Lecture 30 Handling Deadlock.
Deadlocks CS 3100 Deadlocks1. The Deadlock Problem A set of blocked processes each holding a resource and waiting to acquire a resource held by another.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 8: Deadlocks System Model Deadlock Characterization Methods for Handling Deadlocks.
1 Wednesday, June 28, 2006 Command, n.: Statement presented by a human and accepted by a computer in such a manner as to make the human feel that he is.
Chapter 7. Deadlocks.
03/07/2007CSCI 315 Operating Systems Design1 Deadlock Notice: The slides for this lecture have been largely based on those accompanying the textbook Operating.
02/19/2008CSCI 315 Operating Systems Design1 Deadlock Notice: The slides for this lecture have been largely based on those accompanying the textbook Operating.
CS342 Operating Systemsİbrahim Körpeoğlu, Bilkent University 1 Lecture 7 Deadlocks (chapter 7) Dr. İbrahim Körpeoğlu
Chapter 7: Deadlocks. 7.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts - 7 th Edition, Feb 14, 2005 Chapter 7: Deadlocks The Deadlock.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 7: Deadlocks.
03/03/2004CSCI 315 Operating Systems Design1 Deadlock Notice: The slides for this lecture have been largely based on those accompanying the textbook Operating.
Deadlocks Gordon College Stephen Brinton. Deadlock Overview The Deadlock Problem System Model Deadlock Characterization Methods for Handling Deadlocks.
Deadlock Avoidance (brief) CSCI 3753 Operating Systems Spring 2005 Prof. Rick Han.
What we will cover…  The Deadlock Problem  System Model  Deadlock Characterization  Methods for Handling Deadlocks  Deadlock Prevention  Deadlock.
7: Deadlocks1 DEADLOCKS EXAMPLES: "It takes money to make money". You can't get a job without experience; you can't get experience without a job. BACKGROUND:
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Deadlocks.
System Model Deadlock Characterization Methods for Handling Deadlocks Deadlock Prevention, Avoidance, and Detection Recovering from Deadlock Combined Approach.
Silberschatz, Galvin and Gagne ©2013 Operating System Concepts – 9 th Edition Chapter 7: Deadlocks Modified.
Silberschatz, Galvin and Gagne ©2013 Operating System Concepts – 9 th Edition Chapter 7: Deadlocks.
Chapter 7 Deadlocks. 7.2 Modified By Dr. Khaled Wassif Operating System Concepts – 7 th Edition Silberschatz, Galvin and Gagne ©2005 Chapter 7: Deadlocks.
Cosc 4740 Chapter 6, Part 4 Deadlocks. The Deadlock Problem A set of blocked processes each holding a resource and waiting to acquire a resource held.
Computer Architecture and Operating Systems CS 3230: Operating System Section Lecture OS-6 Deadlocks Department of Computer Science and Software Engineering.
Chapter 7: Deadlocks. 7.2 Silberschatz, Galvin and Gagne ©2005 AE4B33OSS Chapter 7: Deadlocks The Deadlock Problem System Model Deadlock Characterization.
CHAPTER 8: DEADLOCKS System Model Deadlock Characterization
 The Deadlock Problem  System Model  Deadlock Characterization  Methods for Handling Deadlocks  Deadlock Prevention  Deadlock Avoidance  Deadlock.
Chapter 81 Deadlock Avoidance Technique  Resource Allocation Denial: Grant incremental resource requests if we can prove that this leaves the system in.
Chapter 7: Deadlocks. 7.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Chapter 7: Deadlocks System Model Deadlock Characterization Methods.
Lecture 12 Handling Deadlock – Prevention, avoidance and detection.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 7: Deadlocks.
Copyright © 2006 by The McGraw-Hill Companies, Inc. All rights reserved. McGraw-Hill Technology Education Lecture 7 Operating Systems.
Chapter 7: Deadlocks. 7.2CSCI 380 – Operating Systems Chapter 7: Deadlocks The Deadlock Problem System Model Deadlock Characterization Methods for Handling.
7.1 Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Chapter 7: Deadlocks The Deadlock Problem System Model Deadlock Characterization.
Chapter 7: Deadlocks. 7.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Chapter 7: Deadlocks The Deadlock Problem System Model Deadlock.
CS307 Operating Systems Deadlocks Fan Wu Department of Computer Science and Engineering Shanghai Jiao Tong University Spring 2012.
1 CS.217 Operating System By Ajarn..Sutapart Sappajak,METC,MSIT Chapter 6 Deadlocks Slide 1 Chapter 6 Deadlocks.
Deadlock A deadlock is a situation wherein two or more competing actions are waiting for the other to finish, and thus neither ever does. Example : “When.
Chapter 7: Deadlocks. 7.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Chapter 7: Deadlocks The Deadlock Problem System Model Deadlock.
Chapter 7 Deadlocks 1. Objectives and Outline Outline The Deadlock Problem System Model Deadlock Characterization Methods for Handling Deadlocks Deadlock.
CSE Operating System Principles Deadlocks. CSE – Operating System Principles2 Overview System Model Deadlock Characterization Methods for.
Deadlock. Examples You can't get a job without experience; you can't get experience without a job. A set of blocked processes each holding a resource.
Chapter 7: Deadlocks. The Deadlock Problem System Model Deadlock Characterization Methods for Handling Deadlocks Deadlock Prevention Deadlock Avoidance.
Silberschatz, Galvin and Gagne ©2013 Operating System Concepts – 9 th Edition Chapter 7: Deadlocks.
Chapter 7: Deadlocks.
OPERATING SYSTEM CONCEPTS AND PRACTISE
Process Management Deadlocks.
CSSE 332 Operating Systems Rose-Hulman Institute of Technology
Chapter 7: Deadlocks.
Chapter 7: Deadlocks.
Deadlock B.Ramamurthy CSE421 1/11/2019 B.Ramamurthy.
Outline Deadlocks, dead lock prevention, avoidance.
Deadlock Prevention Restrain the ways request can be made.
Deadlocks Session - 14.
Lecture 28 Syed Mansoor Sarwar
Deadlock B.Ramamurthy CSE421 2/23/2019 B.Ramamurthy.
Chapter 7: Deadlocks.
Deadlock B.Ramamurthy CSE421 4/23/2019 B.Ramamurthy.
Deadlock B.Ramamurthy CSE421 5/1/2019 B.Ramamurthy.
CSCI 315 Operating Systems Design
Chapter 7: Deadlocks.
Deadlock B.Ramamurthy CSE421 8/28/2019 B.Ramamurthy.
Deadlock B.Ramamurthy CSE421 9/3/2019 B.Ramamurthy.
Presentation transcript:

Deadlock Avoidance CSCI 3753 Operating Systems Spring 2005 Prof. Rick Han

Announcements HW #4 is due Tuesday March 8, 11 am –extra office hours Monday March 7, 2 pm PA #2 assigned, due Thursday March 17 11:55 pm Midterm is Thursday March 10 –covers chapter 1-10 –Midterm review is Tuesday March 8 Read chapter 10 Section this week is grader and prof

From last time... We discussed: –Deadlock Modeling –4 necessary conditions for deadlock mutex hold-and-wait no preemption circular waiting –Deadlock Prevention - ways to prevent at least 1 of these conditions from coming true

Deadlock Avoidance Each process provides OS with information about its requests and releases for resources R i –OS decides whether deadlock will occur at run time –e.g. batch jobs know a priori which resources they’ll request and when –weakness: need a priori info –simple strategy: specify a maximum claim knowing all future requests and releases is difficult estimating a maximum demand for resources for each process is easier to produce A resource allocation state is defined by –# of available resources –# of allocated resources to each process –maximum demands by each process

Deadlock Avoidance A state is safe if there exists a safe sequence of processes for the current resource allocation state –A sequence of processes is safe if for each P i in the sequence, the resource requests that P i can still make can be satisfied by: currently available resources + all resources held by all previous processes in the sequence P j, j<i –If resources needed by P i are not available, P i waits for all P j to release their resources

Deadlock Avoidance Intuition for a safe state: given that the system is in a certain state, we want to find at least one “way out of trouble” –i.e. find a sequence of processes that, even when they demand their maximum resources, won’t deadlock the system –this is a worst-case analysis it may be that during the normal execution of processes, none ever demands its maximum in a way that causes deadlock –to perform a more optimal (less than worst-case) analysis is more complex, and also requires a record of future accesses

Deadlock Avoidance A safe state provides a safe “escape” sequence A deadlocked state is unsafe An unsafe state is not necessarily deadlocked A system may transition from a safe to an unsafe state if a request for resources is granted –ideally, check with each request for resources whether the system is still safe deadlocked unsafe safe

Deadlock Avoidance Example 1: –12 instances of a resource –At time t0, P0 holds 5, P1 holds 2, P2 holds 2 –Available = 3 free instances processesmax needsallocated P0105 P142 P292

Deadlock Avoidance Example 1 (cont) –Is the system in a safe state? Can I find a safe sequence? –Yes, I claim the sequence is safe. P1 requests its maximum (currently has 2, so needs 2 more) and holds 4, then there is only 1 free resource Then P1 then releases all of its held resources, so that there are 5 free Next, suppose P0 requests its maximum (currently has 5, so needs 5 more) and holds 10, so that there are 0 free Then P0 releases all of its held resources, so that there are 10 free Next P2 requests its max of 9, leaving 3 free and then releases them all –Thus the sequence is safe, and is able in the worst-case to request maximum resources for each process in the sequence, and release all such resources for the next process in the sequence

Deadlock Avoidance Example 2: –at time t1, process P2 requests and is given 1 more instance of the resource, then processesmax needsallocated P0105 P142 P293 –Available = 2 free instances –Is the system in a safe state?

Deadlock Avoidance Example 2 (cont) –P1 can request its maximum (currently holds 2, and needs 2 more) of 4, so that there are 0 free –P1 releases all its held resources, so that available = 4 free –Neither P0 nor P2 can request their maximum resources (P0 needs 5, P2 needs 6, and there are only 4 free) Both would have to wait, so there could be deadlock –The system is deemed unsafe The mistake was granting P2 an extra resource at time t1 Forcing P2 to wait for P0 or P1 to release their resources would have avoided potential deadlock

Deadlock Avoidance Policy: before granting a request, at each step, perform a worst-case analysis - is there a safe sequence, a way out? –If so, grant request. –If not, delay requestor, and wait for more resources to be freed. Banker’s Algorithm takes this approach Resource allocation graph approach does not use a worst-case analysis (next slide), but is limited in its applicability

Deadlock Avoidance Using a Resource Allocation Graph for deadlock avoidance –each process identifies possible future claims, drawn as claim edges (dotted lines) –If converting a claim edge to a request edge creates a loop, then don’t grant request limited applicability - only valid when there is 1 instance of each resource –example: Granting P2’s request for R2 creates a loop, so don’t grant it P1P2 R2 R1 claim edge granted request creates loop claim edge

Deadlock Avoidance Banker’s Algorithm: –when there is a request, the system determines whether allocating resources for the request leaves the system in a safe state that avoids deadlock if no, then wait for another process to release resources –each process declares its maximum demands must be less than total resources in system –Advantages: generalization of earlier examples (1 and 2), to allow multiple types of resources works for multiple instances of resources, unlike resource allocation graph adapts at run time to individual requests, avoids deadlock individual requests don’t need to be known a priori, except for maximum demands, which is not completely unrealistic

Deadlock Avoidance Banker’s Algorithm: –Define quantities: Available resources in a vector or list Available[j], j=1,...,m resource types –Available[j] = k means that there are k instances of resource R j available Maximum demands in a matrix or table Max[i,j], where i=1,...,n processes, and j=1,...,m resource types –Max[i,j] = k means that process i’s maximum demands are for k instances of resource R j Allocated resources in a matrix Alloc[i,j] –Alloc[i,j] = k means that process i is currently allocated k instances of resource R j Needed resources in a matrix Need[i,j] = Max[i,j] - Alloc[i,j]

Deadlock Avoidance Banker’s Algorithm: –An example of the Alloc[i,j] matrix: Row i Column j Resources Processes Alloc i is shorthand for row i of matrix Alloc[i,j], i.e. the resources allocated to process i

Deadlock Avoidance Banker’s Algorithm: –Some terminology: let X and Y be two vectors. Then we say X ≤ Y if and only if X[i] ≤ Y[i] for all i. Example: V1 = V2 = V3 = then V2 ≤ V1, but V3 ≤ V1, i.e. V3 is not less than or equal to V1

Deadlock Avoidance Banker’s (Safety) Algorithm: find a safe sequence, i.e. is the system in a safe state? 1.Let Work and Finish be vectors length m and n respectively. Initialize Work = Available, and Finish[i]=false for i=0,...,n-1 2.Find a process i such that both Finish[i]==false, and Need i ≤ Work If no such i exists, go to step 4. 3.Work = Work + Alloc i Finish[i] = true Go to step If Finish[i]==true for all i, then the system is in a safe state Intuition: if all prior processes give up all their resources, is there enough to meet the max needs of next process in the sequence?

Deadlock Avoidance Example 3: –3 resources (A,B,C) with total instances available (10,5,7) –5 processes –At time t0, the allocated resources Alloc[i,j], Max needs Max[i,j], and Available resources Avail[j], are: Alloc[i,j] A B C P0 P1 P2 P3 P4 Max[i,j] A B C Avail[j] A B C Need[i,j] A B C where Need[i,j] is computed given Alloc[i,j] and Max[i,j]

Deadlock Avoidance Example 3 (cont) –Execute Banker's Algorithm - is the system in a safe state? is there a safe sequence? –Yes, I claim the sequence is safe Both P1 and P3 have needs that can be satisfied by what is available. Select P1. –P1's Need 1 = ≤ Available = –P1 takes all that it needs, then releases all held resources, which equals its maximum demands. So update Available' = Available -Need 1 + Max 1 = Available + Alloc 1, which we're tracking with Work in the algorithm = + = Next select P3 whose Need 3 = ≤ Work = Available' = –P3 takes all it needs, and releases its maximum claim, so »Work = Available '' = Available' + Alloc 3 = + = If we look at the remaining process's needs P0, P2, and P4, we see that they all satisfy Need i ≤ Work = Available'', so we can satisfy their needs in any order, say P4, P2, P0. Thus, the sequence is safe.

Deadlock Avoidance Complexity of Banker’s Algorithm is order O(m*n 2 ) –If there are n processes, then in the worst case the processes are ordered such that each iteration of the banker’s algorithm must evaluate all remaining processes before the last one satisfies Need i ≤ Work the 1 st time, n processes have to compare if their Need i ≤ Work the 2 nd time, n-1 processes have to be compared Thus, in the worst case, there are n + (n-1) + (n-2) = n(n+1)/2 comparisons, which is proportional to n 2 complexity Each vector comparison requires m individual comparisons, since there are m resource types, so total complexity is O(m*n 2 )

Deadlock Avoidance Questions about Banker’s Algorithm: –If it finds a safe sequence, are there other safe sequences, i.e. is the safe sequence that is found unique? The safe sequence is not necessarily unique. There may be others. –Simple case is if two processes P1 and P2 both can have their max needs satisfied by available resources, then one safe sequence is, and another safe sequence is

Deadlock Avoidance Questions about Banker’s Algorithm (cont): –If a safe sequence is not found, could we reorder our search to find another safe sequence? do we have to search exhaustively all possible sequences and/or backtrack our search? I haven’t found a clear answer in all the information sources I’ve looked at Here’s my best guess: no amount of reordering will find a safe sequence if a safe sequence couldn’t be found the first time, so we don’t have to search exhaustively or backtrack –This is because each step of the algorithm only releases more resources. At each step, I am expanding the number of processes whose needs can be met by what has been cumulatively released by the previous processes. The order of process releases that we reach a given quantity of released (available) resources does not matter. –example: suppose there are 3 processes. We run B.A. and it selects P0 first whose max needs can be met (acquires and releases its max resources, increasing the number of available resources). Now suppose neither P1 nor P2 can satisfy their max needs. So we have not found a safe sequence yet. If we run the banker’s algorithm again, and try to select P1 or P2 instead of P0, we see that neither P1 nor P2 could possibly have their needs met since there are even fewer resources than before (P0 has not released its currently held resources). Thus my claim is that if B.A. can’t find a safe sequence the first time, then no amount of reordering will find another safe sequence.