Chapter 2: System Structures: Silberschatz, Galvin and Gagne ©2013 Operating System Concepts - 9 Edition
Chapter 2: System Structures: Silberschatz, Galvin and Gagne ©2013 Operating System Concepts - 9 Edition
Operating System Concepts – 9th Edition Silberschatz, Galvin and Gagne ©2013
Chapter 2: Operating-System Structures
Operating System Concepts – 9th Edition 2.2 Silberschatz, Galvin and Gagne ©2013
A View of Operating System Services
Operating System Concepts – 9th Edition 2.3 Silberschatz, Galvin and Gagne ©2013
Operating System Services
● User interface
● Program Execution
● I/O Operations
● File System manipulation
● Communications
● Error detection
● Resource Allocation
● Accounting
● Protection and Security
Operating System Concepts – 9th Edition 2.4 Silberschatz, Galvin and Gagne ©2013
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).
4 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/Ooperations - A running program may require I/O, which may involve a file or an I/O
device.
● For efficiency and protection, users cannot control I/O devices directly, rather
OS provides a means to do I/O.
Operating System Concepts – 9th Edition 2.5 Silberschatz, Galvin and Gagne ©2013
Operating System Services (Cont.)
One set of operating-system services provides functions that are helpful to the
user (Cont.):
• File-system manipulation: Programs need to read and write files and
directories. Create and delete file, search for a file, list file information etc,.
• Some programs include permission management to allow or deny access to
files and directories based on file ownership.
• 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 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
User Operating System Interface - CLI
Operating System Concepts – 9th Edition 2.13 Silberschatz, Galvin and Gagne ©2013
User Operating System Interface - GUI
Operating System Concepts – 9th Edition 2.14 Silberschatz, Galvin and Gagne ©2013
Touchscreen Interfaces
Operating System Concepts – 9th Edition 2.16 Silberschatz, Galvin and Gagne ©2013
Example of System Calls
System call sequence to copy the contents of one file to another file
Example of Standard API
System Call Implementation
Operating System Concepts – 9th Edition 2.30 Silberschatz, Galvin and Gagne ©2013
Types of System Calls
▪ 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
Process control
● End , abort
● Load, Execute
● Create process, terminate process
● Wait for time
● Allocate and free memory
● Wait event, signal event
● Get process attributes, set PA
Operating System Concepts – 9th Edition 2.32 Silberschatz, Galvin and Gagne ©2013
File management , Device management
File management
Device management
● Request device , release device
● Read , write , reposition
● Get device attributes
● Set device attributes
Operating System Concepts – 9th Edition 2.34 Silberschatz, Galvin and Gagne ©2013
Information maintenance , communications
▪ 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 – 9th Edition 2.35 Silberschatz, Galvin and Gagne ©2013
▪ Protection
• Control access to resources
• Get and set permissions
• Allow and deny user access
Types of System Calls
Examples of Windows and Unix System Calls
Standard C Library Example
▪ C program invoking printf() library call, which calls write() system call
Example: Arduino
• Single-tasking
• No operating system
• Programs (sketch) loaded via USB
into flash memory
• Single memory space
• Boot loader loads program
• Program exit -> shell reloaded At system startup running a program
Example: FreeBSD
▪ Unix variant
▪ Multitasking
▪ User login -> invoke user’s choice of shell
▪ Shell executes fork() system call to create
process
➢ Executes exec() to load program into
process
➢ Shell waits for process to terminate or
continues with user commands
▪ Process exits with:
➢ code = 0 – no error
➢ code > 0 – error code
System Services/System Programs/Utilities
Operating System Concepts – 9th Edition 2.48 Silberschatz, Galvin and Gagne ©2013
Why Applications are Operating System Specific
Operating System Concepts – 9th Edition 2.50 Silberschatz, Galvin and Gagne ©2013
Operating System Design and Implementation (Cont.)
● Implementation
● Early OS in assembly language
● Now C, C++
Operating System Concepts – 9th Edition 2.51 Silberschatz, Galvin and Gagne ©2013
Operating System Structure
● General-purpose OS is very large program
● Various ways to structure ones
● Simple structure – MS-DOS
● More complex -- UNIX
● Layered – an abstrcation
● Microkernel -Mach
Operating System Concepts – 9th Edition 2.52 Silberschatz, Galvin and Gagne ©2013
Simple Structure -- MS-DOS
Operating System Concepts – 9th Edition 2.53 Silberschatz, Galvin and Gagne ©2013
Traditional UNIX system structure
• The Linux operating system is based on
UNIX and is structured similarly
• Applications typically use the glibc
standard C library when
communicating with the system call
interface to the kernel.
• The Linux kernel is monolithic in that it
runs entirely in kernel mode in a single
address space.
• But, it does have a modular design that
allows the kernel to be modified during
run time.
Layered Approach
Operating System Concepts – 9th Edition 2.57 Silberschatz, Galvin and Gagne ©2013
Microkernel System Structure
● Moves as much from the kernel into user space
● Mach example of microkernel
● 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 – 9th Edition 2.58 Silberschatz, Galvin and Gagne ©2013
Microkernel System Structure
Modules
● Many modern operating systems implement loadable kernel
modules
● Uses 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, similar to layers but with more flexible
● Linux, Solaris, etc
Operating System Concepts – 9th Edition 2.60 Silberschatz, Galvin and Gagne ©2013
Hybrid Systems
Operating System Concepts – 9th Edition 2.67 Silberschatz, Galvin and Gagne ©2013
Virtual Machines
Operating System Concepts – 9th Edition 2.68 Silberschatz, Galvin and Gagne ©2013
Virtualization
Operating System Concepts – 9th Edition 2.69 Silberschatz, Galvin and Gagne ©2013
Operating System Generation
● The configuration of the system or system generated for each specific
computer site a process is known as System Generation.
● The system programs reads from a given file or asks the operator of the
system for information about specific configuration of the hardware
systems.
● The following kind of information must be determined
i) What CPU is to be used ?
ii)How much memory is available ?
iii) What devices are available ?
iv) What operating systems options are desired ?
Operating System Concepts – 9th Edition 2.70 Silberschatz, Galvin and Gagne ©2013
System Boot
● When power initialized on system, execution starts at a fixed
memory location
● Firmware ROM used to hold initial boot code
● Operating system must be made available to hardware so
hardware can start it
● Small piece of code – bootstrap loader, stored in ROM or
EEPROM locates the kernel, loads it into memory, and starts it
● Sometimes two-step process where boot block at fixed
location loaded by ROM code, which loads bootstrap loader
from disk
Operating System Concepts – 9th Edition 2.71 Silberschatz, Galvin and Gagne ©2013
Operating-System Debugging
▪ Debugging is finding and fixing errors, or bugs
▪ Also performance tuning
▪ OS generate log files containing error information
▪ Failure of an application can generate core dump file capturing memory of the
process
▪ Operating system failure can generate crash dump file containing kernel
memory
▪ Beyond crashes, performance tuning can optimize system performance
➢ Sometimes using trace listings of activities, recorded for analysis
➢ Profiling is periodic sampling of instruction pointer to look for statistical
trends
▪ Kernighan’s Law: “Debugging is twice as hard as writing the code in the first
place. Therefore, if you write the code as cleverly as possible, you are, by
definition, not smart enough to debug it.”
End of Chapter 2
Operating System Concepts – 9th Edition Silberschatz, Galvin and Gagne ©2013