

### Virtual Memory

- Use main memory as a "cache" for secondary storage to
  - Allow efficient and safe sharing of memory among multiple programs
  - Provide the ability to easily run programs larger than the size of physical memory
  - Simplify loading a program for execution by providing for code relocation (i.e., the code can be loaded anywhere in main memory)
- What makes it work? again the Principle of Locality
  - A program is likely to access a relatively small portion of its address space during any period of time
- Each program is compiled into its own address space a virtual address space
  - During run-time each virtual address must be translated to a physical address (an address in main memory)

## Two Programs in Physical Memory

#### Board and Chalk Example!

- Picture of two programs in virtual space mapping to one physical memory
- page base address and offset within a page are required to get to an actual instruction
- The two programs share the physical space















|                       | Paged VM                     | TLBs        |
|-----------------------|------------------------------|-------------|
| Fotal size (blocks)   | 16,000 to 250,000            | 16 to 512   |
| Total size (KB)       | 250,000 to<br>1,000,000,000  | 0.25 to 16  |
| Block size (B)        | 4000 to<br>64,000            | 4 to 32     |
| Miss penalty (clocks) | 10,000,000 to<br>100,000,000 | 10 to 1000  |
| Miss rates            | 0.00001% to 0.0001%          | 0.01% to 2% |

|                  | Intel P4                                    | AMD Opteron                                                       |  |  |
|------------------|---------------------------------------------|-------------------------------------------------------------------|--|--|
| TLB organization | 1 TLB for instructions<br>and 1TLB for data | 2 TLBs for instructions and<br>2 TLBs for data                    |  |  |
|                  | Both 4-way set<br>associative               | Both L1 TLBs fully<br>associative with ~LRU                       |  |  |
|                  | Both use ~LRU                               | replacement                                                       |  |  |
|                  | replacement<br>Both have 128 entries        | Both L2 TLBs are 4-way set<br>associative with round-robin<br>LRU |  |  |
|                  |                                             | Both L1 TLBs have 40<br>entries                                   |  |  |
|                  |                                             | Both L2 TLBs have 512<br>entries                                  |  |  |
|                  | TLB misses handled in<br>hardware           | TBL misses handled in<br>hardware                                 |  |  |

| TLB  | Page<br>Table | Cache | Possible? Under what circumstances?                                        |
|------|---------------|-------|----------------------------------------------------------------------------|
| Hit  | Hit           | Hit   | Yes – what we want!                                                        |
| Hit  | Hit           | Miss  | Yes – although the page table is not<br>checked if the TLB hits            |
| Miss | Hit           | Hit   | Yes – TLB miss, PA in page table                                           |
| Miss | Hit           | Miss  | Yes – TLB miss, PA in page table, but data<br>not in cache                 |
| Miss | Miss          | Miss  | Yes – page fault                                                           |
| Hit  | Miss          | Miss  | Impossible – TLB translation not possible if<br>page not present in memory |
| Hit  | Miss          | Hit   | Impossible – TLB translation not possible if<br>page not present in memory |
| Miss | Miss          | Hit   | Impossible – data not allowed in cache if page is not in memory            |





#### The Hardware/Software Boundary

- What parts of the virtual to physical address translation is done by or assisted by the hardware?
  - Translation Lookaside Buffer (TLB) that caches the recent translations
    - TLB access time is part of the cache hit time
    - Can allot an extra stage in the pipeline for TLB access
  - Page table storage, fault detection and updating
    - Page faults result in interrupts (precise) that are then handled by the OS
      Hardware must support (i.e., update appropriately) Dirty and
    - Reference bits (e.g., ~LRU) in the Page Tables
  - Disk placement
    - Bootstrap (e.g., out of disk sector 0) so the system can service a limited number of page faults before the OS is even loaded

## Summary

The Principle of Locality:
Program likely to access a relatively small portion of the address space at any instant of time.
Temporal Locality: Locality in Time
Spatial Locality: Locality in Space
Caches, TLBs, Virtual Memory all understood by examining how they deal with the four questions: 1) Where can block be placed? 2) How is block found? 3) What block is replaced on miss? 4) How are writes handled?
Page tables map virtual address to physical address
TLBs are important for fast translation

# Reminders

- Next lecture
  - Quiz on chapter 7
  - Final review
- □ HW #6
  - On cache and memory (chapter 7)
  - Due on Friday 12/9 at 5pm
- Final exam schedule
  - Friday December 16th at 1:30pm
  - Office hours on Thursday 12/15 3-5pm