wisemonkeys logo
FeedNotificationProfileManage Forms
FeedNotificationSearchSign in
wisemonkeys logo

Blogs

Concurrency and Deadlocks

profile
Akshat Gohil
Aug 12, 2024
0 Likes
0 Discussions
152 Reads

Concurrency:

Concurrency refers to the ability of the Operating Systems to execute multiple of processes or threads simultaneously for making efficient usage of CPU time/resources.

Processes are nothing but an instance of a program that is running with its own memory space.

 

OSes uses Context Switching mechanism to implement concurrency. It is the process of saving the current state of a currently executing process or thread and restoring other process or thread. This allows OS to switch between tasks giving an illusion of simultaneous execution.

Concurrency in OS leads to problems like Deadlock and Starvation.

 

Deadlock:

A deadlock is a situation when two are more processes are unable to proceed because each process is waiting for other to release a resource. This leads to a state where none of the processes can continue and they’re stuck indefinitely.

Deadlocks occur when several conditions are met simultaneously:

Mutual Exclusion: Resources are not shared and can be allocated to only one process at a time.

Hold and Wait: A process holding particular resources can request additional resources without releasing currently held.

No Preemption: Resources cannot be taken forcibly from resources and they must be freed simultaneously.

Circular Chain: A circular chain of process where processes wait for other to release resources held by them.

 

Deadlock Prevention:

Deadlock prevention ensures that at least one of the four conditions will not come true and will not lead to a deadlock from occurring.

Prevent Mutual Exclusion: Design systems where minimum number of resources are non-shareable, or convert non-shareable resources to shareable ones if possible reducing the probability of having deadlock.

Prevent Hold and Wait: Processes should request all the necessary resources before execution. If all resources not available it waits for them.

 

Prevent No Preemption: Allow pre-emption of resources where necessary to break deadlock conditions. If P2 needs a resource that P1 holds, P1 is forced to release its resource and wait until both resources are available. The system preempts P1, breaking the deadlock condition.

 

Prevent Circular Wait: Give each resource a unique priority. A process can only request resources in increasing order of their priority. This ensures there is always a linear dependency preventing circular wait.

 

Deadlock Avoidance:

Deadlock Avoidance dynamically decisions are made whether the granting the resource will potentially lead a deadlock.

A process is not granted a resource if it might lead to a deadlock.

Deadlock avoidance allows processes to request resources that prevents the system from entering a deadlock.

 

 

 

 

 

­­­­­­­

 


Comments ()


Sign in

Read Next

12 Principles of Animation

Blog banner

Firewall / IDS Evasion Techniques

Blog banner

Cache memory

Blog banner

Method of Evaluating Information Security Level in an Organization

Blog banner

Delhi city

Blog banner

On-Page SEO

Blog banner

DMZ: Your Secret Weapon for Data Security

Blog banner

Tea, Coffee, Red Wine, and Teeth: A Stain Survival Guide

Blog banner

Raid and levels of raid.

Blog banner

10 Unsolved Mysteries all over the world

Blog banner

How User Data Shapes Personalised Campaigns

Blog banner

First-Order Logic (FOL): The Foundation of Modern Logic

Blog banner

Why Soft Skills Matter as Much as Grades?

Blog banner

Disk scheduling

Blog banner

What is Password Cracking ? and it's Techniques.

Blog banner

Bots and Cyber Security

Blog banner

I/O Management and Disk Scheduling

Blog banner

Jira Software

Blog banner

Loneliness

Blog banner

Measuring IT Risk

Blog banner

Explain the concept of ( MIS) Management information systems

Blog banner

The khan mehtab transforming the modular switches company

Blog banner

Data Exfiltration

Blog banner

Multicore and multithreading 171

Blog banner

Virtual Memory

Blog banner

Data Visualization

Blog banner

operating system

Blog banner

Optimization of operating system design

Blog banner

Why Are So Many Adults Getting Diagnosed with ADHD?

Blog banner

Software Piracy & Online Data Protection in Digital World

Blog banner

FIREWALL

Blog banner

The Impact of Tolerances and Wall Thickness on Pipeline Integrity

Blog banner

Self defence

Blog banner

Data Warehousing

Blog banner

Paralysis/Paralysis Stroke

Blog banner

Short note on expert system

Blog banner

Music

Blog banner

Sagar Parikrama

Blog banner

Asana

Blog banner

Memory Management Techniques

Blog banner

Operating System Objectives and Functions

Blog banner

Article on Fresh Book

Blog banner