Professional Documents
Culture Documents
Note: Some slides and/or pictures in the following are adapted from slides ©2005
Silberschatz, Galvin, and Gagne. Slides courtesy of Anthony D. Joseph, John
Kubiatowicz, AJ Shankar, George Necula, Alex Aiken, Eric Brewer, Ras Bodik,
Ion Stoica, Doug Tygar, and David Wagner.
Caching Concept
Secondary
Secondary Storage
Main (Disk)
Core Storage
Memory
(SSD)
(DRAM)
0 2n - 1
Address Space
• Temporal Locality (Locality in Time):
– Keep recently accessed data items closer to processor
• Spatial Locality (Locality in Space):
– Move contiguous blocks to the upper levels
Lower Level
To Processor Upper Level Memory
Memory
Blk X
From Processor Blk Y
Sources of Cache Misses
• Compulsory (cold start): first reference to a block
– “Cold” fact of life: not a whole lot you can do about it
– Note: When running “billions” of instruction, Compulsory Misses
are insignificant
• Capacity:
– Cache cannot contain all blocks access by the program
– Solution: increase cache size
• Conflict (collision):
– Multiple memory locations mapped to same cache location
– Solutions: increase cache size, or increase associativity
• Two others:
– Coherence (Invalidation): other process (e.g., I/O) updates
memory
– Policy: Due to non-optimal replacement policy
Caching Questions
• 8 byte cache Physical Memory
• 32 byte memory 11111
11110
11101
• 1 block = 1 byte 11100
11011
11010
• Assume CPU accesses 01100 11001
11000
10111
Cache 10110
10101
111 10100
(01100) 110 10011
101 10010
100 10001
011 10000
010 01111
001 01110
000 01101
01100
01011
1. How do you know whether byte @ 01100 is 01010
01001
cached? 01000
00111
00110
00101
00100
00011
00010
00001
00000
Caching Questions
• 8 byte cache Physical Memory
• 32 byte memory 11111
11110
11101
• 1 block = 1 byte 11100
11011
11010
• Assume CPU accesses 01100 11001
11000
10111
Cache 10110
10101
111 10100
110 10011
101 10010
100 (01 10001
011 1 00) 10000
010 01111
001 01110
000 01101
01100
01011
1. How do you know whether byte @ 01100 is 01010
01001
cached? 01000
00111
00110
2. If not, at which location in the cache do you 00101
00100
place the byte? 00011
00010
00001
00000
Caching Questions
• 8 byte cache Physical Memory
• 32 byte memory 11111
11110
11101
• 1 block = 1 byte 11100
11011
11010
• Assume CPU accesses 01100 11001
11000
10111
Cache 10110
10101
111 10100
110 10011
101 10010
100 10001
011 10000
010 01111
001 01110
000 01101
01100
01011
1. How do you know whether byte @ 01100 is 01010
01001
cached? 01000
00111
00110
2. If not, at which location in the cache do you 00101
00100
place the byte? 00011
00010
00001
3. If cache full, which cached byte do you evict? 00000
Simple Example: Direct Mapped Cache
• Each byte (block) in physical memory is
Physical Memory
cached to a single cache location 11111
11110
– Least significant bits of address (last 3 bits) 11101
11100
index the cache 11011
11010
– (00100),(01100),(10100),(11100) cached to 11001
11000
100 10111
10110
Index Tag Cache 10101
111 10100
110 10011
101 10010
100 10001
011 10000
010 01111
001 01110
000 01101
01100
01011
• How do you know which byte is 01010
01001
cached? 01000
00111
00110
– Cache stores the most significant two 00101
00100
00011
bits (i.e., tag) of the cached byte 00010
00001
00000
Simple Example: Direct Mapped Cache
Physical Memory
d
Index Tag Cache
111
110(01100)?
ex
2. At which cache location do you place
– 100 101
100
3. If cache full, which cached byte do 01
you evict?
– 100 011
010
0 001
000
01100
Simple Example: Fully Associative Cache
• Each byte can be stored at any location Physical Memory
in the cache 11111
11110
11101
11100
11011
11010
11001
11000
10111
Tag Cache 10110
10101
10100
10011
10010
10001
10000
01111
01110
01101
01100
01011
• How do you know which byte is 01010
01001
cached? 01000
00111
00110
– Tag store entire address of cached byte 00101
00100
00011
00010
00001
00000
Simple Example: Fully Associative Cache
• Each byte can be stored at any location Physical Memory
in the cache 11111
11110
11101
11100
11011
11010
11001
11000
10111
Tag Cache 10110
10101
10100
10011
10010
10001
10000
01100 01111
01110
01101
01100
1. How do you know whether (01100) is cached? 01011
01010
01001
– Check tag of all cache entries 01000
00111
2. At which cache location do you place (01100)? 00110
00101
– Any 00100
00011
3. If cache full, which cached byte do you evict? 00010
00001
00000
– Specific eviction policy (random, LRU)
Direct Mapped Cache
• Cache index selects a cache block
• “Byte select” selects byte within cache block
– Example: Block Size=32B blocks
• Cache tag fully identifies the cached data
• Data with same “cache index” shares the same cache entry
– Conflict misses
31 8 4 0
Cache Tag Cache Index Byte Select
Ex: 0x21
Cache Tag Valid Bit Cache Data
Byte 31 Byte 1 Byte 0
: :
Byte 63 Byte33 Byte 32
: : :
Compare
Hit
Set Associative Cache
• N-way set associative: N entries per Cache Index
– N direct mapped caches operates in parallel
• Example: Two-way set associative cache
– Two tags in the set are compared to input in parallel
– Data is selected based on the tag result
31 8 4 0
Cache Tag Cache Index Byte Select
Valid Cache Tag Cache Data Cache Data Cache Tag Valid
Cache Block 0 Cache Block 0
: : : : : :
OR
Hit
Cache Block
Fully Associative Cache
• Fully Associative: Every block can hold any line
– Address does not include a cache index
– Compare Cache Tags of all Cache Entries in Parallel
• Example: Block Size=32B blocks
– We need N 27-bit comparators
– Still have byte select to choose from within block
31 4 0
Cache Tag (27 bits long) Byte Select
Ex: 0x01
: :
= Byte 63 Byte 33 Byte 32
=
=
=
: : :
Where does a Block Get Placed in a
Cache?
• Example: Block 12 placed in 8 block cache
32-Block Address Space:
Block 1111111111222222222233
no. 01234567890123456789012345678901
Direct mapped: Set associative: Fully associative:
block 12 (01100) block 12 can go block 12 can go
can go only into anywhere in set 0 anywhere
block 4 (12 mod 8)
Block 01234567 Block 01234567 Block 01234567
no. no. no.
11 00101
10 00100
code
0001 0000
code 01 00011
00 00010 0000 0000
What Actually Happens on a TLB Miss?
• Hardware traversed page tables:
– On TLB miss, hardware in MMU looks at current page table to fill
TLB (may walk multiple levels)
» If PTE valid, hardware fills TLB and processor never knows
» If PTE marked as invalid, causes Page Fault, after which kernel
decides what to do afterwards
• Options?
– Invalidate TLB: simple but might be expensive
» What if switching frequently between processes?
– Include ProcessID in TLB
» This is an architectural solution: needs hardware
TLB Lookup
Access
V Rights PA
assoc
lookup
index
32 TLB 4K Cache 1K
20 10 2 4 bytes
page # disp 00
Hit/
Miss
PA = PA Data Hit/
Miss
Page Table
(1st level)
Page Table
(2nd level)
Putting Everything Together: TLB
Physical
Virtual Address: Memory:
Virtual Virtual
P1 index P2 index Offset
Page Table
(1st level)
Page Table
(2nd level)
TLB:
…
Putting Everything Together: Cache
Physical
Virtual Address: Memory:
Virtual Virtual
P1 index P2 index Offset
… …
Summary (1/2)
• The Principle of Locality:
– Program likely to access a relatively small portion of the address
space at any instant of time.
» Temporal Locality: Locality in Time
» Spatial Locality: Locality in Space