

# **OPERATING SYSTEMS**

**Handwritten Notes**

**VIVEKANAND VERNEKAR**

**GateWallah Parakram C 2024**  
**(Hinglish Weekday)**

**Other Notes Uploaded Below**

**<https://t.me/pwgatenotes>**

Introduction

What is an Operating System?

- \* Is an interface between user and the hardware
- \* Resource manager
- \* Set of utilities to simplify the application development
- \* Set of program(s) / Software
- \* Operating System acts like a government.



1. Control Unit (C.U): It is circuitry that directs operations within a computer's processor.

- \* Timing / control signals
- \* Sequencing / execution of micro-operations.

Operations that are carried out on the data, stored in registers (CPU)



VON-NEUMANN Architecture.

2. Arithmetic Logic Unit (ALU): It is a part of CPU that carries out arithmetic and logic operations on the Operands in computer instruction words

Memory:

Primary      Secondary

also called

"Main memory"

"Auxiliary memory"

e.g.: hard disk, Pendrive etc.

e.g.: Ram, ROM,  
Cache, registers.

Primary memory

\* Volatile (not ROM)

\* faster to access

$\times 10^{-9}$  (ns)

\* Smaller size

\* more expensive

Secondary memory

\* Non volatile

\* Slower to access (ms)  $\times 10^{-3}$ .

\* Larger size.

\* less expensive

Note: as per Von Neumann Architecture, All Secondary Storage devices are part of I/O devices.

Q How are programs executed in Von Neumann Architecture?

→ The programs are executed by the CPU by stored program concept



- \* CPU cannot execute the programs (.exe) directly from disk.

- \* Instructions of the program are executed sequentially.



Modules of OS:

Process manager (CPU)

Memory manager (Memory)

File manager {Device

Devices manager

Protection manager (Resources)

Collection is called  
"Kernel / Nucleus"

Kernel is a central component of an operating system that manages operations of computer and hardware. It basically manages operations of memory and CPU time.

Functions of OS:

1. Process management
2. Memory mgmt.
3. Error detection
4. Security
5. File Management.

Functions and Goals:

1. Convenience (ease of use)
2. Efficiency
3. Reliability
4. Robustness
5. Scalability
6. Portability

★ Primary (main) goal of an Operating System: Convenience

(For personal computing)

★ Convenience is not primary goal of all other computing environment

Other Computing Environment:

(a) Real time Systems (RTS): + operate in real time (fixed deadline)

↓

Main goal: efficiency

\* Ex: missile, satellite, nuclear system control

{ Hard - Real time System }

(b) Mobile Operating System main goal: battery efficiency.

Tim Types of OS:

1. Batch OS
  2. Multiprogrammed OS
  3. Time Sharing OS
  4. Real time OS
  5. Network OS
  6. Distributed OS
- } Advanced

## Generations of Computers:

1<sup>st</sup> Generation of Computers (1930 - 40s): No O.S

2<sup>nd</sup> Generation of Computers (1940 - 1950s): magnetic Tape

3<sup>rd</sup> Generation of Computers (1950 - 1960s)

↓  
Magnetic Disk (Hard disk, floppy disk)

Uni-programmed

Multi-programmed

Uni-programming: Ability of the O.S to hold a single program in memory



### Drawback:

- \* Single program in memory is not enough (sufficient) to keep the CPU always busy.
- \* Throughput and efficiency will be less.  
↑  
no of programs completed  
Unit time.

Multiprogramming: Ability of the operating system to hold (manage) multiple ready to run programs in memory.

Objective:

- \* Maximize CPU utilization
- \* Maximize throughput.



Multiprogramming: Multiplexing of CPU among different (another definition) programs in memory.

### Types of multiprogramming:

- 1. Non Preemptive
  - \* No forced deallocation
  - \* Running program on CPU will not be forced to leave CPU. It will release CPU voluntarily:
    - 1. Complete execution
    - 2. needs I/O Syst. call.
- \* Drawback: leads to starvation to other waiting programs.
  - lack of interactiveness, responsiveness.

### 2. Preemptive

- \* Forceful deallocation.
- \* Program running on CPU can get forcefully deallocated from CPU (Pre Emption), So that waiting program can get their chance to run on CPU.

Objective:

- \* Improve interactiveness
- \* Increase responsiveness

Preemption is done based on:

- 1. Priority
- 2. Time

### Multiprogramming (Schematic View)

Job Creation



Architectural (H/w) requirements for implementing a multi programmed Operating System:

1. Secondary Storage Device (Io) : DMA [Direct Memory Access] (Disk)

2. Memory (RAM) : Address Translation



3. CPU (Processor) : Dual mode operation

Every CPU of multiprogrammed OS should have two mode of execution.



### User mode

- All user applications run in Um.

- Um is preemptive (Non Atomic)

### Kernel mode

- All OS routines programs run in Km.

- Km is non preemptive (Atomic)



\* Many a times it becomes necessary to shift the mode from User mode and kernel mode and back from kernel mode to User mode.

Mode Shifting: Shifting of mode from User mode to Kernel mode and back is called mode shifting.

Mode Shifting (Process) is needed to avail of service.

API : Application Programmer's Interface / System Call Interface

Implementation of mode shifting process via API/SCI.

```
main()
{
    int a,b,c;
    b=1;
    c=2;
    a=b+c;
    f(a);
}
```

```
f(int k)
{
    k++;
    printf("%d",k);
}
```

\* Implementation is in Library file (.lib)

\* *f* - predefined fn.  
- library fun.  
- built-in.

f();  
'user defined function'

\* <stdio.h> file  
Contains function prototypes, which is used for type checking

- \* `printf()`, `scanf()` are defined by the Compiler implementor and the Compiler code will be in library file.
- \* User defined functions are run in user mode along with built-in functions because they are written by users.

```

★ main()
{
    int a,b,c;
    a=1;
    b=2;
    c=a+b;
    f(c);
    fork(); ← Km.
    printf("·Id",c); } Um.
}
  
```

- fork() is a function  
 \* It is a System Call ? OS routine
- \* Fork() is defined / implemented in OS Kernel
- \* Execution of a fork() results in creating a child process

```

★ main()      * CT: Compile time
{             * BSA: branch and save address } Instructions
:             * SVC: Supervisor Call
f(); → BSA   {privileged inst.} } All pre defined Functions
:             are translated into
fork(); → SVC
: { Software interrupt
:   instrucu } } (non privileged instruction)
:             - User mode at runtime.
* fork() is converted into SVC
because it is a not user defined
- S/W interrupt at runtime.
  
```

- \* Interrupt generated by Software Instructions are called Software interrupt.
- \* ISR : Interrupt Service routine : A program of OS to service the interrupt.

ISR: \* ISR will go to register and convert the mode bit from '1' to '0' to shift from user mode to kernel mode and vice versa.



\* ISR examines an interrupt and determines how to handle it, executes the handling and then returns a logical interrupt value (return the address of `fork` from the dispatch table).

- \* All the Operating Systems - Windows, Linux, Unix follow the same paradigm
- \* The `fork()` will be executed at kernel mode in the dispatch table. All instructions will be executed of the `fork` and the last instruction will change the mode bit from '0' to '1' after execution and then `fork` is executed successfully at kernel mode and returned to User mode and then remaining code will run.
- \* To change the mode from kernel mode to User mode then no Software interrupt is required, interrupt is required for changing modes from Um to Km only

`printf()`: Library file can also use System-call.

```
{
  : : {
    : : User mode
    : : instructions
    : :
  } write(); → mode shifting
  : System call
}
```

Note: every privileged instruction does not generate interrupt

1. Kernel mode: In Kernel mode, the executing code has complete and unrestricted access to the underlying hardware. It can execute any CPU instruction and reference

any memory address. Kernel mode is generally reserved for lowest-level, most trusted functions of the operating system. Crashes in kernel mode are catastrophic, they will halt the entire PC.

- Q2. User mode: In User mode the executing code has no ability to directly access hardware or reference memory. Code running in User mode must delegate to System APIs to access hardware or memory. Due to the protection afforded by this sort of isolation, crashes in User mode are always recoverable. Most of the code running on your computer will execute in User mode.



- Q1. A processor needs Software interrupt to  
 : Obtain System Services which need execution of privileged instructions.
- Q2 A CPU has 2 modes Privileged & non privileged. In order to change the mode from privileged to non privileged:  
 : A privileged instruction (which does not generate an interrupt) is needed.

## Process Management.

Q3. System Calls are usually invoked by using:  
 : Software interrupt

Q4. A computer handles several interrupt sources of which of the following are relevant for this question:

- \* Interrupt from CPU temperature Sensor (raises interrupt if CPU temperature is too high)
- \* Interrupt from mouse (raises interrupt if it is moved / button is pressed)
- \* Interrupt from Keyboard (" " key is pressed / released)
- \* " " Harddisk (" disk read is completed")

Which one of these will be handled at the highest priority?  
 : Interrupt from CPU temperature



### Static and Dynamic

Ex: int n; int \*ptr;  
 scanf("%d", &n);  
 ptr = (int \*) malloc(sizeof(int)\*n);



- Process:
- \* Program in Execution
  - \* When program is loaded from Disk to main memory then program is converted to process.
  - \* Instance of a program.
  - \* Locus of control
  - \* Animated Spirit.



Representation of process in memory.



Process Operations:

1. Create(): resource allocation
2. Schedule(): the act of selecting process to run on Cpu
3. Executefunc(): the act of executing instruction from CodeSection
4. block / wait: for I/O Operations / System call
5. Suspend: act of moving process from memory to disk.

6. Resume : act of moving process from disk to memory  
 7. Terminate: act of resource deallocation.

Process as an entity is associated with several attributes:

1. Identification :  $\langle \text{Pid}, \text{gid}, \text{Ppid} \dots \rangle$
  2. CPU related :  $\langle \text{Program Counter}, \text{Priority}, \text{State}, \text{burst time} \dots \rangle$
  3. Memory related:  $\langle \text{Size}, \text{limits}, \dots \rangle$
  4. File related:  $\langle \text{list of files}, \dots \rangle$
  5. Accounting :  $\langle \text{resources} \dots \rangle$
- And many more attributes  
but these are some important ones.

PCB (Process Control Block):

- \* Contains all attributes of process. Process Content
- \* each process has its own PCB. : Content of PCB
- \* PCB is stored in memory.

Process States:

1. new : a process is created and resource is allocated
2. ready: ready to run on CPU
3. running: executing instructions on CPU
4. block/wait: process needs to perform I/O or system call.
5. terminate: resource deallocation.



## classmate Date \_\_\_\_\_ Page \_\_\_\_\_

### Process State transition diagram of uni programmed OS:



- Notes:
1. As long as the process is in ready + running + block states, it is in main memory.
  2. There can be many ready, block processes.
  3. Maximum number of running processes depend on no. of CPUs.
  4. The process may go from ready state to block/wait state because of any missing resource.

Q1 The process state transition diagram given below is representation of: Ans: An Operating System with preemptive Scheduler.



Ans An Operating System with pre-emptive Scheduler.

Q2. In the following process state transition diagram for a Uniprocessor system. Assume that there are always some processes in ready state.

- (i) If process makes a transition D, it would result in another process making transition A immediately.
- (ii) A process  $P_2$  is blocked state can make transition E while another process  $P_1$  is in running state.
- (iii) The OS uses preemptive scheduling
- (iv) The OS uses non preemptive scheduling.



Which of the above statements are true? → II and III.

Q3. Which combination of the following feature will suffice to characterize an OS as multi programmed OS?

- (a) more than one program may be loaded into main memory at the same time for execution.

Ans:

only 'a'

- (b) If a program waits for certain events such as I/O, another program is immediately scheduled for execution
- (c) If the execution of program terminates, another program is immediately scheduled for execution.

Q4. The maximum number of processes that can be in ready state for a computer system with 'n' CPUs:

Ans: Independent of n. (theoretically there can be infinite no. of programs in ready state).

\* Ans will be n if 'running state' was asked.

Q5. Consider the following statements about process State transitions for a system using preemptive scheduling.

- I. A running process can move to ready state
- II. A ready process can move to running state
- III. A blocked process can move to running state
- IV. A blocked process can move to ready state.

Which of the above statements are true? Ans : I, II, III

Q6. Consider a system having 'n' cpus ( $n \geq 1$ ) and 'k' processes ( $k \geq 0$ ). Calculate lower bound and upper bound of the number of processes that can be in the ready, running and blocked states.

|         | L.B. | U.P. | $n = \text{no. of cpus } (n \geq 1)$ |
|---------|------|------|--------------------------------------|
| Ready   | 0    | $k$  |                                      |
| Running | 0    | $n$  |                                      |
| Block.  | 0    | $k$  |                                      |

|         | L.B. | U.P. |                                   |
|---------|------|------|-----------------------------------|
| Ready   | 0    | $k$  | $n = \text{no. of cpus } (n > 1)$ |
| Running | 0    | $k$  | $k = \text{no. of processes}$     |
| Block   | 0    | $k$  | $(k < n)$                         |

### Scheduling Queue and State - Queuing Diagram



Queue on disk

## 1. Job Queue

Input Queue

## 2. Suspend Queue

\* Contains list of processes

\* Contains programs that are ready to be loaded in memory

that get suspended from memory into disk.

State Queuing Diagram:

Detailed diagram ↓

Job Q.



The upper pair  
of scheduling  
queue diagram.



## Schedulers and Dispatchers

- \* Scheduling means making a decision
- \* Scheduler is a component of O.S. that make decisions.
- \* There are three types of schedulers:

1.) Long term scheduler (LTS): Operates on Job-Q.

(~~CPU Scheduler~~)

New

LTS.

Ready

Selects process based on a criteria

2.) Short term scheduler: Operate on ready to Queue, to decide which ready process should run next.

(CPU Scheduler)

3.) Medium term Scheduler: Operates on Suspend Queue.  
also called "Swapper".

Q. Which scheduler controls degree of multi programming?

Ans: Long term Scheduler (L.T.S.).

\* Dispatcher: Carrying out activity of context-switching.

\* Context Switching: is the activity of loading and saving the PCBs of processes, during a process switch on CPU.

Context Switching:

ST runs on CPU and Selects a process from ready queue based on an algorithm

- \* Time taken by dispatcher to load and save the PCB's is known as "Context Switching time" or "CPU Scheduling Overhead" or "dispatch latency"

- Q1. Let the time taken to switch between user and kernel mode of execution be  $t_1$ , while the time taken to switch between two user processes be  $t_2$ . Which of the following is true?

$$\text{Context switching time} = t_2$$

$$\text{mode shifting time} = t_1$$

$$\therefore t_1 < t_2$$

\* process switching involves mode shifting time

- Q2 Dispatch latency is defined as:

The time to switch from one process to another on CPU

- Q3. Which of the following is an invalid process state transition?

- a. Ready - running ✓
- b. Running - terminate ✓
- c. Block - ready ✓
- d. Ready - Suspend ✓
- e. Suspend - running ✗

- f. block - terminate ✗
- g. Suspend - ready ✓
- h. block - new ✗
- i. Suspend - terminate ✗

## CPU Scheduling

CPU Scheduling: Design and implementation of S.T.S.



Goals (Scheduling Criteria):

- \* Maximize CPU utilization (throughput)
- \* Minimise Waiting time (WT), turnaround time (TAT), response time (RT).

Process Times:

1. Arrival time (AT): first time when the process comes from new to ready state is called arrival time.



2. Waiting time: total time spent by the process in ready (WT) queue.

3. Burst time: time spent by the process executing in the (BT) CPU is called CPU burst time.

4. I/O Burst time: time spent by the process in block (I/O BT) queue performing I/O operation is called I/O burst time.

5. Completion time: time at which process complete.

6. Turn Around time : the time taken by the process from its arrival time to completion time is called turn around time.

$$TAT = C.T - A.T.$$

7. Waiting time (WT) : total time spent by the process in ready queue is called waiting time.

$$WT = TAT - (BT + IOBT)$$

Note:

$$1. n \text{ processes } (P_1 \dots P_n)$$

$$2. AT(P_i) = A_i$$

$$3. BT(P_i) = X_i$$

$$4. IOBT(P_i) = Y_i$$

$$5. CT(P_i) = C_i$$

$$a) TAT(P_i) = (C_i - A_i)$$

$$\text{Average TAT} = \frac{\sum_{i=1}^n (C_i - A_i)}{n}$$

$$b) WT(P_i) = (C_i - A_i) - (X_i + Y_i)$$

$$\text{Average WT} = \frac{\sum_{i=1}^n (C_i - A_i) - (X_i + Y_i)}{n}$$

Schedule length: Total time taken to complete all 'n' processes (L) as per schedule

- \* No. of schedules with n-processes =  $n!$  (non preemptive)
- \* No. of schedules with n-processes =  $\infty$  (pre-emptive)

$$L = (\text{completion time of last process}) - (\text{A.T of last process}) \\ \Rightarrow \max(C_i) - \min(A_i)$$

Throughput = no. of processes completed per unit time.

$$\eta = \frac{n}{L}$$

Context-Switch time : CPU Scheduling Overhead

Let CPU Scheduling overhead = "8"



Time taken to load PCB to process from Ready Queue onto CPU.

CPU Scheduling OccursTypes of CPU Scheduling:

1. Preemptive
2. Non Preemptive.

Scheduling Criteria:

| Maximize          | Minimize          |
|-------------------|-------------------|
| * CPU utilization | * Turnaround time |
|                   | * Waiting time    |
|                   | * Response time   |

CPU - I/O Bursts:

Process execution consists of a cycle of CPU execution and I/O wait:

- \* different processes may have distributions of bursts.
- \* CPU bound processes: perform lots of computations in long bursts, very little I/O.
- \* I/O bound process: performs lots of I/O followed by short bursts of computation.
- \* ideally, the system admits a mix of CPU bound I/O bound processes to maximise CPU and I/O.

Example:1. FCFS {First Come First Serve}

\* Selection Criteria: A.T

\* Mode of operation: Non pre-emptive.

\* Conflict resolution: Lower process id.

\* Assumption:

(i) Time is in clock ticks

(ii) No IOBTS

(iii) Scheduling overheads ( $\delta$ ) = '0'.

Ex: 1

| P.no. | A.T. | B.T | C.T. | TAT | WT. | RQ              |                     |
|-------|------|-----|------|-----|-----|-----------------|---------------------|
| 1     | 0    | 4   | 4    | 4   | 0   | $P_1, P_2, P_3$ |                     |
| 2     | 0    | 3   | 7    | 7   | 4   | CPU             | $P_1   P_2   P_3  $ |
| 3     | 0    | 5   | 12   | 12  | 7   |                 | 0 4 7 12.           |

$$\text{Avg TAT} = \frac{23}{3}$$

$$\text{Avg WT} = \frac{11}{3}$$

Gantt Chart  $\rightarrow$

$$L = 12.$$

Ex: 2

P.no A.T B.T C.T. TAT. WT.

|   |   |   |    |   |   |                                 |
|---|---|---|----|---|---|---------------------------------|
| 1 | 0 | 2 | 2  | 2 | 0 |                                 |
| 2 | 0 | 1 | 3  | 3 | 2 |                                 |
| 3 | 2 | 3 | 6  | 4 | 1 | CPU                             |
| 4 | 3 | 2 | 8  | 5 | 3 | $P_1   P_2   P_3   P_4   P_5  $ |
| 5 | 5 | 4 | 12 | 7 | 3 | 0 2 3 6 8 12                    |

$$\text{Avg TAT} = \frac{21}{5}, \quad \text{Avg WT} = \frac{9}{5}, \quad L = 12. \quad \eta = \frac{\eta}{L} = \frac{5}{12}.$$

Ex: 3

P.no A.T B.T C.T TAT WT

|   |    |   |    |   |   |                         |
|---|----|---|----|---|---|-------------------------|
| 1 | 3  | 5 | 8  | 5 | 0 |                         |
| 2 | 10 | 2 | 12 | 2 | 0 | CPU                     |
| 3 | 15 | 4 | 19 | 4 | 0 | $P_1   P_2   P_3   P_4$ |
| 4 | 18 | 5 | 24 | 6 | 1 | 0 3 8 10 12 15 19 24    |

$$\therefore \text{CPU idle time} = \frac{5}{21}.$$

Ex. 4. P.no A.T B.T

| P.no | A.T | B.T |
|------|-----|-----|
| 1    | 5   | 2   |
| 2    | 3   | 1   |
| 3    | 8   | 4   |



$$L = 12 - 3 = 9$$

Time →

Ex. 5. P.no A.T B.T

| P.no | A.T | B.T |
|------|-----|-----|
| 1    | 10  | 3   |
| 2    | 11  | 4   |
| 3    | 20  | 5   |
| 4    | 2   | 3   |
| 5    | 12  | 3   |
| 6    | 8   | 1.  |

→ RQ : P<sub>4</sub> P<sub>6</sub> P<sub>1</sub> P<sub>5</sub> P<sub>3</sub>.

$$L = 25 - 2 \text{ } \because \text{CPU idleness}$$

$$= 23. = \frac{4}{23}.$$

## CPU Scheduling Techniques / Algorithms

1. FCFS : Scheduling with I/O-BT's and CPU Scheduling Overheads.

Ex. 2 :  $S=1$ .P.no A.T  $\langle B.T : IOBT : BT \rangle$ 

|   |   |   |   |   |
|---|---|---|---|---|
| 1 | 0 | 3 | 7 | 2 |
| 2 | 2 | 5 | 2 | 3 |
| 3 | 5 | 1 | 4 | 2 |

System has multiple I/O devices.



$$L = 22.$$

$$\begin{array}{ll} TAT(P_1) = 15 & WT(P_1) = 1 \\ TAT(P_2) = 17 & WT(P_2) = 5 \\ TAT(P_3) = 17 & WT(P_3) = 8 \end{array}$$

% CPU Idleness = 0%

\* With  $\delta > 0$  the formula for W.T becomes

$$WT = TAT - (BT + IOBT + \delta)$$

\*  $\delta$  = no of times process gets scheduled into CPU.

- Q1. Consider three processes  $P_1, P_2, P_3$  arriving in the ready queue at time 0 in the order  $P_1, P_2, P_3$ . Their service time requirements are 10, 20 and 30 units respectively. Each process spends 20% of its service time on I/O followed by 70% of its service time on computation at CPU and last 10% on DIO before completion. Assuming concurrent I/O and negligible scheduling overhead, calculate FCFS scheduling:

- (i) Average TAT      (ii) % CPU Idleness.

$$L=47$$

$$\therefore \text{CPU idleness} = \frac{5}{47}$$

$$\text{Avg TAT} = \frac{44+44+47}{3} = 44$$

| <u>Soln:</u> | P.no | S.T | AT | $\langle IOBT; BT; IOBT; \rangle$ |
|--------------|------|-----|----|-----------------------------------|
|              | 1    | 10  | 0  | 2 7 1                             |
|              | 2    | 20  | 0  | 4 14 2                            |
|              | 3    | 30  | 0  | 6 21. 3                           |



Above problem with  $\delta = 1$ .

$$RQ \rightarrow P_1 P_2 P_3 P_1 P_2 P_3 P_1 P_2 P_3 \quad L=52$$

| CPU | 8 | $P_1$   | 8 | $P_2$   | 8 | $P_3$   | 8 | $P_1$ | 8  | $P_2$    | 8  | $P_3$    | 8  | $P_1$    | 8  | $P_2$ | 8  | $P_3$ |
|-----|---|---------|---|---------|---|---------|---|-------|----|----------|----|----------|----|----------|----|-------|----|-------|
| 0   | 1 | 1       | 2 | 2       | 3 | 3       | 4 | 11    | 12 | 20       | 27 | 48       | 49 | 49       | 50 | 50    | 51 | 52    |
|     |   | (10)..2 |   | (10)..4 |   | (10)..6 |   |       |    | (10)..12 |    | (10)..28 |    | (10)..51 |    |       |    |       |
|     |   | $P_1$   |   | $P_2$   |   | $P_3$   |   |       |    | $P_1$    |    | $P_2$    |    | $P_3$    |    |       |    |       |

\* ∴ CPU overhead activity:

$$\Rightarrow 9/52$$

$$*\therefore \text{CPU idleness} = \frac{1}{52}$$

\* ∴ CPU efficiency

$$\Rightarrow 100 - \left( \frac{9}{52} + \frac{1}{52} \right)$$

Homework: Repeat Q 2 and 3 assuming System has only one I/O-device.

|     | P.no | AT | <BT IOBT BT> |      |
|-----|------|----|--------------|------|
| S=2 | 1    | 0  | 3            | 4 2  |
|     | 2    | 5  | 2            | 0 3  |
|     | 3    | 20 | 1            | 15 6 |

|      | P.no | AT | I/O | BT | IOBT  |
|------|------|----|-----|----|-------|
| S=1. | 1    |    | 3   | 5  | 2 3   |
|      | 2    |    | 8   | 2  | 10 4  |
|      | 3    |    | 12  | 6  | 12 1. |

## 2. Shortest Job First (SJF) / Shortest Process Next (SPN)

\* Selection Criteria: Burst-Time

\* Mode of operation: Non pre emptive

\* Conflict resolution: Lower process id.

: Among the processes present in RQ Select the one having least BT and schedule it on CPU.

|   | P.no | A.T | B.T |
|---|------|-----|-----|
| 1 | 0    |     | 2   |
| 2 | 2    |     | 3   |
| 3 | 3    |     | 1   |
| 4 | 5    |     | 2   |
| 5 | 8    |     | 3   |
| 6 | 10   |     | 2   |

RQ: P<sub>1</sub> P<sub>2</sub> P<sub>3</sub> P<sub>4</sub> P<sub>5</sub> P<sub>6</sub>



|   | P.no | A.T | B.T |
|---|------|-----|-----|
| 1 | 10   |     | 1   |
| 2 | 4    |     | 2   |
| 3 | 6    |     | 4   |
| 4 | 2    |     | 3   |
| 5 | 5    |     | 2   |
| 6 | 3.   |     | 2   |

RQ: P<sub>4</sub>, P<sub>2</sub>, P<sub>5</sub>, P<sub>3</sub>



∴ CPU idle time = 0  
L

### 3. Shortest Remaining Time First (SRTF) / Pre-emptive SJF

\* Selection Criteria: BT

\* mode of operation : Pre-emptive

\* Conflict resolution: Lower process id

→ Pre-emption of running process is based on availability of strictly shorter process.

Ex: 1.

P.no. AT BT

|                |                |                |     |                                                                                                          |                |                |                |
|----------------|----------------|----------------|-----|----------------------------------------------------------------------------------------------------------|----------------|----------------|----------------|
| 1              | 0              | 5              | CPU | <table border="1"> <tr> <td>P<sub>1</sub></td><td>P<sub>2</sub></td><td>P<sub>1</sub></td></tr> </table> | P <sub>1</sub> | P <sub>2</sub> | P <sub>1</sub> |
| P <sub>1</sub> | P <sub>2</sub> | P <sub>1</sub> |     |                                                                                                          |                |                |                |
| 2              | 2              | 2              |     | 0 2 4 7<br>↓<br><u>P<sub>r</sub></u>                                                                     |                |                |                |

Ex: 2

P.no. AT. BT

|                |                |                |                |                                                                                                                                |                |                |                |                |
|----------------|----------------|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------|----------------|----------------|----------------|----------------|
| 1              | 0              | 5              | CPU            | <table border="1"> <tr> <td>P<sub>1</sub></td><td>P<sub>3</sub></td><td>P<sub>1</sub></td><td>P<sub>2</sub></td></tr> </table> | P <sub>1</sub> | P <sub>3</sub> | P <sub>1</sub> | P <sub>2</sub> |
| P <sub>1</sub> | P <sub>3</sub> | P <sub>1</sub> | P <sub>2</sub> |                                                                                                                                |                |                |                |                |
| 2              | 1              | 4              |                | 0 2 4 7 11<br>↓<br><u>P<sub>r</sub></u>                                                                                        |                |                |                |                |
| 3              | 2              | 2              |                |                                                                                                                                |                |                |                |                |

Ex: 3

P.no A.T. BT

|   |                |                |                |                                                                                                                                                                                                                                                                                         |                                                                                                         |                |                |                |                |                |                |                |                |                |                |
|---|----------------|----------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 1 | 1              | 3              | 6              |                                                                                                                                                                                                                                                                                         | 10 9 8 7 6 5 4 3.                                                                                       |                |                |                |                |                |                |                |                |                |                |
| 2 | 2              | 10             |                |                                                                                                                                                                                                                                                                                         | RQ: P <sub>2</sub> , P <sub>6</sub> , P <sub>1</sub> , P <sub>5</sub> , P <sub>3</sub> , P <sub>4</sub> |                |                |                |                |                |                |                |                |                |                |
| 3 | 5              | 2              | CPU            | <table border="1"> <tr> <td>≡</td> <td>P<sub>6</sub></td> <td>P<sub>1</sub></td> <td>P<sub>5</sub></td> <td>P<sub>3</sub></td> <td>P<sub>3</sub></td> <td>P<sub>4</sub></td> <td>P<sub>5</sub></td> <td>P<sub>1</sub></td> <td>P<sub>6</sub></td> <td>P<sub>2</sub></td> </tr> </table> | ≡                                                                                                       | P <sub>6</sub> | P <sub>1</sub> | P <sub>5</sub> | P <sub>3</sub> | P <sub>3</sub> | P <sub>4</sub> | P <sub>5</sub> | P <sub>1</sub> | P <sub>6</sub> | P <sub>2</sub> |
| ≡ | P <sub>6</sub> | P <sub>1</sub> | P <sub>5</sub> | P <sub>3</sub>                                                                                                                                                                                                                                                                          | P <sub>3</sub>                                                                                          | P <sub>4</sub> | P <sub>5</sub> | P <sub>1</sub> | P <sub>6</sub> | P <sub>2</sub> |                |                |                |                |                |
| 4 | 6              | 1              |                | 0 2 3. 4 5 ↓ 6 7 8 11 16 23 33.                                                                                                                                                                                                                                                         |                                                                                                         |                |                |                |                |                |                |                |                |                |                |
| 5 | 4              | 4              |                |                                                                                                                                                                                                                                                                                         | <u>P<sub>r</sub></u> <u>P<sub>r</sub></u> <u>P<sub>r</sub></u>                                          |                |                |                |                |                |                |                |                |                |                |
| 6 | 2              | 8              |                |                                                                                                                                                                                                                                                                                         |                                                                                                         |                |                |                |                |                |                |                |                |                |                |

Ex: 4

P.no AT. BT

|                |                |                |                |                                                                                                                                                                                                  |                |                |                |                |                |                |                |
|----------------|----------------|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 1              | 4              | 2              | CPU            | <table border="1"> <tr> <td>P<sub>3</sub></td><td>P<sub>1</sub></td><td>P<sub>3</sub></td><td>P<sub>4</sub></td><td>P<sub>2</sub></td><td>P<sub>4</sub></td><td>P<sub>5</sub></td></tr> </table> | P <sub>3</sub> | P <sub>1</sub> | P <sub>3</sub> | P <sub>4</sub> | P <sub>2</sub> | P <sub>4</sub> | P <sub>5</sub> |
| P <sub>3</sub> | P <sub>1</sub> | P <sub>3</sub> | P <sub>4</sub> | P <sub>2</sub>                                                                                                                                                                                   | P <sub>4</sub> | P <sub>5</sub> |                |                |                |                |                |
| 2              | 10             | 1              |                | 0 3 4 6 9 10 11 13 17<br>↓ ↓                                                                                                                                                                     |                |                |                |                |                |                |                |
| 3              | 3              | 4              |                |                                                                                                                                                                                                  |                |                |                |                |                |                |                |
| 4              | 5              | 3              |                | <u>P<sub>r</sub></u> <u>P<sub>r</sub></u>                                                                                                                                                        |                |                |                |                |                |                |                |
| 5              | 3              | 4              |                | L = 17 - 3 = 14                                                                                                                                                                                  |                |                |                |                |                |                |                |

Q1. Consider the following processes, with AT and lengths of the CPU burst given in ms. The scheduling algo used is preemptive SRTF.

Process    AT.    B.T    The average turn around time

P<sub>1</sub>      0      10      of these processes is 8.25

P<sub>2</sub>      3      6

P<sub>3</sub>      7      1

P<sub>4</sub>      8      3

|                |                |                |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|
| P <sub>1</sub> | P <sub>2</sub> | P <sub>3</sub> | P <sub>2</sub> | P <sub>4</sub> | P <sub>1</sub> |
| 0              | 3.             | 7              | 8              | 10             | 13             |

P<sub>1</sub>    P<sub>2</sub>

$$\text{Average TAT} = \frac{20+7+1+5}{4}$$

$$= \frac{33}{4} = 8.25$$

Q2. Process    P<sub>1</sub>    P<sub>2</sub>    P<sub>3</sub>    P<sub>4</sub>    The processes are run on a single processor using pre-emptive SRTF. If avg WT = 1ms, then value of z = ?

$$\text{Average WT} = 1 \text{ ms (SRTF)}$$

→ Case 1: z < 3.

$$\text{Avg WT} = 1 + 0 + (2+1) + 0$$

|     |                |                |                |                |                |
|-----|----------------|----------------|----------------|----------------|----------------|
| CPU | P <sub>1</sub> | P <sub>2</sub> | P <sub>1</sub> | P <sub>4</sub> | P <sub>3</sub> |
| 0   | 1              | 2              | 4              | 4+2            | 7+2            |

$$1 = z+2$$

$$\frac{1}{4} \therefore z = 2$$

Case 2: z ≥ 3.

|                |                |                |                |                |
|----------------|----------------|----------------|----------------|----------------|
| P <sub>1</sub> | P <sub>2</sub> | P <sub>1</sub> | P <sub>3</sub> | P <sub>4</sub> |
| 0              | 1              | 2              | 4              | 7              |

$$\text{Avg WT} = \frac{1+0+1+3}{4} = \frac{5}{4} = 1.25$$

Because Avg WT = 1. So z is less than 3.

### Performance of SJF/SRTF :

1. It favors shorter process:

→ Advantages: \* Complete more processes, max throughput  
\* minimizing of Avg TAT, Avg WT.

→ Drawback: \* Starvation to longer processes.

Note: \* SJF/SRTF is considered the "optimal algorithm"

- \* Since B.T.'s of processes are not known Apriori, SJF/SRTF is "not practically implementable"!
- \* SJF is used as a benchmark to measure performance of other algorithms.
- \* SJF can be implemented with predicted burst times.

Q3. Three processes arrive at time zero with CPU bursts of 10, 20 and 10 milliseconds. If the scheduler has prior knowledge about the lengths of CPU bursts, the min achievable average waiting time for these three processes in non-preemptive scheduler is 12 milliseconds.

| Cpu | P <sub>3</sub> | P <sub>1</sub> | P <sub>2</sub> | Avg WT = $\frac{10+20+0}{3} = \frac{30}{3} = 12$ |
|-----|----------------|----------------|----------------|--------------------------------------------------|
|     | 0              | 10             | 20             | 40                                               |

### Prediction Techniques

Static

: Total burst time  
of processes.

Dynamic

: Partial (near CPU burst)  
burst

(Process size)  
Type  
Bytes.

| Pri | WT <sub>1</sub> | BT <sub>1</sub> | I/O BT | WT <sub>2</sub> | BT <sub>2</sub> | ? |
|-----|-----------------|-----------------|--------|-----------------|-----------------|---|
|     | RQ              | CPU             | I/O    | R.Q             | CPU             |   |
|     |                 |                 |        |                 |                 |   |

P<sub>i</sub> = 't'

'new CPU burst'

Exponential Averaging Technique / Aging Algorithm: (To predict next CPU burst)

Let P<sub>i</sub> : process

Let t<sub>i</sub> : completed B.T

Let T<sub>i</sub> : predicted B.T

Let T<sub>i+1</sub> denote next predicted B.T

$$T_{i+1} = \alpha t_m + (1-\alpha) T_i$$

$$0 < \alpha < 1$$

Recurrence Relation:

$$\begin{aligned} T_{n+1} &= \alpha t_n + (1-\alpha) T_{n-1} \quad \text{(I)} \\ T_n &= (\alpha t_{n-1} + (1-\alpha) T_{n-2}) \quad \text{(II)} \end{aligned}$$

Back Substitution

$$\begin{aligned} T_{n+1} &= \alpha t_n + (1-\alpha)[\alpha t_{n-1} + (1-\alpha) T_{n-1}] \\ &= \alpha t_n + \alpha(1-\alpha)t_{n-1} + (1-\alpha)^2 T_{n-1} \quad \text{(III)} \\ &= \alpha t_n + \alpha(1-\alpha)t_{n-1} + \alpha(1-\alpha)^2 t_{n-2} + (1-\alpha)^3 T_{n-2} \quad \text{(IV)} \\ &\quad (\gamma_1 = \text{initial guess}) \end{aligned}$$

Given the value of ' $\alpha$ ' and  $\gamma_1$ , one can predict next CPU BT.

- Q1. Consider a system using exponential averaging technique to predict next CPU BT. Given  $\alpha=0.5$  and  $\gamma_1=10$ . The process BT's in previous runs are: 4, 8, 12, 10. Predict the next CPU burst time of process.

Sol:-  $T_S = ?$

$$4, 8, 12, 10 \\ \downarrow \\ t_1, t_2, t_3, t_4$$

$$T_{n+1} = \alpha t_n + (1-\alpha) T_n \quad \text{(I)}$$

$$\begin{aligned} T_S &= 0.5 \times t_4 + 0.5 \times T_4 \quad \downarrow 9.75 \\ &= \frac{1}{2} \times (t_4 + T_4) = \frac{1}{2} (10 + T_4) \end{aligned}$$

$$T_3 = \frac{1}{2} (t_2 + T_2) = \frac{1}{2} (8 + T_2) = \underline{\underline{7}}$$

$$T_2 = \frac{1}{2} (t_1 + T_1) = \frac{1}{2} (4 + 10)$$

$$T_2 = \underline{\underline{7}}.$$

$$\therefore T_S = \frac{1}{2} (10 + 9.75) = \frac{19.75}{2} = \underline{\underline{9.875}}$$

#### 4 Highest Response Ratio Next (HRRN)

→ HRRN not only favours shorter process but also limits the waiting time of longer process

- \* Selection Criteria: Response ratio :  $\frac{W.T + BT}{BT}$
- \* Mode of operation: Non pre-emp.

Ex 1.

P.no AT BT

HRRN:

1 0 3

2 2 6

3 4 4

4 6 5

5 8 2

|    | P <sub>1</sub> | P <sub>2</sub> | P <sub>3</sub> | P <sub>5</sub> | P <sub>4</sub> |    |
|----|----------------|----------------|----------------|----------------|----------------|----|
| 0  |                |                |                |                |                | 20 |
| 3  |                |                |                |                |                |    |
| 9  |                |                |                |                |                |    |
| 13 |                |                |                |                |                |    |
| 15 |                |                |                |                |                |    |



## 5. Longest Remaining Time First (LRTF)

→ It is just opposite of longest to smallest remaining time first.

\* Selection Criteria: Burst Time

\* Mode of operation: Pre-emptive.

Ex 1.

P.no AT BT

CPU. (it's pre emp)

TAT:

1 0 2

2 0 4

3 0 8

|    | P <sub>3</sub> | P <sub>2</sub> | P <sub>1</sub> |
|----|----------------|----------------|----------------|
| 0  |                |                |                |
| 8  |                |                |                |
| 12 |                |                |                |
| 14 |                |                |                |

$$P_1 = 14 - 0 = 14$$

$$P_2 = 12 - 0 = 12$$

$$P_3 = 8 - 0 = 8$$

| CPU | P <sub>3</sub> | P <sub>2</sub> | P <sub>3</sub> | P <sub>2</sub> | P <sub>3</sub> | P <sub>1</sub> | P <sub>2</sub> | P <sub>3</sub> | P <sub>1</sub> | P <sub>2</sub> | P <sub>3</sub> |  |
|-----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--|
| 0   |                |                |                |                |                |                |                |                |                |                |                |  |
| 4   |                |                |                |                |                |                |                |                |                |                |                |  |
| 5   |                |                |                |                |                |                |                |                |                |                |                |  |
| 6   |                |                |                |                |                |                |                |                |                |                |                |  |
| 7   |                |                |                |                |                |                |                |                |                |                |                |  |
| 8   |                |                |                |                |                |                |                |                |                |                |                |  |
| 9   |                |                |                |                |                |                |                |                |                |                |                |  |
| 10  |                |                |                |                |                |                |                |                |                |                |                |  |
| 11  |                |                |                |                |                |                |                |                |                |                |                |  |
| 12  |                |                |                |                |                |                |                |                |                |                |                |  |
| 13  |                |                |                |                |                |                |                |                |                |                |                |  |
| 14  |                |                |                |                |                |                |                |                |                |                |                |  |

$$\text{Avg T.A.T.} = \frac{12+13+14}{3}$$

$$\text{Avg T.A.T.} = 13$$

- Q1. Consider 3 processes A, B, C with compute BT.s are 4, 6, 9 units. All the processes arrive at time zero. Consider the longest remaining time first (LRTF). In LRTF tie are broken by giving priority to processes with lowest Pid. Find the avg of completion times of A, B?

$$RQ: P_1 P_2 P_3$$

P.no AT BT

A 0 4

B 0 6

C 0 9

|    | P <sub>3</sub> | P <sub>2</sub> | P <sub>3</sub> | P <sub>2</sub> | P <sub>3</sub> | P <sub>1</sub> | P <sub>2</sub> | P <sub>3</sub> | P <sub>1</sub> | P <sub>2</sub> | P <sub>3</sub> | P <sub>1</sub> |  |
|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--|
| 0  |                |                |                |                |                |                |                |                |                |                |                |                |  |
| 3  |                |                |                |                |                |                |                |                |                |                |                |                |  |
| 4  |                |                |                |                |                |                |                |                |                |                |                |                |  |
| 5  |                |                |                |                |                |                |                |                |                |                |                |                |  |
| 6  |                |                |                |                |                |                |                |                |                |                |                |                |  |
| 7  |                |                |                |                |                |                |                |                |                |                |                |                |  |
| 8  |                |                |                |                |                |                |                |                |                |                |                |                |  |
| 9  |                |                |                |                |                |                |                |                |                |                |                |                |  |
| 10 |                |                |                |                |                |                |                |                |                |                |                |                |  |
| 11 |                |                |                |                |                |                |                |                |                |                |                |                |  |
| 12 |                |                |                |                |                |                |                |                |                |                |                |                |  |
| 13 |                |                |                |                |                |                |                |                |                |                |                |                |  |
| 14 |                |                |                |                |                |                |                |                |                |                |                |                |  |

$$\text{Avg. CT} = \frac{17+18}{2} = 17.5$$

Q2 In a system using single processor, a new process arrives at the rate of 10 processes per minute and each such process require 5 seconds of service time. What is % CPU utilization?

Sol :-  $60 \text{ s} \rightarrow 10 \text{ processes}$

$$\begin{array}{c} \text{---} \rightarrow (5 \text{ sec}) \\ | \\ \boxed{(P_1, P_2, \dots, P_{10})} \\ \leftarrow \quad \rightarrow \quad \text{60 sec cycle.} \\ \text{---} \\ \% \text{ CPU Utilization} = \frac{50}{60} \times 100 \\ = 83.33\% \end{array}$$

Q3. Six jobs are waiting to be run. The expected running times are 9, 7, 5, 2, 1 and  $x$  respectively. Where  $5 < x < 7$  and avg CT. is 13. Find the value of  $x$  using SJF algorithm? (Assume all jobs arrive at same time = 0).

## 6. Priority Based Scheduling

→ Priority based Scheduling works exactly like SJF/SRTF except that it looks at priority instead of burst time.

\* Selection Criteria : Priority

\* Mode of operation : Non preemptive / preemptive

\* Tie breaking : Lower process id.

| Prio | P.no | AT | BT |
|------|------|----|----|
| 4    | 1    | 0  | 4  |
| 5    | 2    | 1  | 3  |
| 8    | 3    | 2  | 5  |

Non  
pre-emp

| P1 | P3 | P2 |
|----|----|----|
| 0  | 4  | 9  |

Pre-emp.

| P1 | P2 | P3 | P2 | P1 |
|----|----|----|----|----|
| 0  | 1  | 2  | 7  | 9  |

Ex 2.

| Prio. | P.no | AT | BT |
|-------|------|----|----|
|-------|------|----|----|

|   |   |   |   |
|---|---|---|---|
| 4 | 1 | 4 | 1 |
| 6 | 2 | 3 | 3 |
| 8 | 3 | 8 | 6 |
| 3 | 4 | 2 | 4 |
| 7 | 5 | 5 | 2 |
| 5 | 6 | 3 | 5 |

$$L = 23 - 2 = 21.$$



Ex 3.

| Prio | P.no | AT | BT |
|------|------|----|----|
|------|------|----|----|

|   |   |   |    |
|---|---|---|----|
| 4 | 1 | 0 | 21 |
| 5 | 2 | 1 | 3  |
| 6 | 3 | 2 | 5  |
| 7 | 4 | 3 | 1  |
| 8 | 5 | 5 | 4  |



$$\text{Avg WT} =$$

$$\text{Avg TAT} = \frac{15+13+10+1+4}{5} = \frac{43}{5} = 8.6$$

### Performance of priority based scheduling:

- \* Causes Starvation to low priority process, a solution exists "Dynamic priority": It increases the priority of the processes at regular intervals of time using an algorithm called "Aging" algorithm

- Q1. Consider a System with Pre-emptive priority based scheduling with processes P<sub>1</sub>, P<sub>2</sub>, P<sub>3</sub> having infinite instances of them. The instance of these processes arrive at regular intervals of 3, 7 and 20 ms respectively. The priority of these process instances is inverse of their periods. Each of the process instance P<sub>1</sub>, P<sub>2</sub>, P<sub>3</sub> consumes 1, 2 and 4 ms CPU time respectively. The 1<sup>st</sup> instance of each process is available at 1ms. What is the completion time of the 1<sup>st</sup> instance of process P<sub>3</sub>?

| Prio. | Period | P <sub>1</sub> no | AT | BT | <Other instances>     |
|-------|--------|-------------------|----|----|-----------------------|
| 1/3   | 3      | 1                 | 1  | 1  | <4, 7, 10, 13, 17...> |
| 1/7   | 7      | 2                 | 1  | 2  | <8, 15, 22, ...>      |
| 1/20  | 20     | 3                 | 1  | 4  | <21, 41, 61...>       |

Rq: P<sub>1</sub>, P<sub>2</sub>, P<sub>3</sub>, P<sub>1</sub><sub>2</sub>, P<sub>2</sub><sub>2</sub>,



Completion time of P<sub>3</sub> first instance is 13ms (at the end of 12)

Q2. Consider a System using Preemptive Priority based scheduling with dynamically changing priority. On its arrival a process is assigned a priority of zero and running process priority increases at the rate of 'B' and priority of the processes in the ready Q increase at the rate of 'a'. By dynamically changing values of a and B one can achieve different scheduling disciplines among the processes. What discipline will be followed for the following conditions

1. B > a > 0
2. a < B < 0

Ans: FCFF for first condition and LIFO for second condition.

### F. Round Robin Scheduling

→ It is used in Pre-emptive multi programmed time shared Operating Systems.

\* Selection Criteria: Arrival time + Time Quantum

\* mode of operation: Pre-emptive

\* Working principle: - each process is allotted a fixed time quantum  
- pre-emption is based on completion or expiration of time quantum.

Ex. 1.  $P_{no}$  AT BT  $TQ=3$   $R_Q = 1, 2, 3, 4, 1, 5, 3, 5.$

|   |   |   |
|---|---|---|
| 1 | 0 | 4 |
| 2 | 1 | 5 |
| 3 | 2 | 3 |
| 4 | 3 | 2 |
| 5 | 5 | 6 |

| $P_1$ | $P_2$ | $P_3$ | $P_4$ | $P_5$ | $P_1$ | $P_2$ | $P_5$ |
|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 3     | 6     | 9     | 11    | 14    | 15    | 17    |

$$L = 20.$$

Ex. 2.  $P_{no}$  AT BT  $TQ=2$   $P_4 P_1 P_5 P_4 P_1 P_3 P_5 P_3 P_2 P_5 = P_2$

|   |    |   |
|---|----|---|
| 1 | 4  | 4 |
| 2 | 15 | 5 |
| 3 | 8  | 6 |
| 4 | 3  | 3 |
| 5 | 5  | 4 |

|   |   |       |       |       |       |       |       |       |       |       |       |        |
|---|---|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|--------|
|   |   | $P_4$ | $P_1$ | $P_5$ | $P_4$ | $P_1$ | $P_3$ | $P_5$ | $P_3$ | $P_2$ | $P_5$ | $P_2$  |
| 0 | 3 | 5     | 7     | 9     | 10    | 12    | 14    | 16    | 18    | 20    | 22    | 23, 25 |

Pr. Pr.

$P_{no}$  AT BT IOBT BT  $TQ=2$

|   |   |   |   |   |
|---|---|---|---|---|
| 1 | 0 | 3 | 5 | 4 |
| 2 | 2 | 5 | 8 | 1 |
| 3 | 3 | 2 | 2 | 2 |

$R_Q: P_1 P_2 P_1 P_3 P_2 P_3 P_2 P_1$

|   |       |       |       |       |       |       |       |       |       |                |
|---|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------------|
|   | $P_1$ | $P_2$ | $P_1$ | $P_3$ | $P_2$ | $P_3$ | $P_2$ | $P_1$ | $P_1$ | $\cancel{P_2}$ |
| 0 | 2     | 4     | 5     | 7     | 9     | 11    | 12    | 14    | 16    | 20             |

Pr. : 20..(9) 10..(10) 20..(20)

Q1. Consider a set of 4 processes, A B C D arriving in the order at time 0. Their burst time req are : 4, 1, 8, 1 respectively. Using RR scheduling with  $TQ = 1$ . The completion time of process A is 9.

|   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|
| A | B | C | D | A | C | A | C | A |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |

Q2. Consider a system using RR Scheduling with 10 processes all arriving at time 0. Each process is associated with 20 identical request. Each process request consumes 20 ms of CPU time after which it spends 10 ms of time on I/O thereafter, initiates Subsequent request. Assuming Scheduling overhead of 2ms and

TQ of 20ms. Calculate:

(i) Response time of 1<sup>st</sup> request of 1<sup>st</sup> process. - Ans: 22 ms

(ii) Response time of 1<sup>st</sup> request of last process - Ans: 220ms

(iii) Response time of Subsequent req. of any process - Ans: 210ms



### Performance of Round Robin

very small:

Efficiency = 0

Time Quantum.

Small

Large

very large: worse like FCFS

→ More context switching (overhead)

→ Less context switching (less overhead), poor interactivity, responsiveness.

Makes the system

better responsive

- Q1. Consider a System with 'n' processes arriving at time  $0^+$  with substantially large BT. The CPU scheduling overhead is 's' seconds, Time quantum is 'q' seconds. Using RR scheduling what must be value of time quantum 'q' such that each process is guaranteed to get its turn at CPU exactly after 't' seconds in its subsequent run at CPU.

$$\rightarrow t - ns = (n-1)q$$

$$\Rightarrow q = \frac{t - ns}{n-1}$$



i)  $q_r = \left( \frac{t - ns}{n-1} \right)$  : process will get into CPU exactly after  $t$  seconds.

ii)  $q_r < \left( \frac{t - ns}{n-1} \right)$  : process will get into CPU earlier than  $t$  seconds.

iii)  $q_r \geq \left( \frac{t - ns}{n-1} \right)$  : process will get into CPU after every  $t$  seconds

HW

Q2. Consider the following set of processes, assumed to have arrived at time 0. Consider the CPU scheduling algorithm (SJF) and RR. Order: P<sub>1</sub>, P<sub>2</sub>, P<sub>3</sub>, P<sub>4</sub>.

Processes: P<sub>1</sub> P<sub>2</sub> P<sub>3</sub> P<sub>4</sub>

Times: 8 7 2 4

The time quantum for RR is 4 sec, then the absolute value of average turnaround time in SJF and RR is

SJF

| CPU | P <sub>3</sub> | P <sub>4</sub> | P <sub>2</sub> | P <sub>1</sub> |
|-----|----------------|----------------|----------------|----------------|
| 0   | 2              | 6              | 13             | 21             |

RR

|    |   |   |   |   |
|----|---|---|---|---|
| 0  | 4 | 0 | 4 | 0 |
| 4  | 0 | 4 | 0 | 4 |
| 8  | 0 | 4 | 0 | 4 |
| 12 | 0 | 4 | 0 | 4 |

$$\text{Avg TAT} = \frac{21 + 13 + 2 + 6}{4}$$

$$= \frac{42}{4} = 10.5$$

HW

Q3. Consider processes P<sub>1</sub> and P<sub>2</sub> arriving in RQ at time 0 with:

i) P<sub>1</sub> needs a total of 12 units of CPU time and 20 units of I/O time. After every 3 units of CPU time P<sub>1</sub> spends 5 units on I/O.

ii) P<sub>2</sub> needs a total of 15 units of CPU time and no I/O. P<sub>2</sub> arrives just after P<sub>1</sub>.

Compute the completion time of P<sub>1</sub> and P<sub>2</sub> using SRTF & RR.

Q4. Consider 4 processes P, Q, R, S scheduled on a CPU as per RR algorithm with  $TQ=4$  units. Processes arrive in order P, Q, R, S all at time  $t=0$ . There is exactly one context switch from S to Q, exactly one context switch from R to Q and exactly two context switches from Q to R. There is no context switch from S to P. Switching to a ready process after termination of another process is also considered a Context Switch.

Q5. Which of the following statements is/are correct in context of CPU Scheduling?

- A. The goal is to only maximize CPU utilization and minimize throughput
- B. Turnaround time includes waiting time
- C. Implementing pre-emptive scheduling needs hardware support
- D. RR policy can be used even when the CPU time required by each of the processes is not known a priori

### 8. Multi Level Queue Scheduling:



9. Multilevel feedback Queue Scheduling :

- \* Another way to put a reference on short lived processes, penalize processes that have been running longer.
- \* Pre emptive.

Q6. Consider a system which has CPU bound process, which require the burst time of 80 seconds, the multilevel feedback queue scheduling algorithm is used and the queue time quantum is '4' sec and in each level it is incremented by '10' seconds. Then how many times the process will be interrupted, and on which queue the process will terminate the execution?

Ans : 4, 5.

$$TQ = 4$$

$$B.T = 80 \text{ ms}$$

$$4 + 4 + 24 + 34 = \underline{\underline{80}}$$

$$TQ = 14$$

$$TQ = 24$$

$$TQ = 34$$

$$TQ = 44$$

Burst quantum

Preempt

Deadline quantum

Context switching

Process switch

Process switch

## Synchronization

\* **IPC:** Inter process communication is a mechanism that allows processes to communicate with each other and synchronize their actions.

Every communication should be synchronized / co-ordinated  
→ Lack of synchronization in IPC environment leads to:

1. Inconsistency (Incorrectness)
2. Loss of data
3. Deadlock (lockup)

**Synchronization:** It is agreed upon protocol in an IPC environment, to make sure that there is no inconsistency, data loss or deadlock.

### IPC Environment:



\* Synchronization involves the orderly sharing of system resources by processes.

\* We can think of this intersection as a system resource that is shared by two resources.

### Types of Synchronization.

#### Competitive

Two or more processes are said to be in competitive sync. if they compete for accessibility of a shared resource.



#### Co-operative

Two or more processes are said to be in Co-operative synchronization if they get affected by each other. i.e. execution of one process affects the other process.

Ex: Producer-consumer problem

- Note:
- \* Lack of synchronization among completing processes may lead to either inconsistency, dataloss.
  - \* Lack of synchronization among co-operating processes may lead to deadlock.
  - \* An application of an IPC environment may involve either competition or cooperation or both type of synchronization



- Note:
- \* Sometimes we get correct results and other times it is possible to get incorrect results.
  - \* As an end user we want a solution, that always gives correct result whether preemptions take place or not.

### Implementation of producer consumer problem

```
#define N 100
```

```
int buffer[N];
```

```
int count = 0; {NO. of data items in buffer}
```

Void Producer (void)

```
{ int itemp; in = 0;
  while (1)
```

{

~~NC8~~ a) itemp = Produce-item();

~~CS b)~~ while (count == N); *busy waiting*

~~CS c)~~ Buffer [in] = itemp;

~~CS d)~~ in = (in + 1) % N;

~~CS e)~~ count = count + 1; }

}

Void Consumer:

```
{ int itemC, out = 0;
  while (1)
```

{ a) while (count == 0);

b) itemC = Buffer [out];

c) out = (out + 1) % N;

d) count = count - 1;

e) Process-item(); }

*Busy waiting*

## Necessary Conditions for Synchronization Problems.

1. Critical Section: It is that part of the program where shared resources are accessed.
2. Race conditions: Situation where two processes are trying to access Critical section and final result depends on the order at which they finish their update.
3. Preemption:



Note: Process running in User mode can get prompted any time and any number of times (After completing any instance).

## Requirements of C.S. Problems:

1. Mutual Exclusion (m/E): If process  $P_i$  is executing in its Critical Section then no other process can be executing in their Critical Sections.
2. Progress: If no process is executing in its Critical Section and some processes wish to enter their Critical Sections, then only those processes that are not executing in their remained Sections can participate in deciding which will enter its Critical Section next and this Selection cannot be postponed independently.
3. Bounded waiting: There exist a bound, or limit, 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.

Note: \* If mutual exclusion is not guaranteed then inconsistency + data loss may happen.

\* If bounded waiting is not guaranteed then starvation.

\* If progress is violated then it is an unfair solution (Indefinite postponement).

## Synchronization Mechanism



Assumptions:

- \* Process enters <CS> and come out of it in finite amount of time.
- \* When a process is in entry section then it means, it is interested in <CS>.
- \* A process is said to have left CS only when it has executed its Critical Section.
- \* A process can get pre-empted from CPU while executing entry + <CS> + Exit Section.

1. Lock Variable:

- Busy waiting Solution
- Software Solution implementation at user mode
- Multi process Solution.



Implementation : High Level

```
int lock = 0;
Void process (int i)
{
    while (1)
    {
        a). NON-CS
        b). while (lock != 0);
        lock = 1;
        c). CS
        d). lock = 0; } }
```

The code implements a high-level lock mechanism. It starts with an integer variable 'lock' set to 0. The 'process' function enters a loop. Inside the loop, it first checks if 'lock' is not equal to 0 (Non-CS). If it is not, it enters a 'while' loop that continues until 'lock' is 0. Once 'lock' becomes 0, it is set to 1 (CS). After the CS section, it is set back to 0 (Exit Section).

Implementation : Low Level.

```
integer lock = 0;
Process (int i):
```

- a) NON-CS
- b) Load R1, lock;
- c) Compare R1, #0; } Entry Section
- d) JNZ Step b; } Section
- e) Store lock, #1;
- f) <CS>.
- g) Store lock, #0 } Exit Section

\* Lock variable does not always guarantee mutual exclusion along with bounded wait.

- Note :
- \* Lock variable does not guarantee mutual exclusion always.
  - \* Lock variable guarantees progress always.
  - \* Lock variable fails to satisfy bounded wait.
  - \* Because a process can enter CS multiple times successfully while other processes are waiting for their turn to enter 'CS'.
  - \* Lock variable is a busy waiting solution leading to wastage of CPU time / cycles (in the loop).

Q1. Several concurrent processes are attempting to share an I/O device. In an attempt to achieve M/E each process is given the following structure.

<code unrelated to device use>

Repeat

until  $\text{busy} = \text{false}$ ;

$\text{busy} = \text{true}$ ;

<code to access shared>

$\text{busy} = \text{false}$ ;

<code unrelated to device use>

Which of the following is/are true of this approach?

- I. It provides a reasonable solution to the problem of guaranteeing M/E
- II. It may consume substantial CPU time accessing the Busy variable.
- III. It will fail to guarantee mutual exclusion.

## 2. Strict Alternation:

- Busy waiting
- Software solution implementable at user mode
- Two process solution ( $P_1 | P_2$ )



"Strictly one alternate basic process takes turn to enter CS."

Implementation: High Level.

```
int turn = rand(0,1);
```

```
void process(0)
```

{

```
while(1)
```

```
{ a> NON-CC();
```

```
b> while(turn!=0)
```

```
c> CS
```

```
d> turn=1; }
```

}

```
void process(1)
```

```
{ b> CS;
```

```
{ a> NON-CC();
```

```
b> while(turn!=1);
```

```
c> CS
```

```
d> turn=0; }
```

}

- \* Strict alternation always guarantees mutual exclusion.
- \* Strict alternation does not guarantee progress.
- \* Strict alternation always guarantees bounded waiting.
- \* Like lock variable this is a busy waiting solution which leads to wastage of CPU time/cycles.

Generalised Implementation of Strict Alternation:

```
int turn = rand(i,j);
```

```
void process(int i)
```

```
{ int j = NOT(i);
```

```
while(1)
```

```
{ a> NON-CC();
```

```
b> while(turn!=i)
```

```
c> CS
```

```
d> turn=j; }
```

}

Q2 Consider the following two-process synchronization  
solution.

## Process 0

Entry: loop while ( $\text{turn} = 1$ );  
 (critical section)

Exit:  $\text{turn} = 1$ ;

## Process 1

Entry: loop while ( $\text{turn} = 0$ );  
 (critical section)

Exit:  $\text{turn} = 0$ ;

The shared variable turn is initialized to zero. Which of the following is true?

Ans: This solution violates progress requirement.

Q3. Code Snippet:

```
int turn=0;
void Process(0)
{
  while(1)
  {
    a>.NON-CS();
    b>.while (turn==1);
    c>.CS
    d>.turn=1;?
  }
}
```

```
void process(1)
{
  while(1)
  {
    a>.NON-CS();
    b>.while (turn==1);
    c>.CS
    d>.turn=1;?
  }
}
```

Does the above code guarantee mutual exclusion?

Ans No.

\* If  $\text{turn} = 1$ ; then it will result in deadlock as no process can enter in the Critical Section.

```

Q4. int turn = rand(i, j);
void Process (int i)
{
    int j = NOT (i);
    while (1)
    {
        a) NON-CSI;
        b) while (turn != i);
        -turn = j;
        c) CS
        d) turn = j; }
}

```

i) Does this guarantee T/E?

T/E is not guaranteed.

ii) Progress?

iii) Bounded Wait?

### 3. Peterson's Solution:

- Busy-waiting
- Software Solution implemented at user mode
- Two process Solution
- Combination of Lock & Strict alternation.

```

#define N 2
#define True 1
#define False 0
int flag[N] = {False};
int turn;

void Process (int i)
{
    int j = NOT(i);
    while (1)
    {
        a) NON-CSI;
        b) flag[i] = True;
        c) turn = i; -j
        d) while (flag[j] == True and turn == i);
        e) CS;
        f) flag[i] = False; }
}

```

Note: Peterson's Solution

guarantees T/E always.

- \* It guarantees progress
- \* It guarantees bounded waiting.

Qs. void DekkersAlgorithm(int i)

{

int j = !(i);

while (1)

{

a) NON-CS();

b) flag[i] = True;

c) while (flag[j] == True);

{ if (turn == j)

{ flag[i] = False;

while (turn == j);

flag[i] = True }

}

d) CS

e) flag[i] = False;

turn = j;

}

\* Dekkers algorithm is a variation of peterson's algorithm and is a correct solution.

Analyse the solution.

Q6 Process P<sub>1</sub> and P<sub>2</sub> hold/use Critical flag in the following routine to achieve互斥. Assume that Critical-flag is initialised to false in main program.

get-exclusive-access()

{ if (critical-flag == False)

{ critical-flag = True;

Critical-region();

critical-flag = False; }

}

Consider the following statements

- I. It is possible for both P<sub>1</sub> and P<sub>2</sub> to access Critical region Concurrently.

- II. This may lead to a deadlock

Ans I. is true and II is false..

Q7. Two processes P<sub>1</sub> and P<sub>2</sub> need to access a critical section of the code. Consider the following synchronization construct used by the process.

|P<sub>1</sub>|

```
while (true)
{
    wants1 = true;
    while (wants2 == true);
    |CS1|
    wants2 = false; }
```

|Remainder Section|

|P<sub>2</sub>|

```
while (true)
{
    wants2 = true;
    while (wants1 == true);
    |CS2|
    wants1 = false; }
```

|Remainder Section|

Here wants<sub>1</sub> and wants<sub>2</sub> are shared variables which are initialised to false. Which of the statements are true.

- I. It does not ensure M/E.
- II. It does not ensure bounded waiting.
- III. It requires that processes enter Critical Section in strict alternation
- IV. It does not prevent deadlock but ensured M/E.

Q8. Two processes X and Y need to access a critical section. Consider the following synchronization construct used by both.

Process X

```
while (true)
{
    varP = true;
    while (varQ = true)
    {
        |CS1|
        varP = false; }
```

Process Y

```
while (true)
{
    varQ = true;
    while (varP == true)
    {
        |CS1|
        varQ = false; }
```

Here varP and varQ are shared variables and both initialised to false. Which of statements are true?

- I. The proposed solution prevents deadlock but fails to guarantee M/E.
- II. It guarantees M/E but fails to prevent deadlock.
- III. It guarantees M/E and prevents deadlock.
- IV. It fails to prevent deadlock and M/E.

### Synchronization Hardware:

Each processor supports some support instructions (H/W) that are atomic <Executive non preemptively>

a) TSL

b) SWAP.

→ Busy waiting

→ Can be used at user mode as spl. instructions

→ Hardware Category

→ Multi process Solution

→ Lock based Solution.

a) TSL : Test and Set Lock

TSL (&Lock); < Process executing TSL, returns the current value of lock and sets the value of lock always to True >

Bool TSL (Bool \*target)

```
{ Bool rv;
  rv = *target;
  *target = True;
  return (rv); }
```

Completely runs on Kernel mode  
(Atomic)

## Solving CS Problem through TSL

```

Bool lock = false;
void Process (int i)
{
    while (1)
    {
        a) NON-CSC;
        b) while (TSL(&lock) == True);
        c) {CS}
        d) Lock = F; }
    }
}

```

\* This solution guarantees mutual exclusion.

\* Does not guarantee bounded waiting.

## b) SWAP Instruction (ATOMIC)

```

SWAP (Bool *a, Bool *b)
{
    Bool t;
    t = *a;
    *a = *b;
    *b = t; }
}

```

- \* Guarantees mutual exclusion
- \* Guarantees progress
- \* Guarantees bounded waiting.

### User process :

```

Bool lock = False;
void Process (int i)
{
    Bool key = True;
    while (1)
    {
        a) NON-CSC;
        b) while (key == True)
            SWAP (&lock, &key);
        c) CS
        d) Lock = False; }
    }
}

```

Q9. The enter-CS(); and leave-CS() functions to implement Critical Section of a process and are realised using test-and-set instructions as follows:

void enter-CS(x)

{ while (test-and-set(x)); }

void leave-CS(x)

{ x=0; }

In the above solution,  $X$  is a memory location associated with the CS and is initialised to 0. Now consider:

- I. The above solution to CS problem is deadlock free.
- II. Solution is starvation free.
- III. The process enters CS in FIFO order
- IV. More than one Process Can enter CS at Same time

### Priority Inversion Problem

All correct busy waiting Software solutions suffer from Priority inversion problem. This problem happens on Preemptive Priority based scheduling



- \* If  $P_H$  is not interested in CS then there is no problem
- \* If  $P_H$  is also interested in CS, then it results in "Deadlock"

- Q10.** Fetch-And-Add ( $x, i$ ) is a atomic Read-modify-Write instruction that reads the value of memory location  $x$ , increments it by the value  $i$  and returns the old value of  $x$ . It is used in the pseudocode shown below to implement a busy-wait lock.  $L$  is an unsigned integer Shared Variable initialised to 0. The value of 0 corresponds to lock being available, while any non-zero value corresponds to the lock being not available.

Acquire Lock ( $L$ )

{ while (Fetch-And-Add( $L, 1$ ))  
 $L=1;$  }

Release Lock ( $L$ )

{  $L=0$  }

This implementation:

- I. fails as  $L$  can overflow
- II. fails as  $L$  can take on a non-zero value when lock is actually available
- III. works correctly but may starve some process.
- IV. works correctly without starvation.

Analysis:

RQ.  $[P_1 P_2 P_3]$

$\phi X_2$  Lock

int lock = 0

$P_1$

CS

Entry while (Fetch-And-Add(&lock, 1))

$L=1;$

<CS>

Exit  $L=0;$

which are read as per need

\* If MSQ asked, I. also correct  
 in rare case

I:

$t_1 : (P_1) : F\ A\ -A : \rightarrow 0$

$t_2 : (P_2) : F\ A\ -A : \rightarrow 01$

II:

$t_1 : (P_1) : F\ A\ -A : 0 : <CS> \dots P_n$

$t_2 : (P_2) : F\ A\ -A : 1 : P_1 <L=1>$

$t_3 : (P_1) : <CS>$

$t_4 : (P_2) : L=1, F\ A\ -A = 1$

Blocking Mechanism / Non-busy waiting

- to avoid wastage of CPU time in the form of loops.
- all blocking mechanisms are implemented using "if-else-thus".

There are three mechanisms:

1. Sleep-wakeup
2. Semaphores
3. Monitors.

## 1. Sleep() and Wakeup():

- Blocking Construct
- Multi process solution
- Are OS primitives
- When process executes Sleep() - gets blocked till some other process wakes it up (wakeup)

### Producer-Consumer using Sleep() and Wakeup()

```
#define N 100
int buffer[N];
int count = 0;
```

```
Void Producer(void)
{
    int itemp, i=0;
    while(1)
    {
        a) itemp = produce-item();
        b) if (Count == N) Sleep();
        c) Buffer[N] = itemp;
        d) i = (i+1) % N;
        e) Count = Count + 1;
        f) if (Count == 1) wakeup(consumer);
    }
}
```

```
Void Consumer(void)
```

```
{
    int itemc, out = 0;
    while(1)
    {
        a) if (Count == 0) Sleep();
        b) itemc = Buffer[out];
        c) out = (out+1) % N;
        d) Count = Count - 1;
        e) if (Count == (N-1)) wakeup(producer);
        f) Process-item(itemc);
    }
}
```

\* When producer and consumer both try to update the value of count, leads to "inconsistency".

Two problems with this implementation

- i. Inconsistency
- ii. Deadlock.

## Semaphores

- \* Blocking construct
- \* OS based < is an OS resource (S/W) >
- \* General purpose utility
  - <CS>
  - Requirements of classical IPC Problem
  - Concurrency mechanisms?
- \* It was proposed by E. Dijkstra
- \* Semaphore is implemented as an abstract data type.

Definition: Semaphore is a variable

<ADT: SEM> that takes only  
integer values.

### Operations

down()      up()  
wait()      signal()  
P()      V()

### Types

1. Binary (mutex)      2. Counting (General)

$\langle 0, 1 \rangle$

$\langle -\infty \text{ to } \infty \rangle$

### Counting Semaphore $\langle -\infty \text{ to } \infty \rangle$

#### UM:

#### TypeDef

```
struct
{
  int value;
  QueueType L;
} CSME;
```

List of PCBs of those

processes that get blocked while performing down operation unsuccessfully.

CSEM S;

S.value = 1;

(S=1);

Down(S);

$\langle S_i \rangle$

Next Statement.

KM:

DOWN (CSEM S)

{

1. S.value = value - 1;
  2. if (S.value < 0) || unsuccessful
 

{ Put this process PCB  
in the S.L(Q) and block  
the process (Sleep); }
- else
- return; } || success.

eg: CSEM S:

$S = 5;$

How many DOWN Operations  
can be carried out by  
process successfully?

$S = \$ \# \# \# \# \# - 1.$

 $\rightarrow \boxed{1} \boxed{1} \boxed{1} \boxed{1} \boxed{1} \boxed{1}.$ 

Successful after this process  
down opr's. get blocked

- \* Positive value of Semaphore indicate that those many down operations can be carried out successfully.
- \* After carrying out a series of down operations, if the value of Semaphore becomes negative, then the magnitude of the negative value indicates the number of blocked processes.



(CSEM S;

$S = 1;$

UP (CSEM S)

{

1. S.value = S.value + 1;
2. if (S.value < 0)
 

{ Select a process from  
S.L(Q) and wake up(); }

else

return; }

Block Queue.  
 $S = 1;$   
 $\emptyset - X - Z - \emptyset = 1.$   
 blocked (down)      (up)

- \* If the value of S is less than or equal to '0' then there are blocked process in queue.

Q1. CSEM S=8;

Operations : 10P, 1V, 15P, 2V, 6P, 3V  
 $-2 \quad -1 \quad -16 \quad -14 \quad -20 \quad -17.$  What is current value?

Current value of S = 17.

Q2. CSEM S=?

Operations : 12P, 4V, 6P, 3V, 8P, 1V, Final value is -6.

What should be initial value of S?

Initial value of S should be 12.

Q3. Consider a non-negative Counting Semaphore S. The operation P(S) decrements S, and V(S) increments S. During an execution, 20 P(S) operations and 12 V(S) operations are issued in some Order. The largest initial value of S for which atleast one P(S) operation will remain blocked 7

### Binary Semaphore <0,1>

```
typedef
struct
{
    enum value(0,1);
    QueueType L;
} BSEM;
```

→ List of PCBs that  
 gets blocked while performing  
 down operation unsuccessfully.

#### VM:

BSEM S;

S=1;

DOWN(S);

<Next>

DOWN(BSEM S)

{ if (S.value == 1)

{ S.value = 0; // Success

return; }

else

{ put this process (PCB)  
 in S.L() and

block it (sleep()); }

}

\* In binary Semaphore we don't get to know the no. of blocked processes because no negative numbers after down operations.

UP (BSEM S)

```

    {
        if (S.L(Q) is NotEmpty)
            {
                Select a process from
                S.L(Q) and wakeup();
            }
        else
            S.value = 1;
    }
  
```

Cases of Binary Semaphores

|                                                                         |                                                                                                 |                                                                                                                       |
|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| 1. BSEM S;<br><br>S=1;<br><br>P(S);<br><br>S=0<br><br>Status = Success. | 2. BSEM S;<br><br>S=0;<br><br>P(S);<br><br>S=0<br><br>Status = Unsuccessful.                    | 3. BSEM S;<br><br>S=0;<br><br>V(S);<br><br>S → 0 : if 'Q' not empty<br>1 : if 'Q' empty.<br><br>Status = Success.     |
| 4. BSEM S;<br><br>S=1;<br><br>V(S);<br><br>S=1<br><br>Status = Success. | 5. BSEM S;<br><br>S=0;<br><br>V(S); // first operation.<br><br>S=1.<br><br>Status = Successful. | Note:<br><br>As long as there is a<br>process in "Cs" & process<br>in block 'Q' then<br>value of BSEM must<br>be '0'. |

Q4

BSEM S=1;

Operations: 10P, 2V, 18P, 3V, 4P, 5V;

(i) Final value of S?

(ii) Size of 'Q' [L]?

S=X 0

10P, 2V, 18V, 3V, 4P, 5V;

Final value of S=0

and 21 blocked processes.

L → 9 7 25 24 26 21

Both binary and counting Semaphore can be used to solve the problems of CS.



Q1. BSEM  $S=1, T=1$ ;

$Pr(i)$   
 $\{$  while (1)  
 $\{$   $P(S);$   $\rightarrow$  To prevent deadlock  
 $P(T);$   $\}$   
 $\langle CS \rangle$   
 $V(T);$   
 $V(S); \}$   
 $\}$

$Pr(j)$   
 $\{$  while (1)  
 $\{$   $P(T);$   
 $P(S);$   
 $\langle CS \rangle$   
 $V(S);$   
 $V(T); \}$   
 $\}$

Does it guarantee M/E?  
and deadlock?  
Yes it guarantees M/E but  
it is not deadlock free.

To prevent it from deadlock  
Swap down operation in  
one process. Both process  
down opns. should be same.

Q2. BSEM  $S=1, T=0$

$Pr(i)$   
 $\{$  while (1)  
 $\{$   $P(T);$   
 $Print('1');$   
 $Print('1');$   
 $V(S); \}$   
 $\}$

$Pr(j)$   
 $\{$  while (1)  
 $\{$   $P(S);$   
 $Print('0');$   
 $Print('0');$   
 $V(T); \}$   
 $\}$

What will be output?  
00110011...  
Does it guarantee  
1. M/E ✓  
2. Progress ✗  
3. Bounded wait ✓

This is a implementation of "since alternation" using semaphores

Q3. BSEM  $m[0..4] = \{1\};$  $P_i(i) \ i=0,4$ 

(i). Does it guarantee m/e?

No

{ while(1)

{ P( $m[i]$ );

(ii) If m/e is not guaranteed then max no. of processes that can be in CS?

P( $m[(i+1) \cdot 4]$ ); $m[0] = X_0$ 

&lt;CS&gt;

 $m[1] = X_0$ CS:  $P_0, P_2$ . $\begin{cases} P_1 \\ P_3 \\ P_4 \end{cases}$  } blockedV( $m[i]$ ); $m[2] = X_0$ V( $m[(i+1) \cdot 4]$ ); } $m[3] = X_0$ 

{ }

 $m[4] = X_0$ 

∴ 2 processes in CS

\* Deadlock can occur.

Q4. BSEM = 1, T=0, Z=0

 $P_i(i)$ 

{ while(1)

 $P_j(j)$  $P_k(k)$ 

{ P(s);

{ P(t);

{ P(z);

Print(\*);

V(s); }

V(s); }

V(t);

V(z); }

What is min and max no of \* that get printed?

{ }

Case I:  $P_{ri}, P_{rj}, P_{rk}, P_{ri} \rightarrow 2$  blkdI: <\*\*> : minimum  $\rightarrow 2$ Case II:  $P_{ri}, P_{rj}, P_{ri}, P_{rk}, P_{ri}$ II: <\*\*\*> : maximum  $\rightarrow 3$ .

Variation: BSEM S=1, T=0, Z=0;

 $P_{ri}$ 

{ while(1)

 $P_r;$  $P_{rk}$ 

{ P(s);

{ P(t);

{ P(z);

Print(\*);

V(z); }

V(s); }

{ }

In this variation the min and max no of stars to be printed = 2;

Qs. Consider the following processes  $T_1, T_2, T_3$  executing on a single processor, synchronized using three binary Semaphore Variables  $S_1, S_2$  and  $S_3$ , operated upon using Standard wait() and Signal(). The threads can be context switched in any order and at any time. Which.

Which initialization of Semaphores would print sequence BCABCABC...?

$T_3$

while (true)

{ wait ( $S_2$ );  
Print ("A");  
Signal ( $S_1$ ); }

Ans:  $S_1=1$        $S_2=0$        $S_3=0$

$T_2 \rightarrow T_1 \rightarrow T_3$

Qs Consider a Counting Semaphore initialized to 2, there are 4 concurrent processes  $P_i, P_j, P_k$  and  $P_l$ . The processes  $P_i$  and  $P_j$  desire to increment the current value of variable  $C$  by 1 whereas  $P_k$  and  $P_l$  desire to decrement the value of  $C$  by 1. All processes perform their update on  $C$  under Semaphore control. What can be the min and max value of  $c$  after all processes finish their update?



Assuming initial value of  $c = 0$

Process (a)

{  $P(s);$        $x=i, j, k, l$   
 $\langle C = C \pm 1 \rangle$        $= +1 = -1$   
 $V(s);$  }

Q7. Consider three processes using four binary Semaphores a,b,c,d in the order shown below.

Which is sequence is a deadlock free sequence?

X : P(b); P(a); P(c);       $a=b=c=d=1$ . } Initialized.

Y : P(b); P(c); P(d);

Z : P(a); P(c); P(d);

Q8. Each of a set of  $n$  processes execute the following code using two semaphores a and b initialized to 1 and 0 resp. Assume that count is a shared variable initialized to 0 and not used in Code Section P.

<Code Section P>

wait(a);

Count = Count + 1;

if (Count == n) signal(b);

signal(a); wait(b); signal(b);

<Code Section Q>

What does Code achieve?

It ensures that no process executes code section Q

before every process has finished code section P.

HW

Q9. Consider two functions Incr() and Decr()

GATE 2023

Incr()

{ wait(s); }  
 $x = x + 1;$   
 Signal(s); }

Decr()

{ wait(s); }  
 $x = x - 1;$   
 Signal(s); }

Five processes invoke Incr() and three processes invoke Decr()

x is a shared variable initialized to 10.  $(10+5-3)=12$

I<sub>1</sub>: S value is 1 (Bin.Sem.)  $\max / \min = 12$

I<sub>2</sub>: S value is 2 (Counting.Sem.)

Let V<sub>1</sub> and V<sub>2</sub> be min possible values of implementation of I<sub>1</sub> and I<sub>2</sub> then choose the value of x for V<sub>1</sub> and V<sub>2</sub>.

- Q1. Which of the following may result in a process getting blocked?
- a. DOWN  
 b. UP.  
 c. System-call  
 d. Scheduler dispatch.

### Classical IPC Problems

#### 1. Producer Consumer Problem:

```
#define N 100
int Buffer[N];
CSEM Empty = N;
<No of empty slots>
CSEM Full = 0;
<No. of full slots (data-items)>
BSEM mutex = 1;
<used b/w P and C to
ensure M/E on buffer>
```

#### void Producer (void)

```
{ int temp, in=0;
while (1)
{
    a). itemp = produce-item();
    b). Down (Empty);
    c). Down (mutex);
    d). Buffer[in] = itemp;
    e). in = (in+1) * N;
}
f). UP (mutex);
g). UP (full);
```

#### void Consumer (void)

```
{ int itemc, out=0;
while (1)
{
    a). Down (full);
    b). Down (mutex);
    c). itemc = Buffer[out];
    d). out = (out+1) * N;
    e). UP (mutex);
    f). UP (empty);
    g). Process-item (itemc);
}
```

Q1. Consider the following solution to the P-C Sync. problem. Shared buffer size is N. Three semaphores empty, full and mutex are declared with respective initial values of 0, N and 1. Semaphore empty denotes the no. of available slots in the buffer, for consumer to read from. Semaphore full denotes no of available slots in the buffer, for producer to write to. The placeholder variable denoted by P, Q, R, and S in code below can be assigned either empty or full.

Producer:

```
do{
    wait(P);
    wait(mutex);
    // add item - buffer
    signal(mutex);
    signal(Q);
}
while(1);
```

Consumer:

```
do{
    wait(R);
    wait(mutex);
    // consume item - buffer
    signal(mutex);
    signal(S);
}
while(1);
```

Which of the assignments of P, Q, R, and S yield correct solution?

Ans P: full, Q: empty, R: empty, S: full

Q2. Consider the procedure below for P-C problems using semaphores:

Semaphore n=0;

Semaphore s=1;

void Producer()

```
{
    while(true)
    {
        produce();
        semWait(s);
        addToBuffer();
        semSignal(s);
        semSignal(n);
    }
}
```

void Consumer()

```
{
    while(true)
    {
        semWait(s);
        semWait(n);
        removeFromBuffer();
        semSignal(s);
        consume();
    }
}
```

Ans. Deadlock occurs when if the consumer succeeds in acquiring semaphores when buffer is empty.

Q. Reader Writer Problem.



BSEM mutex = 1;  
 {  
   P(mutex);  
   <DB>  
   V(mutex); }  
 }

First Reader Writer Problem.

t<sub>1</sub>: r<sub>1</sub> and w<sub>1</sub> : Anyone  
 t<sub>2</sub>: r<sub>1</sub>; ✓ w<sub>1</sub> (wait)  
 -t<sub>3</sub>: r<sub>2</sub>; ✓ ✓  
 t<sub>4</sub>: r<sub>3</sub>;



t<sub>1</sub>: r<sub>1</sub> and w<sub>1</sub> : Anyone  
 t<sub>2</sub>: w<sub>1</sub>; ✓ r<sub>1</sub> (wait)  
 t<sub>3</sub>: w<sub>2</sub>; ✗ (wait)



problem: starvation to writer.

Implementation of first R-W using Semaphore

int rc = 0;  
 BSEM mutex = 1;  
 <used by R's to update>  
 BSEM db = 1;  
 <used by R's and W's to access <DB> as CS>

Void reader (void)  
 {  
   while (1)  
     {  
       a). Down (mutex);  
       b). <DB-Ready>  
       c). UP (db); }  
 }

Void Reader (void)  
 {  
   while (1)  
     {  
       a). Down (mutex);  
       b). rc = rc + 1;  
       c). if (rc == 1) Down (db);  
       d). UP (mutex);  
       e). <DB-Ready>  
       f). Down (mutex);  
       g). rc = rc - 1;  
       h). if (rc == 0) up (db);  
       i). Up (mutex); }  
 }

Q. Synchronization in the classical readers and writers problem can be achieved through use of semaphores. In the following incomplete code for readers-writers problem, two binary semaphores

mutex and wrt are used to obtain sync.

Wait (wrt)

If waiting is performed

Signal (wrt)

Wait (mutex)

readCount = readCount + 1

If readCount == 1, then "S1"

"S2"

If reading is performed

"S3"

readCount = readCount - 1

If readCount == 0 then "S4"

Signal (mutex)

The values of S1, S2, S3, S4 in that order are:

Ans: Wait (wrt), Signal (mutex),  
Wait (mutex), Signal (wrt).

### 3. Dining Philosophers Problem

'N'- Philosophers ( $N \geq 2$ )

#define N 5

void Philosopher (int i)

```
{
    while (1)
    {
        a> think (i);
        b> take-fork (i);
        c> take-fork ((i+1)%N);
        d> eat (i);
        e> put-fork (i);
        f> put-fork ((i+1)%N); }
```

If all become hungry  
Causes "Deadlock"

Without deadlock, for  $N=5$  what is the max no of philosophers that can be eating?

P0 : f0, f1 ✓

P1 : x Ans: 2

P2 : f2, f3 ✓

P3 : f4

P4 : f4, f0 x

## Prevent/Avoid Deadlock in Dining Philosophers



Q4. A solution to the dining philosophers problem which avoids deadlock is:

Ensure that one particular philosopher picks up the left fork before right fork, and all other philosophers pick up right before left fork.

Q5. Let  $m[0..4]$  be mutual and  $P_0 - P_4$  be processes. Suppose each process  $P[i]$  execute the following

$\text{Wait}(m[i]) : \text{Wait}(m[i+1] \cdot |0..4|)$   
<CS>

which situation could occur?

$\text{release}(m[i]) ; \text{release}(m[i-1] \cdot |0..4|)$

Ans: Deadlock.

## Concurrency vs Sequentiality

$$\left\{ \begin{array}{l} S_1 : a = b + c; \\ S_2 : d = e * f; \\ S_3 : k = a + d; \\ S_4 : l = k * 10; \end{array} \right.$$

- I<sub>1</sub>: Load R<sub>1</sub>, b
- I<sub>2</sub>: Load R<sub>2</sub>, c
- I<sub>3</sub>: Add R<sub>1</sub>, R<sub>2</sub>
- I<sub>4</sub>: Store a, R<sub>1</sub>

\* Only S<sub>1</sub> and S<sub>2</sub> can perform concurrently (no dependency)



Precedence Graph  
(directed)

S<sub>i</sub> : High level language statement.

ConcurrencyParallelism

- \* A system is said to be concurrent if it can support two or more actions in progress at the same time.
  - \* Concurrency is about dealing with lots of things at once.
- A system is said to be parallel if it can support two or more actions executing simultaneously.
- Parallelism is about doing lots of things at once.

SequentialConcurrentParallelAn Analogy:

Concurrent : Two queue and one coffee machine

Parallel : Two queue and two coffee machines

Note:

- \* In Concurrency process will execute with preemption.
- \* Parallelism is possible with multiple CPUs/cores.
- \* Concurrency is about structure, parallelism is about execution.
- \* Concurrency provides a way to structure a solution to solve a problem that may (but not necessarily) be parallelizable.

\* The modern world parallel it has:

1. Multi Core
2. Networks.
3. Cloud of CPU's
4. Loads of users.

\* Concurrency makes parallelism easy.

### Types of Concurrency

1. Pseudo

(One CPU)

2. Real/Physical (Parallelism)

→ Multiple processing units

→ Interleaved execution

among processes/  
applications.

### Concurrency Conditions

$$\rightarrow S_i = a = b + c; \quad S_j = d = e * f;$$

$S \leftarrow R(S)$  : Read set  
 $W(S)$  : Write Set

\* Output of one statement should not serve as input to another

eg: (I)  $S : a = b + c$   
 $R(S) \rightarrow b, c$ ,  $W(S) \rightarrow a$ .

(II)  $S : a += b + -c;$   
 $R(S)$  and  $W(S) \rightarrow a, b, c$ .

(III)  $S : \text{scanf}("-d", &x);$   
 $R(S) \rightarrow \emptyset$   
 $W(S) \rightarrow x$

(IV)  $\text{printf}(x);$   
 $R(S) \rightarrow x$   
 $W(S) \rightarrow \emptyset$ .

Bernstein's Concurrency Conditions: I.  $R(S_i) \cap W(S_j) = \emptyset$

II.  $W(S_i) \cap R(S_j) = \emptyset$

III.  $W(S_i) \cap W(S_j) = \emptyset$

IV.  $R(S_i) \cap R(S_j) = \text{may/may not } \emptyset$

Concurrency mechanismsI. Parbegin - Paren / Cobegin - Coend :

eg: S1;  
**Parbegin**  
S2; S3;  
S4;  
begin S5; S6; end  
begin S7; S8; S9; end  
S10;  
**Parend**  
S11;



How many times  
parallel construct to  
be used?

Q1:

S1: BSEM a,b,c,d,e,f,g = {Φ}

Cobegin

begin S1; V(a); V(b); end

begin P(a); S2; S4; V(c); V(d); end

begin P(b); S3; V(e); end

begin P(c); S5; V(f); end

begin P(d); P(e); S6; V(g); end

begin P(f); P(g); S7; end

Coend

Q1. Draw the precedence graph for the concurrent program.

S1;

Parbegin

begin

S2; S4; end

S3;

Parbegin S5;

begin S6; S8; end

Parenend

end.

S7;

Parenend;

S9;



Q2.

void P(void)

{ A;  
B;  
C; }

void Q(void)

{ D;  
E; }

void main()

{ Parbegin  
P(); Q();  
Parenend; }

Valid Output Sequence: ABCDE

DEABC, ADBEC.

Q3.  $\text{int } x=0; y=0;$

Co begin

begin

$S_1: x=1;$

$S_2: y=y+x;$

end

begin

$S_3: y=2;$

$S_4: x=x+3;$

end

Co end.

Final values of x and y

I.  $x=1, y=2$

II.  ~~$x=1, y=3$~~

III.  ~~$x=4, y=6$~~

Statements  $S_3, S_4, S_1, S_2$  result in  $x=1, y=3$ .

Statements  $S_1, S_3, S_4, S_2 \rightarrow x=4, y=6$

Q4.  $\text{int } x=0, y=20;$

Bsem:  $mz=1; my=1;$

Final possible value  
of x 21, 23

Co begin

begin

P( $mz$ );

$x=x+1;$

V( $my$ );

end;

begin

P( $mx$ );

$x=y+1;$

V( $mz$ );

end

Co end

HW

Q5. integer B=2;

P1()

{  
  C=B-1;  
  B=2<sup>+C</sup>;  
}

P2()

{  
  D=2<sup>+B</sup>;  
  B=D-1;  
}

main()

{  
  Par begin  
    P1()  
    P2()  
  Par end.  
}

The no. of distinct values of B are \_\_\_\_\_

## 2. Fork join

Syntax of Fork : Fork L;

→ Execution of fork results in Starting 2 computation Concurrently

I. Which is immediately after fork

II. Which is at Label 'L'.

eg:

```

integer Count=2;
S1;
Fork L;
S2;
goto X;
L: S3;
X: Join (Count);
S4;

```



Join (Int-count)

```

{ Count = Count - 1;
  if (Count != 0) then exit;
  else
    return;
}

```

eg:



int COUNT=3;

```

S1;
Fork L;
S2; S4;
Fork X;
S5;
Goto Z;

```

L: S3;

```

Goto Z;
X: S6;
Z: Join (Count)
S7;

```

eg



```

P1;
Fork L;
P2;
L: fork X
P3;
P4;
Goto Z;

```

X: P4

```

Z: Join (Count);
P5;

```

eg.

 $N=2, M=2$ for  $L_3, L_4$ : $S_1;$  $L_1: \text{Join } N$  $S_3; &$  $L_2: \text{Join } M$  $S_5: \text{goto next};$  $L_3: S_2;$  $\text{goto } L_1;$  $L_4: S_4;$  $\text{goto } L_2;$  $\text{next: } S_6;$ 

Draw the precedence graph.



- Q1. Consider the following pseudo code where  $S$  is a semaphore initialized to five and Counter is a shared variable initialized to 0 in line 1. Assume that increment operation in line #7 is not atomic.

```
int Counter = 0
```

```
Semaphore S = init(5);
```

```
void parop(void)
```

```
{
    wait(S);
    wait(S);
}
```

```
Counter +=;
```

```
Signal(S);
```

```
Signal(S);
```

If five processes execute the function

parop concurrently, which of the following program behaviour is/are possible?

I. there is a deadlock involving all process.

II. Counter = 5 after all processes comp. parop

III. Counter = 1 " "

IV. Counter = 0 " " "

Q2.  $\text{int count=0; void test() }$

```
{
    int i, n=5;
    for(int i=1; i<=n; ++i)
        Count = Count + 1;
}
```

$\text{main() }$

```
{
    Parbegin
        test();
        test();
    Parenend
}
```

## DeadLock

Deadlock: Two or more processes are said to be in deadlock if they wait for the happening of an event which will never happen.

Consequences:

- \* Throughput/Efficiency drops
- \* Ineffective utilization of resources



### System Model:

→  $n$ : no of processes  $\langle P_1 \dots P_n \rangle$   
 →  $m$ : no. of resource  $\langle R_1 \dots R_m \rangle$



### Necessary Conditions for Deadlock:

1. Mutual Exclusion  
↳ Shared resource  $\langle CS \rangle$
2. Hold and wait  
Every H&W is not deadlock but every deadlock will have H&W.
3. No pre-emption of resources
4. Circular wait

## Resource Allocation Graph (RAG)

Graph  $G = (V, E)$ :



Graph 1.



It is deadlock free.

After changes it will result in deadlock ( $P_1 \rightarrow R_1 \rightarrow P_2 \rightarrow P_3 \rightarrow P_3 \rightarrow R_2 \rightarrow P_1$ ) cycle

Graph 2



It is deadlock free ( $P_1 \rightarrow R_1 \rightarrow P_3 \rightarrow R_2 \rightarrow P_1$ )

This system will go in deadlock if  $P_3 \rightarrow R_2$  and  $P_4 \rightarrow R_1$

## Deadlock Handling Strategies

1. Deadlock Prevention } Type 1 (Deadlock never occurs)
2. Deadlock avoidance → Banker's Algorithm.
3. Deadlock detection and recovery } Type 2 (Deadlock definitely occurs.)
4. Deadlock Ignorance → Ostrich Algo

## I. Deadlock Ignorance (Ostrich Algorithm)

- \* Pretend there is no problem (Ignorant Strategy of Ostrich)
- \* Reasonable if : (i) deadlock occur very rarely  
(ii) cost of prevention is high.
- \* UNIX and Windows take this approach
- \* It is a trade-off between convenience and correctness.

## II. Deadlock Prevention

Deadlock Prevention can be done by disallowing or negating the necessary conditions of deadlock.

a). Mutual Exclusion:  $\rightarrow$  Since every multi-programmed Operating System has atleast one shared resource  $\therefore$  M/E is non-disatisfiable.

b). Hold and Wait  $\rightarrow$  Hold or Wait implementation

(i) Process must request and be allocated all resource prior to its start.

**Drawback:** Causes/leads to starvation, inefficiency

(ii), Process must release all resources before making a fresh/new request.

**Drawback:** Suffer from Starvation

(iii)

c). No Preemption:  $\rightarrow$  Preemption of resource from process.



forced      Self  
(Running process should not block)      (Allows other processes to complete first)

**Drawback:** Causes Starvation.

d). Circular-wait:  $\rightarrow$  is prevented by a total order relation among all processes and resources.

(i) Assign unique numbers/IDs to each resource

(ii) Never allow a process to request a lower numbered resource than the last one allocated.

**Drawback:** Starvation Possible

Note :

- ① If the R.A.G. has resource of only multi instance type, then cycle is only a necessary condition.
- ② If R.A.G. has resource of both single and multi instance, then presence of cycle is only a necessary condition for deadlock.
- ③ If the R.A.G. has resources of only single instance type, then cycle is a necessary and sufficient condition for deadlock.

III.

Deadlock Avoidance

1. Single instance  
resource

<Resource Allocation  
Graph algorithm>

2. Multi instance of Resource (SI+MI)

Banker's Algorithm

(i) Safety algorithm

(ii) Resource request algorithm

Note: Both the algorithms are based on a priori knowledge/information.

I. Resource Allocation Graph Algorithms <Single instance resource>

\* Resource are claimed a priori in the system.

\* If process  $P_i$  starts executing then all Claim edges must appear in R.A.G.

\* If  $P_i$ 's request resource  $R_j$ , then the request is granted Only if, converting the request edge to Assigned edge does not lead to a cycle in R.A.G otherwise

System State

Safe

Unsafe

↓

No  
deadlock

↓

Danger of  
deadlock

the process is blocked

< No cycle implies safe state and formation of cycle implies unsafe state >

- \* The basic objective of R.A.G algorithm (S.I) is to always operate the system is in SAFE state.
- \* System is said to be safe, if the conversion of request edge to assigned edge does not lead to cycle in R.A.G. Otherwise if it is leading cycle then it is unsafe mode.



System State

|          |               |
|----------|---------------|
| SAFE     | → No deadlock |
| UNSAFE   | → Warning     |
| Deadlock |               |

### Banker's Algorithm (m. Instances.)

- (i) Safety algorithm    (ii) Resource request algorithm

#### Data Structure (System state)

1. n : no of processes (P<sub>1</sub>...P<sub>n</sub>)
2. m : no. of resources (R<sub>1</sub>...R<sub>m</sub>)
3. Maximum [1...n, 1...m]<sub>nxm</sub> :

$$\text{Max}[i,j] = k$$

$$P_i \rightarrow k(R_j)$$

Process P<sub>i</sub> demands (apriori)  
'k' copies of R<sub>j</sub>.

4. Allocation  $[1 \dots n, 1 \dots m]_{n \times m}$  :  $\text{Alloc}[i, j] = a$   
 $P_i \leftarrow a(R_j) \quad [a \leq k]$

5. Need  $[1 \dots n, 1 \dots m]_{n \times m}$  :  $\text{Need}[i, j] = b \rightarrow \text{Need} = \text{Max-Allocation}$   
 $P_i \rightarrow b(R_j) \quad [b = k - a]$

6. Request  $[1 \dots n, 1 \dots m]_{n \times m}$  :  $P_i \rightarrow c(R_j) @ \text{time } t$ .  
 $\text{Req}[i, j] = c. \quad [c \leq b]$

7. Total  $[1 \dots m]$

Total  $[j] = z \rightarrow$  There are 'z' copies of  $R_j$  in the system.

8. Available  $[1 \dots m]$

Avail  $[j] = e$  There are  $e(R_j)$  free available @ time  $t$ .

$$\text{Avail} = \text{Total} - \sum_{i=1}^n \text{Alloc}_i \quad [e \leq z]$$

Example :  $n=5, m=1, R=22$  (Total)

| Pid.           | Max R | Alloc R | Need R | Avail R |
|----------------|-------|---------|--------|---------|
| P <sub>1</sub> | 10    | 5       | 5      | 3       |
| P <sub>2</sub> | 8     | 4       | 4      | 5       |
| P <sub>3</sub> | 12    | 5       | 7      | 8       |
| P <sub>4</sub> | 5     | 2       | 3      | 13      |
| P <sub>5</sub> | 6     | 3       | 3      | 17      |

$\langle P_4; P_5; P_1; P_2; P_3; \rangle$

↓  
"Safe Sequence"

(We can have multiple safe sequences)

$\langle 22 \rangle$

Need = Max - Alloc

Safety Algorithm:

System is said to be "Safe" if the need of all processes can be satisfied with available resources in some order, otherwise it is "Unsafe".

Example 2:  $\langle A, B, C \rangle = \langle 10, 5, 7 \rangle$        $\langle P_1; P_2; P_3; P_4; P_5 \rangle$

|                | Allocation | Max   | Available | Need  |                   |
|----------------|------------|-------|-----------|-------|-------------------|
|                | A B C      | A B C | A B C     | A B C |                   |
| P <sub>0</sub> | 0 1 0      | 7 5 3 | 3 3 2     | 7 4 3 | "System is Safe." |
| P <sub>1</sub> | 2 0 0      | 3 2 2 | 5 3 2     | 1 2 2 |                   |
| P <sub>2</sub> | 3 0 2      | 9 0 2 | 7 4 3     | 6 0 0 |                   |
| P <sub>3</sub> | 2 1 1      | 2 2 2 | 7 4 5     | 0 1 1 |                   |
| P <sub>4</sub> | 0 0 2      | 4 3 3 | 7 5 5     | 4 3 1 |                   |
|                |            |       | 10 5 7    |       |                   |

### (ii) Resource request algorithm

Algorithm Res-request (P<sub>i</sub>, Reg<sub>i</sub>, Alloc<sub>i</sub>, Need<sub>i</sub>, Avail)

{

1. Reg<sub>i</sub> ≤ Need<sub>i</sub>
2. Reg<sub>i</sub> ≤ Alloc<sub>i</sub>
3. [Assume to have satisfied the Reg<sub>i</sub>]
  - a. Avail = Avail - Reg<sub>i</sub>
  - b. Need<sub>i</sub> = Need<sub>i</sub> - Reg<sub>i</sub>
  - c. Alloc<sub>i</sub> = Alloc<sub>i</sub> + Reg<sub>i</sub>
4. Run Safety algorithm
5. If System is SAFE then grant the Reg<sub>i</sub>  
else deny the Reg<sub>i</sub> and block the process P<sub>i</sub>; }

| <u>HW</u> | Processes      | Allocation | Max     | Available |  |
|-----------|----------------|------------|---------|-----------|--|
|           |                | A B C D    | A B C D | A B C D   |  |
|           | P <sub>0</sub> | 0 0 1 2    | 0 0 1 2 | 1 5 2 0   |  |
|           | P <sub>1</sub> | 1 0 0 0    | 1 7 5 0 |           |  |
|           | P <sub>2</sub> | 1 3 5 4    | 2 3 5 6 |           |  |
|           | P <sub>3</sub> | 0 6 3 2    | 0 6 5 2 |           |  |
|           | P <sub>4</sub> | 0 0 1 4    | 0 6 5 6 |           |  |

- Q. An OS uses the banker's algorithm for deadlock avoidance while managing the allocation of three resources type X, Y and Z to the processes P<sub>0</sub>, P<sub>1</sub> and P<sub>2</sub>. The table given below presents the Current System State. Here the Allocation matrix shows the current no. of resources of each type allocated to each process and max matrix shows the maximum number of resources of each type required by each process during its execution.

|                | Allocation |   |   | Max |   |   |
|----------------|------------|---|---|-----|---|---|
|                | X          | Y | Z | X   | Y | Z |
| P <sub>0</sub> | 0          | 0 | 1 | 8   | 4 | 3 |
| P <sub>1</sub> | 3          | 2 | 0 | 6   | 2 | 0 |
| P <sub>2</sub> | 2          | 1 | 1 | 3   | 3 | 3 |

There are 3 units of type X, 2 units of type Y and 2 units of Z still available. System is currently in safe state. Consider the following independent requests for additional resources in current state.

Req1: P<sub>0</sub> requests 0 units of X, 0 units of Y and 2 units of Z

Req2: P<sub>1</sub> requests 2 units of X, 0 unit of Y and 0 of Z.

|                | Max   | Alloc | Need  | Avail   |
|----------------|-------|-------|-------|---------|
|                | X Y Z | X Y Z | X Y Z | X Y Z   |
| P <sub>0</sub> | 8 4 3 | 0 0 1 | 8 4 2 | 3 2 2   |
| P <sub>1</sub> | 6 2 0 | 3 2 0 | 3 0 0 | <1 2 2> |
| P <sub>2</sub> | 3 3 3 | 2 1 1 | 1 2 2 | <6 4 2> |

To: P<sub>0</sub> :  $\rightarrow \langle 0, 0, 2 \rangle$

$\langle P_1, \dots \rangle$

System is unsafe

& Req1 is not granted

T<sub>1</sub>: P<sub>1</sub> :  $\langle 2, 0, 0 \rangle$

$\langle 8 5 3 \rangle$

Request 2 :  $\langle P_1, P_2, P_0 \rangle$

$\langle 8 5 4 \rangle$

∴ System is safe but request is granted

Only Request 2 is granted and Request 1 is not granted

(iv) Deadlock detection and recovery:

When to activate/activate (apply detection algo.)?

- Under utilization of CPU
- majority of processes are blocked.

Deadlock detection

For single instance  
of every resource

Using the wait-for  
Graph method

For multi instances of  
every resource

Using the Safety algorithm  
method



1. Prevention { Class 1 }
2. Avoidance { }
3. Detection and Recovery { Class 2 }
4. Ignorance. { Class 3 }

Conceptual problems.

- Q2. Consider a system having 'n' processes and a single 'R' having '6' copies. Each process need 2 copies of R to complete.
- What is min(n) to cause deadlock? :  $\rightarrow 6$
  - What is max(n) to deadlock freedom? :  $\rightarrow 5$

Q3  $n=3$ , Processes ( $P_1, P_2, P_3$ )

$$R = ?$$

$$P_i = 2(R)$$

a) What is max(R) to cause deadlock?  $\rightarrow 3$

b) What is min (R) to free deadlock?  $\rightarrow 4$

Q4. n-processes

$$R = 6 \text{ copies. } P_i \text{ required: } 3(R)$$

a) What is min(n) to cause deadlock? : 3

b) What is max(n) for deadlock freedom? : 2

Q5.

Max-demand

$$n=5, R.$$

$$P_1 \quad 10 - 9$$

a) Max(R) to cause deadlock: 36

$$P_2 \quad 8 - 7$$

$$P_3 \quad 5 - 4$$

b) Min (R) for deadlock freedom: 37

$$P_4 \quad 12 - 11$$

$$P_5 \quad 6 - 5$$

$$\underline{36}$$

Q6. Which of them is not a valid deadlock prevention scheme?

Ans Never request a resource after releasing any resource

Q7. Which is not true of deadlock prevention and deadlock avoidance?

Ans In deadlock prevention the request for resources is always granted if the resulting state is safe.

Q8. An OS implements a policy that requires a process to release all resources before making a request for another resource. Select true statement.

Ans. Starvation can occur but deadlock cannot occur.

Q9. A computer has 6 tape drives, with  $n$  processes competing for them. Each process may need two drives. What is the max value of ' $n$ ' for deadlock freedom?

Ans 5

Q10 Consider a system having  $m$  resources of some type. These resources are shared by 3 processes A, B, C which have a peak demand 3, 4, 6 resp. What value of ' $m$ ' deadlock will not occur?

Ans Value should be greater than 10.

Q11. A system shares 9 tape drives. The current allocation and max req. of tape drives for:

Which of them best describes the current state of system?

| Process        | Current Allocation | Max. Req. |                           |
|----------------|--------------------|-----------|---------------------------|
| P <sub>1</sub> | 3                  | 7         | Ans: Safe, Not deadlocked |
| P <sub>2</sub> | 1                  | 6         |                           |
| P <sub>3</sub> | 3                  | 5         |                           |

Q12 Which of following statements is/are true w.r.t deadlock?

Ans. a. Circular wait is a necessary condition for formation of deadlock.

d. In the resource allocation graph of a system, if every edge is an assignment edge, then system is not in deadlock state.

## Memory Management



Block diagram - Primary Memory

Linear dimensional view of Memory  
(Abstract view)



Total no. of words

= 'N' memory Capacity

fixed  
length  
address

You can store  
instructions  
+  
data

Memory: Memory is specified as number of words  $\times$  width of word

$$(N \times m)$$

n: Size of address in bit

m: word length / width of word

N: total number of words

### I. Relation b/w N & n:

→ Binary bits: (0,1)

→ Using 3 binary bits 8 combinations are possible

→ 'n' bits:  $\rightarrow 2^n$  combinations possible

eg:



$$N = 8 \text{ words}$$

$$n = 3 \text{ bits}$$

$$2^3 = 8W$$

$$N = 2^n \text{ words}$$

$$n = \log_2 N \text{ bits}$$

Conversion:

$$2^{10} = 1024 = 1 \text{ K words}$$

$$2^{20} = 20 \text{ M. words}$$

$$2^{30} = 1 \text{ G words}$$

$$2^{40} = 1 \text{ T words.}$$

$$2^{50} = 1 \text{ P words}$$

eg. \*  $N = 256$

$$n = \log_2 256 = 8 \text{ bits}$$

\*  $n = 6 \text{ bits}$

$$N = 2^6 = 64 \text{ words.}$$

\*  $n = \log_2 z \text{ bits}$

$$\begin{aligned} N &= z^{\log_2 z} \\ &= z^{(\log_2 z)} \therefore \underline{N = z \text{ Bytes}} \end{aligned}$$

1.  $N \times n \times m.$

$$1. \quad n = 13 \text{ bits}$$

$$m = 8 \text{ bits}$$

$$N = 8 \text{ KW}$$

$$= 8 \text{ KB.}$$

$$2. \quad n = 18 \text{ bits}$$

$$m = 16 \text{ bits}$$

$$N = 256 \text{ KW Word view}$$

$$= 512 \text{ KB Byte view}$$

$$3. \quad n = 33 \text{ bits}$$

$$m = 64 \text{ bits}$$

$$N = 8 \text{ GW}$$

$$= 64 \text{ GB}$$

4.  $N = 64 \text{ KB}$

$$m = 4 \text{ B.}$$

$$n = \frac{64 \text{ KB}}{4 \text{ B}} = 16 \text{ K words.}$$

5.  $n = 23 \text{ bits}$

$$m = 32 \text{ bits}$$

$$N = 2^{23} = 2^3 \times 2^{30} = 8 \text{ M words}$$

$$N = 8m \times 4 = 32 \text{ M Bytes.}$$

6.  $N = 256 \text{ MB}$

$$m = 128 \text{ B}$$

$$N = \frac{256 \text{ MB}}{128 \text{ B}} = 2 \text{ M words.}$$

$$n = 21 \text{ bits (W)}$$

$$n = 28 \text{ bits (B)}$$

7.  $N = 8 \text{ G bytes (Twist)}$

$$m = 64 \text{ bits}$$

$$N = 128 \text{ M words}$$

$$N = 16 \text{ Bytes.}$$

## Loading vs Linking

Loading: Loading refers to the activity of loading the program or bringing the program from disk to memory. The component of the operating system that does this activity is called "Loader".

The two approaches of loading are:

1. Static loading

2. Dynamic loading

1. Static loading: The whole program is loaded in memory before starting the execution.

- \* Advantage: Faster execution (time efficient)

- \* Drawback: possible wastage of space (ineffective utilization of memory).

2. Dynamic Loading: The process of loading the program on demand at runtime is called Dynamic loading.

- \* Advantage: no wastage of memory

- \* Drawback: slow execution (time inefficient)

Linking: Linking is the process of resolving external references in the program

```
#include <stdio.h>
main()
{
    fun();
    scanf();
}
```

```
fun()
{
    ...
    ...
    ...
    ...
}
```

Note: Compilation always starts with { from first line of code

\* Execution of program always starts with main()

Bsa: Branch and save address

- The two ways of linking are:
1. Static linking
  2. Dynamic linking

Static Linking: Linking of program before execution. Space inefficiency is the drawback of static linking.



Dynamic Linking: Linking at runtime is called dynamic linking.  
It is space efficient but time inefficient.



STUB: a small piece of code that gives the address to BSA.

DLL: (Dynamic link library). The libraries linked at runtime using principle of dynamic linking is called DLL

### Advantages:

- \* Space efficiency
- \* Reusability
- \* Modification flexibility  
is easy.

### Drawbacks:

- \* Time inefficiency
- \* Less security (Insecure)

Note: Static linking is more secure

Address Binding: Association of program instructions and data units to memory locations (address) is address binding



| $x$ : Variable entity |             |            |         |      |
|-----------------------|-------------|------------|---------|------|
| Name                  | Type        | Value      | Address | Size |
| $x$                   | int (garb.) | (mem. loc) | (2B)    |      |

Q1. The capacity of a memory unit is defined by the number of words multiplied by the number of bits/word. How many separate address and data lines are needed for a memory of  $4K \times 16$ ?

Ans  $n = \log_2 4K = 12$  bits,  $m = 16$  bit = 2B = Data lines / bus

int a, b, c;

- $a=1$ ;  $T_1$ : Store a, #1
- $b=2$ ;  $T_2$ : Store b, #2
- $c=a+b$ ;  $T_3$ : Load  $r_1, a$
- $T_4$ : Load  $r_2, b$
- $T_5$ : Add  $r_1, r_2$
- $T_6$ : Store C,  $r_1$

|   |       |   |
|---|-------|---|
| 0 |       |   |
| 1 |       | a |
| 2 |       | b |
| 3 |       | c |
| 4 | $r_1$ |   |
| 5 | $r_2$ |   |

Binding time: Time at which the binding takes place is called as binding time.

int (x);  
 $x=1$ ;

- Type : at compile time (static binding)
- Address : at load time (st. b)
- Value : run time (address binding)
- Size : Compile time (st. b)

- Types of binding:
1. Static binding (cannot change)
  2. Dynamic binding (can change)



### Multistep processing of a user program.



## Memory Management Techniques.

Contiguous  
<Centralized>



Non-Contiguous  
<Decentralized>



Techniques:

- Overlay
- Paging
- Segmentation
- Paging and Segm.
- Demand paging

fixed  
variable

## Function of Memory Manager:

1. Allocation
2. Protection.
3. Free Space management
4. Address translation
5. De-allocation

## Goals of memory manager:

- \* Utilize memory efficiently (min waste) <Fragmentation>
- \* Ability of memory manager to manage larger program in small memory areas.

### ① Overlays.

2 pass assembler:

Pass 1 and

Pass 2 are

Independent.

Pass 1 : 70 KB

Pass 2 : 80 KB

Symbol table : 30 KB

Common Rts : 20 KB

O.V Loader : 10 KB

: 210 KB.

Memory : 150 KB

|       |                       |
|-------|-----------------------|
| 10 KB | O.L                   |
| 30 KB | S.T                   |
| 20 KB | C.Rts                 |
| 90 KB | { Overlay = replace } |

Pass 1.

Overlay concept is possible only if "program divisible into independent module."

Consider the following programs expressed as an overlay.



Prog-Size : 92 KB (on disk)

\* What is minimum memory required to successfully execute this program using Overlay?

$$\begin{aligned} \text{Min. Memory Required} &= \max \{ \text{Path-length} \\ &\quad \text{from root} \\ &\quad \text{to leaf} \} \\ &= 29 \text{ KB} \end{aligned}$$

## ② Partitions:

(i) Fixed partitions (MFT): Multiprogramming with fixed tasks.



Trap to Operating System  
monitor - addressing error

## Partition allocation policies:

1. First fit: first free big enough (Internal fragmentation)
2. Best fit: smallest free big enough
3. Next fit: next fit works like first fit, but search for free partition beginning from last allocation.
4. Worst fit: largest free big enough.

## Performance of fixed partition: (fixed partition)

1. Internal fragmentation ✓
2. External fragmentation X
3. Degree of multi programming: Limited
4. Maximum process size: Limited
5. Partition allocation policy: Best-fit (See internal fragment.)

(ii) Variable Partitions (mvt): Multi programming with variable tasks (dynamic partitioning).

### Memory (free hole)

|           |                     |
|-----------|---------------------|
| User area | P <sub>1</sub> 85K  |
|           | P <sub>2</sub> 115K |
|           | P <sub>3</sub> 315K |
|           | P <sub>4</sub> 15K  |
|           | P <sub>5</sub> 120K |

free hole

Process Req.'s < 35K; 115K; 315K; 15K; 120K; ...

P<sub>1</sub> P<sub>2</sub> P<sub>3</sub> P<sub>4</sub> P<sub>5</sub>

### Performance issues:

1. Internal fragmentation X
2. External fragmentation ✓
3. Degree of multi programming: Flexible
4. Maximum process size: Flexible
5. Partition allocation policy: Worst-fit is better.

## External Fragmentation:

|                |
|----------------|
| 50K            |
| P <sub>1</sub> |
| 80K            |
| P <sub>2</sub> |
| 20K            |

Free space: 150K  
 Process: P<sub>3</sub> = 85K  
 (External frag of 150K)

→  
relocn

Memory map.

(i) Compaction (time consuming operation)

|                |
|----------------|
| P <sub>1</sub> |
| P <sub>2</sub> |



\* Compaction is not possible if there is no runtime address bindings.

## (ii) Non Contiguous Allocation:

- \* One of the reason of having non contiguous allocation is to avoid the problem of external fragmentation.
- \* N.CG allocation divides the process into smaller parts and distributed to free holes.

Note: Adjacent free holes are automatically merged to one free hole.

Q1 Consider a memory System having 6 partitions of Size 200K, 400K, 600K, 500K, 300K, 250K. There are 4 processes of size: 351K, 210K, 468K, 49K. Using Best-fit allocation policy, what are partitions that remain Unallocated?

|                |     |
|----------------|-----|
| P <sub>4</sub> | 200 |
| P <sub>1</sub> | 400 |
|                | 600 |
| P <sub>3</sub> | 500 |
|                | 300 |
| P <sub>2</sub> | 250 |

600K, 300K remain unallocated

Q2 Consider the following memory map in which blank regions are not in use and hatched regions are in use. Using variable partitions with no compaction.



The sequence of requests for blocks of size 300k, 25k, 125k, 50k, can be satisfied if we use:

Ans First fit but not best fit.

Q3. Consider a system with memory of size 1000 bytes. It uses variable partitions with no compaction. Presently there are 2 partitions of size 200k and 260k respectively.

(i) What is the allocation request of the process which could be always denied?

Ans: 541k

(ii) What is the smallest allocation request which could be possibly denied?

Ans: 181k

Q4. Consider a system having memory of size  $2^{46}$  bytes, uses fixed partitioning. It is divided into fixed size partitions each of size  $2^{24}$  bytes. The OS maintains a process table with one entry per process. Each entry has 2 fields: first, a pointer pointing to partition in which process is loaded and second, field is Process ID. The size of PID is 4 bytes.

Calculate:

(a) The size of pointer to the nearest byte :- 3B

$$\text{No. of partitions (N)} = \frac{2^{46}}{2^{24}} - 2^2, \text{ Partition address} = 22 \text{ bits} \\ = \underline{\underline{3 \text{ Bytes}}}$$

(b) Size of process table in bytes is if system has 500 processes.

$$\text{Ptr size} = 3B$$

$$\text{Process ID} = \underline{\underline{4B}}$$

$$7B \times 500 \rightarrow \underline{\underline{3500B}}$$

Q5. Consider a system with Variable Partition with no compaction

H.W. free hole : 4k, 8k, 20k, 2k.

Program size : 2k, 14k, 3k, 6k, 10k, 20k, 2k.

Time for execution : 4, 10, 2, 1, 4, 1, 8.

Using best fit allocation policy and FCFS CPU Scheduling, find the time of loading and time of completion of each program.

The burst time in seconds are.



Q6. Consider the allocation of memory to a new process. Assume that none of the existing hole in the memory will exactly fit the process's memory requirement. Hence, a new hole of smaller size will be created if allocation is made in any of the existing holes. Which of the following is true?

Ans - The hole created by best fit is never larger than hole created by first fit.

Non Contiguous Allocation : (to prevent external fragmentation)

\* Address Space : A set of space/words associated with addresses

Virtual (A.S)  
Logical Address Space

Physical Address Space.

Physical A.S

|                        |  |                         |
|------------------------|--|-------------------------|
| 0                      |  | words (cells) locations |
| 1                      |  |                         |
| 2                      |  |                         |
| 3                      |  |                         |
| .                      |  |                         |
| P.A                    |  |                         |
| PAS = 2 <sup>P.A</sup> |  |                         |

$$P.A = \log_2 P.A.S. \quad \text{Ram/memory}$$



Eg: ① L.A.S = 64 MB ; P.A.S = 4 MB  
 $L_A = 26 \text{ bits}$        $P_A = 22 \text{ bits}$

②  $L_A = 33 \text{ bits}$

LAS is byte, if word

Size is 64 bits = 8B.

$$\text{LAS(B)} = 2^{33} \times 8B = 8G \times 8B \\ = 64GB$$

$P_A = 23 \text{ bits}$

PAS, W.S = 64 bits = 8B

$8M \times 8B = 64MB$

\* Logical address: address generated by CPU to access instruction / data unit of program in execution.

\* Physical Address (Real/Absolute): address needed to access needed to access the program instructions / data unit in physical memory ie address in MAR

### 1. Simple Paging:

\* Organising of LAS/VAS:

|                |
|----------------|
| P <sub>0</sub> |
| P <sub>1</sub> |
| P <sub>2</sub> |
| P <sub>3</sub> |
| P <sub>4</sub> |

LAS: 5KB.  $\rightarrow$  LAS is divided into equal size units known as pages.

$\rightarrow$  Page size is generally in the power of 2.

Formulae  $\rightarrow \text{No. of pages } (N) = \frac{\text{L.A.S}}{\text{P.S}}$

$\rightarrow \text{Page offset/displacement } (d) = \log_2 \text{P.S (bits)}$

$\rightarrow \text{Page No. } (P) = \log_2 N$

$\rightarrow \text{P.S} = 2^d \text{ B}$

$$N = 2^P$$

L.A / V.A format

$$\text{L.A} = 13 \text{ bits}$$

|   |    |
|---|----|
| P | d  |
| 3 | 10 |

Q1. L.A.S = 32 MB

$$\text{P.S} = 4 \text{ KB} = 2^{12}$$

$$N = 8 \text{ K} [2^{13}]$$

$$P = 13 \text{ bits}$$

$$d = 12 \text{ bits}$$

|    |    |
|----|----|
| P  | d  |
| 13 | 12 |

$$\text{L.A.S} = 2^{25} = 32 \text{ MB}$$

(ii)  $\text{L.A} = 25 \text{ bits}$

$$d = 13 \text{ bits}$$

What are the no. of pages in the system?

$$\text{L.A} : \frac{25 \text{ bits}}{12 \text{ bits}} = 2^{13}$$

$$N = 2^{12} = 4 \text{ K}$$

(iii) System has  $2^k$  pages and L.A of 32 bits.

What is P.S?

$$N = 2^k$$

$$P = 11 \text{ bits}$$

|    |    |
|----|----|
| P  | d  |
| 11 | 21 |

$$d = 21, P.S = 2^{21} = 2^4 = 16 \text{ MB}$$

\* Organization of P.A.S (4 KB):



→ P.A.S is divided into equal

size units known as frames

[page frames].

→ Frame size = page size

→ Each frame holds one page

→ Any page can be stored in any frame (N.C.Q)

Formulae \* No. of frames (m) =  $\frac{\text{P.A.S}}{\text{F.S}}$

\* frame offset = page offset = d

\* P.A Format:

|   |    |
|---|----|
| f | d  |
| 2 | 10 |

\* frame no. (f<sub>i</sub>) bits =  $\log_2 m$ .

$$m = 2^f$$

$$Q1. L.A = 31 \text{ bits}, P.A = 20 \text{ bits}, P.S = 4 \text{ KB}$$

$$N = LAS / PS = \frac{2^{31}}{2^{12}} = 2^{19} = 512 \text{ K}$$

$$M = \frac{2^{20}}{2^{12}} = 2^8 = 256$$

$$P = 19 \text{ bits}, f = 8 \text{ bits}, d = 12 \text{ bits}$$

$$LA: \boxed{P \mid d}, 19+12 = \underline{\underline{31}}$$

$$PA: \begin{matrix} f & d \\ \hline 8 & 12 \end{matrix} = 20 \text{ bits}$$

Q2 System has 4 K page and 1 K frame, calculate the size of P.A.S, if LA = 32 bits.

$$P=12$$

$$N=4 \text{ K}, M=1 \text{ K} = f=10$$

$$LA = 32 \text{ bits}$$

$$\leftarrow 32 \text{ bit} \rightarrow$$

$$LA \quad \begin{matrix} P & d \\ \hline 12 & 20 \end{matrix}$$

$$PA:$$

$$\boxed{f \mid d}$$

$$10 \quad 20$$

$$32 \text{ bit}$$

$$PAS = 2^{30} = \underline{\underline{1GB}}$$

### \* Organization of M.M.U [page table/address table]

- Each process has its own P.T
- P.T.s are stored in memory
- P.T is organised as set of entries, known as "Page table entries" (PTE).
- No. of entries in Page table = No. of pages.
- P.T.E contains frame number in which page is present.
- P.T.E is denoted as 'e' (Bytes)
- P.T Size =  $N + e$  (Bytes)

$$e \geq 1B$$



Page Table

Address translation process:

Q1. A computer System using Paging technique implements an 8KB page with page table of size 24MB. The page table entry is 24 bits. What is the length of Virtual Address in the system?

Ans

$$P.S = 8\text{KB}$$

$$d = 13 \text{ bits}$$

$$P.T.S = 24\text{MB}$$

$$e = 24 \text{ bit} = 3B$$

$$P.T.S = N \times e$$

$$N = \frac{P.T.S}{e} = \frac{24\text{MB}}{3B} = \underline{\underline{8m}}$$

Q2 Consider a Computer System with 40-bit virtual addressing and page size of 16KB. If the Computer System has a one level page table per process and each page table entry requires 48 bits, then the size of per process Page table is megabyte.

Soln

$$V.A = 'l' \text{ bits}$$

$$N = 'z'$$

$$m = 't'$$

$$P = \log_2 z$$

$$d = (l - \log_2 z) \text{ bits}$$

$$P_A:$$

$$(\log_2^t + l - \log_2 z)$$

$$P.A.S = 2^{(l + \log_2 t - \log_2 z)}$$

$$= 2^{l + \log_2 (\frac{t}{z})}$$

$$= 2^l \times \underline{\underline{\frac{t}{z}}}$$

$$= 2^l \times \underline{\underline{\frac{16}{2}}}$$

Q3. Consider a System having/using Simple paging technique with logical address of 32 bits. Page table entry of 32 bits. What must be the page size in bytes, such that the page table of the process exactly fits in one frame of memory (PAS)?

Sol<sup>2</sup>

$$L.A = 32 \text{ bits}$$

$$Lr \text{ P.S} = 2^k \text{ B}$$

$$P.T.E = e = 32 \text{ bits} - 4 \text{ B}$$

$$P.T.S = N * e$$

$$P.S = ?$$

$$N = \frac{2^{32}}{2^k} = 2^{32-k}$$

$$[P.T.S] = 2^{32-k} \times 4 \text{ B}$$

$$2^{32-k} = 2^{34-k}$$

$$34 = 2k \therefore k = 17$$

Q4. Consider a System using Paging technique with VA = 32 bits and P.S = 4 KB, what must be appropriate P.T.S in bytes, given P.A.S = 64 MB.

Ans

$$PAS = 64 \text{ MB}$$

$$P.T.S = N * e$$

$$VA = 32 \text{ bits}$$

$$M = \frac{2^{26}}{2^{12}} = 2^4, N = \frac{2^{32}}{2^{12}} = 2^{20} = 1 \text{ M}$$

$$P.S = 4 \text{ KB}$$

$$P.T.S = 1 \text{ M} \times 2^8$$

$$= 2 \text{ MB}$$

Performance of paging:

### 1. Timing issue :

- \* Main memory access time (MMAT) = 'm'
- \* Effective memory access time (EMAT) =  $2m$ .
- \* Objective : Reduce EMAT from  $2m$  to  $m$ .

Cache memory:



\* faster memory access time

\* costly

\* Smaller in size

\* Supports parallel search.

TLB  
(Translation Lookaside Buffer)

## Paging Hardware with T.L.B.



Page Table

### Formulas

$$\ast \text{PMMAT} = m$$

$$\ast \text{TLB hit} = \alpha \text{ ratio}$$

$$\ast \text{TLB miss} = C$$

$$\ast \text{TLB miss} = 1 - \alpha \text{ ratio}$$

$$\ast \text{EMMAT} = 2m$$

$$\ast \text{EMMAT} = \alpha(C+m) + (1-\alpha)(C+2m)$$

Q1.

$$m = 100\text{ns}$$

$$C = 200\text{ns} \quad (\text{a}) \text{EMMAT using Paging: } 2m = 2 \times 100 = 200\text{ns}$$

$$(\text{b}) \text{If } \alpha = 0.9 \cdot \text{ what is EUB TLB: } \alpha = 0.9, (1-\alpha) = 0.1$$

$$= \alpha(C+m) + (1-\alpha)(C+2m)$$

$$= 0.9(120) + 0.1(220) = 108 + 22 = 130\text{ns} [200 - 120]$$

$$(\text{c}) \text{If } \alpha = 0.1 \cdot \text{ what is EMMAT TLB?}$$

$$= 0.1(120) + 0.9(220)$$

$$= 20\text{ns} [200 - 20\text{ns}]$$

## Paging with TLB and Physical Address Cache (PAC)



Q2 Consider a system using Paging with TLB. What hit ratio is required to reduce the EMT from 'D' to 'Z' by using TLB. Assume that TLB access time is 'k' ms.

$$2m=0$$

$$m=D/2$$

$$EMAT = x(C_{tm}) + (1-x)(C_0 + 2m)$$

$$'Z' = x\left[k + \frac{D}{2}\right] + (1-x)[k + m]$$

### (2) Space Consumption in Paging

$$P.T.S(B_y) = N * e(B_y)$$

e.g.: LA = 32 bits, PS = 4 KB

$$P.T.S \propto N$$

Appropriate P.T Size?

$$N = 2^{32}/2^{12} = 2^8$$

Objective: Reduce Page table size of processes.

if  $e = 4B$

$$P.T.S = 1m * 4B = 4MB$$

If System has 100 processes, amount of memory required =  $100 \times 4 = 400MB$ .

Reduce P.T Size | Associate Smaller PTs with processes.

$$\star P.T.S = N \cdot e$$

$$P.T.S \propto N \quad (i)$$

$$\star P.T.S \propto N \cdot e + P.S$$

$$\star N = \frac{L.A.S}{P.S}$$

$$N \propto \frac{1}{P.S} \quad (ii)$$

$$P.T.S \propto \frac{1}{P.S}$$

(ii) Reduce P.T.S by increasing Page Size.

Optimal page size?

Let V.A.S = 'S' Bytes

Let P.T.E = 'e' Bytes

Let Page Size = 'P' Bytes.

$$(i). P.T.S = \left[ \left( \frac{S}{P} \right) + e \right] \text{ Bytes}$$

$$(ii). I.F = \frac{P}{2} \text{ Bytes.}$$

$$\text{Total overhead} = \left[ \left( \frac{S}{P} \right) e + \frac{P}{2} \right] - 1 \quad (1)$$

diff eqn (1) w.r.t. P = 0

$$\left[ -\frac{1}{P^2} Se + \frac{1}{2} \right] = 0$$

$$\frac{Se}{P^2} = \frac{1}{2} \Rightarrow P^2 = 2Se$$

$$P = \sqrt{2Se}$$

- Q1. A machine has a 32 bit address space in an 8KB page. The page table is entirely in hardware, with one 32-bit word per entry. When a process starts, the page table is copied to the hardware from memory, at one word every 100 nsec. If each process runs for 100 msec (including the time to load the page table), what fraction of CPU time is devoted to loading the page tables?

$$N \text{ pages} = \frac{2^{32}}{2^{13}} = 2^{19}$$

$$\text{Time to load P.T} = 2^{19} \times 100 \text{ nsec.}$$

$$\therefore \text{Fraction of CPU time} = \frac{2^{19} \times 100 \text{ ms}}{100 \text{ ms}}$$

$$= \frac{2^{19} \times 100 \times 10^{-9}}{100 \times 10^{-3} \text{ s}} = 50.1$$

Q2.

Consider a system using Paging technique with an address space of 65,536 Bytes. The page size in this system is 4096 Bytes. The program consists of Text, Data and Stack sections as per the space:

Text: 32,768 B

Data: 16,386 B

Stack: 15,870 B

A page of the program contains portions of only one section i.e either Text or Data or Stack

(a) Does program fit in given address space? No

(b) What is the maximum page size in Bytes such that the program fits in given address space.

$$VAS = 65,536 = 64 \text{ KB}$$

$$\text{Text} = 32,768 / 4096 = 8$$

$$N = \frac{64 \text{ KB}}{4 \text{ KB}} = \frac{2^16}{2^12} = 2^4 = 16$$

$$\text{Data} = 16,386 / 4096 = 5$$

$$4 \text{ KB} \quad 2^{12}$$

$$\text{Stack} = 15,870 / 4096 = 4$$

$$\text{Total} = 17 \quad \text{So you cannot.}$$

## (II) Hashed Paging / Paging with Hashing

\* Element ( $x$ )  $\sim h(f(i)) \xrightarrow{i}$  index

\* We will design a 'Page-table' using hashing

$$[x \circ 10] \leftarrow \begin{matrix} 0 \\ 9 \end{matrix}$$

Collision: Let  $I_1$  and  $I_2$  be two distinct elements

$$f(I_1) = f(I_2) = i$$

\* To resolve Collision - Chaining is used.

\* Space optimized, but time inefficient.

Hashed page table(III) Multi Level Paging / Hierarchical Paging (Recursive paging)

Objective: To reduce Page table size overhead by associating Smaller Page table's with process.

e.g.: VA = 32 bit

$$P.S = 4 \text{ KB}$$

$$e = 4B$$

$$\begin{aligned} P.P.S &= 1 \text{ MB} \times 4 \text{ KB} \\ &= 4 \text{ MB} \end{aligned}$$

When do we say P.T is small?

- If the pagetable fits in one frame of memory

Paging as a concept involves 3-Steps:

1. Divide the address space into pages (chunks).
2. Store the page in physical address space
3. Access the pages (chunks) of address space in physical address space through page table

Performance:  $TMAT = m$

$$EMAT_{2LP} = 3m$$

$$EMAT_{nLP} = (n+1)m$$

eg::  $LA = 32 \text{ bits}$ ,  $PS = 4 \text{ KB}$ .

b. Address of page (chunk) of I.P.T



Logical address

|                |                |   |
|----------------|----------------|---|
| P <sub>1</sub> | P <sub>2</sub> | d |
|----------------|----------------|---|



Q.1 In the Context of Operating Systems, which of the following are correct w.r.t. Paging?

- \* Paging helps solve the issue of external fragmentation.
- \* Paging incurs memory overhead.

Q.2. Consider a System using 2 level Paging Architecture. The top level 9 bits of the Virtual Address are used to index into the outer Page Table. The next 7 bits of the address are used to index into next level page table. If the size of virtual address is 28 bits. Then

- How large are the pages and how many are there in virtual address space?

$$P = \text{No of Pages in VAS} , N = 2^{\frac{16}{6+10}} = 64\text{KB}$$

$$\text{P.S of VAS} = 2^{12} = 4\text{KB}$$

- If P.T.E at both levels is 32 bit in size then what is the space overhead needed to translate Virtual Address to Physical Address of an instruction or Data Unit?

$$\begin{array}{ll}
 \text{P. } & \Phi_1 \quad d \\
 & 2\text{KB} + 512\text{B} \\
 9 & 7 \quad 12 \\
 & 2.8\text{KB}
 \end{array}$$

Q3. Consider a Computer System using three level Paging Architecture with uniform page size at all levels of paging. The size of virtual address is 46 bits. Page Table Entry at all levels of paging is 32 bit. What must be the page size in Bytes such that the outer page table exactly fits in one frame of memory. Assume page size is power of 2 in Bytes. Show the virtual address format indicating the number of bits required to process all the three levels of page-tables and the page offset of virtual address space.

$$VAS = 2^{46}$$

$$\text{Let } P.S = 2^x \text{ B} \rightarrow \left(\frac{2^{46}}{2^x}\right) = \left[2^{\frac{46-x+2}{2}}\right]_B \rightarrow \left[\frac{2^{46-x+2}}{2^x}\right]_B$$

$$\Rightarrow \left[\frac{46-3x+2+2+2}{2^x}\right]_B$$

$$x=13$$

$$2^{13} = \underline{8KB}$$

Derivation:

$$\text{Let } VAS = 2^S \text{ Bytes } VA = 8 \text{ bits}$$

$$P.S = 2^x \text{ Bytes}, \quad P.T.E = 2^C \text{ Bytes}$$

$$\text{Level of paging} = 'l'$$

$$\rightarrow \text{Size of outer-level P.T} = \left[2^{\frac{s-l.x+l.c}{2}}\right] \text{ Bytes.}$$

$$\rightarrow \frac{2^S}{2^x} \cdot 2^C = \left[2^{\frac{s-x+c}{2}}\right]$$

Q4 Consider a computer system with 57 bit virtual addressing, using multi level tree structured page tables with 1 level for Virtual to Physical address translation. Page size is 4KB and Page Table Entry is of 8 Bytes at all level. The value of L is 5

$$VA = 57 \text{ bit}$$

$$P.S = 4 \text{ KB}$$

$$OPT = 1 \text{ Page / frame}$$

$$\text{No. of levels} = 'L'$$

$$P.T.E = 8B$$

$$OPT = 4 \text{ KB}$$

$$OPT = \left[ \frac{S + L_1 \cdot 12 + L_2}{2} \right] \text{ Byte.}$$

$$= 2^{12} \text{ B}$$

$$57 - 9l = 12$$

$$l = \underline{s}$$

HW

Qs. Consider a three level page-table to translate a 39-bit virtual address to a physical address as shown below.

← 39 bit virtual address →

| Level 1 offset | Level 2 offset | Level 3 offset | Page offset |
|----------------|----------------|----------------|-------------|
| 9 bits         | 9 bits         | 9 bits         | 12 bits     |

The page size is 4KB ( $1\text{KB} = 2^{10} \text{ Byte}$ ) and page table entry size at every level is 8 byte. If process P is currently using 2GB virtual memory which is mapped to 2GB of physical memory, the minimum amount of memory required for the page table of P across all levels is \_\_\_\_ KB.

2.

Segmentation.

- \* Paging does not pressure user's view of memory allocation to programs
- \* As per user's view of memory allocation, Program is divided into logical units, known as Segments (Function, block, procedure, D.S., Class).
- \* These segments are assumed to be stored in their entirety entirely at non-contiguous locations.

HW

Q1. Consider the following Segment table:

| Segment | Base | Length |
|---------|------|--------|
| 0       | 1219 | 600    |
| 1       | 3300 | 14     |
| 2       | 90   | 100    |
| 3       | 2327 | 580    |
| 4       | 1952 | 96     |

What are the physical addresses for the following logical addresses?

## Performance of Segmentation

1. Time :  $M_{MAT} = 'm'$

$$E_{MAT} = '2m'$$

$$T_{UBAT} = C$$

$$T_{UB} \text{ hit ratio} = \alpha$$

$$T_{UB} \text{ miss ratio} = 1 - \alpha$$

$$E_{MAT} = \alpha(C + m) + (1 - \alpha)(C + 2m)$$

2. Space :

When Segment table become large, apply paging on Segment table

## Compare Paging and Segmentation wrt fragmentation

|         | Int. frag.       | External frag. |
|---------|------------------|----------------|
| Paging  | ✓<br><last page> | X              |
| Segment | X                | ✓<br>in P.A.S. |

## Segmentation

### External fragmentation

1. Compaction

De-fragmentation

2. Paging

(Segmented-paging)

## Virtual Memory (Vm)

Virtual memory gives an illusion to the programmer that a huge / large amount of memory is available for executing programs, that are larger than the available / given Physical memory.

$$P.A.S = 8 \text{ KB}$$

$$P.S = 1 \text{ KB}$$



$$P.A.S = 4 \text{ KB}$$



V.M

Demand Paging

Demand paging: \* Loading the page from disk to memory on demand at runtime.

\* Virtual memory is implemented through "Demand Paging".

\* Program (8KB/8 Page) : stored initially on disk, required pages are loaded in P.A.S.



Demand paging

Pure DP

Pre Fetched D.P.

< Execution of the  
process will start  
when empty frame >

Note: \* Size of virtual memory is  
limited by size of disk.

\*  $P.A.S \leq VAS \leq \text{Disk AS}$ .

Steps taken to service page fault:



\* Amount of time taken by O.S (VMM) to service a page fault is known as "Page fault service time." (ms)

- Q1. In a virtual memory system the address space specified by the address line of the CPU must be Larger than the physical memory size and Smaller Secondary Storage size.

## Performance Of Virtual Memory:

### 1. Time issue (Temporal)

$$T.M.A.T = 'm' [ns | \mu s]$$

$$P.F.R = 's' [s \gg m]$$

$$\text{Page fault rate} = 'P'$$

$$\text{Page hit rate} = '1 - P'$$

$$E.M.A.T = (1 - P)^m + P * s$$

D.P.

Q2 The total size of address space in virtual memory system is limited by:

Ans. Size of Secondary Storage

Q3. The essential content(s) in each entry of a page table is/are  
Ans (i) Page frame number  
(ii) Access right information

Q4 In a system with 32 bit VA and 1KB page size, use of one level page table for virtual to physical address translation is not practical because of

Ans the large memory overhead in maintaining page table

Q5. Suppose - the time to service a page fault is on the average 10 ms, while a memory access takes 1 microsecond. Then a 99.99% hit ratio results in Average Memory Access Time of 2μs

Ans  $T.M.A.T = 1 \mu s$

$$P.F.R (S) = 10ms \quad 1 - P = 99.99\% \\ = (0.9999)$$

$$P = 0.001$$

$$= 0.0001$$

$$E.M.A.T = (1 - P)m + P * s$$

$$= 0.9999 \times 1 \times 10^{-6}s + 0.0001 \times 10 \times 10^3s$$

$$= 0.9999 \times 1 \times 10^{-6} + 1 \times 10^{-6}$$

$$= 1.9999 \times 10^{-6} \mu s \sim 2 \mu s$$

Q6. If an instruction takes 'i' microseconds and a page fault takes an additional 'j' microseconds, the Effective Instruction Time if on the average a page fault occurs every 'k' instructions is \_\_\_\_\_

Ans

Instruction time without Page Fault :  $i \mu s$

Instruction time with Page Fault :  $i + j \mu s$

$$P = \frac{1}{k}$$

$$(1-P) = \left(1 - \frac{1}{k}\right)$$

$$\text{Effective Inst. Time} : \frac{1}{k}(i+j) + \left(1 - \frac{1}{k}\right)i$$

$$= \cancel{\frac{i}{k}} + j + i - \cancel{\frac{i}{k}}$$

$$= \underline{i + j/k}$$

HW

Q7. Assume that we have a Demand-paged memory. It takes 8 milliseconds to service a page fault if an empty frame is available or if the rejected page is not modified, and 20 milliseconds if the replaced page is modified. Memory-access time is 100 nanoseconds. Assume that the page to be replaced is modified 70 percent of the time. What is the acceptable page fault rate for an effective access time of no more than 2000 nanoseconds?

Sol.

Ans

$S \rightarrow 8(\text{ms}) : \text{EF} + \text{clear page } [70\%]$

$$m = 100 \text{ ns}$$

$\rightarrow 20(\text{ms}) : \text{Dirty page } [30\%]$

$$P = ?$$

70%

$$EMAT = 2000 \text{ ns}$$

$$2000 \text{ ns} = (1-P)^* 100 \text{ ns} + P (0.7 * 20 \text{ ms} + 0.3 * 8 \text{ ms})$$

$$P =$$

Q8. Consider a process executing on an Operating System that uses demand paging. The average time for a memory access in the system is  $m$  units if the corresponding memory page is available in memory, and  $D$  units if the memory access causes a page fault. It has been experimentally measured that the average time taken for a memory access for the process is  $x$  units. Which one of the following is correct expression for the page fault rate experienced by the process?

Ans

$$m = M \quad x = (1-p)m + p*D$$

$$s = D \quad = p = \frac{x-m}{D-m}$$

$$(D-m) \approx$$

Q9. Consider a paging system that uses 1-level page table residing in main memory and a TIB for address translation. Each main memory access time takes 100 ns and TIB lookup takes 200 ns. Each page transfer to / from the disk takes 5000 ns. Assume that the TIB hit ratio is 95:1, page fault rate is 10%. Assume that for the 20% of the total page faults, a dirty page has to be written back to disk before the required page is read in from disk. TIB update time is negligible. The average memory access time in ns (round off to 1 decimal place) is 154.5

Ans

$$m = 100 \text{ ns}$$

$$\text{Disk R/W} = 5000 \text{ ns}$$

$$c = 200 \text{ ns}$$

$$\text{TIB hit rate} = 95:1$$

$$\text{Page fault rate} = 10\%$$

80% - Clean page

TIB hit

20% - Dirty page

$$EMAT = 0.95 [200 \text{ ns} + 100 \text{ ns}] + 0.05 [200 \text{ ns} +$$

$$\text{page hit} \quad 0.9 (100 \text{ ns} + 100 \text{ ns}) + 0.1 \rightarrow \text{P.F.}$$

$$(100 \text{ ns} + 0.2 \times (5000 + 5000) +$$

$$0.8 (500 \text{ ns}))$$

$\uparrow$  D.P.

$\uparrow$  Clean page

$$EMAT = 154.5 \approx 155$$

- Q10. The minimum number of page frames that must be allocated to a running process in a virtual memory environment is determined by  
**Ans** Instruction Structure Architecture.

Page Replacement: One important concept of Virtual Memory implementation.

a) Reference String (Page-Rf string): Set of successively unique pages (Page Nos.) referred in given list of V.A.s.

eg.:  $\langle P_r \rangle \langle 7, 1, 6, 4, 0, 1, 7, 9, 6, 7, \dots \rangle$   
 $\langle 702, 704; 123; 654; 483; 012; 122; 124; 180; 785; 934; \dots \rangle$

Let  $P.S = 100 B$

$$P = \frac{V.A}{P.S}$$



Length = 10

Unique pages = 6



$\langle 0 \dots 99 \rangle : P_0$

$\langle 100 \dots 199 \rangle : P_1$

$\langle 200 \dots 299 \rangle : P_2$

b) Frame allocation Policies

\*  $n = \text{no. of processes } (P_1 \dots P_m)$

$n=5 \quad \langle P_1 \dots P_5 \rangle ; m=40$

\*  $S_i = \text{Demand (frame) of process } P_i$

| $P_i$ | Demand $s_i$ | Eq. alloc. $a_i = M/n$ | Prop. alloc. $a_i = (s_i/m)M$ | $a_i = s_i/2$ |
|-------|--------------|------------------------|-------------------------------|---------------|
| $P_1$ | 10           | 8                      | 5                             |               |
| $P_2$ | 5            | 8                      | 3                             |               |
| $P_3$ | 35           | 8                      | 17                            |               |
| $P_4$ | 18           | 8                      | 9                             |               |
| $P_5$ | 12           | 8                      | 6                             |               |

\*  $D = \text{Total Demand}$

$$= \sum_{i=1}^n s_i$$

$$D = 50$$

\*  $m = \text{Available frames}$

\*  $a_i = \text{Allocated frames}$

- \* Min. no of frames to be allocated to a process:
  - Process cannot execute without this minimum number of frames
  - Process should be able to execute minimum one instruction.

### Page Replacement Techniques:

- Ref string:  $\langle 7; 0; 1; 2; 0; 3; 0; 4; 2; 3; 0; 3; 2; 1; 2; 0; 1; 7; 0; 1 \rangle$   
length = 20, n = 6

(1) FIFO

|          |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----------|---|---|---|---|---|---|---|---|---|---|---|---|---|
|          | 7 | 2 | 2 | 2 | 4 | 4 | 4 | 0 | 0 | 0 | 7 | 7 | 7 |
| Criteria | 0 | 0 | 3 | 3 | 3 | 2 | 2 | 2 | 1 | 1 | 1 | 0 | 0 |
| : TOL    | 1 | 1 | 1 | 0 | 0 | 0 | 3 | 3 | 3 | 2 | 2 | 2 | 1 |

3 frames: 15

-frame-

$$\varphi = \frac{15^3}{20^4} = \frac{75}{16}$$

eg:: 2 Ref string:  $\langle 1, 2, 3, 4, 1, 2, 5, 1, 2, 3, 4, 5 \rangle$

FIFO: pure demand paging

hence 3 frames:

|             |   |   |   |   |   |   |   |
|-------------|---|---|---|---|---|---|---|
| 3 frames: 9 | X | 4 | 4 | 4 | S | S | S |
|             | 2 | X | 1 | 1 | X | 3 | 3 |
| 4 Frame: 10 | 3 | 3 | X | 2 | 2 | X | 4 |

HW

Frame

Page  
Fault  
rate

Natural Behaviour



Belady's Anomaly:

As the number of frames allocated to the process increases, page fault also sometimes increases.

Only FIFO and LIFO based suffers from Belady's Anomaly.

- ② Optimal Replacement: replace that page which will not be used for the longest duration of time in future references.

e.g.: Ref String  $\langle 7, 0, 1, 2, 0, 3, 0, 4, 2, 3, 0, 3, 2, 1, 2, 0, 1, 7, 0, 1 \rangle$

| 3 Frames : 9 | 7 | 2 | 2 | 2 | 2 | 2 | 7 |
|--------------|---|---|---|---|---|---|---|
| 4 Frames : ? | 0 | 0 | 0 | 4 | 0 | 0 | 0 |
| (Hw)         | 1 | 1 | 3 | 3 | 3 | 1 | 1 |

Frame.

\* We use this algorithm as a benchmark to check performance of other replacement strategies. Optimal replacement is not implemented practically.

- ③ Least Recently Used (LRU): replace that page which has not been used for the longest duration of time in the past.

Criteria : Time of Reference.

e.g.:  $\langle 7, 0, 1, 2, 0, 3, 0, 4, 2, 3, 0, 3, 2, 1, 2, 0, 7, 7, 0, 1 \rangle$

| 3 Frames : 12. | 7 | 2 | 2 | 4 | 4 | 4 | 4 | 1 | 1 | 1 |
|----------------|---|---|---|---|---|---|---|---|---|---|
| 4 Frames : ?   | 0 | 0 | 0 | 0 | 0 | 3 | 3 | 3 | 0 | 0 |
| (Hw)           | 1 | 1 | 3 | 3 | 2 | 2 | 2 | 2 | 2 | 7 |

- ④ Most Recently Used (MRU): Symmetrical opposite of least recently used, replace that page which has been used for longer duration of time.

H.W eg::  $\langle 7, 0, 1, 2, 0, 3, 0, 4, 2, 3, 0, 3, 2, 1, 2, 0, 1, 7, 0, 1 \rangle$

3 Frame:  $\langle 0, 1, 2, 0, 3, 0, 4, 2, 3, 0, 3, 2, 1, 2, 0, 1, 7, 0, 1 \rangle$

4 Frame:  $\langle 0, 1, 2, 0, 3, 0, 4, 2, 3, 0, 3, 2, 1, 2, 0, 1, 7, 0, 1 \rangle$

Similar to LRU, but instead of removing least frequently used, it removes the most frequently used.

### (5) Counting Algorithms:

a) L.F.U [least frequently used]

\* Criteria: Count of reference.

b) M.F.U [most frequently used]

eg::  $\langle 7, 0, 1, 2, 0, 3, 0, 4, 2, 3, 0, 3, 2, 1, 2, 0, 1, 7, 0, 1 \rangle$

(H.W: Solve with 3 frames (both) !)

Note: \* Among all the algorithms, Optimal is having least page fault rate.

- \* LRU ~ Optimal
- \* Many OS implement either LRU / LRU approximately
- \* The best method to implement LRU is by "stack method".

LRU Approximations < These algorithms are not really LRU, but they approximate to the behaviour of LRU.

They are based on a concept called <Reference bit (R)> : Each page in the page table will be associated with a reference bit 'R'.



a.) Reference bit (R):

- Criteria: 'R'
- 0 : Page is not referred so far during present Epoch.
  - 1 : Page has been referred atleast once during Present Epoch.

| eg:: | P | f | v/I | T.O.L | R  |                                               |
|------|---|---|-----|-------|----|-----------------------------------------------|
|      | 0 | a | 1   | 2     | 1  | Reference bit fails when all R value are '1'. |
|      | 1 | e | 1   | 3     | 0  |                                               |
|      | 2 | d | 1   | 0     | 1  |                                               |
| P.P  | 3 | - | 0   | -     | -  |                                               |
|      | 4 | c | 1   | 4     | 10 |                                               |
|      | 5 | b | 1   | 1     | 0  |                                               |

Page Table

b). Additional Reference bits: Each page is associated with more than one reference bits.

|       | $R_1$ | $R_2$ | $R_3$ | $R_4$ | $R_5$ | $R_6$ | $R_7$ | $R_8$ | Current Epoch |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|---------------|
| $P_i$ | 1     | 0     | 0     | 1     | 0     | 1     | 1     | 1     |               |
| $P_j$ | 0     | 0     | 1     | 1     | 1     | 0     | 1     | 1     |               |
| $P_k$ | 0     | 0     | 1     | 1     | 0     | 1     | 1     | 1     |               |

(P<sub>i</sub>) X : Cause Page Fault

When current Epoch gets over

↓  
[Shift left operations]

### c) Second Chance [Clock Algorithm]

Criteria : [T.O.L + Reference]

eg:::

← P.T.E →

| P | V/I/E | T.O.L | R              | f |
|---|-------|-------|----------------|---|
| 0 | 1     | 2     | 1              | e |
| 1 | 1     | 3     | 0              | a |
| 2 | 1     | 0     | X <sup>o</sup> | b |
| 3 | 0     | -     | -              | - |
| 4 | 1     | 1     | 0 <sup>v</sup> | c |
| 5 | 1     | 4     | +              | d |

When all page 'R' value  
is '1' then FIFO page gets  
selected

\* Second ~ FIFO  
Chance

Page Table

Belady's Anomaly

### d) Enhanced Second Chance / N.R.U. (Not recently used).

Criteria: Reference + modified

Rm

- I. 00 → Not referenced and not modified
- II. 01 → Not referenced but modified
- III. 10 → Referenced but clean
- IV. 11 → Referenced and modified

eg::

| P.T.E. Structure |   |     |       |   |   |
|------------------|---|-----|-------|---|---|
| P                | f | V/I | T.o.L | R | m |
| 0                | c | 1   | 4     | 1 | 1 |
| 1                | a | 1   | 3     | 0 | 0 |
| 2                | - | 0   | -     | - | - |
| 3                | b | 1   | 0     | 1 | 1 |
| 4                | d | 1   | 2     | 1 | 0 |
| 5                | e | 1   | 1     | 0 | 1 |

(i) FIFO:  $P_3$ (ii) R:  $P_1$ (iii) Second Chance:  $P_5$ 

(iv) Enhanced Second

Chance:  $P_1$ 

Q1. Consider a System with  $V.A.S = P.A.S = 2^{16}$  Byte. Page size is 512 Byte. The size of the page table entry is 32 bits. If the page table entry contains beside information 1 V/I bit, 1 Reference, 1 modified bit, 3 bits for page protection. How many bits can be assigned for storing other attributes of the page. Also compute Page Table Size in Bytes?

Ans:

| P.P.S = 32 bits |   |     |   |   |      |
|-----------------|---|-----|---|---|------|
| P               | f | V/I | R | m | PPr. |
| 7               | 1 | 1   | 1 | 3 | 2    |

$n_{frames} = \frac{2^{16}}{2^9} = 2^7$

$$\begin{aligned} P.T.S &= N \times e \\ &= 2^7 \times 2^2 = 2^9 \rightarrow 512B \end{aligned}$$

Q2. Consider a virtual memory system with FIFO page replacement policy, for an arbitrary page access pattern, increasing the number of page frames in main memory will

Ans Sometimes increase the no. of page faults (Belady's Anomaly)

Q3. A memory page containing a heavily used variable that was initialised very early and is in constant use is removed when

Ans FIFO page replacement algorithm is used.

Q4. Recall that Belady's anomaly is that the page fault rate may increase as the number of allocated frames increases. Now consider the following statements:

S1: Random page replacement algorithm (where a page chosen at random is replaced) suffers from Belady's anomaly.

S2: LRU page replacement algorithm suffers from Belady's anomaly.

Ans: S1 is true and S2 is false.

Q5 Consider a process having reference string of length 'l' in which  $n$  unique pages occur. 'z' frames are allocated to the process. Calculate the lower bound and upper bound of the no. of page faults.

a) Maximum = ' $l$ ' [ $z=1$ ]

(Upper bound)

b) Minimum ( $l$ ) = ' $n$ ' [ $z \geq n$ ] - if we use pure demand paging

(Lower bound)

= 0 - if we use pre-fetched demand paging

Thrashing: Excessive / high paging activity (high page fault rate)

↓  
(The act of causing a page-fault leading to loading and saving the page on disk.)

\* Thrashing like deadlock is also an undesirable feature of OS.

Reasons for Thrashing: (Main)

1. High degree of multiprogramming
2. Frame allocation declines (lack of memory)

Other Reasons :

1. Page replacement policy

2. Page size :

large : (less pages)

Less page fault.



3. Programming techniques and data structure.

### Thrashing Control Strategies

#### 1) Prevention

- \* Thrashing never occurs.
- \* By controlling degree of multi-programming, thrashing can be controlled.

(Long term Scheduler)

#### 2) Detection and Recovery.

- \* Thrashing occurs.
- \* Thrashing can be detected when there is low CPU utilization.
- \* Max no. of processes giving back
- \* High degree of multi-programming
- \* High disk utilization
- \* Recovery: Process Suspension

(Medium Term Scheduler)

Case I : integer A[1...128][1...128]; P.S = 128 w; Row major order

1. for i ← 1 to 128  
    for j ← 1 to 128  
        A[j, i] = 1;

2. for i ← 1 to 128  
    for j ← 1 to 128  
        A[i, j] = 1;

No of page faults:

a) Pure DP:  $128^2$   
b) FIFO: 128

| $f_1$     | _____ |
|-----------|-------|
| $f_2$     | _____ |
| :         | _____ |
| :         | _____ |
| :         | _____ |
| $f_{128}$ | _____ |



Locality of Reference

$$128 \times 128 = 2^{14} \\ = 16K$$

Case II : Array v/s Linked List

Q1. Which is better for demand page environment?

Ans Array, because of less page fault.

Case III : Linear Search v/s Binary Search

$O(n)$

$O(\log n)$

Q1. Which is better for demand page environment?

Ans Linear Search may generate less page fault, (locality of reference).

Conclusion: A programming technique or a data structure is said to be good in demand page environment, if it satisfies locality model.

Working Set Strategy (Model): To minimize page fault rate and also utilize memory effectively.

< Principle of locality of reference >

| 10KB   | → 21KB   | → 28KB | → 15KB | Prog. Size = 55 KB<br>Page Size = 1 KB<br>N. of pages = 55 |
|--------|----------|--------|--------|------------------------------------------------------------|
| main() | f()      | g()    | h()    |                                                            |
| {      | {        | {      | {      |                                                            |
| :      | :        | :      | :      |                                                            |
| ⋮      | { g(); } | ⋮      | ⋮      |                                                            |
| ⋮      | }        | ⋮      | ⋮      |                                                            |
| ⋮      | }        | ⋮      | ⋮      |                                                            |
|        |          | ⋮      | ⋮      | scanf();                                                   |
|        |          | ⋮      | ⋮      | ⋮                                                          |

50% Rule → 26 frames.

The basic idea of working set model is to estimate the size of locality in which the program is executing and only ask for those many frames.

W.S.S follows dynamic type memory allocation (Allocation of frame)

Working set window (ws<sub>w</sub>): Set of unique pages referred in the reference string during the past 'Δ' references.

e.g.:  $P_i < 5, 4, 8, 2, 9, 12, 54, 58, 56, 53, 51, 52, 58, 56, 57, 54,$

$\Delta = 10$

(Sliding window)  $t$

$$ws_{w,i}^t = \{51, 52, 53, 54, 56, \\ \Delta=10 \quad \quad \quad 57, 58\}$$

$\Delta$  = integer (value)

$$ws_{w,i}^t = 7 \\ \Delta=10.$$

→ Let, No. of processes = 'n'  $\langle P_1 \dots P_n \rangle$

→ Total available frames =  $m$

→ Demand of each =  $s_i = ws_{w,i}^t$   $\Delta=10$

→ Process for frames

→ Total demand @ 't' =  $\sum_{i=1}^n s_i = D$

I.  $D = m$  [no-thrashing]

II.  $D < m$  [no thrashing]

↓  
The degree of  
multi-programming

III.  $D > m$  [Systemic  
thrashing]



\* Leads to more page faults      \* Ineffective utilization of memory

Q1. Let the Page reference and the Delta ( $\Delta$ ) be "ccdbcecead" and 4 respectively. The initial working set at time  $t=0$  contains the page {a, d, e}. Since 'd' was referenced at time  $t=0$ , 'd' was referenced at time  $t=-1$ , and 'e' was referenced at time  $t=-2$ . Determine the total number of page faults and the average number of page frames used by computing the working set at each reference.

$t < -2 \ 1 \ 0 \ 1 \ 2 \ 3 \ 4 \ 5 \ 6 \ 7 \ 8 \ 9 \ 10 >$   
e d a c c d b c e c e a d

$\Delta = 4$ 

$t_0 = \langle e d a \rangle$

$t_1 = \langle e d a c \rangle : 4$

$t_2 = \langle d a c \rangle : 3$

$t_3 = \langle a c d \rangle : 3$

$t_4 = \langle c d b \rangle : 3$

$t_5 = \langle d b c \rangle : 3$

$t_6 = \langle d b c e \rangle : 4$

$t_7 = \langle b e c \rangle : 3$

$t_8 = \langle c, e \rangle : 2$

$t_9 = \langle c e a \rangle : 3$

$t_{10} = \langle c e a d \rangle : 4$

No. of page faults = 5

Avg. WSTOQ =  $\frac{2}{10}$

## File System and Device Management

\* File System is the only visible part of the operating system.



\* Before storing the data on disk, it must be formatted in some few system (NTFS, ExFAT32, UFS)

\* Disk is a collection of circular / elliptical platters.

\* Every platter has 2 tracks surface, and consists of circular tracks.

\* Each track consists of sectors, Sector is measured in bytes





\* Disk Access Time = Seek-time (ST) + Rotational latency time + Transfer time  
 $(T_{TT}) \quad (RT = \frac{R}{2})$   
 $R$  - time for one rotation.

$T_{TT} = \text{Track-track time}$

Eg: 3600 rpm

$3600 \text{ rotations} = 60 \text{ s}$

$1 \text{ rotation} = ?$

$R = \frac{60}{3600} = 16.67 \text{ ms}$

$\rightarrow \text{Track size} = 'Z' \text{ bytes}$

$\rightarrow \text{Sector size} = 'S' \text{ bytes}$

$\rightarrow \text{Rotation time} = 'R'$

To one rotation, we can read one complete track.

$'Z' \text{ Bytes} = R \text{ (ms)}$

$'S' \text{ Bytes} = ?$

$\boxed{\text{Transfer time} = \frac{(SR)}{Z} \text{ ms}}$

Data Transfer Rate (By/sec): Rate at which the data transfer takes place  
 (Speed of disk)  
 is called data transfer rate

$'Z' \text{ Bytes} = R \times 10^{-3} \text{ (s)}$

$? = 1 \text{ s.}$

$= \frac{Z}{R} \times 10^3 \text{ Bytes/sec}$

Q1 Consider the following disk specifications

Number of platters = 16

No. of tracks / surface = 512

No. of sectors / track = 2048 (2<sup>11</sup>)

Sector offset = 12 bit  $\rightarrow 2^12 = 4\text{KB}$

Average seek time = 30 ms

Disk rpm = 3600

Calculate:

(i) Unformatted Capacity of the disk:  

$$= 32 \times 512 \times 2\text{KB} \times 4\text{KB} = 2^9 \times 2^{12} \times 2^{12} = 2^{37} (+2)$$
(missed to write.)  

$$= \underline{\underline{128\text{GB}}}$$

(ii) To time / Sector:

$$ST + LT + TT = 30\text{ms} + 8.3\text{ms} + 0 = 38.3\text{ms}$$

Track size =  $2\text{KB} \times 4\text{KB}$

$$= \underline{\underline{8\text{MB}}} \quad \left( \frac{4\text{KB} \times 16.6\text{ms}}{8\text{MB}} \right) \leftarrow TT.$$

(iii) Data transfer rate:

$$\frac{TS}{8\text{MB}} = \frac{R}{16.6 \times 10^3} \Rightarrow \frac{8\text{MB} \times 10^3 \text{s.}}{16.6} = \underline{\underline{1/2\text{GB/s}}}$$

(iv) Sector address = 2s bit required to select one sector.

| 4   | 1    | 9     | 11  | 12 |
|-----|------|-------|-----|----|
| P/t | Surf | Track | Sec | d  |
|     |      |       |     |    |
|     |      |       |     |    |
|     |      |       |     |    |

← 2s bit                      →  
                                 ← 3s bit

Disk capacity =  $2^{37} = \underline{\underline{128\text{GB}}}$   
(another approach)

Hw

Q2. Consider a disk with following Specs:

No. of surfaces = 64

Outer diameter = 16 cm, Inner dia = 4 cm

Inner track space = 0.1 mm

Track density = 8000 bit/cm

Calculate the unformatted Capacity of disk.

$$\text{No. of tracks} = \frac{6\text{cm}}{0.1\text{mm}} = \underline{\underline{600}}$$

$$\text{Inner Track SIR} = 2\pi r = \pi \times d$$

$$= 3.14 \times 4 = 12.56 \text{ cm}$$

8000 bits - 1cm  
? - 12.56 cm.

$$\text{Track SIR} = \frac{8000 \times 12.56}{8}$$

$$= 1000 \times 12.56 \text{ B.}$$

$$\text{Disk Capacity} = 64 \times 600 \times 12.56 \text{ KB}$$

$$= 64 \times 6 \times 1256 \text{ KB}$$

$$= 64 \times 6 \times 1.256 \text{ MB}$$

$$= 482.3 \text{ MB} = 0.48 \text{ GB}$$

$$\therefore \text{Disk Cap} = 0.48 = 0.5 \text{ GB}$$

- Q3. How long does it take to load a 64KB program from a disk whose avg. seek time is 30ms, Rotation time is 20ms, Track SIR is 32 Kbyte, Page SIR is 4 Kbyte. Assume that pages of program are distributed randomly around the disk. What will be the  
(i) Saving in time if 50% of the pages of program are contiguous?

$$S.T = 30 \text{ ms}$$

$$R = 20 \text{ ms}$$

$$T.S = 32 \text{ KB}$$

$$P.S = 4 \text{ KB}$$

$$N = \frac{64 \text{ KB}}{4 \text{ KB}} = N = 16$$

$$\text{Time to load program} = T. \text{to load a page} * N$$

$$\text{Time to load page} = S.T + L.T + T.T$$

$$= 30 \text{ ms} + 10 \text{ ms} + 25 \text{ ms}$$

$$= 65 \text{ ms}$$

$$\text{Prog-loading} = 42.5 \times 16$$

$$(T) = 680 \text{ ms} = 0.685$$

$$32 \text{ KB} - 20 \text{ ms}$$

$$4 \text{ KB} - ?$$

$$\frac{4 \text{ KB}}{32 \text{ KB}} \times 20 = 2.5 \text{ ms}$$

When pages are contiguous then only one seek

and one latency:

$$= (30 \text{ ms} + 10 \text{ ms} + 2.5 \times 8) + 8 \times 42.5 \text{ ms}$$

$$(C_4) \quad (N C_4)$$

$$= 60 \text{ ms} + 34 = 94 \text{ ms} = 0.94$$

$$(i) 0.685$$

$$(ii) 0.94 = 0.28 \text{ s (diff)}$$

$$\therefore \text{Savings} = \left( \frac{0.28}{0.685} \right) = 41.1\% \text{ Percentage}$$

$$\text{Savings} = 41$$

## File System and Device Management (continued)

Logical Structure of disk : [Formatting Process]

↳ Placing infrastructure on disk



[for effective storage and faster retrieval.]

"Multi boot Computer"

→ Disk divided into partitions (volumes / minidisks)

(OS) Primary  
(Bootable)

Extended / Logical drive

(Non-bootable) : Data + S/w

: Data + S/w

MBR < Master Boot record >

Partition Table  
Boot Loader

Steps in Booting process :

1. Power On or Switch On
2. POST < Power On Self Test >
3. BIOS < Basic To System >
4. Bootstrap loader MBR into Ram and hands over the control to boot loader
5. Boot loader reads partition table and display options if available.
6. Boot loader will load the kernel program from disk into memory.

Partition Structure [ What data structure (infrastructure) are embedded on the disk/partition after formatting ]



Disk is divided into 2 part: 1. Control data  
2. User data.

Some of the memory will be taken as memory overheads (B.C.B + P.C.B + D. Structure) - that is the reason in Pendrive the size mentioned will be 128GB but memory actual avail is 114GB.

### File v/s Directory:

File: File is a collection of logically related records of entity. It is an abstract data type < Definition, Representation, Operations, Attributes >

Operations: Create, Open, read, write, truncate, seek, Close, Copy, move, delete, ..

File  
(Series of Bytes)  
Record  
(Series of records)  
Hierarchical Tree  
(B-tree, B+..)

Attributes: Name, identifier, type, protection, time, date, location... (different OS have diff attributes)

\* File's attributes are stored in File Control Block (FCB)

UNIX  
(I-node)  
Windows  
(Directory entry)

Directory: It is a collection of files. It is also a special file (data about other files → "Meta data")

Directory contains meta data of files.



### Directory Structure

\* "Single level directory"

|           |     |    |   |      |      |     |      |     |         |
|-----------|-----|----|---|------|------|-----|------|-----|---------|
| Directory | car | bo | a | test | data | mai | Cont | hex | records |
|-----------|-----|----|---|------|------|-----|------|-----|---------|

(Single directory for all users)

- \* no sub directory
- \* simple to implement
- \* search time is more
- \* Name conflict.

### \* Two level directory

- \* separate directory for each user
- \* path name
- \* can have the same file name for diff. user
- \* efficient searching
- \* no grouping capability

### \* Tree Structured Directories (Multi-level)

### \* Acyclic graph Directories (File Sharing)

- also called directed acyclic graph directory for file sharing purpose
- Link count : Counts the no. of people sharing a file.

### \* General graph directory (Cycle)

- \* To search a file, we may have to traverse the directory, for that we may use Graph traversal like DFS, BFS.
- \* Directory as a file also supports operations like Open, read, write but there is a special operation on directory called "traverse".

Q1. Consider a linear list based directory implementation in a file system. Each directory is a list of nodes, where each node contains the file name along with the file metadata, such as the list of pointers to data blocks. Consider a given directory foo. Which of the following operations will necessarily require a full scan of foo for successful completion?

Ans Creation of a new file in foo.

Renaming of an existing file in foo.

### Layered File System.

Application Programs



Logical file System



File-organization module



Basic file system



I/O Control



Devices

Allocation Methods

\*  $DBA = 16 \text{ bits} / \text{block size}$

$DBS = 1 \text{ KB}$  \* Max possible file size on the disk = Max possible (given) disk size.

e.g.: no. of blocks =  $2^{16}$  = 64K

Disk size =  $64K \times 1KB = 64MB$

\* Maximum Possible disk Size =  $(2^{DBA}) \times DBS$

### 1. Contiguous Allocation of Disk Space.

Performance: 1. internal fragmentation : Yes (last block)

2. external fragmentation : Yes

3. increasing file size : Inflexible

4. type of access : Sequential | Random/direct access

(Faster)

### 2. Linked allocation of disk space.

Performance: 1. Internal fragmentation : Yes (last block)

2. External fragmentation : No

3. Increasing file size : Flexible.

4. Type of access : only sequential (slower)

5. Performance / Efficiency : ptrs consume disk space

6. Vulnerability of pointers : pointers can get broken.

(3)

### Indexed allocation of disk space

\* Each file has index block, index block holds address of data blocks of file.

eg::

|             |   |      |                                                                   |
|-------------|---|------|-------------------------------------------------------------------|
| 2.28        | } | 1KB. | DBA = 16 bits = 2B                                                |
| 2B.4        |   |      | DBS = 1KB.                                                        |
| :           |   |      |                                                                   |
| :           |   |      | No. of addresses = $\frac{1KB}{2B} = \underline{\underline{512}}$ |
| Index block |   |      |                                                                   |

eg:: DBA = 32 bits

DBS = 4KB.

Max possible file size with index block : ?

$$\text{No. of addresses} = \frac{4KB}{4B} = \underline{\underline{1K}}$$

$$\text{File size} = 1K \times 4KB = \underline{\underline{4MB}}$$

Q1. A file system supports a DBS = 4KB, each block can hold 512 addresses (ptrs). What is the size of DBA in bits?

$$\text{DBA} = \frac{\text{DBS}}{\text{N. addresses}}$$

N. addresses.

$$\begin{aligned} \text{DBA} &= \frac{4KB}{512} = \frac{2^{12}}{2^9} = 2^3 \\ &= 8B \\ &= \underline{\underline{64 \text{ bits}}} \end{aligned}$$

## Case Studies of OS

1. UNIX / LINUX : each file is associated with a I-node

| File.N | I-node |
|--------|--------|
| KKC    | 23     |

I-node Structure :



→ With double indirect

$$S12 \times S12 \times 1KB = 2^{28} = 512MB$$

$$\rightarrow \text{Total file size} = 256 \times 522 MB$$

## DOS / WINDOWS

Block info.

Master File Table

| File Name | (Other attributes) | First DBA | Last DBA | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
|-----------|--------------------|-----------|----------|---|---|---|---|---|---|---|---|---|---|----|
| KKC       |                    | 5         | 10       |   |   |   |   |   |   |   |   |   |   |    |

Linked allocation

\* No. of entries in FAT (MFT) = no. of blocks

\* Fat entry contains address of next data block

FAT-32 Fat entry size DBA

Q1. In a file allocation system, which of the following allocation schemes(s) can be used if no external fragmentation is allowed?

- Ans (i) Linked allocation  
 (ii) Indexed allocation

Q2. Consider a Unix-Inode Structure that has 8 direct disk block address and 3 indirect block address, namely single, double and triple. Disk block size is 1KB and each block can hold 128 DBA. Calculate:

(i) Max file size with this Inode structure: 16.136 MB.

$$= 8 \times 1\text{KB} + 128 \times 1\text{KB} + 128 \times 128\text{KB} + 128 \times 128 \times 128\text{KB}$$

$$= 8\text{KB} + 128\text{KB} + 16\text{MB} + 2\text{GB}$$

$$16.136\text{ MB} = 0.016\text{GB} + 2\text{G} = 2.016\text{ GB}$$

$$= \underline{\underline{2\text{GB}}}$$

(ii) Size of the disk block address:

$$\text{DBA} = \underline{1\text{KB}}$$

$$128 = \frac{2^{10}}{2^7} = \underline{\underline{2^3}} = 64\text{ bit}$$

(iii) Is this file size possible over given disk?

Q3. The index node of a Unix-like file system has 12 direct, one single-indirect and one double-indirect pointers. The disk block size is 4KB, and the disk block address is 32 bit long. The max possible file size is 4GB.

Ans N. addressed =  $\frac{4\text{KB}}{4\text{B}} = 1\text{K}$

$$\begin{aligned} \text{File Size} &= 12 \times 4\text{KB} + 1\text{K} \times 4\text{KB} + 1\text{K} \times 1\text{K} \times 4\text{KB} \\ &= 48\text{KB} + 4\text{MB} + 4\text{GB} \\ &= 4.004\text{GB} \rightarrow 4\text{GB} \end{aligned}$$

Q4 A file system with 300GB disk uses a file descriptor entry 8 DBA, 1 indirect block address and 1 doubly indirect block address. The size of each disk block is 128B and size of each DBA is 8 bytes. Max possible file size in the file system is

Ans  $DBB = 128B$

$$DBA = 8B \quad \text{No. addresses} = \frac{128}{8} = 16$$

$$\begin{aligned} \text{File Size} &= 8 \times 128B + 16 \times 128B + 16 \times 16 \times 128B \\ &= 1KB + 2KB + 32KB \\ &= \underline{\underline{35KB}} \end{aligned}$$

Q5. The data blocks of a very large file in the Unix file system are allocated using:

Ans An extension of indexed allocation

Q6 Using a larger block size in a fixed block size file system leads to  
Ans Better disk throughput and poor disk space utilization

Q7 A FAT based file system is being used and total overhead of each entry in the FAT is 4 bytes in size. Given a  $100 \times 10^6$  byte disk on which the file system is stored and data block size is  $10^3$  bytes, the maximum size of a file that can be stored on this disk in units of  $10^6$  bytes is  $\underline{\underline{99.6}}$

$$N = \frac{100 \times 10^6}{10^3} - 100 \times \frac{4}{10^3}$$

$$\begin{aligned} \text{Max. file size} &= \text{Given disk size} - \text{FAT size} \\ &= 100 \times 10^6 - 0.4 \times 10^6 \\ &= \underline{\underline{99.6 \times 10^6}} \end{aligned}$$

$$\begin{aligned} \text{FAT size} &= 100 \times 10^3 \times 4B \\ &= 400 \times 10^3 B \\ &= 4 \times 10^5 B \\ &= 0.4 \times 10^6 B. \end{aligned}$$

Q8 A file system with one level directory structure is implemented on a disk with disk block size of 4KB. The disk is used as follows:

Disk block 0 : Boot control block

Disk block 1 : File allocation system/table, consisting of 10-bit entry per data block, representing the data block address of next data block in file.

Disk block 2, 3 : Directory with 32-bit entry per file.

Disk block 4 : Data block

Disk block 5 : Data block 2, 3, etc.

(i) What is the max possible number of files?

(ii) What is the max possible file size in bytes?

Ans. Number of files (max) = no. of entries

$$= \frac{8 \text{ KB}}{4 \text{ B}} = 2^10 = 2048$$

DBA = 10 bits

DBS = 4 KB

Max file size = Disk size - (control overhead) No. of blocks =  $2^{10}$

$$\begin{aligned} &= 1024 - 4 = 1020 \times 4 \text{ KB} = 1024 - 4 = 1020 \\ &= 4080 \text{ KB} \\ &= 4.08 \text{ MB} \end{aligned}$$

Q9. Consider a file system that stores 128 DBA in the index table of the directory. Disk block size is 4 KB. If the file size is less than 128 blocks, then these addresses act as direct data block addresses.

However, if the file size is more than 128 blocks, then the 128 addresses in the index table point to next level index blocks, each of which contains 256 data block addresses. What is the max file size in the system?

Ans. Min file size =  $128 \times 4 \text{ KB}$

$$= 512 \text{ KB}$$

$$128 \times 256 \times 4 \text{ KB}$$

$$= 2^7 \times 2^8 \times 2^{12} = 2^{27} = 128 \text{ MB}$$

## Disk Free Space management algorithms:

Assume: Disk - 20 MB;

DBS : 1 KB

DBA : 16 bits

$$\text{N. blocks} = \frac{20\text{MB}}{1\text{KB}} = \frac{20\text{K}}{1\text{KB}}$$

Given disk  $\leq$  Max. possible size

$\therefore$  D.S

$$2^{\text{DBA}} \times \text{DBS}$$

1. Free linked list : linked list of free blocks.



2. Free list : keeps track of free blocks only, faster compared to bit map.



Q. How many blocks are (freelist) are needed to store 20K free DBS?

Ans: 1 Block - 512 free DBS

$$? - 20\text{K free DBS} = \frac{20\text{K}}{512} = 40$$

3. Bit-map / Vector

: Associate a Binary bit with each block

: Bit Map keeps track of all blocks

: Slower Compared to bit-map. (In-use)

Q. How many blocks of disk are needed to store our bit-map?

Ans: DBS = 1 KB

DBA = 16 bits

1 Block  $\rightarrow$  8 Kbit

?  $\rightarrow$  20K bit

$$\frac{20\text{K}}{8\text{K}} = 2.5 = 3 \text{ Blocks}$$

4. Counter method: When we have many Contiguous free blocks.

Start free DBA: No. of CG free blocks

|    |     |     |
|----|-----|-----|
| 1. | 5   | 45  |
| 2. | 85  | 200 |
| 3. | 325 | 125 |
| 4. | 600 | 25  |

e.g.: New Free F = 20 blocks  
Consumption can be done by  
first fit, best fit, even fit.

Q1. Consider a disk with 'B' blocks, 'F' are free, DBA is 'D' bit Disk block size is 'x' Bytes.

(A) Calculate:

(i) Given disk size : " $B \times x$ " Bytes.

(ii) Max. possible disk size =  $2^D \times x$  Bytes

(iii) Relation b/w 'B' and 'D':  $B \leq 2^D$ .

(B) What is the condition in which Free List uses less space than Bit-Map?

$$F + D < B$$

Q2. The beginning of a free space bit map looks like after the disk partition is first formatted: 100 0000 0000 0000. The system always searches for free blocks starting at the lowest numbered block, so after writing file A, which uses 6 blocks, the bit map looks like this: 1111 1110 0000 0000. Show the bit map after each of the following additional actions of the code.

- \* File B is written, using 5 blocks
- \* File deleted.

Q3. A file system uses an in-memory Cache to cache disk blocks. The miss rate of the cache is shown in the figure. The latency to read a block from Cache is 1 ms and to read a block from disk is 10 ms. Assume that the cost of checking

whether a block exists in the Cache is negligible. Available Cache Size are in multiples of 10MB.

The Smallest Cache size required to ensure an average read latency of less than 6ms is 30MB MB.

Ans

$$6\text{ms} = x(1\text{ms}) + (1-x)(10\text{ms})$$

$$= x + 10 - 10x$$

$$-4 = -9x$$

$$x = 4/9 = 0.44.$$

$$\text{Miss ratio} = 0.55$$

$$55 \cdot \Rightarrow 25\text{ms}$$

$= 30\text{ms}$  (for this miss ratio  
reduce, FMAT  $\downarrow$ )

Q4. The amount of disk space that must be available for page storage is related to maximum number of process 'N', the number of bytes in Virtual Address Space 'B' and the number of bytes in RAM 'R'. Give an expression for worst case disk space required:

Ans.

$$N \times S \text{ Bytes}$$

### Device Scheduling:

Process requests : 98, 183, 37, 122, 14, 124, 65, 67. (Track no./cylinder no.)



Total no. of seeks = 640

$$\text{Avg no. of seeks} = \frac{640}{80}$$

$$= 80$$

\* Objective of disk scheduler  
is to reduce average seek time.



- ② Shortest Seek time first : Total Seek = 236



- ③ Scan/Elevator : Total Seek = 331



- ④ Look : Total Seek = 299



- ⑤ C-Scan (Circular) : Total Seek = 382



⑥ C-Look : Total seeks : 322

- Q1. Consider a disk queue with requests for 210 to blocks on cylinder 47, 38, 121, 191, 87, 11, 92, 10. The C-Look Scheduling Algorithm is used. The head is initially at cylinder no. 63, moving towards larger cylinder numbers on its servicing pass. The cylinders are numbered from 0 to 199. The total head movement incurred while servicing these requests is: 346



- Q2. Disk requests come to disk driver for cylinders 10, 22, 20, 2, 40, 05 and 38, in that order at a time when the disk drive is regarding from cylinder 20. The seek time is 6ms/sec per cylinder. Compute the total seek time if the disk arm scheduling algorithm is:

(a) First Come First Serve.

## (b) Closest cylinder next:

Q4. Consider a storage disk with 4 platters (0-43) 200 cylinders (0-199) and 256 sectors per-track (numbered as 0, 1, 255). The following 6 disk requests of the form [Sect.no, Cyl.no, platter no] are received by disk controller at same time [120, 72, 2], [184, 134, 1], [60, 20, 0], [212, 86, 3], [56, 116, 2], [118, 6, 1].

Currently head is at no. 100 of cylinder 80 and moving towards higher cylinder numbers. The average power dissipation in making the head over 100 cylinders is 20 milliwatt and for reversing the direction of the head movement once is 15 milliwatt. Power dissipation associated with rotational latency and switching of head between different platters is negligible. The total power consumption in milliwatts to satisfy all of the above disk request using the shortest seek time first disk scheduling algorithm is 85.

Anc. Requests <72, 134, 20, 86, 116, 16>



Q5. Suppose a disk has 201 cylinders, numbered from 0 to 200. At some time the disk arm is at cylinder 100, there is a queue of disk access requests for cylinders 30, 85, 90, 100, 105, 110, 135, 145. If SSTF is being used for scheduling the disk access

the request for cylinder 90 is serviced after servicing 3 no of requests.

Ans.



Q6 Consider an operating system capable of loading and executing a single sequential user process at a time. The disk head scheduling algorithm used is FCFS. If FCFS is replaced by SPT, claimed by vendor to give 50% better benchmark results, what is the expected improvement in the I/O performance of user programme?

Ans. 0.1 (no improvement)

Q7. Consider the following five disk access requests of the form (req. id, cylinder number) that are present in the disk scheduler queue at a given time (P, 155), (Q, 85), (R, 110), (S, 30), (T, 115)  
Ans  
Assume the head is positioned at cylinder 100. The scheduler follows Shortest Seek Time First to serve the requests. Which of statements is false?

Q8. Consider a disk with following details:

Track-track time = 1ms.

Current-head position = 6s

Direction: moving towards higher tracks with higher track - 199

Current clock time = 160ms.

Consider the following data set:

TW

| Track no. | T. of arrival |
|-----------|---------------|
| 12        | 65 ms         |
| 85        | 80 ms         |
| 40        | 110 ms        |
| 100       | 120 ms        |
| 75        | 175 ms        |

Calculate time of decision, Pending requests, Head position, Selected request, Seek time using FCFS, C-scan, SSTF, SCAN, LOOK, C-LOOK algorithms.

