# CS184b: Computer Architecture (Abstractions and Optimizations)

Day 13: April 29, 2005 Virtual Memory and Caching

CS184 Spring2005













### **Opportunity 1:**

• Instructions touched < Total Instructions

7

9

- Data touched
  - not uniformly accessed
  - working set < total data
  - locality
    - temporal
    - spatial

ltech CS184 Spring2005 -- DeHon



 don't want other programs to be able to see your data

8

Problem 2:
If share same address space

where program is loaded (puts its data) depends on other programs (running? Loaded?) on the system

Want abstraction

every program sees same machine

 every program sees same machine abstraction independent of other running programs
 CS184 Spring2005 - DeHon



- Support large address space
- Use cheaper/larger media to hold complete data
- Manage physical memory "like a cache"
- Translate large address space to smaller physical memory
- Once do translation

   translate multiple address spaces onto real memory

- use translation to define/limit what can touch

















4



h CS184 Spring2005 -- DeHon

20

22



[Hennessy and Patterson 5.43e2/(5.36e3, close)] 21

TLB



ch CS184 Spring2005 -- DeHor











ch CS184 Spring2005 -- DeHor

















### Physically Mapped Cache

- Must translate address before can check tags
  - TLB translation can occur in parallel with cache read
  - (if direct mapped part is within page offset) - contender for critical path?
- No need to flush between tasks
- Shared code/data not require flush/reload between tasks
- Caches big enough, keep state in cache between tasks
   <sup>38</sup>











CS184 Spring2005 -- DeHor















### **Multi-level Caching**

- First cache: Level 1 (L1)
- Second cache: Level 2 (L2)
- CPI = Base CPI

ch CS184 Spring2005 -- DeHor

+Refs/Instr (L1 Miss Rate)(L2 Latency) + +Ref/Instr (L2 Miss Rate)(Memory Latency)





CS184 Spring2005 -- DeHon











# How disruptive is a Miss? With multiple issue a reference every 3-4 instructions memory references 1+ times per cycle Miss means multiple (8,20,100?) cycles to service Each miss could holds up 10's to 100's

62

of instructions...

CS184 Spring2005 -- DeHon









## **Big Ideas**

• Structure - spatial locality

h CS184 Spring2005 -- DeHor

• Engineering - worked once, try it again...until won't work

68