Maximum CPU Utilization Obtained With Multiprogramming CPU-I/O Burst Cycle - Process Execution Consists of A Cycle of CPU Execution and I/O Wait. CPU Burst Distribution

Download as ppt, pdf, or txt
Download as ppt, pdf, or txt
You are on page 1of 54

 Maximum CPU utilization obtained with

multiprogramming
 CPU–I/O Burst Cycle – Process execution
consists of a cycle of CPU execution and I/O
wait.
 CPU burst distribution

Operating System Concepts


Operating System Concepts
 Selects from among the processes in memory
that are ready to execute, and allocates the CPU
to one of them.
 CPU scheduling decisions may take place when a
process:
1. Switches from running to waiting state.
2.Switches from running to ready state.
3. Switches from waiting to ready.
4.Terminates.
 Scheduling under 1 and 4 is nonpreemptive.
 All other scheduling is preemptive.

Operating System Concepts


 Dispatcher module gives control of the CPU
to the process selected by the short-term
scheduler; this involves:
 switching context
 switching to user mode
 jumping to the proper location in the user
program to restart that program
 Dispatch latency – time it takes for the
dispatcher to stop one process and start
another running.
Operating System Concepts
 CPU utilization – keep the CPU as busy as
possible
 Throughput – # of processes that complete
their execution per time unit
 Turnaround time – amount of time to
execute a particular process
 Waiting time – amount of time a process
has been waiting in the ready queue
 Response time – amount of time it takes
from when a request was submitted until
the first response is produced, not output
(for time-sharing environment)
Operating System Concepts
 Max CPU utilization
 Max throughput
 Min turnaround time
 Min waiting time
 Min response time

Operating System Concepts


Process Burst Time
P1 24
P2 3
P3 3
 Suppose that the processes arrive in the order: P1 , P2
, P3
The Gantt Chart for the schedule is:
P1 P2 P3

0 24 27 30

 Waiting time for P1 = 0; P2 = 24; P3 = 27


 Average waiting time: (0 + 24 + 27)/3 = 17

Operating System Concepts


Suppose that the processes arrive in the order
P2 , P3 , P1 .
 The Gantt chart for the schedule is:
P2 P3 P1

0 3 6 30

 Waiting time for P1 = 6; P2 = 0; P3 = 3


 Average waiting time: (6 + 0 + 3)/3 = 3
 Much better than previous case.
 Convoy effect short process behind long process

Operating System Concepts


 A priority number (integer) is associated with each
process
 The CPU is allocated to the process with the highest
priority (smallest integer  highest priority).
 Preemptive
 nonpreemptive
 SJF is a priority scheduling where priority is the
predicted next CPU burst time.
 Problem  Starvation – low priority processes may
never execute.
 Solution  Aging – as time progresses increase the
priority of the process.

Operating System Concepts


 Each process gets a small unit of CPU time (time
quantum), usually 10-100 milliseconds. After this
time has elapsed, the process is preempted and
added to the end of the ready queue.
 If there are n processes in the ready queue and
the time quantum is q, then each process gets
1/n of the CPU time
 No process waits more than (n-1)q time units.
 Performance
 q large  FIFO
 q small  q must be large with respect to context
switch, otherwise overhead is too high.
Operating System Concepts
Process Burst Time
P1 53
P2 17
P3 68
P4 24
 The Gantt chart is:

P1 P2 P3 P4 P1 P3 P4 P1 P3 P3

0 20 37 57 77 97 117 121 134 154 162

 Typically, higher average turnaround than SJF, but


better response.

Operating System Concepts


 Associate with each process the length of its
CPU burst. Use these lengths to schedule the
process with the shortest time.
 Two schemes:
 nonpreemptive – once CPU given to the process it
cannot be preempted until completes its CPU burst.
 preemptive – if a new process arrives with CPU burst
length less than remaining time of current executing
process, preempt. This scheme is know as the
Shortest-Remaining-Time-First (SRTF).
 SJF is optimal – gives minimum average waiting
time for a given set of processes.
Operating System Concepts
Process Arrival Time Burst Time
P1 0.0 7
P2 2.0 4
P3 4.0 1
P4 5.0 4
 SJF (non-preemptive)
P1 P3 P2 P4

0 3 7 8 12 16

 Average waiting time = (0 + 6 + 3 + 7)/4 - 4

Operating System Concepts


Process Arrival Time Burst Time
P1 0.0 7
P2 2.0 4
P3 4.0 1
P4 5.0 4
 SJF (preemptive)
P1 P2 P3 P2 P4 P1

0 2 4 5 7 11 16

 Average waiting time = (9 + 1 + 0 +2)/4 - 3

Operating System Concepts


Operating System Concepts
 Ready queue is partitioned into separate queues:
foreground (interactive)
background (batch)
 Each queue has its own scheduling algorithm,
foreground – RR
background – FCFS
Operating System Concepts
 A process can move between the various queues;
aging can be implemented this way.
 Multilevel-feedback-queue scheduler defined by the
following parameters:
 number of queues
 scheduling algorithms for each queue
 method used to determine when to upgrade a process
 method used to determine when to demote a process
 method used to determine which queue a process will
enter when that process needs service
 Three queues:
 Q0 – time quantum 8 milliseconds
 Q1 – time quantum 16 milliseconds
 Q2 – FCFS
 A new job enters queue Q0 which is served FCFS.
When it gains CPU, job receives 8 milliseconds. If it
does not finish in 8 milliseconds, job is moved to
queue Q1.
 At Q1 job is again served FCFS and receives 16
additional milliseconds. If it still does not complete,
it is preempted and moved to queue Q2.
Operating System Concepts
 CPU scheduling more complex when multiple
CPUs are available.
 Homogeneous processors within a
multiprocessor.
 Load sharing
 Asymmetric multiprocessing – only one
processor accesses the system data
structures, alleviating the need for data
sharing.
Operating System Concepts
 Hard real-time systems – required to
complete a critical task within a guaranteed
amount of time.
 Soft real-time computing – requires that
critical processes receive priority over less
fortunate ones.

Operating System Concepts


 Background
 The Critical-Section Problem
 Synchronization Hardware
 Semaphores
 Classical Problems of Synchronization
 Critical Regions
 Monitors
 Synchronization in Solaris 2 & Windows 2000

Operating System Concepts


 Concurrent access to shared data may result
in data inconsistency.
 Maintaining data consistency requires
mechanisms to ensure the orderly execution
of cooperating processes.
 Shared-memory solution to bounded-butter
problem allows at most n – 1 items in buffer
at the same time.
 A solution, where all N buffers are used is not
simple.
Operating System Concepts
 Race condition: The situation where several
processes access – and manipulate shared
data concurrently. The final value of the
shared data depends upon which process
finishes last.

 To prevent race conditions, concurrent


processes must be synchronized.

Operating System Concepts


 n processes all competing to use some
shared data
 Each process has a code segment,
called critical section, in which the
shared data is accessed.
 Problem – ensure that when one
process is executing in its critical
section, no other process is allowed to
execute in its critical section.

Operating System Concepts


1. Mutual Exclusion. If process Pi is executing in its critical
section, then no other processes can be executing in
their critical sections.
2. Progress. If no process is executing in its critical section
and there exist some processes that wish to enter their
critical section, then the selection of the processes that
will enter the critical section next cannot be postponed
indefinitely.
3. Bounded Waiting. A bound must exist on the number
of times that other processes are allowed to enter their
critical sections after a process has made a request to
enter its critical section and before that request is
granted.
 Assume that each process executes at a nonzero speed
 No assumption concerning relative speed of the n processes.
Operating System Concepts
 Only 2 processes, P0 and P1
 General structure of process Pi (other process Pj)
do {
entry section
critical section
exit section
reminder section
} while (1);
 Processes may share some common variables to
synchronize their actions.

Operating System Concepts


 Synchronization tool that does not require
busy waiting.
 Semaphore S – integer variable
 can only be accessed via two indivisible
(atomic) operations
wait (S):
while S 0 do no-op;
S--;
signal (S):
S++;
Operating System Concepts
 Deadlock – two or more processes are waiting indefinitely
for an event that can be caused by only one of the waiting
processes.
 Let S and Q be two semaphores initialized to 1
P0 P1
wait(S); wait(Q);
wait(Q); wait(S);
 
signal(S); signal(Q);
signal(Q) signal(S);
 Starvation – indefinite blocking. A process may never be
removed from the semaphore queue in which it is
suspended.
Operating System Concepts
 System Model
 Deadlock Characterization
 Methods for Handling Deadlocks
 Deadlock Prevention
 Deadlock Avoidance
 Deadlock Detection
 Recovery from Deadlock
 Combined Approach to Deadlock Handling

Operating System Concepts


 A set of blocked processes each holding a resource
and waiting to acquire a resource held by another
process in the set.
 Example
 System has 2 tape drives.
 P1 and P2 each hold one tape drive and each needs another
one.
 Example
 semaphores A and B, initialized to 1

P0 P1
wait (A); wait(B)
wait (B); wait(A)

Operating System Concepts


 Traffic only in one direction.
 Each section of a bridge can be viewed as a
resource.
 If a deadlock occurs, it can be resolved if one car
backs up (preempt resources and rollback).
 Several cars may have to be backed up if a
deadlock occurs.
 Starvation is possible.

Operating System Concepts


 Resource types R1, R2, . . ., Rm
CPU cycles, memory space, I/O devices
 Each resource type Ri has Wi instances.
 Each process utilizes a resource as follows:
 request
 use
 release

Operating System Concepts


Deadlock can arise if four conditions hold simultaneously.

 Mutual exclusion: only one process at a time can use


a resource.
 Hold and wait: a process holding at least one
resource is waiting to acquire additional resources
held by other processes.
 No preemption: a resource can be released only
voluntarily by the process holding it, after that process
has completed its task.
 Circular wait: there exists a set {P0, P1, …, P0} of
waiting processes such that P0 is waiting for a resource
that is held by P1, P1 is waiting for a resource that is
held by
P2, …, Pn–1 is waiting for a resource that is held by
Pn, and P0 is waiting for a resource that is held by P0.
Operating System Concepts
A set of vertices V and a set of edges E.

 V is partitioned into two types:


 P = {P1, P2, …, Pn}, the set consisting of all the
processes in the system.

 R = {R1, R2, …, Rm}, the set consisting of all


resource types in the system.
 request edge – directed edge P1  Rj
 assignment edge – directed edge Rj  Pi

Operating System Concepts


 Process

 Resource Type with 4 instances

 Pi requests instance of Rj
Pi
Rj
 Pi is holding an instance of Rj

Pi
Rj

Operating System Concepts


Operating System Concepts
Operating System Concepts
Operating System Concepts
 If graph contains no cycles  no deadlock.

 If graph contains a cycle 


 if only one instance per resource type, then
deadlock.
 if several instances per resource type, possibility
of deadlock.

Operating System Concepts


 Ensure that the system will never enter a
deadlock state.

 Allow the system to enter a deadlock state


and then recover.

 Ignore the problem and pretend that


deadlocks never occur in the system; used by
most operating systems, including UNIX.
Operating System Concepts
Restrain the ways request can be made.

 Mutual Exclusion – not required for sharable


resources; must hold for nonsharable
resources.
 Hold and Wait – must guarantee that
whenever a process requests a resource, it
does not hold any other resources.
 Require process to request and be allocated all
its resources before it begins execution, or allow
process to request resources only when the
process has none.
 Low resource utilization; starvation possible.

Operating System Concepts


 No Preemption –
 If a process that is holding some resources requests
another resource that cannot be immediately allocated to
it, then all resources currently being held are released.
 Preempted resources are added to the list of resources for
which the process is waiting.
 Process will be restarted only when it can regain its old
resources, as well as the new ones that it is requesting.

 Circular Wait – impose a total ordering of all resource


types, and require that each process requests
resources in an increasing order of enumeration.
Operating System Concepts
Requires that the system has some additional a priori information
available.
 Simplest and most useful model requires that
each process declare the maximum number of
resources of each type that it may need.
 The deadlock-avoidance algorithm
dynamically examines the resource-
allocation state to ensure that there can
never be a circular-wait condition.
 Resource-allocation state is defined by the
number of available and allocated resources,
and the maximum demands of the processes.
Operating System Concepts
 When a process requests an available resource, system must
decide if immediate allocation leaves the system in a safe state.

 System is in safe state if there exists a safe sequence of all


processes.

 Sequence <P1, P2, …, Pn> is safe if for each Pi , the resources


that Pi can still request can be satisfied by currently available
resources + resources held by all the Pj , with j<I.
 If Pi resource needs are not immediately available, then Pi can wait until
all Pj have finished.
 When Pj is finished, Pi can obtain needed resources, execute, return
allocated resources, and terminate.
 When Pi terminates, Pi+1 can obtain its needed resources, and so on.

Operating System Concepts


 If a system is in safe state  no deadlocks.

 If a system is in unsafe state  possibility of


deadlock.

 Avoidance  ensure that a system will never


enter an unsafe state.

Operating System Concepts


Operating System Concepts
 Claim edge Pi  Rj indicated that process Pj may
request resource Rj; represented by a dashed line.

 Claim edge converts to request edge when a process


requests a resource.

 When a resource is released by a process,


assignment edge reconverts to a claim edge.

 Resources must be claimed a priori in the system.

Operating System Concepts


 Allow system to enter deadlock state

 Detection algorithm

 Recovery scheme

Operating System Concepts


 Maintain wait-for graph
 Nodes are processes.
 Pi  Pj if Pi is waiting for Pj.

 Periodically invoke an algorithm that


searches for a cycle in the graph.

 An algorithm to detect a cycle in a graph


requires an order of n2 operations, where n is
the number of vertices in the graph.
Resource-Allocation Graph Corresponding wait-for graph

Operating System Concepts


 Abort all deadlocked processes.

 Abort one process at a time until the deadlock cycle


is eliminated.

 In which order should we choose to abort?


 Priority of the process.
 How long process has computed, and how much longer to
completion.
 Resources the process has used.
 Resources process needs to complete.
 How many processes will need to be terminated.
 Is process interactive or batch?
 Selecting a victim – minimize cost.

 Rollback – return to some safe state, restart


process for that state.

 Starvation – same process may always be


picked as victim, include number of rollback
in cost factor.

Operating System Concepts

You might also like