

With 4 KiB pages and byte addresses,  $2^{\text{page offset bits}} = 4096$ , so there are 12 page offset bits. Translate virtual addresses (VA) to physical addresses (PA) using the translation lookaside buffer (TLB) and page table. Then, use the physical address to access memory as the program intended.



Pages

A chunk of memory or disk with a set size. Addresses in the same virtual page map to addresses in the same physical page. The page table determines the mapping.

| Valid                   | Dirty | Permission Bits | PPN |
|-------------------------|-------|-----------------|-----|
| — Page entry (VPN: 0) — |       |                 |     |
| — Page entry (VPN: 1) — |       |                 |     |

Each stored row of the page table is called a **page table entry**. The page table is stored in memory: the OS sets a register telling the hardware the address of the first entry of the page table. The processor updates the "dirty" bit in the page table which lets the OS to know whether updating a page on disk is necessary. Each process gets its own page table.

Protection Fault The page table entry for a virtual page has permission bits that

Page Fault The page table entry for a virtual page has its valid bit set to false.

Not in PAM
The entry is not in memory.

## Translation Lookaside Buffer

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:





0xac

VPN PPN Valid Dirty LRU

Final TLB

