Evolution of Operating System
Download
Report
Transcript Evolution of Operating System
Operating Systems I
An Introduction
to
Operating System
Concepts
CMSC 104
1
OS Introduction
Computer applications today require a
single machine to perform many
operations and the applications may
compete for the resources of the machine.
This demands a high degree of
coordination
This coordination is handled by system
software known as the operating system
CMSC 104
2
Evolution of Operating System
OS for batch jobs
o Program execution required significant
preparation of equipment
o Program execution (job)
o OS was a system to simplify program setup
and simplify transition between jobs
o Physical separation of users and
equipment led to computer operators
CMSC 104
3
OS Evolution (cont’d)
o User’s left jobs with the operator and came
back the next day (batch jobs)
o Users had no interaction with computer
during program execution. Maybe okay for
some applications, but not for all.
CMSC 104
4
OS Evolution
OS for Interactive Processing
o Allowed programs to carry on dialogue with
user via remote terminals (workstations)
o Real-time processing
o Users demand timely response
o Machines too expensive to serve only one
user
o Common for several users to want
interactive services at the same time
CMSC 104
5
OS Evolution (cont’d)
OS for time-sharing
o To accommodate multiple real-time users,
the OS rotates its various jobs in and out of
execution via time-sharing
o Each job gets a predetermined “time slice”
o At end of time slice current job is set aside
and a new one starts
o By rapidly shuffling jobs, illusion of several
jobs executing simultaneously is created
CMSC 104
6
OS Evolution (cont’d)
o without time slicing, a computer spends
most of its time waiting for peripheral
devices or users
o A collection of tasks can be completed in
less time with time-sharing than when
completed sequentially
CMSC 104
7
Different Operating Systems on the
Same Machine ?
It is possible to have more than one
operating system available to be used
on a machine.
Only one operating system is run at a
time, though.
Examples:
o VAX - VMS or Ultrix
o IBM PCs - DOS or Linux
CMSC 104
8
Types of software
Applications software
Performs tasks specific to the machine’s
utilization.
Generally transportable
System Software
Performs tasks common to computer
systems in general
Operating systems vary based on the
hardware they’re used on
CMSC 104
9
Types of software (cont’d)
Utility software
o providing fundamental activities, yet not
included with OS
o “extend” the OS
o Distinction between applications and
utilities is often vague
o Distinction between OS and utilities is also
vague
CMSC 104
10
The OS Shell
Defines interface between OS and
users
o Windows GUI
o UNIX command line
o UNIX users can choose among a variety of
shells
•csh is the “C shell”
•tcsh is an enhanced “C shell”
o Shell programming
CMSC 104
11
OS Shell interface
Users
Users
O/S
Users
shell
CMSC 104
12
The OS Kernel
The internal part of the OS is often
called the Kernel
Kernel Components
o File Manager
o Device Drivers
o Memory Manager
o Scheduler
o Dispatcher
CMSC 104
13
OS File Manager
Maintains information about the files
that are available on the system
Where files are located in mass storage,
their size and type and their protections,
what part of mass storage is available
Files usually allowed to be grouped in
directories or folders. Allows
hierarchical organization.
CMSC 104
14
OS Device Drivers
Software to communicate with
peripheral devices or controllers
Each driver is unique
Translates general requests into specific
steps for that device
CMSC 104
15
OS Memory Manager
This unit is responsible for coordinating
the use of the machine’s main memory.
It decides what area of memory is to be
allocated for a program and it’s data
It allocates and deallocates memory for
different programs and always knows
what areas are free.
CMSC 104
16
OS Scheduler
Maintains a record of processes that are
present, adds new processes, removes
completed processes
o memory area(s) assigned
o priority
o state of readiness to execute (ready/wait)
CMSC 104
17
OS Dispatcher
Ensures that processes that are ready
to run are actually executed
Time is divided into small (50 ms)
segments called a time slice.
When the time slice is over, the
dispatcher allows scheduler to update
process state for each process, then
selects the next process to run
CMSC 104
18
OS Summary
Shell -- interface to user
File Manager -- manages mass memory
Device Drivers -- communicate with
peripherals
Memory Manager -- manages main
memory
Scheduler & Dispatcher -- manage
processes
CMSC 104
19
Utilities
Operating Systems usually come with
some associated utility programs
UNIX usually has the text editors emacs
and vi (and sometimes pico)
UNIX has it’s own sort utility
UNIX has it’s own mail utility
CMSC 104
20