

## UNIT - 4 (Part II)

### NON-CONTINUOUS MEMORY ALLOCATION:-

It is a memory allocation technique. It allows to store parts of a single process in non-contiguous fashion. The different parts of the same process can be stored at different places in the main memory.



PAGING: ⇒ Paging is a fixed size partitioning scheme.

⇒ In Paging, secondary and main memory are divided into equal fixed size partitions.

⇒ The partitions of secondary memory are called as pages.

⇒ The partitions of main memory are called as frames.

(2)

each process divided into parts where size of each part is same as page size



The pages of process are stored in the frames of main memory depending upon their availability.

### LOGICAL ADDRESS AND PHYSICAL ADDRESS

⇒ CPU always generates a logical address.  
A physical address is needed to access the main memory.

⇒ CPU generates a logical address consisting of two parts.

① Page number:- specifies the specific page of the process from which CPU wants to read the data.

(3)  
Q) Page offset:- Page offset specifies the specific word on the page that CPU wants to read.

⇒ For the Page number generated by the CPU.

Page Table:- Page Table Provides the corresponding frame numbers (base address of the frame) where that page is stored in the main memory.

⇒ The frame number combined with the page offset forms the required Physical Address.

⇒ Page offset specifies the specific word that has to be read from that page.



①

## Page Table Base Register (PTBR).

### PAGE TABLE:

Page table is a data structure. Page table is stored in the main memory. Each process has its own independent Page table.

PTBR (Page Table Base Register) contains the Base address of Page table.

Working:



PIBR (Page Table Base Register) provides the Base Address of Page table.  
The Base address of the Page table is added.

It gives the entry of the Page table containing the frame number, where the referenced page is stored.

## Ex Paging

① Calculate the size of memory if its address consists of 22 bits and the memory is 2-byte addressable.

sol we have

Number of location possible with = 22 bits

$$= 2^{22} \text{ location}$$

The size of one location = 2 bytes.

size of memory

size of memory =  $2^n \times$  size of one location

$$= 2^{22} \times 2$$

$$= 2^{22} \times 2^1$$

$$= 2^{23} \text{ bytes Ans}$$

$$= -8$$

② Calculate the number of bits required in the address for memory having size at 16 GB Assume the memory is 4-byte addressable.

Sol

Let 'n' number of bits are required

$$\text{Size of memory} = 2^n \times 4 \text{ bytes}$$

$$= 2^n \times 4 \text{ bytes}$$

$$= 2^{16} \text{ bytes}$$

$$= 16 \text{ KB}$$

$$2^n \times 4 = 16 \text{ KB}$$

$$2^n \times 2^2 = 2^{34}$$

$$2^n = 2^{32}$$

$n = 32 \text{ bits}$

## SEGMENTATION:-

Segmentation is a memory management technique in which the memory is divided into the variable size parts. Each part is known as a segment which can be allocated to a process.

(7)

## Segment table:-

Segment table is a table that stores the information about each segment of the process.

It has two columns. First column stores the size or length of the segment.

Second column stores the base address of starting address of the segment in the main memory.

Segment - 0

|                | Limit | Base |
|----------------|-------|------|
| S <sub>0</sub> | 1500  | 1500 |
| S <sub>1</sub> | 500   | 6300 |
| S <sub>2</sub> | 400   | 4800 |
| S <sub>3</sub> | 1100  | 3200 |
| S <sub>4</sub> | 1000  | 4700 |
| S <sub>5</sub> | 300   | 5700 |

Segment  
Table

⇒ Limit indicates the length or size of the segment.

⇒ Base indicates the base address or starting address of the segment in the main memory.

③

the Segment table - the segment are stored in the main memory.

|             |       |
|-------------|-------|
| Segment - 0 | 3000  |
|             | 3200  |
| Segment - 3 | 4300  |
| Segment - 2 | 4700  |
| Segment - 4 | 5700  |
| segment - 5 | 60 00 |
|             | 6300  |
| Segment - 1 | 6800  |

### Translating Logical Address into Physical Address:

CPU always generates a Logical address. A Physical Address is needed to access the main memory.

CPU generates a Logical Address consisting of two parts,

- ① Segment Number
- ② Segment offset.

(9)

⇒ Specific segment of the Process from which CPU wants to read the data.

⇒ Specific word in the segment that CPU wants to read.

② ⇒ for the generated segment Number corresponding entry is located in the Segment Table.

⇒ Then, Segment offset is compared with the Limit (size) of the segment.

Case-1 Segment offset  $\geq$  Limit:-

⇒ if segment offset is found to be greater than or equal to the limit, a trap is generated.

Case-2 Segment offset  $<$  Limit:-

⇒ if segment offset  $<$  limit then request is treated as a valid request.

⇒ The segment offset must always lie in the range [0, limit-1].



Difference Between Paging and Segmentation

### Paging

### Segmentation

① Paging divides Programs into fixed size Pages.

② Paging is closer to operating system

① Segmentation divides Programs into variable size Segments.

② Segmentation is closer to user.

- ③ It suffers from internal fragmentation.
- ④ Logical address is divided into page number and page offset.
- ⑤ Page table is used to maintain the page information.
- ⑥ Paging is invisible to user.
- ⑦ Paging results in a less efficient system.
- ⑧ It suffers from external fragmentation.
- ⑨ Logical address is divided into segment number and segment offset.
- ⑩ Segment table maintains segment information.

Cache memory:- Cache memory is a Random Access memory. The main advantage of cache memory is its very fast speed.

It can be accessed by the CPU at much faster speed than main memory.



### Multilevel cache organization

⇒ A multilevel cache organization is an organization where cache memories of different sizes are organized at multiple levels to increase the processing speed to a greater extent.

⇒ The smaller the size of cache the faster its speed.

Ex three level cache organization consists of three cache memories different size organized at three different level as -



(Three level cache organization)

### Cache Mapping:-

Cache mapping is a technique by which the contents of main memory are brought into the cache memory.



(14)

main memory is divided into equal size partitions called as blocks or frames.

cache memory is divided into partitions having same size as that of blocks called as lines.

### Cache mapping techniques:-

- (1) Direct mapping.
- (2) Fully Associative mapping
- (3) k-Way Set Associative mapping.

THRASHING!:- Thrashing in operating system is a phenomenon that occurs in computer operating system when the system spends an excessive amount of time swapping data between physical memory (RAM) and virtual memory (disk storage) due to high memory demanded and low available resources.

Swapping out a piece of a process just before that piece is needed.

(15)

## THRASHING

The Processor spends most of its time swapping pieces rather than executing user instruction. This activity is called the thrashing.

If a Process does not have enough pages the Page fault rate is very high, this leads to

⇒ Low CPU utilization

⇒ Operating System think that it needs to increase the degree of multiprogramming.

⇒ Another Process added to the system.

\* A process is busy swapping pages in and out.

\* The high Paging activity is called thrashing.

\* more paging and less CPU utilization.



$P_0 \otimes P_1 \otimes P_2 \otimes P_3$

(16)

CPU is utilize its complete time in swapping rather than executing instruction.



Swapping is done the CPU utilization is decreasing.

### VIRTUAL MEMORY IMPLEMENTATION USING PAGING:

Virtual memory is a concept that gives an illusion to the user that he has sufficient main memory (RAM) to execute any program/application of any size, however computer actually

(17)

have relatively smaller main memory,



## PAGE REPLACEMENT :-

Page replacement is a process of swapping out an existing page from the frame of a main memory and replacing it with the required page.

All the frames of main memory are already occupied.

Thus a page has to be replaced to create a room for the required page.

## Page Replacement Algorithms:-

- ⇒ FIFO Page Replacement Algorithms,
- ⇒ LIFO Last in first out
- ⇒ LRU Least recently used
- ⇒ Optimal
- ⇒ Random Page replacement Algorithms,  
⇒ MRU (Most recently used)

A Good Page Replacement algorithm is one that minimizes the number of Page faults.

## FIFO (first in first out) :-

This Algorithm works on the principle of "first in first out".

It replaces the oldest page that has been present in the main memory for the longest time.

It is implemented by keeping track of all page in a queue.

Ex A system uses 3 page frames for storing process page in the main

(19)

in the main memory. It uses the first in first out (FIFO) Page Replacement Policy. Assume that all the Page frames are initially empty. What is the total no of page faults that will occur while processing the Page reference string given 4, 7, 6, 1, 7, 6, 1, 2, 7, 2

so Page frames = 3



Number of Page hit = 4

Total Page fault = 6

$$\begin{aligned}
 \text{Hit ratio} &:= \frac{\text{Total no of page hit}}{\text{Total no of references}} \\
 &= \frac{4}{10} \text{ or } 40\% \underline{\text{Ans}}
 \end{aligned}$$

## Calculating miss ration:

20

Total Page Fault = 6

$$\text{miss ratio} = \frac{\text{Total No of Page miss}}{\text{Total No of references}}$$

## LIFO Page Replacement Algorithm

This algorithm work on the principle of Last in first out.

it replaces the newest page that arrived at last in the main memory

Ex Page refle seince Stating:-

4, 7, 6, 1, 7, 6, 1, 2, 7, 2,

for reference string: 4, 7, 6, 1, 7, 6, 1, 7,  
2



(21)

$$\text{Hit ratio} = \frac{\text{Total no of Page hit}}{\text{total no of references}}$$

$$= \frac{3}{10}$$

$$= 0.3 \text{ or } 30\%$$

$$\text{Miss ratio} = \frac{\text{Total no of Page miss}}{\text{Total no of references}}$$

$$= \frac{7}{10}$$

$$= 0.7 \text{ or } 70\% \quad \underline{\text{Ag}}$$

LRU (least recently used) Page Replacement Algorithm,

This Algorithm work on the Principle of "Least recently used".

It replace the Page that has not been referred by the CPU for the longest time.

Ex Page reference string  
 4, 7, 6, 1, 7, 6, 1, 2, 7, 2,  
 frame size = 3

208

(22)



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

$$\text{Page hit} = 4$$

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

$$= \frac{4}{10} = 0.4 \Rightarrow 40\%$$

$$\text{Miss ratio} = \frac{\text{Total no of Page misses}}{\text{Total no of Page reference}}$$

$$= \frac{6}{10} = 0.6 = 60\%$$

(23)

## Optimal Page Replacement Algorithm

This algorithm replaces the page that will not be referred by the CPU in future for the longest time.

It is practically impossible to implement this algorithm,

This is because the pages that will not be used in future for the longest time can not be predicted.

Ex      Page reference string                  Page frame size = 3  
 4, 7, 6, 1, 7, 6, 1, 2, 7, 2



Number of Page Hit = 5

Number of Page Fault = 5

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

$$= \frac{5}{10} = 0.5 \text{ or } 50\%$$

(24)

$$\text{Miss ratio} = \frac{\text{total no of Page misses}}{\text{total no of Page reference}}$$

$$= \frac{5}{10} = 0.5 = 50\% \text{ Ans}$$

### RANDOM PAGE REPLACEMENT Algorithm

Random Page Replacement Algorithm as the name suggest, this algorithm randomly replaces any page.

⇒ So this algorithm may behave like any other algorithm like FIFO, LIFO, LRU, optimal etc.

Ex

reference string

2, 7, 5, 1, 7, 2, 1, 2, 7, 2,

Do your  
best //

MRU (most recently (frequently used) page replacement algorithm) 25

Replace the most recently (frequently) used page in Page.

Ex Reference string

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

No of frame size = 4



(26)

Number of Page fault = 12  
No of Page Hit = 8 A

## LOCALITY OF REFERENCE, IN CACHE MEMORY

Locality of Reference! Locality of reference is also known as principle of Locality.

Locality of reference is a term for the phenomenon, in which the same values or related storage locations are frequently accessed depending on the memory access pattern.

⇒ Locality of reference is the tendency of a processor to access the set of memory locations repetitively over a short period of time,



Ex (1) Program loop  
? --.  
3 -- )

(2) subroutine (function)  
sub()  
? -  
3 - )

(3) Array  
ac[i]

i=1, 2, ..., n

On Table Look up procedure

### Types of Locality of Reference:

- ① Temporal Locality
- ② Spatial Locality

(i) Temporal Locality: Temporal Locality says that if a program access on memory address there is a good cache that it will access the same address again.

⇒ if refers to reuse of specific data resource within a short period of time.

Ex Loop excellent example of Temporal Locality

for loop (i do -- 50)

?

- -

- -

g

(2) Spatial Locality: Spatial Locality says that if a Program access one memory address, other nearby address  $\Rightarrow$  It refers to use of data elements within relatively close storage location.

Ex Nearly "every Program" exhibits spatial Locality (Because instruction are usually executed in sequence).

Inc Data)

Array a[i]

$i = 0, i = 1, i = 2 \dots$



employees (Id, name, Add(PhoneNo))