2019-11-01 13:45:29 +01:00
|
|
|
# ARM architecture configuration options
|
2015-05-20 18:40:39 +02:00
|
|
|
|
|
|
|
# Copyright (c) 2014-2015 Wind River Systems, Inc.
|
2017-01-19 02:01:01 +01:00
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
2015-05-20 18:40:39 +02:00
|
|
|
|
2016-03-15 18:24:36 +01:00
|
|
|
menu "ARM Options"
|
2015-10-09 12:20:52 +02:00
|
|
|
depends on ARM
|
|
|
|
|
|
|
|
config ARCH
|
|
|
|
default "arm"
|
2015-05-26 16:38:04 +02:00
|
|
|
|
2020-03-31 03:56:32 +02:00
|
|
|
config CPU_CORTEX
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
This option signifies the use of a CPU of the Cortex family.
|
|
|
|
|
2020-02-11 08:21:36 +01:00
|
|
|
config ARM_CUSTOM_INTERRUPT_CONTROLLER
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
This option indicates that the ARM CPU is connected to a custom (i.e.
|
2023-09-21 00:19:29 +02:00
|
|
|
non-GIC or NVIC) interrupt controller.
|
2020-02-11 08:21:36 +01:00
|
|
|
|
|
|
|
A number of Cortex-A and Cortex-R cores (Cortex-A5, Cortex-R4/5, ...)
|
|
|
|
allow interfacing to a custom external interrupt controller and this
|
|
|
|
option must be selected when such cores are connected to an interrupt
|
2023-09-21 00:19:29 +02:00
|
|
|
controller that is not the ARM Generic Interrupt Controller (GIC) or
|
|
|
|
the Cortex-M ARM Nested Vectored Interrupt Controller (NVIC).
|
2020-02-11 08:21:36 +01:00
|
|
|
|
|
|
|
When this option is selected, the architecture interrupt control
|
|
|
|
functions are mapped to the SoC interrupt control interface, which is
|
|
|
|
implemented at the SoC level.
|
|
|
|
|
2023-09-21 00:19:29 +02:00
|
|
|
N.B. Since all Cortex-M cores have a NVIC, if this option is selected it
|
|
|
|
is assumed that the custom interrupt control interface implementation
|
|
|
|
assumes responsibility for handling the NVIC.
|
2020-02-11 08:21:36 +01:00
|
|
|
|
2021-04-29 00:08:37 +02:00
|
|
|
config CODE_DATA_RELOCATION_SRAM
|
|
|
|
bool "Relocate code/data sections to SRAM"
|
|
|
|
depends on CPU_CORTEX_M
|
|
|
|
select CODE_DATA_RELOCATION
|
|
|
|
help
|
|
|
|
When selected this will relocate .text, data and .bss sections from
|
|
|
|
the specified files and places it in SRAM. The files should be specified
|
|
|
|
in the CMakeList.txt file with a cmake API zephyr_code_relocate(). This
|
|
|
|
config is used to create an MPU entry for the SRAM space used for code
|
|
|
|
relocation.
|
|
|
|
|
2023-02-20 12:07:41 +01:00
|
|
|
config ARM_ON_ENTER_CPU_IDLE_HOOK
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
Enables a hook (z_arm_on_enter_cpu_idle()) that is called when
|
|
|
|
the CPU is made idle (by k_cpu_idle() or k_cpu_atomic_idle()).
|
|
|
|
If needed, this hook can be used to prevent the CPU from actually
|
|
|
|
entering sleep by skipping the WFE/WFI instruction.
|
|
|
|
|
2023-09-26 14:28:36 +02:00
|
|
|
config ARM_ON_ENTER_CPU_IDLE_PREPARE_HOOK
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
Enables a hook (z_arm_on_enter_cpu_idle_prepare()) that is called when
|
|
|
|
the CPU is made idle (by k_cpu_idle() or k_cpu_atomic_idle()).
|
|
|
|
If needed, this hook can prepare data to upcoming call to
|
|
|
|
z_arm_on_enter_cpu_idle(). The z_arm_on_enter_cpu_idle_prepare differs
|
|
|
|
from z_arm_on_enter_cpu_idle because it is called before interrupts are
|
|
|
|
disabled.
|
|
|
|
|
2023-07-06 13:32:27 +02:00
|
|
|
config ARM_ON_EXIT_CPU_IDLE
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
Enables a possibility to inject SoC-specific code just after WFI/WFE
|
|
|
|
instructions of the cpu idle implementation.
|
|
|
|
|
|
|
|
Enabling this option requires that the SoC provides a soc_cpu_idle.h
|
|
|
|
header file which defines SOC_ON_EXIT_CPU_IDLE macro guarded by
|
|
|
|
_ASMLANGUAGE.
|
|
|
|
|
|
|
|
The SOC_ON_EXIT_CPU_IDLE macro is expanded just after
|
|
|
|
WFI/WFE instructions before any memory access is performed. The purpose
|
|
|
|
of the SOC_ON_EXIT_CPU_IDLE is to perform an action that mitigate issues
|
|
|
|
observed on some SoCs caused by a memory access following WFI/WFE
|
|
|
|
instructions.
|
|
|
|
|
2023-07-04 08:21:40 +02:00
|
|
|
rsource "core/Kconfig"
|
|
|
|
rsource "core/Kconfig.vfp"
|
2020-03-31 03:56:32 +02:00
|
|
|
|
2022-09-14 22:23:15 +02:00
|
|
|
# General options signifying CPU capabilities of ARM SoCs
|
|
|
|
config CPU_HAS_ARM_MPU
|
|
|
|
bool
|
|
|
|
select CPU_HAS_MPU
|
|
|
|
help
|
|
|
|
This option is enabled when the CPU has a Memory Protection Unit (MPU)
|
|
|
|
in ARM flavor.
|
|
|
|
|
|
|
|
config CPU_HAS_NXP_MPU
|
|
|
|
bool
|
|
|
|
select CPU_HAS_MPU
|
|
|
|
help
|
|
|
|
This option is enabled when the CPU has a Memory Protection Unit (MPU)
|
|
|
|
in NXP flavor.
|
|
|
|
|
|
|
|
config CPU_HAS_CUSTOM_FIXED_SOC_MPU_REGIONS
|
|
|
|
bool "Custom fixed SoC MPU region definition"
|
|
|
|
help
|
|
|
|
If enabled, this option signifies that the SoC will
|
|
|
|
define and configure its own fixed MPU regions in the
|
|
|
|
SoC definition. These fixed MPU regions are currently
|
|
|
|
used to set Flash and SRAM default access policies and
|
|
|
|
they are programmed at boot time.
|
|
|
|
|
|
|
|
config CPU_HAS_ARM_SAU
|
|
|
|
bool
|
|
|
|
select CPU_HAS_TEE
|
|
|
|
help
|
|
|
|
MCU implements the ARM Security Attribution Unit (SAU).
|
|
|
|
|
|
|
|
config CPU_HAS_NRF_IDAU
|
|
|
|
bool
|
|
|
|
select CPU_HAS_TEE
|
|
|
|
help
|
|
|
|
MCU implements the nRF (vendor-specific) Security Attribution Unit.
|
|
|
|
(IDAU: "Implementation-Defined Attribution Unit", in accordance with
|
|
|
|
ARM terminology).
|
|
|
|
|
|
|
|
config HAS_SWO
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
When enabled, indicates that SoC has an SWO output
|
|
|
|
|
2016-03-15 03:51:58 +01:00
|
|
|
endmenu
|