Community
cancel
Showing results for 
Search instead for 
Did you mean: 
Highlighted
Beginner
5 Views

L3 references = L2 cache misses ?

My cpu has 1 MB L3 cache and 512K L2 cache. When I run vtune, I found out that L3 cache references > L2 cache misses.

L2 cache miss: 10625310
L3 cache reference: 36781316

L2 cache miss is causing L3 cache reference. What else is causing that?

And from the numbers, it looks like

L2 cach3 miss/L2 cache reference is low: .7%

but L3 cache miss/L3 cache ference is high: 70%

Although I know you cannot use cache miss/reference to get cache hit rate, but it still give a hint of the effectiveness of the cache, right?

Thanks for you guys's help
0 Kudos
2 Replies
Highlighted
5 Views

Interesting question, liang46051!
I've asked some experts their opinions on this, and either I or they will post their thoughts here, hopefully in the next few days.
HOWEVER, that said, my guess is that, depending on what workloads you're running, your data may actually fit in L2 but spills out of L3. (Sounds pretty simple: maybe *too* simple, eh?...)
An engineer I ran this by quickly suggested that there is a push to less-recently used data from L2 into L3; but whether or not the compiler can influence this, or it's a strictly hardware-thing, we're not remembering.
Stay tuned! The experts will weigh in here, and set us all straight.
cheers
jdg
0 Kudos
Highlighted
Beginner
5 Views

Thanks jdgallag, I think I understand the much higher cache misses of L3 cache. the reason is that: when you bring data from memory to caches, you bring it to both L2 and L3 (then half of L3 cache is poluted when all entries in L2 is renewed, since L3 1M L2 512K), and since L2 miss is low and when L3 cache is referenced, it's very likely that it's a brand new data(Most data in L3 are the "once upon a time" old data in L2, caused by cache misses). So, L3 cache effectiveness are very low. The main reason is that L3 is not too much bigger than L2 (only two times bigger), compare with the difference of L1 and L2 (512/20).

What I still don't understand is the first question, why L3 references > L2 cache misses

Thanks
0 Kudos