





















## Concepts in Example 2

- Interleaved execution among threads.
- Shared variable communication
- Unintended shared variable values
- > Due to unforeseen interleavings
- > And, a mechanism for
  - Specifying the unintended behavior
  - Producing the interleaving that produces this unintended behavior.
- We only do this in our modeling environment hard to do this for real programs!

















































| Exerc                      | ise 2 - Take a                                                                                                                                   | guess!                                                                                                                                                               |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Suppose th                 | e infinite loop is compiled                                                                                                                      | by a naïve compiler as follows.The                                                                                                                                   |
| sequence                   | e of instructions executed                                                                                                                       | by process A and process B are shown.                                                                                                                                |
| The pro-                   | cesses are running asynchr                                                                                                                       | onously, and each time a process is                                                                                                                                  |
| schedule                   | d, only its next instruction                                                                                                                     | is executed atomically. Initially x = 1.                                                                                                                             |
| Loop <sub>A</sub> :        | Process A<br>$reg_{A}^{1} = x$<br>$reg_{A}^{2} = x$<br>$reg_{A}^{3} = reg_{A}^{1} + reg_{A}^{2}$<br>$x = reg_{A}^{3}$<br>go to Loop <sub>A</sub> | Process B<br>Loop <sub>B</sub> : $reg_{B}^{1} = x$<br>$reg_{B}^{2} = x$<br>$reg_{B}^{3} = reg_{B}^{1} + reg_{B}^{2}$<br>$x = reg_{B}^{3}$<br>go to Loop <sub>B</sub> |
| <ul> <li>What ar</li></ul> | e all the possible values th                                                                                                                     | at × reach during system execution in                                                                                                                                |
| this situa                 | ition ? Explain your answer                                                                                                                      | : Note that × is a shared global variable                                                                                                                            |
| and reg <sub>A</sub>       | ', reg <sub>B</sub> ' are local registers ir                                                                                                     | processes A and B respectively.                                                                                                                                      |
| ▶ 42                       | Copyright 2012 by Abhik Roychoudhury                                                                                                             |                                                                                                                                                                      |