## Homework 7

Chinese Name: 杨人一

Pinyin Name: Yang Renyi

Student ID: <u>2023533030</u>

E-Mail prefix: yangry2023

1. Put T (True) or F (False) for each of following statement. [2 points each]

- (a) (T) The virtual memory system, via page table-based address translation mechanisms, enables multiple processes to securely share identical physical memory regions (e.g., shared code libraries) while maintaining isolation.
- (b) (F) A page-table walker (PTW) handles and resolves page faults by loading missing pages into memory.
- (c) (F) The size of the virtual address space accessible to the program cannot be larger than the size of the physical address space.
- (d) (F) Multi-level page tables optimize memory usage by storing complete physical addresses at the leaf level, enabling direct memory access without translation overhead.
- (e) (F) When a page fault occurs, the operating system must evict a resident page before loading the requested page into memory.

## 24 2. TLB [24 points]

The system uses a 32-bit virtual address space with byte-addressable memory and 30-bit physical addresses, employing a single-level page table with 4KB pages and a 4-way set-associative TLB (total 16 entries, LRU replacement policy).

(a) Answer the following questions. Specify bit ranges as [high:low] with zero-based indexing (bit 0 = LSB). [8 points]

The range of bits for the VPN (virtual page number) [31:12]

The range of bits for the offset within a page [11:0]

The range of bits for the TLB tag [31:14]

The range of bits for the TLB set number [13:12] .

(b) Assume the TLB is initially empty, and the accessed VPNs are 4, 17, 20, 8, 21, 5, 17, 25, 29 in sequence. Complete Final TLB State (Table 1). [4 points]

Table 1: Final TLB State

| Index | VPN        |  |  |
|-------|------------|--|--|
| 0     | 4 20 8     |  |  |
| 1     | 17 29 5 25 |  |  |
| 2     |            |  |  |
| 3     |            |  |  |

- (c) Based on part (b), subsequent accesses to VPNs are 12, 24, 21, 5, 4, 8, 17, 12, 29. [12 points]
  - For Table 2:
    - Mark TLB-hit VPNs with ✓
    - Mark VPNs that evict others with ()
    - Mark VPNs that are evicted with ×
    - If a newly annotated element has causal relationship with an existing element, both should be marked (e.g., when element A replaces element B, then A is marked with and B is marked with ×). Otherwise, only the current access is annotated.
  - Complete Final TLB State (Table 3)

Table 2: Access Sequence Change

| VPN | Marks | VPN | Marks | VPN | Marks |
|-----|-------|-----|-------|-----|-------|
| 4   | ×     | 17  | ✓×    | 5   | 0     |
| 17  |       | 25  | ×     | 4   | 0     |
| 20  | ×     | 29  | 0     | 8   | ✓     |
| 8   |       | 12  |       | 17  | 0     |
| 21  | ×     | 24  | 0     | 12  | ✓     |
| 5   | ×     | 21  | 0     | 29  | ✓     |

Table 3: Final TLB State

| Index | VPN        |  |  |
|-------|------------|--|--|
| 0     | 24 4 8 12  |  |  |
| 1     | 5 29 21 17 |  |  |
| 2     |            |  |  |
| 3     |            |  |  |

12 3. Multi-level Page Tables [12 points]

The system employs a 48-bit virtual address space with byte-addressable memory, using 4KB pages and 32-bit page table entries (PTEs) where 8 bits are reserved for protection and valid flags. The address translation uses a three-level page table hierarchy. Each of the three page table index fields is 10 bits.

- (a) Given the virtual address 0x3456789ABC. Suppose the contents of the page table entries of the three-level page table are as follows:
  - The base address of the first-level page table is 0x1000.
  - The base address of the second-level page table is 0x2000.
  - The base address of the third-level page table is 0x3000, and the PTE with index 3 points to the Physical Page Frame (PPN) 0x4000. [4 points]

Final physical address: <u>0x4000ABC</u>.

(b) Calculate the total size of all second-level page tables. [4 points]

Each second-level page table has 2<sup>10</sup> entries, and each entry is 8 bytes. Therefore, the size of each second-level page table is:

$$2^{10}$$
 entries  $\times$  4 bytes/entry = 4 KB

Since there are  $2^{10}$  second-level page tables, the total size is:

$$2^{10}$$
 tables  $\times$  4 KB/table = 4 MB

(c) Consider an x86-64 system with 64-bit virtual addressing (48-bit usable), 4KB page tables, and 8-byte PTEs, supporting both 4KB pages (4-level: PML4→PDPT→PD→PT) and 2MB huge pages (3-level, no PT). When using 2MB huge pages for application data, how is the virtual address partitioned? Specify bit allocations for PML4, PDPT, PD indices and page offset as [high:low] ranges using zero-based indexing. [4 points]

$$(48 - 21)/3 = 9$$

- PML4 index: [47:39] (9 bits)
- PDPT index: [38:30] (9 bits)
- PD index: [29:21] (9 bits)
- Page offset: [20:0]  $(2^{21} = 2MB)$

4. Page Faults [28 points]

The system implements a single-level page table for 32-bit virtual addresses in byte-addressable memory, using 4KB pages with 32-bit page table entries (PTEs) that reserve 8 bits for protection and valid flags. Given the program segment:

```
int w[24][64];

int w[24][64];

for ( i=0; i<24; i++ )

for ( j=0; j<64; j++ ) w[i][j]=10;</pre>
```

Assume the array w[24][64] (row-major order, starting at 0x392E00, 4-byte integers) is initially not present in main memory, with no page replacement during execution.

(a) After execution: [12 points]

- The array spans 3 pages in the virtual address space.
- The number of page faults triggered is 3
- Fault addresses (page base address): 0x392000, 0x39300, 0x394000
- (b) If the page size is 128 bytes, and the array is stored in column-major order, after execution: [8 points]
  - The number of page faults triggered is 48
- (c) Assume page size is 16KB with two-level page table. What is the maximum size of the physical memory that can be supported by this computer? [8 points]

  The page table entry (PTE) is 32 bits. The maximum number of PPN is  $2^{32-8} = 2^{24}$ , and each PTE can map to a physical frame of size  $2^{14}$  bytes. Therefore, the maximum physical memory size is:

$$2^{24} \times 2^{14} = 2^{38}$$
 bytes = 256 GB.

## 5. Page Table Walk [26 points]

The system employs a 32-bit virtual address space with a three-level page table (2 bits per level for indexing), using 16B pages and 32-bit PTEs.

## Assume:

- Page table base register: Set to 0
- Free PPNs list (allocated in order): 0x3, 0x9, 0x12, 0x19
- Partial Memory Content: Table 4 shows a snapshot of physical memory. Column Cont. (PA) indicates that the content stored at this location is a physical address (page base address).

| PA   | Cont. (PA) |
|------|------------|------|------------|------|------------|------|------------|
| 0x00 | 0x10       | 0x28 | 0x70       | 0x50 |            | 0x78 |            |
| 0x04 | 0x20       | 0x2C | 0x110      | 0x54 |            | 0x7C |            |
| 0x08 |            | 0x30 |            | 0x58 | 0x160      | 0x80 | 0x200      |
| 0x0C |            | 0x34 |            | 0x5C |            | 0x84 | 0x240      |
| 0x10 | 0x40       | 0x38 |            | 0x60 | 0x130      | 0x88 |            |
| 0x14 |            | 0x3C |            | 0x64 | 0x150      | 0x8C | 0x260      |
| 0x18 |            | 0x40 |            | 0x68 | 0x170      | 0x90 |            |
| 0x1C |            | 0x44 |            | 0x6C |            | 0x94 |            |
| 0x20 |            | 0x48 | 0x120      | 0x70 | 0x140      | 0x98 |            |
| 0x24 | 0x50       | 0x4C |            | 0x74 |            | 0x9C |            |

Table 4: Partial Memory Content

22

(a) Based on the content of Partial Memory Content (Table 4), for Process A's virtual address access sequence 0x162 and 0x324, answer the following questions. All numerical answers should be in hexadecimal format, the leading zeros are optional, and all values must represent the final state of the system. [22 points]

Virtual Address 0x162:

For virtual address 0x162:  $VPN = \underline{0x16}$ , Page Offset  $= \underline{0x2}$ .

Using a three-level page table with two index bits per level:

The Level 1 index is  $\underline{0x1}$ , the Level 2 index is  $\underline{0x1}$ , and the Level 3 index is  $\underline{0x2}$ .

The initial value of the Page Table Base Register is 0x0.

First, in the Level 1 page table, the corresponding entry is  $PA = \underline{0x04}$ , Cont. = 0x20. Thus, the Level 2 page table base address is 0x20.

| Next, in the Level 2 page table, the corresponding entry is $PA = \underline{0x24}$ , $Cont. = \underline{0x50}$ . Thus, the Level 3 page table base address is $\underline{0x50}$ .     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Finally, in the Level 3 page table, the corresponding entry is $PA = \underline{0x58}$ , $Cont. = \underline{0x160}$ . Thus, the target page frame base address is $\underline{0x160}$ . |
| Combining the page frame base address with the Page Offset, the final physical address is $0x162$ , resulting in a Page Hit.                                                             |
| Virtual Address 0x324:                                                                                                                                                                   |
| For virtual address $0x324$ : $VPN = \underline{0x32}$ , Page Offset $= \underline{0x4}$ .                                                                                               |
| Using a three-level page table with two index bits per level:                                                                                                                            |
| The Level 1 index is $0x3$ , the Level 2 index is $0x0$ , and the Level 3 index                                                                                                          |
| is <u>0x2</u> .                                                                                                                                                                          |
| The initial value of the Page Table Base Register is 0x0.                                                                                                                                |
| First, in the Level 1 page table, the corresponding entry is $PA = \underline{0x0C}$ , $Cont. =$                                                                                         |
| 0x30 . Thus, the Level 2 page table base address is $0x30$ .                                                                                                                             |
| Next, in the Level 2 page table, the corresponding entry is $PA = \underline{0x30}$ , $Cont. = \underline{0x90}$ . Thus, the Level 3 page table base address is $\underline{0x90}$ .     |
| Finally, in the Level 3 page table, the corresponding entry is $PA = \underline{0x98}$ , $Cont. =$                                                                                       |
| 0x120 . Thus, the target page frame base address is $0x120$ .                                                                                                                            |
| Combining the page frame base address with the Page Offset, the final physical address is <u>0x124</u> , resulting in a Page <u>Miss</u> (Hit/Miss).                                     |

(b) Calculating the size of the increase in the physical memory occupied by process A during the given sequence of virtual address accesses (counting only process-exclusive physical pages, excluding shared pages, kernel structures, and other unrelated components). [4 points]

4

Page Fault occurs for 3 times, and each page is 16B. Therefore, the increase in physical memory occupied by process A is 3 pages  $\times$  16B per page = 48B.