Last Minute Notes - Operating Systems: Types of Operating System (OS)
Last Minute Notes - Operating Systems: Types of Operating System (OS)
Last Minute Notes - Operating Systems: Types of Operating System (OS)
See Last Minute Notes for all subjects all subjects here.
Operating Systems: It is the interface between the user and the computer hardware.
1. Batch OS – A set of similar jobs are stored in the main memory for execution. A job gets
assigned to the CPU, only when the execution of the previous job completes.
2. Multiprogramming OS – The main memory consists of jobs waiting for CPU time. The OS
selects one of the processes and assigns it to the CPU. Whenever the executing process
needs to wait for any other operation (like I/O), the OS selects another process from the job
queue and assigns it to the CPU. This way, the CPU is never kept idle and the user gets the
flavor of getting multiple tasks done at once.
4. Time Sharing OS – Time-sharing systems require interaction with the user to instruct the OS
to perform various tasks. The OS responds with an output. The instructions are usually given
through an input device like the keyboard.
5. Real Time OS – Real-Time OS are usually built for dedicated systems to accomplish a specific
set of tasks within deadlines.
Threads:
A thread is a lightweight process and forms the basic unit of CPU utilization. A process can perform
more than one task at the same time by including multiple threads.
A thread has its own program counter, register set, and stack
A thread shares resources with other threads of the same process the code section, the data
section, files and signals.
A new thread, or a child process of a given process, can be introduced by using the fork() system call.
A process with n fork() system calls generates 2n – 1 child processes.
There are two types of threads:
User threads
Kernel threads
User threads are implemented by users. kernel threads are implemented by OS.
OS doesn’t recognize user level threads. Kernel threads are recognized by OS.
If one user level thread performs blocking If one kernel thread performs blocking operation
operation then entire process will be blocked. then another thread can continue execution.
Process:
A process is a program under execution. The value of program counter (PC) indicates the address of
the next instruction of the process being executed. Each process is represented by a Process Control
Block (PCB).
1. Arrival Time – Time at which the process arrives in the ready queue.
4. Turn Around Time – Time Difference between completion time and arrival time.
5. Waiting Time (WT) – Time Difference between turn around time and burst time.
Max throughput (Number of processes that complete their execution per time unit)
Min waiting time (Time for which a process waits in ready queue)
1. First Come First Serve (FCFS) : Simplest scheduling algorithm that schedules according to
arrival times of processes.
2. Shortest Job First (SJF): Process which have the shortest burst time are scheduled first.
3. Shortest Remaining Time First (SRTF): It is preemptive mode of SJF algorithm in which jobs
are scheduled according to the shortest remaining time.
4. Round Robin (RR) Scheduling: Each process is assigned a fixed time, in cyclic way.
5. Priority Based scheduling (Non Preemptive): In this scheduling, processes are scheduled
according to their priorities, i.e., highest priority process is schedule first. If priorities of two
processes match, then scheduling is according to the arrival time.
6. Highest Response Ratio Next (HRRN): In this scheduling, processes with highest response
ratio is scheduled. This algorithm avoids starvation.
7. Multilevel Queue Scheduling (MLQ): According to the priority of process, processes are
placed in the different queues. Generally high priority process are placed in the top level
queue. Only after completion of processes from top level queue, lower level queued
processes are scheduled.
8. Multi level Feedback Queue (MLFQ) Scheduling: It allows the process to move in between
queues. The idea is to separate processes according to the characteristics of their CPU
bursts. If a process uses too much CPU time, it is moved to a lower-priority queue.
1. FCFS can cause long waiting times, especially when the first job takes too much CPU time.
2. Both SJF and Shortest Remaining time first algorithms may cause starvation. Consider a
situation when a long process is there in the ready queue and shorter processes keep
coming.
3. If time quantum for Round Robin scheduling is very large, then it behaves same as FCFS
scheduling.
4. SJF is optimal in terms of average waiting time for a given set of processes. SJF gives
minimum average waiting time, but problems with SJF is how to know/predict the time of
next job.
1. Critical Section – The portion of the code in the program where shared variables are
accessed and/or updated.
2. Remainder Section – The remaining portion of the program excluding the Critical Section.
3. Race around Condition – The final output of the code depends on the order in which the
variables are accessed. This is termed as the race around condition.
A solution for the critical section problem must satisfy the following three conditions:
1. Mutual Exclusion – If a process Pi is executing in its critical section, then no other process is
allowed to enter into the critical section.
2. Progress – If no process is executing in the critical section, then the decision of a process to
enter a critical section cannot be made by any other process that is executing in its
remainder section. The selection of the process cannot be postponed indefinitely.
3. Bounded Waiting – There exists a bound on the number of times other processes can enter
into the critical section after a process has made request to access the critical section and
before the requested is granted.
Synchronization Tools:
A Semaphore is an integer variable that is accessed only through two atomic operations, wait () and
signal (). An atomic operation is executed in a single CPU time slice without any pre-emption.
Semaphores are of two types:
1. Counting Semaphore – A counting semaphore is an integer variable whose value can range
over an unrestricted domain.
2. Mutex – A mutex provides mutual exclusion, either producer or consumer can have the key
(mutex) and proceed with their work. As long as the buffer is filled by producer, the
consumer needs to wait, and vice versa.
At any point of time, only one thread can work with the entire buffer. The concept can be
generalized using semaphore.
Misconception:
There is an ambiguity between binary semaphore and mutex. We might have come across that a
mutex is binary semaphore. But they are not! The purpose of mutex and semaphore are different.
May be, due to similarity in their implementation a mutex would be referred as binary semaphore.
Deadlock:
A situation where a set of processes are blocked because each process is holding a resource and
waiting for another resource acquired by some other process. Deadlock can arise if following four
conditions hold simultaneously (Necessary Conditions):
1. Mutual Exclusion – One or more than one resource are non-sharable (Only one process can
use at a time).
2. Hold and Wait – A process is holding at least one resource and waiting for resources.
3. No Preemption – A resource cannot be taken from a process unless the process releases the
resource.
4. Circular Wait – A set of processes are waiting for each other in circular form.
Methods for handling deadlock: There are three ways to handle deadlock
1. Deadlock prevention or avoidance: The idea is to not let the system into deadlock state.
2. Deadlock detection and recovery : Let deadlock occur, then do preemption to handle it
once occurred.
3. Ignore the problem all together – : If deadlock is very rare, then let it happen and reboot
the system. This is the approach that both Windows and UNIX take.
Banker’s Algorithm:
This algorithm handles multiple instances of the same resource.
Memory Management:
These techniques allow the memory to be shared among multiple processes.
Overlays – The memory should contain only those instructions and data that are required at
a given time.
Swapping – In multiprogramming, the instructions that have used the time slice are
swapped out from the memory.
2. Best Fit – The arriving process is allotted the hole of memory in which it fits the best by
leaving the minimum memory empty.
3. Worst Fit – The arriving process is allotted the hole of memory in which it leaves the
maximum gap.
Note:
Best fit does not necessarily give the best results for memory allocation.
The cause of external fragmentation is the condition in Fixed partitioning and Variable
partitioning saying that entire process should be allocated in a contiguous memory
location.Therefore Paging is used.
1. Paging –
The physical memory is divided into equal sized frames. The main memory is divided into
fixed size pages. The size of a physical memory frame is equal to the size of a virtual memory
frame.
2. Segmentation –
Segmentation is implemented to give users view of memory. The logical address space is a
collection of segments. Segmentation can be implemented with or without the use of
paging.
Page Fault:
A page fault is a type of interrupt, raised by the hardware when a running program accesses a
memory page that is mapped into the virtual address space, but not loaded in physical memory.
For example, consider page reference string 1, 3, 0, 3, 5, 6 and 3 page slots. Initially, all slots are
empty, so when 1, 3, 0 came they are allocated to the empty slots —> 3 Page Faults. When 3 comes,
it is already in memory so —> 0 Page Faults. Then 5 comes, it is not available in memory so it
replaces the oldest page slot i.e 1. —> 1 Page Fault. Finally, 6 comes, it is also not available in
memory so it replaces the oldest page slot i.e 3 —> 1 Page Fault.
Belady’s anomaly:
Belady’s anomaly proves that it is possible to have more page faults when increasing the number of
page frames while using the First in First Out (FIFO) page replacement algorithm. For example, if we
consider reference string 3 2 1 0 3 2 4 3 2 1 0 4 and 3 slots, we get 9 total
page faults, but if we increase slots to 4, we get 10 page faults.
Optimal page replacement is perfect, but not possible in practice as an operating system cannot
know future requests. The use of Optimal Page replacement is to set up a benchmark so that other
replacement algorithms can be analyzed against it.
Let say the page reference string 7 0 1 2 0 3 0 4 2 3 0 3 2 . Initially, we have 4-page slots empty.
Initially, all slots are empty, so when 7 0 1 2 are allocated to the empty slots —> 4 Page faults. 0 is
already their so —> 0 Page fault. When 3 came it will take the place of 7 because it is least recently
used —> 1 Page fault. 0 is already in memory so —> 0 Page fault. 4 will takes place of 1 —> 1 Page
Fault. Now for the further page reference string —> 0 Page fault because they are already available
in the memory.
File System: A file is a collection of related information that is recorded on secondary storage. Or file
is a collection of logically related entities.
File Directories: Collection of files is a file directory. The directory contains information about the
files, including attributes, location and ownership. Much of this information, especially that is
concerned with storage, is managed by the operating system.
1. SINGLE-LEVEL DIRECTORY: In this a single directory is maintained for all the users
2. TWO-LEVEL DIRECTORY: Due to two levels there is a path name for every file to
locate that file.
Disk Scheduling:
Disk scheduling is done by operating systems to schedule I/O requests arriving for disk. Disk
scheduling is also known as I/O scheduling.
7. Seek Time: Seek time is the time taken to locate the disk arm to a specified track
where the data is to be read or write.
8. Rotational Latency: Rotational Latency is the time taken by the desired sector of
disk to rotate into a position so that it can access the read/write heads.
9. Transfer Time: Transfer time is the time to transfer the data. It depends on the
rotating speed of the disk and number of bytes to be transferred.
10. Disk Access Time: Seek Time + Rotational Latency + Transfer Time
11. Disk Response Time: Response Time is the average of time spent by a request
waiting to perform its I/O operation. Average Response time is the response time of
the all requests.
12. FCFS: FCFS is the simplest of all the Disk Scheduling Algorithms. In FCFS, the requests
are addressed in the order they arrive in the disk queue.
13. SSTF: In SSTF (Shortest Seek Time First), requests having shortest seek time are
executed first. So, the seek time of every request is calculated in advance in a queue
and then they are scheduled according to their calculated seek time. As a result, the
request near the disk arm will get executed first.
14. SCAN: In SCAN algorithm the disk arm moves into a particular direction and services
the requests coming in its path and after reaching the end of the disk, it reverses its
direction and again services the request arriving in its path. So, this algorithm works
like an elevator and hence also known as elevator algorithm.
15. CSCAN: In SCAN algorithm, the disk arm again scans the path that has been scanned,
after reversing its direction. So, it may be possible that too many requests are
waiting at the other end or there may be zero or few requests pending at the
scanned area.
16. LOOK: It is similar to the SCAN disk scheduling algorithm except for the difference
that the disk arm in spite of going to the end of the disk goes only to the last request
to be serviced in front of the head and then reverses its direction from there only.
Thus it prevents the extra delay which occurred due to unnecessary traversal to the
end of the disk.
17. CLOOK: As LOOK is similar to SCAN algorithm, in a similar way, CLOOK is similar to
CSCAN disk scheduling algorithm. In CLOOK, the disk arm in spite of going to the end
goes only to the last request to be serviced in front of the head and then from there
goes to the other end’s last request. Thus, it also prevents the extra delay which
occurred due to unnecessary traversal to the end of the disk.