HOMEWORK 3

Due Date: November 6, 2002

1. A student came to my office with the following space-time diagram for Lamport’s distributed mutual exclusion algorithm. The student argued that the Site S2 can enter into Critical Section (CS) at Tx (instead of Ty), even though:

  1. S2 has not received a REPLY message from S1 at Tx.
  2. S2’s request is not at the top of S1’s request_queue at Tx.

Give me precise points to counter or accept the student’s argument. (If the answer is “Yes”, you should say why there would not be a problem in entering into CS without S1’s REPLY message and without S2’s request being at the top of S1’s queue. If the answer is “No”, you should explain which aspect of Lamport’s algorithm will prevent S2’s entry into CS at Tx).

What would be your arguments if the system follows Ricart-Agrawala’s algorithm instead of Lamport’s?

2. Expand on the Singhal's example discussed in the class as follows: show that after a site executes CS, there may be more than 1 site requesting CS. (Idea is to show the need for a fair selection of sites).

3. Assume a distributed system with 9 sites using Maekawa's algorithm. Enumerate the elements (i.e., the site ids) in each subset Ri. Construct an example scenario where the above system run into deadlock (when Maekawa's algorithm is applied) and explain how the deadlock will be resolved.

4. We saw that Singhal's heuristic algorithm may not follow the order of requests to critical section. I feel that the same problem may exist with Suzuki-Kasami's algorithms, i.e., the algorithms may not follow the order of CS requests as well (though the degree of the problem may considerably be lower). Can you construct an example scenario for Suzuki-Kasami algorithm to show this?

5. Consider Singhal's heuristic algorithm. Is it possible that a token holder does not receive a site's token request message but still passes the token to that site? Explain your answer.

6. Consider the WFG in a distributed system shown in (Figure 7.1 of Singhal's book). Assume that the system follows the OR request model. Apply the diffusion computation based algorithm. Show the flow of messages and determine whether a deadlock is present in the system.

7. Consider the following Wait For Graph (WFG) in a distributed system following the AND resource request model. Let us assume that the edge-chasing algorithm is initiated by P5 and P2. Both P5 and P2 detect cycles, and hence detect 2 deadlocks in the system. Now, P5 identifies that rolling back or terminating P3 (i.e., make P3 release the resources involved in the deadlock) will help in resolving the deadlock (on the left hand side of the figure). Incidentally, rolling back or terminating P3 also helps in resolving the other deadlock (on the right hand side of the figure). However, P2 being unaware of this fact, wants to rollback or terminate P1 to resolve the deadlock (on the right hand side of the figure). Note: you can assume all processes have the same priority.

As you can see, the above case of 2 roll backs or terminations is not needed. Can you suggest some ways to overcome the extra roll back or termination initiated by P2? Try to make your suggestion in such a way that it can work in a general scenario as well, i.e., do not make your suggestion very specific to the given example WFG. Also, your suggestion need NOT have any relation to the edge-chasing algorithm.

8. Show whether Byzantine agreement can be reached among 5 processors if 2 of them are faulty.

Suggestion: Try all Exercise problems in book. Construct examples for deadlock detection and mutual exclusion algorithms.