Design Techniques II Chapter 9 9/20/2018 Crowley OS Chap. 9.

Slides:



Advertisements
Similar presentations
Operating System Concepts and Techniques Lecture 12 Interprocess communication-1 M. Naghibzadeh Reference M. Naghibzadeh, Operating System Concepts and.
Advertisements

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 5.
Dr Mohamed Menacer College of Computer Science and Engineering Taibah University CS-334: Computer.
Operating System Support Focus on Architecture
Chapter 8 Operating System Support
©Brooks/Cole, 2003 Chapter 7 Operating Systems Dr. Barnawi.
CS533 - Concepts of Operating Systems
Computer Organization and Architecture
A. Frank - P. Weisberg Operating Systems Introduction to Cooperating Processes.
1/26/2007CSCI 315 Operating Systems Design1 Processes Notice: The slides for this lecture have been largely based on those accompanying the textbook Operating.
1 Threads Chapter 4 Reading: 4.1,4.4, Process Characteristics l Unit of resource ownership - process is allocated: n a virtual address space to.
CS364 CH08 Operating System Support TECH Computer Science Operating System Overview Scheduling Memory Management Pentium II and PowerPC Memory Management.
Layers and Views of a Computer System Operating System Services Program creation Program execution Access to I/O devices Controlled access to files System.
Chapter 3: Processes Process Concept Process Scheduling Operations on Processes Interprocess Communication Examples of IPC Systems Communication in Client-Server.
Implementing Processes and Process Management Brian Bershad.
Chapter 5 Operating System Support. Outline Operating system - Objective and function - types of OS Scheduling - Long term scheduling - Medium term scheduling.
Recall: Three I/O Methods Synchronous: Wait for I/O operation to complete. Asynchronous: Post I/O request and switch to other work. DMA (Direct Memory.
MODERN OPERATING SYSTEMS Third Edition ANDREW S. TANENBAUM Chapter 2 Processes and Threads Tanenbaum, Modern Operating Systems 3 e, (c) 2008 Prentice-Hall,
Concurrency: Mutual Exclusion and Synchronization Chapter 5.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 3: Process-Concept.
1 Computer Systems II Introduction to Processes. 2 First Two Major Computer System Evolution Steps Led to the idea of multiprogramming (multiple concurrent.
Processes. Process Concept Process Scheduling Operations on Processes Interprocess Communication Communication in Client-Server Systems.
Chapter 5 Concurrency: Mutual Exclusion and Synchronization Operating Systems: Internals and Design Principles, 6/E William Stallings Patricia Roy Manatee.
Concepts and Structures. Main difficulties with OS design synchronization ensure a program waiting for an I/O device receives the signal mutual exclusion.
Embedded Real-Time Systems Processing interrupts Lecturer Department University.
1 Module 3: Processes Reading: Chapter Next Module: –Inter-process Communication –Process Scheduling –Reading: Chapter 4.5, 6.1 – 6.3.
OPERATING SYSTEMS STRUCTURES Jerry Breecher 2: Operating System Structures 1.
Computer System Structures
Chapter 13: I/O Systems Modified by Dr. Neerja Mhaskar for CS 3SH3.
Processes and threads.
Chapter 3: Process Concept
CS703 – Advanced Operating Systems
Operating Systems (CS 340 D)
Concurrency.
Process Management Presented By Aditya Gupta Assistant Professor
Processes Overview: Process Concept Process Scheduling
Chapter 3: Process Concept
William Stallings Computer Organization and Architecture
Intro to Processes CSSE 332 Operating Systems
Real-time Software Design
Main Memory Management
Operating Systems (CS 340 D)
Chapter 8: Main Memory.
MODERN OPERATING SYSTEMS Third Edition ANDREW S
Design IV Chapter 18 11/14/2018 Crowley OS Chap. 18.
Concurrency: Mutual Exclusion and Synchronization
Chapter 4: Processes Process Concept Process Scheduling
Lecture 2: Processes Part 1
GEOMATIKA UNIVERSITY COLLEGE CHAPTER 2 OPERATING SYSTEM PRINCIPLES
Recap OS manages and arbitrates resources
Operating Systems.
CSE 451: Operating Systems Spring 2012 Module 6 Review of Processes, Kernel Threads, User-Level Threads Ed Lazowska 570 Allen.
Operating Systems.
Thread Implementation Issues
Lecture Topics: 11/1 General Operating System Concepts Processes
Threads Chapter 4.
Background and Motivation
Multiprocessor and Real-Time Scheduling
Chapter 3: Processes.
CSE 451: Operating Systems Autumn 2003 Lecture 7 Synchronization
CSE 451: Operating Systems Autumn 2005 Lecture 7 Synchronization
CSE 451: Operating Systems Winter 2003 Lecture 7 Synchronization
Chapter 3: Process Concept
CSE 153 Design of Operating Systems Winter 2019
COMP755 Advanced Operating Systems
Design Techniques II Chapter 9 6/25/2019 Crowley OS Chap. 9.
Chapter 13: I/O Systems “The two main jobs of a computer are I/O and [CPU] processing. In many cases, the main job is I/O, and the [CPU] processing is.
Presentation transcript:

Design Techniques II Chapter 9 9/20/2018 Crowley OS Chap. 9

Key concepts in chapter 9 Indirection State machines Win big, then give some back Separation of concepts Reducing a problem to a special case Reentrant programs Using models for inspiration Adding a facility to a system 9/20/2018 Crowley OS Chap. 9

Design technique: Indirection Access an object indirectly, through a third object This allows you to gain control whenever an access occurs access becomes an event to which you can attach actions 9/20/2018 Crowley OS Chap. 9

Indirection in C++ 9/20/2018 Crowley OS Chap. 9

Indirection in text formatting Direct formatting: attach formats (e.g., bold, italics, font, etc.) to the text directly Indirect formatting: attach a formatting code to each character of the text, then attach formats to each formatting code the formatting code is the logical formatting the formats attached to the formatting code is the physical formatting. 9/20/2018 Crowley OS Chap. 9

Indirect formatting 9/20/2018 Crowley OS Chap. 9

Indirection in OSs Message queues Initial process RPC implementation (with stubs) Implementing “shared memory” with page faults Dynamic loading Character generator memory 9/20/2018 Crowley OS Chap. 9

Indirection in CS Two-level implementations Access private data in an object Memory management Sorting large objects Passing parameters by reference Defined constants 9/20/2018 Crowley OS Chap. 9

Dangling pointers after compaction 9/20/2018 Crowley OS Chap. 9

Indirection using memory handles 9/20/2018 Crowley OS Chap. 9

Sorting using indirection 9/20/2018 Crowley OS Chap. 9

Indirection examples Source object Reference Indirect object Reference Desired object Process Send Message queue Receive Process OS Create by hand Initial process Create Processes Client process RPC call RPC client stub Server RPC Server process Process Memory ref. Indirect pointer Memory ref. Data object Statement Name Symbolic constant Table lookup Value Characters Name Abstract style Style sheet Concrete format 9/20/2018 Crowley OS Chap. 9

State machine 9/20/2018 Crowley OS Chap. 9

Design technique: State machines State machines (a.k.a. state diagrams) are an effective way to represent information but they are only good for state-transition oriented systems Good visual representations are powerful We have seen process state diagrams 9/20/2018 Crowley OS Chap. 9

Design technique: Win big, then give some back Some techniques produce huge gains in speed or space used but the lose some useful property Example: video compression But, often we can give up some of the gains to regain the property 9/20/2018 Crowley OS Chap. 9

Video compression 9/20/2018 Crowley OS Chap. 9

OS examples Shortest-response-ratio-next (SRN) scheduling Shortest-job-first minimizes average wait time but penalized long jobs too much SRN has a very good average wait time (short jobs run quickly) but does not penalize long job so much Multiprogramming increases system efficiency but introduces parallelism and hence race conditions Mono-programming in critical section solves that problem we lose some parallelism but regain correctness 9/20/2018 Crowley OS Chap. 9

Design technique: Separation of concepts Often the first version of an idea combines two concepts e.g. processes = threads + resource holding Separation of the concepts allows them to be used independently smaller building blocks so they are more flexible 9/20/2018 Crowley OS Chap. 9

OS examples Process = thread + resource holder Create process = fork + exec Messages = synchronization + information transfer 9/20/2018 Crowley OS Chap. 9

Design technique: Reducing a problem to a special case Motivation Implement mutual exclusion with semaphores general mutual exclusion for any length of time But we need mutual exclusion in the OS to implement semaphores special mutual exclusion: only a few machine instructions so busy waiting to acceptable 9/20/2018 Crowley OS Chap. 9

OS examples Mutual exclusion Process blocking: OS does it but then we have to blocking OS system calls Name servers: expensive to broadcast for names in a network but once we find the name server it can resolve names for us Unique global names: use hierarchy so we only have to generate locally unique names 9/20/2018 Crowley OS Chap. 9

CS examples Help systems: it is hard to remember how to use all the commands but if you can remember how to use the “help” command it can tell you about the others Text editor data structures: sequential characters is time-inefficient a linked list of characters is space-inefficient but a linked list of line pointers to lines of sequential characters is reasonable efficient 9/20/2018 Crowley OS Chap. 9

Design technique: Reentrant programs Two threads can execute the same code simultaneously so the shared global data is a problem Programs with embedded data are not reentrant, also called not thread-safe We make them reentrant by removing the embedded data and allocating it for each execution data is accessed through a pointer 9/20/2018 Crowley OS Chap. 9

Non-reentrant and reentrant browsers // Browser using global variables WindowID wBrowser; char *wCurrentDirectory; void redrawWindow( void ) { char ** list = GetFileList( wCurrentDirectory ); UpdateListBox( wBrowser, list ); } // Broswer using a state structure typedef struct browserStruct { WindowID browserID; char *currentDirectory } Browser; void redrawWindow( Browser * browser ) { char ** list = GetFileList( browser->currentDirectory ); UpdateListBox( browser->browserID, list ); } 9/20/2018 Crowley OS Chap. 9

Examples Embedded data in threaded programs Embedded data in an OS MS/DOS: most versions are not reentrant Object-oriented programming languages Each object’s data area is allocated from the free store (the heap) so they are automatically thread-safe 9/20/2018 Crowley OS Chap. 9

Design technique: Using models for inspiration A model is a representation of a system: an equation, a clay model, a simulation, etc. For the model to predict or prove something about the system the model must be validated to give evidence that it is accurate But a model can also be used to generate ideas about things that might be true in the system or useful The ideas are validated in the system so there is no necessity to validate the model 9/20/2018 Crowley OS Chap. 9

Examples We used computer hardware models to give us ideas about processes and threads File I/O can be based on the disk model or the tape model Blackboard architectures are based on the model of experts sharing a blackboard Some people have used the economic market model for processor scheduling 9/20/2018 Crowley OS Chap. 9

Design technique: Adding a new function to a system Three ways to add a new function 1. Use an existing facility to build the new function 2. Add a new low-level primitive function and use it to build the new function 3. Add a new high-level function that does exactly what you want All solutions fit into one of these categories often there are several solutions in a category 9/20/2018 Crowley OS Chap. 9

OS Examples Receiving from two message queues 1. Use processes or threads to do the waiting 2. Add a non-blocking receive and poll 3. Add a receive from two queues Implementing mutual exclusion 1. Use the disable interrupts function 2. Add an exchange-word instruction 3. Add monitors 9/20/2018 Crowley OS Chap. 9

Three ways to implement threads 1. Implement user-level threads inside of a process 2. Implement a “scheduler thread” facility whenever a process makes a system call that would block, the OS calls a designated scheduler thread instead 3. Implement threads in the kernel 9/20/2018 Crowley OS Chap. 9

CS example Iterate over an encapsulated data structure 1. Get a chunk of memory that will hold all the items in the data structure and return that 2. Implement an external iterator interface void StartInteration() void MoveToNextItem() Item GetCurrentItem() Boolean More Items?() 3. Implement an internal iterator that calls a callback function once for each item in the data structure 9/20/2018 Crowley OS Chap. 9

Design method Whenever you are adding a facility Potential problem look for solutions of all three types if you are missing a type, think carefully about how you could do it that way Potential problem adding a new low-level primitive can sometimes cause a security problem if it can be used in unexpected ways, or if it interacts with other functionality 9/20/2018 Crowley OS Chap. 9

Consequences Using an existing function no changes required, nothing new to learn often is inefficient Adding a low-level primitive function simpler to implement than a high-level function more flexible than a high-level function and can be used for other purposes Adding a high-level primitive function can be the most efficient and easy to use not as flexible or general 9/20/2018 Crowley OS Chap. 9