













































| <pre>int c1 = 0, c2 = 0;<br/>cobegin<br/>p1: while (1) {<br/>c1 = 1;<br/>.</pre>                                                                                                                                             | Algorithm 4                                                                                                                                                                                                                                                           |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>while (c2){ c1 = 0; random_wait; c1=1; }; /*wait*/ CS1; c1 = 0; program1; } p2: while (1) {     c2 = 1;     while (c1){         c2 = 0; random_wait; c2=1;         }; /*wait*/     CS2; c2 = 0; program2; } coend</pre> | <pre>= 0, c2 = 0;<br/>n<br/>ile (1) {<br/>c1 = 1;<br/>while (c2){<br/>c1 = 0; random_wait; c1=1;<br/>}; /*wait*/<br/>CS1; c1 = 0; program1;<br/>ile (1) {<br/>c2 = 1;<br/>while (c1){<br/>c2 = 0; random_wait; c2=1;<br/>}; /*wait*/<br/>CS2; c2 = 0; program2;</pre> |
| COR4500 + Operating Systems                                                                                                                                                                                                  | ra Sustance Japan Jac                                                                                                                                                                                                                                                 |















































## 5.4.3 N-Thread Mutual Exclusion: Lamport's Bakery Algorithm

Applicable to any number of threads

COP4600 : Operating Systems

- Creates a queue of waiting threads by distributing numbered "tickets"
- Each thread executes when its ticket's number is the lowest of all threads
  Unlike Dekker's and Peterson's Algorithms, the Bakery Algorithm
- works in multiprocessor systems and for *n* threads

Joohan Lee

- Relatively simple to understand due to its real-world analog

## 5.4.3 N-Thread Mutual Exclusion: Lamport's Bakery Algorithm

Figure 5.12 Lamport's Bakery Algorithm. (1 of 3)







