Learning Objectives At the end of the chapter, the students are able to: • understand the major operating systems components • understand basic computer system organization • describe the services an operating system provides to users, processes, and other systems • discuss the various ways of structuring an operating system • explain how operating systems are installed and customized and how they boot
What is an Operating System? • A program that acts as an intermediary between a user of a computer and the computer hardware. • Operating system goals: • Execute user programs and make solving user problems easier. • Make the computer system convenient to use. • Use the computer hardware in an efficient manner.
Computer System Structure • Computer system can be divided into four components • Hardware – provides basic computing resources • CPU, memory, I/O devices • Operating system • Controls and coordinates use of hardware among various applications and users • Application programs – define the ways in which the system resources are used to solve the computing problems of the users • Word processors, compilers, web browsers, database systems, video games • Users - People, machines, other computers
Operating System Definition • OS is a resource allocator • Manages all resources • Decides between conflicting requests for efficient and fair resource use • OS is a control program • Controls execution of programs to prevent errors and improper use of the computer
Operating System Definition (Cont.) • No universally accepted definition • “Everything a vendor ships when you order an operating system” is good approximation • But varies wildly • “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
Computer Startup • Operating system must be made available to hardware so hardware can start it • Small piece of code – bootstrap loader, locates the kernel, loads it into memory, and starts it • Sometimes two-step process where boot block at fixed location loads bootstrap loader • When power initialized on system, execution starts at a fixed memory location • Firmware used to hold initial boot code
Computer Startup • bootstrap program is loaded at power-up or reboot • Typically stored in ROM or EEPROM , generally known as firmware • Initializes all aspects of system • Loads operating system kernel and starts execution *EEPROM = electrically erasable programmable read-only memory
ROM BIOS Chip BIOS = basic input/output system
Booting Up Your Computer • Hard (cold) boot versus soft (warm) boot • Startup BIOS is in control when boot process begins • Turns control over to the OS A cold boot is accomplished by powering up the computer from a shut down state. A warm boot is done when you need to restart while the computer is still powered but unresponsive, (for example, during a freeze up that isn’t resolved with a force quit). You do this by holding down the Control and Command keys simultaneously then pressing the Power Up key (or the on/off key on a laptop). A+ Guide to Managing and Maintaining Your PC, Fifth Edition
Steps in the Boot Process • Startup BIOS runs power-on self test (POST) and assigns resources • ROM BIOS startup program searches for and loads an OS • OS configures the system and completes its own loading • Application software is loaded and executed A+ Guide to Managing and Maintaining Your PC, Fifth Edition
Boot Step 1: POST A+ Guide to Managing and Maintaining Your PC, Fifth Edition
How the BIOS Finds and Loads the OS A+ Guide to Managing and Maintaining Your PC, Fifth Edition
How the BIOS Finds and Loads the OS (continued) • BIOS executes MBR program • Turns to partition table to find OS boot record • Program in OS boot record attempts to find a boot loader program for OS • Ntldr (Windows NT/2000/XP) • Io.sys (Windows 9x) A+ Guide to Managing and Maintaining Your PC, Fifth Edition
How the BIOS Finds and Loads the OS (continued) A Master Boot Record (MBR), or partition sector, is the 512-byte boot sector that is the first sector of a partitioned data storage device such as a hard disk. (The boot sector of a non-partitioned device is a Volume Boot Record, which is also the term used to describe the first sector of an individual partition on a partitioned device) It is sometimes used for bootstrapping operating systems, sometimes used for holding a disc's partition table, and sometimes used for uniquely identifying individual disc media; although on some machines it is entirely unused and redundant. A+ Guide to Managing and Maintaining Your PC, Fifth Edition
Boot Step 2: Loading the OS A+ Guide to Managing and Maintaining Your PC, Fifth Edition
Loading the MS-DOS Core of Windows 9x • Brings OS to real-mode command prompt • Relevance: Real-mode DOS core often used as a troubleshooting tool A+ Guide to Managing and Maintaining Your PC, Fifth Edition
Loading the MS-DOS Core of Windows 9x (continued) • Files necessary to boot to command prompt • Io.sys • Msdos.sys • Command.com • To customize 16-bit portion of load process • Autoexec.bat (Autoexec.nt – NT, 2000, XP) • Config.sys (Config.nt – NT, 2000, XP) A+ Guide to Managing and Maintaining Your PC, Fifth Edition
Boot Step 3: OS Initializes Itself A+ Guide to Managing and Maintaining Your PC, Fifth Edition
Emergency Startup Disks • Bootable disks with some utility programs to troubleshoot a failed hard drive • Each OS provides automated method to create a rescue disk (Windows 9x) or set of disks (Windows 2000) A+ Guide to Managing and Maintaining Your PC, Fifth Edition
Emergency Startup Disks (continued) • Creating a Windows 9x startup disk • Add/Remove Programs icon in Control Panel • Using a Windows 9x startup disk with another OS A+ Guide to Managing and Maintaining Your PC, Fifth Edition
Windows 9x Startup Disks A+ Guide to Managing and Maintaining Your PC, Fifth Edition
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
Basic Elements • Processor • Main Memory • volatile • referred to as real memory or primary memory • I/O modules • secondary memory devices • communications equipment • terminals • System bus • communication among processors, memory, and I/O modules
Processor • Internal registers • Memory address register (MAR) • Specifies the address for the next read or write • Memory buffer register (MBR) • Contains data written into memory or receives data read from memory • I/O address register • I/O buffer register
Processor Registers • User-visible registers • Enable programmer to minimize main-memory references by optimizing register use • Control and status registers • Used by processor to control operating of the processor • Used by privileged operating-system routines tocontrol the execution of programs
User-Visible Registers • May be referenced by machine language • Available to all programs - application programs and system programs • Types of registers • Data • Address • Index • Segment pointer • Stack pointer
User-Visible Registers • Address Registers • Index • Involves adding an index to a base value to get an address • Segment pointer • When memory is divided into segments, memory is referenced by a segment and an offset • Stack pointer • Points to top of stack
Control and Status Registers • Program Counter (PC) • Contains the address of an instruction to be fetched • Instruction Register (IR) • Contains the instruction most recently fetched • Program Status Word (PSW) • Condition codes • Interrupt enable/disable • Supervisor/user mode • Condition Codes or Flags • Bits set by the processor hardware as a result of operations • Examples • Positive result • Negative result • Zero • Overflow
Instruction Execution • Two steps • Processor reads instructions from memory • Fetches • Processor executes each instruction
Instruction Fetch and Execute • The processor fetches the instruction from memory • Program counter (PC) holds address of the instruction to be fetched next • Program counter is incremented after each fetch
Instruction Register • Fetched instruction is placed in the instruction register • Categories • Processor-memory • Transfer data between processor and memory • Processor-I/O • Data transferred to or from a peripheral device • Data processing • Arithmetic or logic operation on data • Control • Alter sequence of execution
Computer-System Operation • I/O devices and the CPU can execute concurrently. • Each device controller is in charge of a particular device type. • Each device controller has a local buffer. • CPU moves data from/to main memory to/from local buffers • I/O is from the device to local buffer of controller. • Device controller informs CPU that it has finished its operation by causing an interrupt.
Interrupts • Interrupt the normal sequencing of the processor • Most I/O devices are slower than the processor • Processor must pause to wait for device Classes of interrupts
Common Functions of Interrupts • Interrupt transfers control to the interrupt service routine generally, through the interrupt vector, which contains the addresses of all the service routines. • Interrupt architecture must save the address of the interrupted instruction. • Incoming interrupts are disabled while another interrupt is being processed to prevent a lost interrupt. • A trap is a software-generated interrupt caused either by an error or a user request. • An operating system is interrupt driven.
Interrupt Handling • When CPU is interrupted, it stops what it is doing and immediately transfers execution to a fixed location. • The operating system preserves the state of the CPU by storing registers and the program counter. • Determines which type of interrupt has occurred: • polling • vectored interrupt system • Separate segments of code determine what action should be taken for each type of interrupt
Interrupts • Suspends the normal sequence of execution
Interrupt Cycle • Processor checks for interrupts • If no interrupts fetch the next instruction for the current program • If an interrupt is pending, suspend execution of the current program, and execute the interrupt-handler routine
I/O Structure Synchronous • After I/O starts, control returns to user program only upon I/O completion. • 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.
I/O Structure Asynchronous • After I/O starts, control returns to user program without waiting for I/O completion. • 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 indicating its type, address, and state. • Operating system indexes into I/O device table to determine device status and to modify table entry to include interrupt.
Two I/O Methods Synchronous Asynchronous
Storage Structure • Main memory – the only large storage media that the CPU can access directly. • Secondary storage – extension of main memory that provides large nonvolatile storage capacity. • Magnetic disks – rigid metal or glass platters covered with magnetic recording material • Disk surface is logically divided into tracks, which are subdivided into sectors. • The disk controller determines the logical interaction between the device and the computer.
Storage Hierarchy • Storage systems organized in hierarchy. • Speed • Cost • Volatility • Caching – copying information into faster storage system; main memory can be viewed as a last cache for secondary storage.