

Each stored row of the page table is called a **page table entry**. There are 2<sup>VPN bits</sup> such entries in a page table. Say you have a VPN of 5 and you want to use the page table to find what physical page it maps to; you'll check the 5th (0-indexed) page table entry. If the valid bit is 1, then that means that the entry is valid (in other words, the physical page corresponding to that virtual page is in main memory as opposed to being only on disk) and therefore you can get the PPN from the entry and access that physical page in main memory. The page table is stored in memory: the OS sets a register (the Page Table Base Register) telling the hardware the address of the first entry of the page table. If you write to a page in memory, the processor updates the "dirty" bit in the page table entry corresponding to that page, which lets the OS know that updating that page on disk is necessary (remember: main memory contains a subset of what's on disk). This is a similar concept as

A lot of this is done by hardware that the 05. This is up to the ISA of the larguage of the machine.

## 2 Virtual Memory

having a dirty bit for each cache block in a write-back cache, which we covered in lecture and in Lab 9. Each process gets its own illusion of full memory to work with, and therefore its own page table.

**Protection Fault** The page table entry for a virtual page has permission bits that prohibit the requested operation. This is how a segmentation fault occurs.

Page Fault The page table entry for a virtual page has its valid bit set to false. This means that the entry is not in memory, so we pull it from disk, add the page to memory (evicting another page if necessary), and add the mapping to

the page table and the TLB. — This is if it is not in DRAM. May be on dish.

If so, evict a page in DRAM + Allocate the spacer

Translation Lookaside Buffer Move the page from dish to DRAM. If not vald,

A cache for the page table. Each block is a single page table entry. If an entry is

not in the TLB, it's a TLB miss. Assuming fully associative:

| TLB Valid     | Tag (VPN) | Page Table Entry |                 |     |  |  |  |
|---------------|-----------|------------------|-----------------|-----|--|--|--|
|               |           | Page Dirty       | Permission Bits | PPN |  |  |  |
| — TLB entry — |           |                  |                 |     |  |  |  |
| — TLB entry — |           |                  |                 |     |  |  |  |



To access some memory location, we get the virtual page number (VPN) from the virtual address (VA) and first try to translate the VPN to a physical page number (PPN) using the translation lookaside buffer (TLB). If the TLB doesn't contain the desired VPN, we check if the page table contains it (remember: the TLB is a subset of the page table!). If the page table doesn't contain an entry for the VPN, then this is a page fault; memory doesn't contain the corresponding physical page! This means we need to fetch the physical page from disk and put it into memory, update the page table entry, and load the entry into the TLB, Then, we use the physical page and the offset of the physical address in the page to access memory as the program intended.

What are three specific benefits of using virtual memory?

( well really the following space) 1.1

• Illusion of infinite memory (bridges memory and disk in memory hierarchy).

• Simulates full address space for each process so that the linker/loader dont need to know about other programs.

tolation!

- Enforces protection between processes and even within a process (e.g. read-only pages set up by the OS).
- What should happen to the TLB when a new value is loaded into the page table address register?

The valid bits of the TLB should all be set to 0. The page table entries in the TLB corresponded to the old process/page table, so none of them are valid once the page table address register points to a different page table

A processor has 16-bit addresses, 256 byte pages, and an 8-entry fully associative TLB with LRU replacement (the LRU field is 3 bits and encodes the order in which pages were accessed, 0 being the most recent). At some time instant, the TLB for the current process is the initial state given in the table below. Assume that all current page table entries are in the initial TLB. Assume also that all pages can be read from and written to. Fill in the final state of the TLB according to the access pattern below.

Question: How many bits does the TLB need to Store?

Answer: UPN+PPN+Valid+dirty+LRV 8+8+1+1+3=21

> Perties ro log\_ (8) bits necold

4 Virtual Memory (1)

Free Physical Pages 0 17, 0 8, 0 9

## Access Pattern

1. 0x11 f0 (**Read**)

4. 0x23/32 (Write)

2. 0x1301 (Write)

5. 0x20ff (**Read**)

3. 0x20ae (**Write**)

6. 0x3415 (**Write**)

## Initial TLB

|            | VPN              | PPN                | Valid | Dirty | LRU | <b>(</b> | 2 | 3 | (4) | <b>(5)</b> | <b>©</b> |
|------------|------------------|--------------------|-------|-------|-----|----------|---|---|-----|------------|----------|
| _          | 0x01             | 0x11               | 1     | 1     | 0   | 1        | 2 | 3 | 4   | 4          | ς        |
| (2)        | 0 x 13<br>0 x 00 | 0×17<br>0×00       | 150   | 150   | 7   | 7        | 0 | 1 | 2   | 2          | 3        |
| G          | 0x10             | 0x13               | 1     | 1     | 1   | 2        | 3 | 4 | 5   | 5          | 6        |
| (5)(3)     | 0x20             | 0x12               | 1     | امو   | 5   | 5        | 6 | 0 | 1   | 0          | ١        |
| (4)        | 0x23             | 0×90               | A71   | اص    | 7   | 7        | 7 | 7 | 0   | l          | 2        |
| <u>(1)</u> | 0x11             | 0x14               | 1     | 0     | 4   | 0        | ſ | 2 | 3   | 3          | 4        |
| V          | 0xac             | 0x15               | 1     | 1     | 2   | 3        | 4 | 5 | b   | 6          | 7        |
| (6)        | ох34<br>Oxff     | 0 x 1 9<br>0 x f f | 1     | 871   | 3   | 4        | 5 | ( | 7   | 7          | 0        |

## Final TLB

| VPN                | PPN          | Valid | Dirty | LRU |
|--------------------|--------------|-------|-------|-----|
| 0x01               | 0x11         | 1     | 1     | 5   |
| 0x13               | 0x17         | 1     | 1     | 3   |
| 0x10               | 0x13         | 1     | 1     | 6   |
| 0x20               | 0x12         | 1     | 1     | 1   |
| 0x23               | 0x18         | 1     | 1     | 2   |
| 0x11               | 0x14         | 1     | 0     | 4   |
| 0xac               | 0x15         | 1     | 1     | 7   |
| 0×34<br>λη / \ / β | 0x19<br>.√ ) | 1     | 1     | 0   |

on Miss, we use LRU Replacement to put the new page in.

Page = 256 = 28 so 1092 (28)=8 hit of tred

Address space size - Page Offset

16-8=86it tag

1) Determine Vadder tay ( UPN

1) Check TLB for VPN 1. 0x11 f0 (Read): hit, LRUs: 1, 7, 2, 5, 7, 0, 3, 4

because that is a tree physical Page

7) If exist check valid 2. 0x13/01 (Write): miss, map VPN 0x13 to PPN 0x17, valid and dirty, the dirty by it was a water larger a 7 and larger a 1 and large

Loal new page

3. 0x20ae (Write): hit, dirty, LRUs: 3, 1, 4, 0, 7, 2, 5, 6

T) Translate Vaddr (Virtual Bage Number) to

4. 0x23/32 (Write): miss, map VPN 0x23 to PPN 0x18, valid and dirty,
LRUs: 4, 2, 5, 1, 0, 3, 6, 7

Product ( Physical ruge 5. 0x20 ff (Read): hit, LRUs: 4, 2, 5, 0, 1, 3, 6, 7

6. 0x3415 (Write): miss and replace last entry, map VPN 0x34 to 0x19, dirty, LRUs, 5, 3, 6, 1, 2, 4, 7, 0

since LRU is not dirty, we do not need to write the Page back to dist.

TLB full so evict+write to mem the LRV

notinTLB+