



## Lecture: 30

# CLASSES



# Summary So Far..

- Base & Bound
- Segmentation
- Paging.



# Operating Systems

Two programs one memory



GO  
CLASSES





## Relocation

- One way to achieve this is to relocate program at different addresses



# Address TRANSLATION IN BASE Setup





## Two processes, one memory?



What if Process1 generate some illegal address ?





## Base and Bound ↳ (limit register)

- 2 hardware registers: base and bound

↓ Process size =

- A process can only access physical memory in [base, base+bound)

Process size = bound (limit)

logical address =  $[0, \frac{\text{bound}-1}{\text{limit}-1}]$  or  $(0, \frac{\text{bound}}{\text{limit}})$



# Base and Bound

- ✓ • 2 hardware registers: base and bound
  - A process can only access physical memory in [base, base+bound)
  - On a context switch:
    - ♦ Save/restore base and bound registers
- } ← Providing Protection

ES



## Base+Bounds Advantages

- Provides protection across address spaces
- Supports dynamic relocation
- Simple, inexpensive, fast HW implementation
  - Few registers, little logic in MMU
- Simple context switching logic
  - Save and restore a couple of registers

ES

[https://compas.cs.stonybrook.edu/~nhonarmand/courses/fa17/cse306/slides/05-virtual\\_memory.pdf](https://compas.cs.stonybrook.edu/~nhonarmand/courses/fa17/cse306/slides/05-virtual_memory.pdf)

# Base+Bounds Disadvantages

- Each process must be allocated **contiguously** in physical memory
  - Must allocate memory that may not be used by process

*disadvantage*



[https://compas.cs.stonybrook.edu/~nhonarmand/courses/fa17/cse306/slides/05-virtual\\_memory.pdf](https://compas.cs.stonybrook.edu/~nhonarmand/courses/fa17/cse306/slides/05-virtual_memory.pdf)

Why not just Base and Bound?



- Big chunk of “free” space
- “free” space takes up physical memory.

SSES

<https://www.cs.unm.edu/~crandall/operatingsystems20/slides/14-Address-Space-Segmentation.pdf>



## Segmentation





# Segmentation

- Split each process' logical address space into multiple segments
- Segment: variable-sized area of memory
- Natural extension of base and bound
  - ◆ Base and bound: 1 segment per process
  - ◆ Segmentation: many segments per process



# Operating Systems



No longer

Contiguous memory needed



# Operating Systems





# Segmentation is ok... but





# Segmentation is ok... but

initially we do not have idea about  
( can not )  
segment sizes ( specifically for heap , and stack )



# What if process needs more memory?





# What if process needs more memory?





# Operating Systems

## You can move P2 in memory





## ❖ Problems

- External fragmentation
  - Segments of many different sizes have to be allocated contiguously
  - This problem also applies to base and bound schemes





## Dealing with fragmentation

- Compact memory by copying
  - Swap a program out
  - Re-load it, adjacent to another
  - Adjust its base register
  - “Lather, rinse, repeat”
  - Ugh





Free space management, when allocating a new chunk...

## Segmentation



GO  
CLASSES



Questions on  
Base-Bound and Segmentation



## Question

5. Assume you have the following process table (list of active processes):

```
[ Process A base:100 bounds:10 ]  
[ Process B base:1000 bounds:20 ]  
[ Process C base:500 bounds:50 ]
```

Assume process A is running on a CPU. After the switch to process B, which of the following is a physical address that process B might legally refer to?

- a. 0
- b. 20
- c. 500
- d. 1015
- e. None of the above

1000 — 1019



## Question

5. Assume you have the following process table (list of active processes):

[ Process A base:100 bounds:10 ]  
[ Process B base:1000 bounds:20 ]  
[ Process C base:500 bounds:50 ]

Assume process A is running on a CPU. After the switch to process B, which of the following is a physical address that process B might legally refer to?

- a. 0
- b. 20
- c. 500
- d. 1015
- e. None of the above

1000 — 1019



# Operating Systems

5. Assume you have the following process table (list of active processes):

```
[ Process A base:100 bounds:10 ]  
[ Process B base:1000 bounds:20 ]  
[ Process C base:500 bounds:50 ]
```

Assume process A is running on a CPU. After the switch to process B, which of the following is a physical address that process B might legally refer to?

- a. 0
- b. 20
- c. 500
- d. 1015
- e. None of the above

B's base is 1000, bounds 20  
 $\Rightarrow$  1000 ... 1019 are legal  
 $\Rightarrow$  1015



# Operating Systems

## Question

### Logical



- { What will be physical address corresponding to  
logical address 100  
logical address 4200  
logical address 7000  
logical address 15K

| seg   | base | bound/size |
|-------|------|------------|
| code  | 32K  | 2K         |
| heap  | 34K  | 2K         |
| stack | 28K  | 2K         |



## Solution

- check: 100 in code segment
- physical = code base + offset
  - ◆  $32K + 100 = \text{32868}$

**address: 7000**

- check: not in any segment
- **Segmentation fault**

- check: 4200 in heap segment
- physical = heap base + offset
  - ◆  $34K + (4200 - 4K) = \text{34920}$

**address: 15K ?**

- For home thinking / reading

*Stack*



## Question

Consider the following Segment Table:

| Base | Limit |
|------|-------|
| 219  | 600   |
| 2300 | 14    |
| 90   | 100   |
| 1327 | 580   |
| 1952 | 96    |

- i. What are the physical addresses corresponding to the following two logical addresses:  
1000, 2400

- ii. What is the logical address for the physical address: 1375

good



# Operating Systems

**Solution :** The logical address space of the process is drawn below according to the segment sizes of the 5 segments given in the segment table.



ES



# Operating Systems

i.

So, logical address 1000 is in Seg. No. 3

$$\begin{aligned}\text{Offset of the address in its segment} &= 1000 - 714 \text{ (base logical addr. Of Seg. 3)} \\ &= 286\end{aligned}$$

$$\begin{aligned}\text{Hence, the corresponding physical address} &= 1327 \text{ (base physical addr. Of Seg. 3)} + 286 \\ &= 1613\end{aligned}$$

2400 is beyond the logical address space of the process. Hence, it will generate a TRAP: Addressing Error. (Ans.)

ii.

Physical address 1375 belongs to the space allocated to Seg. 3 in main memory. [Because physical address space for Seg. 3 is 1327 to  $(1327+580) = 1907$ . // See the Segment table give in the question paper.]

So, offset of this physical address =  $1375 - 1327$  (base physical addr. Of Seg. 3) = 48

$$\begin{aligned}\text{Hence, the corresponding logical address} &= 714 \text{ (base logical addr. Of Seg. 3)} + 48 \\ &= 762\end{aligned}$$



## Paging



Not really a new idea...



- Divide content into **fixed-sized** pages.
- Each page has a page number.
- Locate content in a page by an offset, e.g., “10th word of Page 8”, ...
- There is a “table” which tells you which content is in which page.

## Modern technique: Paging

- Solve the external fragmentation problem by using fixed sized units in both physical and logical memory
- Solve the internal fragmentation problem by making the units small





## Address Translation

Logical page number (LPN) to Physical page number (PPN) using page table.

$$\frac{\text{Logical address}}{\text{page\_size}}$$

$$\text{Frame Number} = \text{page\_table} \left[ \frac{\text{Logical address}}{\text{page\_size}} \right]$$

$$\text{offset} = \text{logical address \%page\_size} \quad \text{Page\_number}$$



## Address Translation

Logical page number (LPN) to Physical page number (PPN) using page table.

$$\frac{\text{Logical address}}{\text{page\_size}}$$

$$\text{Frame Number} = \text{page\_table} \left[ \frac{\text{Logical address}}{\text{page\_size}} \right]$$

$$\text{offset} = \text{logical address \%page\_size} \quad \text{Page\_number}$$

$$\text{PA} = \text{frameNo} \times \text{frame size} + \text{offset}$$



# Operating Systems



<https://www.cs.columbia.edu/~junfeng/13fa-w4118/lectures/I05-mem.pdf>



# Operating Systems

## Question

Suppose LAS = 1024 Bytes

page size = 8 bytes

and page table is given as follows

Logical → Physical  
905 → ??

| pn  | fn |
|-----|----|
| 0   | 3  |
| 1   | 6  |
| :   |    |
| 113 | 10 |
| :   |    |
| 127 |    |



# Operating Systems

logical address  
↓  
page No.  
go4 → 113  
go5 → 113  
go6 → 113  
go7 → 113  
go8 → 113  
⋮  
go11 → 113

| PN  | FN |
|-----|----|
| 0   | 3  |
| 1   | 6  |
| :   |    |
| 113 | 10 |
| :   |    |
| 127 |    |





## Question

Each page contains = 8 Bytes  
800 will be in 100<sup>th</sup> page number

What will be physical address corresponding to 807 ?

| Pg No     | Frame No |
|-----------|----------|
| 0         |          |
| 1         |          |
|           |          |
| 100       | xyz      |
|           |          |
|           |          |
|           |          |
| $2^7 - 1$ |          |

2<sup>7</sup> Entries





Two intuitive ways to understand why this split make sense :





# Operating Systems

$$\underline{807} = \left( 100 \times \underset{\text{page size}}{8} \right) + \underset{\text{remainder}}{7}$$

→ logical address

“Power of 2”





# Operating Systems

Divide by 10

$$1298376 \% \underline{10} = 6$$

$$1298376 \% \underline{100} = 76$$

$$1298376 \% \underline{1000} = 376$$

Decimal division is very good for power of 10.

Divide by 2

$$1622 \% \underline{2} = 0$$

$$1622 \% \underline{2^2} = 2$$

$$1622 \% \underline{2^3} = 6$$

~~logical address~~

logical address

page size

NO  
shortcut  
=====



What does Page  
table entry  
contain ?



What does Page  
table entry  
contain ?

{ frame No. and  
few other  
bits }

Can it contain the byte number?



PM

1) Convert frame no. to byte no

$\text{fno} \times \text{f size}$   
Byte number

2) add offset to convert to PA.

# Question

we have 8 pages (each size  $2^{32}$  B)

to store in PM of

size  $2^{32}$  B

# bits required to identify  
page No. ?



PM

Why 3 is wrong answer

000  
001  
010  
:  
111 - 7

GO  
CLASSES





Number of Pages = 8 } ← doesn't  
matter to



Size of the page matters







## Other PTE Info

- What other info is in PTE besides PFN?
  - **Valid** bit
  - **Protection** bit
  - **Present** bit (needed later)
  - **Referenced** bit (needed later)
  - **Dirty** bit (needed later)

SSES



# Operating Systems

Free space management, when allocating a new chunk...

## Segmentation



Scanning through the list of free memory regions:

- not big enough,
- not big enough, ...,
- yes, big enough, but maybe it's not the best fit, let's keep scanning...
- scan is over, now I have to make a decision...



## Paging



**Paging is simple.**



## A Typical System has:

Page size = 4 KB, 32 bit LA

$$\text{So, } \frac{2^{32}}{4 \text{ KB}} = \frac{2^{32}}{2^{12}} = 2^{20} \text{ pages}$$

### Observation

Usually there is lot of unallocated pages for a process in between heap and stack.

Process just usages few pages.

We can not afford this huge page table for every process

There will be  $2^{20}$  page table entries,

if each page table entry is 4B then page size =



Process Size  
could be too  
small.

- One such page table for each process.



## Why are page tables so large?

Answer Page tables are full of invalid PTEs



Question How to avoid storing invalid PTE?

[https://web.fe.up.pt/~pfs/aulas/so2021/at/24vm\\_tables.pdf](https://web.fe.up.pt/~pfs/aulas/so2021/at/24vm_tables.pdf)



# Multi Level Paging



# Operating Systems

6 bits

8 bits

8 bits

10 bits





# Operating Systems





# Operating Systems

Consider a 3-level page table on a system where pages are 256 bytes, page table entries are 2 bytes, and

- first level page tables contain 16 entries
- second level page tables contains 128 entries
- third level page tables contain 128 entries

What is size of VAS ?





# Operating Systems

## Question

Consider a system, Starting with a 48-bit virtual addresses, it uses 4 levels of page table to translate the address to a 52-bit physical address.

Each page table entry is 8 bytes long.

If the page size is increased, the number of levels of page table can be reduced. How large must pages be in order to translate 48-bit virtual addresses with only a 2 level page table?



# Operating Systems

Notice first that the page size is  $2^{12}$  in Figure 1. The page table size is also  $2^{12}$  ( $2^9 * 8$  bytes per page table entry, for a 64 bit processor).

For a two level page table, say page size is  $2^n$ . The page table size is also  $2^n$  bytes in this multi-level page table. So the number of PTE in a page table is  $2^{(n-3)}$ .

So the virtual address is broken into  $(n-3)$ ,  $(n-3)$ , and  $n$  bits.

$$(n-3) + (n-3) + n = 48$$

$n = 18$ , so page size is  $2^{18} = 256KB$ .

The 48-bit virtual address is divided into 15, 15, 18 bits. The first 15 bits index into the first page table, the second 15 bits index in the second page table, and the rest of the 18 bits is the page offset.



# Operating Systems

|     |     |     |   |
|-----|-----|-----|---|
| p-2 | p-2 | p-2 | p |
|-----|-----|-----|---|

logical address space is 46 bits as given. Hence. equation becomes,

$$(p - 2) + (p - 2) + (p - 2) + p = 46$$

$$\Rightarrow p = 13.$$

Therefore, page size is  $2^{13}$  Bytes = **8KB**.



<https://gateoverflow.in/379/gate-cse-2013-question-52>



## GATE CSE 2008 | Question: 67



237



A processor uses 36 bit physical address and 32 bit virtual addresses, with a page frame size of 4 Kbytes. Each page table entry is of size 4 bytes. A three level page table is used for virtual to physical address translation, where the virtual address is used as follows:

- Bits 30 – 31 are used to index into the first level page table.
- Bits 21 – 29 are used to index into the 2nd level page table.
- Bits 12 – 20 are used to index into the 3rd level page table.
- Bits 0 – 11 are used as offset within the page.

The number of bits required for addressing the next level page table(or page frame) in the page table entry of the first, second and third level page tables are respectively

- A. 20,20,20
- B. 24,24,24
- C. 24,24,20
- D. 25,25,24



gatecse-2008

operating-system

virtual-memory

normal



Should i must  
be having 2<sup>25</sup> slots  
chunks  $\Rightarrow$  No.

$$PM = 2^{36} B$$

LAS

|   |   |   |    |
|---|---|---|----|
| 2 | 3 | 3 | 12 |
|---|---|---|----|



2<sup>9</sup> entries  
2<sup>11</sup> Bytes



285



Best answer

Physical address is 36 bits. So, number of bits to represent a page frame

$= 36 - 12 = 24 \text{ bits}$  (12 offset bits as given in question to address 4 KB assuming byte addressing). So, each entry in a third level page table must have 24 bits for addressing the page frames.

A page in logical address space corresponds to a page frame in physical address space. So, in logical address space also we need 12 bits as offset bits. From the logical address which is of 32 bits, we are now left with  $32 - 12 = 20 \text{ bits}$ ; these 20 bits will be divided into three partitions (as given in the question) so that each partition represents 'which entry' in the  $i^{\text{th}}$  level page table we are referring to.

- An entry in level  $i$  page table determines 'which page table' at  $(i + 1)^{\text{th}}$  level is being referred.

Now, there is only 1 first level page table. But there can be many second level and third level page tables and "how many" of these exist depends on the physical memory capacity. (In actual the no. of such page tables depend on the memory usage of a given process, but for addressing we need to consider the worst case scenario). The simple formula for getting the number of page tables possible at a level is to divide the available physical memory size by the size of a given level page table.

$$\begin{aligned}\text{Number of third level page tables possible} &= \frac{\text{Physical memory size}}{\text{Size of a third level page table}} \\ &= \frac{2^{36}}{\text{Number of entries in a single third level page table} \times \text{Size of an entry}} \\ &= \frac{2^{36}}{2^9 \times 4} \because (\text{bits 12-20 gives 9 bits}) \\ &= \frac{2^{36}}{2^{11}} \\ &= 2^{25}\end{aligned}$$

PS: No. of third level page tables possible means the no. of distinct addresses a page table can have. At any given time, no. of page tables at level  $j$  is equal to the no. of entries in the level  $j - 1$ , but here we are considering the **possible** page table addresses.

ems

GO Classes

<http://www.cs.utexas.edu/~lorenzo/corsi/cs372/06F/hw/3sol.html> See Problem 3, second part solution - It clearly says that we should not assume that page tables are page aligned (page table size need not be same as page size unless told so in the question and different level page tables can have different sizes).

So, we need 25 bits in second level page table for addressing the third level page tables.

Similarly we need to find the no. of possible second level page tables and we need to address each of them in first level page table.

Now,

$$\begin{aligned}\text{Number of second level page tables possible} &= \frac{\text{Physical memory size}}{\text{Size of a second level page table}} \\ &= \frac{2^{36}}{\text{Number of entries in a single second level page table} \times \text{Size of an entry}} \\ &= \frac{2^{36}}{2^9 \times 4} \because (\text{bits 21-29 gives 9 bits}) \\ &= \frac{2^{36}}{2^{11}} \\ &= 2^{25}\end{aligned}$$

So, we need 25 bits for addressing the second level page tables as well.

So, answer is (D).

Video Explanation for Multi-level Paging: <https://youtu.be/bArypfVmPb8>

(Edit:-

There is nothing to edit for such awesome explanation but just adding one of my comment if it is useful - [comment](#). However if anyone finds something to add (or correct) then feel free to do that in my comment.)

answered Nov 14, 2014 • edited Jul 13, 2018 by **kenzou**

[edit](#) [flag](#) [hide](#) [comment](#) Unfollow

Pip Box [Delete with Reason](#) Wrong Useful



# Systems

GO Classes

{ Page Size = 4KB  
Page table (single) Size = 4MB }

↳ we can store the page table into RAM  
but we need lot of contiguous space.

even if we have contiguous 4MB pages, is it worth saving the space of the page table?

↳ No, what if Page table contains too many invalid entries.



## Why Multi-level paging ?

- We may not find continuous space to store page table in main memory.

- We have seen most of the pages are empty.

Why to store entries corresponding to the pages which are empty ?



# Operating Systems

But where are the savings ?

It seems we have added one more page table and not saving any space.

Where are savings that we promised earlier ?





The red area corresponds to (most of) the unused portion of the virtual address space. Red PTEs are marked as having no frame so cause a page fault if referenced. OS takes appropriate action (extend stack or data, create a new 2nd level page table).

*this part  
of page table  
is not stored  
anywhere*



The red area corresponds to (most of) the unused portion of the virtual address space. Red PTEs are marked as having no frame so cause a page fault if referenced. OS takes appropriate action (extend stack or data, create a new 2nd level page table).



## Problem 1

In a 32-bit machine we subdivide the virtual address into 4 segments as follows:



We use a 3-level page table, such that the first 10-bit are for the first level and so on.

1. What is the page size in such a system?
2. What is the size of a page table for a process that has 256K of memory starting at address 0?
3. What is the size of a page table for a process that has a code segment of 48K starting at address 0x1000000, a data segment of 600K starting at address 0x80000000 and a stack segment of 64K starting at address 0xf0000000 and growing upward (like in the PA-RISC of HP)?



## Problem 1

In a 32-bit machine we subdivide the virtual address into 4 segments as follows:



We use a 3-level page table, such that the first 10-bit are for the first level and so on.

1. What is the page size in such a system?
2. What is the size of a page table for a process that has 256K of memory starting at address 0?





## Solution:

1. The page field is 8-bit wide, then the page size is 256 bytes.
2. Using the subdivision above, the first level page table points to 1024 2nd level page tables, each pointing to 256 3rd page tables, each containing 64 pages. The program's address space consists of 1024 pages, thus we need we need 16 third-level page tables. Therefore we need 16 entries in a 2nd level page table, and one entry in the first level page table. Therefore the size is: 1024 entries for the first table, 256 entries for the 2nd level page table, and 16 3rd level page table containing 64 entries each. Assuming 2 bytes per entry, the space required is  $1024 * 2 + 256 * 2 + 16 * 64 * 2 = 4608$  bytes.
3. First, the stack, data and code segments are at addresses that require having 3 page tables entries active in the first level page table. For 64K, you need 256 pages, or 4 third-level page tables. For 600K, you need 2400 pages, or 38 third-level page tables and for 48K you need 192 pages or 3 third-level page tables. Assuming 2 bytes per entry, the space required is  $1024 * 2 + 256 * 3 * 2 + 64 * (38+4+3) * 2 = 9344$  bytes.



26



Consider a three-level page table to translate a 39-bit virtual address to a physical address as shown below:



The page size is 4 KB ( $1\text{KB} = 2^{10}$  bytes) and page table entry size at every level is 8 bytes. A process  $P$  is currently using 2GB ( $1\text{GB} = 2^{30}$  bytes) virtual memory which is mapped to 2GB of physical memory. The minimum amount of memory required for the page table of  $P$  across all levels is \_\_\_\_\_ KB.



# Operating Systems

Answer: 4108





## GATE CSE 2003 | Question: 79

asked in Operating System Apr 24, 2016 • edited Jun 23, 2018 by Pooja Khatri

17,893 views

69 A processor uses 2-level page tables for virtual to physical address translation. Page tables for both levels are stored in the main memory. Virtual and physical addresses are both 32 bits wide. The memory is byte addressable. For virtual to physical address translation, the 10 most significant bits of the virtual address are used as index into the first level page table while the next 10 bits are used as index into the second level page table. The 12 least significant bits of the virtual address are used as offset within the page. Assume that the page table entries in both levels of page tables are 4 bytes wide.

Suppose a process has only the following pages in its virtual address space: two contiguous code pages starting at virtual address  $0x00000000$ , two contiguous data pages starting at virtual address  $0x00400000$ , and a stack page starting at virtual address  $0xFFFFF000$ . The amount of memory required for storing the page tables of this process is

- A. 8 KB
- B. 12 KB
- C. 16 KB
- D. 20 KB

Suppose a process has only the following pages in its virtual address space: two contiguous code pages starting at virtual address  $0x00000000$ , two contiguous data pages starting at virtual address  $0x00400000$ , and a stack page starting at virtual address  $0xFFFFF000$ . The amount of memory required for storing the page tables of this process is



- A. 8 KB
- B. 12 KB
- C. 16 KB
- D. 20 KB

Code : 3 0x00000000,

Date : 3 0x00400000,  
0xFFFFF000

Stack : 1

1 chunk

5 entries

- A. 8 KB
- B. 12 KB
- C. 16 KB
- D. 20 KB

code : 3  
 data : 3  
 stack : 1

0x00000000,  $\Rightarrow 0$   
 0x00400000,  $\Rightarrow 1$   
 0xFFFFF000  $\Rightarrow 2^{16} - 1$   
 $= 65535$

ENTRY numbers  
 of outermost page  
 table



- A. 8 KB
- B. 12 KB
- C. 16 KB
- D. 20 KB

Code : 2 {  
  0x00000000,

⇒ 0

ENTRY numbers

data : 2

of outermost page  
table

Stack : 1

0x00400000

⇒ 1

0xFFFFF000

⇒  $2^{10} - 1$

0x 0000 0000 offset

Address of 2nd page (or page 1) : - 0x 0000 1 000

0x 0000 0000 offset

Page No = 0









10|10|12





outermost

~~~

we only need to  
store 3 chunks here.

==





89



First level page table is addressed using 10 bits and hence contains  $2^{10}$  entries. Each entry is 4 bytes and hence this table requires 4 KB. Now, the process uses only 3 unique entries from this 1024 possible entries (two code pages starting from 0x00000000 and two data pages starting from 0x00400000 have same first 10 bits). Hence, there are only 3 second level page tables. Each of these second level page tables are also addressed using 10 bits and hence of size 4 KB. So,



Best answer

$$\begin{aligned} \text{total page table size of the process} \\ = 4 \text{ KB} + 3 * 4 \text{ KB} \\ = 16 \text{ KB} \end{aligned}$$

Correct Answer: C

answered Apr 29, 2016 • edited May 22, 2019 by Naveen Kumar 3

edit flag hide comment Unfollow Pip Box

Delete with Reason Wrong Useful

share this



Arjun



# Operating Systems

Virtual  
Memory





# Operating Systems

Virtual  
Memory



Virtual  
Memory



divide  
into pages

# Operating Systems





this is called “internal fragmentation”  
(within the page there is nothing)



- Advantages

- No external fragmentation
- Fast to allocate (no searching for space) and free (no coalescing) *compacting*

- Disadvantages

- Additional memory reference to page table (hint: use a cache)
- Internal fragmentation (tension regarding page size)
- Required space for page table may be substantial *(use multilevel paging)*

<https://hexhive.epfl.ch/OSTEP-slides/14-paging.pdf>



# G GO CLASSES

## Hashed Page Table:

↳ used as an alternative to multi level paging (reducing the size of page table)

The idea is to reduce the size of page table but without using multilevel paging.

## Why are page tables so large?

**Answer** Page tables are full of invalid PTEs



| PFN                           | valid | prot |
|-------------------------------|-------|------|
| 8                             | 1     | r-x  |
| 3                             | 1     | r-x  |
| 18                            | 1     | r-x  |
| -                             | 0     | -    |
| 0                             | 1     | rw-  |
| 12                            | 1     | rw-  |
| -                             | 0     | -    |
| -                             | 0     | -    |
| <i>many more invalid PTEs</i> |       |      |
| -                             | 0     | -    |
| -                             | 0     | -    |
| 24                            | 1     | rw   |



**Question** How to avoid storing invalid PTE?

Store only valid PTEs

|    |
|----|
| 10 |
| 2  |
| 9  |
| X  |
| X  |
| 9  |
| 1  |

Page table (Suppose only 5 valid)

frame No's



|    |
|----|
| 10 |
| 2  |
| 9  |
| 9  |
| 1  |

5 entries  
only



| Page No. | frame No. |
|----------|-----------|
| 0        | 10        |
| 1        | 2         |
| 2        | 9         |
| 1022     | 9         |
| 1023     | 1         |

GO  
CLASSES

Soln is  
hasing

it will take  
lot of time to search





- Need collision resolution
  - One possible solution is to use a chain table



Many collisions means we have to traverse a long linked list

hash value being the virtual page number.



Figure 8.19 Hashed page table.

### 8.6.2 Hashed Page Tables

A common approach for handling address spaces larger than 32 bits is to use a **hashed page table**, with the hash value being the virtual page number. Each entry in the hash table contains a linked list of elements that hash to the same location (to handle collisions). Each element consists of three fields: (1) the virtual page number, (2) the value of the mapped page frame, and (3) a pointer to the next element in the linked list.

The algorithm works as follows: The virtual page number in the virtual address is hashed into the hash table. The virtual page number is compared with field 1 in the first element in the linked list. If there is a match, the corresponding page frame (field 2) is used to form the desired physical address. If there is no match, subsequent entries in the linked list are searched for a matching virtual page number. This scheme is shown in Figure 8.19.

Page table size is too big

used by almost all systems

→ multi level paging

→ Hashed page table

→ inverted page table

Now



# Inverted Page Table:



# Operating Systems

## Inverted Page Table:

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

Page Table for P1

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

Page Table for P2

*frame no.*

*pid Page no.*

| pid | Page no. |
|-----|----------|
| 0   | 1        |
| 1   | 2        |
| 2   | 0        |
| 3   | 1        |
| 4   | 0        |
| 5   | 2        |

Inverted Page Table

→ One GLOBAL  
page table for  
ALL Processes

for every frame there is  
a row.  
hence Size of inverted page table =  
No. of frames  $\times$  Inverted page table  
entry

# Operating Systems

So many virtual pages...





# Operating Systems

So many virtual pages...



... comparatively few physical frames

# Inverted Page Tables





Question: True/False

**Problem 1a[2pts]:** The size of an inverted page table grows with the size of the virtual address space that it is supporting.



CLASSES

[https://hkn.eecs.berkeley.edu/examfiles/cs162\\_fa10\\_mt1\\_sol.pdf](https://hkn.eecs.berkeley.edu/examfiles/cs162_fa10_mt1_sol.pdf)



# Operating Systems

**Problem 1a[2pts]:** The size of an inverted page table grows with the size of the virtual address space that it is supporting.

True / **False**

**Explain:** *Since an inverted page table holds a hash on entries, it only needs to grow with the size of the physical address space. Entries not found in the inverted page table can be assumed to be invalid.*





# Operating Systems

## Question:

### 1. [20 points] Memory Management/Design:

A. [10 points] Assume a machine has a 16-bit virtual address space and is byte-addressable. The physical memory is 8K bytes ( $2^{13}$ ) and the page/frame size is 256 bytes ( $2^8$ ). Give the best answer to each of the following with a short justification. If you need to make additional assumptions to give an answer, state the assumptions that you are making [*Note: if the answer is a power of 2, leave it in exponential form.*]

a. [0.5pt] How many bits are used for the page offset? \_\_\_\_\_

b. [0.5pt] How many bits of virtual address are used for page number? \_\_\_\_\_

B. [10 points] For the previous problem (1.A), suppose you want to use an **inverted page table**:

a. [5pt] determine the size of the **inverted page table** (show/explain the number/meaning of bits)

b. [5pt] Explain why (or why not) you would use the **inverted page table** in this system instead of the **conventional page table** given in 1.A.



# Operating Systems

## 1. [20 points] Memory Management/Design:

A. [10 points] Assume a machine has a 16-bit virtual address space and is byte-addressable. The physical memory is 8K bytes ( $2^{13}$ ) and the page/frame size is 256 bytes ( $2^8$ ). Give the best answer to each of the following with a short justification. If you need to make additional assumptions to give an answer, state the assumptions that you are making [Note: if the answer is a power of 2, leave it in exponential form.]

a. [0.5pt] How many bits are used for the page offset? \_\_\_\_\_ 8 bits \_\_\_\_\_

b. [0.5pt] How many bits of virtual address are used for page number? \_\_\_\_\_ 8 bits \_\_\_\_\_

B. [10 points] For the previous problem (1.A), suppose you want to use an **inverted page table**:

a. [5pt] determine the size of the **inverted page table** (show/explain the number/meaning of bits)

a. Inverted page table will have  $2^5 = 32$  entries \* 4 bytes( 2bytes for pid + 8 bits for p + 8 bits for control e.g., i/v )

=  $2^7 = 128$  Bytes while conventional table size was  $2^8= 256$  Bytes for each process

b. [5pt] Explain why (or why not) you would use the **inverted page table** in this system instead of the **conventional page table** given in 1.A.

b. both are OK as long as you explain why! For example, I would prefer inverted as it significantly uses less memory! Unfortunately it requires searching through the array but since it is a small size array, this search should be done quickly.

Conventional (1 page table per process) is OK as it is faster than inverted table but requires more memory when the number of process increases ...



## Question:

17. Consider a computer system with a 32-bit logical address and 4 KB page size. The system supports up to 512 MB of physical memory. How many entries are there in:
- A conventional single-level page table?
  - An inverted page table?

CLASSES

H.W.



## Solution

17. Consider a computer system with a 32-bit logical address and 4 KB page size. The system supports up to 512 MB of physical memory. How many entries are there in:
- A conventional single-level page table?
  - An inverted page table?

**Answer:** a. 4kb page size – 12 bits. Therefore, 20 bits for page table. Page table contains  $2^{20}$  entries.

b. 512 MB of physical memory requires 29 bits. Frame size = page size = 4kb. So, page offset is still 12 bits. So, number of physical frames =  $2^{29-12} = 2^{17}$ .

<http://ittc.ku.edu/~kulkarni/teaching/EECS678/F19-prep-final-solution.pdf>



## Question:

Assume we make a single memory access on a processor which has no caches and no TLB. All else being equal, which of the following are true?

- Base-and-bound will on average be faster than a single-level page table.
- An inverted page table will on average be faster than a single-level page table.
- A single-level page table will on average be faster than a multi-level page table.
- A multi-level page table will on average be faster than an inverted page table.
- None of the above.

<https://cs162.org/static/exams/sp21-mt2-solutions.pdf>



## Question:

Assume we make a single memory access on a processor which has no caches and no TLB. All else being equal, which of the following are true?

- Base-and-bound will on average be faster than a single-level page table.
- An inverted page table will on average be faster than a single-level page table.
- A single-level page table will on average be faster than a multi-level page table.
- A multi-level page table will on average be faster than an inverted page table.
- None of the above.

one extra  
memory access

<https://cs162.org/static/exams/sp21-mt2-solutions.pdf>



Assume we make a single memory access on a processor which has no caches and no TLB. All else being equal, which of the following are true?

- Base-and-bound will on average be faster than a single-level page table.
- An inverted page table will on average be faster than a single-level page table.
- A single-level page table will on average be faster than a multi-level page table.
- A multi-level page table will on average be faster than an inverted page table.
- None of the above.

To translate the virtual address to a physical address, base-and-bound would require 0 memory accesses (only arithmetic operations), a single-level page table and an inverted page table would both require 1 memory access (to access the page table), and a multi-level page table would require multiple memory accesses, depending on the number of page tables to traverse.

Searching  
is also  
required



## Inverted Page Table

- One global page table
  - One page table entry per **physical** page.
  - Entries keyed by PID and virtual page number.
  - Physical frame number = index in page table.
- Advantages
  - Bounded amount of memory for page table(s).
    - 32-bit address space, 4K pages, 4GB RAM, 4B per PTE
    - 1-level page table: \_\_\_\_\_ x # processes.
    - Inverted Table: \_\_\_\_\_ MB
- Disadvantages
  - Costly translation
    - Using hashing can help

→ Hashed Inverted page table



# What's done in practice



- Some systems have used inverted page tables (e.g., IBM RS/6000, PowerPC), but hierarchical page tables seem to dominate at this point

[http://courses.ics.hawaii.edu/ReviewICS332/morea/090\\_VirtualMemory/ics332\\_virtualmemory1.pdf](http://courses.ics.hawaii.edu/ReviewICS332/morea/090_VirtualMemory/ics332_virtualmemory1.pdf)



# Inverted Page Table: Discussion

Tradeoffs:

- ↓ memory to store page tables
- ↑ time to search page tables

Solution: hashing → hashed inverted page table

- $\text{hash}(\text{page}, \text{pid}) \rightarrow \text{PT entry (or chain of entries)}$



## GATE CSE 2022 | Question: 28



Which one of the following statements is FALSE?

14



- A. The TLB performs an associative search in parallel on all its valid entries using page number of incoming virtual address.
- B. If the virtual address of a word given by CPU has a TLB hit, but the subsequent search for the word results in a cache miss, then the word will always be present in the main memory.
- C. The memory access time using a given inverted page table is always same for all incoming virtual addresses.
- D. In a system that uses hashed page tables, if two distinct virtual addresses V1 and V2 map to the same value while hashing, then the memory access time of these addresses will not be the same.

gatecse-2022

operating-system

memory-management

translation-lookaside-buffer

2-marks

<https://gateoverflow.in/371908/gate-cse-2022-question-28>



## GATE CSE 2022 | Question: 28



14

*false*

- Which one of the following statements is FALSE?
- C. The memory access time using a given inverted page table is always same for all incoming virtual addresses.
  - D. In a system that uses hashed page tables, if two distinct virtual addresses V1 and V2 map to the same value while hashing, then the memory access time of these addresses will not be the same.

gatecse-2022

operating-system

memory-management

translation-lookaside-buffer

2-marks

<https://gateoverflow.in/371908/gate-cse-2022-question-28>