ALICE AND BOB DISCOVER THE PETERSON'S ALGORITHM COSC 4330/6310 Summer 2013
The problem Alice and Bob share a critical section (CS) They want to ensure mutual exclusion They start by using the Reserve first and check later algorithm
How they implement it When one of them wants to enter the CS section, –It changes his/her status to "wants to enter the CS" –It repeatedly checks the status of his/her partner until this status is "is not interested" When one of them leaves the critical section, –It changes his/her status to "wants to enter the CS"
Stating point Alice is not interestedBob is not interested The critical section
Alice arrives Alice wants to use CSBob is not interested Alice is inside the CS She indicates her intention and enters the CS
Bob arrives Alice wants to use CSBob wants to use CS Alice is inside the CS Bob waits He indicates his intention but must wait
Alice leaves Alice is not interestedBob wants to use CS Bob is inside the CS Bob can now enter the CS
Alice and Bob arrive in lockstep Alice wants to use CSBob wants to use CS Deadlock Alice and Bob block each other
The tiebreaking rule When both Alice and Bob both want to enter the critical section, the last one to arrive (there is always one!) will wait –Works when one is already inside the critical section and the other arrive –Works when both arrive in lockstep
How they implement it (I) When one of them wants to enter the CS section, –He/she writes in a shared variable that he/she is the last one to request entry –He/she changes his/her status to "wants to enter the CS" –If he/she was the last one to request entry He/she repeatedly checks the status of his/her partner until this status is " is not interested "
How they implement it (II) When one of them leaves the critical section, –It changes his/her status to "is not interested"
Stating point Alice is not interestedBob does not The critical section Who arrived last?
Alice arrives Alice wants to use CSBob does not Alice is inside the CS Alice arrived last
Bob arrives Alice wants to use CSBob wants to use CS Alice is inside the CS Bob waits Bob arrived last
Alice leaves Alice is not interestedBob wants to use CS Bob is inside the CS Bob arrived last
Alice and Bob arrive in lockstep Alice wants to use CSBob wants to use CS Bob is inside the CS Alice arrived last Alice waits
How we implement it (I) Two shared variables –mustwait contains the process ID of the process that arrived last –reserved[2] an array such that reserved[i] == 1 if process i wants to enter the critical section reserved[i] == 0 otherwise
How we implement it (II) The entry rule is other = 1 - pid ; mustwait = pid;//last arrived while ((reserved[other] == 1) && (must wait == pid)) ; Busy wait