RM0082
CPU subsystem_ARM926EJ-S
Doc ID 018672 Rev 1
The MMU TLB consists of two parts:
●
The main TLB, which is a two-way, set-associative cache for page table information. It
has 32 entries per way for a total of 64 entries.
●
The lockdown TLB, which is an eight-entry fully-associative cache that contains locked
TLB entries. Locking TLB entries can ensure that a memory access to a given region
never incurs the penalty of a page table walk.
The MMU features are:
●
Standard ARM architecture v4 and v5 MMU mapping sizes, domains, and access
protection scheme,
●
Mapping sizes are 1 MB (sections), 64 KB (large pages), 4 KB (small pages), and 1 KB
(tiny pages),
●
Access permissions for large pages and small pages can be specified separately for
each quarter of the page (subpage permissions),
●
Hardware page table walks,
●
Invalidate entire TLB using CP15 c8,
●
Invalidate TLB entry selected by MVA, using CP15 c8,
●
Lockdown of TLB entries using CP15 c10.
7.3.2
Caches and write buffer
The ARM926EJ-S processor includes an Instruction Cache (ICache), a Data Cache
(DCache) and a write buffer of 16 KB each. The size of the caches are 16 KB Instruction
Cache and 16 KB Data Cache.
The caches have the following features:
●
Virtual index, virtual tag, addressed using the Modified Virtual Address (MVA),
●
Four-way set associative, with a cache line length of 32 bytes per line, and with two
dirty bits in the DCache,
●
DCache supports write-through and write-back (or copyback) cache operations,
●
Allocate on read-miss is supported. The caches perform critical-word first cache
refilling,
●
Pseudo-random or round-robin replacement selectable,
●
Cache lockdown registers enable control over which cache ways are used for allocation
on a linefill, providing a mechanism for both lockdown and controlling cache pollution,
●
The DCache stores the Physical Address (PA) tag,
●
PLD data preload instruction does not cause data cache linefills,
●
Maintenance operations to provide efficient invalidation of the entire DCache or
ICache, regions of the two caches or region of virtual memory,
●
Provide operations for efficient cleaning and invalidation of entire DCache, regions of it
and regions of virtual memory.
The latter allows DCache coherency to be efficiently maintained when small code changes
occur, for example for self-modifying code and changes to exception vectors.
7.3.3
Bus interface unit
The ARM926EJ-S Bus Interface Unit (BIU) arbitrates and schedules the AHB requests.