Chapter 5 Concurrency: Mutual Exclusion and Synchronization

Slides:



Advertisements
Similar presentations
Chapter 5 Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles, 6/E William Stallings Patricia Roy Manatee.
Advertisements

1 Chapter 5 Concurrency: Mutual Exclusion and Synchronization Principals of Concurrency Mutual Exclusion: Hardware Support Semaphores Readers/Writers Problem.
Concurrency: Mutual Exclusion and Synchronization Chapter 5.
Chapter 6: Process Synchronization
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 6: Process Synchronization.
Process Synchronization. Module 6: Process Synchronization Background The Critical-Section Problem Peterson’s Solution Synchronization Hardware Semaphores.
CH7 discussion-review Mahmoud Alhabbash. Q1 What is a Race Condition? How could we prevent that? – Race condition is the situation where several processes.
Chapter 5 Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles Seventh Edition By William Stallings.
Concurrency: mutual exclusion and synchronization Slides are mainly taken from «Operating Systems: Internals and Design Principles”, 8/E William Stallings.
Chapter 5 Concurrency: Mutual Exclusion and Synchronization
Chapter 5 Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles Seventh Edition By William Stallings.
Concurrency: Mutual Exclusion and Synchronization Chapter 5.
1 Concurrency: Mutual Exclusion and Synchronization Chapter 5.
Operating Systems CMPSC 473 Mutual Exclusion Lecture 13: October 12, 2010 Instructor: Bhuvan Urgaonkar.
Informationsteknologi Wednesday, September 26, 2007 Computer Systems/Operating Systems - Class 91 Today’s class Mutual exclusion and synchronization 
Computer Systems/Operating Systems - Class 8
Chapter 5 Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles, 6/E William Stallings Patricia Roy Manatee.
Enforcing Mutual Exclusion, Semaphores. Four different approaches Hardware support Disable interrupts Special instructions Software-defined approaches.
1 Concurrency: Mutual Exclusion and Synchronization Chapter 5.
Chapter 6: Process Synchronization. Outline Background Critical-Section Problem Peterson’s Solution Synchronization Hardware Semaphores Classic Problems.
1 Chapter 6: Concurrency: Mutual Exclusion and Synchronization Operating System Spring 2007 Chapter 6 of textbook.
A. Frank - P. Weisberg Operating Systems Introduction to Cooperating Processes.
Instructor: Umar KalimNUST Institute of Information Technology Operating Systems Process Synchronization.
Adopted from and based on Textbook: Operating System Concepts – 8th Edition, by Silberschatz, Galvin and Gagne Updated and Modified by Dr. Abdullah Basuhail,
Operating Systems CSE 411 CPU Management Oct Lecture 13 Instructor: Bhuvan Urgaonkar.
Operating System 5 CONCURRENCY: MUTUAL EXCLUSION AND SYNCHRONIZATION.
Chapter 5 Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles, 6/E William Stallings 1.
Chapter 5 Concurrency: Mutual Exclusion and Synchronization
Chapter 6: Process Synchronization. 6.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts – 7 th Edition, Feb 8, 2005 Background Concurrent.
Chapter 5 Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles, 6/E William Stallings Dave Bremer Otago.
Concurrency, Mutual Exclusion and Synchronization.
Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles, 6/E William Stallings Dave Bremer Otago Polytechnic,
Concurrency: Mutual Exclusion and Synchronization Chapter 5.
Chapter 5 Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles, 6/E William Stallings Dave Bremer Otago.
© Janice Regan, CMPT 300, May CMPT 300 Introduction to Operating Systems Introduction to Concurrency.
© Janice Regan, CMPT 300, May CMPT 300 Introduction to Operating Systems Classical problems.
Critical Problem Revisit. Critical Sections Mutual exclusion Only one process can be in the critical section at a time Without mutual exclusion, results.
Midterm 1 – Wednesday, June 4  Chapters 1-3: understand material as it relates to concepts covered  Chapter 4 - Processes: 4.1 Process Concept 4.2 Process.
Concurrency: Mutual Exclusion and Synchronization Chapter 5.
Concurrency: Mutual Exclusion and Synchronization Chapter 5.
Chap 6 Synchronization. Background Concurrent access to shared data may result in data inconsistency Maintaining data consistency requires mechanisms.
Concurrency: Mutual Exclusion and Synchronization Chapter 5.
1 Concurrency: Mutual Exclusion and Synchronization Chapter 5.
Chapter 5 Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles, 6/E William Stallings Patricia Roy Manatee.
1 Concurrency: Mutual Exclusion and Synchronization Chapter 4.
1 Concurrency: Mutual Exclusion and Synchronization Chapter 5.
CSNB334 Advanced Operating Systems 4. Concurrency : Mutual Exclusion and Synchronization.
Chapter 5 Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles, 6/E William Stallings Patricia Roy Manatee.
Chapter 6: Process Synchronization. 6.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Module 6: Process Synchronization Background The.
Computer Architecture and Operating Systems CS 3230: Operating System Section Lecture OS-5 Process Synchronization Department of Computer Science and Software.
Operating Systems CSE 411 CPU Management Dec Lecture Instructor: Bhuvan Urgaonkar.
Concurrency in Shared Memory Systems Synchronization and Mutual Exclusion.
Chapter 5 Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles, 6/E William Stallings Patricia Roy Manatee.
Operating System Chapter 5. Concurrency: Mutual Exclusion and Synchronization Lynn Choi School of Electrical Engineering.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Chapter 6: Process Synchronization.
Chapter 6 Synchronization Dr. Yingwu Zhu. The Problem with Concurrent Execution Concurrent processes (& threads) often access shared data and resources.
Chapter 5 Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles, 6/E William Stallings Patricia Roy Manatee.
G.Anuradha Reference: William Stallings
Concurrency.
Chapter 5 Concurrency: Mutual Exclusion and Synchronization
Concurrency These slides are intended to help a teacher develop a presentation. This PowerPoint covers the entire chapter and includes too many slides.
Concurrency: Mutual Exclusion and Synchronization
Chapter 5: Process Synchronization
Concurrency: Mutual Exclusion and Synchronization
Chapter 5 Concurrency: Mutual Exclusion and Synchronization
Concurrency: Mutual Exclusion and Process Synchronization
Operating System 5 CONCURRENCY: MUTUAL EXCLUSION AND SYNCHRONIZATION
Operating Systems Concepts
Chapter 5 Mutual Exclusion(互斥) and Synchronization(同步)
Presentation transcript:

Chapter 5 Concurrency: Mutual Exclusion and Synchronization Principals of Concurrency Mutual Exclusion: Hardware Support Semaphores Readers/Writers Problem

Multiple Processes Central to the design of modern Operating Systems is managing multiple processes Multiprogramming Multiprocessing Distributed Processing Big Issue is Concurrency Managing the interaction of all of these processes

Interleaving and Overlapping Processes Earlier (Ch2) we saw that processes may be interleaved on uniprocessors

Interleaving and Overlapping Processes And not only interleaved but overlapped on multi-processors Both interleaving and overlapping present the same problems in concurrent processing

Difficulties of Concurrency Sharing of global resources consider two processes perform reads and writes on the same global variable Optimally managing the allocation of resources is difficult Difficult to locate programming errors as results are not deterministic and reproducible.

A Simple Example void echo() Suppose echo is a shared procedure and P1 echoes ‘x’ and P2 echoes ‘y’ void echo() { // send a keyboard-input character to display chin = getchar(); chout = chin; putchar(chout); } What would happen if P1 is interrupted here by P2? What would happen if only one process is permitted at a time to be in the procedure?

A Simple Example: On a Multiprocessor Process P1 Process P2 . . chin = getchar(); . . chin = getchar(); chout = chin; chout = chin; putchar(chout); . . putchar(chout); . .

Enforce Single Access Solution: Control access to shared resource If we enforce a rule that only one process may enter the function at a time then: P1 & P2 run on separate processors P1 enters echo first, P2 tries to enter but is blocked P1 completes execution P2 resumes and executes echo Solution: Control access to shared resource

Race Condition A race condition occurs when Multiple processes or threads read and write data items They do so in a way where the final result depends on the order of execution of the processes The output depends on who finishes the race last (the loser) However, the processes and outputs must be independent of the processing speed

Process Interaction Example: multiprogramming of multiple independent processes Example: processes share access to some object, such as an I/O buffer Example: Processes designed to work jointly on some activity

Competition among Processes for Resources Three main control problems: Need for Mutual Exclusion Critical resource: nonsharable resource, e.g., printer Critical section: portion of the program that uses a critical resource Deadlock Starvation

Requirements for Mutual Exclusion Only one process at a time is allowed in the critical section for a resource A process that halts in its noncritical section must do so without interfering with other processes No deadlock or starvation

Requirements for Mutual Exclusion A process must not be delayed access to a critical section when there is no other process using it No assumptions are made about relative process speeds or number of processes A process remains inside its critical section for a finite time only

Roadmap Principals of Concurrency Mutual Exclusion: Hardware Support Semaphores Readers/Writers Problem

Disabling Interrupts Uniprocessors only allow interleaving Interrupt Disabling A process runs until it invokes an operating system service or until it is interrupted Disabling interrupts guarantees mutual exclusion because the critical section cannot be interrupted

Pseudo-Code while (true) { } /* disable interrupts */; /* critical section */; /* enable interrupts */; /* remainder */; }  Reduced interleaving  Will not work in multiprocessor architecture

Special Machine Instructions Use of atomic action: instruction is treated as a single step that cannot be interrupted Compare&Swap Instruction int compare_and_swap (int *word, int testval, int newval) { /* checks a memory location (*word) against a test value (testval) */ int oldval; oldval = *word; if (oldval == testval) *word = newval; return oldval; }

Mutual Exclusion (fig 5.2) The only process that may enter its critical section is one that finds bolt equal to 0 All other processes go into a busy waiting mode

Hardware Mutual Exclusion: Advantages Applicable to any number of processes on either a single processor or multiple processors sharing main memory It is simple and therefore easy to verify It can be used to support multiple critical sections

Hardware Mutual Exclusion: Disadvantages Busy-waiting consumes processor time Starvation is possible when a process leaves a critical section and more than one process is waiting Some process could indefinitely be denied access because selection of a waiting process is arbitrary Deadlock is possible Example: P1 enters its critical section and is then preempted by higher priority P2 which will go into a busy waiting loop

Roadmap Principals of Concurrency Mutual Exclusion: Hardware Support Semaphores Readers/Writers Problem

Semaphore Semaphore: An integer value used for signalling among processes Only three operations may be performed on a semaphore, all of which are atomic: initialize (to a nonnegative integer value) decrement (semWait) increment (semSignal)

Semaphore Primitives

Binary Semaphore Primitives

Strong/Weak Semaphore A queue is used to hold processes waiting on the semaphore In what order are processes removed from the queue? Strong Semaphores use FIFO Weak Semaphores don’t specify the order of removal from the queue

Mutual Exclusion Using Semaphores The first process that executes a semWait will be able to enter the critical section immediately, setting the value of s to 0 Any other processes attempting to enter the critical section will find it busy and will be blocked

Processes Accessing Shared Data Using Semaphore Three processes (A,B,C) access a shared resource protected by the semaphore lock.

Mutual Exclusion Using Semaphores The semaphore can be initialized to a specified value to allow more than one process in its critical section at a time s.count0: the number of processes that can execute semWait(s) without suspension s.count<0: the magnitude is the number processes suspended in s.queue

Producer/Consumer Problem General Situation: One or more producers are generating data and placing these in a buffer A single consumer is taking items out of the buffer one at time Only one producer or consumer may access the buffer at any one time The Problem: Ensure that the Producer can’t add data into full buffer and consumer can’t remove data from empty buffer Producer/Consumer Animation

Functions Assume an infinite buffer b with a linear array of elements Producer Consumer while (true) { /* produce item v */ b[in] = v; in++; } while (in <= out) /*do nothing */; w = b[out]; out++; /* consume item w */

Buffer The consumer must make sure that the producer has advanced beyond it (in > out) before proceeding The producer can generate items and store them in the buffer at its own pace. Each time, in is incremented

Semaphores n is equal to the number of items in the buffer Prevent the consumer and any other producer from accessing the buffer during the append operation The consumer must wait on both semaphores before proceeding

Bounded Buffer The buffer is treated as a circular storage; pointer values are expressed modulo the size of the buffer

Functions in a Bounded Buffer in and out are initialized to 0 and n is the size of the buffer Producer Consumer while (true) { /* produce item v */ while ((in + 1) % n == out) /* do nothing */; b[in] = v; in = (in + 1) % n } while (in == out) w = b[out]; out = (out + 1) % n; /* consume item w */

Semaphores e keeps track of the number of empty spaces

Demonstration Animations Producer/Consumer Illustrates the operation of a producer-consumer buffer. Bounded-Buffer Problem Using Semaphores Demonstrates the bounded-buffer consumer/producer problem using semaphores.

Roadmap Principals of Concurrency Mutual Exclusion: Hardware Support Semaphores Readers/Writers Problem

Readers/Writers Problem A data area (e.g., a file) is shared among many processes Some processes (readers) only read the data area, some (writers) only write to the area Conditions to satisfy: Multiple readers may simultaneously read the file Only one writer at a time may write If a writer is writing to the file, no reader may read it interaction of readers and writers.

Readers have Priority readcount keeps track of the number of readers x is used to assure that readcount is updated properly the first reader that attempts to read should wait on wsem wsem is used to enforce mutual exclusion: as long as one writer is accessing the shared data area, no other writers and no readers may access it

Readers/Writers Problem Once a single reader has begun to access the data area, it is possible for readers to retain control of the data area as long as there is at least one reader reading. Therefore, writers are subject to starvation An alternative solution: no new readers are allowed access to the data area once at least one writer wants to write

Writers have Priority y controls the updating of writecount writecount controls the setting of rsem rsem inhibits all readers while there is at least one writer desiring access to the data area

Writers have Priority only one reader is allowed to queue on rsem, with any additional readers queuing on z

Writers have Priority

Key Terms 44