SlideShare una empresa de Scribd logo
1 de 30
Chapter 3: Deadlocks




                 Chapter 3
Overview
     Resources
     Why do deadlocks occur?
     Dealing with deadlocks
             Ignoring them: ostrich algorithm
             Detecting & recovering from deadlock
             Avoiding deadlock
             Preventing deadlock




CS 1550, cs.pitt.edu                   Chapter 3     2
(originaly modified by Ethan
Resources
     Resource: something a process uses
             Usually limited (at least somewhat)
     Examples of computer resources
             Printers
             Semaphores / locks
             Tables (in a database)
     Processes need access to resources in reasonable order
     Two types of resources:
             Preemptable resources: can be taken away from a process with no ill
              effects
             Nonpreemptable resources: will cause the process to fail if taken away




CS 1550, cs.pitt.edu                          Chapter 3                        3
(originaly modified by Ethan
When do deadlocks happen?
     Suppose
             Process 1 holds resource A
              and requests resource B                      Process 1   Process 2
             Process 2 holds B and
              requests A                                      A
             Both can be blocked, with
              neither able to proceed                                      B
     Deadlocks occur when …
             Processes are granted                                        A
              exclusive access to devices or
              software constructs                             B
              (resources)
             Each deadlocked process
              needs a resource held by                      DEADLOCK!
              another deadlocked process


CS 1550, cs.pitt.edu                           Chapter 3                       4
(originaly modified by Ethan
Using resources
     Sequence of events required to use a resource
             Request the resource
             Use the resource
             Release the resource
       Can’t use the resource if request is denied
             Requesting process has options
                     Block and wait for resource
                     Continue (if possible) without it: may be able to use an alternate
                      resource
                     Process fails with error code
             Some of these may be able to prevent deadlock…


CS 1550, cs.pitt.edu                               Chapter 3                         5
(originaly modified by Ethan
What is a deadlock?
     Formal definition:
      “A set of processes is deadlocked if each process in
      the set is waiting for an event that only another
      process in the set can cause.”
     Usually, the event is release of a currently held
      resource
     In deadlock, none of the processes can
             Run
             Release resources
             Be awakened


CS 1550, cs.pitt.edu              Chapter 3             6
(originaly modified by Ethan
Four conditions for deadlock
     Mutual exclusion
             Each resource is assigned to at most one process
     Hold and wait
             A process holding resources can request more resources
     No preemption
             Previously granted resources cannot be forcibly taken
              away
     Circular wait
             There must be a circular chain of 2 or more processes
              where each is waiting for a resource held by the next
              member of the chain

CS 1550, cs.pitt.edu                    Chapter 3                     7
(originaly modified by Ethan
Resource allocation graphs
                                               Resource allocation
A                                  B            modeled by directed graphs
                                               Example 1:
                                                      Resource R assigned to
R                                  S                   process A
                                               Example 2:
                                                      Process B is requesting /
                                                       waiting for resource S
                             T                 Example 3:
                                                      Process C holds T, waiting
C                                      D               for U
                                                      Process D holds U, waiting
                             U                         for T
                                                      C and D are in deadlock!
    CS 1550, cs.pitt.edu                   Chapter 3                               8
    (originaly modified by Ethan
Dealing with deadlock
     How can the OS deal with deadlock?
             Ignore the problem altogether!
                     Hopefully, it’ll never happen…
             Detect deadlock & recover from it
             Dynamically avoid deadlock
                     Careful resource allocation
             Prevent deadlock
                     Remove at least one of the four necessary conditions
     We’ll explore these tradeoffs




CS 1550, cs.pitt.edu                                Chapter 3                9
(originaly modified by Ethan
Getting into deadlock
                     A                 B                      C
            Acquire            R   Acquire   S         Acquire    T
            Acquire            S   Acquire   T         Acquire    R
            Release            R   Release   S         Release    T
            Release            S   Release   T         Release    R


         A           B         C   A   B       C       A      B    C


         R           S         T   R   S       T       R      S    T
            Acquire R              Acquire S           Acquire T

         A           B         C   A   B       C       A      B    C


         R           S         T   R   S       T       R      S    T
                                                           Deadlock!
            Acquire S              Acquire T
                                                       Acquire R
CS 1550, cs.pitt.edu                       Chapter 3                   10
(originaly modified by Ethan
Not getting into deadlock…
     Many situations may result in deadlock (but don’t
      have to)
             In previous example, A could release R before C requests
              R, resulting in no deadlock
             Can we always get out of it this way?
     Find ways to:
             Detect deadlock and reverse it
             Stop it from happening in the first place




CS 1550, cs.pitt.edu                     Chapter 3                11
(originaly modified by Ethan
The Ostrich Algorithm
     Pretend there’s no problem
     Reasonable if
             Deadlocks occur very rarely
             Cost of prevention is high
     UNIX and Windows take this approach
             Resources (memory, CPU, disk space) are plentiful
             Deadlocks over such resources rarely occur
             Deadlocks typically handled by rebooting
     Trade off between convenience and correctness



CS 1550, cs.pitt.edu                   Chapter 3                  12
(originaly modified by Ethan
Detecting deadlocks using graphs
              Process holdings and requests in the table and in the graph
               (they’re equivalent)
              Graph contains a cycle => deadlock!
                     Easy to pick out by looking at it (in this case)
                     Need to mechanically detect deadlock
              Not all processes are deadlocked (A, C, F not in deadlock)
                                       R        A                   B
Process       Holds     Wants

A             R         S              C        S        D          T    E
B                       T
C                       S
D             U         S,T                     F        U               V
E             T         V
F             W         S
G             V         U                       W        G
      CS 1550, cs.pitt.edu                              Chapter 3            13
      (originaly modified by Ethan
Deadlock detection algorithm
     General idea: try to find           For each node N in the graph {
      cycles in the resource                Set L = empty list
                                            unmark all arcs
      allocation graph                      Traverse (N,L)
                                         }
      Algorithm: depth-first              If no deadlock reported by now,
      search at each node                 there isn’t any
             Mark arcs as they’re
                                             define Traverse (C,L) {
              traversed                        If C in L, report deadlock!
             Build list of visited nodes      Add C to L
             If node to be added is already   For each unmarked arc from C {
                                                 Mark the arc
              on the list, a cycle exists!       Set A = arc destination
     Cycle == deadlock                           /* NOTE: L is a
                                                     local variable */
                                                  Traverse (A,L)
                                              }
                                          }

CS 1550, cs.pitt.edu                       Chapter 3                     14
(originaly modified by Ethan
Resources with multiple instances
     Previous algorithm only works if there’s one
      instance of each resource
     If there are multiple instances of each resource, we
      need a different method
             Track current usage and requests for each process
             To detect deadlock, try to find a scenario where all
              processes can finish
             If no such scenario exists, we have deadlock




CS 1550, cs.pitt.edu                     Chapter 3                   15
(originaly modified by Ethan
Deadlock detection algorithm

                          A B C D             current=avail;
                                              for (j = 0; j < N; j++) {
          Avail           2 3 0 1              for (k=0; k<N; k++) {
                                                if (finished[k])
                                                 continue;
         Process A B C D                        if (want[k] < current) {
                                                 finished[k] = 1;
Hold




               1           0 3        0   0      current += hold[k];
                                                 break;
               2           1 0        1   1     }
               3           0 2        1   0     if (k==N) {
               4           2 2        3   0      printf “Deadlock!n”;
         Process A B C D                         // finished[k]==0 means process is in
                                                 // the deadlock
                                                 break;
Want




               1           3 2        1   0     }
               2           2 2        0   0   }
               3           3 5        3   1
                                              Note: want[j],hold[j],current,avail are arrays!
               4           0 4        1   1
       CS 1550, cs.pitt.edu                                 Chapter 3                           16
       (originaly modified by Ethan
Recovering from deadlock
     Recovery through preemption
             Take a resource from some other process
             Depends on nature of the resource and the process
     Recovery through rollback
             Checkpoint a process periodically
             Use this saved state to restart the process if it is found deadlocked
             May present a problem if the process affects lots of “external” things
     Recovery through killing processes
             Crudest but simplest way to break a deadlock: kill one of the
              processes in the deadlock cycle
             Other processes can get its resources
             Preferably, choose a process that can be rerun from the beginning
                     Pick one that hasn’t run too far already


CS 1550, cs.pitt.edu                                  Chapter 3                 17
(originaly modified by Ethan
Resource trajectories




                               Two process resource trajectories
CS 1550, cs.pitt.edu                            Chapter 3          18
(originaly modified by Ethan
Safe and unsafe states
    Has Max                             Has Max            Has Max                       Has Max           Has Max

A    3          9                A       3        9    A    3        9               A    3        9   A    3        9
B    2          4                B       4        4    B    0        -               B    0        -   B    0        -
C    2          7                C       2        7    C    2        7               C    7        7   C    0        -
    Free: 3                             Free: 1            Free: 5                       Free: 0           Free: 7
                                          Demonstration that the first state is safe


    Has Max                             Has Max            Has Max                       Has Max

A    3          9                A       4        9    A    4        9               A    4        9
B    2          4                B       2        4    B    4        4               B    0        -
C    2          7                C       2        7    C    2        7               C    2        7
    Free: 3                             Free: 2            Free: 0                       Free: 4
                                    Demonstration that the second state is unsafe

         CS 1550, cs.pitt.edu                                            Chapter 3                               19
         (originaly modified by Ethan
Banker's Algorithm for a single resource
             Has Max                Has Max                       Has Max

       A       0          6     A   1     6                   A   1    6
       B       0          5     B   1     5                   B   2    5
       C       0          4     C   2     4                   C   2    4
       D       0          7     D   4     7                   D   4    7
      Free: 10                     Free: 2                     Free: 1
Any sequence finishes          C,B,A,D finishes          Deadlock (unsafe state)

     Bankers’ algorithm: before granting a request, ensure that a
      sequence exists that will allow all processes to complete
             Use previous methods to find such a sequence
             If a sequence exists, allow the requests
             If there’s no such sequence, deny the request
     Can be slow: must be done on each request!

CS 1550, cs.pitt.edu                              Chapter 3                        20
(originaly modified by Ethan
Banker's Algorithm for multiple resources




      Example of banker's algorithm with multiple resources

CS 1550, cs.pitt.edu               Chapter 3                  21
(originaly modified by Ethan
Preventing deadlock
     Deadlock can be completely prevented!
     Ensure that at least one of the conditions for
      deadlock never occurs
             Mutual exclusion
             Circular wait
             Hold & wait
             No preemption
     Not always possible…




CS 1550, cs.pitt.edu             Chapter 3             22
(originaly modified by Ethan
Eliminating mutual exclusion
     Some devices (such as printer) can be spooled
             Only the printer daemon uses printer resource
             This eliminates deadlock for printer
     Not all devices can be spooled
     Principle:
             Avoid assigning resource when not absolutely necessary
             As few processes as possible actually claim the resource




CS 1550, cs.pitt.edu                    Chapter 3                  23
(originaly modified by Ethan
Attacking “hold and wait”
     Require processes to request resources before starting
             A process never has to wait for what it needs
     This can present problems
             A process may not know required resources at start of run
             This also ties up resources other processes could be using
                     Processes will tend to be conservative and request resources they might
                      need
     Variation: a process must give up all resources before making
      a new request
             Process is then granted all prior resources as well as the new ones
             Problem: what if someone grabs the resources in the meantime—how
              can the process save its state?



CS 1550, cs.pitt.edu                                 Chapter 3                           24
(originaly modified by Ethan
Attacking “no preemption”
     This is not usually a viable option
     Consider a process given the printer
             Halfway through its job, take away the printer
             Confusion ensues!
     May work for some resources
             Forcibly take away memory pages, suspending the process
             Process may be able to resume with no ill effects




CS 1550, cs.pitt.edu                          Chapter 3                 25
(originaly modified by Ethan
Attacking “circular wait”
     Assign an order to
      resources
                                                                  D
      Always acquire resources in
      numerical order
             Need not acquire them all at
              once!                                                C
     Circular wait is prevented                               3       2
             A process holding resource n
              can’t wait for resource m                            B
              if m < n
                                                                      1
              No way to complete a cycle
                     Place processes above the
                      highest resource they hold                   A
                      and below any they’re
                      requesting
                     All arrows point up!

CS 1550, cs.pitt.edu                               Chapter 3               26
(originaly modified by Ethan
Deadlock prevention: summary
     Mutual exclusion
             Spool everything
     Hold and wait
             Request all resources initially
     No preemption
             Take resources away
     Circular wait
             Order resources numerically




CS 1550, cs.pitt.edu                      Chapter 3   27
(originaly modified by Ethan
Example: two-phase locking
     Phase One
             Process tries to lock all data it needs, one at a time
             If needed data found locked, start over
             (no real work done in phase one)
     Phase Two
             Perform updates
             Release locks
     Note similarity to requesting all resources at once
     This is often used in databases
     It avoids deadlock by eliminating the “hold-and-
      wait” deadlock condition
CS 1550, cs.pitt.edu                      Chapter 3                    28
(originaly modified by Ethan
“Non-resource” deadlocks
     Possible for two processes to deadlock
             Each is waiting for the other to do some task
     Can happen with semaphores
             Each process required to do a down() on two semaphores
              (mutex and another)
             If done in wrong order, deadlock results
     Semaphores could be thought of as resources…




CS 1550, cs.pitt.edu                     Chapter 3               29
(originaly modified by Ethan
Starvation
     Algorithm to allocate a resource
             Give the resource to the shortest job first
     Works great for multiple short jobs in a system
     May cause long jobs to be postponed indefinitely
             Even though not blocked
     Solution
             First-come, first-serve policy
     Starvation can lead to deadlock
             Process starved for resources can be holding resources
             If those resources aren’t used and released in a timely
              fashion, shortage could lead to deadlock
CS 1550, cs.pitt.edu                      Chapter 3                 30
(originaly modified by Ethan

Más contenido relacionado

Similar a Amer deadlocks (15)

Dead Lock
Dead LockDead Lock
Dead Lock
 
FP 202 Chapter 2 - Part 3
FP 202 Chapter 2 - Part 3FP 202 Chapter 2 - Part 3
FP 202 Chapter 2 - Part 3
 
Section07-Deadlocks (1).ppt
Section07-Deadlocks (1).pptSection07-Deadlocks (1).ppt
Section07-Deadlocks (1).ppt
 
Section07-Deadlocks_operating_system.ppt
Section07-Deadlocks_operating_system.pptSection07-Deadlocks_operating_system.ppt
Section07-Deadlocks_operating_system.ppt
 
Deadlocks.ppt
Deadlocks.pptDeadlocks.ppt
Deadlocks.ppt
 
CH07.pdf
CH07.pdfCH07.pdf
CH07.pdf
 
OS - Deadlock
OS - DeadlockOS - Deadlock
OS - Deadlock
 
Deadlocks final
Deadlocks finalDeadlocks final
Deadlocks final
 
Section07-Deadlocks.pdf
Section07-Deadlocks.pdfSection07-Deadlocks.pdf
Section07-Deadlocks.pdf
 
Operating System Deadlock Galvin
Operating System  Deadlock GalvinOperating System  Deadlock Galvin
Operating System Deadlock Galvin
 
Deadlock Detection Algorithm
Deadlock Detection AlgorithmDeadlock Detection Algorithm
Deadlock Detection Algorithm
 
Deadlocks prefinal
Deadlocks prefinalDeadlocks prefinal
Deadlocks prefinal
 
Deadlocksprefinal 161014115456
Deadlocksprefinal 161014115456Deadlocksprefinal 161014115456
Deadlocksprefinal 161014115456
 
Mch7 deadlock
Mch7 deadlockMch7 deadlock
Mch7 deadlock
 
Dead Lock In Operating Systems
Dead Lock In Operating SystemsDead Lock In Operating Systems
Dead Lock In Operating Systems
 

Más de Mohd Arif

Bootp and dhcp
Bootp and dhcpBootp and dhcp
Bootp and dhcp
Mohd Arif
 
Arp and rarp
Arp and rarpArp and rarp
Arp and rarp
Mohd Arif
 
User datagram protocol
User datagram protocolUser datagram protocol
User datagram protocol
Mohd Arif
 
Project identification
Project identificationProject identification
Project identification
Mohd Arif
 
Project evalaution techniques
Project evalaution techniquesProject evalaution techniques
Project evalaution techniques
Mohd Arif
 
Presentation
PresentationPresentation
Presentation
Mohd Arif
 
Pointers in c
Pointers in cPointers in c
Pointers in c
Mohd Arif
 
Peer to-peer
Peer to-peerPeer to-peer
Peer to-peer
Mohd Arif
 
Overview of current communications systems
Overview of current communications systemsOverview of current communications systems
Overview of current communications systems
Mohd Arif
 
Overall 23 11_2007_hdp
Overall 23 11_2007_hdpOverall 23 11_2007_hdp
Overall 23 11_2007_hdp
Mohd Arif
 
Objectives of budgeting
Objectives of budgetingObjectives of budgeting
Objectives of budgeting
Mohd Arif
 
Network management
Network managementNetwork management
Network management
Mohd Arif
 
Networing basics
Networing basicsNetworing basics
Networing basics
Mohd Arif
 
Iris ngx next generation ip based switching platform
Iris ngx next generation ip based switching platformIris ngx next generation ip based switching platform
Iris ngx next generation ip based switching platform
Mohd Arif
 
Ip sec and ssl
Ip sec and  sslIp sec and  ssl
Ip sec and ssl
Mohd Arif
 
Ip security in i psec
Ip security in i psecIp security in i psec
Ip security in i psec
Mohd Arif
 
Intro to comp. hardware
Intro to comp. hardwareIntro to comp. hardware
Intro to comp. hardware
Mohd Arif
 

Más de Mohd Arif (20)

Bootp and dhcp
Bootp and dhcpBootp and dhcp
Bootp and dhcp
 
Arp and rarp
Arp and rarpArp and rarp
Arp and rarp
 
User datagram protocol
User datagram protocolUser datagram protocol
User datagram protocol
 
Project identification
Project identificationProject identification
Project identification
 
Project evalaution techniques
Project evalaution techniquesProject evalaution techniques
Project evalaution techniques
 
Presentation
PresentationPresentation
Presentation
 
Pointers in c
Pointers in cPointers in c
Pointers in c
 
Peer to-peer
Peer to-peerPeer to-peer
Peer to-peer
 
Overview of current communications systems
Overview of current communications systemsOverview of current communications systems
Overview of current communications systems
 
Overall 23 11_2007_hdp
Overall 23 11_2007_hdpOverall 23 11_2007_hdp
Overall 23 11_2007_hdp
 
Objectives of budgeting
Objectives of budgetingObjectives of budgeting
Objectives of budgeting
 
Network management
Network managementNetwork management
Network management
 
Networing basics
Networing basicsNetworing basics
Networing basics
 
Loaders
LoadersLoaders
Loaders
 
Lists
ListsLists
Lists
 
Iris ngx next generation ip based switching platform
Iris ngx next generation ip based switching platformIris ngx next generation ip based switching platform
Iris ngx next generation ip based switching platform
 
Ip sec and ssl
Ip sec and  sslIp sec and  ssl
Ip sec and ssl
 
Ip security in i psec
Ip security in i psecIp security in i psec
Ip security in i psec
 
Intro to comp. hardware
Intro to comp. hardwareIntro to comp. hardware
Intro to comp. hardware
 
Heap sort
Heap sortHeap sort
Heap sort
 

Último

+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
Health
 

Último (19)

Belgium Vs Slovakia Belgium at Euro 2024 Teams in group, fixtures, schedule, ...
Belgium Vs Slovakia Belgium at Euro 2024 Teams in group, fixtures, schedule, ...Belgium Vs Slovakia Belgium at Euro 2024 Teams in group, fixtures, schedule, ...
Belgium Vs Slovakia Belgium at Euro 2024 Teams in group, fixtures, schedule, ...
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
 
UEFA Euro 2024 Clash and Eurovision 2024 Poll Insights.docx
UEFA Euro 2024 Clash and Eurovision 2024 Poll Insights.docxUEFA Euro 2024 Clash and Eurovision 2024 Poll Insights.docx
UEFA Euro 2024 Clash and Eurovision 2024 Poll Insights.docx
 
Croatia vs Italy Inter Milan Looking to Carry On Success at Euro 2024.pdf
Croatia vs Italy Inter Milan Looking to Carry On Success at Euro 2024.pdfCroatia vs Italy Inter Milan Looking to Carry On Success at Euro 2024.pdf
Croatia vs Italy Inter Milan Looking to Carry On Success at Euro 2024.pdf
 
Italy Vs Albania Italy vs Albania Euro 2024 Prediction Can Albania pull off a...
Italy Vs Albania Italy vs Albania Euro 2024 Prediction Can Albania pull off a...Italy Vs Albania Italy vs Albania Euro 2024 Prediction Can Albania pull off a...
Italy Vs Albania Italy vs Albania Euro 2024 Prediction Can Albania pull off a...
 
Netherlands Players expected to miss UEFA Euro 2024 due to injury.docx
Netherlands Players expected to miss UEFA Euro 2024 due to injury.docxNetherlands Players expected to miss UEFA Euro 2024 due to injury.docx
Netherlands Players expected to miss UEFA Euro 2024 due to injury.docx
 
Cricket Api Solution.pdfCricket Api Solution.pdf
Cricket Api Solution.pdfCricket Api Solution.pdfCricket Api Solution.pdfCricket Api Solution.pdf
Cricket Api Solution.pdfCricket Api Solution.pdf
 
Trusted Cricket Betting ID Provider In India: Get your Cricket ID Now
Trusted Cricket Betting ID Provider In India: Get your Cricket ID NowTrusted Cricket Betting ID Provider In India: Get your Cricket ID Now
Trusted Cricket Betting ID Provider In India: Get your Cricket ID Now
 
Albania Vs Spain South American coaches lead Albania to Euro 2024 spot.docx
Albania Vs Spain South American coaches lead Albania to Euro 2024 spot.docxAlbania Vs Spain South American coaches lead Albania to Euro 2024 spot.docx
Albania Vs Spain South American coaches lead Albania to Euro 2024 spot.docx
 
Luka Modric Elevating Croatia's Stars for Euro Cup 2024.docx
Luka Modric Elevating Croatia's Stars for Euro Cup 2024.docxLuka Modric Elevating Croatia's Stars for Euro Cup 2024.docx
Luka Modric Elevating Croatia's Stars for Euro Cup 2024.docx
 
Genuine 8617370543 Hot and Beautiful 💕 Etah Escorts call Girls
Genuine 8617370543 Hot and Beautiful 💕 Etah Escorts call GirlsGenuine 8617370543 Hot and Beautiful 💕 Etah Escorts call Girls
Genuine 8617370543 Hot and Beautiful 💕 Etah Escorts call Girls
 
Personal Brand Exploration - By Bradley Dennis
Personal Brand Exploration - By Bradley DennisPersonal Brand Exploration - By Bradley Dennis
Personal Brand Exploration - By Bradley Dennis
 
Unveiling the Mystery of Main Bazar Chart
Unveiling the Mystery of Main Bazar ChartUnveiling the Mystery of Main Bazar Chart
Unveiling the Mystery of Main Bazar Chart
 
JORNADA 6 LIGA MURO 2024TUXTEPECOAXACA.pdf
JORNADA 6 LIGA MURO 2024TUXTEPECOAXACA.pdfJORNADA 6 LIGA MURO 2024TUXTEPECOAXACA.pdf
JORNADA 6 LIGA MURO 2024TUXTEPECOAXACA.pdf
 
basketball evolution History Slides.pdf
basketball evolution  History Slides.pdfbasketball evolution  History Slides.pdf
basketball evolution History Slides.pdf
 
Slovenia Vs Serbia Eurovision odds Slovenia have top.docx
Slovenia Vs Serbia Eurovision odds Slovenia have top.docxSlovenia Vs Serbia Eurovision odds Slovenia have top.docx
Slovenia Vs Serbia Eurovision odds Slovenia have top.docx
 
Hire 💕 8617370543 Amethi Call Girls Service Call Girls Agency
Hire 💕 8617370543 Amethi Call Girls Service Call Girls AgencyHire 💕 8617370543 Amethi Call Girls Service Call Girls Agency
Hire 💕 8617370543 Amethi Call Girls Service Call Girls Agency
 
Churu Escorts 🥰 8617370543 Call Girls Offer VIP Hot Girls
Churu Escorts 🥰 8617370543 Call Girls Offer VIP Hot GirlsChuru Escorts 🥰 8617370543 Call Girls Offer VIP Hot Girls
Churu Escorts 🥰 8617370543 Call Girls Offer VIP Hot Girls
 
Spain to be banned from participating in Euro 2024.docx
Spain to be banned from participating in Euro 2024.docxSpain to be banned from participating in Euro 2024.docx
Spain to be banned from participating in Euro 2024.docx
 

Amer deadlocks

  • 2. Overview  Resources  Why do deadlocks occur?  Dealing with deadlocks  Ignoring them: ostrich algorithm  Detecting & recovering from deadlock  Avoiding deadlock  Preventing deadlock CS 1550, cs.pitt.edu Chapter 3 2 (originaly modified by Ethan
  • 3. Resources  Resource: something a process uses  Usually limited (at least somewhat)  Examples of computer resources  Printers  Semaphores / locks  Tables (in a database)  Processes need access to resources in reasonable order  Two types of resources:  Preemptable resources: can be taken away from a process with no ill effects  Nonpreemptable resources: will cause the process to fail if taken away CS 1550, cs.pitt.edu Chapter 3 3 (originaly modified by Ethan
  • 4. When do deadlocks happen?  Suppose  Process 1 holds resource A and requests resource B Process 1 Process 2  Process 2 holds B and requests A A  Both can be blocked, with neither able to proceed B  Deadlocks occur when …  Processes are granted A exclusive access to devices or software constructs B (resources)  Each deadlocked process needs a resource held by DEADLOCK! another deadlocked process CS 1550, cs.pitt.edu Chapter 3 4 (originaly modified by Ethan
  • 5. Using resources  Sequence of events required to use a resource  Request the resource  Use the resource  Release the resource  Can’t use the resource if request is denied  Requesting process has options  Block and wait for resource  Continue (if possible) without it: may be able to use an alternate resource  Process fails with error code  Some of these may be able to prevent deadlock… CS 1550, cs.pitt.edu Chapter 3 5 (originaly modified by Ethan
  • 6. What is a deadlock?  Formal definition: “A set of processes is deadlocked if each process in the set is waiting for an event that only another process in the set can cause.”  Usually, the event is release of a currently held resource  In deadlock, none of the processes can  Run  Release resources  Be awakened CS 1550, cs.pitt.edu Chapter 3 6 (originaly modified by Ethan
  • 7. Four conditions for deadlock  Mutual exclusion  Each resource is assigned to at most one process  Hold and wait  A process holding resources can request more resources  No preemption  Previously granted resources cannot be forcibly taken away  Circular wait  There must be a circular chain of 2 or more processes where each is waiting for a resource held by the next member of the chain CS 1550, cs.pitt.edu Chapter 3 7 (originaly modified by Ethan
  • 8. Resource allocation graphs  Resource allocation A B modeled by directed graphs  Example 1:  Resource R assigned to R S process A  Example 2:  Process B is requesting / waiting for resource S T  Example 3:  Process C holds T, waiting C D for U  Process D holds U, waiting U for T  C and D are in deadlock! CS 1550, cs.pitt.edu Chapter 3 8 (originaly modified by Ethan
  • 9. Dealing with deadlock  How can the OS deal with deadlock?  Ignore the problem altogether!  Hopefully, it’ll never happen…  Detect deadlock & recover from it  Dynamically avoid deadlock  Careful resource allocation  Prevent deadlock  Remove at least one of the four necessary conditions  We’ll explore these tradeoffs CS 1550, cs.pitt.edu Chapter 3 9 (originaly modified by Ethan
  • 10. Getting into deadlock A B C Acquire R Acquire S Acquire T Acquire S Acquire T Acquire R Release R Release S Release T Release S Release T Release R A B C A B C A B C R S T R S T R S T Acquire R Acquire S Acquire T A B C A B C A B C R S T R S T R S T Deadlock! Acquire S Acquire T Acquire R CS 1550, cs.pitt.edu Chapter 3 10 (originaly modified by Ethan
  • 11. Not getting into deadlock…  Many situations may result in deadlock (but don’t have to)  In previous example, A could release R before C requests R, resulting in no deadlock  Can we always get out of it this way?  Find ways to:  Detect deadlock and reverse it  Stop it from happening in the first place CS 1550, cs.pitt.edu Chapter 3 11 (originaly modified by Ethan
  • 12. The Ostrich Algorithm  Pretend there’s no problem  Reasonable if  Deadlocks occur very rarely  Cost of prevention is high  UNIX and Windows take this approach  Resources (memory, CPU, disk space) are plentiful  Deadlocks over such resources rarely occur  Deadlocks typically handled by rebooting  Trade off between convenience and correctness CS 1550, cs.pitt.edu Chapter 3 12 (originaly modified by Ethan
  • 13. Detecting deadlocks using graphs  Process holdings and requests in the table and in the graph (they’re equivalent)  Graph contains a cycle => deadlock!  Easy to pick out by looking at it (in this case)  Need to mechanically detect deadlock  Not all processes are deadlocked (A, C, F not in deadlock) R A B Process Holds Wants A R S C S D T E B T C S D U S,T F U V E T V F W S G V U W G CS 1550, cs.pitt.edu Chapter 3 13 (originaly modified by Ethan
  • 14. Deadlock detection algorithm  General idea: try to find For each node N in the graph { cycles in the resource Set L = empty list unmark all arcs allocation graph Traverse (N,L)  } Algorithm: depth-first If no deadlock reported by now, search at each node there isn’t any  Mark arcs as they’re define Traverse (C,L) { traversed If C in L, report deadlock!  Build list of visited nodes Add C to L  If node to be added is already For each unmarked arc from C { Mark the arc on the list, a cycle exists! Set A = arc destination  Cycle == deadlock /* NOTE: L is a local variable */ Traverse (A,L) } } CS 1550, cs.pitt.edu Chapter 3 14 (originaly modified by Ethan
  • 15. Resources with multiple instances  Previous algorithm only works if there’s one instance of each resource  If there are multiple instances of each resource, we need a different method  Track current usage and requests for each process  To detect deadlock, try to find a scenario where all processes can finish  If no such scenario exists, we have deadlock CS 1550, cs.pitt.edu Chapter 3 15 (originaly modified by Ethan
  • 16. Deadlock detection algorithm A B C D current=avail; for (j = 0; j < N; j++) { Avail 2 3 0 1 for (k=0; k<N; k++) { if (finished[k]) continue; Process A B C D if (want[k] < current) { finished[k] = 1; Hold 1 0 3 0 0 current += hold[k]; break; 2 1 0 1 1 } 3 0 2 1 0 if (k==N) { 4 2 2 3 0 printf “Deadlock!n”; Process A B C D // finished[k]==0 means process is in // the deadlock break; Want 1 3 2 1 0 } 2 2 2 0 0 } 3 3 5 3 1 Note: want[j],hold[j],current,avail are arrays! 4 0 4 1 1 CS 1550, cs.pitt.edu Chapter 3 16 (originaly modified by Ethan
  • 17. Recovering from deadlock  Recovery through preemption  Take a resource from some other process  Depends on nature of the resource and the process  Recovery through rollback  Checkpoint a process periodically  Use this saved state to restart the process if it is found deadlocked  May present a problem if the process affects lots of “external” things  Recovery through killing processes  Crudest but simplest way to break a deadlock: kill one of the processes in the deadlock cycle  Other processes can get its resources  Preferably, choose a process that can be rerun from the beginning  Pick one that hasn’t run too far already CS 1550, cs.pitt.edu Chapter 3 17 (originaly modified by Ethan
  • 18. Resource trajectories Two process resource trajectories CS 1550, cs.pitt.edu Chapter 3 18 (originaly modified by Ethan
  • 19. Safe and unsafe states Has Max Has Max Has Max Has Max Has Max A 3 9 A 3 9 A 3 9 A 3 9 A 3 9 B 2 4 B 4 4 B 0 - B 0 - B 0 - C 2 7 C 2 7 C 2 7 C 7 7 C 0 - Free: 3 Free: 1 Free: 5 Free: 0 Free: 7 Demonstration that the first state is safe Has Max Has Max Has Max Has Max A 3 9 A 4 9 A 4 9 A 4 9 B 2 4 B 2 4 B 4 4 B 0 - C 2 7 C 2 7 C 2 7 C 2 7 Free: 3 Free: 2 Free: 0 Free: 4 Demonstration that the second state is unsafe CS 1550, cs.pitt.edu Chapter 3 19 (originaly modified by Ethan
  • 20. Banker's Algorithm for a single resource Has Max Has Max Has Max A 0 6 A 1 6 A 1 6 B 0 5 B 1 5 B 2 5 C 0 4 C 2 4 C 2 4 D 0 7 D 4 7 D 4 7 Free: 10 Free: 2 Free: 1 Any sequence finishes C,B,A,D finishes Deadlock (unsafe state)  Bankers’ algorithm: before granting a request, ensure that a sequence exists that will allow all processes to complete  Use previous methods to find such a sequence  If a sequence exists, allow the requests  If there’s no such sequence, deny the request  Can be slow: must be done on each request! CS 1550, cs.pitt.edu Chapter 3 20 (originaly modified by Ethan
  • 21. Banker's Algorithm for multiple resources Example of banker's algorithm with multiple resources CS 1550, cs.pitt.edu Chapter 3 21 (originaly modified by Ethan
  • 22. Preventing deadlock  Deadlock can be completely prevented!  Ensure that at least one of the conditions for deadlock never occurs  Mutual exclusion  Circular wait  Hold & wait  No preemption  Not always possible… CS 1550, cs.pitt.edu Chapter 3 22 (originaly modified by Ethan
  • 23. Eliminating mutual exclusion  Some devices (such as printer) can be spooled  Only the printer daemon uses printer resource  This eliminates deadlock for printer  Not all devices can be spooled  Principle:  Avoid assigning resource when not absolutely necessary  As few processes as possible actually claim the resource CS 1550, cs.pitt.edu Chapter 3 23 (originaly modified by Ethan
  • 24. Attacking “hold and wait”  Require processes to request resources before starting  A process never has to wait for what it needs  This can present problems  A process may not know required resources at start of run  This also ties up resources other processes could be using  Processes will tend to be conservative and request resources they might need  Variation: a process must give up all resources before making a new request  Process is then granted all prior resources as well as the new ones  Problem: what if someone grabs the resources in the meantime—how can the process save its state? CS 1550, cs.pitt.edu Chapter 3 24 (originaly modified by Ethan
  • 25. Attacking “no preemption”  This is not usually a viable option  Consider a process given the printer  Halfway through its job, take away the printer  Confusion ensues!  May work for some resources  Forcibly take away memory pages, suspending the process  Process may be able to resume with no ill effects CS 1550, cs.pitt.edu Chapter 3 25 (originaly modified by Ethan
  • 26. Attacking “circular wait”  Assign an order to resources  D Always acquire resources in numerical order  Need not acquire them all at once! C  Circular wait is prevented 3 2  A process holding resource n can’t wait for resource m B if m < n  1 No way to complete a cycle  Place processes above the highest resource they hold A and below any they’re requesting  All arrows point up! CS 1550, cs.pitt.edu Chapter 3 26 (originaly modified by Ethan
  • 27. Deadlock prevention: summary  Mutual exclusion  Spool everything  Hold and wait  Request all resources initially  No preemption  Take resources away  Circular wait  Order resources numerically CS 1550, cs.pitt.edu Chapter 3 27 (originaly modified by Ethan
  • 28. Example: two-phase locking  Phase One  Process tries to lock all data it needs, one at a time  If needed data found locked, start over  (no real work done in phase one)  Phase Two  Perform updates  Release locks  Note similarity to requesting all resources at once  This is often used in databases  It avoids deadlock by eliminating the “hold-and- wait” deadlock condition CS 1550, cs.pitt.edu Chapter 3 28 (originaly modified by Ethan
  • 29. “Non-resource” deadlocks  Possible for two processes to deadlock  Each is waiting for the other to do some task  Can happen with semaphores  Each process required to do a down() on two semaphores (mutex and another)  If done in wrong order, deadlock results  Semaphores could be thought of as resources… CS 1550, cs.pitt.edu Chapter 3 29 (originaly modified by Ethan
  • 30. Starvation  Algorithm to allocate a resource  Give the resource to the shortest job first  Works great for multiple short jobs in a system  May cause long jobs to be postponed indefinitely  Even though not blocked  Solution  First-come, first-serve policy  Starvation can lead to deadlock  Process starved for resources can be holding resources  If those resources aren’t used and released in a timely fashion, shortage could lead to deadlock CS 1550, cs.pitt.edu Chapter 3 30 (originaly modified by Ethan