

## Paging:



Page size = frame size.

Any page can sit in any frame.

A process need not be contiguous

CPU → logical add → physical add.



PT

P<sub>5</sub>



PT & P<sub>1</sub>

|   |                |
|---|----------------|
| 0 | f <sub>0</sub> |
| 1 | f <sub>1</sub> |
| 2 | f <sub>2</sub> |
| 3 | f <sub>3</sub> |

PT & P<sub>2</sub>

|   |                |
|---|----------------|
| 0 | f <sub>4</sub> |
| 1 | f <sub>5</sub> |
| 2 | f <sub>6</sub> |
| 3 | f <sub>7</sub> |

PT & P<sub>3</sub>

|   |                 |
|---|-----------------|
| 0 | f <sub>8</sub>  |
| 1 | f <sub>9</sub>  |
| 2 | f <sub>10</sub> |
| 3 | f <sub>11</sub> |

PT & P<sub>4</sub>

|   |                 |
|---|-----------------|
| 0 | f <sub>12</sub> |
| 1 | f <sub>13</sub> |
| 2 | f <sub>14</sub> |
| 3 | f <sub>15</sub> |

P<sub>1</sub>

|   |   |
|---|---|
| 0 | • |
| 1 |   |
| 2 |   |
| 3 |   |

P<sub>2</sub>

|   |   |
|---|---|
| 0 | • |
| 1 |   |
| 2 |   |
| 3 |   |

P<sub>3</sub>

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

P<sub>4</sub>

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

OS



Page size = 1 KB

Process size  $\rightarrow$  10 KB

# Pages  $\rightarrow \frac{10 \text{ KB}}{1 \text{ KB}} = 10$  exactly.

# frames  $\rightarrow$  10  $\rightarrow$  no wastage.

---

Page size = 1 KB  
Process size  $\rightarrow$  10 KB + 1 B  $\rightarrow$  1 Pages

Pages  $\rightarrow$  11

# frames  $\rightarrow$  11

Last frame is wasted.

Best Case  $\rightarrow$  no wastage  
Worst Case  $\rightarrow$  entire frame is wasted

Average  $\rightarrow \left( \frac{0+1}{2} \right)$  page/process

internal fragmentation

$\rightarrow$  avg  $\rightarrow \frac{1}{2}$  of page

Size of a process is called logical address space (LAS)  
No of bits required to address LAS is logical address.

Ex: Let process size = 128 KB

then  $LAS = 128 \text{ KB} = 2^7 \times 2^{10} \text{ B} = 2^{17} \text{ B}$

$$LA = \lceil \log_2 LAS \rceil = \underline{\underline{17 \text{ bits}}} \quad LA =$$


Let Page size = 1 KB =  $2^{10} \text{ B}$

$$\text{Page offset} = \lceil \log_2 \text{Page size} \rceil = \underline{\underline{10 \text{ bits}}}$$

$$\# \text{Pages} = \frac{\text{Process size}}{\text{Page size}} = \frac{128 \text{ KB}}{1 \text{ KB}} = 128 = 2^7$$

Size of main memory is called physical address space (PAS)  
No of bits used to address main memory is called (PA)

Ex: Let main memory size =  $512 \text{ KB} = (\text{PAS})$

$$= 2^{19} \text{ B}$$

$$\text{PA} = \lceil \log_2 \text{PAS} \rceil = 19 \text{ bits.} \rightarrow \text{PA}$$

$$\text{Let frame size} = 512 \text{ B.} = 2^9 \text{ B}$$

frame offset = 9 bits.

$$\# \text{ frames} = \frac{\text{main memory size}}{\text{frame size}} = \frac{512 \text{ KB}}{512 \text{ B}} = K = 2$$





$PS = FS$   
all pages are  
of same size.



Page offset  
index into a page

NID H.I.D.

$PS = FS$   
always ✓



$$\text{Main memory} = \underline{64B} = \text{PAS}$$

$$\text{PA} = 6 \text{ bits}$$

$$\text{Frame size} = \underline{4B}$$

$$\text{frame off set} = \underline{2 \text{ bits}}$$

$$\# \text{ frames} = \frac{\text{mm size}}{\text{frame size}} = \frac{64B}{4B} = \underline{16} = 2^4$$



$$\text{Process size} = 16B = \text{LAS}$$

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

$$\text{Page size} = \underline{4B}$$

$$\text{Page offset} = \underline{2 \text{ bits}}$$

$$\# \text{ Pages} = \frac{\text{LAS}}{\text{Page size}} = \frac{16B}{4B} = \underline{4} = 2^2$$



P<sub>1</sub>

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

$$\text{LA(6)} = \text{PA(14)}$$

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

|   |      |                |
|---|------|----------------|
| 0 | 0010 | → flame number |
| 1 | 0011 |                |
| 2 | 0100 |                |
| 3 | 0101 |                |

$$\text{LA} = 6$$



OS

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

Every process will have a separate page table.

Ex:



The number of entries in a PT are equal to no of pages in the process.

For each page of a process, there will be an entry in the page table.

$$mm = 64 B$$

$$\text{Page size} = \text{Frame size} = 4 B$$

$$\text{Process size} = 16 B$$

Size of ~~PT~~ in ?

$$\begin{aligned}\text{Page table size} &= \text{No of entries in PT} * \text{Size of each entry} \\ &= \text{No of pages in process} * \text{bits required for frame number} \\ &= 4 * 4 \text{ bits} = 16 \text{ bits.} \\ &\quad = 2 \text{ Bytes.}\end{aligned}$$

$$\# \text{ pages} = \frac{\text{Process size}}{\text{Page size}} = \frac{16 B}{4 B} = 4$$

$$\# \text{ frame} = \frac{mms}{\text{Page size}} = \frac{64 B}{4 B} = 16 = 2^4$$

Generally computers are word addressable.

add:

100 → 2 Bytes.



100 → 4 Bytes.



Every 2 Bytes has one address.  
and so word size = 2 Bytes

Every 4 B has one address  
and so word size = 4 Bytes.

$LAS = 256 \text{ MB}$ , word size =  $4B$ ,  $LA = ?$

$$\begin{aligned} LAS &= 256 \text{ m}\cancel{B} = \frac{256 \text{ m}}{4} \cancel{w} \\ &= 64 \text{ m} \underline{\text{words}} \\ &= 2^6 \times 2^{20} \text{ words} \\ &= 2^{26} \text{ words} \end{aligned}$$

$$\therefore LA = 2^6 \text{ bits}$$

In exam, if they don't mention words, then it is  
byte addressable i.e  $1 \text{ word} = 1 \text{ Byte}$ .

PAS = 512 KB , words = 4 B , PA = ?

$$PAS = 512 KB = \frac{512 K}{4} words$$

$$= 2^{17} words$$

∴ PA = 17 bits.

PS = 512 B , WS = 4 B , Page offset

$$PS = 512 B = \frac{512}{4} \omega = 2^7 \omega$$

$$Page offset = 7 bits$$

## Virtual address space:



$$LAS = M = 2^m$$

$$LA = \lceil \log_2 M \rceil = m \text{ bits}$$

$$PAS = P = 2^p$$

$$PA = \lceil \log_2 P \rceil = p \text{ bits}$$

$$\text{Page size} = 2^K = \text{frame size}.$$

$$\# \text{ Pages} = \frac{LAS}{\text{Page size}} = \frac{2^m}{2^{p-K}} = 2^{m-K}$$



$$\# \text{ frames} = \frac{PAS}{\text{frame size}} = \frac{2^p}{2^K} = 2^{p-K}$$



$$\begin{aligned} LAS &= \# \text{ pages} \times \text{PS} \\ &= (2^{m-K}) \times 2^K = 2^m \end{aligned}$$

$$\begin{aligned} PAS &= \# \text{ frame} \times \text{frame size} \\ &= 2^{p-K} \times 2^K = 2^p \end{aligned}$$

$$\begin{aligned} \text{Page table size} &= \underbrace{\text{No of entries}}_{= 2^{m-K}} \times \text{frame no bits} \\ &\times (p-K) \end{aligned}$$

$$VAS - LAS = \frac{128 MB}{1 MB} = 2^{27} B$$

$$PAS = \frac{1 MB}{4 KB} = 2^{20} B$$

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



Virtual memory

many ways.



$$PTS = \# \text{ Pages} * \text{bits for frame number}$$

$$= 2^{15} * 8 \text{ bits} =$$

$$LAS = 128 \text{ KB} , PAS = 128 \text{ KB} , \text{Page size} = ? \text{ KB} , PTS = ?$$

$$= 2^{17} B \quad = 2^{17} B \quad = 2^{12} B.$$



$PTS = \# \text{ Pages} * \text{bit for frame number.}$

$$= 2^5 * 5 \text{ bits.}$$

$LAS = 256 \text{ KB}$ ,  $PAS = 1 \text{ MB}$ , Page size =  $4 \text{ KB}$

Page table entry size =  $2B$ .  $\underline{\underline{PTS}}$ ?



$$\# \text{ pages} = \frac{256 \text{ KB}}{4 \text{ KB}}$$
$$= \underline{\underline{64}}$$

$$\underline{\underline{PTS}} = \# \text{ pages} * \text{PTE}$$
$$= 64 * 2B = \underline{\underline{128B}}$$