

Software: set of tested programs + documentation

## Software

### System software

(low-level software)

[ runs in background ]

- operating s.s.

- Device Drivers

- Translators

  - + Compiler

  - + Interpreter

  - + Assembler

- Utility

  - antivirus

  - cleanup tools

  - defragmenters

### Application software

(end-user software)

[ runs above system software ]

- Word Processors

  - NotePad, MS Word

- Database software

  - MySQL, MS Access

- Multimedia software

  - VLC Media Player, Windows MP.

- Graphics software

  - Adobe Photoshop, Blender

- Web Browsers

  - Google Chrome, Opera, uc

## OPERATING SYSTEM SOFTWARE

[ kernel - core program ] + [ some more system p/g ]

User's View :

It is an interface between the user and the hardware [ CPU, I/O devices, memory ]

System's View : control program

It is a Resource Manager



components of computer system

Interface :

- CUI [Character User Interface]

eg : DOS

- GUI [Graphical User Interface]

eg : Windows

FUNCTIONSGOALS

- Resource Management
- CPU Scheduling / Process Management
- Memory Management (Mainly RAM)
- I/O device Management
- Storage Management [disk / file system]
- Security & Protection (passwords etc.)
- Process synchronization
- coordination between other software & users (e.g. translation)

- Efficient utilization of resources
- Convenience (user-friendly)

TYPES

eg: job

|                    |                   |
|--------------------|-------------------|
| Calculator Program |                   |
| Input : 12,2       | Output : division |

12/2

1) Batch Operating System

Job : Program + input data + control instructions

Batch : group of similar kind of jobs

- Each user prepares its job on an off-line device (punch cards) and submits it to the computer operator.
- Computer operator then groups similar kind of jobs to speed up the processing. [All the jobs in a batch requires similar resources] → time of allocation/deallocation reduced.
- Batches are fed to the computer one by one. One job is executed at a time. First come first served.
- Then output is obtained (in the form of punch cards) and returned to the user.

Advantages

- saves time that was being wasted earlier (context switching)
- No manual intervention required
- Multiple users can share batch system

Disadvantages

- CPU remain idle for long time
- May lead to starvation
- Priority can't be set for jobs
- Lack of interaction b/w user & job

## 2) Multi Programming Operating System



Multiprogramming : Interleaved execution of multiple processes by the same computer

Note : Only one process is executed by a processor at a time

- In multiprogramming, multiple processes are loaded into the main memory which are ready to execute.
- If running process performs I/O operations etc., CPU doesn't sit idle rather picks another process for execution.
- Therefore CPU never sits idle [except at the time of context switching or if no process is ready for execution]

### Advantages

- High CPU utilization
- Waiting time is less
- Increased throughput
- Priority can be assigned

Multi - user

### Disadvantages

- Scheduling is required
- Main memory management is required [Memory fragmentation, paging]
- CPU is allocated to another process only if it is idle
- Context switching is required

### 3) Multi Tasking - Operating System

maximizes  
response  
time

( Time sharing / fair share / Multiprogramming with Round-Robin )



Multi tasking: execution of multiple tasks by sharing processor's time.

Time quantum / slice / slot: short period of time during which a task gets user CPU attention. (10-100 milliseconds)

- Multiple processes are loaded into the memory and CPU switches between them in fixed time intervals (time quanta)
- Time slot is decided by the OS
- Context switching is frequent enough to give an impression that all tasks are being executed simultaneously
- Reduces response time (main goal)

#### Advantages

- Response time ↓
- High CPU efficiency
- Throughput ↑
- Multi-user & user friendly

#### Disadvantages

- context switching overhead
- data communication problems
- system must have higher specification

## Multi Processing Operating Systems



Multiprocessing: executing multiple processes simultaneously using multiple processors.

- Multiple processors work in parallel sharing the resources like memory, bus, peripheral devices, system clock etc (tightly coupled systems)
- Applications designed for the use in multiprocessor are threaded, so they can be broken into smaller routines and that are executed on multiple processors independently
- Each CPU contains a copy of the OS and these copies communicate with one another to coordinate operations.
- Used when large data is to be processed at high speed eg: satellite control, weather forecasting etc.

### Types:

- Symmetric Multiprocessing OS (SMP OS)
- Asymmetric Multiprocessing OS (ASMP OS)

Adv.: - high speed, time ↓ throughput  
 - if one CPU fails, others handle the execution  
 - cost effective [shared resources]

Disadv.: - Process sync required  
 - Memory management  
 - CPU scheduling

## i) Symmetric Multi-processing OS

- All processors are equal (no master - no slave)
- All processors can execute processes as per their decisions and have equal load.
- Processors communicate with each other for the execution if required.

### advantages

- If one processor fails, other handles the execution
- No dependency.

### disadvantages

- difficult to design

## ii) Asymmetric Multi-processing OS

- It uses the concept of Master-Slave architecture
- Only one processor work as a primary or master processor which controls the other slave processors.
- Some processors are assigned maintenance task while others perform application tasks (asymmetry)

### advantages

- easy to design

### disadvantages

- If master processor fails, execution stops

## PROCESSES

program : set of instructions that perform a specific task.  
 (process unit)

Process : a program in execution  
 (active unit) - it is an instance of a computer program that is being executed by one or many threads.

- Stack : contains the temporary data such as function parameters, local variables, return addresses etc. [size is determined during compilation & allocated when process begins to execute]
- Heap : dynamically allocated memory to a process during runtime [via new, malloc etc.] [size is determined during runtime & allocated during execution]
- Data : global and static variables
- Text : compiled program code [current activity represented by the value of program counter & contents of processor's registers]



PCB (Process Control Block) Task Control Block

PCB is a data structure used by OS to maintain all the information about a process  
[Brain of a Process]

- |                                                                                                                             |                                                                                                 |
|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|
| • Process ID : Unique Id / number provided to each process by the OS                                                        | Process ID<br>Pointer                                                                           |
| • Counter : points to parent process                                                                                        | Process state<br>Process Counter                                                                |
| • Process state represents current state of the process : new, ready, running etc.                                          | CPU registers<br>CPU scheduling<br>Memory management info<br>Accounting info<br>I/O status info |
| • Process counter : represents the address of next instruction to be executed.                                              | Process privileges                                                                              |
| • CPU registers : contains state info of the process which allows the process to continue when it is scheduled to run again | ( accumulators, index registers, stack pointer etc)                                             |
| • CPU scheduling information : stores the parameters of criteria used for scheduling such as process priority etc.          |                                                                                                 |

- Memory Management info: stores limit register info, page and segment tables etc.
- Accounting info keeps bookkeeping data such as CPU time used, time limits, job numbers etc.
- I/O status info: list of I/O devices allocated to the process, list of open files.
- process privileges: access-permissions for resources of the system.

Context Switching remove PCB of running process & place PCB of next process in queue

- It is a process in which CPU switches from one process or task to another.
- The state of currently running process is saved (so that it can resume execution later) and another process is allotted to the CPU.
- It is used for multitasking.
- Context switching occurs so fastly that it gives an illusion that all processes are being executed at the same time  
(state of running process is switched)

Steps involved :

- Context of the process P1 (running currently) is saved in the PCB of process 1
- PCB1 is moved to relevant queue (ready queue, I/O queue, waiting queue etc.)
- New process that is to be executed is selected from ready queue
- PCB of process 2 is updated.



- Triggers for context switching
- Multitasking
  - Interrupt Handling
  - User and kernel Mode switching

### Advantages

- used for multitasking / multiprogramming .
- only 1 CPU is required to run multiple processes.

### Disadvantage

- context - switch time is pure overhead (No useful task is performed during context switching )  
(takes few msec. / switch)



- **New:** The program which is to be picked up by the OS for execution (from the secondary memory) is said to be in 'new' state.  
At a time - multiple processes can be in new state.
- **Ready:** After creation, process is transferred to main memory in Ready queue & is said to be in 'ready' state.  
A process in ready state waits for the CPU to be assigned.  
At a time - multiple processes can be in ready state.
- **Running:** Once a process is chosen by OS for execution from the ready queue, it enters into 'running' state.  
At a time - only 1 process can be in running state (for single processor)  
- n processes — (for n processors)
- **Waiting / Blocked** Whenever a process requires other resources (I/O devices etc.), it enters in 'waiting' or 'blocked' state & waits for the resources (in waiting queue).  
At a time - multiple processes can be in waiting state.

- Terminated: When process finishes its execution, it comes in the terminated state. Reallocation of resources PCB for the process is deleted by OS.
- Suspended Ready: Some processes are transferred to secondary memory from the ready queue (main memory) due to lack of resources (primary memory). Such processes are said to be in 'suspended ready' state.
  - When high priority processes come for execution & main memory is full, lower priority processes are transferred to sec. memory.
  - Suspended ready processes wait in the sec. memory until space gets available in the main memory & are then transferred to the main memory again.
- Suspended Waiting: When processes are transferred to sec. memory from the waiting or blocked state, they are said to be in 'suspended waiting' state (due to lack of space in main memory).
  - A process in suspended waiting state still executes & is transferred to suspended ready state in case I/O op. is completed & if still not completed & space gets available in waiting queue  $\rightarrow$  returns to the waiting queue]

- CPU bound processes : processes which spend most of their time on executing the code i.e. take more CPU time.  
eg :
  - complex mathematical algorithms
  - searching / sorting algorithms
  - encryption / decryption algorithms
- I/O - Bound processes : processes which spend most of their time submitting I/O requests and waiting for the response i.e. takes more I/O time.  
eg : word processor  
[more time is spent in waiting for input & less on CPU - spell checking, auto suggestion etc.]
- Throughput : Number of processes completed per unit time

point of time → Arrival time : The point of time at which process enters the ready queue / state.

duration → Burst time : time required by a process to get executed on CPU  
( execution time / running time / CPU time )

point of time → Completion time : The time at which process completes its execution ( exit time )

duration → Turnaround time : Total time spent by a process in the system

$$\begin{aligned} TA \text{ time} &= \text{Completion / exit time} - \text{arrival time} \\ &= \text{Burst time} + \text{waiting time} \end{aligned}$$

duration

- Waiting time : time spent by process in ready queue waiting for the CPU.
- $$\text{waiting time} = TA \text{ time} - \text{burst time}$$

duration

- Response time : Time between a process enters ready queue and gets scheduled on the CPU for the first time.
- $$RT = \text{time at which process gets CPU for the first time} - \text{arrival time}$$

- Starvation (indefinite blocking)

Phenomenon in which a process is ready to run but has to wait indefinitely due to lower priority [when CPU is biased]

Schedulers Special system software used to handle process scheduling

### 1) Long Term Scheduler

Selects processes from secondary memory & loads them into main memory (in ready queue) for execution

- controls the degree of multiprogramming [no. of processes that can fit in ready queue]
- LT scheduler must select a careful mixture of I/O bound & CPU bound processes

If CPU bound processes ↑ → I/O devices remain idle

If I/O bound processes ↑ → CPU remains idle.

### 2) Short Term Scheduler

Selects a process from the ready queue for execution based on some scheduling algorithm. CPU scheduling

- executes most frequently
- ensures that there is no starvation due to high burst time processes

### 3) Medium Term Scheduler

Swaps out a process from main memory [from ready queue / waiting queue] & places into sec. memory [suspended ready / suspended waiting queue] & later swaps in.

- responsible for suspending & resuming a process
- for maintaining balance b/w I/O & CPU bound processes
- degree of multiprog.

Dispatcher responsible for loading the process selected by ST scheduler on the CPU from ready queue

- context switching

frequency : ST > MT > LT

## PROCESS - SCHEDULING

It is an OS task which involves allocation of resources and time to the processes in multi programming systems.

- handles the removal of the running process from the CPU & selection of another process on the basis of a particular algorithm.
- schedules processes in different states - ready, running and waiting
- OS maintains separate queue for each of the process states:
  - Job Queue: keeps all the processes not in system
  - Ready Queue: keeps all the processes residing in main memory, ready to execute
  - Device Queue: keeps all the processes which are waiting for I/O devices.

(Ready State)

CPU

Pending Data

CPU Scheduling

Process of determining which process will use the CPU while another process is on hold (for maximum CPU utilisation) based on different algorithms [using SJF scheduler]

Criteria

- CPU utilization should be maximum  
ideally - 100%, practically - 40% - 90%.
- Throughput should be high  
10/second
- Avg. Turnaround time should be minimum
- Avg. waiting time minimum
- Avg. response time minimum

## CPU Scheduling Algorithms

### 1) Preemptive Scheduling

- CPU can be allocated to another process of high priority (or due to time quantum) in between the execution of currently running process.
- efficient CPU utilization
- WT & RT is less
- overhead of switching the process from ready stat to running stat & vice versa.
- CPU is allocated to a process for specific time (may be less than its BT)
- Round Robin, SRTF, preemptive priority.  
low priority processes may face starvation

2) Non-preemptive scheduling

- CPU can't be allocated to another process until current process completes its execution.

- Poor CPU utilization
- WT & RT is high
- No such overhead

- CPU is allocated to a process until it terminates (equal to its BT)
- FCFS, non-preemptive SJF, non-preemptive priority may lead to convoy effect

PUSchd.  
ago →

FCFS, SJF, LJF, Multilevel Queue

SRTF, LRTF, Round Robin, Priority

B+



DI \_\_\_\_\_

Pg \_\_\_\_\_

B+

### FIRST COME FIRST SERVE (FCFS)

[available for batch os]

(simplest algorithm)

assign CPU to the process which arrives first into the ready queue

- Non-preemptive scheduling ( $WT = RT$ )

[as soon as a process gets response - doesn't have to wait anymore - completes &amp; exits]

Example:

(Assumption: I/O time is not required for any process)

| Process | Arrival time (AT) | Burst time (BT) | Completion time (CT) | Turnaround time (TAT) | Waiting time (WT) | Response time (RT) |
|---------|-------------------|-----------------|----------------------|-----------------------|-------------------|--------------------|
| P1      | 2                 | 2               | 4                    | 4-2 = 2               | 2-2=0             | 0                  |
| P2      | 0                 | 1               | 1                    | 1-0 = 1               | 1-1=0             | 0                  |
| P3      | 2                 | 3               | 7                    | 7-2 = 5               | 5-3=2             | 2                  |
| P4      | 3                 | 5               | 12                   | 12-3 = 9              | 9-5=4             | 4                  |
| P5      | 4                 | 4               | 16                   | 16-4 = 12             | 12-4=8            | 8                  |
|         |                   |                 |                      | 29                    | 14                | 14                 |

\*[if more than 1 process arrive at same time - any of them can be taken]

Gantt chart :



$$\rightarrow \text{average TAT} : 29/5 = 5.8$$

$$\rightarrow \text{average WT} : 14/5 = 2.8$$

$$\rightarrow \text{average RT} : 14/5 = 2.8$$

$$\rightarrow \text{throughput} : 5/16$$

### Convey Effect

It is a phenomenon associated with FCFS in which processes of higher burst time comes before the processes with lower burst time resulting in high avg waiting time.

a CPU bound process followed by I/O bound process

| Case 1         |    |    |     |    |
|----------------|----|----|-----|----|
| Process        | AT | BT | TAT | WT |
| P <sub>1</sub> | 0  | 50 | 50  | 0  |
| P <sub>2</sub> | 1  | 1  | 50  | 49 |
| P <sub>3</sub> | 1  | 2  | 52  | 50 |

starvation:  
wait due  
to priority

gantt chart:

| P <sub>1</sub> | P <sub>2</sub> | P <sub>3</sub> |
|----------------|----------------|----------------|
| 0              | 50             | 51             |

$$\text{avg waiting time} = 99/3 = 33$$

gantt chart:

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

$$\text{avg waiting time} = 3/3 = 1$$

Case 1 suffers from convey effect.

- Adv.:- simple & easy algorithm  
 - suitable for batch OS

Disadv.:- convey effect

- non-preemptive nature - CPU utilization is low.
- doesn't respond according to priority of process

- Three processes  $P_1, P_2, P_3$  with process time 20, 30, 10 respectively. Each process uses first 30% of its process time on CPU then 50% in I/O & last 20% on CPU. Find avg WT, TAT, RT if FCFS scheduling is followed.

| Process | PT | AT | BT | I/OT | BT | CT | TAT | WT | RT |
|---------|----|----|----|------|----|----|-----|----|----|
| $P_1$   | 20 | 0  | 6  | 10   | 4  | 22 | 22  | 12 | 0  |
| $P_2$   | 30 | 0  | 9  | 15   | 6  | 36 | 36  | 21 | 6  |
| $P_3$   | 10 | 0  | 3  | 5    | 2  | 25 | 25  | 20 | 15 |

$P_1 \text{ } P_2 \text{ } P_3 \text{ } X \text{ } X$



$$\text{avg. RT} = 21/3 = 7$$

$$\text{avg. WT} = 53/3 = 17.\bar{6}$$

$$\text{avg. TAT} = 83/3 = 27.\bar{6}$$

$$\text{throughput} = 3/36 = 1/12$$

$$\text{CPU utilization factor} = \frac{30}{36} = 0.833 = 83.3\%$$

$$\text{CPU idle time factor} = \frac{6}{36} = \frac{1}{6} = 16.6\%$$

SHORTEST JOB FIRST ( SJF )

- assigns CPU to the process which has smallest burst time out of all the processes present in ready queue - effectively reduces the average waiting time .

- Preemptive SJF ( SRTF )
- non-preemptive SJF ( normal )

Non-preemptive SJF

Once CPU is assigned to a process , it can't be snatched by another process , even if its burst time is smaller .

Example :

\* I/o times X

| Process        | AT | BT | CT | TAT | WT | RT |  |
|----------------|----|----|----|-----|----|----|--|
| P <sub>1</sub> | 2  | 1  | 7  | 5   | 4  | 4  |  |
| P <sub>2</sub> | 1  | 5  | 16 | 15  | 10 | 10 |  |
| P <sub>3</sub> | 4  | 1  | 8  | 4   | 3  | 3  |  |
| P <sub>4</sub> | 0  | 6  | 6  | 6   | 0  | 0  |  |
| P <sub>5</sub> | 2  | 3  | 11 | 9   | 6  | 6  |  |
|                |    |    |    | 39  | 23 | 23 |  |

\* [if more than one process have same BT  $\rightarrow$  follow FCFS ] : P<sub>4</sub>, P<sub>1</sub>, P<sub>2</sub>, P<sub>3</sub>, P<sub>5</sub>



throughput : 5 / 16

avg waiting time :  $23 / 5 = 4.6$

avg response time : 4.6

avg TAT :  $39 / 5 = 7.8$

Preemptive SJF

(SRTF : Shortest Remaining Time First)

CPU can be allotted to another process if its burst time is smaller than currently running process. the remaining time of

Example :

| Process        | AT | BT    | CT | TAT | WT | RT |
|----------------|----|-------|----|-----|----|----|
| P <sub>1</sub> | 2  | 1     | 3  | 1   | 0  | 0  |
| P <sub>2</sub> | 1  | 5     | 16 | 15  | 10 | 10 |
| P <sub>3</sub> | 4  | 1     | 5  | 1   | 0  | 0  |
| P <sub>4</sub> | 0  | 6 5 4 | 11 | 11  | 5  | 0  |
| P <sub>5</sub> | 2  | 3 2   | 7  | 5   | 2  | 1  |
|                |    |       |    | 33  | 11 | 11 |

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

Gantt chart : 

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

$$\text{avg. TAT} = 33/5 = 6.6$$

$$\text{avg. WT} = 17/5 = 3.4$$

$$\text{avg. RT} = 11/5 = 2.2$$

$$\text{throughput} = 5/16$$

If arrival time is same for all processes  
non preemptive SJF  $\approx$  preemptive SJF

Dr.

Pg.

B+

- Adv. :
- min. avg. WT & TAT (SRTF) than all other algo
  - better response time
  - max. throughput (SRTF)
  - provides a standard for other algo [for wt]  
used in batch OS
- optimal when arrival time is same for all processes.  
(no convoy effect)

- Disadv. :
- can not be implemented bcz it depends on BT of the processes which is usually not known beforehand. (approx BT can be determined)
  - may lead to starvation of the processes with larger burst time. [Longer BT process may have to wait for a long time]
  - convoy effect in non-preemptive SJF
  - priorities can't be set
  - poor response time for processes with larger BT

## Prediction of Burst time

To implement SJF algo, BT needs to be known before  
 Following techniques are used to predict BT:

### → Static Techniques

- Process size

If  $P_{old}$  ( $100 \text{ KB}$ ) - 5 units

$\therefore P_{new}$  ( $102 \text{ KB}$ )  $\approx 5$  units

As their size is approximately same, their BT is predicted to be equal.

- Process type

- OS process (system process)

[schedulers, compilers, program managers etc]

lower BT - 3 to 5 units

- User process

|- interactive process I/O bound

lower BT

|- foreground process I/O bound + CPU bound

slightly higher BT MS office, editors

background process CPU bound

higher BT key logger

→ Dynamic Techniques

- Simple Averaging

$$\begin{array}{ccccc} P_1 & P_2 & P_3 & P_4 & P_5 \\ \downarrow & \downarrow & \downarrow & \downarrow & \downarrow \\ P_6 = \frac{t_1 + t_2 + t_3 + t_4 + t_5}{5} \end{array}$$

Predicted burst time of  $(n+1)$ th process =  $\frac{1}{n} \sum_{i=1}^n T(i)$

- Exponential Averaging

$$E_{i+1} = \alpha A_i + (1 - \alpha) E_i$$

$E_{i+1}$  = expected time for process  $i+1$

$E_i$  = expected time for process  $i$

$A_i$  = Actual burst time of process  $i$

$\alpha$  = Smoothening factor

$$0 \leq \alpha \leq 1$$

• If  $\alpha = 0$        $E_{i+1} = E_i$  expected BT of previous process

• If  $\alpha = 1$        $E_{i+1} = A_i$  Actual BT of previous process

• If  $\alpha = 1/2$       equally weighted -  $E_i \& A_i$

Ex:  $\alpha = 0.5$        $E_1 = 5$        $E_5 = ?$

| Process | BT | $E_i$ | $E_2 = 0.5(4) + 0.5(5)$                       |
|---------|----|-------|-----------------------------------------------|
| $P_1$   | 4  | 5     | $= 2.0 + 2.5 = 4.5$                           |
| $P_2$   | 8  | 4.5   | $E_3 = 0.5(8) + 0.5(4.5)$                     |
| $P_3$   | 5  | 6.25  | $= 4.0 + 2.25 = 6.25$                         |
| $P_4$   | 6  | 5.625 | $E_4 = 0.5(5) + 0.5(6.25)$                    |
|         |    |       | $2.5 + 3.125 = 5.625$                         |
|         |    |       | $E_5 = 0.5(6) + 0.5(5.625)$                   |
|         |    |       | <del><math>3.0 + 2.8125 = 5.8125</math></del> |

→ Three processes  $P_1$ ,  $P_2$ ,  $P_3$  with process time 20, 30, 10 respectively. Each process uses its first 30% of the process time on CPU, then 50% in I/O & last 20% on CPU. Find avg WT, TAT, RT, CPU utilisation % if system follows SJF scheduling non-preemptive by default

| Process | PT | AT | BT | I/O T | BT | TAT | TAT-BT | WT | RT       |
|---------|----|----|----|-------|----|-----|--------|----|----------|
| $P_1$   | 20 | 0  | 6  | 10    | 4  | 24  | 14     | 3  |          |
| $P_2$   | 30 | 0  | 9  | 15    | 6  | 41  | 26     | 11 |          |
| $P_3$   | 10 | 0  | 3  | 5     | 2  | 11  | 6      | 0  |          |
|         |    |    |    |       |    |     |        |    | 76 46 14 |

\* \* \*



$$\text{avg WT} = 46/3 = 15.3$$

$$\text{avg TAT} = 76/3 = 25.3$$

$$\text{avg RT} = 14/3 = 4.6$$

$$\text{CPU utilization factor} = \frac{\text{expected CPU time}}{\text{actual CPU time}} = \frac{30}{41} = 0.7317 \approx 73\%$$

$$\text{CPU idle time factor} = \frac{\text{CPU idle time}}{\text{total CPU time}} = \frac{11}{41} = 0.2683 \approx 27\%$$

$$\text{throughput} = 3/41$$

ROUND ROBIN

[FCFS + time quantum]

assigns time slices to each process in equal portions  
 (in circular order) [starvation free] [nonshortest  $\downarrow$ ]

- no priorities
- suitable for time sharing OS
- preemptive

Time quantum: period of time for which process is allowed to execute uninterruptedly in preemptive multitasking  
 (10 - 100 ms)

- Time quantum must be selected carefully
  - if too small
    - overhead of context switching
    - waiting time  $\uparrow$
  - if too large - ends up as FCFS scheduling



Example:

| → Process        | AT | BT    | CT | TT | WT | RT |
|------------------|----|-------|----|----|----|----|
| ✓ P <sub>1</sub> | 0  | 8 5 2 | 22 | 22 | 14 | 0  |
| ✓ P <sub>2</sub> | 5  | 2     | 11 | 6  | 4  | 4  |
| ✓ P <sub>3</sub> | 1  | 7 4 1 | 23 | 22 | 15 | 2  |
| ✓ P <sub>4</sub> | 6  | 3     | 14 | 8  | 5  | 5  |
| ✓ P <sub>5</sub> | 8  | 5 2   | 25 | 17 | 12 | 9  |
|                  |    |       |    | 75 | 50 | 20 |

$$TQ = 3$$



$$\text{avg TT} = 75/5 = 15$$

$$\text{avg WT} = 50/5 = 10$$

$$\text{avg RT} = 20/5 = 4$$

| → Process        | BT    | AT | CT            | TT           | WT            | RT | • context switch time = 1 unit              |
|------------------|-------|----|---------------|--------------|---------------|----|---------------------------------------------|
| ✓ P <sub>1</sub> | 8 5 2 | 0  | 32            | 32           | 24            | 0  |                                             |
| ✓ P <sub>2</sub> | 2     | 0  | 6             | 6            | 4             | 4  | • TQ = 3 units                              |
| ✓ P <sub>3</sub> | 7 4 1 | 0  | 34            | 34           | 27            | 7  | - no. of context switches = 9               |
| ✓ P <sub>4</sub> | 3     | 0  | 14            | 14           | 11            | 11 |                                             |
| ✓ P <sub>5</sub> | 5 2   | 0  | 29            | 29           | 24            | 15 | - CPU utilization = $\frac{25}{34} = 0.735$ |
|                  |       |    | 115/5<br>= 23 | 90/5<br>= 18 | 37/5<br>= 7.4 |    |                                             |



- Adv. : - easy & simple to implement (it's not required as in SJF)  
 - each process gets a fair share of CPU (same priority for all processes)  
 - starvation free  
 - no convoy effect  
 - diminishes response time  
 - suitable for multitasking

Disadv. : - deciding size of TA is very tough.

(if not decided properly may lead to)

WT ↑, TAT ↑, RT ↑, throughput ↓, CPU utilization ↓

- overhead of context switching
- priorities can't be set.

→ Let there are  $n$  processes in a system. Context switch time is  $S$  seconds. What should be the max time quantum so that any process has to wait for almost  $T$  seconds to enter in CPU again?



$$[t_q * (n-1) + n * S] \leq T$$

$$t_q \leq \frac{T - nS}{n-1}$$

## PRIORITY SCHEDULING

- A priority is associated with each process. CPU is assigned to the process having higher priority.
- Priority is decided based on memory requirements, time requirements etc.
  - In case of tie, FCFS is followed.
  - Priorities can be
    - [ static : doesn't change throughout the execution.
    - [ dynamic : changes after some fixed interval of time

### Preemptive Priority Scheduling:

CPU can be assigned to a process with higher priority in the middle of execution of a process with lower priority.

#### Example :

Lower the no , higher the priority

| Process        | Priority | AT | BT  | CT    | TT   | WT   | RT |
|----------------|----------|----|-----|-------|------|------|----|
| P <sub>1</sub> | 3        | 0  | 8/3 | 15    | 15   | 7    | 0  |
| P <sub>2</sub> | 4        | 1  | 2   | 17    | 16   | 14   | 14 |
| P <sub>3</sub> | 4        | 3  | 4   | 21    | 18   | 14   | 14 |
| P <sub>4</sub> | 5        | 4  | 1   | 22    | 18   | 17   | 17 |
| P <sub>5</sub> | 2        | 5  | 6/1 | 12    | 7    | 1    | 0  |
| P <sub>6</sub> | 6        | 6  | 5   | 27    | 21   | 16   | 16 |
| P <sub>7</sub> | 1        | 10 | 1   | 11    | 1    | 0    | 0  |
|                |          |    |     | 96/7  | 69/7 | 61/7 |    |
|                |          |    |     | =13.7 | =9.8 | =8.7 |    |

gantt

chart :



### Non-Preemptive Priority Scheduling:

Lower no  $\rightarrow$  higher priority

| Process          | Priority | AT | BT   | CT | TT   | WT   | RT   |
|------------------|----------|----|------|----|------|------|------|
| ✓ P <sub>1</sub> | 3        | 0  | 8    | 8  | 8    | 0    | 0    |
| ✓ P <sub>2</sub> | 4        | 1  | 2    | 17 | 16   | 14   | 14   |
| ✓ P <sub>3</sub> | 4        | 3  | 4    | 21 | 18   | 14   | 14   |
| ✓ P <sub>4</sub> | 5        | 4  | 1    | 22 | 18   | 17   | 17   |
| ✓ P <sub>5</sub> | 2        | 5  | 6    | 14 | 9    | 3    | 3    |
| P <sub>6</sub>   | 6        | 6  | 5    | 27 | 21   | 16   | 16   |
| ✓ P <sub>7</sub> | 1        | 10 | 1    | 15 | 5    | 4    | 4    |
|                  |          |    | (27) |    | 95/7 | 68/7 | 68/7 |
|                  |          |    |      |    | 13.5 | 9.7  | 9.7  |

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<sub>7</sub>

Gantt chart : | P<sub>1</sub> | P<sub>5</sub> | P<sub>7</sub> | P<sub>2</sub> | P<sub>3</sub> | P<sub>4</sub> | P<sub>6</sub> |  
0 8 14 15 17 21 22 (27)

Adv. priorities can be set

- starvation of processes with lower priority.
- deciding priorities is tough

once in 1967, IBM 7094 used priority sch. - a process waited till 1973

### AGING

method to prevent starvation

Gradually priority of processes is inc. after fixed intervals of time.

## MEMORY MANAGEMENT

- It is a functionality provided by operating system which manages the primary memory of computer system
- Tasks
  - Moves processes back & forth between main memory & disk
  - keeps track of memory allocation / deallocation
  - security: prohibits user program to enter in os area & other user area.

- goals
  - maximise memory utilization
  - maximise CPU utilization
  - security to user programs & os



degree of multiprogramming

no. of processes that can be accommodated in main memory at a time for execution.

- degree of multi prog;  $\uparrow$ , CPU utilization  $\uparrow$   
depends on size of RAM

Example :

$$\begin{aligned} \text{RAM size} &= 4 \text{ MB} & \text{Process size} &= 4 \text{ KB} \\ \text{degree} &= 1 & \text{idle time} &= k (75\%) \\ \text{CPU utilisation} &= 1 - k (33.3\%) \end{aligned}$$

$$\begin{aligned} \text{RAM size} &= 16 \text{ MB} & \text{Process size} &= 4 \text{ MB} \\ \text{degree} &= 4 & \text{idle time} &= k^4 \\ \text{CPU utilisation} &= 1 - k^4 (94\%) \end{aligned}$$

$$\begin{aligned} \text{RAM size} &= 8 \text{ MB} & \text{Process size} &= 4 \text{ MB} \\ \text{degree} &= 2 & \text{idle time} &= k^2 \\ \text{CPU utilisation} &= 1 - k^2 (76\%) \end{aligned}$$

# Memory Allocation Techniques

## Contiguous

- Fixed partitioning
  - equal sized
  - variable sized
- Dynamic partitioning

## Non Contiguous

- Paging
  - Multi-level Paging
  - Inverted Paging
- Segmentation
- Segmented Paging

### Contiguous

- Contiguous memory allocation allocates consecutive blocks of memory to a process
- Faster execution of process
- Not ~~on~~ much address translations  
 ∴ less overhead
- process need not be divided into blocks.
- A table is maintained by OS that contains all available & occupied partitions in memory.
- wastage of memory

### Non - Contiguous

- Non contiguous memory allocation allocates several memory blocks at different locations in memory
- slower execution
- More address translations  
 ∴ more overheads
- process is divided into various blocks
- A table is maintained for each process that contains base addresses of each block acquired by the process in memory
- less wastage

## Fixed Partitioning

no. of size of partitions is decided in advance  
before the process is loaded

- oldest & simplest technique
- Memory is divided into fixed - size partitions.
- No. of partitions are fixed.
- size of partition may or may not be same
- swapping is not allowed.
- A partition is allocated to a single process only
- No. of partitions = degree of multiprogramming



Equal Size Partitioning

Unequal Size Partitioning

## Internal Fragmentation (memory wastage)

When the process is allocated to a memory block whose size is more than that of process & due to which some part of the memory is left unused.

- Adv. • Easy to implement

- Disadv.
- Internal Fragmentation → external fragmentation
  - limitation to size of the process  
(processes which are larger than the size of partitions are not allocated the memory)
  - limitation to the degree of multiprogramming  
( = no. of partition → fixed )
  - no. of partitions & their sizes need to be decided carefully.

## Dynamic Partitioning

- Initially RAM is not partitioned.
- Partitions are created at the time of process loading.
- Size of partition is equal to the incoming process  
(this avoids internal fragmentation)
- No. of processes or size of partitions is not fixed & depends on the size of incoming processes & size of main memory.



## Internal fragmentation

When the memory space is sufficient but can't be utilised because it is not contiguous.  
holes are formed in memory, their size ↓ over the time

- Adv.
- No internal fragmentation  
(bcz partition size = process size)
  - No limitation on size of processes  
(bcz partitions are made dynamically) in accordance with the size of process
  - No limitation on degree of multiprogramming  
(bcz no. of processes aren't fixed)

- Disadv.
- External fragmentation
  - Allocation & deallocation of memory is complex

Compaction (defragmentation)

It is a process of combining all the free spaces together to make it contiguous & avoid external fragmentation.



drawback: efficiency of the system is decreased. Huge amount of time is invested & CPU remains idle for this time.

## Fragmentation

When processes are loaded & removed from the memory, the free memory space is broken into smaller pieces. Due to the small size, these memory fragments can't be allocated which leads to memory wastage. This is called fragmentation.

→ Internal Fragmentation      allocated space is wasted

- When memory block assigned to a process is bigger than the process size, leftover portion of the block remains unused.
- It usually happens when a block / partition is allocated to a single process & sharing is not allowed.



- It can be removed by following best fit algo or dynamic partitioning.

→ External Fragmentation      unallocated space is wasted

- Total memory space is enough to satisfy the memory request but it is not contiguous.
- It can be removed by compaction, paging or segmentation.



Algorithms (for unique fixed & dynamic partitioning)

In fixed & dynamic partitioning, free partitions and holes are allocated processes based on some algorithms.

### 1) First - Fit

Process is allocated the first available memory with (unallocated partition / hole) with space more than or equal to it's size.

adv : fast

disadv : memory wastage (not efficient)



### 2) Next - Fit (modified - first-fit)

Process is allocated the first available memory with space more than or equal to its size, starting from the last allocated memory space.

- uses a moving pointer to track last allocated memory space.

faster.



### 3) Best Fit

searches the whole memory  
see to the size of process &  
allocates it to the closest-fitting  
free partition/hole in the memory

- keeps a list of free memory  
(smallest - largest)



adv: • memory efficient  
(less memory is wasted)

disadv: • slow

- reduces holes to much smaller size which  
can be very rarely occupied afterwards.

### 4) Worst Fit

searches the whole memory  
& allocates the process to  
largest sufficient partition among  
all the freely available partitions



adv: remaining holes are  
large enough to accommodate  
other processes.

disadv: if large process comes later, it can't be  
accommodated.

Questions :

- 300K, 25K, 125K, 50K are requested respectively  
 Above requirement could be satisfied with  
 a) Best Fit only b) First fit only c) both d) None



→

|  | Request No   | J <sub>1</sub>   | J <sub>2</sub> | J <sub>3</sub> | J <sub>4</sub> | J <sub>5</sub> | J <sub>6</sub> | J <sub>7</sub> | J <sub>8</sub> |  | 3K-J <sub>3</sub>                                                               | 4K  |
|--|--------------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--|---------------------------------------------------------------------------------|-----|
|  | Request Size | 2K               | 14K            | 3K             | 6K             | 6K             | 10K            | 7K             | 20K            |  | 6K-J <sub>4</sub>   6K-J <sub>5</sub>                                           | 8K  |
|  | Usage Time   | 4                | 10             | 2              | 8              | 4              | 1              | 8              | 6              |  | 14K-J <sub>2</sub>   10K-J <sub>4</sub>   6K-J <sub>5</sub>   7K-J <sub>7</sub> | 20K |
|  | "best fit"   | arrival time = 0 |                |                |                |                |                |                |                |  | 2K-J <sub>1</sub>                                                               | 2K  |

Calculate the time at which J<sub>7</sub> will be

- Completed a) 17 b) 20 c) 19 d) 37



PAGING

- It is a non-contiguous memory allocation technique
- In this technique,
  - logical address space is divided into pages (fixed-size)
  - physical address space is divided into frames (fixed-size)
  - size of page = size of frame  
(for max memory utilisation & avoid fragmentation)
- A process is divided into pages & stored in frames in main memory  
(Pages can be stored at different locations in non-contiguous frames)
- Logical Address Space (in reference to the secondary memory)
  - set of all the logical addresses generated by the CPU
  - it is a virtual / conceptual space which doesn't exist in memory

Logical address: It is a virtual address generated by CPU during program execution.

It is used as a reference to access the physical memory

| Logical address                                                            | Page no. (p) | Page offset (d) | word / byte | page 0            | page 1        | page 2 | page 3 |
|----------------------------------------------------------------------------|--------------|-----------------|-------------|-------------------|---------------|--------|--------|
| For n bit page no.,                                                        | $n=2$        |                 |             | 0                 | 1             | 2      | 3      |
| no. of <sup>pages</sup> words = $2^n$                                      |              | 4 pages         |             | 0                 | 1             | 2      | 3      |
| For m bit page offset,                                                     | $m=2$        |                 |             | 0                 | 1             | 2      | 3      |
| no. of words / page = $2^m$                                                |              | 4 words / page  |             | 0                 | 1             | 2      | 3      |
| no. of bits in logical address =                                           |              |                 |             |                   |               |        |        |
| no. of bits in page no. + no. of bits in pg offset                         |              |                 |             | ↑ Logical Address | ↑ Page offset |        |        |
| = $n+m$                                                                    |              |                 |             | space             | space         |        |        |
| size of logical address space = $2^{n+m} \cdot 2^{d+2} = 16 \text{ words}$ |              |                 |             |                   |               |        |        |

→ Physical Address Space (in reference to the memory)  
 set of all the physical addresses corresponding to  
 logical address in logical space  
 It actually exists in the memory

physical address [frame no (f) | frame offset (d)]

Note: The user never directly deals with the physical address. CPU generates the logical address & program runs on the logical address. But actually logical addresses are mapped to the corresponding physical addresses by MMU.

### MMU (Memory Management Unit)

It is a hardware device responsible for converting logical addresses into physical addresses using a page table.



$$\begin{aligned}
 \text{physical address} &= \text{frame no} * \text{size of frame} + \text{offset} \\
 &= f * n + d
 \end{aligned}$$

Relocation Register: special register in CPU used to map logical addresses to physical addresses

## Example

(unit) frame size = page size = 4 words

Memory size = 20 words

$$\text{no. of frames} = \frac{20}{4} = 5$$

process size = 12 words

$$\text{no. of pages} = \frac{12}{4} = 3$$

$$\text{logical address} = \frac{2 \text{ bits} + 2 \text{ bits}}{= 4 \text{ bits}}$$

$$\text{physical address} = 3 \text{ bits} + 2 \text{ bits} \\ = 5 \text{ bits}$$

$$(p, d) = (1, 2) \quad [g] \text{ in logical space}$$

$$2 \leq 4 \quad \checkmark$$

$$f = 2 \quad (f, d) = (2, 2)$$

$$\text{physical address} = 2 * 4 + 2 = 10 \quad [\text{eg}] \text{ in physical space}$$

$$(p,d) = \underbrace{(2,0)}_{\text{logical add}} \rightarrow 0 \leq 4 \xrightarrow{\text{true}} \underbrace{(4,0)}_{\text{physical add}} \rightarrow 4*4+0 = 16$$

$$\begin{array}{lll} 2^3 = 8 & 2^{10} = 1024 & 2^{20} = 1048576 \\ 2^2 = 4 & 2^9 = 512 & 2^{19} = 524288 \\ 2^1 = 2 & 2^8 = 256 & 2^{18} = 262144 \end{array}$$

→

|   | A | B | Page no. | frame no. |
|---|---|---|----------|-----------|
| 0 | a | b | 0        | 2         |
| 1 | c | d | 1        | 4         |

logical address

space

page table

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 |
| 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 |
| 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 |
| 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 |
| 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 |
| 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
| 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 |
| 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 |
| 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 |
| 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 |
| 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 |
| 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 |
| 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 |
| 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 |
| 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 |

physical address

space

$$\text{frame size} = \text{page size} = 2$$

$$\text{memory size} = 16$$

$$\text{no. of frames } 16/2 = 8$$

$$\text{process size} = 4$$

$$\text{no. of pages} = 4/2 = 2$$

1 bit

1 bit

3 bits

1 bit

(2 → d)

(4 → d)

$$\text{logical address} = 1 \text{ bit} + 1 \text{ bit} = 2 \text{ bits}$$

0

1

→ 0 | 0 | 1

(1 → b)

(5 → b)

$$\text{Physical address} = 3 \text{ bits} + 1 \text{ bit} = 4 \text{ bits}$$

→

$$\text{LAS} = 4 \text{ GB}$$

$$\text{PAS} = 64 \text{ MB}$$

no. of pages? no. of frames? size of LA? PA?

no. of entries in page table?

$$\text{Page size} = 4 \text{ KB}$$

size of page table?

$$\text{no. of pages} =$$

$$\frac{\text{largest address space}}{\text{page size}} = \frac{4 \text{ GB}}{4 \text{ KB}} = \frac{2^{2+30}}{2^{2+10}} = 2^{20}$$

$$\text{no. of bits req. for page no.} = 20 \text{ bits}$$

$$\text{no. of frames} = \frac{\text{physical address space}}{\text{frame size}} = \frac{64 \text{ MB}}{4 \text{ KB}} = \frac{2^{6+20}}{2^{2+10}} = 2^{14}$$

$$\text{no. of bits req. for frame no.} = 14 \text{ bits}$$

$$\text{no. of bits req. for logical address} \Rightarrow 4 \text{ GB} = 2^{32} \quad 32 \text{ bits}$$

$$\text{or bits for page no. + bits for offset, } 4 \text{ KB} = 2^{12} \quad 12 \text{ bits}$$

$$20 + 12 = 32 \text{ bits}$$

assumption - each word = 1 byte

size of physical address  $\Rightarrow 64\text{ MB} = 2^{26}$  bits  
~~or~~ bits for frame no. + bits of offset  
 $14 + 12 = 26$  bits

no. of entries in page table = no. of pages  $= 2^{20}$

size of page table = no. of pages  $\times$  size of each entry  
 $(2^{20} \times 14)$  bits  
 $\hookrightarrow$  page table stores frame no.

$\rightarrow LA = 7$  bits  $PA = 6$  bits page size = 8 words / byte

no. of pages? no. of frames? size of page table?

no. of bits req. for offset  $\Rightarrow 8 = 2^3$  3 bits

no. of bits req. for page no. = size of LA - size of offset  
 $= 7 - 3 = 4$

no. of bits req. for frame no. = size of PA - size of offset  
 $6 - 3 = 3$

no. of pages  $= 2^4 = 16$  pages

no. of frames  $= 2^3 = 8$  frames

size of page table = no. of entries  $\times$  size of an entry  
 $=$  no. of pages  $\times$  size of frame no.  
 $= 16 \times 3 = 48$

size of LAS =  $2^7 = 128$  Bytes / words

size of PAS =  $2^6 = 64$  Bytes / words

## Page Table

- It is used to keep all the information about the page.
- Its base address is stored in PTBR (Page Table Base Register).

Page Table entries:

|           |                | Modify             |                 |         |       |
|-----------|----------------|--------------------|-----------------|---------|-------|
| Frame No. | Valid/ Invalid | Protection (R W X) | Reference (0/1) | Caching | Dirty |
|           |                |                    |                 |         |       |

↑  
optional

- Frame no: frame no. corresponding to every page.  
no. of bits depend on no. of frames.
- Valid / Invalid bit : 0 - if present, 1 - if absent  
if a page is absent  $\rightarrow$  page fault  
(it is used to support virtual memory)
- Protection bit: R - Read , W - Write , X - execute

used in page replacement algo LRU

- Reference bit: 0 - if page is not accessed in last clk cycle  
1 - if accessed.

- Caching : disabled - if page changes frequently & fresh page is req. (cache stores old info.)  
enabled - if caching is required (i.e. write-access)
  - Dirty bit: 1 - if modified  
0 - if not modified
- do that changes can be saved when page is written out

## MULTILEVEL PAGING

- It is a paging technique in which multiple levels of page tables are used (bcz size of page table > size of a frame ∴ page table too needs to be divided)
- The last level page tables contains actual frame info
- First level contains only 1 page table & its address is stored in PTBR
- One access to each level is required to find the actual frame.
- Each page table (except the last level) contains frame no. of next level page tables

Logical address:

| Page no. |         |     |         |
|----------|---------|-----|---------|
| Level 1  | Level 2 | --- | Level n |
|          |         |     | offset  |

Physical address:

| frame no | offset |
|----------|--------|
|          |        |



Example:

$$\text{Physical address space} = 256 \text{ MB} = 2^{28} \text{ B}$$

$$\text{Logical address space} = 4 \text{ GB} = 2^{32} \text{ B}$$

$$\text{Frame size} = 4 \text{ KB} = 2^{12} \text{ B}$$

$$\text{Page table entry} = 2^8$$

Memory is byte addressable

Example LA  
Page

$$(2^{32} \text{ B})$$

$$4 \text{ KB}$$

2<sup>12</sup>  
page



$$LA = [9 \ 11 \ 12]$$

$$2 \text{ MB}$$

$$256 \text{ MB}$$

level 1 offset

$$\text{no. of pages} = 4 \text{ GB} / 4 \text{ KB} = 2^{20} \text{ B}$$

$$[20 \text{ bits} \ 12 \text{ bits}] \text{ LA}$$

$$\text{no. of frames} = 256 \text{ MB} / 4 \text{ KB} = 2^{16} \text{ B}$$

$$[15 \text{ bits} \ 12 \text{ bits}] \text{ PA}$$

$$\rightarrow \text{size of page table} = \text{no. of entries} \times \text{size of each entry}$$

$$\text{no. of pages} \leftarrow 2^{20} \times 2 = 2^{21} = 2 \text{ MB}$$

no. of bits for frame no.

(size of page table = 2MB) > (size of frame = 4KB)

∴ multilevel paging is required

$$\rightarrow \text{no. of page tables in inner level} = 2 \text{ MB} / 4 \text{ KB} = 2^9 \text{ B}$$

$$\rightarrow \text{size of page tables at outer level} = 2^9 \times 2 = 2^{10} = 1 \text{ KB}$$

Example

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

$$\text{Page size} = 4 \text{ KB } 2^{12}, \text{ Page Table entry} = 4 \text{ B } 2^2 \text{ B}$$

$$(2^{32} \text{ B})$$



$$\begin{aligned} \text{No. of pages} &= (\text{Size of logical memory}) / (\text{size of a page}) \\ &= 2^{32} / 2^{12} = 2^{20} \text{ pages} \end{aligned}$$

|    |    |
|----|----|
| 20 | 12 |
|----|----|

Inner level

$$\text{no. of entries in page table} = 2^{20}$$

$$\text{size of each entry} = 4B$$

$$\therefore \text{size of inner page table} = 2^{20} \times 2^2 = 2^{22} B = 4M$$

4MB > 4KB i.e. (size of page table > frame size)

∴ inner page table needs to be divided

$$\text{No. of divisions of page table} = 4M / 4KB = 2^{10}$$

Outer level

$$\text{no. of entries} = 2^{10}, \text{ size of each entry} = 4B$$

$$\therefore \text{size of outer page table} = 2^{10} \times 4B = 2^{12} B = 4KB$$

4KB = 4KB i.e. (size of outer page table) = (size of frame) Tutorial

B+  
Rarely used due to ↑ search time

Dr

Pg

B+

## INVERTED PAGING

In this paging technique, an inverted page table / frame table is maintained for the frames present in physical memory rather than maintaining separate page tables for each process.

#

Inverted page table / frame table

- no. of entries = no. of frames
- contains page no & page id  
(both combined refers to a unique page)

| Frame | Page No | Page Id |
|-------|---------|---------|
| 0     | -       | -       |
| 1     | -       | -       |
| 2     | -       | -       |
| 3     | -       | -       |

|   |                   |   |                |
|---|-------------------|---|----------------|
| 0 | f <sub>0..1</sub> | 0 | X              |
| 1 | X                 | 1 | f <sub>3</sub> |
| 2 | f <sub>2</sub>    | 2 | f <sub>5</sub> |
| 3 | X                 | 3 | X              |

Page Table of P<sub>1</sub>

Page Table of P<sub>3</sub>

| fNo | Page No        | Page Id        |
|-----|----------------|----------------|
| 0   | P <sub>0</sub> | P <sub>1</sub> |
| 1   | P <sub>1</sub> | P <sub>2</sub> |
| 2   | P <sub>2</sub> | P <sub>1</sub> |

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

frame table / inverted page table

Page Table of P<sub>2</sub>

- Each process has its own P.T.
- Only one page inverted PT is in the memory.
- If pages of n processes are not in memory, then n P.T. are not in the memory (memory overhead).
- Linear search is performed to find the frame no. (search time ↑)

Working :



Advantages  
Reduced memory space

Disadvantages  
Search time ↑

## Advantages of Paging

- No external fragmentation
- Swapping of pages is easy as pages are of same size.
- Efficient use of memory

## Disadvantages of Paging

- Access time is high ( $LN \rightarrow PA$ )
- Internal fragmentation in last page of the process.
- Large memory space is required as page tables are also stored

## VIRTUAL MEMORY

It is a memory allocation scheme in which secondary memory can be used as main a part of main memory at the times of shortage of RAM

- All memory references must be logical addresses and must be dynamically translated into physical addresses at run time. [∴ parts of the process can change locations during execution]
- Process must be divided into pieces

In this scheme,

- Only required parts of the process is loaded into the main memory & rest of the parts are stored in a part of secondary memory & fetched when required.
- This section of secondary memory is termed as virtual memory.
- It gives an illusion to the user that complete processes are loaded into the main memory and therefore it is large enough but in actual, real memory is limited.

### Features:

- Processes which are larger than RAM can be executed
- Reduces external fragmentation (An entire program need not be loaded at the same time)
- The amount of space used by the process (in real memory) in main memory can be varied during execution
- Location of various processes may be varied during execution
- Degree of multiprogramming increases
- It is implemented by 'Demand Paging'
- It can also be implemented by 'Segmentation' & 'paged segmentation' techniques but it is quite complex.

Demand Paging

[ paging concept + virtual memory concept ]

- The process of loading a page into the main memory only when it is demanded. Lazy Swapper
- A page may or may not be present in the memory when it is demanded.
- If the page is present in main memory, it is accessed.
- If page is not present in main memory, page interrupt occurs & control is shifted from user to OS - Page Fault

FMT

## Page Map Table (PMT)

- It contains frame no., valid / invalid bit.
- If page is present in main memory, corresponding frame no. is entered & valid bit = 1
- If page is not present, frame no is empty & valid bit = 0

| fno. | v/i |
|------|-----|
| 0    | 0   |
| 1    | 1   |
| 2    | 0   |
| 3    | 1   |

PMT

When page fault occurs,

- if frame is free (in the main memory), it is allocated to the new page.
- if frame is not available, a page (which is not being used) needs to be replaced using page replacement algorithms.

## Handling Page Faults





## Effective Memory Access Time (EMAT)

$$\text{page fault rate} = p \quad [0 \leq p \leq 1]$$

(probability of page fault occurrence)

page fault service time = s (usually in msec)

(time taken to handle page fault)

memory access time =  $m$  (usually in nanosec)

(time taken to access the memory)

$$E\text{HAT} = p * (S + m) + (1-p) * m$$

$$= p * s + (1-p) * m \quad [ \because p < s ]$$

Example: MM Access time = 100  $\mu$ sec, Page fault rate = 40%,  $s = 4$  msec

$$EMAT = 0.4(4 \times 10^{-3}) + (0.6)(100 \times 10^{-6})$$

$$= -1.6 \times 10^{-3} + 0.6 \times 10^{-4}$$

$$= 0.01 \times 10^{-3} + 0.06 \times 10^{-3} = 1.66 \times 10^{-3} \text{ sec}$$

$$= 1660 \text{ msec}$$

## Page Replacement Algorithms

Algorithms that are used to decide which page needs to be replaced by the new page that is demanded, in case page fault occurs

### i) FIFO (First In First Out)

The page that comes first in the main memory, is replaced first.

OS maintains a queue for all the pages, front  $\rightarrow$  oldest page.

Example:

| Reference String | 3 | 2 | 1 | 3 | 4 | 1 | 6 | 2 | 4 | 3 | 4 | 2 | 1 | 4 | 5 | 2 | 1 | 3 | 4 |
|------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| f <sub>1</sub>   | 3 | 3 | 3 | 3 | 4 | 4 | 4 | 4 | 4 | 3 | 3 | 3 | 3 | 5 | 5 | 5 | 5 | 4 |   |
| f <sub>2</sub>   |   | 2 | 2 | 2 | 2 | 2 | 6 | 6 | 6 | 6 | 4 | 4 | 4 | 4 | 4 | 2 | 2 | 2 |   |
| f <sub>3</sub>   |   |   | 1 | 1 | 1 | 1 | 1 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 3 | 3 |   |
|                  | M | M | M | H | M | H | M | M | H | M | M | H | M | H | M | M | M | M |   |

no. of hits = 6

hit ratio =  $(6/19) \times 100$

no. of miss = 13

miss ratio =  $(13/19) \times 100$

| Reference String | 7 | 0 | 1 | 2 | 0 | 3 | 0 | 4 | 2 | 3 | 0 | 3 | 1 | 2 | 0 |   |  |  |
|------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|--|
| f <sub>1</sub>   |   | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 3 | 3 | 3 | 3 | 2 | 2 |   |  |  |
| f <sub>2</sub>   | 0 | 0 | 0 | 0 | 3 | 3 | 3 | 3 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 |  |  |
| f <sub>3</sub>   | 7 | 7 | 7 | 2 | 2 | 2 | 2 | 4 | 4 | 4 | 0 | 0 | 0 | 0 | 0 |   |  |  |
|                  | X | X | X | X | V | X | X | X | X | X | X | V | X | X | X | ✓ |  |  |

no. of hits = 3

hit ratio =  $3/15 = 1/5 = 20\%$

miss = 12

miss ratio =  $12/15 = 4/5 = 80\%$

## Belady's Anomaly :

(in FIFO)

←  
for  
Belady's  
anomaly

no. of frames

for some reference strings no. of page faults increase with increase in by increasing no. of frames. This is known as Belady's Anomaly.

Example :

| Reference String | 1 | 2 | 3 | 4 | 1 | 2 | 5 | 1 | 2 | 3 | 4 | 5 |          |
|------------------|---|---|---|---|---|---|---|---|---|---|---|---|----------|
| $f_3$            |   | 3 | 3 | 3 | 2 | 2 | 2 | 2 | 2 | 4 | 4 | 4 | Hits = 3 |
| $f_2$            | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 3 | 3 | 3 | 3 | Miss = 9 |
| $f_1$            | 1 | 1 | 1 | 4 | 4 | 4 | 5 | 5 | 5 | 5 | 5 | 5 |          |
|                  | x | x | x | x | x | x | v | v | x | x | v |   |          |

  

| Reference String | 1 | 2 | 3 | 4 | 1 | 2 | 5 | 1 | 2 | 3 | 4 | 5 |           |
|------------------|---|---|---|---|---|---|---|---|---|---|---|---|-----------|
| $f_4$            |   | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 3 | 3 | 3 | 3 | Hits = 2  |
| $f_3$            | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 2 | 2 | 2 | 2 | 2 |           |
| $f_2$            | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | x | 5 | Miss = 10 |
| $f_1$            | 1 | 1 | 1 | 1 | 1 | 1 | 5 | 5 | 5 | 5 | 4 | 4 |           |
|                  | x | x | x | x | v | v | x | x | x | x | x | x |           |

Last replaced page is the one demanded next

bcz future requests are not known  
 practically not possible , use a theoretical benchmark for other algos <sup>DL Pg</sup> B+

## 2) Optimal Page Replacement (Best) for all ref. str.

The page which is not used for longest period of time in the future is replaced.

Example :

| Reference String | 7 | 0 | 1 | 2 | 0 | 3 | 0   | 4 | 2 | 3 | 0 | 3 | 2 | 1 | 2 | 0 | 1 | 7 | 0 | 1 |
|------------------|---|---|---|---|---|---|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|
| $f_4$            |   |   |   | 2 | 2 | 2 | 2   | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 |
| $f_3$            |   |   | 1 | 1 | 1 | 1 | + 4 | 4 | 4 | 4 | 4 | 4 | 4 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| $f_2$            |   | 0 | 0 | 0 | 0 | 0 | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| $f_1$            | 7 | 7 | 7 | 7 | 7 | 3 | 3   | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 7 | 7 |
| X                | X | X | X | ✓ | X | ✓ | X   | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | X | ✓ | ✓ | ✓ | X | ✓ | ✓ |

$$\text{page hits} = 12 \quad \text{page hit ratio} = 12/20 = 3/5$$

$$\text{page miss} = 8 \quad \text{page miss ratio} = 8/20 = 2/5$$

3) Least Recently Used (LRU)  
 The page that is least recently used is replaced  
 page that is not used for long time

Example:

| Reference String | 7 | 0 | 1 | 2 | 0 | 3 | 0 | 4 | 2 | 3 | 0 | 3 | 2 | 1 | 2 | 0 | 1 | 7 |
|------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| f <sub>4</sub>   |   |   |   | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 |
| f <sub>3</sub>   |   | 1 | 1 | 1 | 1 | 1 | 1 | 4 | 4 | 4 | 4 | 4 | 4 | 1 | 1 | 1 | 1 | 1 |
| f <sub>2</sub>   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| f <sub>1</sub>   | 7 | 7 | 7 | 7 | 7 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 7 |
| X                | X | X | X | V | X | V | X | V | V | V | V | V | X | V | V | V | X |   |

page hit = 12      hit ratio =  $12/20 = 3/5$   
 page miss = 8      miss ratio =  $8/20 = 2/5$

4) Most Recently Used (MRU)

The page that is most recently used is replaced

| Reference String | 7 | 0 | 1 | 2 | 0 | 3 | 0 | 4 | 2 | 3 | 0 | 3 | 2 | 1 | 2 | 0 | 1 | 7 | 0 | 1 |
|------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| f <sub>4</sub>   |   |   |   | 2 | 2 | 2 | 2 | 2 | 3 | 3 | 3 | 2 | 2 | 2 | 0 | 0 | 0 | 0 | 0 | 0 |
| f <sub>3</sub>   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| f <sub>2</sub>   | 0 | 0 | 0 | 0 | 3 | 0 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 |
| f <sub>1</sub>   | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 | 7 |
| X                | X | X | X | V | X | X | V | X | X | X | V | V | X | V | V | V | V | V | V |   |

page hit = 8      hit ratio =  $8/20 = 2/5$   
 page miss = 12      miss ratio =  $12/20 = 3/5$

## SEGMENTATION

- non-contiguous memory allocation technique
- process is divided into segments which are not necessarily all of the same sizes.
- segments are made as per the user's view. Each segment contains some type of function eg main function may constitute a segment while library function can be included in another segment.
- A segment table is maintained for each process

- Base address: contains the starting physical address where the segments reside in the physical memory.

| Base address | Limit/<br>offset |
|--------------|------------------|
| -            | -                |
| -            | -                |
| -            | -                |

- Limit: specifies length of segment

Logical address : [segment no (c)] [limit (d)]

Physical address : [Base address (b)] [limit (d)]



$$\text{Physical Address} = \text{base address} + \text{limit} / \text{offset}$$

| $S_0$                 |           | $S_1$ | Segment | BA      | Limit | Segment Table          |      | $S_5$ |
|-----------------------|-----------|-------|---------|---------|-------|------------------------|------|-------|
|                       | main()    | Add() |         | 0 2000  | 100   |                        |      |       |
|                       |           |       |         | 1 3600  | 200   | 1500                   | 1800 | $S_2$ |
| $S_2$                 | $S_3$     | $S_4$ |         | 2 1500  | 300   | 2000                   | 2300 | $S_0$ |
|                       | Sub()     | Div() | Mod()   | 3 3800  | 300   | 2100                   | 2400 |       |
|                       |           |       |         | 4 2700  | 600   |                        |      |       |
| $S_5$                 | display() |       |         | 5 3300  | 200   | 2700                   | 3000 | $S_4$ |
| Logical address space |           |       |         | Segment |       | Physical Address Space |      |       |
|                       |           |       |         | Tables  |       | 3300                   | 3600 | $S_5$ |
|                       |           |       |         |         |       | 3500                   | 3800 | $S_1$ |
|                       |           |       |         |         |       | 3600                   | 3900 | $S_3$ |

$\rightarrow (1, 100)$

$$100 \leq 200$$

$$(1, 100) \rightarrow (3600, 100)$$

$$\text{physical address} = 3600 + 100 = 3700$$

$\rightarrow (2, 400)$

$$400 \not\leq 300 \quad \text{Trap}$$

- Adv. :
- No internal fragmentation
  - Segment Table consumes less space in comparison to page table in paging
  - average segment size is larger than page size
  - easier to relocate segments
  - segments are of variable size as per the user's view.

Disadv. :

- external fragmentation

- costly memory management algos.
- maintenance of segment table for each process leads to overhead

## PAGING WITH SEGMENTATION

- This is a non-contiguous memory allocation technique.
- In this technique process is divided into variable-size segments. Further each segment is divided into fixed-size pages. Therefore pages are always smaller than the segments.
- Every process has a segment table and multiple page tables corresponding to different segments.
- Main memory is divided into frames.  
size of page = size of frame.

### Segment Table

|                                                                                    | limit | Page Table Address |
|------------------------------------------------------------------------------------|-------|--------------------|
| → stores information of each segment                                               | -     | -                  |
| → no. of entries in segment table =                                                | -     | -                  |
| no of segments of the process.                                                     | -     | -                  |
| → every process has one segment table                                              |       |                    |
| → Base address of segment table is stored in STBR<br>(Segment Table Base Register) |       |                    |
| → It contains following information :                                              |       |                    |
| • limit : length of the segment                                                    |       |                    |
| • page table address : address of the page table corresponding to that segment     |       |                    |

## Page Table

- Stores information of each page of a segment.
  - Each segment has its own page table. Therefore,
  - No. of page tables in a process =  
    No. of segments.
  - No. of entries in a page table =  
    No. of pages in the corresponding segment.
  - It contains the frame no. corresponding to each page.
  - Each page table occupies one frame in the main memory.



Logical address virtual address generated by the CPU

|                    |                 |                     |
|--------------------|-----------------|---------------------|
| Segment No.<br>(s) | Page No.<br>(p) | Page offset<br>(d') |
|--------------------|-----------------|---------------------|

MMU (Memory Management Unit) is responsible for mapping logical addresses into the physical addresses



Example :



### Advantages

- Internal fragmentation is removed
- Segment table consumes less space as no. of segments are limited
- Length is limited by segment size
- Given programmer's view along with advantages of paging

### Disadvantages

- Internal fragmentation still exists (because last page of segments is usually partially occupied)
- Extra hardware is required therefore costlier
- Complexity increases