CS252: Systems Programming Ninghui Li Based on Slides by Prof. Gustavo Rodriguez-Rivera and Chapters 7,8 of OSTEP Topic 20: Processes Scheduling.

Slides:



Advertisements
Similar presentations
CPU Scheduling Questions answered in this lecture: What is scheduling vs. allocation? What is preemptive vs. non-preemptive scheduling? What are FCFS,
Advertisements

CPU Scheduling CPU Scheduler Performance metrics for CPU scheduling
Silberschatz, Galvin and Gagne  2002 Modified for CSCI 399, Royden, Operating System Concepts Operating Systems Lecture 17 Scheduling III.
Day 25 Uniprocessor scheduling. Algorithm: Selection function Selection function – which process among ready processes to select. w – time spent in system,
Chapter 3: CPU Scheduling
Operating Systems 1 K. Salah Module 2.1: CPU Scheduling Scheduling Types Scheduling Criteria Scheduling Algorithms Performance Evaluation.
CS 311 – Lecture 23 Outline Kernel – Process subsystem Process scheduling Scheduling algorithms User mode and kernel mode Lecture 231CS Operating.
Scheduling in Batch Systems
CS 3013 & CS 502 Summer 2006 Scheduling1 The art and science of allocating the CPU and other resources to processes.
1 Thursday, June 15, 2006 Confucius says: He who play in root, eventually kill tree.
What we will cover…  CPU Scheduling  Basic Concepts  Scheduling Criteria  Scheduling Algorithms  Evaluations 1-1 Lecture 4.
CS 104 Introduction to Computer Science and Graphics Problems Operating Systems (2) Process Management 10/03/2008 Yang Song (Prepared by Yang Song and.
Wk 2 – Scheduling 1 CS502 Spring 2006 Scheduling The art and science of allocating the CPU and other resources to processes.
Job scheduling Queue discipline.
Slide 6-1 Copyright © 2004 Pearson Education, Inc. Operating Systems: A Modern Perspective, Chapter 6 Threads and Scheduling 6.
1 Lecture 10: Uniprocessor Scheduling. 2 CPU Scheduling n The problem: scheduling the usage of a single processor among all the existing processes in.
1 Scheduling Algorithms FCFS First-Come, First-Served Round-robin SJF Multilevel Feedback Queues.
1Chapter 05, Fall 2008 CPU Scheduling The CPU scheduler (sometimes called the dispatcher or short-term scheduler): Selects a process from the ready queue.
Chapter 8 Multi-Level Feedback Queue Chien-Chung Shen CIS, UD
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 6: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms.
CPU Scheduling Chapter 6 Chapter 6.
Chapter 6: CPU Scheduling
Computer Architecture and Operating Systems CS 3230: Operating System Section Lecture OS-3 CPU Scheduling Department of Computer Science and Software Engineering.
Chapter 6 CPU SCHEDULING.
Number of processes OS switches context from A to B main use fork, and the child process call execvp() Can compiler do something bad by adding privileged.
1 Scheduling Processes. 2 Processes Each process has state, that includes its text and data, procedure call stack, etc. This state resides in memory.
Chapter 7 Scheduling Chien-Chung Shen CIS, UD
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 6: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms.
Scheduling. Alternating Sequence of CPU And I/O Bursts.
CPU Scheduling CSCI 444/544 Operating Systems Fall 2008.
1 Our focus  scheduling a single CPU among all the processes in the system  Key Criteria: Maximize CPU utilization Maximize throughput Minimize waiting.
Alternating Sequence of CPU And I/O Bursts. Histogram of CPU-burst Times.
CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms Thread Scheduling Multiple-Processor Scheduling Operating Systems Examples Algorithm.
CS252: Systems Programming Ninghui Li Slides by Prof. Gustavo Rodriguez-Rivera Topic 9: Processes and Scheduling.
Silberschatz, Galvin and Gagne  Operating System Concepts Chapter 6: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms.
Lecture 7: Scheduling preemptive/non-preemptive scheduler CPU bursts
Chapter 5: Process Scheduling. 5.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Basic Concepts Maximum CPU utilization can be obtained.
1 11/29/2015 Chapter 6: CPU Scheduling l Basic Concepts l Scheduling Criteria l Scheduling Algorithms l Multiple-Processor Scheduling l Real-Time Scheduling.
Cpr E 308 Spring 2005 Process Scheduling Basic Question: Which process goes next? Personal Computers –Few processes, interactive, low response time Batch.
Silberschatz and Galvin  Operating System Concepts Module 5: CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms Multiple-Processor.
1 CS.217 Operating System By Ajarn..Sutapart Sappajak,METC,MSIT Chapter 5 CPU Scheduling Slide 1 Chapter 5 CPU Scheduling.
Processor Scheduling Hank Levy. 22/4/2016 Goals for Multiprogramming In a multiprogramming system, we try to increase utilization and thruput by overlapping.
Lecture Topics: 11/15 CPU scheduling: –Scheduling goals and algorithms.
1 CPU Scheduling Basic Concepts Scheduling Criteria Scheduling Algorithms Multiple-Processor Scheduling Real-Time Scheduling.
CPU Scheduling Operating Systems CS 550. Last Time Deadlock Detection and Recovery Methods to handle deadlock – Ignore it! – Detect and Recover – Avoidance.
Operating Systems Scheduling. Scheduling Short term scheduler (CPU Scheduler) –Whenever the CPU becomes idle, a process must be selected for execution.
Chapter 4 CPU Scheduling. 2 Basic Concepts Scheduling Criteria Scheduling Algorithms Multiple-Processor Scheduling Real-Time Scheduling Algorithm Evaluation.
Lecture 4 CPU scheduling. Basic Concepts Single Process  one process at a time Maximum CPU utilization obtained with multiprogramming CPU idle :waiting.
CPU Scheduling CS Introduction to Operating Systems.
Process Scheduling. Scheduling Strategies Scheduling strategies can broadly fall into two categories  Co-operative scheduling is where the currently.
CPU scheduling.  Single Process  one process at a time  Maximum CPU utilization obtained with multiprogramming  CPU idle :waiting time is wasted 2.
1 Module 5: Scheduling CPU Scheduling Scheduling Algorithms Reading: Chapter
Basic Concepts Maximum CPU utilization obtained with multiprogramming
Lecturer 5: Process Scheduling Process Scheduling  Criteria & Objectives Types of Scheduling  Long term  Medium term  Short term CPU Scheduling Algorithms.
Chapter 7 Scheduling Chien-Chung Shen CIS/UD
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition Chapter 5: CPU Scheduling.
Chapter 5: CPU Scheduling. 5.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts Chapter 5: CPU Scheduling Basic Concepts Scheduling Criteria.
CPU Scheduling Andy Wang Operating Systems COP 4610 / CGS 5765.
CPU Scheduling Scheduling processes (or kernel-level threads) onto the cpu is one of the most important OS functions. The cpu is an expensive resource.
CPU SCHEDULING.
Chapter 5a: CPU Scheduling
Chapter 6: CPU Scheduling
Process management Information maintained by OS for process management
Chapter 6: CPU Scheduling
Chapter 5: CPU Scheduling
Operating System Concepts
Chapter 6: CPU Scheduling
CPU scheduling decisions may take place when a process:
Chapter 6: CPU Scheduling
CPU Scheduling: Basic Concepts
Presentation transcript:

CS252: Systems Programming Ninghui Li Based on Slides by Prof. Gustavo Rodriguez-Rivera and Chapters 7,8 of OSTEP Topic 20: Processes Scheduling

Process Scheduling From the user’s point of view, an OS allows running multiple processes simultaneously. In reality, the OS runs one process after another to give the illusion that multiple processes run simultaneously. For single-core computers The Process Scheduler is the OS subsystem that runs one process after the other and decides what process to run next. A Context Switch is the procedure used by the OS to switch from one process to another

Process Scheduling Steps of a Context Switch Save current running process in process table Load next ready process from process table and put registers and PC in the CPU. Context Switches may happen as a result of: A process needs to go to wait state, and therefore, another process can be scheduled. A process yields (gives up) the CPU so another process can run. Timer interrupt ( Only for Preemptive Scheduling)

Thinking About Scheduling What are the key assumptions? What metrics are important? What basic approaches have been used?

Workload Assumptions Workload: processes running in the system Initial (unrealistic assumptions) All jobs arrive at (about) the same time Once started, each jobs runs to completion The run-time of each job is known Jobs do not perform I/O

Scheduling Metrics Average turnaround time (completion time) The turnaround time for a job is the time the job completes minus the time at which the job arrives This is a performance metric There are other fairness metrics, which often conflicts with performance metrics

First Come First Serve Can perform poorly when an early job is a long- running one, e.g., three jobs Known as the convoy effect, a number of relatively- short potential consumers get queued behind a heavyweight resource consumer How to solve the problem?

Shortest Job First Solves the problem due to convoy effect Provable optimal under the assumptions General scheduling principle, can be applied to any system where the perceived turnaround time per customer (or, in our case, a job) matters (think max- 10 item checkout line in supermarket) Fairness is not as good as FCFS What if jobs don’t arrive at the same time?

Shortest Time-to-Completion First (STCF) We need to use Preemptive Scheduling A job does not always run to completion once scheduled It can be preempted to have another job run Also known as Preemptive Shortest Job First (PSJF)

A New Metric: Response Time When we jobs that are interactive, things change Response Time: Time a job first runs – Time it arrives Cannot have a job waiting until another is done Three metrics now: Turnaround time Response time Fairness

Incorporating I/O Programs without I/O is uninteresting I/O may take long time, during which time jobs/processes are blocked Time to completion can thus be defined as time to next blocking I/O operation Scheduling policies such as STCF requires predicting time to completion

Non Preemptive Scheduling In Non Preemptive Scheduling a context switch (switch from one process to another) happens only when the running process goes to a waiting state or when the process gives up the CPU voluntarily. This is a very primitive type of scheduling. It is also called cooperative scheduling. Expects all programs to “play nice”. It was used in Windows 3.1 and initial versions of MacOS. The main problem of Non Preemptive Scheduling is that a misbehaved process that loops forever may hold the CPU and prevent other processes from running.

Preemptive Scheduling In Preemptive Scheduling a context switch happens periodically (every 1/100sec or quantum time) as a result of a timer interrupt. A timer interrupt will cause a context switch, that is, the running process to go to ready state and the process that has been the longest in ready state will go to running state. Preemptive scheduling is implemented in UNIX, and Windows 95 and above.

Advantages/Disadvantages of Non Preemptive Scheduling Advantages of Non Preemptive Scheduling: More control on how the CPU is used. Simple to implement. Advantages of Preemptive scheduling: More robust, one process cannot monopolize the CPU Fairness. The OS makes sure that CPU usage is the same by all running process.

Scheduling Policies for Preemptive Scheduling Round Robin Scheduling (aka Time Slicing) Each job runs for time slice (aka scheduling quantum) Implementation of Round Robin Ready processes are in a queue. Every time that a time quantum expires, a process is dequeued from the front of the queue and put in running state The previous running process is added to the end of the queue.

Round Robin Round Robin (cont.) (T=10ms) ProcessBurst Time p124ms p23ms p33ms 310 P3P1P2 Average completion time = ( )/3=19.6ms 3 P1 10 P1 4

Quantum Length Analysis What is the impact of quantum length? Assume T=10ms. ProcessBurst Time p120ms p21ms p31ms 110 P3P1P2 Average completion time = ( )/3=15ms 1 P1 10

Quantum Length Analysis What if we choose a smaller quantum length?Assume T=1ms. ProcessBurst Time p120ms p21ms p31ms 11 P3P1P2 Average completion time = (2+3+22)/3=9ms 1 P1 T=1ms P

Quantum Length Analysis The shorter the quantum, the shorter the average completion time. Based on this we could make the quantum time very small to achieve faster response time. What is the catch? We are not considering that context switch takes time. We have to consider the context switch overhead.

Context Switch Overhead The context switch overhead is the time it takes to do a context switch as a portion of the quantum time. Xoverhd% = 100*X/T where Xoverhd% = Context Switch Overhead X = Context Switch Time T = Quantum Time. Assume X=.1ms. For T=10ms Ovhd=100*.1/10=1% For T=2ms Ovhd=100*.1/2=5% For T=.2ms Ovhd=100*.1/.2=50%

Context Switch Overhead Conclusions: The smaller the quantum, the faster the response time (small average completion time) but the larger the context switch overhead. The larger the quantum the smaller the context switch overhead but the larger the response (large average completion time). The standard quantum time is 1/100sec = 10ms that is a compromise between response time and context switch overhead. This may change in the future with faster processors.

CPU Burst Distribution Processes are in waiting state most of the time except for the times they need the CPU, that is usually for short periods of time. These shorts periods of time the processes need the CPU are called CPU bursts. % Distribution of CPU Bursts 10ms 90% 10% CPU burst (ms)

CPU Burst Distribution 90% of CPU bursts are smaller than 10ms. By choosing 10ms to be the quantum length, we make sure that 90% of the CPU burst run until completion without being preempted. This reduces the context switch overhead and reduces the completion time and makes the response time faster.

How to Choose the Size of a Quantum Make the quantum small enough to make the response time smaller (faster). Make the quantum large enough to have an acceptable context switch overhead. Make the quantum large enough so most CPU bursts are able to finish without being preempted.

Towards Multilevel Feedback- Queue Scheduling (MLFQ) Goals: Try to minimize both turnaround time and response time, and doing so without the ability to predict how long a job is How to predict? “Prediction is very difficult, especially if it's about the future.”--- Niels Bohr

The Multilevel Feedback-Queue Scheduling (MLFQ) Multilevel Feedback-Queue Scheduling Instead of a having a single queue of ready processes, there are multiple queues of different priorities. The scheduler will schedule the ready processes with the highest priority first. Within processes of the same priority round robin is used.

Basic Idea of MLFQ Maintains multiple queues with different priorities. Each ready process belongs to one queue Which queue a process belongs to depends on its history Processes in higher-priority queue are scheduled over those in lower-priorities ones Rule 1: If Priority(A) > Priority(B), A runs (B doesn’t). Rule 2: If Priority(A) = Priority(B), A & B run in RR.

How Are Priorities Adjusted? Rule 3: When a job enters the system, it is placed at the highest priority (the topmost queue). Rule 4a: If a job uses up an entire time slice while running, its priority is reduced (i.e., it moves down one queue). Rule 4b: If a job gives up the CPU before the time slice is up, it stays at the same priority level.

Multilevel Feedback-Queue Scheduling P1P6P7 P2P5P8 Priority 10 9 P3P4P98 P10P11P127 Small CPU Burst. Increase priority Large CPU Burst. Decrease priority What are some problems?

Three Problems Some processes may be starved. Long-running jobs never scheduled Process behavior may change A process starting with CPU intensive may become I/O intensive later Possible to game the scheduler Just gives up CPU before quantum is up

Solutions: The priority boost: Rule 5: After some time period S, move all the jobs in the system to the topmost queue. Solves the first two problems Choosing S Better Accounting: Rule 4: Once a job uses up its time allotment at a given level (regardless of how many times it has given up the CPU), its priority is reduced (i.e., it moves down one queue).

Summary of MLFQ Rule 1: If Priority(A) > Priority(B), A runs (B doesn’t). Rule 2: If Priority(A) = Priority(B), A & B run in RR. Rule 3: When a job enters the system, it is placed at the highest priority (the topmost queue). Rule 4: Once a job uses up its time allotment at a given level (regardless of how many times it has given up the CPU), its priority is reduced (i.e., it moves down one queue). Rule 5: After some time period S, move all the jobs in the system to the topmost queue.

More Scheduling Theory MLFQ used in BSD Unix, Solaris, Windows NT and later systems Sometimes with variants Linux currently uses Completely Fair Scheduler (CFS) as the default scheduler Tries to ensure that each process receives a fair amount of CPU, with the fair share value depending on priority, when the process starts, how much CPU time it has used.

Scheduler-Related System Calls in Linux nice() Lower a process’ static priority getpriority()/setpriority() Change priorities of a process group sched get_scheduler()/sched_setscheduler() Set scheduling policy and parameters. (Many more starting with sched ; use man -k to learn their names.)

Clicker Question 1 (IPC) When several processes that are created independently (not by the same parent) want to communicate (sending and receiving data), the best way to do is via: A. Signals B. PIPE C. FIFO D. Shared anonymous memory mapping E. POSIX shared memory without file backing

Clicker Question 2 (Scheduling) Given two jobs that need to run 10ms, and 50ms each (with the 10ms one arriving first), assuming Round Robin is used with quantum of 3ms, what is the average completion time (ignoring context switch overhead)? A. 25 ms B. 30 ms C ms D ms E. None of the above

Clicker Question 3 (Scheduling) What are weaknesses of Round Robin (each process taking turns to run either to blocking I/O or when time slice is used up)? A. It is unfair to I/O-bound processes B. It is unfair to CPU-bound processes C. The average completion time can be significantly improved D. Both A and C E. Both B and C

Clicker Question 4 (For fun) You have 25 horses, you want to find the 3 fastest horses. In one race you can race 5 horses, and you don't have a timer. What is the minimal number of races needed to find the 3 fastest horses among the 25. Assume that the horses all race consistently, that is, if one horse is faster than another, it will always beat another in each race. A. 5B. 6C. 7D. 8E. 9 or higher

Review Questions What is a context switch? What may cause a context switch? What are non-preemptive scheduling and preemptive scheduling? What are the pros & cons of each? Which one is used in modern OS? How does the round robin scheduling work?

Review Questions How to compute response time and overhead for a given quantum length. How response time and overhead are affected by quantum length? What are factors for choosing quantum length? Response time, overhead, CPU burst distribution What is Multilevel Feedback-Queue Scheduling? Key idea: use multiple priority queues, reward processes with smaller CPU burst