6: Process Synchronization 1 1 PROCESS SYNCHRONIZATION I This is about getting processes to coordinate with each other. How do processes work with resources.

Slides:



Advertisements
Similar presentations
Operating Systems Part III: Process Management (Process Synchronization)
Advertisements

Synchronization. How to synchronize processes? – Need to protect access to shared data to avoid problems like race conditions – Typical example: Updating.
Ch 7 B.
Ch. 7 Process Synchronization (1/2) I Background F Producer - Consumer process :  Compiler, Assembler, Loader, · · · · · · F Bounded buffer.
Chapter 6: Process Synchronization
Background Concurrent access to shared data can lead to inconsistencies Maintaining data consistency among cooperating processes is critical What is wrong.
Silberschatz, Galvin and Gagne ©2013 Operating System Concepts – 9 th Edition Chapter 5: Process Synchronization.
5.1 Silberschatz, Galvin and Gagne ©2009 Operating System Concepts with Java – 8 th Edition Chapter 5: CPU Scheduling.
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.
Synchronization Principles Gordon College Stephen Brinton.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 7: Process Synchronization Background The Critical-Section Problem Synchronization.
Chapter 6: Process Synchronization. Outline Background Critical-Section Problem Peterson’s Solution Synchronization Hardware Semaphores Classic Problems.
Chapter 6: Process Synchronization. 6.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts – 7 th Edition, Feb 8, 2005 Objectives Understand.
6: Process Synchronization 1 Jerry Breecher OPERATING SYSTEMS PROCESS SYNCHRONIZATION.
6: Process Synchronization 1 Jerry Breecher OPERATING SYSTEMS PROCESS SYNCHRONIZATION.
Chapter 6: Synchronization. 6.2 Silberschatz, Galvin and Gagne ©2005 Operating System Principles Module 6: Synchronization 6.1 Background 6.2 The Critical-Section.
Synchronization Solutions
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.
Chapter 6: Process Synchronization. 6.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts – 7 th Edition, Feb 8, 2005 Background Concurrent.
Concurrency, Mutual Exclusion and Synchronization.
6: Process Synchronization 1 Jerry Breecher OPERATING SYSTEMS PROCESS SYNCHRONIZATION.
Process Synchronization Continued 7.2 Critical-Section Problem 7.3 Synchronization Hardware 7.4 Semaphores.
6.3 Peterson’s Solution The two processes share two variables: Int turn; Boolean flag[2] The variable turn indicates whose turn it is to enter the critical.
Operating Systems ECE344 Ashvin Goel ECE University of Toronto Mutual Exclusion.
Principles of Operating Systems Lecture 6 and 7 - Process Synchronization.
1 Chapter 6: Process Synchronization Background The Critical-Section Problem Peterson’s Solution Special Machine Instructions for Synchronization Semaphores.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 7: Process Synchronization Background The Critical-Section Problem Synchronization.
Chap 6 Synchronization. Background Concurrent access to shared data may result in data inconsistency Maintaining data consistency requires mechanisms.
Chapter 6: Synchronization. 6.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Module 6: Synchronization Background The Critical-Section.
Process Synchronization.  Whenever processes share things, there is a chance for screwing up things  For example ◦ Two processes sharing one printer.
Silberschatz, Galvin and Gagne ©2013 Operating System Concepts Essentials – 9 th Edition Chapter 5: Process Synchronization.
Chapter 7 -1 CHAPTER 7 PROCESS SYNCHRONIZATION CGS Operating System Concepts UCF, Spring 2004.
Process Synchronization Tanenbaum Ch 2.3, 2.5 Silberschatz Ch 6.
Chapter 6: Process Synchronization. 6.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Module 6: Process Synchronization Background The.
Chapter 6: Process Synchronization. Module 6: Process Synchronization Background The Critical-Section Problem Peterson’s Solution Synchronization Hardware.
Background Concurrent access to shared data may result in data inconsistency Maintaining data consistency requires mechanisms to ensure the orderly execution.
CS399 New Beginnings Jonathan Walpole. 2 Concurrent Programming & Synchronization Primitives.
Operating Systems CSE 411 CPU Management Dec Lecture Instructor: Bhuvan Urgaonkar.
Operating Systems Lecture Notes Synchronization Matthew Dailey Some material © Silberschatz, Galvin, and Gagne, 2002.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 6: Process Synchronization.
Synchronization CSCI 3753 Operating Systems Spring 2005 Prof. Rick Han.
CS4315A. Berrached:CMS:UHD1 Process Synchronization Chapter 8.
Process Synchronization CS 360. Slide 2 CS 360, WSU Vancouver Process Synchronization Background The Critical-Section Problem Synchronization Hardware.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Chapter 6: Process Synchronization.
Silberschatz, Galvin and Gagne ©2013 Operating System Concepts – 9 th Edition Chapter 5: Process Synchronization.
CE Operating Systems Lecture 8 Process Scheduling continued and an introduction to process synchronisation.
Chapter 6 Synchronization Dr. Yingwu Zhu. The Problem with Concurrent Execution Concurrent processes (& threads) often access shared data and resources.
Web Server Architecture Client Main Thread for(j=0;j
6.1 Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Chapter 6: Synchronization Background The Critical-Section Problem Peterson’s.
Process Synchronization
Chapter 5: Process Synchronization
Process Synchronization: Semaphores
Background on the need for Synchronization
Chapter 5: Process Synchronization
Chapter 5: Process Synchronization
Chapter 6: Synchronization Tools
Topic 6 (Textbook - Chapter 5) Process Synchronization
Module 7a: Classic Synchronization
Lecture 2 Part 2 Process Synchronization
Critical section problem
Grades.
Concurrency: Mutual Exclusion and Process Synchronization
Chapter 6: Process Synchronization
CSE 153 Design of Operating Systems Winter 19
Chapter 6: Synchronization Tools
Process/Thread Synchronization (Part 2)
Presentation transcript:

6: Process Synchronization 1 1 PROCESS SYNCHRONIZATION I This is about getting processes to coordinate with each other. How do processes work with resources that must be shared between them? How do we go about acquiring locks to protect regions of memory?

6: Process Synchronization 1 2 PROCESS SYNCHRONIZATION A producer process "produces" information "consumed" by a consumer process. Consider the following code segment: Does it work? All all buffers utilized? The Producer Consumer Problem initialize: in = out = 0; Producer Repeat forever.... produce an item in nextp while in + 1 mod n == out do no-op; buffer[in] = nextp; in = in + 1 mod n; until false; Initialize: in = out = 0; Consumer Repeat forever …. while in == out do no-op; nextc = buffer[out]; out = out + 1 mod n;... consume the item in nextc until false;

6: Process Synchronization 1 3 How about this implementation? Does it work? initialize: in = out = counter = 0; Producer Repeat forever.... produce an item in nextp.... while counter == n do no-op; buffer[in] = nextp; in = in + 1 mod n; counter = counter + 1; until false; Consumer Repeat forever while counter == 0 do no-op; nextc = buffer[out]; out = out + 1 mod n; counter = counter - 1;... consume the item in nextc... until false; PROCESS SYNCHRONIZATION The Producer Consumer Problem

6: Process Synchronization 1 4 Note that counter = counter + 1;  this line is NOT what it seems!! is really --> register = counter register = register + 1 counter = register At a micro level, the following scenario could occur using this code: PROCESS SYNCHRONIZATION The Producer Consumer Problem TO;Producer Executeregister1 = counter register1 = 5 T1;Producer Executeregister1 = register1 + 1 register1 = 6 T2;Consumer Executeregister2 = counter register2 = 5 T3;Consumer Executeregister2 = register2 - 1 register2 = 4 T4;Producer Executecounter = register1 counter = 6 T5;Consumer Executecounter = register2 counter = 4

6: Process Synchronization 1 5 A section of code, common to n cooperating processes, in which the processes may be accessing common variables. A Critical Section Environment contains: Entry SectionCode requesting entry into the critical section. Critical SectionCode in which only one process can execute at any one time. Exit SectionThe end of the critical section, releasing or allowing others in. Remainder SectionRest of the code AFTER the critical section. PROCESS SYNCHRONIZATION Critical Sections

6: Process Synchronization 1 6 The critical section must ENFORCE ALL THREE of the following rules: Mutual Exclusion: No more than one process can execute in its critical section at one time. Progress: If no one is in the critical section and someone wants in, then those processes not in their remainder section must be able to decide in a finite time who should go in. Bounded Wait: All requesters must eventually be let into the critical section. PROCESS SYNCHRONIZATION Critical Sections

6: Process Synchronization 1 7 The hardware required to support critical sections must have (minimally):  Indivisible instructions (what are they?)  Atomic load, store, test instruction. For instance, if a store and test occur simultaneously, the test gets EITHER the old or the new, but not some combination.  Two atomic instructions, if executed simultaneously, behave as if executed sequentially. PROCESS SYNCHRONIZATION Critical Sections

6: Process Synchronization 1 8 Here we try a succession of increasingly complicated solutions to the problem of creating valid entry sections. NOTE: In all examples, i is the current process, j the "other" process. In these examples, envision the same code running on two processors at the same time. TOGGLED ACCESS: repeat while ( turn ^= i ) do no-op; /* critical section */ turn = j; /* remainder section */ until ( false ); PROCESS SYNCHRONIZATION Two Processes Software Are the three Critical Section Requirements Met?

6: Process Synchronization 1 9 Answer: Looking at that same code again, we see it alternately allows each of the processes access in turn. But what happens, for example, if i wants to get in twice? NOTE: The equivalent C code is: while (TRUE) { while ( turn ^= i ); /* Critical Section */ turn = j; } PROCESS SYNCHRONIZATION Two Processes Software repeat while ( turn ^= i ) do no-op; /* critical section */ turn = j; /* remainder section */ until ( false ); Repeat of code on last slide

6: Process Synchronization 1 10 FLAG FOR EACH PROCESS INDICATES STATE: Each process maintains a flag indicating that it wants to get into the critical section. It then checks the flag of the other process and doesn’t enter the critical section if that other process wants to get in. Are the three Critical Section Requirements Met? PROCESS SYNCHRONIZATION Two Processes Software var flag: array [0..1] of Boolean; repeat flag[i] = true; while ( flag[j] ) do no-op; /* critical section */ flag[i] = false; /* remainder section */ until ( false );

6: Process Synchronization 1 11 FLAG TO REQUEST ENTRY: Each processes sets a flag to request entry. But each process toggles a bit to allow the other in first. This code is executed for each process i. Are the three Critical Section Requirements Met? PROCESS SYNCHRONIZATION Two Processes Software var flag: array [0..1] of Boolean; turn: 0..1; repeat flag[i] = true; turn = j; while ( flag[j] and turn == j ) do no-op; /* critical section */ flag[i] = false; /* remainder section */ until ( false );

6: Process Synchronization 1 12 Disabling Interrupts:Works for the Uni Processor case only. WHY? Atomic test and set: Returns parameter and sets parameter to true atomically. while ( test_and_set ( lock ) ) do no-op; /* critical section */ lock = false; Example of Assembler code: GET_LOCK: IF_CLEAR_THEN_SET_BIT_AND_SKIP BRANCH GET_LOCK /* set failed */ /* set succeeded */ Must be careful if these approaches are to satisfy a bounded wait condition - must use round robin - requires code built around the lock instructions. PROCESS SYNCHRONIZATION Hardware Solutions

6: Process Synchronization 1 13 Booleanwaiting[N]; intj;/* Takes on values from 0 to N - 1*/ Booleankey; While { waiting[i] = TRUE; key = TRUE; while( waiting[i] && key ) key = test_and_set( lock ); /* Spin lock*/ waiting[ i ] = FALSE; /****** CRITICAL SECTION ********/ j = ( i + 1 ) mod N; while ( ( j != i ) && ( ! waiting[ j ] ) ) j = ( j + 1 ) mod N; if ( j == i ) lock = FALSE; else waiting[ j ] = FALSE; /******* REMAINDER SECTION *******/ } Using Hardware Test_and_set. PROCESS SYNCHRONIZATION Hardware Solutions

6: Process Synchronization 1 14 We first need to define, for multiprocessors: caches, shared memory (for storage of lock variables), write through cache, write pipes. The last software solution we did ( the one we thought was correct ) fails utterly on a cached multiprocessor. Why? { Hint, is the write by one processor visible immediately to all other processors?} What changes must be made to the hardware for this program to work? PROCESS SYNCHRONIZATION Current Hardware Dilemmas

6: Process Synchronization 1 15 Does the sequence below work on a cached multiprocessor? Initially, location a contains A0 and location b contains B0. a) Processor 1 writes data A1 to location a. b) Processor 1 sets b to B1 indicating data at a is valid. c) Processor 2 waits for b to take on value B1 and loops until that change occurs. d) Processor 2 reads the value from a. What value is seen by Processor 2 when it reads a? How must hardware be specified to guarantee the value seen? PROCESS SYNCHRONIZATION Current Hardware Dilemmas a: A0b: B0

6: Process Synchronization 1 16 We need to discuss: Write Ordering: The first write by a processor will be visible before the second write is visible. This requires a write through cache. Sequential Consistency: If Processor 1 writes to Location a "before" Processor 2 writes to Location b, then a is visible to ALL processors before b is. To do this requires NOT caching shared data. The software solutions discussed earlier should be avoided since they require write ordering and/or sequential consistency. PROCESS SYNCHRONIZATION Current Hardware Dilemmas

6: Process Synchronization 1 17 Hardware test and set on a multiprocessor causes  an explicit flush of the write to main memory and  the update of all other processor's caches. Imagine needing to write all shared data straight through the cache. With test and set, only lock locations are written out explicitly. In not too many years, hardware will no longer support software solutions because of the performance impact of doing so. PROCESS SYNCHRONIZATION Current Hardware Dilemmas

6: Process Synchronization 1 18 PURPOSE: We want to be able to write more complex constructs and so need a language to do so. We thus define semaphores which we assume are atomic operations: As given here, these are not atomic as written in "macro code". We define these operations, however, to be atomic (Protected by a hardware lock.) FORMAT: wait ( mutex ); <-- Mutual exclusion: mutex init to 1. CRITICAL SECTION signal( mutex ); REMAINDER WAIT ( S ): while S <= 0 do no-op; S = S - 1; SIGNAL ( S ): S = S + 1; PROCESS SYNCHRONIZATION Semaphores

6: Process Synchronization 1 19 Semaphores can be used to force synchronization ( precedence ) if the preceeder does a signal at the end, and the follower does wait at beginning. For example, here we want P1 to execute before P2. P1: P2: statement 1; wait ( synch ); signal ( synch ); statement 2; PROCESS SYNCHRONIZATION Semaphores

6: Process Synchronization 1 20 We don't want to loop on busy, so will suspend instead: Block on semaphore == False, Wakeup on signal ( semaphore becomes True), There may be numerous processes waiting for the semaphore, so keep a list of blocked processes, Wakeup one of the blocked processes upon getting a signal ( choice of who depends on strategy ). To PREVENT looping, we redefine the semaphore operations as: type semaphore = record value: integer; L: list of process; /* linked list of PTBL waiting on S */ end; PROCESS SYNCHRONIZATION Semaphores

6: Process Synchronization 1 21 type semaphore = record value: integer; L: list of process; /* linked list of PTBL waiting on S */ end; It's critical that these be atomic - in uniprocessors we can disable interrupts, but in multiprocessors other mechanisms for atomicity are needed. Popular incarnations of semaphores are as "event counts" and "lock managers". (We'll talk about these in the next chapter.) wait(s): s.value = s.value - 1; if ( s.value < 0 ) then begin add this process to s.L; block; end; signal(s): s.value = s.value + 1; if ( s.value <= 0 ) then begin remove a process P from s.L; wakeup(P); end; PROCESS SYNCHRONIZATION Semaphores

6: Process Synchronization 1 22 DEADLOCKS: · May occur when two or more processes try to get the same multiple resources at the same time. P1: P2: wait(S); wait(Q); wait(Q); wait(S); signal(S); signal(Q); signal(Q); signal(S); · How can this be fixed? PROCESS SYNCHRONIZATION Semaphores

6: Process Synchronization 1 23 Wrap up In this chapter we have: Looked at many incarnations of the producer consumer problem. Understood how to use critical sections and their use in semaphores. PROCESS SYNCHRONIZATION