

## CS2106 Operating Systems

### Virtual Memory Management

1. [TLB + Paging + Virtual Paging] We have learnt the idea of paging, translation look aside buffers (TLBs) and virtual memory in the last two lectures. In this question, we are going to put them all in the same scenario and study the interaction.

Here is the basic setup. Note: To make the question easier to comprehend, the scale is vastly reduced compared to the real world counterparts.

- Page Size = Frame Size = 4KB
- TLB = 2 entries (0..1)
- Page Table = 8 entries (i.e. 8 pages, 0..7)
- Physical Frame = 8 frames (0..7)
- Swap Page (Virtual page in hard disk) = 16 pages (0..15)

Below is a snapshot of process P at time T:

**TLB** (should have the same fields as the PTE, not shown for simplicity):

| Page No. | Frame No. |
|----------|-----------|
| 3        | 7         |
| 0        | 4         |

**Page Table:**

| Page No | Frame No/<br>Swap Page No | Memory<br>Resident? | Valid? |
|---------|---------------------------|---------------------|--------|
| 0       | 4                         | 1                   | 1      |
| 1       | 1                         | 1                   | 1      |
| 2       | 1                         | 0                   | 1      |
| 3       | 7                         | 1                   | 1      |
| 4       | 2                         | 1                   | 1      |
| 5       | 15                        | 0                   | 1      |
| 6       | ---                       | 0                   | 0      |
| 7       | ---                       | 0                   | 0      |

Although the content / layout of the physical memory frames and hard disk swap pages can be deduced from the above, you are encouraged to sketch the RAM and hard disk content to aid understanding.

- a. Below is the skeleton of the access algorithm for this setup. Give the missing algorithm for the OS **TLB fault** and **page fault** handlers.

|                                                    |
|----------------------------------------------------|
| <b>Algorithm for accessing virtual address VA:</b> |
| 1. [HW] VA is decomposed into <Page#, Offset>      |
| 2. [HW] Search TLB for <Page#>:                    |

- |                                                                                                                                                                                                                                                                                                                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ol style="list-style-type: none"> <li>a. If TLB miss: Trap to OS { <b>TLB Fault</b> }</li> <li>3. [HW] Is &lt;Page#&gt; memory resident?           <ol style="list-style-type: none"> <li>a. Non-memory resident: Trap to OS { <b>Page Fault</b> }</li> </ol> </li> <li>4. [HW] Use &lt;Frame#&gt;&lt;Offset&gt; to access physical memory.</li> </ol> |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

b. Using (a), walkthrough the following access **in sequence**. For simplicity, only the page number is given. If TLB/ Page Replacement is needed, just pick the entry with the smallest page number.

- i. Access Page 3
- ii. Access Page 1
- iii. Access Page 5

(Optional) Think about how a dynamically allocated new page fit into this scheme.

c. If we have the following hardware specification:

- TLB access time = 1ns
- Memory access time = 30ns
- Hard disk access time (per page) = 5ms

Give the best and worst memory access scenarios and the respective memory access speed. For simplicity, you can give an approximate answers.

- d. If 2-Level paging is used, is there a worse scenario compared to (c)?
2. [Adapted from AY1920S2 Final – Page Table Structure] The Linux machines in the SoC cluster used in the labs have 64-bit processors, but the virtual addresses are 48-bit long (the highest 16 bits are not used). The physical frame size is 4KiB. The system uses a hierarchical direct page table structure, with each table/directory entry occupying 64 bits (8 bytes) regardless of the level in the hierarchy.

Assume Process *P* runs the following simple program on one of the lab machines:

|                                                                                                                                                                                                           |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre> 1. #include &lt;stdio.h&gt; 2. #include &lt;stdlib.h&gt;  3. #define ONE_GIG 1&lt;&lt;30 4. #define NUM_PAGES 1&lt;&lt; 18  5. void main() { 6.   char* array = malloc(ONE_GIG); 7.   int i; </pre> |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

```
8.   for (i=0; i<NUM_PAGES; i++)
      array[i<<12]='a';
9.   printf("0x%lx\n", array);
10.  // point of interest
11.  free(array);
12. }
```

At line 9, the program prints out the value of variable **array** in hexadecimal:

**0x7F9B55226010**

Consider the point in time when the process execution reaches the point of interest (line 10 in the listing). Answer the following questions:

- a. If we use a single-level page table, how much memory space is needed just to store the page table for process  $P$ ?
- b. How many levels are there in the page-table structure for process  $P$ ?
- c. How many **entries in the root page directory** are holding information related to process  $P$ 's **dynamically allocated data**?
- d. How many **physical frames** are holding information related to process  $P$ 's dynamically allocated data in the **second level** of the hierarchical page-table structure (next after the root)?
- e. How many **physical frames** are holding information related to process  $P$ 's dynamically allocated data in the **penultimate level** of the page-table structure (i.e., the level before the last one).
- f. How many **physical frames** are holding information related to process  $P$ 's dynamically allocated data in the **last level** of the page-table structure?

3. [Adapted from final exam AY2018/19 S1 – Page Replacement]

Below is a snapshot of the memory frames in RAM on a system with virtual memory. The memory pages in the frame is shown as <Process><Page#>, e.g. **B17** means Page **17** of Process **B**.



The OS maintains additional information shown on the right to perform **second chance** page replacement algorithm on the memory frames.

- Suppose **Process A access Page 8** (i.e. A08) now, answer the following:
  - Which **memory frame** will be replaced?
  - Give the steps OS takes to update the affected page table entries.
- Continuing from (a), if **Process B access Page 13** (i.e. B13) now, answer the following:
  - Which memory frame will be replaced?
  - If OS keeps an **inverted page table**, give the content of the inverted page table **after** the replacements (after a. and c.).
  - Give the steps OS takes to update the affected page table entries with the help of inverted page table.

### For your own practice

1. [Page Table Structure] Given the following information:

- Virtual Memory Address Space = 32 bits
- Physical memory = 512MB
- Page Size = 4 KB
- PTE Size = 4 bytes

Suppose there are 4 processes, each using 512MB virtual memory. Answer the following:

- Direct Paging is used. What is the total space needed for all page tables used?
- Two-levels paging is used. What is the total space needed for this scheme?
- Inverted table is used. What is the total space needed? You can assume each inverted table entry takes 8 bytes.