2.66 Memory Protection Unit (mpu)
The Memory Protection Unit (MPU) divides the memory map into 8 or 16 regions, and defines the start address, size, memory type, data access permission, and instruction access permission.
Using The Library
Configure the peripheral library using the MCC.
The Memory Protection Unit (MPU) divides the memory map into 8 or 16 regions, and defines the start address, size, memory attributes, data access permission, and instruction access permission.
Memory Attributes: Memory attributes can used to define the memory type and cache behavior.
Strongly Ordered: The processor preserves the transaction order, and the write buffers are not permitted.
Device Memory: The processor preserves the transaction order, and the write buffers are permitted for device access. Device memory is used for memory mapped peripheral registers.
Normal Memory: The processor can re-order transactions for efficiency, or perform speculative reads.
-
Write through cache: On hits it writes to the cache and the main memory. On misses it updates the block in the main memory by not bringing that block to the cache.
-
Write-back cache: On hits it writes to the cache setting the dirty bit for the block, and the main memory is not updated. On misses it updates the block in the main memory not bringing that block to the cache.
-
Write-back with write allocate: On hits it writes to the cache setting dirty bit for the block, the main memory is not updated. On misses it updates the block in the main memory and brings the block to the cache.
-
Non-cacheable memory
Data Access Permission:
Data access permission can be used to define FLASH as read-only to protect it from accidental writes and define the non-accessible region to detect stack overflow conditions.
AP (bits 2:0) | Access permission |
---|---|
000 | User: No Access, Privileged: No Access |
001 | User: No Access, Privileged: Read/Write |
010 | User: Read only, Privileged: Read/Write |
011 | User: Read/Write, Privileged: Read/Write |
100 | Reserved |
101 | User: No Access, Privileged: Read only |
110 | User: Read only, Privileged: Read only |
111 | User: Read only, Privileged: Read only |
Instruction Access Permission:
Instruction access permission can be used to define non-executable memory region.
Library Interface
Memory Protection Unit peripheral library provides the following interfaces:
Functions
Name | Description |
---|---|
MPU_Initialize | Initializes the Memory Protection Unit |