ReCap Random-Access Memory (RAM) Nonvolatile Memory

Slides:



Advertisements
Similar presentations
University of Amsterdam Computer Systems – cache characteristics Arnoud Visser 1 Computer Systems Cache characteristics.
Advertisements

Cache Memories September 30, 2008 Topics Generic cache memory organization Direct mapped caches Set associative caches Impact of caches on performance.
Computer ArchitectureFall 2007 © November 7th, 2007 Majd F. Sakr CS-447– Computer Architecture.
Cache Memories May 5, 2008 Topics Generic cache memory organization Direct mapped caches Set associative caches Impact of caches on performance EECS213.
ENEE350 Ankur Srivastava University of Maryland, College Park Based on Slides from Mary Jane Irwin ( )
Virtual Memory Topics Virtual Memory Access Page Table, TLB Programming for locality Memory Mountain Revisited.
Caches Oct. 22, 1998 Topics Memory Hierarchy
Systems I Locality and Caching
ECE Dept., University of Toronto
Memory Hierarchy 1 Computer Organization II © CS:APP & McQuain Cache Memory and Performance Many of the following slides are taken with.
University of Washington Memory and Caches I The Hardware/Software Interface CSE351 Winter 2013.
CSIE30300 Computer Architecture Unit 08: Cache Hsin-Chou Chi [Adapted from material by and
– 1 – , F’02 Caching in a Memory Hierarchy Larger, slower, cheaper storage device at level k+1 is partitioned into blocks.
CS 105 Tour of the Black Holes of Computing
CSE378 Intro to caches1 Memory Hierarchy Memory: hierarchy of components of various speeds and capacities Hierarchy driven by cost and performance In early.
Introduction: Memory Management 2 Ideally programmers want memory that is large fast non volatile Memory hierarchy small amount of fast, expensive memory.
Memory hierarchy. – 2 – Memory Operating system and CPU memory management unit gives each process the “illusion” of a uniform, dedicated memory space.
The Memory Hierarchy Topics Storage technologies and trends Locality of reference Caching in the memory hierarchy CS 105 Tour of the Black Holes of Computing.
CS.305 Computer Architecture Memory: Caches Adapted from Computer Organization and Design, Patterson & Hennessy, © 2005, and from slides kindly made available.
1 Memory Hierarchy ( Ⅲ ). 2 Outline The memory hierarchy Cache memories Suggested Reading: 6.3, 6.4.
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.
Systems I Cache Organization
1 Cache Memory. 2 Outline General concepts 3 ways to organize cache memory Issues with writes Write cache friendly codes Cache mountain Suggested Reading:
Lecture 5: Memory Performance. Types of Memory Registers L1 cache L2 cache L3 cache Main Memory Local Secondary Storage (local disks) Remote Secondary.
University of Washington Today Midterm topics end here. HW 2 is due Wednesday: great midterm review. Lab 3 is posted. Due next Wednesday (July 31)  Time.
Memory Hierarchy 1 Computer Organization II © CS:APP & McQuain Cache Memory and Performance Many of the following slides are taken with.
Memory Management memory hierarchy programs exhibit locality of reference - non-uniform reference patterns temporal locality - a program that references.
Advanced Computer Architecture CS 704 Advanced Computer Architecture Lecture 26 Memory Hierarchy Design (Concept of Caching and Principle of Locality)
Cache Memories.
COSC3330 Computer Architecture
Memory Hierarchy Ideal memory is fast, large, and inexpensive
CSE 351 Section 9 3/1/12.
Yu-Lun Kuo Computer Sciences and Information Engineering
Optimization III: Cache Memories
The Goal: illusion of large, fast, cheap memory
Cache Memories CSE 238/2038/2138: Systems Programming
Ramya Kandasamy CS 147 Section 3
Multilevel Memories (Improving performance using alittle “cash”)
How will execution time grow with SIZE?
The Hardware/Software Interface CSE351 Winter 2013
Today How’s Lab 3 going? HW 3 will be out today
CS 105 Tour of the Black Holes of Computing
Cache Memory Presentation I
CS 105 Tour of the Black Holes of Computing
CACHE MEMORY.
The Memory Hierarchy : Memory Hierarchy - Cache
CS 201 The Memory Heirarchy
Memory hierarchy.
Authors: Adapted from slides by Randy Bryant and Dave O’Hallaron
Cache Memories September 30, 2008
Memory hierarchy.
Cache Memories Topics Cache memory organization Direct mapped caches
CS 105 Tour of the Black Holes of Computing
Memory Hierarchy Memory: hierarchy of components of various speeds and capacities Hierarchy driven by cost and performance In early days Primary memory.
Adapted from slides by Sally McKee Cornell University
Caches II CSE 351 Winter 2018 Instructor: Mark Wyse
Memory Operation and Performance
CSE 153 Design of Operating Systems Winter 2018
Memory Hierarchy Memory: hierarchy of components of various speeds and capacities Hierarchy driven by cost and performance In early days Primary memory.
Instructors: Majd Sakr and Khaled Harras
Chapter Five Large and Fast: Exploiting Memory Hierarchy
Computer Organization and Assembly Languages Yung-Yu Chuang 2006/01/05
Cache Memory and Performance
Cache Memory and Performance
Sarah Diesburg Operating Systems CS 3430
Andy Wang Operating Systems COP 4610 / CGS 5765
Memory Management Jennifer Rexford.
Overview Problem Solution CPU vs Memory performance imbalance
Sarah Diesburg Operating Systems COP 4610

Presentation transcript:

ReCap Random-Access Memory (RAM) Nonvolatile Memory Data transfer between memory and CPU Hard Disk Data transfer between memory and disk SSD

Memory Hierarchy (Ⅱ)

Outline Storage trends Locality The memory hierarchy Cache memories Suggested Reading: 6.1, 6.2, 6.3, 6.4

Storage Trends Metric 1980 1985 1990 1995 2000 2005 2010 2010:1980 SRAM Metric 1980 1985 1990 1995 2000 2005 2010 2010:1980 $/MB 19,200 2,900 320 256 100 75 60 320 access (ns) 300 150 35 15 3 2 1.5 200 DRAM Metric 1980 1985 1990 1995 2000 2005 2010 2010:1980 $/MB 8,000 880 100 30 1 0.1 0.06 130,000 access (ns) 375 200 100 70 60 50 40 9 typical size (MB) 0.064 0.256 4 16 64 2,000 8,000 125,000 Disk Metric 1980 1985 1990 1995 2000 2005 2010 2010:1980 $/MB 500 100 8 0.30 0.01 0.005 0.0003 1,600,000 access (ms) 87 75 28 10 8 4 3 29 typical size (MB) 1 10 160 1,000 20,000 160,000 1,500,000 1,500,000

CPU Clock Rates Inflection point in computer history when designers hit the “Power Wall” 1980 1990 1995 2000 2003 2005 2010 2010:1980 CPU 8080 386 Pentium P-III P-4 Core 2 Core i7 --- Clock rate (MHz) 1 20 150 600 3300 2000 2500 2500 Cycle time (ns) 1000 50 6 1.6 0.3 0.50 0.4 2500 Cores 1 1 1 1 1 2 4 4 Effective cycle 1000 50 6 1.6 0.3 0.25 0.1 10,000 time (ns)

The CPU-Memory Gap The gap widens between DRAM, disk, and CPU speeds. SSD DRAM CPU

The CPU-Memory Gap The gap widens between DRAM, disk, and CPU speeds. The key to bridging this CPU-Memory gap is a fundamental property of computer programs known as locality SSD DRAM CPU

Storage technologies and trends Locality The memory hierarchy Cache memories

Locality Principle of Locality: Programs tend to use data and instructions with addresses near or equal to those they have used recently Temporal locality Recently referenced items are likely to be referenced again in the near future Spatial locality Items with nearby addresses tend to be referenced close together in time

Locality All levels of modern computer systems are designed to exploit locality Hardware Cache memory (to speed up main memory accesses) Operating systems Use main memory to speed up virtual address space accesses Use main memory to speed up disk file accesses Application programs Web browsers exploit temporal locality by caching recently referenced documents on a local disk

Locality Address 4 8 12 16 20 24 28 Contents v0 v1 v2 v3 v4 v5 v6 v7 int sumvec(int v[N]) { int i, sum = 0 ; for (i = 0 ; i < N ; i++) sum += v[i] ; return sum ; } Address 4 8 12 16 20 24 28 Contents v0 v1 v2 v3 v4 v5 v6 v7 Access order 1 2 3 5 6 7

Locality in the example sum: temporal locality v: spatial locality Stride-1 reference pattern Stride-k reference pattern Visiting every k-th element of a contiguous vector As the stride increases, the spatial locality decreases

Stride-1 reference pattern int sumarrayrows(int a[M][N]) //M=2,N=3 { int i, j, sum = 0 ; for (i = 0 ; i < M ; i++) for ( j = 0 ; j < N ; j++ ) sum += a[i][j] ; return sum ; } Address 4 8 12 16 20 Contents a00 a01 a02 a10 a11 a12 Access order 1 2 3 5 6

Stride-N reference pattern int sumarraycols(int a[M][N]) //M=2,N=3 { int i, j, sum = 0 ; for (j = 0 ; j < N ; j++) for ( i = 0 ; i < M ; i++ ) sum += a[i][j] ; return sum ; } Address 4 8 12 16 20 Contents a00 a01 a02 a10 a11 a12 Access order 1 3 5 2 6

Locality Locality of the instruction fetch Spatial locality In most cases, programs are executed in sequential order Temporal locality Instructions in loops may be executed many times

Locality Data references Instruction references sum = 0; for (i = 0; i < n; i++) sum += a[i]; return sum; Data references Reference array a elements in succession Spatial locality Reference variable sum each iteration Temporal locality Instruction references Reference instructions in sequence. Spatial locality Cycle through loop repeatedly Temporal locality

Storage technologies and trends Locality The memory hierarchy Cache memories

Memory Hierarchy Fundamental properties of storage technology and computer software Different storage technologies have widely different access times Faster technologies cost more per byte than slower ones and have less capacity The gap between CPU and main memory speed is widening Well-written programs tend to exhibit good locality

An example memory hierarchy CPU registers hold words retrieved from cache memory. Smaller, faster, and costlier (per byte) storage devices registers on-chip L1 cache (SRAM) L1 cache holds cache lines retrieved from the L2 cache. L1: L2 cache holds cache lines retrieved from memory. off-chip L2 cache (SRAM) L2: Main memory holds disk blocks retrieved from local disks. main memory (DRAM) L3: Larger, slower, and cheaper (per byte) storage devices local secondary storage (local disks) L4: Local disks hold files retrieved from disks on remote network servers. remote secondary storage (distributed file systems, Web servers) L5:

Caches Fundamental idea of a memory hierarchy: For each K, the faster, smaller device at level K serves as a cache for the larger, slower device at level K+1. Why do memory hierarchies work? Because of locality, programs tend to access the data at level k more often than they access the data at level k+1. Thus, the storage at level k+1 can be slower, and thus larger and cheaper per bit. Big Idea: The memory hierarchy creates a large pool of storage that costs as much as the cheap storage near the bottom, but that serves data to programs at the rate of the fast storage near the top.

General Cache Concepts Smaller, faster, more expensive memory caches a subset of the blocks Cache 8 4 9 10 14 3 Data is copied in block-sized transfer units 10 4 Larger, slower, cheaper memory viewed as partitioned into “blocks” 1 2 3 4 4 5 6 7 8 9 10 10 11 12 13 14 15

General Cache Concepts: Hit Request: 14 Data in block b is needed Block b is in cache: Hit! Cache 8 9 14 14 3 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15

General Cache Concepts: Miss Request: 12 Data in block b is needed Block b is not in cache: Miss! Cache 8 12 9 14 3 Block b is fetched from memory 12 Request: 12 Block b is stored in cache Placement policy: determines where b goes Replacement policy: determines which block gets evicted (victim) 1 2 3 4 5 6 7 8 9 10 11 12 12 13 14 15

Cold (compulsory) miss Capacity miss Types of Cache Misses Cold (compulsory) miss Cold misses occur because the cache is empty. Capacity miss Occurs when the set of active cache blocks (working set) is larger than the cache.

Types of Cache Misses Conflict miss Most caches limit blocks at level k+1 to a small subset (sometimes a singleton) of the block positions at level k. e.g. Block i at level k+1 must be placed in block (i mod 4) at level k. Conflict misses occur when the level k cache is large enough, but multiple data objects all map to the same level k block. e.g. Referencing blocks 0, 8, 0, 8, 0, 8, ... would miss every time.

Cache Memory History At very beginning, 3 levels Registers, main memory, disk storage 10 years later, 4 levels Register, SRAM cache, main DRAM memory, disk storage Modern processor, 5~6 levels Registers, SRAM L1, L2(,L3) cache, main DRAM memory, disk storage Cache memories small, fast SRAM-based memories managed by hardware automatically can be on-chip, on-die, off-chip

Examples of Caching in the Hierarchy Cache Type What is Cached? Where is it Cached? Latency (cycles) Managed By Registers 4-8 bytes words CPU core Compiler TLB Address translations On-Chip TLB Hardware L1 cache 64-bytes block On-Chip L1 1 Hardware L2 cache 64-bytes block On/Off-Chip L2 10 Hardware Virtual Memory 4-KB page Main memory 100 Hardware + OS Buffer cache Parts of files Main memory 100 OS Disk cache Disk sectors Disk controller 100,000 Disk firmware Network buffer cache Parts of files Local disk 10,000,000 AFS/NFS client Browser cache Web pages Local disk 10,000,000 Web browser Web cache Web pages Remote server disks 1,000,000,000 Web proxy server

Storage technologies and trends Locality The memory hierarchy Cache memories

Cache Memory CPU looks first for data in L1, then in L2, then in main memory Hold frequently accessed blocks of main memory in caches CPU chip register file ALU Cache memory system bus memory bus main memory bus interface I/O bridge

Inserting an L1 cache between the CPU and main memory a b c d block 10 p q r s block 21 ... w x y z block 30 The big slow main memory has room for many 8-word blocks. The small fast L1 cache has room for two 8-word blocks. The tiny, very fast CPU register file has room for four 4-byte words. The transfer unit between the cache and main memory is a 8-word block (32 bytes). the CPU register file and the cache is a 4-byte block. line 0 line 1

Generic Cache Memory Organization • • • B–1 1 valid tag set 0: B = 2b bytes per cache block E lines per set S = 2s sets t tag bits per line 1 valid bit set 1: set S-1: Cache is an array of sets. Each set contains one or more lines. Each line holds a block of data.

Fundamental parameters Cache Memory Fundamental parameters Parameters Descriptions S = 2s E B=2b m=log2(M) Number of sets Number of lines per set Block size(bytes) Number of physical(main memory) address bits

Cache Memory Derived quantities Parameters Descriptions M=2m s=log2(S) b=log2(B) t=m-(s+b) C=BES Maximum number of unique memory address Number of set index bits Number of block offset bits Number of tag bits Cache size (bytes) not including overhead such as the valid and tag bits

For a memory accessing instruction Access cache by A directly movl A %eax Access cache by A directly If cache hit get the value from the cache Otherwise, cache miss handling get the value

Addressing caches Physical Address A: Split into 3 parts: t bits m-1 Split into 3 parts: t bits s bits b bits m-1 <tag> <set index> <block offset>

Characterized by exactly one line per set. Direct-mapped cache Simplest kind of cache Characterized by exactly one line per set. valid tag • • • set 0: set 1: set S-1: E=1 lines per set cache block p633

Accessing Direct-Mapped Caches Three steps Set selection Line matching Word extraction

Use the set index bits to determine the set of interest Set selection Use the set index bits to determine the set of interest set 0: valid tag cache block selected set set 1: valid tag cache block • • • t bits s bits b bits set S-1: valid tag cache block 0 0 0 0 1 m-1 set index block offset tag

(1) The valid bit must be set Line matching Find a valid line in the selected set with a matching tag =1? (1) The valid bit must be set 1 2 3 4 5 6 7 selected set (i): 1 0110 (2) The tag bits in the cache line must match the tag bits in the address = ? t bits s bits b bits 0110 i m-1 tag set index block offset

Word Extraction selected set (i): 1 0110 w0 w1 w2 w3 1 2 3 4 5 6 7 selected set (i): 1 0110 w0 w1 w2 w3 block offset selects starting byte t bits s bits b bits 0110 i 100 m-1 tag set index block offset

Simple Memory System Cache 16 lines 4-byte line size Direct mapped 11 10 9 8 7 6 5 4 3 2 1 Offset Index Tag

Simple Memory System Cache Idx Tag Valid B0 B1 B2 B3 19 1 99 11 23 15 – 2 1B 00 02 04 08 3 36 4 32 43 6D 8F 09 5 0D 72 F0 1D 6 31 7 16 C2 DF 03

Simple Memory System Cache Idx Tag Valid B0 B1 B2 B3 8 24 1 3A 00 51 89 9 2D – A 93 15 DA 3B B 0B C 12 D 16 04 96 34 E 13 83 77 1B D3 F 14

Address Translation Example Address: 0x354 11 10 9 8 7 6 5 4 3 2 1 Offset Index Tag Offset: 0x0 Index: 0x05 Tag: 0x0D Hit? Yes Byte: 0x36

Line Replacement on Misses Check the cache line of the set indicated by the set index bits If the cache line valid, it must be evicted Retrieve the requested block from the next level How to get the block ? Current line is replaced by the newly fetched line

Check the cache line =1? If valid bit is set, evict the line 1 2 3 4 5 6 7 selected set (i): 1 Tag

Get the Address of the Starting Byte Consider memory address looks like the following Clear the last bits and get the address A m-1 <tag> <set index> <block offset> xxx… … … xxx m-1 <tag> <set index> <block offset> 000 … … …000

Read the Block from the Memory Put A on the Bus (A is A’000) CPU chip register file ALU Cache memory system bus memory bus main memory A bus interface I/O bridge A’ x

Read the Block from the Memory Main memory reads A’ from the memory bus, retrieves 8 bytes x, and places it on the bus CPU chip register file ALU Cache memory system bus memory bus main memory X bus interface I/O bridge A’ x

Read the Block from the Memory CPU reads x from the bus and copies it into the cache line CPU chip register file ALU Cache memory X system bus memory bus main memory bus interface I/O bridge A’ x

Read the Block from the Memory Increase A’ by 1, and copy Y in A’+1 into the cache line. CPU chip register file ALU Cache memory XY system bus memory bus main memory bus interface I/O bridge A’+1 Y

Read the Block from the Memory Repeat several times (4 or 8 ) CPU chip register file ALU Cache memory XYZW system bus memory bus main memory bus interface I/O bridge A’+3 W

Cache line, set and block A fixed-sized packet of information Moves back and forth between a cache and main memory (or a lower-level cache) Line A container in a cache that stores A block, the valid bit, the tag bits Other information Set A collection of one or more lines

Direct-mapped cache simulation Example M=16 byte addresses B=2 bytes/block, S=4 sets, E=1 entry/set x t=1 s=2 b=1 xx Address trace (reads): 0 [0000] 1 [0001] 13 [1101] 8 [1000] 0 [0000] 1 2 3 set v tag data

Direct-mapped cache simulation Example M=16 byte addresses B=2 bytes/block, S=4 sets, E=1 entry/set x t=1 s=2 b=1 xx Address trace (reads): 0 [0000] 1 [0001] 13 [1101] 8 [1000] 0 [0000] miss 1 m[0]m[1] v tag data 0 [0000] (miss) (1) 1 2 3 set

Direct-mapped cache simulation Example M=16 byte addresses B=2 bytes/block, S=4 sets, E=1 entry/set x t=1 s=2 b=1 xx Address trace (reads): 0 [0000] 1 [0001] 13 [1101] 8 [1000] 0 [0000] miss hit 1 m[0]m[1] v tag data 1 [0001] (hit) (2) 1 2 3 set

Direct-mapped cache simulation Example M=16 byte addresses B=2 bytes/block, S=4 sets, E=1 entry/set x t=1 s=2 b=1 xx Address trace (reads): 0 [0000] 1 [0001] 13 [1101] 8 [1000] 0 [0000] miss hit miss 1 m[0]m[1] v tag data m[12]m[13] 13 [1101] (miss) (3) 1 2 3 set

Direct-mapped cache simulation Example M=16 byte addresses B=2 bytes/block, S=4 sets, E=1 entry/set x t=1 s=2 b=1 xx Address trace (reads): 0 [0000] 1 [0001] 13 [1101] 8 [1000] 0 [0000] miss hit miss miss 1 m[8]m[9] v tag data m[12]m[13] 8 [1000] (miss) (4) 1 2 3 set

Direct-mapped cache simulation Example M=16 byte addresses B=2 bytes/block, S=4 sets, E=1 entry/set x t=1 s=2 b=1 xx Address trace (reads): 0 [0000] 1 [0001] 13 [1101] 8 [1000] 0 [0000] miss hit miss miss miss 1 m[0]m[1] v tag data m[12]m[13] 0 [0000] (miss) (5) 1 2 3 set

Direct-mapped cache simulation Example M=16 byte addresses B=2 bytes/block, S=4 sets, E=1 entry/set x t=1 s=2 b=1 xx Address trace (reads): 0 [0000] 1 [0001] 13 [1101] 8 [1000] 0 [0000] miss hit miss miss miss 1 m[0]m[1] v tag data m[12]m[13] 0 [0000] (miss) (5) Thrashing! 1 2 3 set

Conflict Misses in Direct-Mapped Caches 1 float dotprod(float x[8], float y[8]) 2 { 3 float sum = 0.0; 4 int i; 5 6 for (i = 0; i < 8; i++) 7 sum += x[i] * y[i]; 8 return sum; 9 }

Conflict Misses in Direct-Mapped Caches Assumption for x and y x is loaded into the 32 bytes of contiguous memory starting at address 0 y starts immediately after x at address 32 Assumption for the cache A block is 16 bytes big enough to hold four floats The cache consists of two sets A total cache size of 32 bytes

Conflict Misses in Direct-Mapped Caches Trashing Read x[0] will load x[0] ~ x[3] into the cache Read y[0] will overload the cache line by y[0] ~ y[3]

Conflict Misses in Direct-Mapped Caches Padding can avoid thrashing Claim x[12] instead of x[8]

Direct-mapped cache simulation Address bits Address (decimal) Tag bits (t=1) Index bits (s=2) Offset bits (b=1) Set number (decimal) 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 00 01 Direct-mapped cache simulation

Direct-mapped cache simulation Address bits Address (decimal) Index bits (s=2) Tag bits (t=1) Offset bits (b=1) Set number (decimal) 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 00 01 Direct-mapped cache simulation

Why use middle bits as index? High-Order Bit Indexing Middle-Order Bit Indexing 4-line Cache 00 0000 0000 01 0001 0001 10 0010 0010 11 0011 0011 0100 0100 0101 0101 0110 0110 0111 0111 1000 1000 1001 1001 1010 1010 1011 1011 1100 1100 1101 1101 1110 1110 1111 1111

Why use middle bits as index? High-Order Bit Indexing Adjacent memory lines would map to same cache entry Poor use of spatial locality Middle-Order Bit Indexing Consecutive memory lines map to different cache lines Can hold C-byte region of address space in cache at one time