

# CS & IT ENGINEERING



## Operating System

### Memory Management

Lecture -3

By- Vishvadeep Gothi sir



# Recap of Previous Lecture



Topic

Non-Contiguous MMT

Topic

Paging

Topic

Page Table

# Topics to be Covered



Topic

TLB Mapping

Topic

Segmentation



## Topic : Paging



### TLB (Translation Lookaside Buffer)





## Topic : Paging



### How TLB Stores Entries?



## Topic : Paging

### TLB Mapping

1. Fully Associative
2. Direct
3. Set-Associative



TLB

| Page no. | entry <sup>P-T</sup> |
|----------|----------------------|
| 100      | ✓                    |
| 110      | ✓                    |
| 001      | ✓                    |
| 101      | ✓                    |

4 entries

P.T.

|     |  |
|-----|--|
| 000 |  |
| 001 |  |
| 010 |  |
| 011 |  |
| 100 |  |
| 101 |  |
| 110 |  |
| 111 |  |

8 entries



## Topic : Paging

### TLB Mapping: Direct



P. T.



8 entries

Page no.

|     |               |
|-----|---------------|
| Tag | TLB entry no. |
|-----|---------------|

ex :- Page no = 000

no. of bits in TLB  
 entry no. =  $\log_2(\text{no. of entries in TLB})$



page no. = 100



ex:- no. of pages =  $2^{10} \Rightarrow p = 10$  bits

no. of entries in TLB =  $32 = 2^5$

Tag bits = 5?

Direct mapping





## Topic : Question

P  
W

#Q. A computer system implements a 31-bit virtual address, page size of 8 kilobytes, and a 256-entry translation look-aside buffer (TLB) organized as direct mapped. The minimum length of the TLB tag in bits is 10?





## Topic : Question

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

$$\Leftrightarrow 2^{10} B$$

#Q. A computer system implements a 44-bit virtual address, page size of 1 kilobytes, and a 16KB look-aside buffer (TLB) organized as direct mapped. Each page table entry is of 4bytes. The minimum length of the TLB tag in bits is 22?



$$\begin{aligned} \text{no. of entries} \\ \text{in TLB} &= \frac{16KB}{4B} \\ &= 4K \\ &= 2^{12} \end{aligned}$$



## Topic : Paging

### TLB Mapping: Set Associative



$$\text{no. of TLB set no.} = \log_2 (\text{no. of sets in TLB})$$

$$\text{no. of sets in TLB} = \frac{\text{no. of entries in TLB}}{\text{associativity}}$$

Ex:- no. of pages =  $2^{10} \Rightarrow p = 10$  bits

no. of entries in TLB = 32

2-way set associative TLB

$$\text{no. of sets} = \frac{32}{2} = 16 = 2^4$$





## Topic : Question

#Q. A Computer system implements a 36-bit virtual address, page size of 16 Kbytes and a 256 - entry translation look-aside buffer (TLB) organized into 64 sets each having four ways. Assume that the TLB tag does not store any process id. The minimum length of the TLB tag in bits is 16.



Paging suffers from internal Fragmentation

Page size = 4 KB





## Topic : Segmentation

- Divide Process in logically related partitions (Segments)  
*variable sizes*
- Segments are scattered in physical memory





# Topic : Segmentation

| Process | Segment Table |                         |
|---------|---------------|-------------------------|
| seg 0   | 00            | 9000 500                |
| seg 1   | 01            | 1000 300                |
| seg 2   | 10            | 12000 400               |
| seg 3   | 11            | 5000 800                |
|         |               | Base address      limit |



$$S = 2$$

$$d = 249$$

$$\begin{aligned} P.A. &= 12000 \\ &\quad + 249 \\ &= \underline{\underline{12249}} \end{aligned}$$



# Topic : Segmentation





## Topic : Segmentation



Segment Table

|    |       |     |
|----|-------|-----|
| 00 | 9000  | 500 |
| 01 | 1000  | 300 |
| 10 | 12000 | 400 |
| 11 | 5000  | 800 |

| Segment number | Offset | Physical Address    |
|----------------|--------|---------------------|
| 1              | 204    | $1000 + 204 = 1204$ |
| 0              | 449    | $9000 + 449 = 9449$ |
| 2              | 436    | fault               |
| 3              | 737    | $5000 + 737 = 5737$ |



## Topic : Segmentation

- Size of segment can vary, so along with base, keep limit information also
- Limit defines max number of words within the segment

L  
or bytes

---

no. of bits in d decided based on size of max possible segment.

## [NAT]

- #Q. Maximum segment size = 16KB =  $2^{14}$  B  $\Rightarrow d = 14$  bits  
Number of segments in process =  $2^{10} = s = 10$  bits  
Logical address = 24 bits ??





## Topic : Segmentation

- Segmentation suffers from external fragmentation

## L.A. to P.A. translation for decimal in paging :-

ex:- Page size = 4 bytes



$$\text{Page no.} = \left\lfloor \frac{\text{LA}}{\text{Page size}} \right\rfloor = \left\lfloor \frac{14}{4} \right\rfloor = 3$$

$$d = \text{LA \% page size} = 14 \% 4 = 2$$

---

$$\begin{aligned}\text{LA} &= (\text{Page no.} * \text{page size}) + d \\ &= (3 * 4) + 2 \\ &= 14\end{aligned}$$

$$f = \left\lfloor \frac{P.A.}{\text{page size}} \right\rfloor$$

$$d = P.A. \% \text{ page size}$$

$$\overline{P.A. = (f * \text{page size}) + d}$$

Ques) Page size = 64 B

$$L.A.S. = \frac{256 B}{64 B} = 2^8$$

$$L.A. = 147$$

$$P.A. = 83$$

$$\stackrel{\text{Soln}}{=} P = \frac{147}{64} = 2$$

$$d = 147 \% 64 = 19$$

Page Table

|   |
|---|
| 5 |
| 3 |
| 1 |
| 7 |

$$f = 1$$

$$P.A. = (1 * 64) + 19$$

$$= 83$$

8 bits



$$(147)_{10} = \boxed{10010011}$$

$\xrightarrow{P: 1, \Rightarrow f=1 \rightarrow}$

$$\boxed{1010011} \Rightarrow (83)_{10}$$

(GATE-2024)

Ques) page size = 2 kB

Pages 0, 1, 2, 3 are stored on 1, 3, 2, 0 frames in main memory.

$$L.A. = (2500)_{10}$$
$$P.A. = \underbrace{(6596)}_{10} \quad ?$$

$$\frac{S_0}{n} = P = \left\lfloor \frac{2500}{2048} \right\rfloor = 1 \Rightarrow P.T. \Rightarrow f = 3$$

$$d = 2500 \% 2048 = 452$$



$$P.A. = (3 * 2048) + 452$$
$$= \underline{\underline{6596}}$$



## Topic : Virtual Memory

- Feature of OS
- Enables to run larger process with smaller available memory





# Topic : Virtual Memory



8 Pages





# Topic : Virtual Memory

P  
W

Process

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

Page table

|     |               |
|-----|---------------|
| 000 | 01            |
| 001 | 10            |
| 010 | 00            |
| 011 |               |
| 100 |               |
| 101 | <del>10</del> |
| 110 | 11            |
| 111 |               |

8 Pages

mm .

|    |        |
|----|--------|
| 00 | Page 2 |
| 01 | Page 0 |
| 10 | Page 5 |
| 11 | Page 6 |

4 frames

secondary mem.





## Topic : Demand Paging

- **Demand Paging:**

Bring pages in memory when CPU demands

- **Page Fault:**

When the demanded page is not available in physical memory

↳ os provides page fault service by bringing demanded page into mm.

↳ After service the instr which caused page fault will start

Pure demand paging :-

mm frames are empty when process starts.

and bring pages in mm only on demand.



## 2 mins Summary



**Topic**

**TLB Mapping**

**Topic**

**Segmentation**



# Happy Learning

## THANK - YOU