120 likes | 381 Views
Computer Architecture 計算機結構. Lecture 5 Review of Memory Hierarchy (Appendix C in textbook). Ping-Liang Lai ( 賴秉樑 ). Outline. C.0 Review From Last Lecture C.1 Introduction C.2 Cache Performance C.3 Six Basic Cache Optimizations C.4 Virtual Memory
E N D
Computer Architecture計算機結構 Lecture 5 Review of Memory Hierarchy (Appendix C in textbook) Ping-Liang Lai (賴秉樑)
Outline • C.0 Review From Last Lecture • C.1 Introduction • C.2 Cache Performance • C.3 Six Basic Cache Optimizations • C.4 Virtual Memory • C.5 Protection and Examples of Virtual Memory • C.6 Fallacies and Pitfalls • C.7 Concluding Remarks • C.8 Historical Perspective and References
Cache Performance • Two indirect performance measures have waylaid many a computer designer. • Instruction count is independent of the hardware; • Miss rate is independent of the hardware. • A better measure of memory hierarchy performance is the Average Memory Access Time (AMAT): • Hit time: 0.25 to 1.0 ns; • Miss penalty: 150 to 200 clock cycles.
Example (C-15) • Which has the lower miss rate: a 16 KB instruction cache with a 16KB data or a 32 KB unified cache? Use the miss rates in Figure C.6 to help calculate the correct answer, assuming 36% of the instructions are data transfer instructions. Assume a hit take 1 clock cycle and the miss penalty is 100 clock cycles. A load or store hit takes 1 extra clock cycle on a unified cache if there is only one cache port to satisfy two simultaneous requests. Using the pipelining terminology of Chapter 2, the unified cache leads to a structure hazard. What is the average memory access time in each case? Assume write-through caches with a write buffer and ignore stalls due to the write buffer. • Answer: First let’s convert misses per 1000 instructions into miss rates. Solving the general formula from above, the miss rate is Since every instruction access has exactly one memory access to fetch the instruction, the instruction miss rate is
Example (C-15) Since 36% of the instructions are data transfers, the data miss rate is The unified miss rate needs to account for instruction and data access: As stated above, about 74% of the memory accesses are instruction references. Thus, the overall miss rate for the split caches is Thus, a 32 KB unified cache has a slightly lower effective miss rate than two 16 KB caches. The average memory access time formula can be divided into instruction and data accesses: Therefore, the time for each organization is
Example (C-17) • Let’s use an in-order execution computer for the first example. Assume the cache miss penalty is 200 clock cycles, and all instructions normally take 1.0 clock cycles (ignoring memory stalls). Assume the average miss rate is 2%, there is an average of 1.5 memory references per instruction, and the average number of cache misses per 1000 instructions is 30. what is the impact on performance when behavior of the cache is included? Calculate the impact using both misses per instruction and miss rate. • Answer: The performance, including cache misses, is Now calculating performance using miss rate:
Outline • C.0 Review From Last Lecture • C.1 Introduction • C.2 Cache Performance • C.3 Six Basic Cache Optimizations • C.4 Virtual Memory • C.5 Protection and Examples of Virtual Memory • C.6 Fallacies and Pitfalls • C.7 Concluding Remarks • C.8 Historical Perspective and References
Cache Optimization • The AMAT formula gave us a framework to present cache optimizations for improving cache performance: • Hence, we organize six cache optimizations into three categories: • Reducing the miss rate: larger block size, large cache size, and higher associativity; • Reducing the miss penalty: multilevel caches and giving reads priority over write; • Reducing the time to hit in the cache: avoiding address translation when indexing the cache.
Three C’s of Miss • Three simple categories that sorts all misses • Compulsory: The very first access to a block cannot be in the cache, so the block must be brought into the cache. Also called cold-start misses or first-reference misses. • Capacity: If the cache cannot contain all the blocks needed during execution of a program, capacity misses will occur because of blocks being discarded and later retrieved. • Conflict: If the cache placement strategy is set associative or direct mapped, conflict misses will occur. Also called collision misses.
6 Basic Cache Optimizations • Reducing Miss Rate • Larger Block size (Compulsory misses) • Larger Cache size (Capacity misses) • Higher Associativity (Conflict misses) • Reducing Miss Penalty • Multilevel Caches • Reducing hit time • Giving Reads Priority over Writes • E.g., Read complete before earlier writes in write buffer • Avoiding Address Translation during Cache Indexing