Opera&ng Systems ECE344

Similar documents
Operating Systems ECE344

CSE 153 Design of Operating Systems

CS 318 Principles of Operating Systems

CSE 120 Principles of Operating Systems Spring 2016

CSE 120 Principles of Operating Systems Spring 2016

Lecture 6 (cont.): Semaphores and Monitors

CS 318 Principles of Operating Systems

CSE 451: Operating Systems Spring Module 10 Semaphores, Condition Variables, and Monitors

Semaphores. Blocking in semaphores. Two types of semaphores. Example: Bounded buffer problem. Binary semaphore usage

CSE 120. Fall Lecture 6: Semaphores. Keith Marzullo

Lecture 7: CVs & Scheduling

CSE120 Principles of Operating Systems. Prof Yuanyuan (YY) Zhou Synchronization: Semaphore

CSE 451: Operating Systems Winter Synchronization. Gary Kimura

CSE 120 Principles of Operating Systems Spring 2016

There are 8 total numbered pages, 6 Questions. You have 60 minutes. Budget your time carefully!

Dealing with Issues for Interprocess Communication

CS 153 Design of Operating Systems Winter 2016

Semaphores. Jinkyu Jeong Computer Systems Laboratory Sungkyunkwan University

Semaphores and Monitors: High-level Synchronization Constructs

CS 318 Principles of Operating Systems

Operating Systems. Operating Systems Summer 2017 Sina Meraji U of T

Synchronization. CS 416: Operating Systems Design, Spring 2011 Department of Computer Science Rutgers University

Synchronization. Dr. Yingwu Zhu

Concurrency. On multiprocessors, several threads can execute simultaneously, one on each processor.

CS510 Operating System Foundations. Jonathan Walpole

Synchroniza+on II COMS W4118

EECS 482 Introduction to Operating Systems

Lecture 8: September 30

CS 537 Lecture 8 Monitors. Thread Join with Semaphores. Dining Philosophers. Parent thread. Child thread. Michael Swift

Synchronization 1. Synchronization

Concurrency. On multiprocessors, several threads can execute simultaneously, one on each processor.

Reminder from last time

Concurrency. On multiprocessors, several threads can execute simultaneously, one on each processor.

Semaphores INF4140. Lecture 3. 0 Book: Andrews - ch.04 ( ) INF4140 ( ) Semaphores Lecture 3 1 / 34

IV. Process Synchronisation

Summary Semaphores. Passing the Baton any await statement. Synchronisation code not linked to the data

Operating Systems CMPSC 473. Synchronization February 26, Lecture 12 Instructor: Trent Jaeger

Introduction to OS Synchronization MOS 2.3

CSC501 Operating Systems Principles. Process Synchronization

CS 162 Operating Systems and Systems Programming Professor: Anthony D. Joseph Spring Lecture 8: Semaphores, Monitors, & Condition Variables

CS 153 Design of Operating Systems Winter 2016

Semaphore. Originally called P() and V() wait (S) { while S <= 0 ; // no-op S--; } signal (S) { S++; }

Enforcing Mutual Exclusion Using Monitors

Locks and Condition Variables Recap. Introducing Monitors. Hoare Monitors: Semantics. Coke Machine Example. Locks. Condition variables

Concept of a process

Chapter 6: Synchronization. Operating System Concepts 8 th Edition,

Critical Section Problem: Example

Synchronization 1. Synchronization

Chapter 6: Process Synchronization

Silberschatz and Galvin Chapter 6

Process Management And Synchronization

Operating Systems. Lecture 4 - Concurrency and Synchronization. Master of Computer Science PUF - Hồ Chí Minh 2016/2017

Process Synchronization. studykorner.org

Semaphores. To avoid busy waiting: when a process has to wait, it will be put in a blocked queue of processes waiting for the same event

Semaphores. Semaphores. Semaphore s operations. Semaphores: observations

Operating Systems (2INC0) 2017/18

Synchronization. Disclaimer: some slides are adopted from the book authors slides 1

Critical Section Problem: Example

Concurrency. On multiprocessors, several threads can execute simultaneously, one on each processor.

CS 4410 Operating Systems. Review 1. Summer 2016 Cornell University

Background. The Critical-Section Problem Synchronisation Hardware Inefficient Spinning Semaphores Semaphore Examples Scheduling.

CSE Opera,ng System Principles

Lecture 9: Midterm Review

CSE 451: Operating Systems Winter Lecture 7 Synchronization. Hank Levy 412 Sieg Hall

Synchronization. Heechul Yun. Disclaimer: some slides are adopted from the book authors and Dr. Kulkani

Synchronization. Disclaimer: some slides are adopted from the book authors slides 1

Threading and Synchronization. Fahd Albinali

Deadlock and Monitors. CS439: Principles of Computer Systems September 24, 2018

What's wrong with Semaphores?

Deadlock and Monitors. CS439: Principles of Computer Systems February 7, 2018

CSE 153 Design of Operating Systems

CS 326 Operating Systems Synchronization. Greg Benson Department of Computer Science University of San Francisco

Last Class: Synchronization. Review. Semaphores. Today: Semaphores. MLFQ CPU scheduler. What is test & set?

Concurrency Control. Synchronization. Brief Preview of Scheduling. Motivating Example. Motivating Example (Cont d) Interleaved Schedules

CSE Traditional Operating Systems deal with typical system software designed to be:

Lecture 3: Intro to Concurrent Processing using Semaphores

CS 31: Intro to Systems Misc. Threading. Kevin Webb Swarthmore College December 6, 2018

Synchronization I. Jo, Heeseung

Condition Variables CS 241. Prof. Brighten Godfrey. March 16, University of Illinois

Chapter 8. Basic Synchronization Principles

2 Threads vs. Processes

Operating Systems. Designed and Presented by Dr. Ayman Elshenawy Elsefy

Background. Old Producer Process Code. Improving the Bounded Buffer. Old Consumer Process Code

Process Synchronization Mechanisms

Lecture 6. Process Synchronization

Threads. Concurrency. What it is. Lecture Notes Week 2. Figure 1: Multi-Threading. Figure 2: Multi-Threading

Process synchronization

Chapter 6: Process Synchronization

CHAPTER 6: PROCESS SYNCHRONIZATION

CS370 Operating Systems

CS 153 Design of Operating Systems Spring 18

Plan. Demos. Next Project. CSCI [4 6]730 Operating Systems. Hardware Primitives. Process Synchronization Part II. Synchronization Part 2

CMSC421: Principles of Operating Systems

Chapter 6: Process Synchronization. Operating System Concepts 8 th Edition,

Semaphores. Derived Inference Rules. (R g>0) Q g (g 1) {R} V (g) {Q} R Q g (g+1) V (s), hs := 1; i

Outline for Today. 5 Dining Philosophers. Template for Philosopher. Naive Solution. Objective: Administrative details:

Chapter 6: Synchronization. Chapter 6: Synchronization. 6.1 Background. Part Three - Process Coordination. Consumer. Producer. 6.

Page 1. Goals for Today" Atomic Read-Modify-Write instructions" Examples of Read-Modify-Write "

5 Dining Philosophers. Template for Philosopher. Naive Solution. while (food available) /*pick up forks*/ eat; /*put down forks*/ think awhile;

Learning Outcomes. Concurrency and Synchronisation. Textbook. Concurrency Example. Inter- Thread and Process Communication. Sections & 2.

Transcription:

Opera&ng Systems ECE344 Lecture 6: Synchroniza&on (II) Semaphores and Monitors Ding Yuan

Higher- Level Synchroniza&on We looked at using locks to provide mutual exclusion Locks work, but they have some drawbacks when critical regions are long Spinlocks inefficient Disabling interrupts can miss or delay important events Instead, we want synchronization mechanisms that Block waiters Leave interrupts enabled inside the critical section Look at two common high-level mechanisms Semaphores: binary (mutex) and counting Monitors: mutexes and condition variables Use them to solve common synchronization problems Ding Yuan, ECE344 Opera&ng System 2

Semaphores Semaphores are an abstract data type that provide mutual exclusion to critical region Semaphores can also be used as atomic counters More later Semaphores are integers that support two operations: wait(semaphore): decrement, block until semaphore is open Also P(), after the Dutch word for test, or down() signal(semaphore): increment, allow another thread to enter Also V() after the Dutch word for increment, or up() That's it! No other operations not even just reading its value exist P and V are probably the most unintuitive names you encounter in this course and you have Edsger W. Dijkstra to thank to Semaphore safety property: the semaphore value is always greater than or equal to 0 Ding Yuan, ECE344 Opera&ng System 3

Blocking in Semaphores Associated with each semaphore is a queue of waiting processes/threads When P() is called by a thread: If semaphore is open (> 0), thread continues If semaphore is closed, thread blocks on queue Then V() opens the semaphore: If a thread is waiting on the queue, the thread is unblocked What if multiple threads are waiting on the queue? If no threads are waiting on the queue, the signal is remembered for the next thread In other words, V() has history (c.f., condition vars later) This history is a counter Ding Yuan, ECE344 Opera&ng System 4

Semaphore Types Semaphores come in two types Mutex semaphore (or binary semaphore) Represents single access to a resource Guarantees mutual exclusion to a critical section Counting semaphore (or general semaphore) Represents a resource with many units available, or a resource that allows certain kinds of unsynchronized concurrent access (e.g., reading) Multiple threads can pass the semaphore (P) Number of threads determined by the semaphore count mutex has count = 1, counting has count = N Ding Yuan, ECE344 Opera&ng System 5

Using Semaphores Use is similar to our locks, but semantics are different struct Semaphore { int value; Queue q; S; withdraw (account, amount) { P(S); balance = get_balance(account); balance = balance amount; put_balance(account, balance); V(S); return balance; Threads block cri=cal sec=on P(S); balance = get_balance(account); balance = balance amount; P(S); P(S); put_balance(account, balance); V(S); V(S); It is undefined which thread runs a;er a signal V(S); Ding Yuan, ECE344 Opera&ng System 6

Semaphores in OS161 P(sem) { Disable interrupts; while (sem- >count == 0) { thread_sleep(sem); /* current thread will sleep on this sem */ sem- >count- - ; Enable interrupts; V(sem) { Disable interrupts; sem- >count++; thread_wakeup (sem); /* this will wake up all the threads wai&ng on this sem. Why wake up all threads? */ Enable interrupts; thread_sleep() assumes interrupts are disabled Note that interrupts are disabled only to enter/leave critical section How can it sleep with interrupts disabled? What happens if while (sem->count ==0) is an if (sem->count!= 0)? Ding Yuan, ECE344 Opera&ng System 7

Using Semaphores We ve looked at a simple example for using synchronization Mutual exclusion while accessing a bank account Now we re going to use semaphores to look at more interesting examples Readers/Writers Bounded Buffers Ding Yuan, ECE344 Opera&ng System 8

Readers/Writers Problem Readers/Writers Problem: An object is shared among several threads Some threads only read the object, others only write it We can allow multiple readers but only one writer Let #r be the number of readers, #w be the number of writers Safety: (#r 0) (0 #w 1) ((#r > 0) (#w = 0)) How can we use semaphores to control access to the object to implement this protocol? Ding Yuan, ECE344 Opera&ng System 9

First agempt: one mutex semaphore // exclusive writer or reader Semaphore w_or_r = 1; reader { P(w_or_r); // lock out writers read; V(w_or_r); // up for grabs writer { P(w_or_r); // lock out readers Write; V(w_or_r); // up for grabs Does it work? Why? Which condi&on is sa&sfied and which is not? (#r 0) (0 #w 1) ((#r > 0) (#w = 0)) Ding Yuan, ECE344 Opera&ng System 10

Second agempt: add a counter int readcount = 0; // record #readers Semaphore w_or_r = 1; // mutex semaphore reader { readcount++; if (readcount == 1){ P(w_or_r); // lock out writers read; readcount- - ; if (readcount == 0){ V(w_or_r); // up for grabs writer { P(w_or_r); // lock out readers Write; V(w_or_r); // up for grabs Does it work? readcount is a shared variable, who protects it? Thread 1: Thread 2: reader { readcount++; reader { context switch if (readcount == 1){ P(w_or_r); readcount++; if (readcount == 1){ P(w_or_r); A context switch can happen, a writer can come in since no reader locked the semaphore! Ding Yuan, ECE344 Opera&ng System 11

Readers/Writers Real Solu&on Use three variables int readcount number of threads reading object Semaphore mutex control access to readcount Semaphore w_or_r exclusive writing or reading Ding Yuan, ECE344 Opera&ng System 12

Readers/Writers // number of readers int readcount = 0; // mutual exclusion to readcount Semaphore mutex = 1; // exclusive writer or reader Semaphore w_or_r = 1; writer { P(w_or_r); // lock out readers Write; V(w_or_r); // up for grabs reader { P(mutex); // lock readcount readcount += 1; // one more reader if (readcount == 1) P(w_or_r); // synch w/ writers V(mutex); // unlock readcount Read; P(mutex); // lock readcount readcount - = 1; // one less reader if (readcount == 0) V(w_or_r); // up for grabs V(mutex); // unlock readcount Ding Yuan, ECE344 Opera&ng System 13

Readers/Writers Notes w_or_r provides mutex between readers and writers, and also multiple writers Why do readers use mutex? What if the V(mutex) is above if (readcount == 1)? Why do we need if (readcount == 1)? Why do we need if (readcount == 0)? Ding Yuan, ECE344 Opera&ng System 14

But it s&ll has a problem // number of readers int readcount = 0; // mutual exclusion to readcount Semaphore mutex = 1; // exclusive writer or reader Semaphore w_or_r = 1; writer { P(w_or_r); // lock out readers Write; V(w_or_r); // up for grabs reader { P(mutex); // lock readcount readcount += 1; // one more reader if (readcount == 1) P(w_or_r); // synch w/ writers V(mutex); // unlock readcount Read; P(mutex); // lock readcount readcount - = 1; // one less reader if (readcount == 0) V(w_or_r); // up for grabs V(mutex); // unlock readcount Ding Yuan, ECE344 Opera&ng System 15

Problem: Starva&on What if a writer is wai&ng, but readers keep coming, the writer is starved If you are interested, think how to solve this problem Ding Yuan, ECE344 Opera&ng System 16

Bounded Buffer Problem: There is a set of resource buffers shared by producer and consumer threads Producer inserts resources into the buffer set Output, disk blocks, memory pages, processes, etc. Consumer removes resources from the buffer set Whatever is generated by the producer Producer and consumer execute at different rates No serialization of one behind the other Tasks are independent (easier to think about) The buffer set allows each to run without explicit handoff Safety: Sequence of consumed values is prefix of sequence of produced values If nc is number consumed, np number produced, and N the size of the buffer, then 0 np - nc N Ding Yuan, ECE344 Opera&ng System 17

Bounded Buffer (2) Use three semaphores: empty count of empty buffers Counting semaphore empty = N (np nc) full count of full buffers Counting semaphore np - nc = full mutex mutual exclusion to shared set of buffers Binary semaphore Ding Yuan, ECE344 Opera&ng System 18

Bounded Buffer (3) Semaphore mutex = 1; // mutual exclusion to shared set of buffers Semaphore empty = N; // count of empty buffers (all empty to start) Semaphore full = 0; // count of full buffers (none full to start) producer { while (1) { Produce new resource; P(empty); // wait for empty buffer P(mutex); // lock buffer list Add resource to an empty buffer; V(mutex); // unlock buffer list V(full); // note a full buffer consumer { while (1) { P(full); // wait for a full buffer P(mutex); // lock buffer list Remove resource from a full buffer; V(mutex); // unlock buffer list V(empty); // note an empty buffer Consume resource; Ding Yuan, ECE344 Opera&ng System 19

Bounded Buffer (4) Consumer decrements FULL and blocks when buffer has no item since the semaphore FULL is at 0 Ding Yuan, ECE344 Opera&ng System 20

Bounded Buffer (5) producer { while (1) { Produce new resource; P(empty); // wait for empty buffer P(mutex); // lock buffer list Add resource to an empty buffer; V(mutex); // unlock buffer list Why we need both empty and full semaphores? Semaphore mutex = 1; // mutual exclusion to shared set of buffers Semaphore empty = N; // count of empty buffers (all empty to start) Semaphore full = 0; // count of full buffers (none full to start) V(full); // note a full buffer consumer { while (1) { P(full); // wait for a full buffer P(mutex); // lock buffer list Remove resource from a full buffer; V(mutex); // unlock buffer list V(empty); // note an empty buffer Consume resource; More consumers remove resource than actually produced! Ding Yuan, ECE344 Opera&ng System 21

Bounded Buffer (6) Why need the mutex at all? Reader-Writer and Bounded Buffer are classic examples of synchronization problems Ding Yuan, ECE344 Opera&ng System 22

Semaphore Ques&ons Are there any problems that can be solved with counting semaphores that cannot be solved with mutex semaphores? If a system provides only mutex semaphores, can you use it to implement a coun&ng semaphores? When to use counting semaphore? Problem needs a counter The maximum value is known (bouned) Ding Yuan, ECE344 Opera&ng System 23

Possible Deadlocks with Semaphores Example: Thread 1: P(S); P(Q);.... V(Q); V(S); Thread 2: share two mutex semaphores S and Q S:= 1; Q:=1; P(Q); P(S);.... V(S); V(Q); Ding Yuan, ECE344 Opera&ng System 24

Semaphore Summary Semaphores can be used to solve any of the traditional synchronization problems However, they have some drawbacks They are essentially shared global variables Can potentially be accessed anywhere in program No connection between the semaphore and the data being controlled by the semaphore No control or guarantee of proper usage Sometimes hard to use and prone to bugs Another approach: Use programming language support Ding Yuan, ECE344 Opera&ng System 25

Monitors A monitor is a programming language construct that controls access to shared data Synchronization code added by compiler, enforced at runtime Why is this an advantage? A monitor is a module that encapsulates Shared data structures Procedures that operate on the shared data structures Synchronization between concurrent threads that invoke the procedures A monitor protects its data from unstructured access It guarantees that threads accessing its data through its procedures interact only in legitimate ways Ding Yuan, ECE344 Opera&ng System 26

Monitor Seman&cs A monitor guarantees mutual exclusion Only one thread can execute any monitor procedure at any time (the thread is in the monitor ) If a second thread invokes a monitor procedure when a first thread is already executing one, it blocks So the monitor has to have a wait queue If a thread within a monitor blocks, another one can enter Condition Variable What are the implications in terms of parallelism in monitor? Ding Yuan, ECE344 Opera&ng System 27

Account Example Monitor account { double balance; double withdraw(amount) { balance = balance amount; return balance; Threads block wai=ng to get into monitor When first thread exits, another can enter. Which one is undefined. withdraw(amount) balance = balance amount; withdraw(amount) withdraw(amount) return balance (and exit) balance = balance amount return balance; balance = balance amount; return balance; Hey, that was easy But what if a thread wants to wait inside the monitor? Ding Yuan, ECE344 Opera&ng System 28

Condi&on Variables A condition variable is associated with a condition needed for a thread to make progress once it is in the monitor. Monitor M {... monitored variables Condition c; void enter_mon (...) { if (extra property not true) wait(c); do what you have to do if (extra property true) signal(c); waits outside of the monitor's mutex brings in one thread waiting on condition Ding Yuan, ECE344 Opera&ng System 29

Condi&on Variables Condition variables support three operations: Wait release monitor lock, wait for C/V to be signaled So condition variables have wait queues, too Signal wakeup one waiting thread Broadcast wakeup all waiting threads Condition variables are not boolean objects if (condition_variable) then does not make sense if (num_resources == 0) then wait(resources_available) does An example will make this more clear Ding Yuan, ECE344 Opera&ng System 30

Monitor Bounded Buffer Monitor bounded_buffer { Resource buffer[n]; // Variables for indexing buffer // monitor invariant involves these vars Condi&on not_full; // space in buffer Condi&on not_empty; // value in buffer void put_resource (Resource R) { if (buffer array is full) wait(not_full); Add R to buffer array; signal(not_empty); Resource get_resource() { if (buffer array is empty) wait(not_empty); Get resource R from buffer array; signal(not_full); return R; // end monitor What happens if no threads are waiting when signal is called? Signal is lost Ding Yuan, ECE344 Opera&ng System 31

Monitor Queues Monitor bounded_buffer { Condi&on not_full; other variables Condi&on not_empty; void put_resource () { wait(not_full) signal(not_empty) Resource get_resource () { Wai=ng to enter Wai=ng on condi=on variables Execu=ng inside the monitor 32 Ding Yuan, ECE344 Opera&ng System

Condi&on Vars!= Semaphores Condition variables!= semaphores However, they each can be used to implement the other Access to the monitor is controlled by a lock wait() blocks the calling thread, and gives up the lock To call wait, the thread has to be in the monitor (hence has lock) Semaphore::P just blocks the thread on the queue signal() causes a waiting thread to wake up If there is no waiting thread, the signal is lost Semaphore::V increases the semaphore count, allowing future entry even if no thread is waiting Condition variables have no history Ding Yuan, ECE344 Opera&ng System 33

Locks and Condi&on Vars In OS161, we don t have monitors But we want to be able to use condi&on variables So we isolate condi&on variables and make them independent (not associated with a monitor) Instead, we have to associate them with a lock (mutex) Now, to use a condi&on variable Threads must first acquire the lock (mutex) CV::Wait releases the lock before blocking, acquires it auer waking up Ding Yuan, ECE344 Opera&ng System 34

Signal Seman&cs There are two flavors of monitors that differ in the scheduling semantics of signal() Hoare monitors (original) signal() immediately switches from the caller to a waiting thread The condition that the waiter was anticipating is guaranteed to hold when waiter executes Mesa monitors (Mesa, Java) signal() places a waiter on the ready queue, but signaler continues inside monitor Condition is not necessarily true when waiter runs again Returning from wait() is only a hint that something changed Must recheck conditional case Ding Yuan, ECE344 Opera&ng System 35

Hoare vs. Mesa Monitors Hoare if (empty) wait(condition); Mesa while (empty) wait(condition); Tradeoffs Mesa monitors easier to use, more efficient Fewer context switches, easy to support broadcast Hoare monitors leave less to chance Easier to reason about the program Ding Yuan, ECE344 Opera&ng System 36

Monitor Readers and Writers Using Mesa monitor semantics. Will have four methods: StartRead, StartWrite, EndRead and EndWrite Monitored data: nr (number of readers) and nw (number of writers) with the monitor invariant (nr 0) (0 nw 1) ((nr > 0) (nw = 0)) Two conditions: canread: nw = 0 canwrite: (nr = 0) (nw = 0) Ding Yuan, ECE344 Opera&ng System 37

Monitor Readers and Writers Write with just wait() (will be safe, maybe not live - why?) Starvation Monitor RW { int nr = 0, nw = 0; Condi&on canread, canwrite; void StartRead () { while (nw!= 0) do wait(canread); nr++; void EndRead () { nr- - ; if (nr == 0) signal(canwrite); void StartWrite { while (nr!= 0 nw!= 0) do wait(canwrite); nw++; void EndWrite () { nw- - ; broadcast(canread); signal(canwrite); // end monitor Ding Yuan, ECE344 Opera&ng System 38

Monitor Readers and Writers Is there any priority between readers and writers? What if you wanted to ensure that a waiting writer would have priority over new readers? Ding Yuan, ECE344 Opera&ng System 39

Summary Semaphores P()/V() implement blocking mutual exclusion Also used as atomic counters (counting semaphores) Can be inconvenient to use Monitors Synchronizes execution within procedures that manipulate encapsulated data shared among procedures Only one thread can execute within a monitor at a time Relies upon high-level language support Condition variables Used by threads as a synchronization point to wait for events Inside monitors Ding Yuan, ECE344 Opera&ng System 40