Cache Coherence: Part I: CMU 15-418: Parallel Computer Architecture and Programming (Spring 2012)

Download as pdf or txt
Download as pdf or txt
You are on page 1of 31

Lecture 10:

Cache Coherence: Part I


CMU 15-418: Parallel Computer Architecture and Programming (Spring 2012)
(CMU 15-418, Spring 2012)
Shared memory multi-processor
!
Processors read and write to shared variables
- More precisely: processors issues load and store instructions
!
Intuitively... reading value at address should return the last value written at the
address by any processor
Processor Processor Processor Processor
Interconnect
Memory I/O
(CMU 15-418, Spring 2012)
The cache coherence problem
Modern processors replicate contents of memory in local caches
Result of writes: processors can have diferent values for the same memory location
Processor Processor Processor Processor
Interconnect
Memory
I/O
Cache Cache Cache Cache
P1 $ P2 $ P3 $ P4 $ mem[X] Action
!
"#$ &''( (stored at address ))
*+ ,$'-. ) + !
!
*+ /'01 2
3,04 $5", /'01 607,.,
.8"6$"'# '& &''9
+ ! :
Chart shows value of &'' (variable stored
at address X) stored in main memory and in
each processors cache **
** Assumes write-back cache behavior
*; /'01 ) ! + ! ! <",,
*; ,$'-. ) ! + ! :
*: /'01 ) ! + ! : 5"$
*: /'01 ) ! ! ! <",,
*+ /'01 ) ! ! <",,
(CMU 15-418, Spring 2012)
The cache coherence problem
!
Reading value at address X should return the last value written at address X by any
processor.
!
Coherence problem exists because there is both global state (main memory) and
local state (contents of private processor caches).
(CMU 15-418, Spring 2012)
Cache hierarchy of Intel Core i7
Core
L1 Data Cache
L2 Cache
Shared L3 Cache
(One bank per core)
Ring Interconnect
Core
L1 Data Cache
L2 Cache
Core
L1 Data Cache
L2 Cache
Core
L1 Data Cache
L2 Cache
L1: (private per core)
32 KB
8-way set associative, write back
2 x 16B loads + 1 x 16B store per clock
4-6 cycle latency
10 outstanding misses
L2: (private per core)
256 KB
8-way set associative, write back
32B / clock, 12 cycle latency
16 outstanding misses
L3: (per chip)
8 MB, inclusive
16-way set associative
32B / clock per bank
26-31 cycle latency
64 byte cache line size
Review: key terms
-
cache line
-
write back vs. write
through policy
-
inclusion
(CMU 15-418, Spring 2012)
Intuitive expectation of shared memory
!
Reading value at address should return the last value written at the address by any
processor.
!
Uniprocessor, providing this behavior is fairly simple, since writes typically come
from one client: the processor
- Exception: I/O via DMA
(CMU 15-418, Spring 2012)
Coherence is an issue in a single CPU system
!
Common solutions:
- CPU writes using uncached stores (e.g., driver code)
- OS support:
- mark pages containing shared bufers as uncached
- OS fushes pages from cache when I/O completes
!
In practice DMA transfers are infrequent compared to CPU loads/store
(slower solutions are acceptable)
Processor
Network
Card
Interconnect
Memory
Cache
Case 1:
Processor writes to bufer in main memory
Tells network card to async send bufer
Network card many transfer stale data
Case 2:
Network card receives message
DMA message contents into bufer in main memory
Notifes CPU msg received, bufer ready to read
CPU may read stale data
Message
Bufer
Consider I/O device performing DMA data transfer
(CMU 15-418, Spring 2012)
Problems with the intuition
!
Reading value at address should return the last value written at the address
by any processor.
!
What does last mean?
- What if two processors write at the same time?
- What if a write by P1 is followed by a read from P2 so close in time, its
impossible to communicate occurrence to other processors?
!
In a sequential program, last is determined by program order (not time)
- Holds true within a thread of a parallel program
- But need to come up with a meaningful way to describe orders across threads
(CMU 15-418, Spring 2012)
Defnition: coherence
A memory system is coherent if:
The results of a parallel programs execution are such that for
each memory location, there is a hypothetical serial order of all
program operations to the location that is consistent with the
results of execution, and:
1. Memory operations issued by any one process occur in the
order issued by the process
2. The value returned by a read is the value written by the
last write to the location in the serial order
Chronology of
operations on
address X
P0 write: 5
P1 read (5)
P2 read (5)
P0 read (5)
P1 write: 25
P0 read (5)
(CMU 15-418, Spring 2012)
Defnition: coherence (said diferently)
A memory system is coherent if:
1. A read by processor P to address X that follows a write by P to address X,
should return the value of the write by P (assuming no other processor wrote to X in between)
2. A read by a processor to address X that follows a write by another
processor to X returns the written value... if the read and write are
sufciently separated in time (assuming no other write to X occurs in between)
3. Writes to the same location are serialized; two writes to the same location
by any two processors are seen in the same order by all processors.
(Example: if values 1 and then 2 are written to address X, no processor observes 2 before 1)
Condition 1: program order (as expected of a uniprocessor system)
Condition 2: write propagation: The news of the write has to eventually get to the other processors. Note that
precisely when it is propagated is not defned by defnition of coherence.
Condition 3: write serialization
(CMU 15-418, Spring 2012)
Write serialization
Writes to the same location are serialized; two writes to the same location by any
two processors are seen in the same order by all processors.
(Example: if values 1 and then 2 are written to address X, no processor observes 2 before 1)
Example: P1 writes value a to X. Then P2 writes value b to X.
Consider situation where processors observe diferent order of writes:
Order observed by P1
x " a
x " b
.
.
.
.
.
.
Order observed by P2
x " b
x " a
In terms of frst coherence defnition: there is no global ordering of loads and
stores to X that is in agreement with results of this parallel program.
(CMU 15-418, Spring 2012)
Coherence vs. consistency
!
Coherence defnes behavior of reads and writes to the same memory location
!
Memory consistency defnes the behavior of reads and writes with respect
to accesses to other locations (topic of a future lecture)
- Consistency deals with the WHEN of write propagation
!
For the purposes of this lecture:
- If processor writes to address X and then writes to address Y. Then any
processor that sees result of write to Y, also observes result of write to X.
(CMU 15-418, Spring 2012)
Implementing coherence
!
Software-based solutions
- OS uses page fault mechanism to propagate writes
- Implementations provide memory coherence over clusters of workstations
- We wont discuss these solutions
!
Hardware-based solutions
- Snooping based
- Directory based
- The subject of the next couple of lectures
(CMU 15-418, Spring 2012)
Shared caches: coherence made easy
!
Obvious scalability problems
- Interference / contention
!
But can have benefts:
- Fine-grained sharing (overlapping working sets)
- Actions by one processor might pre-fetch for another
Processor Processor Processor Processor
Memory
I/O
Cache
(CMU 15-418, Spring 2012)
Snooping cache-coherence schemes
!
All coherence-related activity is broadcast to all processors
(actually, cache controllers) in the system
!
Cache controllers monitor (snoop) memory operations, and react
accordingly to maintain memory coherence
Processor
Interconnect
Memory
Cache
Processor
Cache
Processor
Cache
. . .
Notice: now cache controller must respond
to actions from both ends:
1. LD/ST requests from its processor
2. Coherence-related activity broadcast
over-interconnect
(CMU 15-418, Spring 2012)
Very simple coherence implementation
Write-through caches
Granularity of coherence is cache block
Upon write, broadcast invalidation
Next read from other processors will
trigger cache miss
(retrieve updated value due to write-through policy)
P0 $ P1 $ mem location X Action
!
*+ /'01 ) ! ! !
*! /'01 ) ! !
Cache
Processor
P0
Memory
Cache
. . .
Interconnect
Processor
P1
Bus activity
6065. <",, &'- )
6065. <",, &'- )
*! =-"$. +!! $' ) +!! +!! "#80/"10$"'# &'- )
*+ /'01 ) +!! +!! +!! 6065. <",, &'- )
(CMU 15-418, Spring 2012)
Write-through invalidation: state diagram
I
(Invalid)
V
(Valid)
PrRd / --
PrRd / BusRd
PrWr/ BusWr **
PrWr / BusWr
BusWr/--
Broadcast (bus) initiated transaction
Processor initiated transaction
A / B: if action A is observed by cache controller, action B is taken
** Write no-allocate policy (for simplicity)
Requirements of the interconnect:
1. All write transactions visible to all cache controllers
2. All write transactions visible to all cache controllers in
the same order
Simplifying assumptions here:
1. Interconnect and memory transactions are atomic
2. Process waits until previous memory operations is
complete before issuing next memory operation
3. Invalidation applied immediately as part of receiving
invalidation broadcast
(CMU 15-418, Spring 2012)
Write-through policy is inefcient
!
Every write operation goes out to memory
- Very high bandwidth requirements
!
Write-back caches absorb most write trafc as cache hits
- Signifcantly reduces bandwidth requirements
- But now how do we ensure write propagation/serialization?
- Require more sophisticated coherence protocols
(CMU 15-418, Spring 2012)
Review: write miss behavior of write-back cache
(uniprocessor case)
Example: code executes "#$ > ? +(
1. Processor performs write to address in line that is not resident in cache
2. Cache loads line from memory
3. One word in cache is updated
4. Cache line is marked as dirty
Data (64 bytes on Intel Core i7) Tag Line state
Dirty bit
(CMU 15-418, Spring 2012)
Cache coherence with write-back caches
Cache
Processor
P0
Memory
Cache
. . .
Interconnect
Processor
P1
X
Write to X Load X
!
Dirty state of cache line now indicates exclusive ownership
- Exclusive: only cache with a valid copy
- Owner: responsible for supplying data upon request
(CMU 15-418, Spring 2012)
Invalidation-based write-back protocol
!
A line in the exclusive state can be modifed without notifying
other caches
- Other caches dont have the line resident, so other processors cannot read these
values [without generating a memory read transaction]
!
Can only write to lines in the exclusive state
- If processor performs a write to line that is not exclusive in cache, cache controller
frst broadcasts a read-exclusive transaction
- Read-exclusive tells other caches about impending write
(you cant read anymore, because Im going to write)
- Read-exclusive transaction is required even if line is valid in processors local cache
- Dirty state implies exclusive
!
When cache controller snoops a read exclusive for a line it contains
- Must invalidate the line in its cache
(CMU 15-418, Spring 2012)
Basic MSI write-back invalidation protocol
!
Key tasks of protocol
- Obtaining exclusive access for a write
- Locating most recent copy of data on cache miss
!
Cache line states
- Invalid (I)
- Shared (S): line valid in one or more caches
- Modifed (M): line valid in exactly one cache (a.k.a. dirty or exclusive state)
!
Processor events
- PrRd (read)
- PrWr (write)
!
Bus transactions
- BusRd: obtain copy of line with no intent to modify
- BusRdX: obtain copy of line with intent to modify
- BusWB: write line out to memory
(CMU 15-418, Spring 2012)
MSI state transition diagram
S
(Shared)
M
(Modifed)
PrRd / --
PrWr / --
PrRd / BusRd
BusRd / fush
Broadcast (bus) initiated transaction
Processor initiated transaction
A / B: if action A is observed by cache controller, action B is taken
I
(Invalid)
PrWr / BusRdX
PrWr / BusRdX
PrRd / --
BusRdX / --
BusRdX / fush
BusRd / --
Alternative state names:
- E (exclusive, read/write access)
- S (potentially shared, read-only access)
- I (invalid, no access)
(CMU 15-418, Spring 2012)
Does MSI satisfy coherence?
!
Write propagation
- Via invalidation
!
Write serialization
- Writes that appear on bus are ordered by the order they appear on bus (BusRdX)
- Reads that appear on bus are ordered by order they appear on bus (BusRd)
- Writes that dont appear on the bus (PrWr to line already in M state):
- Sequence of writes to line comes between two bus transactions for the line
- All writes in sequence performed by same processor, P (that processor certainly observes them in
correct sequential order)
- All other processors observe notifcation of these writes only after a bus transaction for the line. So
all the writes come before the transaction.
- So all processors see writes in the same order.
(CMU 15-418, Spring 2012)
MESI invalidation protocol
!
MSI requires two bus transactions for the common case of
reading data, then writing to it
- Transaction 1: BusRd to move from I to S state
- Transaction 2: BusRdX to move from S to M state
!
This inefciency exists even if application has no sharing at all
!
Solution: add additional state E (exclusive clean)
- Line not modifed, but only this cache has copy
- Decouples exclusivity from line ownership (line not dirty, so copy in memory is
valid copy of data)
- Upgrade from E to M does not require a bus transaction
(CMU 15-418, Spring 2012)
MESI state transition diagram
E
(Exclusive)
M
(Modifed)
PrRd / --
PrWr / --
PrWr / BusRdX BusRd / fush
I
(Invalid)
PrWr / BusRdX
PrWr / --
PrRd / --
BusRdX / --
BusRdX / fush
BusRd / --
S
(Shared)
PrRd / --
PrRd / BusRd
(no other cache
asserts shared)
PrRd / BusRd
BusRd / --
BusRdX / --
(another cache
asserts shared)
(CMU 15-418, Spring 2012)
Lower-level choices
!
Who should supply data on a cache miss when line is in the E
or S state of another cache?
- Can get data from memory or can get data from another cache
- If source is another cache, which one should provide it?
!
Cache-to-cache transfers add complexity, but commonly used
today to reduce both latency of access and memory
bandwidth requires
(CMU 15-418, Spring 2012)
Increasing efciency (and complexity)
!
MOESI (5-stage invalidation-based protocol)
- In MESI protocol, transition from M to S requires fush to memory
- Instead transition from M to O (O=owned, but not exclusive) and do not fush to
memory
- Other processors maintain shared line in S state, one processor maintains line in O state
- Data in memory is stale, so cache with line in O state must service cache misses
- Used in AMD Opteron
!
MESIF (5-stage invalidation-based protocol)
- Like MESI, but one cache holds shared line in F state rather than S (F=forward)
- Cache with line in F state services miss
- Simplifes decision of which cache should service miss (basic MESI: all caches respond)
- Used by Intel
(CMU 15-418, Spring 2012)
Implications of implementing coherence
!
Each cache must listen and react to all coherent trafc
broadcast on interconnect
- Duplicate cache tags so that tag lookup in response to coherence actions does
not interfere with processor loads and stores
!
Additional trafc on interconnect
- Can be signifcant when scaling to higher core counts
!
To date, GPUs do not implement cache coherence
- Thus far, overhead of coherence deemed not worth it for graphics applications
(CMU 15-418, Spring 2012)
Implications to software developer
What could go wrong with this code?
@@ 0//'60$. A.- $5-.01 80-"0B/. &'- /'60/ 0667<7/0$"'#
"#$ <4C'7#$.-DEFGHIJKLMNOP(
Better:
@@ 0//'60$. A.- $5-.01 80-"0B/. &'- /'60/ 0667<7/0$"'#
,$-76$ *.-I5-.01O$0$. Q
"#$ <4C'7#$.-(
650- A011"#RDST U ,"V.'&3"#$9P(
W(
*.-I5-.01O$0$. <4C'7#$.-DEFGHIJKLMNOP(
(CMU 15-418, Spring 2012)
False sharing
!
Condition where two threads write to diferent variables, but
variables addresses map to same cache line
!
Cache line ping-pongs between caches of writing processors,
generating signifcant amounts of communication due to
coherence protocol
!
No inherent communication, all artifactual communication
!
Can be a factor in when programming for cache coherent
architectures (assignment 3)

You might also like