# Lecture 22: Cache Hierarchies, Memory

- Today's topics:
  - Cache hierarchies
  - DRAM main memory
  - Virtual memory

# Locality

- Why do caches work?
  - Temporal locality: if you used some data recently, you will likely use it again
  - Spatial locality: if you used some data recently, you will likely access its neighbors
- No hierarchy: average access time for data = 300 cycles
- 32KB 1-cycle L1 cache that has a hit rate of 95%: average access time = 0.95 x 1 + 0.05 x (301) = 16 cycles

### Accessing the Cache



# The Tag Array



#### **Example Access Pattern**



### **Increasing Line Size**



# Associativity



# Associativity





- 32 KB 4-way set-associative data cache array with 32 byte line sizes
- How many sets?
- How many index bits, offset bits, tag bits?
- How large is the tag array?



#### Bullet