Professional Documents
Culture Documents
Operating System Concepts – 10th Edition 1.2 Silberschatz, Galvin and Gagne
What is an Operating System?
Operating System Concepts – 10th Edition 1.3 Silberschatz, Galvin and Gagne
Computer System Structure
Operating System Concepts – 10th Edition 1.4 Silberschatz, Galvin and Gagne
Abstract View of Components of Computer
Operating System Concepts – 10th Edition 1.5 Silberschatz, Galvin and Gagne
What Operating Systems Do
Depends on the point of view
Users want convenience, ease of use and good performance
• Don’t care about resource utilization
But shared computer such as mainframe or minicomputer
must keep all users happy
• Operating system is a resource allocator and control
program making efficient use of HW and managing
execution of user programs
Users of dedicate systems such as workstations have
dedicated resources but frequently use shared resources
from servers
Mobile devices like smartphones and tables are resource
poor, optimized for usability and battery life
• Mobile user interfaces such as touch screens, voice
recognition
Some computers have little or no user interface, such as
embedded computers in devices and automobiles
• Run primarily without user
Operating System Concepts – 10th Edition1.6 intervention Silberschatz, Galvin and Gagne
Overview of Computer System Structure
Operating System Concepts – 10th Edition 1.7 Silberschatz, Galvin and Gagne
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
Operating System Concepts – 10th Edition 1.8 Silberschatz, Galvin and Gagne
Computer-System Operation
Operating System Concepts – 10th Edition 1.9 Silberschatz, Galvin and Gagne
Operating-System Operations
Bootstrap program – simple code to initialize the system,
load the kernel
Kernel loads
Starts system daemons (services provided outside of the
kernel)
Kernel interrupt driven (hardware and software)
• Hardware interrupt by one of the devices
• Software interrupt (exception or trap):
Software error (e.g., division by zero)
Request for operating system service – system call
Other process problems include infinite loop,
processes modifying each other or the operating
system
Operating System Concepts – 10th Edition 1.10 Silberschatz, Galvin and Gagne
Multiprogramming (Batch system)
Single user cannot always keep CPU and I/O
devices busy
Multiprogramming organizes jobs (code and data) so
CPU always has one to execute
A subset of total jobs in system is kept in memory
One job selected and run via job scheduling
When job has to wait (for I/O for example), OS
switches to another job
Operating System Concepts – 10th Edition 1.11 Silberschatz, Galvin and Gagne
Multitasking (Timesharing)
Operating System Concepts – 10th Edition 1.12 Silberschatz, Galvin and Gagne
Memory Layout for Multiprogrammed System
Operating System Concepts – 10th Edition 1.13 Silberschatz, Galvin and Gagne
Dual-mode Operation
Operating System Concepts – 10th Edition 1.14 Silberschatz, Galvin and Gagne
Transition from User to Kernel Mode
Operating System Concepts – 10th Edition 1.15 Silberschatz, Galvin and Gagne
Virtualization
Operating System Concepts – 10th Edition 1.16 Silberschatz, Galvin and Gagne
Virtualization (cont.)
Operating System Concepts – 10th Edition 1.17 Silberschatz, Galvin and Gagne
Computing Environments - Virtualization
Operating System Concepts – 10th Edition 1.18 Silberschatz, Galvin and Gagne
(Self Study)
Operating System Concepts – 10th Edition 1.19 Silberschatz, Galvin and Gagne
Computer-System Architecture (Self
Study)
Operating System Concepts – 10th Edition 1.20 Silberschatz, Galvin and Gagne
Symmetric Multiprocessing Architecture
(Self Study)
Operating System Concepts – 10th Edition 1.21 Silberschatz, Galvin and Gagne
Dual-Core Design
(Self Study)
Multi-chip and multicore
Systems containing all chips
• Chassis containing multiple separate systems
Operating System Concepts – 10th Edition 1.22 Silberschatz, Galvin and Gagne
Chapter 1(Cont’d): Operating-
System Services
Operating System Concepts – 10th Edition 1.24 Silberschatz, Galvin and Gagne
Operating System Services
Operating systems provide an environment for execution
of programs and services to programs and users
One set of operating-system services provides functions
that are helpful to the user:
• User interface - Almost all operating systems have a
user interface (UI).
Varies between Command-Line (CLI), Graphics User
Interface (GUI), touch-screen, Batch
• Program execution - The system must be able to load
a program into memory and to run that program, end
execution, either normally or abnormally (indicating
error)
• I/O operations - A running program may require I/O,
which may involve a file or an I/O device
• File-system manipulation - The file system is of
particular interest. Programs need to read and write
files and directories, create and delete them, search
them, list file Information, permission management.
Operating System Concepts – 10th Edition 1.25 Silberschatz, Galvin and Gagne
Operating System Services (Cont.)
One set of operating-system services provides functions
that are helpful to the user (Cont.):
• Communications – Processes may exchange
information, on the same computer or between
computers over a network
Communications may be via shared memory or
through message passing (packets moved by the
OS)
• Error detection – OS needs to be constantly aware of
possible errors
May occur in the CPU and memory hardware, in I/O
devices, in user program
For each type of error, OS should take the
appropriate action to ensure correct and
consistent computing
Debugging facilities can greatly enhance the
user’s and programmer’s abilities to efficiently use
the system
Operating System Concepts – 10th Edition 1.26 Silberschatz, Galvin and Gagne
Operating System Services (Cont.)
Another set of OS functions exists for ensuring the
efficient operation of the system itself via resource
sharing
• Resource allocation - When multiple users or multiple
jobs running concurrently, resources must be
allocated to each of them
Many types of resources - CPU cycles, main
memory, file storage, I/O devices.
• Logging - To keep track of which users use how much
and what kinds of computer resources
• Protection and security - The owners of information
stored in a multiuser or networked computer system
may want to control use of that information,
concurrent processes should not interfere with each
other
Protection involves ensuring that all access to
system resources is controlled
Security of the system from outsiders requires user
authentication, extends to defending external I/O
devices from invalid access attempts
Operating System Concepts – 10th Edition 1.27 Silberschatz, Galvin and Gagne
A View of Operating System Services
Operating System Concepts – 10th Edition 1.28 Silberschatz, Galvin and Gagne
Command Line interpreter
(Self Study)
Operating System Concepts – 10th Edition 1.29 Silberschatz, Galvin and Gagne
Bourne Shell Command Interpreter
(Self Study)
Operating System Concepts – 10th Edition 1.30 Silberschatz, Galvin and Gagne
User Operating System Interface - GUI
(Self Study)
Operating System Concepts – 10th Edition 1.31 Silberschatz, Galvin and Gagne
Touchscreen Interfaces
(Self Study)
Touchscreen devices
require new interfaces
• Mouse not possible or not
desired
• Actions and selection based
on gestures
• Virtual keyboard for text
entry
Voice commands
Operating System Concepts – 10th Edition 1.32 Silberschatz, Galvin and Gagne
The Mac OS X GUI (Self Study)
Operating System Concepts – 10th Edition 1.33 Silberschatz, Galvin and Gagne
System Calls (Self Study)
Operating System Concepts – 10th Edition 1.34 Silberschatz, Galvin and Gagne
Example of System Calls (Self Study)
Operating System Concepts – 10th Edition 1.35 Silberschatz, Galvin and Gagne
System Call Implementation (Self Study)
Operating System Concepts – 10th Edition 1.36 Silberschatz, Galvin and Gagne
Types of System Calls (Self Study)
Process control
• create process, terminate process
• end, abort
• load, execute
• get process attributes, set process attributes
• wait for time
• wait event, signal event
• allocate and free memory
• Dump memory if error
• Debugger for determining bugs, single step execution
• Locks for managing access to shared data between
processes
Operating System Concepts – 10th Edition 1.37 Silberschatz, Galvin and Gagne
Types of System Calls (Cont.) (Self
Study)
File management
• create file, delete file
• open, close file
• read, write, reposition
• get and set file attributes
Device management
• request device, release device
• read, write, reposition
• get device attributes, set device attributes
• logically attach or detach devices
Operating System Concepts – 10th Edition 1.38 Silberschatz, Galvin and Gagne
Types of System Calls (Cont.) (Self
Study)
Information maintenance
• get time or date, set time or date
• get system data, set system data
• get and set process, file, or device attributes
Communications
• create, delete communication connection
• send, receive messages if message passing model
to host name or process name
From client to server
• Shared-memory model create and gain access to
memory regions
• transfer status information
• attach and detach remote devices
Operating System Concepts – 10th Edition 1.39 Silberschatz, Galvin and Gagne
Types of System Calls (Cont.) (Self
Study)
Protection
• Control access to resources
• Get and set permissions
• Allow and deny user access
Operating System Concepts – 10th Edition 1.40 Silberschatz, Galvin and Gagne
Examples of Windows and Unix System Calls
(Self Study)
Operating System Concepts – 10th Edition 1.41 Silberschatz, Galvin and Gagne
Operating System Structure
Operating System Concepts – 10th Edition 1.42 Silberschatz, Galvin and Gagne
Monolithic Structure – Original UNIX
UNIX – limited by hardware functionality, the original
UNIX operating system had limited structuring.
The UNIX OS consists of two separable parts
• Systems programs
• The kernel
Consists of everything below the system-call
interface and above the physical hardware
Provides the file system, CPU scheduling, memory
management, and other operating-system
functions; a large number of functions for one level
Operating System Concepts – 10th Edition 1.43 Silberschatz, Galvin and Gagne
Traditional UNIX System Structure
(Self Study)
Beyond simple but not fully layered
Operating System Concepts – 10th Edition 1.44 Silberschatz, Galvin and Gagne
Linux System Structure (Self Study)
Monolithic plus modular design
Operating System Concepts – 10th Edition 1.45 Silberschatz, Galvin and Gagne
Layered Approach
Operating System Concepts – 10th Edition 1.46 Silberschatz, Galvin and Gagne
Microkernels
Moves as much from the kernel into user space
Mach is an example of microkernel
• Mac OS X kernel (Darwin) partly based on Mach
Communication takes place between user modules
using message passing
Benefits:
• Easier to extend a microkernel
• Easier to port the operating system to new
architectures
• More reliable (less code is running in kernel
mode)
• More secure
Detriments:
• Performance overhead of user space to kernel
space communication
Operating System Concepts – 10th Edition 1.47 Silberschatz, Galvin and Gagne
Microkernel System Structure
Operating System Concepts – 10th Edition 1.48 Silberschatz, Galvin and Gagne
macOS and iOS Structure (Self Study)
Operating System Concepts – 10th Edition 1.49 Silberschatz, Galvin and Gagne
Android (Self Study)
Developed by Open Handset Alliance (mostly Google)
• Open Source
Similar stack to iOS
Based on Linux kernel but modified
• Provides process, memory, device-driver
management
• Adds power management
Runtime environment includes core set of libraries
and Dalvik virtual machine
• Apps developed in Java plus Android API
Java class files compiled to Java bytecode
then translated to executable thnn runs in
Dalvik VM
Libraries include frameworks for web browser
(webkit), database (SQLite), multimedia, smaller libc
Operating System Concepts – 10th Edition 1.50 Silberschatz, Galvin and Gagne
Android Architecture (Self Study)
Operating System Concepts – 10th Edition 1.51 Silberschatz, Galvin and Gagne
End of Chapter 1