deadlock (1) - carnegie mellon school of computer science410-s09/lectures/l13_deadlock.pdf ·...

67
1 Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

Upload: others

Post on 23-Sep-2020

3 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

1

Deadlock (1)

Dave EckhardtRoger Dannenberg

Bruce MaggsGeoff Langdale

L13_Deadlock

Page 2: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

2

Synchronization – P2

� By the end of today, you should really have

� Figured out where wrappers belong, why

� Made some system calls

� Designed mutexes & condition variables

� Drawn pictures of thread stacks (even if not perfec t)

Page 3: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

3

Synchronization – P2

� Debugging reminder

� We can't really help with queries like:� We did x...� ...something strange happened...� ...can you tell us why?

� You need to progress beyond “ something happened”� What was it that happened, exactly?� printf() is not always the right tool

� produces correct output only if run-time environmen t is right� captures only what you told it to, only “C-level” s tuff� changes your code by its mere presence!!!

� We're serious about examining register dumps!� Overall, maybe re-read “Debugging” lecture notes

Page 4: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

4

Synchronization – Readings

� Next three lectures

� Deadlock: 6.5.3, 6.6.3, Chapter 7

� Reading ahead

� Scheduling: Chapter 5

� Virtual Memory: Chapter 8, Chapter 9

Page 5: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

5

Outline

� Process resource graph

� What is deadlock?

� Deadlock prevention

� Next time

� Deadlock avoidance

� Deadlock recovery

Page 6: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

6

Tape Drives

� A word on “tape drives”

� Ancient computer resources

� Access is sequential, read/write

� Any tape can be mounted on any drive

� One tape at a time is mounted on a drive� Doesn't make sense for multiple processes to

simultaneously access a drive� Reading/writing a tape takes a while

� Think “CD burner”...

IBM 3420 (1970-1987)www.ibm.com/ibm/historyNot for publication

Data General 6023wps.com/NOVA4

Page 7: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

7

Process/Resource graph

Tape 1

P1

Tape 2

P2

Tape 3

P3

Request

Page 8: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

8

Process/Resource graph

Tape 1

P1

Tape 2

P2

Tape 3

P3

Allocation

Page 9: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

9

Waiting

Tape 1

P1

Tape 2

P2

Tape 3

P3

Page 10: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

10

Release

Tape 1

P1

Tape 2

P2

Tape 3

P3

Page 11: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

11

Reallocation

Tape 1

P1

Tape 2

P2

Tape 3

P3

Page 12: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

12

Multi-instance Resources

P1 P2 P3

Tapes Disks

Page 13: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

13

Definition of Deadlock

� A deadlock

� Set of N processes

� Each waiting for an event� ...which can be caused only by another process in the set

� Every process will wait forever

Page 14: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

14

Deadlock Examples

� Simplest form

� Process 1 owns printer, wants tape drive

� Process 2 owns tape drive, wants printer

� Less-obvious

� Three tape drives

� Three processes� Each has one tape drive� Each wants “just” one more

� Can't blame anybody, but problem is still there

Page 15: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

15

Deadlock Requirements

� Mutual Exclusion

� Hold & Wait

� No Preemption

� Circular Wait

Page 16: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

16

Mutual Exclusion

� Resources aren't “thread-safe” (“reentrant”)

� Must be allocated to one process/thread at a time

� Can't be shared

� Programmable Interrupt Timer� Can't have a different reload value for each proces s

Page 17: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

17

Hold & Wait

� Process holds some resources while waiting for more

mutex_lock(&m1);mutex_lock(&m2);mutex_lock(&m3);

� This locking behavior is typical

Page 18: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

18

No Preemption

� Can't force a process to give up a resource

� Interrupting a CD-R burn creates a “coaster”

� So don't do that

� Obvious solution

� CD-R device driver forbids second simultaneous open()

� If you can't open it, you can't pre-empt it...

Page 19: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

19

Circular Wait

� Process 0 needs something process 4 has

� Process 4 needs something process 7 has

� Process 7 needs something process 1 has

� Process 1 needs something process 0 has – uh-oh...

� Described as “cycle in the resource graph”

Page 20: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

20

Cycle in Resource Graph

Tape 2

P1

Tape 1

P2

Tape 3

P3

Page 21: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

21

Deadlock Requirements

� Mutual Exclusion

� Hold & Wait

� No Preemption

� Circular Wait

� Each deadlock requires all four

Page 22: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

22

Multi-Instance Cycle

P3P2P1

Tapes Disks

Page 23: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

23

Multi-Instance Cycle (With Rescuer!)

P3P2P1

Tapes Disks

Page 24: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

24

Cycle Broken

P3P2P1

Tapes Disks

Page 25: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

25

Dining Philosophers

� The scene

� 410 staff at a Chinese restaurant

� A little short on utensils

Page 26: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

26

Dining Philosophers

RDRS

MP

DEKB

Page 27: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

27

Dining Philosophers

� Processes

� 5, one per person

� Resources

� 5 bowls (dedicated to a diner: no contention: ignor e)

� 5 chopsticks

� 1 between every adjacent pair of diners

� Contrived example?

� Illustrates contention, starvation, deadlock

Page 28: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

28

Dining Philosophers

� A simple rule for eating

� Wait until the chopstick to your right is free; tak e it

� Wait until the chopstick to your left is free; take it

� Eat for a while

� Put chopsticks back down

Page 29: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

29

Dining Philosophers Deadlock

� Everybody reaches right...

� ...at the same time?

Page 30: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

30

Reaching Right

RDRS

MP

DEKB

Page 31: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

31

Process graph

RDRS

MP

DEKB

Page 32: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

32

Deadlock!

RDRS

MP

DEKB

Page 33: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

33

Dining Philosophers – State

int stick[5] = { -1 }; /* owner */condition avail[5]; /* newly avail. */mutex table = { available };

/* Right-handed convention */

right = diner; /* 3 � 3 */

left = (diner + 4) % 5; /* 3 � 7 � 2 */

Page 34: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

34

start_eating(int diner)

mutex_lock(table);

while (stick[right] != -1) condition_wait(avail[right], table);stick[right] = diner;

while (stick[left] != -1) condition_wait(avail[left], table);stick[left] = diner;

mutex_unlock(table);

Page 35: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

35

done_eating(int diner)

mutex_lock(table);

stick[left] = stick[right] = -1;condition_signal(avail[right]);condition_signal(avail[left]);

mutex_unlock(table);

Page 36: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

36

Can We Deadlock?

� At first glance the table mutex protects us

� Can't have “everybody reaching right at same time”. ..

� ...mutex means only one person can access table...

� ...so allows only one reach at the same time, right ?

Page 37: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

37

Can We Deadlock?

� At first glance the table mutex protects us

� Can't have “everybody reaching right at same time”. ..

� ...mutex means only one person can access table...

� ...so allows only one reach at the same time, right ?

� Maybe we can!

� condition_wait() is a “reach”

� Can everybody end up in condition_wait()?

Page 38: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

38

First diner gets both chopsticks

Page 39: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

39

Next gets right, waits on left

Page 40: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

40

Next two get right, wait on left

Page 41: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

41

Last waits on right

Page 42: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

42

First diner stops eating - briefly

Page 43: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

43

First diner stops eating - briefly

signal()

Page 44: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

44

Next Step – One Possibility

“Natural” –longest-waiting diner progresses

Page 45: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

45

Next Step – Another Possibility

Or –somebody else!

Page 46: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

46

Last diner gets right, waits on left

Page 47: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

47

First diner gets right, waits on left

Page 48: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

48

Now things get boring

Page 49: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

49

Deadlock - What to do?

� Prevention

� Avoidance

� Detection/Recovery

� Just reboot when it gets “too quiet”

Page 50: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

50

1: Prevention

� Restrict behavior or resources

� Find a way to violate one of the 4 conditions� To wit...?

� What we will talk about today

� 4 conditions, 4 possible ways

Page 51: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

51

2: Avoidance

� Processes pre-declare usage patterns

� Dynamically examine requests

� Imagine what other processes could ask for

� Keep system in “safe state”

Page 52: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

52

3: Detection/Recovery

� Maybe deadlock won't happen today...

� ...Hmm, it seems quiet...

� ...Oops, here is a cycle...

� Abort some process

� Ouch!

Page 53: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

53

4: Reboot When It Gets “Too Quiet”

� Which systems would be so simplistic?

Page 54: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

54

Four Ways to Forgiveness

� Each deadlock requires all four

� Mutual Exclusion

� Hold & Wait

� No Preemption

� Circular Wait

� “Deadlock Prevention” - this is a technical term

� Pass a law against one (pick one)

� Deadlock happens only if somebody transgresses!

Page 55: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

55

Outlaw Mutual Exclusion?

� Approach: ban single-user resources

� Require all resources to “work in shared mode”

� Problem

� Chopsticks???

� Many resources don't work that way

Page 56: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

56

Outlaw Hold&Wait?

� Acquire resources all-or-none

start_eating(int diner)

mutex_lock(table);while (1) if (stick[lt] == stick[rt] == -1) stick[lt] = stick[rt] = diner mutex_unlock(table) return; condition_wait(released, table);

Page 57: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

57

Problems

� “Starvation”

� Larger resource set makes grabbing everything harde r� No guarantee a diner eats in bounded time

� Low utilization

� Larger peak resource needs hurts whole system alway s� Must allocate 2 chopsticks (and waiter!)� Nobody else can use waiter while you eat

Page 58: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

58

Outlaw Non-preemption?

� Steal resources from sleeping processes!

start_eating(int diner)right = diner; rright = (diner+1)%5;mutex_lock(table);while (1) if (stick[right] == -1) stick[right] = diner else if (stick[rright] != rright) /* right person can't be eating: take! */ stick[right] = diner;...same for left...wait() if must...mutex_unlock(table);

Page 59: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

59

Problem

� Some resources cannot be cleanly preempted

� CD burner

Page 60: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

60

Outlaw Circular Wait?

� Impose total order on all resources

� Require acquisition in strictly increasing order

� Static order may work: allocate memory, then files

� Dynamic – may need to “start over” sometimes� Traversing a graph

� lock(4), visit(4) /* 4 has an edge to 13 */� lock(13), visit(13) /* 13 has an edge to 0 */� lock(0)?

� Nope!� unlock(4), unlock(13)� lock(0), lock(4), lock(13), ...

Page 61: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

61

Assigning Diners a Total Order

� Lock order: 4, 3, 2, 1, 0 � right chopstick, then left

� Diner 4 � lock(4); lock(3);

� Diner 3 � lock(3); lock(2);

Page 62: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

62

Assigning Diners a Total Order

� Lock order: 4, 3, 2, 1, 0 � right chopstick, then left

� Diner 4 � lock(4); lock(3);

� Diner 3 � lock(3); lock(2);

� Diner 0 � lock(0); lock(4); /* invalid lock order! */

� Requires special-case locking code to get order rig ht

if diner == 0 right = (diner + 4) % 5; left = diner;else right = diner; left = (diner + 4) % 5;...

Page 63: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

63

Problem

� May not be possible to force allocation order

� Some trains go east, some go west

Page 64: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

64

Deadlock Prevention problems

� Typical resources require mutual exclusion

� All-at-once allocation can be painful

� Hurts efficiency

� May starve

� Resource needs may be unpredictable

� Preemption may be impossible

� Or may lead to starvation

� Ordering restrictions may be impractical

Page 65: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

65

Deadlock Prevention

� Pass a law against one of the four ingredients

� Great if you can find a tolerable approach

� Very tempting to just let processes try their luck

Page 66: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

66

Deadlock is not...

� ...a simple synchronization bug

� Deadlock remains even when those are cleaned up

� Deadlock is a resource usage design problem

� ...the same as starvation

� Deadlocked processes don't ever get resources

� Starved processes don't ever get resources

� Deadlock is a “progress” problem; starvation is a “bounded waiting” problem

� ....that “after-you, sir” dance in the corridor

� That's “livelock” – continuous changes of state wit hout forward progress

Page 67: Deadlock (1) - Carnegie Mellon School of Computer Science410-s09/lectures/L13_Deadlock.pdf · Deadlock (1) Dave Eckhardt Roger Dannenberg Bruce Maggs Geoff Langdale L13_Deadlock

67

Next Time

� Deadlock Avoidance

� Deadlock Recovery