





|                                                                                                                                                                                        | RACE CONDITION |           |                   |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------|-------------------|--|--|--|--|--|
| <ul> <li>Consider two cooperating processes, sharing variables A and B and<br/>having the following set of instructions in each of them:</li> </ul>                                    |                |           |                   |  |  |  |  |  |
|                                                                                                                                                                                        | Process 1      | Process 2 | Concurrent access |  |  |  |  |  |
|                                                                                                                                                                                        | A=1            | B=2       | Does not matter   |  |  |  |  |  |
|                                                                                                                                                                                        | A=B+1 $B=B+1$  | B=B*2     | Important!        |  |  |  |  |  |
| • Suppose our intention is to get A as 3 and B as 6 after the execution of both the processes. The interleaving of these instructions should be done in order to avoid race condition. |                |           |                   |  |  |  |  |  |
| • If the order of execution is like:                                                                                                                                                   |                |           |                   |  |  |  |  |  |
| Prepared By Mr. EBIN PM, AP EDULINE 4                                                                                                                                                  |                |           |                   |  |  |  |  |  |

































• Calls to either acquire() or release() must be performed atomically. The main disadvantage of the implementation given here is that it requires busy waiting. • While a process is in its critical section, any other process that tries to enter its critical section must loop continuously in the call to acquire(). • In fact, this type of mutex lock is also called a **spinlock** because the process spins while waiting for the lock to become available. • This continual looping is clearly a problem in а real multiprogramming system, where a single CPU is shared among many processes. Prepared By Mr. EBIN PM, AP EDULINE 21





![](_page_11_Picture_3.jpeg)

![](_page_12_Picture_2.jpeg)

![](_page_12_Picture_3.jpeg)

![](_page_13_Picture_2.jpeg)

![](_page_13_Figure_3.jpeg)

![](_page_14_Picture_2.jpeg)

| MONITORS                                                                                                                                                                   |                                                                                                                                                       |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| The incorrect use of semaphores can result in timing errors.                                                                                                               |                                                                                                                                                       |  |  |  |  |
| Suppose that a process interchanges the order in which the wait()<br>and signal() operations on the semaphore mutex are executed,<br>resulting in the following execution: |                                                                                                                                                       |  |  |  |  |
| signal(mutex);<br><br>critical section<br><br>wait(mutex);                                                                                                                 | In this situation, several processes<br>may be executing in their critical<br>sections simultaneously, violating<br>the mutual-exclusion requirement. |  |  |  |  |
| Prepared By Mr. EBIN PM, AP EDULINE 30                                                                                                                                     |                                                                                                                                                       |  |  |  |  |

![](_page_15_Picture_2.jpeg)

![](_page_15_Picture_3.jpeg)

![](_page_16_Figure_2.jpeg)

![](_page_16_Figure_3.jpeg)

![](_page_17_Picture_2.jpeg)

![](_page_17_Picture_3.jpeg)

![](_page_18_Figure_2.jpeg)

![](_page_18_Picture_3.jpeg)

![](_page_19_Figure_2.jpeg)

![](_page_19_Picture_3.jpeg)

| The structure of a writer process                                                                                          |                |    |
|----------------------------------------------------------------------------------------------------------------------------|----------------|----|
| <pre>do   {     wait (wrt);      /* writing is performed */      signal(wrt);     } while (true);  initially , wrt=1</pre> |                |    |
| Prepared By Mr. EBIN F                                                                                                     | PM, AP EDULINE | 41 |

![](_page_20_Figure_3.jpeg)

![](_page_21_Figure_2.jpeg)

![](_page_21_Picture_3.jpeg)

![](_page_22_Figure_2.jpeg)

![](_page_22_Figure_3.jpeg)

![](_page_23_Picture_2.jpeg)

![](_page_23_Picture_3.jpeg)