



















# Q3: Which block replaced on a miss? °Easy for Direct Mapped

## °Set Associative or Fully Associative:

- Random
- LRU (Least Recently Used)

| • LRU (Least Recently Used)       |             |       |       |       |       |                       |
|-----------------------------------|-------------|-------|-------|-------|-------|-----------------------|
| Miss Rates<br>Associativity:2-way |             |       | 4-way |       | 8-way |                       |
| Size                              | LRU         | Ran   | LRU   | Ran   | LRU   | Ran                   |
| 16 KB                             | 5.2%        | 5.7%  | 4.7%  | 5.3%  | 4.4%  | 5.0%                  |
| 64 KB                             | 1.9%        | 2.0%  | 1.5%  | 1.7%  | 1.4%  | 1.5%                  |
| 250 KB                            | 1.15%       | 1.17% | 1.13% | 1.13% | 1.12% | 1.12%                 |
| CS61C L37                         | VM III (15) |       |       |       | G     | arcia, Fall 2004 © UC |

# Q4: What to do on a write hit? \* Write-through • update the word in cache block and corresponding word in memory \* Write-back

- · update word in cache block
- · allow memory word to be "stale"
- => add 'dirty' bit to each line indicating that memory be updated when block is replaced
- => OS flushes cache before I/O !!!

# ° Performance trade-offs?

· WT: read misses cannot result in writes





#### Three Advantages of Virtual Memory

#### 1) Translation:

- Program can be given consistent view of memory, even though physical memory is scrambled
- · Makes multiple processes reasonable
- Only the most important part of program ("Working Set") must be in physical memory
- Contiguous structures (like stacks) use only as much physical memory as necessary yet still grow later





#### Three Advantages of Virtual Memory

## 2) Protection:

- Different processes protected from each other
- Different pages can be given special behavior
   (Read Only, Invisible to user programs, etc).
- · Kernel data protected from User programs
- Very important for protection from malicious programs ⇒ Far more "viruses" under Microsoft Windows
- Special Mode in processor ("Kernel more") allows processor to change page table/TLB

#### 3) Sharing:

• Can map same physical page to multiple users ("Shared memory")





# Why Translation Lookaside Buffer (TLB)?

- Paging is most popular implementation of virtual memory (vs. base/bounds)
- Every paged virtual memory access must be checked against Entry of Page Table in memory to provide protection
- ° Cache of Page Table Entries (TLB) makes address translation possible without memory access in common case to make fast





#### **Bonus slide: Virtual Memory Overview (1/4)**

- °User program view of memory:
  - · Contiguous
  - · Start from some set address
  - · Infinitely large
  - · Is the only running program
- ° Reality:
  - · Non-contiguous
  - · Start wherever available memory is
  - · Finite size
  - · Many programs running at a time



#### **Bonus slide: Virtual Memory Overview (2/4)**

- ° Virtual memory provides:
  - · illusion of contiguous memory
  - · all programs starting at same set address
  - · illusion of ~ infinite memory (232 or 264 bytes)
  - protection





# **Bonus slide: Virtual Memory Overview (3/4)**

- ° Implementation:
  - Divide memory into "chunks" (pages)
  - Operating system controls page table that maps virtual addresses into physical addresses
  - ·Think of memory as a cache for disk
  - ·TLB is a cache for the page table





## **Bonus slide: Virtual Memory Overview (4/4)**

- °Let's say we're fetching some data:
  - · Check TLB (input: VPN, output: PPN)
    - hit: fetch translation
    - miss: check page table (in memory)
      - Page table hit: fetch translation
      - Page table miss: page fault, fetch page from disk to memory, return translation
  - · Check cache (input: PPN, output: data)
    - hit: return value
    - miss: fetch value from memory







#### And in Conclusion...

- °Virtual memory to Physical Memory Translation too slow?
  - · Add a cache of Virtual to Physical Address Translations, called a TLB
- °Spatial Locality means Working Set of Pages is all that must be in memory for process to run fairly well
- ° Virtual Memory allows protected sharing of memory between processes with less swapping to disk





# **Address Map, Mathematically**

V = {0, 1, ..., n - 1} virtual address space (n > m)
M = {0, 1, ..., m - 1} physical address space
MAP: V --> M U {θ} address mapping function

MAP(a) = a' if data at virtual address a is present in physical address a and a in M = 0 if data at virtual address a is not present in M

