Announcements. Computer System Organization. Roadmap. Major OS Components. Processes. Tevfik Ko!ar. CSC Operating Systems Fall 2009

Similar documents
CSC Operating Systems Fall Lecture - II OS Structures. Tevfik Ko!ar. Louisiana State University. August 27 th, 2009.

OS Design Approaches. Roadmap. OS Design Approaches. Tevfik Koşar. Operating System Design and Implementation

Roadmap. Tevfik Koşar. CSE 421/521 - Operating Systems Fall Lecture - II OS Structures. University at Buffalo. OS Design and Implementation

OS Design Approaches. Roadmap. System Calls. Tevfik Koşar. Operating System Design and Implementation. CSE 421/521 - Operating Systems Fall 2013

CSC Operating Systems Spring Lecture - II OS Structures. Tevfik Ko!ar. Louisiana State University. January 17 th, 2007.

Announcements. Operating System Structure. Roadmap. Operating System Structure. Multitasking Example. Tevfik Ko!ar

Principles of Operating Systems CS 446/646

Four Components of a Computer System

Operating System Architecture. CS3026 Operating Systems Lecture 03

Chapter 1: Introduction

Chapter 1: Introduction

Roadmap. Tevfik Ko!ar. CSC Operating Systems Spring Lecture - III Processes. Louisiana State University. Virtual Machines Processes

CS370 Operating Systems

OPERATING SYSTEMS: Lesson 1: Introduction to Operating Systems

Chapter 1: Introduction

Chapter 1: Introduction. Chapter 1: Introduction

Chapter 1: Introduction. Operating System Concepts 9 th Edit9on

Chapter 1: Introduction. Operating System Concepts 8 th Edition,

European University of Lefke. Instructor: Dr. Arif SARI

CS420: Operating Systems

7/20/2008. What Operating Systems Do Computer-System Organization

Roadmap. Tevfik Ko!ar. CSC Operating Systems Fall Lecture - VII CPU Scheduling - II. Louisiana State University

Roadmap. Multilevel Queue Scheduling. Multilevel Queue. Example of Multilevel Feedback Queue. Multilevel Feedback Queue. Tevfik Ko!

Lecture 1 Introduction (Chapter 1 of Textbook)

Last Class: OS and Computer Architecture. Last Class: OS and Computer Architecture

CS420: Operating Systems

CS370 Operating Systems

Roadmap. Tevfik Ko!ar. CSC Operating Systems Fall Lecture - III Processes. Louisiana State University. Processes. September 1 st, 2009

To provide a grand tour of the major operating systems components To provide coverage of basic computer system organization

Operating-System Structures

Chapter 2: Operating-System Structures. Operating System Concepts 9 th Edit9on

DM510 Operating Systems. Jacob Aae Mikkelsen

Exercise (could be a quiz) Solution. Concurrent Programming. Roadmap. Tevfik Koşar. CSE 421/521 - Operating Systems Fall Lecture - IV Threads

Roadmap. Tevfik Ko!ar. CSC Operating Systems Spring Lecture - X Deadlocks - II. Louisiana State University. Deadlocks

Often, more information is required when designing system call Information varies according to OS and types of system call

! The Process Control Block (PCB) " is included in the context,

Chapter 2: Operating-System Structures. Operating System Concepts 8 th Edition

Process Description and Control

CPSC 341 OS & Networks. Introduction. Dr. Yingwu Zhu

Module 3: Operating-System Structures

Chapter 1: Introduction. Operating System Concepts 8th Edition,

Operating Systems Overview. Chapter 2

Ricardo Rocha. Department of Computer Science Faculty of Sciences University of Porto

Operating System Services

Operating System Review

Operating System Services. User Services. System Operation Services. User Operating System Interface - CLI. A View of Operating System Services

Roadmap. Tevfik Ko!ar. CSC Operating Systems Spring Lecture - XIV Virtual Memory - I. Louisiana State University.

CSC Operating Systems Fall Lecture - I Introduction. Tevfik Ko!ar. Louisiana State University. August 25 th, Contact Information

CSC Operating Systems Spring Lecture - XIX Storage and I/O - II. Tevfik Koşar. Louisiana State University.

RAID Structure. RAID Levels. RAID (cont) RAID (0 + 1) and (1 + 0) Tevfik Koşar. Hierarchical Storage Management (HSM)

Part V. Process Management. Sadeghi, Cubaleska RUB Course Operating System Security Memory Management and Protection

Chapter 4: Threads. Chapter 4: Threads. Overview Multicore Programming Multithreading Models Thread Libraries Implicit Threading Threading Issues

CSC Operating Systems Spring Lecture - XIV Virtual Memory - II. Tevfik Ko!ar. Louisiana State University. March 27 th, 2008.

Operating-System Structures

TDDI04, K. Arvidsson, IDA, Linköpings universitet Operating System Structures. Operating System Structures Overview. Operating System Services

Operating System Structure

OS and Computer Architecture. Chapter 3: Operating-System Structures. Common System Components. Process Management

Module 3: Operating-System Structures. Common System Components

Chapter 3: Processes. Operating System Concepts 8 th Edition,

CSE 4/521 Introduction to Operating Systems

Chapter 2: Operating-System Structures

Chapter 2: Operating-System Structures

Lecture 5: Process Description and Control Multithreading Basics in Interprocess communication Introduction to multiprocessors

What are some common categories of system calls? What are common ways of structuring an OS? What are the principles behind OS design and

Chapter 3: Operating-System Structures

Operating System. Operating System Overview. Layers of Computer System. Operating System Objectives. Services Provided by the Operating System

Operating System Overview. Operating System

Kernel Types Simple OS Examples System Calls. Operating Systems. Autumn CS4023

CSC 453 Operating Systems

Operating-System Structures

Chapter 2: Operating-System Structures. Operating System Concepts Essentials 8 th Edition

Chapter 2: Operating-System

Chapter 5: Processes & Process Concept. Objectives. Process Concept Process Scheduling Operations on Processes. Communication in Client-Server Systems

Chapter 4: Threads. Chapter 4: Threads

Process and Its Image An operating system executes a variety of programs: A program that browses the Web A program that serves Web requests

Roadmap. Tevfik Koşar. CSC Operating Systems Spring Lecture - XII Main Memory - II. Louisiana State University

Chapter 2: Operating-System Structures. Chapter 2: Operating-System Structures. Objectives. Operating System Services

Chapter 2: Operating-System Structures

Chapter 3: Operating-System Structures

ELEC 377 Operating Systems. Week 1 Class 2

Chapter 13: I/O Systems

Chapter 13: I/O Systems. Chapter 13: I/O Systems. Objectives. I/O Hardware. A Typical PC Bus Structure. Device I/O Port Locations on PCs (partial)

Chapter 2: Operating-System Structures. Operating System Concepts 9 th Edition

Four Components of a Computer System. Operating System Concepts 7 th Edition, Jan 12, 2005

Chapter 2: Operating-System Structures

Chapter 4: Multithreaded Programming

Chapter 12: I/O Systems

Chapter 13: I/O Systems

Chapter 12: I/O Systems. Operating System Concepts Essentials 8 th Edition

Overview of Mass Storage Structure

Chapter 2. Operating-System Structures

Chapter 1: Introduction. Operating System Concepts 8th Edition,

Chapter 3: Processes. Operating System Concepts 9 th Edition

Processes and Threads

Operating Systems Overview. Chapter 2

CS420: Operating Systems

Computer-System Architecture (cont.) Symmetrically Constructed Clusters (cont.) Advantages: 1. Greater computational power by running applications

Lecture 2 Operating System Structures (chapter 2)

Last class: OS and Architecture. OS and Computer Architecture

Last class: OS and Architecture. Chapter 3: Operating-System Structures. OS and Computer Architecture. Common System Components

Transcription:

CSC 4103 - Operating Systems Fall 2009 Lecture - II OS Structures Tevfik Ko!ar TA Changed. New TA: Praveenkumar Kondikoppa Email: pkondi1@lsu.edu Announcements All of you should be now in the class mailing list. Let me know if you haven t received any messages yet. Lecture notes are available on the course web site. Louisiana State University August 27 th, 2009 1 2 Roadmap Major OS Components Corresponding OS Responsibilities OS Design and Implementation Different Design Approaches OS API System Calls Dual Mode of Operation Computer System Organization Computer-system operation One or more CPUs, device controllers connect through common bus providing access to shared memory Concurrent execution of CPUs and devices competing for memory cycles 3 4 Major OS Components " A process is the activity of executing a program!! Memory management! CPU Scheduling! I/O Management Pasta for six boil 1 quart salty water thread of execution stir in the pasta CPU 5 cook on medium until al dente serve Program Process 6 input data

process Pasta for six First aid " It can be interrupted to let the CPU execute a higher-priority CPU (changes hat to doctor ) "... and then resumed exactly where the CPU left off Pasta for six hmm... now where was I? boil 1 quart Get the salty first aid kit water Check pulse thread of execution boil 1 quart salty water thread of execution CPU (back to chef ) stir in Clean the pasta wound with alcohol cook on medium until al Apply dente band aid input data stir in the pasta cook on medium until al dente input data serve Program Process 7 serve Program Process 8 " Multitasking gives the illusion of parallel processing (independent virtual program counters) on one CPU............ job 2 job 3 job 2 job 4 (a) Multitasking from the CPU s viewpoint job 3 process 1 Timesharing is logical extension in which CPU switches jobs so frequently that users can interact with each job while it is running, creating interactive computing Response time should be < 1 second Each user has at least one program loaded in memory and executing! process job 2 job 2 process 2 job 3 job 3 process 3 job 4 (b) Multitasking from the processes viewpoint = 4 virtual program counters Pseudoparallelism in multitasking process 4 9 10 Memory Management " Operating System Responsibilities: " Main memory The O/S is responsible for managing processes # the O/S creates & deletes processes # the O/S suspends & resumes processes # the O/S provides mechanisms for process synchronization # the O/S provides mechanisms for interprocess communication # the O/S provides mechanisms for deadlock handling # large array of words or bytes, each with its own address # repository of quickly accessible data shared by the CPU and I/O devices 11 # volatile storage that loses its contents in case of system failure The storage hierarchy 12

Performance of Various Levels of Storage Caching Movement between levels of storage hierarchy can be explicit or implicit Important principle, performed at many levels in a computer (in hardware, operating system, software) Information in use copied from slower to faster storage temporarily Faster storage (cache) checked first to determine if information is there If it is, information used directly from the cache (fast) If not, data copied to cache and used there Cache smaller than storage being cached Cache management important design problem Cache size and replacement policy 13 14 Migration of Integer A from Disk to Register Multitasking environments must be careful to use most recent value, not matter where it is stored in the storage hierarchy Multiprocessor environment must provide cache coherency in hardware such that all CPUs have the most recent value in their cache Distributed environment situation even more complex Several copies of a datum can exist Memory Management " Operating System Responsibilities: The O/S is responsible for an efficient and orderly control of storage allocation # ensures process isolation: it keeps track of which parts of memory are currently being used and by whom # allocates and deallocates memory space as needed: it decides which processes to load or swap out # regulates how different processes and users can sometimes share the same portions of memory # transfers data between main memory and disk and ensures long-term storage 15 16 " Long-term scheduling " Medium-term scheduling CPU Scheduling # the decision to add a program to the pool of processes to be executed (job scheduling) # the decision to add to the number of processes that are partially or fully in main memory ( swapping ) " Short-term scheduling = CPU scheduling # the decision as to which available processes in memory are to be executed by the processor ( dispatching ) " I/O scheduling fine- to coarse-grain level frequency of intervention CPU Scheduling " Operating System Responsibilities: The O/S is responsible for efficiently using the CPU and providing the user with short response times # decides which available processes in memory are to be executed by the processor # decides what process is executed when and for how long, also reacting to external events such as I/O interrupts # relies on a scheduling algorithm that attempts to optimize CPU utilization, throughput, latency, and/or response time, depending on the system requirements # the decision to handle a process s pending I/O request 18

I/O Management Two I/O Methods After I/O starts, control returns to user program only upon I/O completion $ synchronous Wait instruction idles the CPU until the next interrupt Wait loop (contention for memory access). At most one I/O request is outstanding at a time, no simultaneous I/O processing. Device-independent software After I/O starts, control returns to user program without waiting for I/O completion $asynchronous System call request to the operating system to allow user to wait for I/O completion. Device-status table contains entry for each I/O device Tanenbaum, A. S. (2001) Modern Operating Systems (2nd Edition). Layers of the I/O subsystem 19 20 Two I/O Methods I/O Management Synchronous Asynchronous " Operating System Responsibilities: The O/S is responsible for controlling access to all the I/O devices # hides the peculiarities of specific hardware devices from the user # issues the low-level commands to the devices, catches interrupts and handles errors # relies on software modules called device drivers # provides a device-independent API to the user programs, which includes buffering 21 22 Operating System Design and Implementation OS Design Approaches 23 Start by defining goals and specifications Affected by choice of hardware, type of system Batch, time shared, single user, multi user, distributed User goals and System goals User goals operating system should be convenient to use, easy to learn, reliable, safe, and fast System goals operating system should be easy to design, implement, and maintain, as well as flexible, reliable, errorfree, and efficient No unique solution for defining the requirements of an OS % Large variety of solutions % Large variety of OS 24

Operating System Design and Implementation (Cont.) OS Design Approaches Important principle: to separate policies and mechanisms Policy: What will be done? Mechanism: How to do something? Eg. to ensure CPU protection Use Timer construct (mechanism) How long to set the timer (policy) The separation of policy from mechanism allows maximum flexibility if policy decisions are to be changed later Simple Structure (Monolithic) Microkernels Modules 25 26 Simple Structure Monolithic No well defined structure Start as small, simple, limited systems, and then grow No Layers, not divided into modules 27 Simple Structure Silberschatz, A., Galvin, P. B. and Gagne. G. (2003) " Example: MS-DOS # initially written to provide the most functionality in the least space # started small and grew beyond its original scope # levels not well separated: programs could access I/ O devices directly # excuse: the hardware of that time was limited (no dual user/kernel mode) Operating Systems Concepts with Java (6th Edition). MS-DOS pseudolayer structure 28 " Another example: the original UNIX # enormous amount of functionality crammed into the kernel - everything below system call interface # The Big Mess : a collection of procedures that can call any of the other procedures whenever they need to # no encapsulation, total visibility across the system # very minimal layering made of thick, monolithic layers Simple Structure UNIX system structure Silberschatz, A., Galvin, P. B. and Gagne. G. (2003) Operating Systems Concepts with Java (6th Edition). 29 " Monolithic operating systems # no one had experience in building truly large software systems # the problems caused by mutual dependence and interaction were grossly underestimated # such lack of structure became unsustainable as O/S grew " Enter hierarchical layers and information abstraction # each layer is implemented exclusively using operations provided by lower layers # it does not need to know how they are implemented # hence, lower layers hide the existence of certain data structures, private operations and hardware from upper layers 30

The operating system is divided into a number of layers (levels), each built on top of lower layers. The bottom layer (layer 0), is the hardware; The highest (layer N) is the user interface. With modularity, layers are selected such that each uses functions (operations) and services of only lowerlevel layers GLUnix: Global Layered Unix # famous example of strictly layered architecture: the TCP/IP networking stack " Layers can be debugged and replaced independently without bothering the other layers above and below N+1 offers services N uses services N 1 31 32 shell O/S Theoretical model of operating system design hierarchy " Major difficulty with layering #... appropriately defining the various layers! # layering is only possible if all function dependencies can be sorted out into a Directed Acyclic Graph (DAG) # however there might be conflicts in the form of circular dependencies ( cycles ) hardware Stallings, W. (2004) Operating Systems: Internals and Design Principles (5th Edition). 33 Circular dependency on top of a DAG 34 Layered Operating System - Circular View " Circular dependencies in an O/S organization # example: disk driver routines vs. CPU scheduler routines & the device driver for the backing store (disk space used by virtual memory) may need to wait for I/O, thus invoke the CPU-scheduling layer & the CPU scheduler may need the backing store driver for swapping in and out parts of the table of active processes " Other difficulty: efficiency # the more layers, the more indirections from function to function and the bigger the overhead in function calls! backlash against strict layering: return to fewer layers with more functionality 35 36

Microkernel System Structure " The microkernel approach # a microkernel is a reduced operating system core that contains only essential O/S functions # the idea is to minimize the kernel by moving up as much functionality as possible from the kernel into user space Layered OS vs Microkernel # many services traditionally included in the O/S are now external subsystems running as user processes & device drivers & file systems & virtual memory manager & windowing system & security services, etc. Examples: QNX, Tru64 UNIX 37 38 Microkernel System Structure " Benefits of the microkernel approach # extensibility it is easier to extend a microkernel-based O/S as new services are added in user space, not in the kernel # portability it is easier to port to a new CPU, as changes are needed only in the microkernel, not in the other services # reliability & security much less code is running in kernel mode; failures in user-space services don t affect kernel space " Detriments of the microkernel approach # again, performance overhead due to communication from user space to kernel space # not always realistic: some functions (I/O) must remain in kernel space, forcing a separation between policy and mechanism Modular Approach " The modular approach # most modern operating systems implement kernel modules # this is similar to the object-oriented approach: & each core component is separate & each talks to the others over known interfaces & each is loadable as needed within the kernel # overall, modules are similar to layers but with more flexibility # modules are also similar to the microkernel approach, except they are inside the kernel and don t need message passing 39 40 Modular Approach " Modules are used in Solaris, Linux and Mac OS X Mac OS X Structure - Hybrid The Solaris loadable modules Silberschatz, A., Galvin, P. B. and Gagne. G. (2003) Operating Systems Concepts with Java (6th Edition). BSD: provides support for command line interface, networking, file system, POSIX API and threads Mach: memory management, RPC, IPC, message passing 41 42

Summary Major OS Components, Memory Management, CPU Scheduling, I/O Management Corresponding OS Responsibilities OS Design and Implementation Monolithic Systems, Layered Approach, Microkernels, Modules Next Lecture: Hmm.. Reading Assignment: Chapter 2 from Silberschatz. Acknowledgements Operating Systems Concepts book and supplementary material by A. Silberschatz, P. Galvin and G. Gagne Operating Systems: Internals and Design Principles book and supplementary material by W. Stallings Modern Operating Systems book and supplementary material by A. Tanenbaum R. Doursat and M. Yuksel from UNR 43 44