Logo

dev-resources.site

for different kinds of informations.

Process Synchronization and Deadlock: Operating System

Published at
1/2/2025
Categories
os
unix
linux
ubuntu
Author
harshm03
Categories
4 categories in total
os
open
unix
open
linux
open
ubuntu
open
Author
8 person written this
harshm03
open
Process Synchronization and Deadlock: Operating System

Guide to Process Synchronization


Introduction to Process Synchronization

Process Synchronization is a crucial concept in operating systems and concurrent programming that ensures the correct execution of multiple processes or threads. It is essential for coordinating the access to shared resources, preventing inconsistencies, and avoiding race conditions in concurrent environments.

When multiple processes are executed concurrently, there is a risk of simultaneous access to shared resources like variables, files, or data structures. This can result in unexpected and undesirable behavior, such as data corruption or inconsistency, which is where process synchronization plays a key role.


Cooperating Processes and Process Synchronization

A cooperating process is a process that can potentially affect or be affected by other processes in the system. Cooperating processes often share resources, and this sharing can lead to conflicts if not managed properly. To ensure their correct behavior and to prevent conflicts or race conditions, synchronization techniques are employed.

Cooperating processes often need to share data or resources, but when multiple processes try to access these resources simultaneously, inconsistencies and errors can occur. Therefore, process synchronization ensures that the processes cooperate correctly while maintaining the integrity of shared resources.


Race Condition

A race condition arises when multiple processes or threads access shared resources concurrently and the outcome depends on the timing or sequence of execution. If the processes are not synchronized correctly, the final result may be inconsistent or incorrect.

Example:
Imagine two processes attempting to increment a shared counter variable. If both processes read the variable at the same time, modify it, and write it back, the final value of the counter could be incorrect because both processes may have read the same value before either wrote back their changes.

// Process 1 and Process 2
counter = counter + 1;  // Shared counter variable
Enter fullscreen mode Exit fullscreen mode

In the above scenario, both processes might read the counter value at the same time, which leads to a race condition. The solution to this problem is to synchronize the access to the shared variable.


Critical Sections in Process Synchronization

In concurrent programming, the critical section is a part of the code where shared resources are accessed or modified. To prevent race conditions, we need to ensure that only one process can execute the critical section at a time.

Critical Section Problem:

The critical section problem arises when multiple processes want to access and modify shared resources, and proper synchronization is required to prevent inconsistencies.

A critical section problem can be broken down into several important sections:

  1. Entry Section:

    • This is the section where a process requests permission to enter its critical section. The entry section involves setting flags or conditions that signal other processes whether the critical section is available or not.
  2. Critical Section:

    • This is the section where the actual access to shared resources occurs. The critical section must be executed by only one process at a time to maintain data consistency.
  3. Exit Section:

    • This section releases the critical section, allowing other processes to enter. It typically involves clearing flags or updating conditions that indicate the critical section is available.
  4. Remainder Section:

    • This section is the part of the process that executes after the critical section and exit section. The remainder section can be executed by any process and is typically unrelated to the shared resource.

The Critical-Section Problem

A solution to the critical-section problem must satisfy three important criteria:

  1. Mutual Exclusion:
    • Only one process at a time can execute in the critical section. If process Pi is in its critical section, no other process can be in its critical section.

Example:

   if (Pi is in critical section) {
       // No other process can enter its critical section
   }
Enter fullscreen mode Exit fullscreen mode
  1. Progress:
    • If no process is currently in its critical section and some processes want to enter their critical sections, then the decision of which process gets to enter next must be made by processes that are not in their remainder sections. The selection of the process to enter the critical section cannot be postponed indefinitely.

Example:

   // Processes are allowed to decide which enters the critical section.
   // No process should be left indefinitely without entering.
Enter fullscreen mode Exit fullscreen mode
  1. Bounded Waiting:
    • There must be a bound or limit on the number of times that other processes are allowed to enter their critical sections after a process has requested to enter its critical section and before that request is granted.

Example:

   // There is a limit to how many times other processes can enter the critical section 
   // before the requesting process is allowed to enter.
Enter fullscreen mode Exit fullscreen mode

Solutions to the Critical-Section Problem

Several solutions have been proposed to solve the critical-section problem, each with varying degrees of complexity and performance.

1. Peterson’s Solution

Peterson's Solution is a classical solution to the critical-section problem for two processes. It uses two flags and a turn variable to ensure mutual exclusion, progress, and bounded waiting.

The algorithm works as follows:

  1. Each process sets its flag to indicate interest in entering the critical section.
  2. The turn variable ensures that the other process has a chance to enter the critical section.
  3. The process that has the turn to execute in the critical section does so, while the other process waits until the critical section is available.
// Peterson's Algorithm for two processes
// Shared variables
int flag[2] = {0, 0};  // Flag for each process
int turn;              // Variable to decide whose turn

// Process Pi
while (true) {
    flag[i] = 1;              // Indicate interest in entering critical section
    turn = j;                 // Set turn to the other process
    while (flag[j] == 1 && turn == j) {
        // Wait if the other process is interested and it is its turn
    }
    // Critical Section
    flag[i] = 0;  // Exit the critical section
}
Enter fullscreen mode Exit fullscreen mode

Advantages:

  • Satisfies mutual exclusion, progress, and bounded waiting.

Disadvantages:

  • Only works for two processes.
  • Inefficient for larger systems.

2. Test and Set Solution

The Test and Set solution is a hardware-based approach that uses a special atomic operation. This operation tests a value and sets it atomically in one step.

  • The Test and Set operation works as follows:
    • If the flag is 0, set it to 1 and proceed.
    • If the flag is already 1, wait.
// Test and Set function (Atomic operation)
int TestAndSet(int *lock) {
    int old = *lock;
    *lock = 1;
    return old;
}

// Usage in critical section
while (TestAndSet(&lock)) {
    // Wait if the lock is already set
}
// Critical Section
lock = 0;  // Release lock
Enter fullscreen mode Exit fullscreen mode

Advantages:

  • Simple and effective.
  • Can be implemented directly in hardware.

Disadvantages:

  • Can lead to busy-waiting, wasting CPU time.
  • May lead to deadlock if not implemented with care.

3. Mutex Locks

A mutex lock (short for mutual exclusion) is a synchronization primitive that ensures that only one process can access a critical section at any given time. It prevents multiple threads or processes from accessing the critical section simultaneously.

// Mutex lock example
mutex_lock(&mutex); // Acquire lock
// Critical Section
mutex_unlock(&mutex); // Release lock
Enter fullscreen mode Exit fullscreen mode

Advantages:

  • Simple and easy to use.
  • Efficient for protecting shared resources.

Disadvantages:

  • Can cause deadlock or starvation if not used carefully.

4. Semaphore Solution

A semaphore is a synchronization primitive used to control access to shared resources. It is an integer variable that is manipulated using two atomic operations: wait (P) and signal (V).

  • Binary Semaphore (Mutex): Used to implement mutual exclusion, it can only take values 0 or 1.
  • Counting Semaphore: Used when there are multiple resources, such as a pool of available resources, and can take any integer value.
// Binary Semaphore (Mutex)
semaphore mutex = 1;

wait(mutex); // Enter critical section
// Critical Section
signal(mutex); // Exit critical section

// Counting Semaphore
semaphore empty = N;  // Number of available resources
semaphore full = 0;   // Number of occupied resources

wait(empty); // Wait for available resource
// Critical Section
signal(full); // Resource occupied
Enter fullscreen mode Exit fullscreen mode

Advantages:

  • Provides a higher level of abstraction.
  • Allows for more complex synchronization mechanisms.

Disadvantages:

  • Requires careful management to avoid deadlock and starvation.

Deadlock and Starvation

  • Deadlock occurs when a set of processes are blocked because each process is holding a resource and waiting for another resource held by another process. In deadlock situations, the processes will never make progress.

Example of Deadlock:

  • Process A holds Resource 1 and waits for Resource 2.
  • Process B holds Resource 2 and waits for Resource 1.

    • Starvation occurs when a process is perpetually denied access to resources because other processes are continuously given higher priority or access.

Solutions:

  • Use timeout mechanisms or priority schemes to avoid starvation.
  • Implement deadlock detection and recovery mechanisms.

Conclusion

Process synchronization is critical in concurrent programming to ensure that processes interact correctly and do not interfere with each other’s operations. Various techniques like Peterson’s Solution, Mutex locks, and Semaphores help maintain the integrity of shared resources, prevent race conditions, and ensure smooth process execution.

While the basic concepts of process synchronization are relatively simple, applying them in real-world systems requires careful consideration of issues like deadlock, starvation, and performance.


Guide to Deadlocks


Introduction to Deadlocks

A deadlock occurs in a system when a set of processes becomes permanently blocked because each process is holding a resource and waiting to acquire another resource held by another process in the set. In a deadlock situation, none of the processes can proceed, resulting in a system halt or degraded performance.


Deadlock Basics

Resource Request-Use-Release Sequence

Processes interact with system resources in a standard sequence:

  1. Request:

    • A process requests access to a resource.
    • If the resource is not available, the process enters a waiting state until it becomes available.
  2. Use:

    • The process uses the resource to perform operations.
  3. Release:

    • The process releases the resource, making it available to other processes.

Necessary Conditions for Deadlock

For a deadlock to occur, four conditions must be met simultaneously. These conditions are known as Coffman Conditions:

  1. Mutual Exclusion:

    • At least one resource must be held in a non-sharable mode. Only one process can use the resource at a time.
  2. Hold and Wait:

    • A process holding at least one resource is waiting to acquire additional resources that are currently held by other processes.
  3. No Preemption:

    • Resources cannot be forcibly taken away from a process. They must be released voluntarily by the process holding them.
  4. Circular Wait:

    • A set of processes {P1, P2, ..., Pn} exists such that P1 is waiting for a resource held by P2, P2 is waiting for a resource held by P3, ..., and Pn is waiting for a resource held by P1.

If any of these conditions is broken, deadlock cannot occur.


Methods for Handling Deadlocks

Operating systems employ various strategies to handle deadlocks:

  1. Deadlock Prevention:

    • Modifies system conditions to ensure that at least one of the necessary conditions for deadlock cannot hold.
  2. Deadlock Avoidance:

    • Dynamically examines resource allocation to ensure that the system never enters an unsafe state.
  3. Deadlock Detection and Recovery:

    • Allows deadlocks to occur but detects them and takes action to recover.
  4. Ignoring the Problem:

    • Often referred to as the ostrich algorithm, where the system assumes that deadlocks will rarely occur and does nothing to prevent or handle them.

Deadlock Prevention

Deadlock prevention works by ensuring that at least one of the necessary conditions for deadlock is violated.

Breaking the Necessary Conditions

  1. Mutual Exclusion:

    • Avoid mutual exclusion by using shareable resources whenever possible.
    • Example: Read-only files can be shared among multiple processes without conflict.
  2. Hold and Wait:

    • Ensure processes do not hold resources while waiting for other resources.
    • Strategies:
      • Require a process to request all required resources at once. If not all resources are available, none are allocated, and the process waits.
      • Force processes to release all held resources before requesting additional ones.

Drawback:

  • May lead to reduced resource utilization and potential starvation.
  1. No Preemption:

    • Allow preemption of resources.
    • Strategies:
      • If a process requests a resource that is unavailable, forcibly take a resource from another process and allocate it.
      • Example: Use priority schemes to decide which process should keep the resource.
  2. Circular Wait:

    • Impose a total ordering of resource types and require processes to request resources in a predefined order.
    • Example:
      • If resources R1, R2, R3 exist, a process holding R1 can request R2 but not R3 directly.

Drawback:

  • May require complex resource allocation and planning.

Deadlock Avoidance

Deadlock avoidance ensures that the system remains in a safe state, where there is at least one sequence of process execution that allows all processes to complete without entering a deadlock.

Safe State and Unsafe State

  • Safe State:

    • A state where the system can allocate resources to all processes in some order and avoid deadlock.
  • Unsafe State:

    • A state where there is a risk of deadlock because the system cannot guarantee resource allocation to all processes.

Banker’s Algorithm

The Banker's Algorithm is a classic deadlock avoidance algorithm developed by Edsger Dijkstra. It works as follows:

  1. Data Structures:

    • Available: Vector indicating the number of available resources of each type.
    • Max: Matrix indicating the maximum demand of each process for each resource type.
    • Allocation: Matrix indicating the current allocation of resources to each process.
    • Need: Matrix indicating the remaining resource needs of each process. Need[i][j] = Max[i][j] - Allocation[i][j].
  2. Algorithm Steps:

    • Check if the current resource allocation leads to a safe state.
    • If the allocation does not lead to a safe state, the request is denied to avoid deadlock.

Pseudo Code:

   for each process Pi {
       if (Need[i] <= Available) {
           // Allocate resources to process Pi
           Available = Available - Need[i];
           Allocation[i] = Allocation[i] + Need[i];
       }
       if (state is safe) {
           // Process allocation is successful
           return true;
       } else {
           // Deny resource request
           return false;
       }
   }
Enter fullscreen mode Exit fullscreen mode

Advantages:

  • Ensures that the system remains in a safe state.
  • Provides a guarantee against deadlock.

Disadvantages:

  • Requires precise knowledge of maximum resource requirements in advance.
  • Computationally expensive in systems with a large number of processes or resource types.

Comparison: Deadlock Prevention vs. Deadlock Avoidance

Feature Deadlock Prevention Deadlock Avoidance
Approach Breaks one or more deadlock conditions. Ensures the system stays in a safe state.
Resource Knowledge Does not require exact resource demands. Requires precise knowledge of maximum resource needs.
Overhead Less computational overhead. High computational overhead due to checks.
Flexibility Rigid, less flexible allocation. More flexible allocation.

Conclusion

Deadlocks are a significant challenge in operating systems, but by understanding their causes and employing strategies like prevention and avoidance, systems can maintain stability and efficiency. Each method has its trade-offs, and the choice of strategy depends on the system's requirements and constraints.

os Article's
30 articles in total
Favicon
Critical Section Problem: Process Synchronization
Favicon
Reader Writer Problem: Process Synchronization
Favicon
Protection and Security: Operating System
Favicon
Storage Management: Operating System
Favicon
Process Management: Operating System
Favicon
Introduction to Operating System
Favicon
Memory Management: Operating System
Favicon
Process Synchronization and Deadlock: Operating System
Favicon
OpenBSD 7.5 を 7.6 へ アップグレード
Favicon
Understanding Commodore Operating Systems
Favicon
NixOS - A Unique Linux Distribution
Favicon
Remove Windows software completely
Favicon
OpenBSD Upgrade 7.5 to 7.6
Favicon
Chrome OS Guide to go from Zero to DevOps Hero in a nutshell
Favicon
Understanding the Core Components of an Operating System and How They Work
Favicon
Contribuindo para o FreeBSD
Favicon
Unveiling the Magic Behind Your Computer: A Deep Dive into Operating Systems
Favicon
10 Useful but Rarely Used OS Functions in Python
Favicon
How to Fix Lenovo Thinkpad X1 Extreme Gen freezing without blue screen
Favicon
Unlock 1 Billion NYC Taxi Rides: A Step-by-Step Guide
Favicon
Overlooked Vulnerabilities in Modern Mobile Operating Systems: A Comprehensive Guide
Favicon
OS Development (The truth)
Favicon
Building a 32-Bit Operating System: A Beginner-Friendly Project
Favicon
Kernel vs Operating System
Favicon
Deadlock | Valorant
Favicon
chroot system call
Favicon
How the Operating System Manages Hardware Resources in a Complete System
Favicon
Total Madness #2: Async Locks
Favicon
10 Livros sobre Sistemas Operacionais que vale a pena você ler
Favicon
🖥️ Windows vs macOS: The AI Security Showdown 🛡️

Featured ones: