Zephyr API Documentation 4.3.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
arm_mpu_v7m.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2018 Linaro Limited.
3 * Copyright (c) 2018 Nordic Semiconductor ASA.
4 *
5 * SPDX-License-Identifier: Apache-2.0
6 */
7
8#ifndef _ASMLANGUAGE
9
10#include <cmsis_core.h>
11
12/* Convenience macros to represent the ARMv7-M-specific
13 * configuration for memory access permission and
14 * cache-ability attribution.
15 */
16
17/* Privileged No Access, Unprivileged No Access */
18#define NO_ACCESS 0x0
19#define NO_ACCESS_Msk ((NO_ACCESS << MPU_RASR_AP_Pos) & MPU_RASR_AP_Msk)
20/* Privileged No Access, Unprivileged No Access */
21#define P_NA_U_NA 0x0
22#define P_NA_U_NA_Msk ((P_NA_U_NA << MPU_RASR_AP_Pos) & MPU_RASR_AP_Msk)
23/* Privileged Read Write, Unprivileged No Access */
24#define P_RW_U_NA 0x1
25#define P_RW_U_NA_Msk ((P_RW_U_NA << MPU_RASR_AP_Pos) & MPU_RASR_AP_Msk)
26/* Privileged Read Write, Unprivileged Read Only */
27#define P_RW_U_RO 0x2
28#define P_RW_U_RO_Msk ((P_RW_U_RO << MPU_RASR_AP_Pos) & MPU_RASR_AP_Msk)
29/* Privileged Read Write, Unprivileged Read Write */
30#define P_RW_U_RW 0x3U
31#define P_RW_U_RW_Msk ((P_RW_U_RW << MPU_RASR_AP_Pos) & MPU_RASR_AP_Msk)
32/* Privileged Read Write, Unprivileged Read Write */
33#define FULL_ACCESS 0x3
34#define FULL_ACCESS_Msk ((FULL_ACCESS << MPU_RASR_AP_Pos) & MPU_RASR_AP_Msk)
35/* Privileged Read Only, Unprivileged No Access */
36#define P_RO_U_NA 0x5
37#define P_RO_U_NA_Msk ((P_RO_U_NA << MPU_RASR_AP_Pos) & MPU_RASR_AP_Msk)
38/* Privileged Read Only, Unprivileged Read Only */
39#define P_RO_U_RO 0x6
40#define P_RO_U_RO_Msk ((P_RO_U_RO << MPU_RASR_AP_Pos) & MPU_RASR_AP_Msk)
41/* Note: mode 0x7 is the same as 0x6 but supported only by Cortex-M, not Cortex-R */
42
43/* Attribute flag for not-allowing execution (eXecute Never) */
44#define NOT_EXEC MPU_RASR_XN_Msk
45
46/* The following definitions are for internal use in arm_mpu.h. */
47#define STRONGLY_ORDERED_SHAREABLE MPU_RASR_S_Msk
48#define DEVICE_SHAREABLE (MPU_RASR_B_Msk | MPU_RASR_S_Msk)
49#define NORMAL_OUTER_INNER_WRITE_THROUGH_SHAREABLE (MPU_RASR_C_Msk | MPU_RASR_S_Msk)
50#define NORMAL_OUTER_INNER_WRITE_THROUGH_NON_SHAREABLE MPU_RASR_C_Msk
51/* clang-format off */
52#define NORMAL_OUTER_INNER_WRITE_BACK_SHAREABLE \
53 (MPU_RASR_C_Msk | MPU_RASR_B_Msk | MPU_RASR_S_Msk)
54/* clang-format on */
55#define NORMAL_OUTER_INNER_WRITE_BACK_NON_SHAREABLE (MPU_RASR_C_Msk | MPU_RASR_B_Msk)
56#define NORMAL_OUTER_INNER_NON_CACHEABLE_SHAREABLE ((1 << MPU_RASR_TEX_Pos) | MPU_RASR_S_Msk)
57#define NORMAL_OUTER_INNER_NON_CACHEABLE_NON_SHAREABLE (1 << MPU_RASR_TEX_Pos)
58#define NORMAL_OUTER_INNER_WRITE_BACK_WRITE_READ_ALLOCATE_SHAREABLE \
59 ((1 << MPU_RASR_TEX_Pos) | MPU_RASR_C_Msk | MPU_RASR_B_Msk | MPU_RASR_S_Msk)
60#define NORMAL_OUTER_INNER_WRITE_BACK_WRITE_READ_ALLOCATE_NON_SHAREABLE \
61 ((1 << MPU_RASR_TEX_Pos) | MPU_RASR_C_Msk | MPU_RASR_B_Msk)
62#define DEVICE_NON_SHAREABLE (2 << MPU_RASR_TEX_Pos)
63
64/* Bit-masks to disable sub-regions. */
65#define SUB_REGION_0_DISABLED ((0x01 << MPU_RASR_SRD_Pos) & MPU_RASR_SRD_Msk)
66#define SUB_REGION_1_DISABLED ((0x02 << MPU_RASR_SRD_Pos) & MPU_RASR_SRD_Msk)
67#define SUB_REGION_2_DISABLED ((0x04 << MPU_RASR_SRD_Pos) & MPU_RASR_SRD_Msk)
68#define SUB_REGION_3_DISABLED ((0x08 << MPU_RASR_SRD_Pos) & MPU_RASR_SRD_Msk)
69#define SUB_REGION_4_DISABLED ((0x10 << MPU_RASR_SRD_Pos) & MPU_RASR_SRD_Msk)
70#define SUB_REGION_5_DISABLED ((0x20 << MPU_RASR_SRD_Pos) & MPU_RASR_SRD_Msk)
71#define SUB_REGION_6_DISABLED ((0x40 << MPU_RASR_SRD_Pos) & MPU_RASR_SRD_Msk)
72#define SUB_REGION_7_DISABLED ((0x80 << MPU_RASR_SRD_Pos) & MPU_RASR_SRD_Msk)
73
74#define REGION_SIZE(size) ((ARM_MPU_REGION_SIZE_##size << MPU_RASR_SIZE_Pos) & MPU_RASR_SIZE_Msk)
75
76#define REGION_32B REGION_SIZE(32B)
77#define REGION_64B REGION_SIZE(64B)
78#define REGION_128B REGION_SIZE(128B)
79#define REGION_256B REGION_SIZE(256B)
80#define REGION_512B REGION_SIZE(512B)
81#define REGION_1K REGION_SIZE(1KB)
82#define REGION_2K REGION_SIZE(2KB)
83#define REGION_4K REGION_SIZE(4KB)
84#define REGION_8K REGION_SIZE(8KB)
85#define REGION_16K REGION_SIZE(16KB)
86#define REGION_32K REGION_SIZE(32KB)
87#define REGION_64K REGION_SIZE(64KB)
88#define REGION_128K REGION_SIZE(128KB)
89#define REGION_256K REGION_SIZE(256KB)
90#define REGION_512K REGION_SIZE(512KB)
91#define REGION_1M REGION_SIZE(1MB)
92#define REGION_2M REGION_SIZE(2MB)
93#define REGION_4M REGION_SIZE(4MB)
94#define REGION_8M REGION_SIZE(8MB)
95#define REGION_16M REGION_SIZE(16MB)
96#define REGION_32M REGION_SIZE(32MB)
97#define REGION_64M REGION_SIZE(64MB)
98#define REGION_128M REGION_SIZE(128MB)
99#define REGION_256M REGION_SIZE(256MB)
100#define REGION_512M REGION_SIZE(512MB)
101#define REGION_1G REGION_SIZE(1GB)
102#define REGION_2G REGION_SIZE(2GB)
103#define REGION_4G REGION_SIZE(4GB)
104
105#define ARM_MPU_REGION_INIT(p_name, p_base, p_size, p_attr) \
106 { \
107 .name = p_name, \
108 .base = p_base, \
109 .attr = p_attr(size_to_mpu_rasr_size(p_size)), \
110 }
111
112/* Some helper defines for common regions */
113
114/* On Cortex-M, we can only set the XN bit when CONFIG_XIP=y. When
115 * CONFIG_XIP=n, the entire image will be linked to SRAM, so we need to keep
116 * the SRAM region XN bit clear or the application code will not be executable.
117 */
118#define REGION_RAM_ATTR(size) \
119 {(NORMAL_OUTER_INNER_WRITE_BACK_WRITE_READ_ALLOCATE_NON_SHAREABLE | \
120 IF_ENABLED(CONFIG_XIP, (MPU_RASR_XN_Msk |)) size | P_RW_U_NA_Msk)}
121#define REGION_RAM_WT_ATTR(size) \
122 {(NORMAL_OUTER_INNER_WRITE_THROUGH_NON_SHAREABLE | \
123 IF_ENABLED(CONFIG_XIP, (MPU_RASR_XN_Msk |)) size | P_RW_U_NA_Msk)}
124#define REGION_RAM_NOCACHE_ATTR(size) \
125 {(NORMAL_OUTER_INNER_NON_CACHEABLE_NON_SHAREABLE | MPU_RASR_XN_Msk | size | P_RW_U_NA_Msk)}
126#if defined(CONFIG_MPU_ALLOW_FLASH_WRITE)
127#define REGION_FLASH_ATTR(size) \
128 {(NORMAL_OUTER_INNER_WRITE_THROUGH_NON_SHAREABLE | size | P_RW_U_RO_Msk)}
129#else
130#define REGION_FLASH_ATTR(size) \
131 {(NORMAL_OUTER_INNER_WRITE_THROUGH_NON_SHAREABLE | size | P_RO_U_RO_Msk)}
132#endif
133#define REGION_PPB_ATTR(size) {(STRONGLY_ORDERED_SHAREABLE | size | P_RW_U_NA_Msk)}
134#define REGION_IO_ATTR(size) {(DEVICE_NON_SHAREABLE | size | P_RW_U_NA_Msk)}
135#define REGION_EXTMEM_ATTR(size) {(STRONGLY_ORDERED_SHAREABLE | size | NO_ACCESS_Msk)}
136
138 /* Attributes belonging to RASR (including the encoded region size) */
140};
141
143
144/* Typedef for the k_mem_partition attribute */
148
149/* Read-Write access permission attributes */
150#define _K_MEM_PARTITION_P_NA_U_NA (NO_ACCESS_Msk | NOT_EXEC)
151#define _K_MEM_PARTITION_P_RW_U_RW (P_RW_U_RW_Msk | NOT_EXEC)
152#define _K_MEM_PARTITION_P_RW_U_RO (P_RW_U_RO_Msk | NOT_EXEC)
153#define _K_MEM_PARTITION_P_RW_U_NA (P_RW_U_NA_Msk | NOT_EXEC)
154#define _K_MEM_PARTITION_P_RO_U_RO (P_RO_U_RO_Msk | NOT_EXEC)
155#define _K_MEM_PARTITION_P_RO_U_NA (P_RO_U_NA_Msk | NOT_EXEC)
156
157/* Execution-allowed attributes */
158#define _K_MEM_PARTITION_P_RWX_U_RWX (P_RW_U_RW_Msk)
159#define _K_MEM_PARTITION_P_RWX_U_RX (P_RW_U_RO_Msk)
160#define _K_MEM_PARTITION_P_RX_U_RX (P_RO_U_RO_Msk)
161
162/* Kernel macros for memory attribution
163 * (access permissions and cache-ability).
164 *
165 * The macros are to be stored in k_mem_partition_attr_t
166 * objects. The format of k_mem_partition_attr_t is an
167 * "1-1" mapping of the ARMv7-M MPU RASR attribute register
168 * fields (excluding the <size> and <enable> bit-fields).
169 */
170
171/* Read-Write access permission attributes (default cache-ability) */
172#define K_MEM_PARTITION_P_NA_U_NA \
173 ((k_mem_partition_attr_t){ \
174 _K_MEM_PARTITION_P_NA_U_NA | \
175 NORMAL_OUTER_INNER_WRITE_BACK_WRITE_READ_ALLOCATE_NON_SHAREABLE})
176#define K_MEM_PARTITION_P_RW_U_RW \
177 ((k_mem_partition_attr_t){ \
178 _K_MEM_PARTITION_P_RW_U_RW | \
179 NORMAL_OUTER_INNER_WRITE_BACK_WRITE_READ_ALLOCATE_NON_SHAREABLE})
180#define K_MEM_PARTITION_P_RW_U_RO \
181 ((k_mem_partition_attr_t){ \
182 _K_MEM_PARTITION_P_RW_U_RO | \
183 NORMAL_OUTER_INNER_WRITE_BACK_WRITE_READ_ALLOCATE_NON_SHAREABLE})
184#define K_MEM_PARTITION_P_RW_U_NA \
185 ((k_mem_partition_attr_t){ \
186 _K_MEM_PARTITION_P_RW_U_NA | \
187 NORMAL_OUTER_INNER_WRITE_BACK_WRITE_READ_ALLOCATE_NON_SHAREABLE})
188#define K_MEM_PARTITION_P_RO_U_RO \
189 ((k_mem_partition_attr_t){ \
190 _K_MEM_PARTITION_P_RO_U_RO | \
191 NORMAL_OUTER_INNER_WRITE_BACK_WRITE_READ_ALLOCATE_NON_SHAREABLE})
192#define K_MEM_PARTITION_P_RO_U_NA \
193 ((k_mem_partition_attr_t){ \
194 _K_MEM_PARTITION_P_RO_U_NA | \
195 NORMAL_OUTER_INNER_WRITE_BACK_WRITE_READ_ALLOCATE_NON_SHAREABLE})
196
197/* Execution-allowed attributes (default-cacheability) */
198#define K_MEM_PARTITION_P_RWX_U_RWX \
199 ((k_mem_partition_attr_t){ \
200 _K_MEM_PARTITION_P_RWX_U_RWX | \
201 NORMAL_OUTER_INNER_WRITE_BACK_WRITE_READ_ALLOCATE_NON_SHAREABLE})
202#define K_MEM_PARTITION_P_RWX_U_RX \
203 ((k_mem_partition_attr_t){ \
204 _K_MEM_PARTITION_P_RWX_U_RX | \
205 NORMAL_OUTER_INNER_WRITE_BACK_WRITE_READ_ALLOCATE_NON_SHAREABLE})
206#define K_MEM_PARTITION_P_RX_U_RX \
207 ((k_mem_partition_attr_t){ \
208 _K_MEM_PARTITION_P_RX_U_RX | \
209 NORMAL_OUTER_INNER_WRITE_BACK_WRITE_READ_ALLOCATE_NON_SHAREABLE})
210
211/*
212 * @brief Evaluate Write-ability
213 *
214 * Evaluate whether the access permissions include write-ability.
215 *
216 * @param attr The k_mem_partition_attr_t object holding the
217 * MPU attributes to be checked against write-ability.
218 */
219#define K_MEM_PARTITION_IS_WRITABLE(attr) \
220 ({ \
221 int __is_writable__; \
222 switch (attr.rasr_attr & MPU_RASR_AP_Msk) { \
223 case P_RW_U_RW_Msk: \
224 case P_RW_U_RO_Msk: \
225 case P_RW_U_NA_Msk: \
226 __is_writable__ = 1; \
227 break; \
228 default: \
229 __is_writable__ = 0; \
230 break; \
231 } \
232 __is_writable__; \
233 })
234
235/*
236 * @brief Evaluate Execution allowance
237 *
238 * Evaluate whether the access permissions include execution.
239 *
240 * @param attr The k_mem_partition_attr_t object holding the
241 * MPU attributes to be checked against execution
242 * allowance.
243 */
244#define K_MEM_PARTITION_IS_EXECUTABLE(attr) (!((attr.rasr_attr) & (NOT_EXEC)))
245
246/* Attributes for no-cache enabling (share-ability is selected by default) */
247
248#define K_MEM_PARTITION_P_NA_U_NA_NOCACHE \
249 ((k_mem_partition_attr_t){ \
250 (_K_MEM_PARTITION_P_NA_U_NA | NORMAL_OUTER_INNER_NON_CACHEABLE_SHAREABLE)})
251#define K_MEM_PARTITION_P_RW_U_RW_NOCACHE \
252 ((k_mem_partition_attr_t){ \
253 (_K_MEM_PARTITION_P_RW_U_RW | NORMAL_OUTER_INNER_NON_CACHEABLE_SHAREABLE)})
254#define K_MEM_PARTITION_P_RW_U_RO_NOCACHE \
255 ((k_mem_partition_attr_t){ \
256 (_K_MEM_PARTITION_P_RW_U_RO | NORMAL_OUTER_INNER_NON_CACHEABLE_SHAREABLE)})
257#define K_MEM_PARTITION_P_RW_U_NA_NOCACHE \
258 ((k_mem_partition_attr_t){ \
259 (_K_MEM_PARTITION_P_RW_U_NA | NORMAL_OUTER_INNER_NON_CACHEABLE_SHAREABLE)})
260#define K_MEM_PARTITION_P_RO_U_RO_NOCACHE \
261 ((k_mem_partition_attr_t){ \
262 (_K_MEM_PARTITION_P_RO_U_RO | NORMAL_OUTER_INNER_NON_CACHEABLE_SHAREABLE)})
263#define K_MEM_PARTITION_P_RO_U_NA_NOCACHE \
264 ((k_mem_partition_attr_t){ \
265 (_K_MEM_PARTITION_P_RO_U_NA | NORMAL_OUTER_INNER_NON_CACHEABLE_SHAREABLE)})
266
267#define K_MEM_PARTITION_P_RWX_U_RWX_NOCACHE \
268 ((k_mem_partition_attr_t){ \
269 (_K_MEM_PARTITION_P_RWX_U_RWX | NORMAL_OUTER_INNER_NON_CACHEABLE_SHAREABLE)})
270#define K_MEM_PARTITION_P_RWX_U_RX_NOCACHE \
271 ((k_mem_partition_attr_t){ \
272 (_K_MEM_PARTITION_P_RWX_U_RX | NORMAL_OUTER_INNER_NON_CACHEABLE_SHAREABLE)})
273#define K_MEM_PARTITION_P_RX_U_RX_NOCACHE \
274 ((k_mem_partition_attr_t){ \
275 (_K_MEM_PARTITION_P_RX_U_RX | NORMAL_OUTER_INNER_NON_CACHEABLE_SHAREABLE)})
276
277#endif /* _ASMLANGUAGE */
278
279#define _ARCH_MEM_PARTITION_ALIGN_CHECK_SIZE(size) \
280 BUILD_ASSERT(!(((size) & ((size) - 1))) && \
281 (size) >= CONFIG_ARM_MPU_REGION_MIN_ALIGN_AND_SIZE, \
282 "The size of the partition must be power of 2 and greater than or equal to " \
283 "the minimum MPU region size.\n")
284
285/* Some compilers do not handle BUILD_ASSERT on the values of pointers.*/
286#if defined(__IAR_SYSTEMS_ICC__)
287#define _ARCH_MEM_PARTITION_ALIGN_CHECK_START(start, size)
288#else
289#define _ARCH_MEM_PARTITION_ALIGN_CHECK_START(start, size) \
290 BUILD_ASSERT(!((uint32_t)(start) & ((size) - 1)), \
291 "The start address of the partition must align with size.")
292#endif
293
294#define _ARCH_MEM_PARTITION_ALIGN_CHECK(start, size) \
295 _ARCH_MEM_PARTITION_ALIGN_CHECK_SIZE(size); \
296 _ARCH_MEM_PARTITION_ALIGN_CHECK_START(start, size)
struct arm_mpu_region_attr arm_mpu_region_attr_t
Definition arm_mpu_v7m.h:142
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
Definition arm_mpu_v7m.h:137
uint32_t rasr
Definition arm_mpu_v7m.h:139
Definition arm_mpu_v7m.h:145
uint32_t rasr_attr
Definition arm_mpu_v7m.h:146