



KTU  
**NOTES**  
The learning companion.

**KTU STUDY MATERIALS | SYLLABUS | LIVE  
NOTIFICATIONS | SOLVED QUESTION PAPERS**



Website: [www.ktunotes.in](http://www.ktunotes.in)

# OPERATING SYSTEM

## MODULE - 4

### 4.1 MEMORY MANAGEMENT

- Memory consists of a large array of words or bytes, each with its own address.
- The CPU fetches instns from mly according to the value of the pgm counter (pc).
- Main mly & registers built into the processor itself are the only storage that the CPU can access directly.
- Each process has a separate memory space.
- There is a range of legal addresses that the process may access & to the process can access only these legal addresses.
- To provide this protection, two registers are used:
  - Base Register - Holds the smallest legal physical memory address.
  - Limit Register - specifies the size of the range

### Address Binding

- Address Binding is the process of mapping the programs logical or virtual addresses to the corresponding physical or main mly addresses.
- The binding of instructions & data to mly addresses can be done at any of the foll. steps:
  - ✓ Compile Time
  - ✓ Load Time
  - ✓ Execution Time

## Logical Address Space

- Generated by the CPU;  
Also referred as virtual address.
- Logical address space is the set of all logical addresses generated by the programs.

## Physical Address Space

- Addressed seen by the memory unit.
- Physical address space is the set of all physical addresses generated by the pgm.

\* Logical & Physical address are the same in compile time & load time address-binding scheme.

\* Logical & physical address are different in execution time address binding scheme.



## Memory Management Unit

- It is a hardware device that maps virtual addresses to physical address.
- In MMU scheme, the value in relocation reg is added to every address generated by the user process at the time it is sent to memory.
- The user program ~~always~~ deals with logical address. It never sees the real physical address.

## Logical versus Physical Address Space

- Logical address (Virtual address) - Generated by the CPU. Also referred to as virtual address.
- Physical address - Address seen by the memory unit.
- Logical address space is the set of all logical addresses generated by a pgm.
- Physical address space is the set of all physical addresses generated by a pgm.
- Memory Management Unit (MMU) - H/w devices that at run time maps virtual to physical address.



## 4.2 Swapping

- Swapping used in order to implement multi-programming.
- In multiprogramming, can store multiple process in main mly. So that CPU can execute all process in an efficient manner.
- Advantage - utilize CPU performance in efficient manner



- A process must be in memory to be executed.
- A process can be swapped temporarily out of memory to a backing store, and then brought back into memory for continued execution
- Swapping variant used for priority-based scheduling algorithms are called roll out, roll in- lower-priority process is swapped out so higher-priority process can be loaded and executed.
- Swapping requires a backing store.
- The **backing store** is commonly a fast disk. It must be large enough to accommodate copies of all memory images for all users, and it must provide direct access to these memory images.

- The system maintains a ready queue consisting of all processes whose memory images are on the backing store or in memory and are ready to run.
- Whenever the CPU scheduler decides to execute a process, it calls the dispatcher.
- The dispatcher checks to see whether the next process in the queue is in memory. If it is not; and if there is no free memory region, the dispatcher swaps out a process currently in memory and swaps in the desired process. It then reloads registers and transfers control to the selected process.



Swapping of two processes using a disk as a backing store.

## Contiguous v/s Non-Contiguous Allocation

- Way of organizing program in mly

Contiguous

Non-Contiguous

- |                                                                                                                                                             |                                                                                                                                                                                                    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>① Program must exist as a single block of contiguous address.</p> <p>② Sometimes it is impossible to find large enough block.</p> <p>③ Low Overhead.</p> | <p>① Programs divided into chunks called segment.</p> <p>② Each segment can be placed in different parts of memory.</p> <p>③ Easier to find "holes". (Free space) in which segment it will fit</p> |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## Multiprogramming



### \* Fixed Partitioning

- Main mly is divided into no. of static partitions at system generation time.
  - ★ Equal size partition
  - ★ Unequal size partition

#### Pros:

- Simple to implement.
- Little OS overhead.

#### Cons:

- Inefficient
- Maximum no. of active process - fixed

## - Placement Algorithm

- \* One process queue per partitioning .
- \* Single Queue .

Eg:

M.M



Equal size partition .

H.M



Unequal size partition

## Fixed Partitioning Placement Algorithm

- \* One process queue per partitioning



- \* Single Queue .



## \* Dynamic Partitioning



- Partitions are created dynamically .
- Each process is loaded into a partition of exactly the same size of that process.

## Placement Algorithm

- First fit : First hole that is big enough is allocated to programs.
- Best fit : Smallest hole that is big enough is allocated to pgms.
- Worst fit : Largest hole that is big enough is allocated to pgms.

Eg:



(a)



(b)



(c)



(d)

## Memory Allocation

- A simplest method for allocating memory is to divide memory into several fixed-sized partitions.  
Each partition may contain exactly one process. Thus, the degree of multiprogramming is bound by the number of partitions. In this multiple partitioned method, when a partition is free; a process is selected from the input queue and is loaded into the free partition. When the process terminates, the partition becomes available for another process.
- In the variable partition scheme, the operating system keeps a table indicating which parts of memory are available and which are occupied. Initially, all memory is available for user processes and is considered one large block of available memory, a hole. Eventually, memory contains a set of holes of various sizes.
- As processes enter the system, they are put into an input queue. The operating system takes into account the memory requirements of each process and the amount of available memory space in determining which processes are allocated memory.
- When a process is allocated space, it is loaded into memory, and it can then compete for CPU time. When a process terminates, it releases its memory which the operating system may then fill with another process from the input queue.
- In general, the memory blocks available comprise a set of holes of various sizes scattered throughout memory. When a process arrives and needs memory, the system searches the set for a hole that is large enough for this process. If the hole is too large, it is split into two parts. One part is allocated to the arriving process; the other is returned to the set of holes.
- When a process terminates, it releases its block of memory, which is then placed back in the set of holes.
- If the new hole is adjacent to other holes, these adjacent holes are merged to form one larger hole. At this point, the system may need to check whether there are processes waiting for memory and whether this newly freed and recombined memory could satisfy the demands of any of these waiting processes.
- **Dynamic storage allocation problem** concerns how to satisfy a request of size  $n$  from a list of free holes. Solutions for this problems are
  - **First fit.** Allocate the first hole that is big enough. Searching can start either at the beginning of the set of holes or at the location where the previous first-fit search ended. We can stop searching as soon as we find a free hole that is large enough.
  - **Best fit.** Allocate the smallest hole that is big enough. We must search the entire list, unless the list is ordered by size. This strategy produces the smallest leftover hole.
  - **Worst fit.** Allocate the largest hole. Search the entire list, unless it is sorted by size. This strategy produces the largest leftover hole, which may be more useful than the smaller leftover hole from a best-fit approach
- Both the first-fit and best-fit strategies for memory allocation suffer from external fragmentation.
- As processes are loaded and removed from memory, the free memory space is broken into little pieces.

- External fragmentation exists when there is enough total memory space to satisfy a request but the available spaces are not contiguous; storage is fragmented into a large number of small holes.
- In the worst case, it could have a block of free (or wasted) memory between every two processes. If all these small pieces of memory were in one big free block instead, it might be able to run several more processes.
- Memory fragmentation can be internal as well as external.
- The general approach to avoiding this problem is to break the physical memory into fixed-sized blocks and allocate memory in units based on block size.
- The memory allocated to a process may be slightly larger than the requested memory. The difference between these two numbers is internal fragmentation; memory that is internal to a partition.
- **Compaction** is the solution for external fragmentation- shuffles the memory contents so as to place all free memory together in one large block.

## FRAGMENTATION

- A process is loaded & removed from memory, the free space in memory space is broken into little pieces.
  - After sometimes, that process cannot be allocated to memory because of small size & memory block remains unused.
- This problem is called fragmentation.



### External fragmentation

- Total memory space is enough to satisfy a request or reside a process in it, but it is not contiguous, so it cannot be used.
- Memory
- 
- $P_1 = 4M$

### Internal fragmentation

- Memory block assigned to process is bigger. Some portion of memory is left unused, as it cannot be used by another process.
- Memory



$$P_2 = 6M$$

Process

## SEGMENTATION

- \* A program is a collection of segments.
- \* A segment is a logical unit such as:
  - Main program
  - Procedure
  - Function
  - Local variables, global variables
  - Common block
  - Stack
  - Symbol Table
  - Array

### Logical View of Segmentation



\* User specifies each address by 2 quantities :  
(a) Segment name .  
(b) Segment offset .

logical address  $\Rightarrow$  <segment name, offset>



- \* Log. add. is executed with the help of CPU & stored in the phy. mly space in the form of frames.

### Segmentation Architecture:

- \* Logical address contains 2 tuples:  
(seg no, offset)
- \* Segment table maps 2 dimensional physical address.
- \* Segment table entries have:
  - \* Base - ~~start~~ contains starting physical address.
  - \* Limit - specifies the length of segment.
- \* Segment table base Register (STBR) -  
Points to the segment table's location in mly.
- \* Segment table Length Register (STLR) -  
Indicates no. of segments used by program.
- \* Segment no, S is legal if,  $S \leq STLR$ .

### Example of Segmentation:



| segment table |                 |
|---------------|-----------------|
|               | limit      base |
| 0             | 1000      1400  |
| 1             | 400      6300   |
| 2             | 400      4300   |
| 3             | 1100      3200  |
| 4             | 1000      4700  |

| Physical mly |
|--------------|
| Seg 0        |
| 3200         |
| 4300         |
| 4700         |
| 5700         |
| 6300         |
| 6700         |

## Segmentation Hardware

des CLR  
des limif



## PAGINING

→ wherever free space, OS can make use of free space

\* Non-Contiguous allocation (Virtual Memory).

↳ To provide easy to the users.

↳ To increase CPU utilization

\* OS giving illusion to the user such that

- User can write a very big program

- User thinks that its entire program is present in RAM.

- All the space allocated to the user is contiguous.

In reality, only a small portion of the user program is in RAM, which may or may not be contiguous. While the remaining pgm is in secondary memory.



\* A computer can add more memory than the amount physically installed on system. This extra memory is called virtual memory.



- \* Paging is a memory management technique in which process address space <sup>(virtual mly)</sup> is broken into blocks of same size called pages. Size of each page is same.
- \* ~~Block~~ Page size → powers of 2 (2, 4, 6, 8, . . .)
- \* The size of process can be measured in no. of pages. Similarly, main mly is divided into small fixed blocks (physically) of memory called frames. Size of each frame is same.
- \* Size of frame = Size of page.
  - We can avoid External fragmentation.

Process P

|               |
|---------------|
| 1st 100 bytes |
| 2nd 100 bytes |
| 3rd 100 bytes |
| :             |
| :             |
| :             |



Main mly

| OS       |    |
|----------|----|
| P-page 4 | F0 |
|          | F1 |
| P-page 0 | F2 |
| P-page 2 | F3 |
| P-page 1 | F4 |
|          | Fn |

Secondary mly



- A single process is divided into fixed slots called Pages. These pages need to be stored in MM.
- MM is divided into frames & virtual mly into pages. Whatever data send from virtual mly to MM is in form of pages.
- ~~After~~ make After execution, to make MM free, can swap data into secondary mly.

Fig (1)

|        |
|--------|
| page 0 |
| page 1 |
| page 2 |
| page 3 |

Process

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

Page table

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

MM

(Page 1 available  
in frame 4)

## 9

### Address Translation (Paging Hardware)

- Page address is logical address & represented by,  

$$\boxed{\text{logical addr} = \text{Pg no} + \text{page offset}}$$
- Frame <sup>address</sup> is called physical address & represented by,  

$$\boxed{\text{Physical addr} = \text{Frame no} + \text{page offset}}$$





load A

load B

load C



} D      } D

Divided complete process D  
into 2 partitions.

### Advantages & Disadvantages

1. Paging reduces external fragmentation but still suffers from internal fragmentation.
2. It is simple to implement.
3. Swapping becomes very easy because of ~~same~~ equal sizes of pages & frames.
4. It is not suitable for small RAM's.

# Paging Example for a 32-byte memory with 4-byte pages

Process

Logical mly.

| Page |      |
|------|------|
| 0 →  | 0 a  |
| 1 →  | 1 b  |
| 2 →  | 2 c  |
| 3 →  | 3 d  |
| 4 →  | 4 e  |
| 5 →  | 5 f  |
| 6 →  | 6 g  |
| 7 →  | 7 h  |
| 8 →  | 8 i  |
| 9 →  | 9 j  |
| 10 → | 10 k |
| 11 → | 11 l |
| 12 → | 12 m |
| 13 → | 13 n |
| 14 → | 14 o |
| 15 → | 15 p |

page table

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

Main mly or  
Physical mly

| Frame  |
|--------|
| 0      |
| 4 → 1  |
| 8 → 2  |
| 12 → 3 |
| 16 → 4 |
| 20 → 5 |
| 24 → 6 |
| 28 → 7 |

- Size of page (4 bytes) = Size of frame (4 bytes)

$$\text{Log add} \Rightarrow 0 \cdot (\alpha)$$

$$\text{Page} = 0 \cdot$$

$$\text{offset} = 0 \cdot$$

$$\begin{aligned} \text{Phy.add} &= \text{fr.no} \times \text{size} + \text{offset} \\ &= 5 \times 4 + 0 = 20 \end{aligned}$$

$$L.A = 1 \cdot$$

$$Pg = 0 \cdot$$

$$\text{offset} = 1$$

$$\begin{aligned} \text{Phy.add} &= 5 \times 4 + 1 \\ &= 21 \text{ (b)} \end{aligned}$$

$$L.A = 4 \cdot$$

$$Pg = 1$$

$$\text{offset} = 0$$

$$\begin{aligned} P.A &= 6 \times 4 + 0 \\ &= 24 \text{ (e)} \end{aligned}$$

$$LA = 15$$

$$Pg = 3$$

$$\text{offset} = 3$$

$$\begin{aligned} PA &= \\ &2 \times 4 + 3 \\ &\underline{\underline{11(p)}} \end{aligned}$$

# Translation Look-aside Buffer (TLB)

10.

## Paging Hardware with TLB



- \* Page table is stored inside MM.
- \* 2 memory access required:
  - Accessing page table
  - Accessing MM.
- \* CPU generates LA (pg no, offset). Pg no given as i/p to page table. So inorder to access pg table, require 1 my access.  $\rightarrow$  Frame no as o/p - Phy. add. (2nd my. access).
- \* ~~To overcome this~~ 2 my access required for executing a single instan. To overcome this problem, TLB is used.
- \* TLB contains the most frequently accessed ~~pages~~ in page table.
- \* CPU generates LA [P, d]. Page no is compared with every page no. in TLB. ~~If m~~

- If match found, it is TLB hit & gives frame no. as o/p.  
& the frame no is combined with offset will give physical address (1 mly access required)

- If match not found, it is TLB miss.

Page no given as i/p to page table. Produces frame no as o/p & the frame no is combined with offset will give physical address.

After getting frame no, the corresponding entry ie, page no & frame no information will be updated in TLB.

Suppose TLB is full, one of the row will be replaced with this new entry.

### Protection

- \* ~~process~~ How to provide protection in paging.

| process |
|---------|
| page 0  |
| page 1  |
| page 2  |
| page 3  |

| Page table |
|------------|
| 0 2 V      |
| 1 3 V      |
| 2 4 V      |
| 3 7 V      |
| 4 P        |
| 5 I        |
| 6 I        |

| MM       |
|----------|
| 0        |
| 1        |
| 2 Page 0 |
| 3 Page 1 |
| 4 Page 2 |
| 5        |
| 6        |
| 7 Page 3 |
| 8        |
| 9        |
| 10 ; ]   |

- \* Memory protection implemented by associating protection bit with each frame to indicate if read-only or read-write access is allowed.
- \* Valid-Invalid bit attached to each entry in the page table.
  - "Valid"<sup>(v)</sup> indicates that the associated page is in the process's logical address space & is thus a legal page.
  - "Invalid"<sup>(i)</sup> indicates that the page is not in the process's logical address space.
- \* Any violations, result in a trap to the kernel.

### Shared Pages

- \* An advantage of paging is the possibility of sharing common code.
- \* Shared code
  - One copy of read-only code shared among processes (ie, text editors)
  - Similar to multiple threads sharing the same process space.

### P At.

- \* Private code & data.
  - Each process keeps a separate copy of the code & data.
  - The pages for the private code & data can appear anywhere in the logical address space.

|        |
|--------|
| ed 1   |
| ed 2   |
| ed 3   |
| data 1 |

Process P1

|   |
|---|
| 3 |
| 4 |
| 6 |
| 1 |

Page table  
for P1

|        |
|--------|
| ed 1   |
| ed 2   |
| ed 3   |
| data 2 |

Process P2

|   |
|---|
| 3 |
| 4 |
| 6 |
| 7 |

Page table  
for P2

|    |
|----|
| 0  |
| 1  |
| 2  |
| 3  |
| 4  |
| 5  |
| 6  |
| 7  |
| 8  |
| 9  |
| 10 |
| 11 |

Sharing of code in a paging environment

## VIRTUAL MEMORY.

- \* Something which appears to be present but actually it is not.
- \* It just gives illusion to user.
- \* A programmer can write a pgm which requires more memory than the capacity of MM. Such a pgm is executed by virtual memory technique.
- \* Only part of pgm needs to be in MM for execution.
- \* Logical address space can therefore be much larger than Physical address space.
- \* Allows address spaces to be shared by several processes.
- \* More pgms running concurrently.
- \* VM requires less I/O needed to load or swap the process.





- \* Pages in VM are stored in MM & their information send to physical mly.
- \* If MM doesn't contain the page that CPU is demanding, if page not present in MM, it will get from disk & store in ~~MM~~ physical mly in form of disk.
- \* If physical mly is full, an <sup>unused</sup> page will be swapped to the disk.
- \* VM can be implemented via demand paging & demand segmentation.

## 5.6 Demand paging

- Loading the entire program in physical memory at program execution time is not so good because the user doesn't *need* the entire program in memory at a time.
- An alternative strategy is to load pages only as they are needed. This technique is known as **demand paging**.
- With demand-paged virtual memory, pages are only loaded when they are demanded during program execution; pages that are never accessed are thus never loaded into physical memory.



Transfer of a paged memory to contiguous disk space.

- A demand-paging system is similar to a paging system with swapping.
- But here it uses a lazy swapper; where it never swaps a page into memory unless that page will be needed.
- In Demand paging, **pager** is more suitable than swapper .

### Basic Concepts

- With swapping, pager guesses which pages will be used before swapping out again
- Instead, pager brings in only those pages into memory
- some form of hardware support is needed to distinguish between the pages that are in memory and the pages that are on the disk.
- The valid-invalid bit scheme can be used for this purpose.
- With each page table entry a valid-invalid bit is associated ( $v \rightarrow$  in-memory – memory resident,  $i \rightarrow$  not-in-memory)
- Initially valid-invalid bit is set to  $i$  on all entries
- During MMU address translation, if valid-invalid bit in page table entry is  $i$  then a page fault occurs.



Page table when some pages are not in main memory





Steps in handling a page fault.

- If there is a reference to a page, first reference to that page will trap to operating system:
  - page fault
- The procedure for handling this page fault is
  1. Check an internal table (usually kept with the process control block) for this process to determine whether the reference was a valid or an invalid memory access.
  2. If the reference was invalid, terminate the process. If it was valid, but have not yet brought in that page, page it in.
  3. Find a free frame.
  4. Schedule a disk operation to read the desired page into the newly allocated frame.
  5. When the disk read is complete, modify the internal table kept with the process and the page table to indicate that the page is now in memory.
  6. Restart the instruction that was interrupted by the trap. The process can now access the page as though it had always been in memory.
- In the extreme case, we can start executing a process with no pages in memory. When the operating system sets the instruction pointer to the first 404 Chapter 9 Virtual Memory instruction of the process, which is on a non-memory-resident page, the process immediately faults for the page. After this page is brought into memory, the process continues to execute, faulting as necessary until every page that it needs is in memory. At that point, it can execute with no more faults. This scheme is **pure demand paging**: never bring a page into memory until it is required
- Theoretically, some programs could access several new pages of memory with each instruction execution, possibly causing multiple page faults per instruction. This situation would result in unacceptable system performance. Locality of reference can be used for such situations.
- Hardware support needed for demand paging
  - **Page table.** This table has the ability to mark an entry invalid through a valid-invalid bit or a special value of protection bits.
  - **Secondary memory.** This memory holds those pages that are not present in main memory. The secondary memory is usually a high-speed disk. It is known as the swap device, and the section of disk used for this purpose is known as swap space

#### Performance of Demand Paging

- Demand paging can significantly affect the performance of a computer system.
- the effective access time is

$$\text{Effective access time} = (1 - p) \times ma + p \times \text{page fault time.}$$

➤ where,

- $p$  be the probability of a page fault ( $0 \leq p \leq 1$ ).
- $ma$  be the memory-access time

$\therefore p=0$ , no page fault  
 $p=1$ , every reference is a fault.



15/11

### Page Replacement

- It prevents over-allocation of memory by modifying page-fault service routine to include page replacement.
- Use modify (dirty) bit to reduce overhead of page transfers.

### Basic Page Replacement

- Page replacement takes the following approach.

  1. Find the location of the desired page on the disk.
  2. Find a free frame:

    - a. If there is a free frame, use it.
    - b. If there is no free frame, use a page-replacement algorithm to select a victim frame.
    - c. Write the victim frame to the disk; change the page and frame tables accordingly.

  3. Read the desired page into the newly freed frame; change the page and frame tables.
  4. Restart the user process.



### page replacement

- Use modify (dirty) bit to reduce overhead of page transfers – only modified pages are written to disk.
- Page replacement completes separation between logical memory and physical memory – large virtual memory can be provided on a smaller physical memory.
- two major problems to implement demand paging
  - Frame allocation algorithm
  - page replacement algorithm
- Frame-allocation algorithm determines
  - How many frames to give each process
  - Which frames to replace
- Page-replacement algorithm
  - Want lowest page-fault rate on both first access and re-access
- Evaluate algorithm by running it on a particular string of memory references (reference string) and computing the number of page faults on that string
  - String is just page numbers, not full addresses
  - Repeated access to the same page does not cause a page fault
  - Results depend on number of frames available

### First-In-First-Out (FIFO) Algorithm

- A FIFO replacement algorithm associates with each page the time when that page was brought into memory.
- When a page must be replaced, the oldest page is chosen.
- Example:
  - Reference string: 7,0,1,2,0,3,0,4,2,3,0,3,0,3,2,1,2,0,1,7,0,1
  - 3 frames (3 pages can be in memory at a time per process)

| reference string | 3 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 7                | 0 | 1 | 2 | 0 | 3 | 0 | 4 | 2 | 3 | 0 | 3 | 2 | 1 | 2 | 0 | 1 | 7 | 0 | 1 |
| 7                | 7 | 7 | 2 | 2 | 2 | 4 | 4 | 4 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 7 | 7 | 7 |
| 0                | 0 | 0 | 3 | 3 | 3 | 2 | 2 | 2 | 2 | 2 | 3 | 3 | 3 | 2 | 2 | 2 | 1 | 0 | 0 |
| 1                | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 3 | 3 | 3 | 2 | 2 | 2 | 1 | 2 | 2 |

$$\text{Page Hit} = 57$$

$$\text{Page fault} = 15$$

$$\text{Hit ratio} = \frac{\text{no. of hit}}{\text{Total no. of reference}}$$

$$= \frac{7}{22} \times 100$$

- Belady's Anomaly - for some page-replacement algorithms, the page-fault rate may increase as the number of allocated frames increases.

$$\text{Page fault ratio} = \frac{\text{no. of page fault}}{\text{Total no. of ref}}$$

$$= \frac{15}{22} \times 100$$

## First In First Out (FIFO)

16

7, 0, 1, 2, 0, 3, 0, 4, 2, 3, 0, 3, 2, 1, 2, 0, 1, 7, 0, 1  
Frame = 3



$$\text{Page fault} = 15$$

$$\text{Page hit} = 5.$$

Frame = 4



$$\text{Page fault} = 10.$$

$$\text{Page hit} = 10.$$

As no. of frames ↑, page fault ↓.

## Belady's Anomaly in FIFO

1, 2, 3, 4, 1, 2, 5, 1, 2, 3, 4, 5

Frame = 3

Page f = 9



Frame = 4

Page f = 10



As no. of frames ↑, page fault also ↑. This unexpected condition is called Belady's ~~Anomaly~~ Anomaly.

|     |               |   |   |   |   |   |   |   |   |   |   |   |   |                      |       |
|-----|---------------|---|---|---|---|---|---|---|---|---|---|---|---|----------------------|-------|
| DPT | $\rightarrow$ | 2 | 3 | 2 | 1 | 5 | 2 | 4 | 5 | 3 | 2 | 5 | 2 | P.f = 6.             | 17/12 |
| 2   |               | 2 | 2 |   | 3 | 3 | 5 |   |   | 3 | 5 |   |   | Hit = 6.             |       |
| 3   |               |   | 3 |   | 5 |   |   | 2 |   | 5 |   |   |   | Hit $\propto$ 6/12   |       |
| 1   |               |   |   | 5 |   |   |   |   | 5 |   |   |   |   | Miss $\propto$ 6/12. |       |
| *   | *             | H | * | * | H | * | H | * | H | * | H | * | H |                      |       |

o Example: For the reference string 1,2,3,4,1,2,5,1,2,3,4,5

page fault is 9 with frames 3 and page fault is 10 with frames 4.

### Optimal Page Replacement

- Replace page that will not be used for longest period of time.
- It has the lowest page-fault rate of all algorithms and will never suffer from Belady's anomaly-hence known as OPT or MIN.

$$P.f = 9, H_{\text{eff}} = 11$$

reference string

7 0 1 2 0 3 0 4 2 3 0 3 2 1 2 0 1 7 0 1



$$\text{Hit ratio} = 11/20$$

$$\text{Miss ratio} = 9/20.$$

- It is difficult to implement, because it requires future knowledge of the reference string.

### LRU Page Replacement (Least Recently Used Alg (LRU))

- Use past knowledge rather than future.
- Replace page that has not been used in the most amount of time.
- Associate time of last use with each page.

$$P.f = 12.$$

reference string

7 0 1 2 0 3 0 4 2 3 0 3 2 1 2 0 1 7 0 1



- 12 faults - better than FIFO but worse than OPT.
- Generally good algorithm and frequently used.
- Two methods of implementations:
  - Counter implementation
    - Every page entry has a counter; every time page is referenced through this entry, copy the clock into the counter.
    - When a page needs to be changed, look at the counters to find smallest value (less frequently used)
      - Search through table needed
  - Stack implementation
    - Keep a stack of page numbers in a double link form.
    - Page referenced:
      - move it to the top
      - requires 6 pointers to be changed
    - But each update more expensive
    - No search for replacement
  - LRU and OPT are cases of stack algorithms that don't have Belady's Anomaly

|     |               |   |   |   |   |   |   |   |   |   |   |   |   |          |
|-----|---------------|---|---|---|---|---|---|---|---|---|---|---|---|----------|
| LRU | $\rightarrow$ | 2 | 3 | 2 | 1 | 5 | 2 | 4 | 5 | 3 | 2 | 5 | 2 | P.f = 7. |
| 2   | 2             |   | 2 | 2 |   |   | 2 |   |   | 3 | 3 |   |   |          |
| 3   |               | 3 | 5 |   |   | 5 |   |   | 5 | 5 |   |   |   |          |
| 1   |               |   | 1 | 1 |   | 4 |   |   | 4 | 2 |   |   |   |          |
| *   | *             | H | * | * | H | * | H | * | H | * | * | H | H |          |

## FIFO

| Pages:-        | 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 | 4 | 4 | 4 | 4 | 3 | 3 | 3 | 3 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 4 |
| F <sub>2</sub> | 2 | 2 | 2 | 1 | 6 | 6 | 6 | 4 | 4 | 4 | 4 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 |
| F <sub>3</sub> | * | * | * | H | * | H | * | * | H | * | * | * | * | H | * | * | H | * | * |

No. of page faults = 13.

$$\text{Hit ratio} = \frac{\text{No. of hit}}{\text{Total}} = \frac{6}{19}$$

$$\text{Miss ratio} = \frac{\text{No. of miss}}{\text{Total}} = \frac{13}{19}$$

## OPT

Replace a page which is not in use ~~for~~ <sup>in near future</sup> a long time.

|                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 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 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 4 |
| F <sub>2</sub> | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 3 | 3 | 3 |
| F <sub>3</sub> | * | * | * | H | * | H | * | H | * | H | * | H | * | H | * | H | * | H | * |

No. of page fault = 10.

Hit = 9

$$\text{Hit ratio} = \underline{\underline{9/19}}$$

## LRU

Replace a page which is not in use, for a long time

|                |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 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 | 6 | 6 | 6 | 3 |   |   | 1 |   | 1 | 2 | 2 | 2 | 2 | 4 |   |
| F <sub>2</sub> | 2 | 2 | 4 | 4 | 2 | 2 | 2 | 2 |   |   | 2 |   | 5 | 5 | 5 | 5 | 3 | 3 |   |
| F <sub>3</sub> | * | * | 1 | 1 | 1 | 1 | 4 | 4 |   |   | 4 |   | 4 | 4 | 4 | 1 | 1 | 1 | * |

Page fault = 14.

$$\text{hit ratio} = 5/19.$$

## Compare FIFO, OPT, LRU.

- \* whenever CPU needs to execute a page, it checks whether that page is present in MM or not.  
If page present in MM, then CPU executes that page.  
If page not present in MM, then it has page fault.  
Whenever a page fault occurs, OS loads page from Hard disk to MM.
- \* If MM is full, one page needs to be replaced. That is decided with page replacement algorithm.
- FIFO - Page that has been in memory for the longest period of time will be replaced i.e., oldest page-replaced
- OPT - Page that will not be used for longest period of time in the future will be replaced
- LRU - Page that is least recently used in the past will be replaced
- \* OPT is the best alg. bcoz OPT produces less no. of page faults than FIFO & LRU. But it is impossible to implement OPT alg practically bcoz OPT needs to know future page information also.
- \* LRU is best compared to FIFO as it produces less page fault than FIFO.
- \* In increasing frame size, no. of page faults must be less.
- \* In FIFO, it has belady's anomaly. (i.e., even though by increasing the no. of frames, the no. of page faults was also more)

|   |   |   |   |   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 4 | 7 | 0 | 7 | 1 | 0 | 1 | 2 | 1 | 2 | 7 | 1 | 2 |
| 4 | 7 | 0 | 7 | 1 | 0 | 1 | 2 | 1 | 2 | 7 | 1 | 2 |
| 4 | 4 | 0 | 7 | 7 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
| 4 | 4 | 4 | 4 | 4 | 7 | 7 | 7 | 7 | 7 | 0 | 0 | 0 |
|   |   |   |   |   | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 |
|   |   |   |   |   | 4 | 7 | 1 | 2 | 7 | 1 | 2 | 7 |
|   |   |   |   |   |   |   |   |   |   |   |   |   |
|   |   |   |   |   |   |   |   |   |   |   |   |   |

reference string

4 7 0 7 1 0 1 2 1 2 7 1 2

↑ ↑

a b

stack before a

stack after b

Top  $\rightarrow$  most recently used page  
 bottom  $\rightarrow$  less " "

update  $\rightarrow$  expensive

Use of a stack to record the most recent page references.

### LRU-Approximation Page Replacement

#### Additional-Reference-Bits Algorithm

- $\triangleright$  With each page associate a bit, initially = 0
- $\triangleright$  When page is referenced bit set to 1
- $\triangleright$  Replace any with reference bit = 0 (if one exists)

Disadv  $\rightarrow$  Cannot know the order which is most recently or least recently referenced.

#### Second-Chance Algorithm

- $\triangleright$  The basic algorithm of second-chance replacement is a FIFO replacement algorithm.  
 When a page has been selected, inspect its reference bit.
- $\triangleright$  If the value is 0, proceed to replace this page; but if the reference bit is set to 1, give the page a second chance and move on to select the next FIFO page.
- $\triangleright$  When a page gets a second chance, its reference bit is cleared, and its arrival time is reset to the current time. Thus, a page that is given a second chance will not be replaced until all other pages have been replaced.
- $\triangleright$  One way to implement the second-chance algorithm (the clock algorithm) is as a circular queue. A pointer indicates which page is to be replaced next.
- $\triangleright$  When a frame is needed, the pointer advances until it finds a page with a 0 reference bit



Oldest page will be replaced from the my first.

Each page given a second chance,  
 that means if that page is most frequently used page it will be in my

Second-chance (clock) page-replacement algorithm

#### Enhanced Second-Chance Algorithm

- $\triangleright$  Improve algorithm by using reference bit and modify bit (if available) in concert
- $\triangleright$  Take ordered pair (reference, modify)
  1. (0, 0) neither recently used nor modified - best page to replace
  2. (0, 1) not recently used but modified - not quite as good, must write out before replacement
  3. (1, 0) recently used but clean - probably will be used again soon
  4. (1, 1) recently used and modified - probably will be used again soon and need to write out before replacement
- $\triangleright$  When page replacement called for, use the clock scheme but use the four classes replace page in lowest non-empty class
  - $\circ$  Might need to search circular queue several times

High priority  
should not  
be replaced

Page - 1, 2, 3 - Class 1  $\rightarrow$  must selected for replacement

Page - 2, 3 - Class 2  $\rightarrow$  " "