

# Operating Systems - 3

## \* Threads





1 process , different tasks

Threads





1 process

Threads → Shared data

Processes → comp. diff kinds of tasks.  
1 process

✓  
T/V<sub>0</sub>

vs

✓  
CPU  
==

4

100 calls to google.com ✓



100 threads

100 threads make  
a req to google.com.



E wait for them to finish.

Response.

look   ?

$\max(RTT)$

wait for all  
of them  
to finish.





for (i = 0 to 100)

make call to google.com &

get response.



100 \* (Time for each  
RT call)

> 1



Waiting

A process





100

Thread pool

$T_0 \quad T_1 \quad T_2 \dots$

$T_{top}$



many'l



→ \* Producer - Consumer

Producer  
while(true){

Consumer  
while(true){

    }

WORKEE



\* Works most of the time ✓

# Sometimes, it doesn't work.

Why??

What addition

does

BTS.

✓  
To ✓

✓  
 $T_1$

$x++$

$x++$

load  $x$  into a register  
 $x = \text{reg}$

1)  
2)  
3)

lvi  
write & back from register.



To load X Reg,

T<sub>1</sub> load X Reg<sub>2</sub>

To Inc Reg<sub>1</sub>

T<sub>2</sub> Inc Reg<sub>2</sub>

To load X Reg,

To Inc Reg,

To write Reg<sub>1</sub>, ▲

x+1 T<sub>1</sub> - -

T<sub>1</sub> - - }

To write Reg<sub>1</sub>,  $x$

T<sub>1</sub>

T<sub>1</sub> write Reg<sub>2</sub>)  $x$

~~$x$~~

$x+1$

$x+2$

[  $x++$  ] is not an atomic

entry<sub>1</sub>) T<sub>2</sub> entry<sub>2</sub> line



Race condition

\* context switches can lead to data inconsistency.

## Mutual exclusion

\* At any time, only one thread is in its CS.

## Bounded waiting



A bound must exist on the # times processes can enter CS

After 2 process has made a  
req. to enter S before the request  
is granted.

Progress

any process is  
in CS



if no processes  
in CS  
+  
a,y,z entry



App #2



loop A

→ turn = 1

→ while (turn == 1);

CC

loop B

→ turn = 0

while (turn == 0);

?? → CS



$T_0 \text{ in crit}$  =  $T_1$  in crit = False.

loop d



while( $T_1$  is in crit);

loop d



while( $T_0$  in crit);

$T_1$  in crit =  $T$



Peterson's

~~T<sub>0</sub>~~

T<sub>0</sub>

(flag<sub>0</sub> = flag<sub>1</sub> = False)  
Intent

T<sub>1</sub>

loop {

①

flag<sub>0</sub> = True

②

turn → 1



you can  
go first

while (flag<sub>1</sub> & & turn == 1);

Checking  
if T<sub>1</sub> is  
running  
in CS<sub>1</sub>



CS<sub>1</sub>

acq.

flag<sub>0</sub> = False

loop {

- ③
- ④

flag<sub>1</sub> = True

turn → 0

white (flag<sub>0</sub> & 8  
turn == 0);



CS<sub>2</sub>

flag<sub>1</sub> = False

~~↳ No longer intent to run CS~~

↳ get.

~~Lock~~,

acquire()

CS

release()

CAS :- Compare & Swap



Simultaneously get the value & set it to 1.

lock = 0  $\Rightarrow$  free.

critical()

while (test\_and\_set(lock) == 1)

G  $\rightarrow$  CS

& return 0

~~lock = 0~~

set lock = 1

## Semaphores



$T_0 \quad T_1 \quad T_2 \quad T_3$

$T_4 \quad T_5$



{



→ 4 threads





Wait(s) : if  $s > 0$ , then grab it

& decrement it by 1.

signal(s) : increment  $s$  by 1.

$s \geq 2 \Rightarrow$  2 of 5 are available.

R<sub>A</sub>

==

A<sub>1</sub>



A<sub>4</sub>

A<sub>5</sub>

$\Rightarrow A_2 \leftarrow B^4$

P<sub>B</sub>

B<sub>1</sub>

B<sub>2</sub>

B<sub>3</sub>

B<sub>4</sub>

B<sub>5</sub>

wait(s)





~~Deadlocks~~





winday



Linus

