

# Operating system and its functions

## functions

- 1) Resource management
- 2) Process Management (CPU Schedulig)
- 3) Storage mgmt  $\rightarrow$  Hard disk file management
- 4) Memory management (RAM)



Operating system  $\rightarrow$  System call



## Types of operating system

- 1) Batch
- 2) multiprogrammed
- 3) Multitasking
- 4) Real time os
- 5) Distributed os
- 6) clustered
- 7) Embedded

Punch cards were used  
for similar type of work / Batch  
used in 1960  
feature by IBM



## 2) multiprogrammed os - Non preemptive

all tasks are loaded in Ram once and executed  
one by one fully until that program wanted to be  
interrupted / need I/O

- OS can't interrupt program

## Multitasking / Time sharing OS → Preemptive

it is a bit similar to the multiprogrammed only diff is it will not execute a program fully it will execute all programs sequentially for a specific duration and gets executed this cycle until all programs this os can preempt itself unlike multiprogrammed we get responsiveness through this multitasking

## Real time OS

→ Hard  
soft

delays are not expected/accepted  
can cause major loss

delays are accepted  
minor delays long cause much  
faulty

eg missile system

eg YouTube live stream

## Distributed (Environment)

geographically separated



in case 1 system fails  
other system will handle the work of first one

## clustered

- multiple machines are collected in system to make it more powerful, more efficient
- connected in LAN or by any other way
- concept of super computer

processing power.

availability

computing power

every thing increases

## Embedded

- are programmed to do fixed task
- we can't change its functionality

e.g. washing machine

Microcontroller



Long term scheduler - it is responsible for bringing more processes in ready state from secondary memory

Short Term  
Scheduler

- responsible for picking a process from ready queue and giving it to CPU for execution

Medium term  
Scheduler

- is responsible for suspending state due to queue overflow

### Process

- 1) System calls involved in
- 2) OS tasks diff process differently
- 3) diff process have diff copies of data, files, codes
- 4) context switching is slower
- 5) Blocking a process will not block others
- 6) Independent



### Threads

(User level)

There is no system call involved

- 1) All user threads treated as single task for OS
- 2) threads share same copy of code
- 3) context switching is faster
- 4) blocking a thread will block entire process

Interdependent



## User level thread

- User level threads are managed by user level library
- User level threads are typically fast
- context switching is faster
- If one user level thread program blocking operation then entire process gets blocked

## Kernel level threads

- Kernel level threads are managed by OS system calls
- Kernel level threads are slower than user level
- context switching is slower
- If one kernel level thread ~~program~~ blocked, no effect on others

## Starvation

Higher priority long process keeps on executing which results in non execution of process of with low priority



## Synchronization

### Mech.

#### Priority

? h conditions

1) mutual exclusion →

Inside critical section only 1 program is allowed at a time

2) Progress →

one program not entering in critical sections because other program is already in critical section

3) Bounded wait →

infinite time and another can use only critical condition

4) No assumption needed to hard worse and speed

must be unimposed

## Semaphores

Semaphores is an integer variable which is used in mutual exclusive manner by various concurrent cooperative process in order to achieve synchronization.



## Dead lock

If 2 or more processes are waiting on happening of some event, which never happens, then we say these processes are involved in deadlock then that state is called Deadlock.



Condition for deadlock (necessary)

- 1) mutual exclusion
- 2) No preemption
- 3) Hold and wait
- 4) circular wait

## Resource Allocation Graph (RAG)



Single instance



Circular wait

deadlock

Multiple instances



no deadlock

If RAG has circular wait (cycle) (single instance resource)  
then will always be deadlock

Multi instance RAG



|       | All<br>$R_1, R_2$ | Req<br>$R_1, R_2$ |
|-------|-------------------|-------------------|
| $P_1$ | 1 0               | 0 1               |
| $P_2$ | 0 1               | 1 0               |
| $P_3$ | 0 1               | 0 0               |

curr availability  $(0, 0)$

$$\begin{matrix} & R_1 & R_2 \\ P_3 & \begin{pmatrix} 0, 1 \\ 0, 1 \end{pmatrix} & \end{matrix}$$

$$P_1 \rightarrow \begin{pmatrix} 0, 1 \\ 1, 0 \end{pmatrix}$$

$$P_2 \rightarrow \begin{pmatrix} 1, 1 \\ 1, 1 \end{pmatrix}$$



|       | All<br>$R_1, R_2, R_3$ | $R_{12}$<br>$R_1, R_2, P_3$ |
|-------|------------------------|-----------------------------|
| $P_0$ | 1 0 1                  | 0 1 1                       |
| $P_1$ | 1 1 0                  | 1 0 0                       |
| $P_2$ | 0 1 0                  | 0 0 1                       |
| $P_3$ | 0 1 0                  | 1 2 0                       |

  

|       | All<br>$R_1, R_2, R_3$ | $R_{12}$<br>$R_1, R_2, P_1$ |
|-------|------------------------|-----------------------------|
| $P_0$ | 0 0 1                  | 0 1 1                       |
| $P_1$ | 0 1 1                  | 1 1 2                       |
| $P_2$ | 1 1 2                  | 2 2 2                       |

## Methods to handle deadlocks

- (1) Deadlock Ignorance (Gottschalk method)
- (2) Deadlock Prevention ✓
- 3) Deadlock Avoidance (Banker's Algo)
- 4) Deadlock Detection & Recovery

P  
Prevention → means decision such a system which violate atleast one of 4 necessary condition of deadlock and ensure independency from deadlock

Avoidance :-

System maintains a set of data using which it takes decision whether to enter in safe state or not, to be a new atleast

Detection & recovery → Here we wait until deadlock occurs and once we detect it we recover from

Ignorance → We ignore the problem as if it does not exist

## Prevention

X ~~deadlock~~ mutual exclusion → make resources sharable to remove/fake this condition

X No preemption → preempt one of the process to make this condition false  
(Time quantum can be used)  
When we preempt the process it releases all the resources which it is holding and other processes can be used by

X Hold & wait → give all the resources in ready state to avoid this condition

X circled wait → give numbering to resources and the process can only request for resource in increasing/decreasing order, random requests can't be made

# Memory Management

## Techniques



### Fixed partition (static)

- No of partitions are fixed
- Size of each partition may or maynot same
- Contiguous allocation so

spilling is not allowed



- (1) Internal fragmentation: leftover memory gets wasted due to diff-size difference in size of our Ram partition & program

- (2) Limit in process size
- (3) limitation on degree of multiprogramming
- (4) External fragmentation: this happens when we have sufficient total memory to execute the program but it is not contiguous, it is in chunks

## Variable partition (Dynamic partition)

- no internal fragmentation
  - no limitation of size of process
  - no limitation on no. of processes
  - Extend fragmentation - collectively total space for required for execution of program is available but its not contiguous
  - compaction can be used to remove extend fragmentation
  - Allocation & deallocation is complex
- } disadvantage



Division contiguous Mem Allocation



Main memory  
RAM

Process

We divide process in  
secondary memory itself

Page size = frame size

Page table



|   |    |    |
|---|----|----|
| 0 | 1  | 1  |
| 1 | 2  | 3  |
| 2 | 4  | 5  |
| 3 | 6  | 7  |
| 4 | 8  | 9  |
| 5 | 10 | 11 |
| 6 | 12 | 13 |
| 7 | 14 | 15 |



## Segmentation

- In paging all pages have equal size
- in segmentation we have no fixed size  
size is decided by the code.



## Virtual memory

non preemptive (1 complete job complete)

preemptive process needs in multiple ~~parts~~

Page No.

### FIFO

completion time

$(CT - AT)$   
turn around time

| P.No | AT | BT | CT | TUT | WT | <del>ET</del> | TOT-BT |
|------|----|----|----|-----|----|---------------|--------|
| 1    | 0  | 4  | 4  | 4   | 0  | 0             | 4      |
| 2    | 1  | 3  | 7  | 6   | 3  |               |        |
| 3    | 2  | 1  | 8  | 6   | 5  |               |        |
| 4    | 3  | 2  | 10 | 7   | 5  |               |        |
| 5    | 4  | 5  | 15 | 11  | 6  |               |        |

$[P_1 \mid P_2 \mid P_3 \mid P_4 \mid P_5]$

0 1 2 3 4 15 TUT = WT + BT

TUT = CT - AT

### SJF

| P.No | AT | BT | CT | TUT | WT |
|------|----|----|----|-----|----|
| 01   | 1  | 7  | 8  | 7   | 0  |
| 02   | 2  | 5  | 10 | 8   | 9  |
| 03   | 3  | 1  | 9  | 6   | 5  |
| 04   | 4  | 2  | 10 | 6   | 5  |
| 05   | 5  | 6  | 16 | 11  | 11 |

$[P_1 \mid P_4 \mid P_3 \mid P_2 \mid P_5]$

8 9 11 16 21

Round Robin

Shottat zoning time dist SRTf

| Pno | AT | BT   | CT | TUT | bt |
|-----|----|------|----|-----|----|
| 1   | 0  | 76   | 19 | 19  | 12 |
| 2   | 1  | 84   | 13 | 12  | 7  |
| 3   | 2  | 3x17 | 6  | 4   | 3  |
| 4   | 3  | x 2  | 4  | 1   | 0  |
| 5   | 4  | 2x17 | 9  | 5   | 3  |
| 6   | 5  | 14   | 70 | 2   | 1  |



Round robin TA = 2

| PNO | AT | BT   | CT | TUT | bt |
|-----|----|------|----|-----|----|
| 1   | 0  | 76   | 8  | 8   | 4  |
| 2   | 1  | 84   | 18 | 17  | 12 |
| 3   | 2  | 3x17 | 6  | 4   | 2  |
| 4   | 3  | x 2  | 9  | 6   | 5  |
| 5   | 4  | 2x17 | 21 | 17  | 11 |
| 6   | 5  | 14   | 15 | 13  | 10 |



|       |       |       |       |       |       |       |       |       |          |          |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|----------|
| $p_1$ | $p_2$ | $p_3$ | $p_4$ | $p_5$ | $p_6$ | $p_7$ | $p_8$ | $p_9$ | $p_{10}$ | $p_{11}$ |
| 2     | 3     | 6     | 8     | 9     | 11    | 13    | 15    | 17    | 18       | 19       |

$$\text{Tot} = A = 10$$

$$B=5$$

$$C=7$$

### Banks Algorithm

| Process        | Allocation |       | m-x need | Available | Remaining |
|----------------|------------|-------|----------|-----------|-----------|
|                | A          | B     |          |           |           |
| P <sub>1</sub> | 0 1 0      | 1 0 0 | 7 5 3    | 3 3 2     | 2 4 3     |
| P <sub>2</sub> | 2 0 0      | 0 0 0 | 3 2 2    | 5 3 2     | 2 2 2     |
| P <sub>3</sub> | 3 0 2      | 0 0 2 | 9 0 2    | 7 4 3     | 6 0 0     |
| P <sub>4</sub> | 2 1 1      | 1 1 1 | 4 2 2    | 7 4 5     | 2 1 1     |
| P <sub>5</sub> | 0 0 2      | 0 0 2 | 5 3 3    | 7 5 5     | 5 3 1     |
|                | 7 2 5      |       |          | 10 9 7    | 7 3       |

$$\text{Available} = \text{Tot} - \text{Allocated}$$

$$= 10 5 7 - 7 2 5$$

$$P_1 \rightarrow P_2 \rightarrow P_3 \rightarrow P_4 - P_5$$

| Process        | Allocation |       | m-x   | Available | Remaining |
|----------------|------------|-------|-------|-----------|-----------|
|                | F          | G     |       |           |           |
| P <sub>0</sub> | 1 0 1      | 0 1 0 | 4 3 1 | 3 3 0     | 3 3 0     |
| P <sub>1</sub> | 1 1 2      | 1 2 1 | 2 1 9 | 4 3 1     | 4 0 2     |
| P <sub>2</sub> | 1 0 3      | 0 3 0 | 1 5 3 | 5 2 3     | 0 3 0     |
| P <sub>3</sub> | 2 0 0      | 0 0 2 | 6 2 1 | 6 4 6     | 3 4 1     |

$$P_0 \rightarrow P_1 \rightarrow P_2 \rightarrow P_3 - P_0$$

$$P_0 - P_1 - P_2 \rightarrow P_3$$

23

6, 7, 0, 2, 1, 2, 3, 4, 2, 1, 5, 6, 2, 1, 2, 3, 7, 6, 3, 2, 1, 2, 3, 6

FIFO

| 6  | 7  | 0 | 2 | 1 | 2   | 3 | 4 | 2 | 1 | 5 | 6 | 2 | 1   | 2 | 3 | 2 |
|----|----|---|---|---|-----|---|---|---|---|---|---|---|-----|---|---|---|
| 6  | 6. | X | 2 | 2 | 2   | 2 | 4 | 4 | 4 | 5 | 5 | X | 1   | 1 | 1 | X |
| 7. | 2  | X | 1 | 1 | 1   | X | 2 | 2 | X | 6 | 6 | 6 | X   | 3 | 3 |   |
| 0  | 0  | 0 | X | 3 | 3   | X | 1 | 1 | X | 2 | 2 | X | X   | 7 |   |   |
| X  | X  | X | X | X | Hit | X | X | X | X | X | X | X | Hit | X | X | X |

| 6 | 3   | 2 | 1 | 2   | 3 | 6 |
|---|-----|---|---|-----|---|---|
| 6 | 6   | 6 | 6 | X   | 3 | 3 |
| 3 | X   | 2 | 2 | 2   | X | 6 |
| 2 | 7   | X | 1 | 1   | 1 | 1 |
| X | Hit | X | X | Hit | X | X |

$$HIT = 4$$

$$fault = 20$$

LRU

| 6 | 7 | 0 | 2 | 1 | 2   | 3 | 4 | 2   | 1 | 5 | 6 | 2 | 1   | 2 | 3 | 2 |
|---|---|---|---|---|-----|---|---|-----|---|---|---|---|-----|---|---|---|
| 6 | 6 | 6 | 2 | 2 | 2   | 2 | 2 | 2   | 2 | 6 | 6 | 6 | 6   | 3 | 3 |   |
| 7 | 7 | 7 | 1 | 1 | 1   | 4 | 4 | 4   | 5 | 5 | 5 | 5 | 1   | 1 | 1 |   |
| 0 | 0 | 0 | 0 | 3 | 3   | 3 | 1 | 1   | 1 | 2 | 2 | 2 | 2   | 2 | 2 |   |
| X | X | Y | X | X | Hit | X | X | Hit | X | X | X | X | Hit | X | X | X |

$$HIT = 6$$

$$fault = 18$$

| 6 | 3   | 2 | 1 | 2   | 3   | 6 |
|---|-----|---|---|-----|-----|---|
| 3 | 3   | 3 | 3 | 3   | 3   | 3 |
| 2 | 7   | 2 | 2 | 2   | 2   | 2 |
| 6 | 6   | 6 | 1 | 1   | 1   | 6 |
| X | Hit | X | X | Hit | Hit | X |

## Optimal page replacement

|   |   |   |   |   |     |   |   |     |     |   |   |     |     |   |   |   |
|---|---|---|---|---|-----|---|---|-----|-----|---|---|-----|-----|---|---|---|
| 6 | 7 | 0 | 2 | 1 | 2   | 3 | 4 | 2   | 1   | 5 | 6 | 2   | 1   | 2 | 3 | 7 |
| 6 | 6 | 6 | 6 | 6 | 3   | 4 | 4 | 4   | 5   | 6 | 6 | 6   | 6   | 6 | 6 | 6 |
| 7 | 7 | 7 | 1 | 1 | 1   | 1 | 1 | 1   | 1   | 1 | 1 | 1   | 1   | 3 | 3 |   |
| 0 | 2 | 2 | 2 | 2 | 2   | 2 | 2 | 2   | 2   | 2 | 2 | 2   | 2   | 2 | 2 | 7 |
| X | X | X | X | X | hit | X | X | hit | hit | X | X | hit | hit | X | X | X |

|     |     |   |   |     |     |   |  |  |  |  |  |  |  |  |  |  |
|-----|-----|---|---|-----|-----|---|--|--|--|--|--|--|--|--|--|--|
| 6   | 3   | 2 | 1 | 2   | 3   | 6 |  |  |  |  |  |  |  |  |  |  |
| 6   | 6   | 6 | 1 | 1   | 1   | 6 |  |  |  |  |  |  |  |  |  |  |
| 3   | 3   | 3 | 3 | 3   | 3   | 3 |  |  |  |  |  |  |  |  |  |  |
| 7   | 7   | 2 | 2 | 2   | 2   | 2 |  |  |  |  |  |  |  |  |  |  |
| hit | hit | X | X | hit | hit | X |  |  |  |  |  |  |  |  |  |  |

$$\text{hit} = 10$$

$$\text{fault} = \underline{14}$$

most efficient is optimal page replacement

125

143

Q4 FCFS  $\int 86$ , 1670, 913 1774 928 1509 1622 1750 (30)



dist

$$\begin{aligned}
 & (143 - 86) + (1670 - 86) + (1470 - 913) + (1774 - 913) + (1774 - 948) \\
 & + (1509 - 948) + (1509 - 1022) + 1750 - 1022 + (1750 - 130)
 \end{aligned}$$

$$= \underline{\underline{7081}}$$

SCTF



$$\begin{aligned}
 \text{dist} &= (143 - 86) + 1774 - 86 \Rightarrow 143 - 172 + 1774 - 29 \\
 &\quad = 1745
 \end{aligned}$$

c) SCAN



$$\begin{aligned} \text{dist} &= 4599 - 143 + 4599 - 86 \\ &= 9269 \end{aligned}$$

d) LOOK



$$\begin{aligned} \text{dist} &= 1774 - 143 + 1774 - 86 \\ &= \underline{\underline{3319}} \end{aligned}$$

e) CSCAN



$$\begin{aligned}\text{Toll dist} &= 4999 - 143 + 4999 + 130 \\ &\sim 9998 - 13 \\ &= 9985\end{aligned}$$

f) COOK



$$\begin{aligned}\text{dist} &= 1771 - 143 + 1771 - 60 + 80 \cdot 130 - 80 \\ &\sim 3363\end{aligned}$$

Qs(1)

## Thrashing

It is an issue cause when virtual memory is in use it occurs when virtual memory of computer is rapidly exchanging data for data on hard disk to exclusion of most applications - level processing

→ If in page fault and swapping happening very frequently at higher rate then operating system has to spend more time to swap these pages.

This state is called thrashing



Q1

(a)

→ Basic

→ Address spaces

→ Visibility

Generation

Access

Logical Addresses

generated by CPU

Physical Addresses

location in memory unit

Logical Address space is set  
to of all generated  
logical addresses by CPU  
in sequence to a program

User can view logical  
addresses of program

Physical address is set of all  
physical addresses mapped to  
corresponding logical addresses

User can never view physical  
addresses of program

generated by CPU

computed by MMU

The user can use  
logical addresses to access  
the physical addresses

The user indirectly access  
Physical addresses but not  
directly

b)

First fit

2121K → 500 K memory

4171K → 600 K memory

112 K → 288 K (500 - 2121K) memory

426 K - needs to wait no empty space

Best fit

212 K → 300 K memory  
417 K → 500 K memory  
112 K → 200 K memory  
426 K → 600 K memory

Worst fit

212 K = 600 K memory  
417 K = 500 K memory  
112 K = 388 K ( $600\text{K} - 212\text{K}$ ) memory  
426 K needs to wait

most efficient is Best fit

Promptive

can be interrupted

can be paused

non promptive

can not be interrupted

has to complete in 2go