I have the following specifications of an ARM based SoC:
- L1 Data cache = 32 KB, 64 B/line, 2-WAY, LRU
- L2 Cache = 1 MB, 64 B/line, 16-WAY
- L1 Data TLB (for loads): 32 entries, fully associative
- L2 Data TLB: 512 entries, 4-WAY
- PDE Cache: 16 entries (one entry per 1 MB of virtual space)
And I wonder what is the PDE cache? I guess it's something similar to TLB, but I'm not sure.
Answer
It seems that PDE (Page Directory Entry) is Intermediate table walk cache which indeed can be implemented separately from TLB.
The Cortex-A15 MPCore processor implements dedicated caches that store intermediate levels of translation table entries as part of a table walk.
See Question&Answers more detail:
os 与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…