1 / 21

Monitors: An Operating System Structuring Concept

Paper by C. A. R. Hoare Presentation by Emerson Murphy-Hill. Monitors: An Operating System Structuring Concept. The Problem. An OS’s main task is to control access to a machine’s resources (data, devices, time, space) If resources are not tightly controlled, “chaos will ensue”

yitro
Download Presentation

Monitors: An Operating System Structuring Concept

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Paper by C. A. R. Hoare Presentation by Emerson Murphy-Hill Monitors: An Operating System Structuring Concept

  2. The Problem An OS’s main task is to control access to a machine’s resources (data, devices, time, space) If resources are not tightly controlled, “chaos will ensue” race conditions

  3. The Solution Monitors provide control by allowing only one process to access a critical resource at a time A class/module/package Contains procedures and data

  4. An Abstract Monitor name : monitor … some local declarations … initialize local data procedure name(…arguments) … do some work … other procedures

  5. Monitor Rules Any process can access any monitor procedure at any time Only one process may enter a monitor procedure No process may directly access a monitor’s local variables A monitor may only access it’s local variables

  6. Things Needed to Enforce Monitor “wait” operation Forces running process to sleep “signal” operation Wakes up a sleeping process A condition Something to store who’s waiting for a particular reason Implemented as a queue

  7. A Running Example – Emerson’s Kitchen kitchen : monitor occupied : Boolean; occupied := false; nonOccupied : condition; procedure enterKitchen if occupied then nonOccupied.wait; occupied = true; procedure exitKitchen occupied = false; nonOccupied.signal; Monitor Declaration Declarations / Initialization Procedure Procedure

  8. Multiple Conditions Sometimes desirable to be able to wait on multiple things Can be implemented with multiple conditions Example: Two reasons to enter kitchen - cook (remove clean dishes) or clean (add clean dishes) Two reasons to wait: Going to cook, but no clean dishes Going to clean, no dirty dishes

  9. Emerson’s Kitchen kitchen : monitor cleanDishes, dirtyDishes : condition; dishes, sink : stack; dishes := stack of 10 dishes sink := stack of 0 dishes procedure cook if dishes.isEmpty then cleanDishes.wait sink.push ( dishes.pop ); dirtyDishes.signal; procedure cleanDish if sink.isEmpty then dirtyDishes.wait dishes.push (sink.pop) cleanDishes.signal

  10. Condition Queue Checking if any process is waiting on a condition: “condition.queue” returns true if a process is waiting on condition Example: Doing dishes only if someone is waiting for them

  11. Emerson’s Kitchen kitchen : monitor cleanDishes, dirtyDishes : condition; dishes, sink : stack; dishes := stack of 10 dishes sink := stack of 0 dishes procedure cook if dishes.isEmpty then cleanDishes.wait sink.push ( dishes.pop ); dirtyDishes.signal; procedure cleanDishes if sink.isEmpty then dirtyDishes.wait if cleanDishes.queue dishes.push (sink.pop); cleanDishes.signal;

  12. Scheduled Waits Gives a waiting thread a number Lowest number gets woken up first (inverse priority) Example: People who want to cook are prioritized: Highest: Me! Medium: Family Lowest: Vagrants/Friends

  13. Emerson’s Kitchen kitchen : monitor cleanDishes, dirtyDishes : condition; dishes, sink : stack; dishes := stack of 10 dishes sink := stack of 0 dishes procedure cook( p : Person ) if dishes.isEmpty then if p.isEmerson then cleanDishes.wait(1); if p.isFamily then cleanDishes.wait(2); if p.isFriendAndOrVagrant then cleanDishes.wait(3); sink.push ( dishes.pop ); dirtyDishes.signal; procedure cleanDishes if sink.isEmpty then dirtyDishes.wait; while(cleanDishes.queue) dishes.push (sink.pop); cleanDishes.signal;

  14. Summary Advantages Data access synchronization simplified (vs. semaphores or locks) Better encapsulation Disadvantages: Deadlock still possible (in monitor code) Programmer can still botch use of monitors No provision for information exchange between machines

  15. Other Issues Discussed Power of Monitors SemaphoreMonitor MonitorSemaphore Proof Rules I (b.wait) I & B I & B (b.signal) I OS Examples Bounded Buffer Alarm clock Buffer allocation Disk-head Scheduler Reader/Writer

  16. Mutual Exclusion: Implementation Disabling Interrupts kitchen : monitor occupied : Boolean; occupied := false; nonOccupied : condition; procedure enterKitchen disableInterrupts(); if occupied then nonOccupied.wait; occupied = true; enableInterrupts(); procedure exitKitchen disableInterrupts(); occupied = false; nonOccupied.signal; enableInterrupts(); Mutex Insertion kitchen : monitor occupied : Boolean; occupied := false; nonOccupied : condition; lock1 : lock; procedure enterKitchen lock1.acquire(); if occupied then nonOccupied.wait; occupied = true; lock1.release(); procedure exitKitchen lock1.acquire(); occupied = false; nonOccupied.signal; lock1.release();

  17. Monitors In Context Multithreaded code could be implemented with monitors (w/language support) Enforcement of mutex locking conventions Abstraction: deadlock can be avoided, but of course, only if the monitor is written correctly!

  18. Conclusion Monitors are a synchronization mechanism A higher level, easier to use abstraction, better encapsulation vs. semaphores/locks Monitors still suffer from various afflictions

  19. References “Monitors: An Operating System Structuring Concept,” Hoare. Modern Operating Systems, Second Edition, Tannenbaum, pp. 115-119. Jon Walpole, correspondence.

  20. Questions What is the essential implementation difference between monitors and semaphores? What problems can still arise with the use of monitors? What is the most specialized compiler mechanism required to implement monitors? Generally, monitors allow us to encapsulate mutex use and avoid the spread of mutex across code. Can you think of a case where this is not possible?

  21. Possible Answers Atomicity of blocked code-reentrance in monitors Deadlock, inconsistent use (eg, acquire without release) Mutual exclusion in monitor methods When we need uninterrupted access to 2 or more resources located in different monitor proceedures.

More Related