KEMBAR78
Synchronization | PDF | Computing | Computer Programming
0% found this document useful (0 votes)
24 views19 pages

Synchronization

The document discusses process synchronization, focusing on the critical-section problem and various algorithms to solve it, including two-process and multi-process solutions. It explains the importance of mutual exclusion, progress, and bounded waiting in ensuring data consistency when multiple processes access shared data. Additionally, it covers the concepts of race conditions, semaphores, and monitors as mechanisms for synchronizing concurrent processes.

Uploaded by

sambit
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
24 views19 pages

Synchronization

The document discusses process synchronization, focusing on the critical-section problem and various algorithms to solve it, including two-process and multi-process solutions. It explains the importance of mutual exclusion, progress, and bounded waiting in ensuring data consistency when multiple processes access shared data. Additionally, it covers the concepts of race conditions, semaphores, and monitors as mechanisms for synchronizing concurrent processes.

Uploaded by

sambit
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 19

Process Synchronization

Soma Hazra
Assistant Professor
Dept. of Computer Science

1
Outline
Background
The Critical-Section Problem
 Two-process Solution (Algorithm 1 , 2 & 3)
 Multi-process Solution (Bakery Algorithm)
CS Solutions in H/W: TSL and Swap Instructions
Semaphores
 Introduction
 Semaphore Implementation
 Types of Semaphore
Classical Problems of Synchronization
Monitors

2
Background
Cooperating processes may either directly share a logical
address space (i.e. both code and data), or be allowed to share
data only through files.
Concurrent access to shared data may result in data
inconsistency.
Maintaining data consistency requires mechanisms to ensure
the orderly execution of cooperating processes.
Shared-memory solution to bounded-buffer problem allows at
most n – 1 items in buffer at the same time. A solution, where
all N buffers are used is not simple.
 Suppose that we modify the producer-consumer code by
adding a variable counter, initialized to 0 and incremented
each time a new item is added to the buffer

3
Bounded Buffer
Shared data

#define BUFFER_SIZE 10
typedef struct {
...
} item;
item buffer[BUFFER_SIZE];
int in = 0;
int out = 0;
int counter = 0;

4
Bounded Buffer Contd…
Producer process

item nextProduced;
while (1) {
while (counter == BUFFER_SIZE)
; /* do nothing */
buffer[in] = nextProduced;
in = (in + 1) % BUFFER_SIZE;
counter++;
}
5
Bounded Buffer Contd…
Consumer process

item nextConsumed;
while (1) {
while (counter == 0)
; /* do nothing */
nextConsumed = buffer[out];
out = (out + 1) % BUFFER_SIZE;
counter--;
}
6
Bounded-Buffer Contd…
The producer and consumer routines will work properly when
they run separately, but may not function correctly when
executed concurrently.
After concurrent execution of statements “counter++” and
“counter--”, the value of counter will not be correct.
That’s why the statements: “counter++” and “counter--” must
be performed atomically.
Atomic operation means an operation that completes in its
entirety without interruption.
The same can be proved in a machine language also by
implementing the counter value by taking some registers.

7
Bounded-Buffer Contd…
The statement “count++” may be implemented in
machine language as:
register1 = counter
register1 = register1 + 1
counter = register1

The statement “count--” may be implemented as:


register2 = counter
register2 = register2 – 1
counter = register2

8
Bounded-Buffer Contd…
If both the producer and consumer attempt to update
the buffer concurrently, the assembly language
statements may get interleaved.
Assume counter is initially 5. One interleaving of
statements is:
Producer: register1 = counter { register1 = 5 }
producer: register1 = register1 + 1 { register1 = 6 }
consumer: register2 = counter { register2 = 5 }
consumer: register2 = register2 – 1 { register2 = 4 }
producer: counter = register1 { counter = 6 }
consumer: counter = register2 { counter = 4 }
The value of count may be either 4 or 6, where the correct
result should be 5. 9
Race Condition
Race condition: The situation where several
processes access and manipulate the shared
data concurrently and the outcome of the
execution depends on the particular order in
which the access takes place, is called race
condition.

To prevent race conditions, concurrent


processes must be synchronized.

10
The Critical-Section Problem
Consider a system consisting of n processes {P0, P1, ...Pn-1}.
Each process has a code segment, called “critical section”, in
which the process may changing common variables, updating a
table, writing a file, and so on.
Problem (feature) – ensure that when one process is executing in
its critical section, no other process is allowed to execute in its
critical section.
 Thus the execution of critical sections by the processes is
mutually exclusive.
Each process must request permission to enter its critical section.
The section of code for request is “entry section”.
The critical section may be followed by an “exit section”.
The remaining code is “remainder section”.

11
Solution to Critical-Section
Problem
A solution to the critical section problem must satisfy the
following three requirements:
1. Mutual Exclusion: If process Pi is executing in its critical
section, then no other processes can be executing in their
critical sections.
2. Progress: If no process is executing in its critical section and
some processes wish to enter their critical sections, then
only those processes that are not executing in their
remainder section can participate in the decision on which
will enter its critical section next, and this selection cannot
be postponed indefinitely.
3. Bounded Waiting: There exist a bound on the number of
times that other processes are allowed to enter their critical
sections after a process has made a request to enter its
critical section and before that request is granted.
12
General Structure of Process Pi
do {
entry section

critical section

exit section

reminder section
} while (1);

13
Two-Process Solutions
The algorithm is restricted only for two
process.
The processes are numbered P0 and P1.
In general case, if one process is Pi then other
one is Pj, where j = 1-i .
Processes may share some common variables
to synchronize their actions.

14
Algorithm 1
Shared variables: int turn;
The value of turn either 0 or 1 .
Initially, turn is set to 0 (i.e. turn = 0)
If turn == i, then Pi can enter its critical section
The structure of Process Pi
do {
while (turn != i) ;
critical section
turn = j;
reminder section
} while (1);
Satisfies mutual exclusion, but not progress

15
Algorithm 2
Shared variables
 boolean flag[2];
 initially flag [0] = flag [1] = false.
 If flag [i] = true  Pi is ready to enter its critical section
Process Pi
do {
flag[i] = true;
while (flag[j]) ;

critical section
flag [i] = false;
remainder section
} while (1);

16
Explanation of Algorithm 2
Process Pi first sets flag[i] to be true, signaling that it is ready to
enter its critical section. Then, Pi checks whether Pj is executing
in its critical section or not.
If Pj is executing in its critical section then Pi has to wait until Pj
is no longer needed the critical section (i.e. until flag[j] was
false).
Now, Pi can enter to the critical section and by exiting from
critical section Pi would set flag[i] to false, allowing the other
process (if it is waiting) to enter its critical section.
So, mutual-exclusion requirement satisfied, but progress
requirements is not met. To illustrate the problem,
consider the following execution sequence:
– P0 sets flag[0] = true & P1 sets flag[1] = true
– Now P0 and P1 are looping forever in their respective while
statements.

17
Algorithm 3(Peterson’s Solution)
Shared variables:
 By combining the key ideas of Algorithm 1 & 2 .
 boolean flag[2];
 int turn;
• Process Pi
do {
flag[i] = true;
turn = j;
while (flag[j] && turn == j) ;

critical section
flag[i] = false;
remainder section
} while (1);
18
Explanation of Algorithm 3
Initially flag[0]=flag[1]=false, and the value of turn is
immaterial (but is either 0 and 1).
Pi will enters its CS iff either flag[j] == false or turn == i.
If both Pi and Pj wants to execute in their CS at the same
time, then flag[0]=flag[1]=true. But the value of turn could
be either 0 or 1, allowing only one process to be in the CS
at any point of time. Hence mutual exclusion is preserved.
Similarly, progress and bounded waiting can be proved.
As, when turn==i, Pi will enter in its CS and when turn==j, Pj
will enter in its critical section and exiting from the critical
section they will resets the flag value.
So, after at most one entry (bounded waiting) another
process will enter critical section (progress).

19

You might also like