3.25.8 ARM MMU v5
ARM926EJ-S MMU is an ARM architecture v5 MMU. It provides virtual memory features required by systems operating on platforms such as Symbian OS, WindowsCE, and Linux. A single set of two-level page tables stored in main memory is used to control the address translation, permission checks, and memory region attributes for both data and instruction accesses. The MMU uses a single unified Translation Look aside Buffer (TLB) to cache the information held in the page tables. To support both sections and pages, there are two levels of address translation. The MMU puts the translated physical addresses into the MMU Translation Look aside Buffer TLB.
The MMU TLB has two parts: the main TLB and lock down TLB.
The main TLB is a two-way, set-associative cache for page table information. It has 32 entries per way for a total of 64 entries. The lock down TLB 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.
Using The Library
MMU Plib Initializes MMU with a flat address map (e.g. physical and virtual addresses are the same) and enable MMU and caches by invoking MMU_Initialize() in the system initialization.
Library Interface
ARM MMU v5 peripheral library provides the following interfaces:
Functions
Name | Description |
---|---|
MMU_Initialize | Initialize and enable MMU |
icache_InvalidateAll | Invalidate instruction cache |
icache_Enable | Enable instruction cache |
icache_Disable | Disable instruction cache |
dcache_InvalidateAll | Invalidate Data Cache |
dcache_CleanAll | Clean Data Cache |
dcache_CleanInvalidateAll | Clean and Invalidate Data Cache |
dcache_InvalidateByAddr | Invalidate Data Cache by address |
dcache_CleanByAddr | Clean Data Cache by address |
dcache_CleanInvalidateByAddr | Clean Data Cache by address |
dcache_Enable | Enable L1 data cache |
dcache_Disable | Disable L1 data cache |