Introduction to Operating System (OS)

Slides:



Advertisements
Similar presentations
Interactive lesson about operating system
Advertisements

COURSE: COMPUTER PLATFORMS
Introduction CSCI 444/544 Operating Systems Fall 2008.
CMSC 421: Principles of Operating Systems Section 0202 Instructor: Dipanjan Chakraborty Office: ITE 374
CMPT 300: Operating Systems I Dr. Mohamed Hefeeda
Chapter 1: Introduction
1 School of Computing Science Simon Fraser University CMPT 300: Operating Systems I Dr. Mohamed Hefeeda.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 1: Introduction What is an Operating System? Mainframe Systems Desktop Systems.
Phones OFF Please Operating System Introduction Parminder Singh Kang Home:
Modified from Silberschatz, Galvin and Gagne ©2009 CS 446/646 Principles of Operating Systems Lecture 1 Chapter 1: Introduction.
Chapter 1: Introduction
Introduction to Operating System (OS)
1/16/2008CSCI 315 Operating Systems Design1 Introduction Notice: The slides for this lecture have been largely based on those accompanying the textbook.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 1: Introduction What is an Operating System? Mainframe Systems Desktop Systems.
 Introduction Introduction  Definition of Operating System Definition of Operating System  Abstract View of OperatingSystem Abstract View of OperatingSystem.
Chapter 2 Operating System Overview Patricia Roy Manatee Community College, Venice, FL ©2008, Prentice Hall Operating Systems: Internals and Design Principles,
CIS-410: Operating Systems Spring Organizational Details Class Meeting: 7:00-9:45pm, Monday, Room 252N Instructor: Dr. Igor Aizenberg Office: Aikin.
Chapter 2 Operating System Overview Patricia Roy Manatee Community College, Venice, FL ©2008, Prentice Hall Operating Systems: Internals and Design Principles,
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Chapter 1: Introduction.
Operating System A program that controls the execution of application programs An interface between applications and hardware 1.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 2: System Structures.
9/14/2015B.Ramamurthy1 Operating Systems : Overview Bina Ramamurthy CSE421/521.
Chapter 2 Operating System Overview Patricia Roy Manatee Community College, Venice, FL ©2008, Prentice Hall Operating Systems: Internals and Design Principles,
Introduction and Overview Questions answered in this lecture: What is an operating system? How have operating systems evolved? Why study operating systems?
1 5/25/2016 操作系统课件 教材: 《操作系统概念(第六版 影印版)》 【原书名】 Operating System Concepts(Sixth Edition) [ 原书信息 ] Operating System Concepts(Sixth Edition) [ 原书信息 ] 【原出版社】
Thanks to Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 1: Introduction n What is an Operating System? n Mainframe Systems.
 What is an operating system? What is an operating system?  Where does the OS fit in? Where does the OS fit in?  Services provided by an OS Services.
Four Components of a Computer System. Computer System Components Users (people, machines, other computers) Applications programs – define the ways in.
Operating Systems CS3502 Fall 2014 Dr. Jose M. Garrido
Silberschatz, Galvin and Gagne  2002 Modified for CSCI 399, Royden, Operating System Concepts Operating Systems Lecture 1 Introduction Read:
المحاضرة الاولى Operating Systems. The general objectives of this decision explain the concepts and the importance of operating systems and development.
Operating System Concepts Chapter One: Introduction What is an operating system? Simple Batch Systems Multiprogramming Systems Time-Sharing Systems Personal-Computer.
Chapter 1: Introduction. 1.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Chapter 1: Introduction What Operating Systems Do Computer-System.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 3: Operating-System Structures System Components Operating System Services.
1.1 Operating System Concepts Introduction What is an Operating System? Mainframe Systems Desktop Systems Multiprocessor Systems Distributed Systems Clustered.
Operating System What is an Operating System? A program that acts as an intermediary between a user of a computer and the computer hardware. An operating.
Distributed System Concepts and Architectures 2.3 Services Fall 2011 Student: Fan Bai
Operating Systems Introduction to Operating System (OS)
Chapter 2 Operating System Overview Patricia Roy Manatee Community College, Venice, FL ©2008, Prentice Hall Operating Systems: Internals and Design Principles,
CS307 Operating Systems Introduction Fan Wu Department of Computer Science and Engineering Shanghai Jiao Tong University Spring 2013.
Operating Systems Introduction to Operating System (OS)
CS1253- OPERATING SYSTEMS. SYLLABUS UNIT I PROCESSES AND THREADS 9 Introduction to operating systems – Review of computer organization – Operating.
Chapter 1 Basic Concepts of Operating Systems Introduction Software A program is a sequence of instructions that enables the computer to carry.
CCSB234/CSNB234 Operating System Concepts Semester 2, Dec 2006 – Mar 2007 Abdul Rahim Ahmad.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 1: Introduction What is an Operating System? Multiprocessor Systems Distributed.
Operating Systems: Summary INF1060: Introduction to Operating Systems and Data Communication.
1 Chapter 2: Operating-System Structures Services Interface provided to users & programmers –System calls (programmer access) –User level access to system.
Copyright Prentice Hall, Inc. 1 Operating System Overview.
Silberschatz, Galvin and Gagne ©2013 Operating System Concepts – 9 th Edit9on Chapter 1: Introduction.
References A. Silberschatz, P. B. Galvin, and G. Gagne, “Operating Systems Concepts (with Java)”, 8th Edition, John Wiley & Sons, 2009.
Chapter 2 Operating System Overview Dave Bremer Otago Polytechnic, N.Z. ©2008, Prentice Hall Operating Systems: Internals and Design Principles, 6/E William.
CSC322 OPERATING SYSTEM Mr. Dilawar Lecturer, Department of Computer Science, Jahan University Kabul, Afghanistan.
Introduction to Operating Systems
Introduction to Operating Systems Concepts
Introduction to Operating System (OS)
Applied Operating System Concepts
Operating Systems : Overview
Selected topic in computer science (1)
Operating Systems Introduction
Introduction to Operating System (OS)
Lecture Note 0: Course Introduction
Shell & Kernel Concepts in Operating System
What is an Operating System?
Introduction to Operating Systems
Operating Systems : Overview
Operating Systems : Overview
Operating Systems : Overview
Operating Systems : Overview
Lecture Note 0: Course Introduction
Introduction to Operating Systems
Presentation transcript:

Introduction to Operating System (OS) Operating Systems Introduction to Operating System (OS) A. Frank - P. Weisberg

Slides Credits for all PPTs of OS course The slides/diagrams in this course are an adaptation, combination, and enhancement of material from the following resources and persons: Slides of A. Silberschatz, P. B. Galvin and G. Gagne (see book references ahead) with some enhancements by Y. Wiseman. Slides of Mario Marchand of the University of Ottawa and Patricia Roy of Manatee Community College based on W. Stallings (see book reference ahead) with some enhancements by O. Kremien and E. Gruengard. Some diagrams from R. A. Finkel and Andrew S. Tanenbaum (see book references ahead). A. Frank - P. Weisberg

What is an Operating System (1)? A modern computer consists of: One or more processors Main memory Disks Printers Various input/output devices. Managing all these varied components requires a layer of software – the Operating System (OS). A. Frank - P. Weisberg

What is an Operating System (2)? An Operating System is a program that acts as an intermediary/interface between a user of a computer and the computer hardware. OS goals: Control/execute user/application programs. Make the computer system convenient to use. Ease the solving of user problems. Use the computer hardware in an efficient manner. A. Frank - P. Weisberg

Where does the OS fit in? A. Frank - P. Weisberg

Services provided by an OS Facilities for program creation editors, compilers, linkers, debuggers, etc. Program execution loading in memory, I/O and file initialization. Access to I/O and files deals with the specifics of I/O and file formats. System access resolves conflicts for resource contention. protection in access to resources and data. A. Frank - P. Weisberg

Why are Operating Systems Important? Important to understand and know how to correctly use when writing user applications. Large and complex systems that have a high economic impact and result in interesting problems of management. Few actually involved in OS design and implementation but nevertheless many general techniques to be learned and applied. Combines concepts from many other areas of Computer Science: Architecture, Languages, Data Structures, Algorithms. A. Frank - P. Weisberg

Motivation for Operating Systems (OS) Introduction Course Syllabus (1) Motivation for Operating Systems (OS) Introduction What's an Operating System? Computer/Operating System Overview Evolution of Operating Systems Functional/Protection Aspects Operating System Structures A. Frank - P. Weisberg

Course Syllabus (2) Concurrent Processes Process Models and Management Process Description and Control Task/Thread Description and Control Concurrency: Mutual Exclusion and Synchronization Concurrency: Deadlock and Starvation A. Frank - P. Weisberg

Course Syllabus (3) Memory Management Real Memory Management Motivation for Virtual Memory (VM) Paging and Segmentation Page Fetch, Placement and Replacement A. Frank - P. Weisberg

Uniprocessor Scheduling Course Syllabus (4) Uniprocessor Scheduling Levels of CPU Scheduling Process Scheduling External Storage Management File Systems/Management Directories File Allocation Disk Scheduling A. Frank - P. Weisberg

Main Bibliography A. Silberschatz, P. B. Galvin, and G. Gagne, “Operating Systems Concepts (with Java)”, 8th Edition, John Wiley & Sons, 2009. http://codex.cs.yale.edu/avi/os-book/os8/index.php A. Frank - P. Weisberg

Main Bibliography W. Stallings, “Operating Systems: Internals and Design Principles”, 7th ed, Prentice Hall, 2012. http://williamstallings.com/OperatingSystems/ A. Frank - P. Weisberg

Additional Bibliography A. S. Tanenbaum, “Modern Operating Systems”, 3rd Edition, Prentice-Hall Intl., 2008. http://www.pearsonhighered.com/educator/academic/product/0,,0136006639,00%2ben-USS_01DBC.html A. Frank - P. Weisberg

Additional Bibliography A. S. Tanenbaum and A. S. Woodhill, “Operating Systems: Design and Implementation”, 3rd Edition, Prentice-Hall Intl., 2006. http://www.pearsonhighered.com/educator/academic/product/0,,0131429388,00%2ben-USS_01DBC.htm A. Frank - P. Weisberg

Additional Bibliography S. Toledo, “Operating Systems”, in Hebrew, Akademon, 2001. http://www.tau.ac.il/~stoledo/osbook/ G. Nutt, ``Operating Systems: A Modern Perspective'', 2nd Edition Lab Update, Addison-Wesley, 2002. http://www.cs.colorado.edu/~nutt/osamp.html R. A. Finkel, “An Operating Systems Vade Mecum”, Prentice-Hall Intl., 1988. A. Frank - P. Weisberg

UNIX Bibliography (Internals) R. Love, “Linux Kernel Development”, 2nd Edition, Novell Press, 2005. U. Vahalia, “UNIX Internals: The New Frontiers”, Prentice-Hall Intl., 1995. S. J. Leffler, et al, “The Design and Implementation of the 4.3BSD UNIX Operating System”, Addison-Wesley, 1989. M. J. Bach, “The Design of the UNIX Operating System”, Prentice-Hall Intl., 1986. A. Frank - P. Weisberg

UNIX Bibliography (Programming) K. Haviland, et al, “Unix System Programming: A Programmer's Guide to Software Development”, Addison-Wesley, 1999. W. R. Stevens, and S. A. Rago, “Advanced Programming in the UNIX Environment”, 2nd Edition, Addison-Wesley, 2008. D. P. Bovet, and M. Cesati, “Understanding the Linux Kernel”, 3rd ed, O’Reilly Media, 2008 A. Frank - P. Weisberg

Computer Hardware Organization A. Frank - P. Weisberg

Computer System Components Hardware – provides basic computing resources (CPU, Memory, I/O devices, Communication). Operating System – controls and coordinates the use of the hardware among various application programs for various users. System & Application Programs – ways in which the system resources are used to solve computing problems of the users (Word processors, Compilers, Web browsers, Database systems, Video games). Users – (People, Machines, other computers). A. Frank - P. Weisberg

Hierarchical view of computer system A. Frank - P. Weisberg

Static View of System Components A. Frank - P. Weisberg

Dynamic View of System Components A. Frank - P. Weisberg

Layers of a Computer System End User Programmer Application Programs Utilities Operating- System Designer Operating-System Computer Hardware A. Frank - P. Weisberg

Views of an Operating System There are three classical views (in literature): Resource Manager – manages and allocates resources. Control program – controls the execution of user programs and operations of I/O devices. Command Executer – Provides an environment for running user commands. But one more modern view: the Operating System as a Virtual Machine. A. Frank - P. Weisberg

1. Resource Manager Resource Manager: Sort of a bottom-up view. Manages and protects multiple computer resources: CPU, Processes, Internal/External memory, Tasks, Applications, Users, Communication channels, etc… Handles and allocates resources to multiple users or multiple programs running at the same time and space (e.g., processor time, memory, I/O devices). Decides between conflicting requests for efficient and fair resource use (e.g., maximize throughput, minimize response time). Sort of a bottom-up view. A. Frank - P. Weisberg

OS as a Resource Manager A. Frank - P. Weisberg

Resource Manager oriented OS names DEC RSX – Resource Sharing eXecutive MIT Multics – MULTiplexed Information and Computing Services IBM MFT/MVT – Multiple Fixed/Variable Tasks IBM MVS – Multiple Virtual Storage DEC VMS – Virtual Memory System MVS TSO – Time Sharing Option CTSS – Compatible Time Sharing System IBM VM – Virtual machine A. Frank - P. Weisberg

2. Control Program Control Program: Sort of a black box view. Manages all the components of a complex computer system in an integrated manner. Controls the execution of user programs and I/O devices to prevent errors and improper use of computer resources. Looks over and protects the computer: Monitor, Supervisor, Executive, Controller, Master, Coordinator …. Sort of a black box view. A. Frank - P. Weisberg

Control program oriented OS names Unisys MCP – Master Control Program DR CP/M – Control Program/Microcomputer IBM VM/CP – VM Control Program IBM AIX – Advanced Interactive eXecutive DEC RSX – Resource Sharing eXecutive A. Frank - P. Weisberg

3. Command Executer Command Executer: Sort of a top-down view. Interfaces between the users and machine. Supplies services/utilities to users. Provides the users with a convenient CLI (Command Language Interface), also called a Shell (in UNIX), for entering the user commands. Sort of a top-down view. A. Frank - P. Weisberg

Command Executer oriented OS names IBM AIX – Advanced Interactive Executive IBM VM/CMS – Conversational monitor System A. Frank - P. Weisberg

Modern view: Virtual Machine (1) Operating System as a Virtual Machine: An interface between the user and hardware that hides the details of the hardware (e.g., I/O). Constructs higher-level (virtual) resources out of lower-level (physical) resources (e.g., files). Definition: OS is a collection of software enhancements, executed on the bare hardware, culminating in a high-level virtual machine that serves as an advanced programming environment. virtual machine = software enhancement = extended machine = abstract machine = layer = level = ring. A. Frank - P. Weisberg

Modern view: Virtual Machine (2) A. Frank - P. Weisberg

Definition of Operating System There is no universally accepted definition. “Everything a vendor ships when you order an operating system” is good approximation but varies widely. “The one program running at all times on the computer” is the Kernel. Everything else is either a system program (ships with the operating system) or an application program. A. Frank - P. Weisberg

One Kernel Point of View A. Frank - P. Weisberg

What is the OS/Kernel? Is the Operating System just the Kernel (not the utilities and application programs)?! The Command Line Interface (CLI) (or command layer/interpreter or shell) allows direct command entry by the user. The shell used to be in the kernel but now is a (first between equals) utility outside of it: Easy to change/debug Many of them (sh, bsh, csh, ksh, tcsh, wsh, bash) Possible to switch between them (chsh) A. Frank - P. Weisberg

UNIX Shell and Utilities User Utilities Shell Kernel Hardware A. Frank - P. Weisberg

Bourne Shell (bsh) A. Frank - P. Weisberg

A very simplified Shell A. Frank - P. Weisberg

UNIX System Layout A. Frank - P. Weisberg

General UNIX Architecture (1) A. Frank - P. Weisberg

General UNIX Architecture (2) Other application programs nroff sh who a.out cpp Kernel date comp Hardware cc we as ld grep vi ed Other application programs A. Frank - P. Weisberg