### **CS223: Computer Architecture & Organization**

Lecture 23 [01.04.2022]
Advanced Cache Optimizations-Tutorials



Dr. John Jose

**Associate Professor** 

Department of Computer Science & Engineering Indian Institute of Technology Guwahati, Assam.

### **Multilevel Caches**

Assume a 2-level cache system with the following specifications. L1 Hit Time = 1 cycle, L1 Miss Rate = 2.5%, L2 Hit Time = 6 cycles, L2 Miss Rate = 17% (% L1 misses that miss), L2 Miss Penalty = 120 cycles. Compute the average memory access time.

## **Optimization**

A cache has access time (hit latency) of 10 ns and miss rate of 5%. An optimization was made to reduce the miss rate to 3% but the hit latency was increased to 15 ns. Under what condition this change will result in better performance (Lower AMAT)?

## **Optimization**

- A cache has hit rate of 95%, block size of 128B, cache hit latency of 5ns. Main memory takes 50 ns to return first word (32 bits) of a block and 10 ns for each subsequent word.
- (a) What is the miss latency of the cache?
- (b) If doubling the cache block size reduces the miss rate to 3%, does it reduces AMAT?

# **Cache Mapping**

A 16KB direct mapped 256B block unified cache is attached to a 16MB main memory system. The word length as well as instruction length of the processor is 16 bits. Consider a program that consists of a main routine M which in turn calls a subroutine S. M consists of 12 instruction words which are loaded in the main memory from the address 0x4230FA onwards. The last five instructions of M is a loop that is iterated 10 times. The second instruction in the loop is a call to subroutine S. S consists of 4 instruction words loaded in the main memory from the address 0x70F168. The last instruction of S is a subroutine return back to M. The only two data words that are used by M and S are at addresses 0x748074 and 0x846064. Assume the caches are initially empty. Ignore OS level interruption and subsequent cache impact on context switching. List out the block numbers (in decimal) in the cache that are non-empty after the execution of the program.



johnjose@iitg.ac.in http://www.iitg.ac.in/johnjose/