1# Memory Protection Unit (MPU) configuration options
2
3# Copyright (c) 2017 Synopsys
4# SPDX-License-Identifier: Apache-2.0
5
6config ARC_MPU_VER
7	int "ARC MPU version"
8	range 2 8
9	default 2
10	help
11	  ARC MPU has several versions. For MPU v2, the minimum region is 2048 bytes;
12	  For other versions, the minimum region is 32 bytes; v4 has secure features,
13	  v6 supports up to 32 regions. Note: MPU v5 & v7 are not supported.
14
15config ARC_CORE_MPU
16	bool "ARC Core MPU functionalities"
17	help
18	  ARC core MPU functionalities
19
20config MPU_STACK_GUARD
21	bool "Thread Stack Guards"
22	depends on ARC_CORE_MPU && ARC_MPU_VER !=2
23	help
24	  Enable thread stack guards via MPU. ARC supports built-in stack protection.
25	  If your core supports that, it is preferred over MPU stack guard.
26	  For ARC_MPU_VER == 2, it requires 2048 extra bytes and a strong start address
27	  alignment, this will bring big waste of memory, so no support for it.
28
29config ARC_MPU
30	bool "ARC MPU Support"
31	select MPU
32	select SRAM_REGION_PERMISSIONS
33	select ARC_CORE_MPU
34	select THREAD_STACK_INFO
35	select GEN_PRIV_STACKS if !(ARC_MPU_VER = 4 || ARC_MPU_VER = 8)
36	select MPU_REQUIRES_POWER_OF_TWO_ALIGNMENT if !(ARC_MPU_VER = 4 || ARC_MPU_VER = 8)
37	select MPU_REQUIRES_NON_OVERLAPPING_REGIONS if (ARC_MPU_VER = 4 || ARC_MPU_VER = 8)
38	help
39	  Target has ARC MPU
40