Dept. of Info. Sci. & Elec. Engg.

Slides:



Advertisements
Similar presentations
Lecture 19: Cache Basics Today’s topics: Out-of-order execution
Advertisements

1 Lecture 13: Cache and Virtual Memroy Review Cache optimization approaches, cache miss classification, Adapted from UCB CS252 S01.
CSE 490/590, Spring 2011 CSE 490/590 Computer Architecture Cache III Steve Ko Computer Sciences and Engineering University at Buffalo.
CSE 490/590, Spring 2011 CSE 490/590 Computer Architecture Cache II Steve Ko Computer Sciences and Engineering University at Buffalo.
CSE 490/590, Spring 2011 CSE 490/590 Computer Architecture Cache IV Steve Ko Computer Sciences and Engineering University at Buffalo.
February 9, 2010CS152, Spring 2010 CS 152 Computer Architecture and Engineering Lecture 7 - Memory Hierarchy-II Krste Asanovic Electrical Engineering and.
CS 152 Computer Architecture and Engineering Lecture 6 - Memory Krste Asanovic Electrical Engineering and Computer Sciences University of California at.
1  1998 Morgan Kaufmann Publishers Chapter Seven Large and Fast: Exploiting Memory Hierarchy.
1 Chapter Seven Large and Fast: Exploiting Memory Hierarchy.
February 9, 2011CS152, Spring 2011 CS 152 Computer Architecture and Engineering Lecture 7 - Memory Hierarchy-II Krste Asanovic Electrical Engineering and.
CS 152 Computer Architecture and Engineering Lecture 7 - Memory Hierarchy-II Krste Asanovic Electrical Engineering and Computer Sciences University of.
February 9, 2010CS152, Spring 2010 CS 152 Computer Architecture and Engineering Lecture 7 - Memory Hierarchy-II Krste Asanovic Electrical Engineering and.
1 SRAM: –value is stored on a pair of inverting gates –very fast but takes up more space than DRAM (4 to 6 transistors) DRAM: –value is stored as a charge.
CS 152 Computer Architecture and Engineering Lecture 7 - Memory Hierarchy-II Krste Asanovic Electrical Engineering and Computer Sciences University of.
1 CSE SUNY New Paltz Chapter Seven Exploiting Memory Hierarchy.
February 11, 2010CS152, Spring 2010 CS 152 Computer Architecture and Engineering Lecture 8 - Memory Hierarchy-III Krste Asanovic Electrical Engineering.
The Memory Hierarchy 21/05/2009Lecture 32_CA&O_Engr Umbreen Sabir.
CS1104 – Computer Organization PART 2: Computer Architecture Lecture 10 Memory Hierarchy.
Caches Where is a block placed in a cache? –Three possible answers  three different types AnywhereFully associativeOnly into one block Direct mappedInto.
Multilevel Caches Microprocessors are getting faster and including a small high speed cache on the same chip.
Nov. 15, 2000Systems Architecture II1 Machine Organization (CS 570) Lecture 8: Memory Hierarchy Design * Jeremy R. Johnson Wed. Nov. 15, 2000 *This lecture.
1 Chapter Seven CACHE MEMORY AND VIRTUAL MEMORY. 2 SRAM: –value is stored on a pair of inverting gates –very fast but takes up more space than DRAM (4.
1  1998 Morgan Kaufmann Publishers Chapter Seven.
Cache (Memory) Performance Optimization. Average memory access time = Hit time + Miss rate x Miss penalty To improve performance: reduce the miss rate.
1 Chapter Seven. 2 SRAM: –value is stored on a pair of inverting gates –very fast but takes up more space than DRAM (4 to 6 transistors) DRAM: –value.
CMSC 611: Advanced Computer Architecture Memory & Virtual Memory Some material adapted from Mohamed Younis, UMBC CMSC 611 Spr 2003 course slides Some material.
Electrical and Computer Engineering
Associativity in Caches Lecture 25
CSC 4250 Computer Architectures
Multilevel Memories (Improving performance using alittle “cash”)
Virtual Memory Use main memory as a “cache” for secondary (disk) storage Managed jointly by CPU hardware and the operating system (OS) Programs share main.
Lecture: Cache Hierarchies
Cache Memory Presentation I
Morgan Kaufmann Publishers Memory & Cache
Lecture: Cache Hierarchies
Peng Liu Lecture 11 Cache Peng Liu
CS 152 Computer Architecture and Engineering Lecture 6 - Memory
Peng Liu Lecture 10 Cache Peng Liu
Computer Organization & Design 计算机组成与设计
Lecture 21: Memory Hierarchy
Lecture 14 Virtual Memory and the Alpha Memory Hierarchy
Rose Liu Electrical Engineering and Computer Sciences
Krste Asanovic Electrical Engineering and Computer Sciences
Lecture 23: Cache, Memory, Virtual Memory
Lecture 08: Memory Hierarchy Cache Performance
Krste Asanovic Electrical Engineering and Computer Sciences
Lecture: Cache Innovations, Virtual Memory
Performance metrics for caches
Adapted from slides by Sally McKee Cornell University
CS 152 Computer Architecture and Engineering Lecture 6 - Memory
Peng Liu Lecture 10 Cache (2) Peng Liu
Performance metrics for caches
Morgan Kaufmann Publishers Memory Hierarchy: Cache Basics
Lecture 22: Cache Hierarchies, Memory
CS 3410, Spring 2014 Computer Science Cornell University
Peng Liu Lecture 12 Cache Peng Liu
CS 152 Computer Architecture and Engineering Lecture 6 - Memory
CS 152 Computer Architecture and Engineering CS252 Graduate Computer Architecture Lecture 6 – Memory II Krste Asanovic Electrical Engineering and Computer.
Lecture: Cache Hierarchies
CSC3050 – Computer Architecture
Lecture 21: Memory Hierarchy
Performance metrics for caches
Chapter Five Large and Fast: Exploiting Memory Hierarchy
Cache - Optimization.
Cache Memory Rabi Mahapatra
Principle of Locality: Memory Hierarchies
Cache Memory and Performance
Performance metrics for caches
10/18: Lecture Topics Using spatial locality
Overview Problem Solution CPU vs Memory performance imbalance
Presentation transcript:

Dept. of Info. Sci. & Elec. Engg. Computer Architecture and Parallel Computing 体系结构与并行计算 Lecture 4 - Memory Peng Liu Dept. of Info. Sci. & Elec. Engg. Zhejiang University liupeng@zju.edu.cn May 16, 2011

Semiconductor Memory Semiconductor memory began to be competitive in early 1970s Intel formed to exploit market for semiconductor memory Early semiconductor memory was Static RAM (SRAM). SRAM cell internals similar to a latch (cross-coupled inverters). First commercial Dynamic RAM (DRAM) was Intel 1103 1Kbit of storage on single chip charge on a capacitor used to hold value Semiconductor memory quickly replaced core in ‘70s 5 CS252 S05 5

One Transistor Dynamic RAM [Dennard, IBM] 1-T DRAM Cell word bit access transistor Storage capacitor (FET gate, trench, stack) VREF TiN top electrode (VREF) Ta2O5 dielectric W bottom electrode poly word line access transistor 6 CS252 S05 6

Modern DRAM Structure [Samsung, sub-70nm DRAM, 2004] 7

Column Decoder & Sense Amplifiers DRAM Architecture Row Address Decoder Col. 1 Col. 2M Row 1 Row 2N Column Decoder & Sense Amplifiers M N N+M bit lines word lines Memory cell (one bit) D Data Bits stored in 2-dimensional arrays on chip Modern chips have around 4-8 logical banks on each chip each logical bank physically implemented as many smaller arrays 8 CS252 S05 8

DRAM Packaging (Laptops/Desktops/Servers) Address lines multiplexed row/column address Clock and control signals Data bus (4b,8b,16b,32b) DRAM chip ~12 ~7 DIMM (Dual Inline Memory Module) contains multiple chips with clock/control/address signals connected in parallel (sometimes need buffers to drive signals to all chips) Data pins work together to return wide word (e.g., 64-bit data bus using 16x4-bit parts) 9 CS252 S05 9

DRAM Packaging, Mobile Devices [ Apple A4 package on circuit board] Two stacked DRAM die Processor plus logic die [ Apple A4 package cross-section, iFixit 2010 ] 10

DRAM Operation Three steps in read/write access to a given bank Row access (RAS) decode row address, enable addressed row (often multiple Kb in row) bitlines share charge with storage cell small change in voltage detected by sense amplifiers which latch whole row of bits sense amplifiers drive bitlines full rail to recharge storage cells Column access (CAS) decode column address to select small number of sense amplifier latches (4, 8, 16, or 32 bits depending on DRAM package) on read, send latched bits out to chip pins on write, change sense amplifier latches which then charge storage cells to required value can perform multiple column accesses on same row without another row access (burst mode) Precharge charges bit lines to known value, required before next row access Each step has a latency of around 15-20ns in modern DRAMs Various DRAM standards (DDR, RDRAM) have different ways of encoding the signals for transmission to the DRAM, but all share same core architecture Use RAS/CAS to reduce average latency. 11 CS252 S05 11

Double-Data Rate (DDR2) DRAM 200MHz Clock Row Column Precharge Row’ Data 400Mb/s Data Rate [ Micron, 256Mb DDR2 SDRAM datasheet ] 12 CS252 S05 12

CPU-Memory Bottleneck Performance of high-speed computers is usually limited by memory bandwidth & latency Latency (time for a single access) Memory access time >> Processor cycle time Bandwidth (number of accesses per unit time) if fraction m of instructions access memory, 1+m memory references / instruction CPI = 1 requires 1+m memory refs / cycle (assuming MIPS RISC ISA) 13 CS252 S05 13

Processor-DRAM Gap (latency) Time µProc 60%/year DRAM 7%/year 1 10 100 1000 1980 1981 1983 1984 1985 1986 1987 1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 2000 CPU 1982 Processor-Memory Performance Gap: (growing 50%/yr) Performance Why doesn’t DRAM get faster? Four-issue 3GHz superscalar accessing 100ns DRAM could execute 1,200 instructions during time for one memory access! 14 CS252 S05 14

Physical Size Affects Latency Big Memory CPU Small Memory CPU Signals have further to travel Fan out to more locations 15

Relative Memory Cell Sizes DRAM on memory chip On-Chip SRAM in logic chip [ Foss, “Implementing Application-Specific Memory”, ISSCC 1996 ] 16 CS252 S05 16

holds frequently used data Memory Hierarchy Big, Slow Memory (DRAM) Small, Fast Memory (RF, SRAM) A B CPU holds frequently used data capacity: Register << SRAM << DRAM latency: Register << SRAM << DRAM bandwidth: on-chip >> off-chip On a data access: if data Î fast memory  low latency access (SRAM) if data Ï fast memory  long latency access (DRAM) Due to cost Due to size of DRAM Due to cost and wire delays (wires on-chip cost much less, and are faster) 17 CS252 S05 17

Management of Memory Hierarchy Small/fast storage, e.g., registers Address usually specified in instruction Generally implemented directly as a register file but hardware might do things behind software’s back, e.g., stack management, register renaming Larger/slower storage, e.g., main memory Address usually computed from values in register Generally implemented as a hardware-managed cache hierarchy hardware decides what is kept in fast memory but software may provide “hints”, e.g., don’t cache or prefetch Secondary characteristic: Some machines (PDP-10) have overlain the registers on memory (jse) 18 CS252 S05 18

Real Memory Reference Patterns Memory Address (one dot per access) Donald J. Hatfield, Jeanette Gerald: Program Restructuring for Virtual Memory. IBM Systems Journal 10(3): 168-192 (1971) Time CS252 S05 19

Typical Memory Reference Patterns Address n loop iterations Instruction fetches subroutine call subroutine return Stack accesses argument access vector access Data accesses scalar accesses Time CS252 S05 20

Common Predictable Patterns Two predictable properties of memory references: Temporal Locality: If a location is referenced it is likely to be referenced again in the near future. Spatial Locality: If a location is referenced it is likely that locations near it will be referenced in the near future. CS252 S05 21

Memory Reference Patterns Temporal Locality Memory Address (one dot per access) Spatial Locality Donald J. Hatfield, Jeanette Gerald: Program Restructuring for Virtual Memory. IBM Systems Journal 10(3): 168-192 (1971) Time CS252 S05 22

Caches Caches exploit both types of predictability: Exploit temporal locality by remembering the contents of recently accessed locations. Exploit spatial locality by fetching blocks of data around recently accessed locations. CS252 S05 23

Inside a Cache CACHE Main Processor Memory Line Address Tag Data Block copy of main memory location 100 copy of main memory location 101 Data Byte Data Byte 100 Line Data Byte 304 Tag only needs enough bits to uniquely identify the block (jse) Address Tag 6848 416 Data Block CS252 S05 24

Cache Algorithm (Read) Look at Processor Address, search cache tags to find match. Then either Found in cache a.k.a. HIT Return copy of data from cache Not in cache a.k.a. MISS Read block of data from Main Memory Wait … Return data to processor and update cache Q: Which line do we replace? CS252 S05 25

Placement Policy Memory Cache Fully (2-way) Set Direct 0 1 2 3 4 5 6 7 0 1 2 3 Set Number Cache Fully (2-way) Set Direct Associative Associative Mapped anywhere anywhere in only into set 0 block 4 (12 mod 4) (12 mod 8) 0 1 2 3 4 5 6 7 8 9 1 1 1 1 1 1 1 1 1 1 0 1 2 3 4 5 6 7 8 9 2 2 2 2 2 2 2 2 2 2 0 1 2 3 4 5 6 7 8 9 3 3 0 1 Memory Block Number block 12 can be placed Simplest scheme is to extract bits from ‘block number’ to determine ‘set’ (jse) More sophisticated schemes will hash the block number ---- why could that be good/bad? 26 CS252 S05 26

Direct-Mapped Cache Tag Index t k b V Tag Data Block 2k lines t = HIT Offset t k b V Tag Data Block 2k lines t = HIT Data Word or Byte CS252 S05 27

Direct Map Address Selection higher-order vs. lower-order address bits Index Block Offset Tag t k b V Tag Data Block 2k lines t Index and tag reversed = HIT Data Word or Byte CS252 S05 28

2-Way Set-Associative Cache Tag Data Block V = Block Offset Index t k b HIT Data Word or Byte Compare latency to direct mapped case? (jse) CS252 S05 29

Fully Associative Cache Tag Data Block V = Block Offset t b HIT Data Word or Byte CS252 S05 30

Replacement only happens on misses Replacement Policy In an associative cache, which block from a set should be evicted when the set becomes full? Random Least-Recently Used (LRU) LRU cache state must be updated on every access true implementation only feasible for small sets (2-way) pseudo-LRU binary tree often used for 4-8 way First-In, First-Out (FIFO) a.k.a. Round-Robin used in highly associative caches Not-Most-Recently Used (NMRU) FIFO with exception for most-recently used block or blocks This is a second-order effect. Why? NLRU used in Alpha TLBs (jse) Replacement only happens on misses 31 CS252 S05 31

Block Size and Spatial Locality Block is unit of transfer between the cache and memory 4 word block, b=2 Tag Word0 Word1 Word2 Word3 Split CPU address block address offsetb 32-b bits b bits 2b = block size a.k.a line size (in bytes) Larger block size has distinct hardware advantages less tag overhead exploit fast burst transfers from DRAM exploit fast burst transfers over wide busses What are the disadvantages of increasing block size? Larger block size will reduce compulsory misses (first miss to a block). Larger blocks may increase conflict misses since the number of blocks is smaller. Fewer blocks => more conflicts. Can waste bandwidth. 32 CS252 S05 32

CPU-Cache Interaction (5-stage pipeline) 0x4 E Add M Decode, Register Fetch A ALU we Y addr nop IR B Primary Data Cache rdata R addr PC inst D hit? hit? wdata wdata PCen Primary Instruction Cache MD1 MD2 Stall entire CPU on data cache miss How are writes to istream handled? To Memory Control Cache Refill Data from Lower Levels of Memory Hierarchy 33 CS252 S05 33

Improving Cache Performance Average memory access time = Hit time + Miss rate x Miss penalty To improve performance: reduce the hit time reduce the miss rate reduce the miss penalty What is the simplest design strategy? Design the largest primary cache without slowing down the clock Or adding pipeline stages. Biggest cache that doesn’t increase hit time past 1-2 cycles (approx 8-32KB in modern technology) [ design issues more complex with out-of-order superscalar processors ] 34 CS252 S05 34

Serial-versus-Parallel Cache and Memory access a is HIT RATIO: Fraction of references in cache 1 - a is MISS RATIO: Remaining references CACHE Processor Main Memory Addr Data Average access time for serial search: tcache + (1 - a) tmem CACHE Processor Main Memory Addr Data Average access time for parallel search: a tcache + (1 - a) tmem Savings are usually small, tmem >> tcache, hit ratio a high High bandwidth required for memory path Complexity of handling parallel paths can slow tcache CS252 S05 35

Causes for Cache Misses Compulsory: first-reference to a block a.k.a. cold start misses - misses that would occur even with infinite cache Capacity: cache is too small to hold all data needed by the program - misses that would occur even under perfect replacement policy Conflict: misses that occur because of collisions due to block-placement strategy - misses that would not occur with full associativity 36 CS252 S05 36

Effect of Cache Parameters on Performance Larger cache size reduces capacity and conflict misses hit time will increase Higher associativity reduces conflict misses may increase hit time Larger block size reduces compulsory and capacity (reload) misses increases conflict misses and miss penalty Requested block first…. The following could be in the slide… spatial locality reduces compulsory misses and capacity reload misses fewer blocks may increase conflict miss rate larger blocks may increase miss penalty 37 CS252 S05 37

Write Policy Choices Cache hit: Cache miss: Common combinations: write through: write both cache & memory Generally higher traffic but simpler pipeline & cache design write back: write cache only, memory is written only when the entry is evicted A dirty bit per block further reduces write-back traffic Must handle 0, 1, or 2 accesses to memory for each load/store Cache miss: no write allocate: only write to main memory write allocate (aka fetch on write): fetch into cache Common combinations: write through and no write allocate write back with write allocate 38 CS252 S05 38

Write Performance Tag Index b t k V Tag Data 2k lines t = WE HIT Block Offset b t k V Tag Data 2k lines t = Completely serial (jse) WE HIT Data Word or Byte 39 CS252 S05 39

Reducing Write Hit Time Problem: Writes take two cycles in memory stage, one cycle for tag check plus one cycle for data write if hit Solutions: Design data RAM that can perform read and write in one cycle, restore old value after tag miss Fully-associative (CAM Tag) caches: Word line only enabled if hit Pipelined writes: Hold write data for store in single buffer ahead of cache, write cache data during next store’s tag check Need to bypass from write buffer if read address matches write buffer tag! 40 CS252 S05 40

Pipelining Cache Writes Address and Store Data From CPU Tag Index Store Data Delayed Write Addr. Delayed Write Data Load/Store =? Tags Data S L =? 1 Load Data to CPU Hit? Data from a store hit written into data portion of cache during tag access of subsequent store 41 CS252 S05 41

Write Buffer to Reduce Read Miss Penalty Unified L2 Cache Data Cache CPU Write buffer RF Evicted dirty lines for writeback cache OR All writes in writethrough cache Processor is not stalled on writes, and read misses can go ahead of write to main memory Problem: Write buffer may hold updated value of location needed by a read miss Simple scheme: on a read miss, wait for the write buffer to go empty Faster scheme: Check write buffer addresses against read miss addresses, if no match, allow read miss to go ahead of writes, else, return value in write buffer Deisgners of the MIPS M/1000 estimated that waiting for a four-word buffer to empty increased the read miss penalty by a factor of 1.5. 42 CS252 S05 42

Block-level Optimizations Tags are too large, i.e., too much overhead Simple solution: Larger blocks, but miss penalty could be large. Sub-block placement (aka sector cache) A valid bit added to units smaller than full block, called sub-blocks Only read a sub-block on a miss If a tag matches, is the word in the cache? 100 300 204 1 1 1 1 1 0 0 0 1 0 1 Main reason for subblock placement is to reduce tag overhead. Sector cache (jse) 43 CS252 S05 43

Multilevel Caches Problem: A memory cannot be large and fast Solution: Increasing sizes of cache at each level CPU L1$ L2$ DRAM Local miss rate = misses in cache / accesses to cache Global miss rate = misses in cache / CPU memory accesses Misses per instruction = misses in cache / number of instructions MPI makes it easier to compute overall performance (jse) 44 CS252 S05 44

Presence of L2 influences L1 design Use smaller L1 if there is also L2 Trade increased L1 miss rate for reduced L1 hit time and reduced L1 miss penalty Reduces average access energy Use simpler write-through L1 with on-chip L2 Write-back L2 cache absorbs write traffic, doesn’t go off-chip At most one L1 miss request per L1 access (no dirty victim write back) simplifies pipeline control Simplifies coherence issues Simplifies error recovery in L1 (can use just parity bits in L1 and reload from L2 when parity error detected on L1 read) 45 CS252 S05 45

Inclusive multilevel cache: Inclusion Policy Inclusive multilevel cache: Inner cache holds copies of data in outer cache External coherence snoop access need only check outer cache Exclusive multilevel caches: Inner cache may hold data not in outer cache Swap lines between inner/outer caches on miss Used in AMD Athlon with 64KB primary and 256KB secondary cache Why choose one type or the other? New slide (jse) 46 CS252 S05 46

Itanium-2 On-Chip Caches (Intel/HP, 2002) Level 1: 16KB, 4-way s.a., 64B line, quad-port (2 load+2 store), single cycle latency Level 2: 256KB, 4-way s.a, 128B line, quad-port (4 load or 4 store), five cycle latency Level 3: 3MB, 12-way s.a., 128B line, single 32B port, twelve cycle latency If two is good, then three must be better (jse) 47 CS252 S05 47

Power 7 On-Chip Caches [IBM 2009] 32KB L1 I$/core 32KB L1 D$/core 3-cycle latency 256KB Unified L2$/core 8-cycle latency 32MB Unified Shared L3$ Embedded DRAM 25-cycle latency to local slice 48

What types of misses does prefetching affect? Speculate on future instruction and data accesses and fetch them into cache(s) Instruction accesses easier to predict than data accesses Varieties of prefetching Hardware prefetching Software prefetching Mixed schemes What types of misses does prefetching affect? Reduces compulsory misses, can increase conflict and capacity misses. 49 CS252 S05 49

Issues in Prefetching Usefulness – should produce hits Timeliness – not late and not too early Cache and bandwidth pollution L1 Instruction Unified L2 Cache CPU L1 Data RF Prefetched data 50 CS252 S05 50

Hardware Instruction Prefetching Instruction prefetch in Alpha AXP 21064 Fetch two blocks on a miss; the requested block (i) and the next consecutive block (i+1) Requested block placed in cache, and next block in instruction stream buffer If miss in cache but hit in stream buffer, move stream buffer block into cache and prefetch next block (i+2) Prefetched instruction block Req block Stream Buffer Unified L2 Cache CPU Need to check the stream buffer if the requested block is in there. Never more than one 32-byte block in the stream buffer. L1 Instruction Req block RF 51 CS252 S05 51

Hardware Data Prefetching Prefetch-on-miss: Prefetch b + 1 upon miss on b One Block Lookahead (OBL) scheme Initiate prefetch for block b + 1 when block b is accessed Why is this different from doubling block size? Can extend to N-block lookahead Strided prefetch If observe sequence of accesses to block b, b+N, b+2N, then prefetch b+3N etc. Example: IBM Power 5 [2003] supports eight independent streams of strided prefetch per processor, prefetching 12 lines ahead of current access HP PA 7200 uses OBL prefetching Tag prefetching is twice as effective as prefetch-on-miss in reducing miss rates. 52 CS252 S05 52

Software Prefetching for(i=0; i < N; i++) { prefetch( &a[i + 1] ); prefetch( &b[i + 1] ); SUM = SUM + a[i] * b[i]; } Cache should be non-blocking or lockup-free. By that we mean that the processor can proceed while the prefetched Data is being fetched; and the caches continue to supply instructions And data while waiting for the prefetched data to return. 53 CS252 S05 53

Software Prefetching Issues Timing is the biggest issue, not predictability If you prefetch very close to when the data is required, you might be too late Prefetch too early, cause pollution Estimate how long it will take for the data to come into L1, so we can set P appropriately Why is this hard to do? for(i=0; i < N; i++) { prefetch( &a[i + P] ); prefetch( &b[i + P] ); SUM = SUM + a[i] * b[i]; } Must consider cost of prefetch instructions 54 CS252 S05 54

Compiler Optimizations Restructuring code affects the data block access sequence Group data accesses together to improve spatial locality Re-order data accesses to improve temporal locality Prevent data from entering the cache Useful for variables that will only be accessed once before being replaced Needs mechanism for software to tell hardware not to cache data (“no-allocate” instruction hints or page table bits) Kill data that will never be used again Streaming data exploits spatial locality but not temporal locality Replace into dead cache locations Miss-rate reduction without any hardware changes. Hardware designer’s favorite solution. 55 CS252 S05 55

Readings POWER5 BLUEGene/L Cell processor