2019-06-04 07:37:31 +02:00
|
|
|
# ARC options
|
2015-06-20 15:23:14 +02:00
|
|
|
|
2019-06-04 07:37:31 +02:00
|
|
|
# Copyright (c) 2014, 2019 Wind River Systems, Inc.
|
2017-01-19 02:01:01 +01:00
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
2016-03-15 18:24:36 +01:00
|
|
|
|
|
|
|
menu "ARC Options"
|
2015-10-09 12:20:52 +02:00
|
|
|
depends on ARC
|
2015-08-23 19:08:06 +02:00
|
|
|
|
2015-10-09 12:20:52 +02:00
|
|
|
config ARCH
|
|
|
|
default "arc"
|
2015-06-20 15:23:14 +02:00
|
|
|
|
2019-11-01 10:24:07 +01:00
|
|
|
config CPU_ARCEM
|
2021-03-19 23:00:50 +01:00
|
|
|
bool
|
2016-04-26 18:59:44 +02:00
|
|
|
select ATOMIC_OPERATIONS_C
|
2015-06-20 15:23:14 +02:00
|
|
|
help
|
2019-06-04 07:37:31 +02:00
|
|
|
This option signifies the use of an ARC EM CPU
|
2015-06-20 15:23:14 +02:00
|
|
|
|
2019-11-01 10:24:07 +01:00
|
|
|
config CPU_ARCHS
|
2021-03-19 23:00:50 +01:00
|
|
|
bool
|
2021-04-30 03:46:46 +02:00
|
|
|
select ATOMIC_OPERATIONS_BUILTIN
|
2019-06-04 08:57:27 +02:00
|
|
|
help
|
|
|
|
This option signifies the use of an ARC HS CPU
|
|
|
|
|
2015-06-20 15:23:14 +02:00
|
|
|
|
2021-03-19 23:34:01 +01:00
|
|
|
choice
|
|
|
|
prompt "ARC Instruction Set"
|
|
|
|
default ISA_ARCV2
|
|
|
|
|
|
|
|
config ISA_ARCV2
|
|
|
|
bool "ARC ISA v2"
|
|
|
|
select ARCH_HAS_STACK_PROTECTION if ARC_HAS_STACK_CHECKING || (ARC_MPU && ARC_MPU_VER !=2)
|
|
|
|
select ARCH_HAS_USERSPACE if ARC_MPU
|
2022-05-12 17:21:07 +02:00
|
|
|
select ARCH_HAS_SINGLE_THREAD_SUPPORT if !SMP
|
2021-03-19 23:34:01 +01:00
|
|
|
select USE_SWITCH
|
|
|
|
select USE_SWITCH_SUPPORTED
|
|
|
|
help
|
|
|
|
v2 ISA for the ARC-HS & ARC-EM cores
|
|
|
|
|
2021-03-30 23:48:35 +02:00
|
|
|
config ISA_ARCV3
|
|
|
|
bool "ARC ISA v3"
|
2022-05-12 17:21:07 +02:00
|
|
|
select ARCH_HAS_SINGLE_THREAD_SUPPORT if !SMP
|
2021-03-30 23:48:35 +02:00
|
|
|
select USE_SWITCH
|
|
|
|
select USE_SWITCH_SUPPORTED
|
|
|
|
|
2021-03-19 23:34:01 +01:00
|
|
|
endchoice
|
|
|
|
|
|
|
|
if ISA_ARCV2
|
|
|
|
|
2019-10-25 05:00:41 +02:00
|
|
|
config CPU_EM4
|
|
|
|
bool
|
2021-03-19 23:00:50 +01:00
|
|
|
select CPU_ARCEM
|
2019-10-25 05:00:41 +02:00
|
|
|
help
|
|
|
|
If y, the SoC uses an ARC EM4 CPU
|
|
|
|
|
|
|
|
config CPU_EM4_DMIPS
|
|
|
|
bool
|
2021-03-19 23:00:50 +01:00
|
|
|
select CPU_ARCEM
|
2019-10-25 05:00:41 +02:00
|
|
|
help
|
|
|
|
If y, the SoC uses an ARC EM4 DMIPS CPU
|
|
|
|
|
|
|
|
config CPU_EM4_FPUS
|
|
|
|
bool
|
2021-03-19 23:00:50 +01:00
|
|
|
select CPU_ARCEM
|
2019-10-25 05:00:41 +02:00
|
|
|
help
|
|
|
|
If y, the SoC uses an ARC EM4 DMIPS CPU with the single-precision
|
|
|
|
floating-point extension
|
|
|
|
|
|
|
|
config CPU_EM4_FPUDA
|
|
|
|
bool
|
2021-03-19 23:00:50 +01:00
|
|
|
select CPU_ARCEM
|
2019-10-25 05:00:41 +02:00
|
|
|
help
|
|
|
|
If y, the SoC uses an ARC EM4 DMIPS CPU with single-precision
|
|
|
|
floating-point and double assist instructions
|
|
|
|
|
|
|
|
config CPU_EM6
|
|
|
|
bool
|
2021-03-19 23:00:50 +01:00
|
|
|
select CPU_ARCEM
|
2022-07-25 10:43:15 +02:00
|
|
|
select CPU_HAS_DCACHE
|
|
|
|
select CPU_HAS_ICACHE
|
2019-10-25 05:00:41 +02:00
|
|
|
help
|
|
|
|
If y, the SoC uses an ARC EM6 CPU
|
|
|
|
|
2021-03-19 23:00:50 +01:00
|
|
|
config CPU_HS3X
|
|
|
|
bool
|
|
|
|
select CPU_ARCHS
|
2022-07-25 10:43:15 +02:00
|
|
|
select CPU_HAS_DCACHE
|
|
|
|
select CPU_HAS_ICACHE
|
2021-03-19 23:00:50 +01:00
|
|
|
help
|
2022-08-23 12:33:27 +02:00
|
|
|
If y, the SoC uses an ARC HS3x CPU
|
|
|
|
|
|
|
|
config CPU_HS4X
|
|
|
|
bool
|
|
|
|
select CPU_ARCHS
|
|
|
|
select CPU_HAS_DCACHE
|
|
|
|
select CPU_HAS_ICACHE
|
|
|
|
help
|
|
|
|
If y, the SoC uses an HS4X CPU
|
2021-03-19 23:00:50 +01:00
|
|
|
|
2021-03-19 23:34:01 +01:00
|
|
|
endif #ISA_ARCV2
|
|
|
|
|
2021-03-30 23:48:35 +02:00
|
|
|
if ISA_ARCV3
|
|
|
|
|
2022-05-05 17:42:24 +02:00
|
|
|
config CPU_HS5X
|
|
|
|
bool
|
|
|
|
select CPU_ARCHS
|
2022-07-25 10:43:15 +02:00
|
|
|
select CPU_HAS_DCACHE
|
|
|
|
select CPU_HAS_ICACHE
|
2022-05-05 17:42:24 +02:00
|
|
|
help
|
|
|
|
If y, the SoC uses an ARC HS6x CPU
|
|
|
|
|
2021-03-30 23:48:35 +02:00
|
|
|
config CPU_HS6X
|
|
|
|
bool
|
|
|
|
select CPU_ARCHS
|
|
|
|
select 64BIT
|
2022-07-25 10:43:15 +02:00
|
|
|
select CPU_HAS_DCACHE
|
|
|
|
select CPU_HAS_ICACHE
|
2021-03-30 23:48:35 +02:00
|
|
|
help
|
|
|
|
If y, the SoC uses an ARC HS6x CPU
|
|
|
|
|
|
|
|
endif #ISA_ARCV3
|
|
|
|
|
2019-10-25 06:25:49 +02:00
|
|
|
config FP_FPU_DA
|
|
|
|
bool
|
|
|
|
|
2021-03-19 23:34:01 +01:00
|
|
|
menu "ARC CPU Options"
|
2015-06-20 15:23:14 +02:00
|
|
|
|
2021-04-07 18:23:23 +02:00
|
|
|
config ARC_HAS_ZOL
|
|
|
|
bool
|
|
|
|
depends on ISA_ARCV2
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
ARCv2 CPUs have ZOL hardware loop mechanism which the ARCv3 ISA drops.
|
|
|
|
Architecturally ZOL provides
|
|
|
|
- LPcc instruction
|
|
|
|
- LP_COUNT core reg
|
|
|
|
- LP_START, LP_END aux regs
|
|
|
|
Disabling this option removes usage of ZOL regs from code
|
|
|
|
|
2019-11-01 10:24:07 +01:00
|
|
|
config NUM_IRQ_PRIO_LEVELS
|
2018-08-14 16:19:20 +02:00
|
|
|
int "Number of supported interrupt priority levels"
|
2015-06-20 15:23:14 +02:00
|
|
|
range 1 16
|
|
|
|
help
|
|
|
|
Interrupt priorities available will be 0 to NUM_IRQ_PRIO_LEVELS-1.
|
|
|
|
The minimum value is 1.
|
|
|
|
|
|
|
|
The BSP must provide a valid default for proper operation.
|
|
|
|
|
2019-11-01 10:24:07 +01:00
|
|
|
config NUM_IRQS
|
2018-08-14 16:19:20 +02:00
|
|
|
int "Upper limit of interrupt numbers/IDs used"
|
2016-01-04 22:54:14 +01:00
|
|
|
range 17 256
|
2015-06-20 15:23:14 +02:00
|
|
|
help
|
|
|
|
Interrupts available will be 0 to NUM_IRQS-1.
|
2016-01-04 22:54:14 +01:00
|
|
|
The minimum value is 17 as the first 16 entries in the vector
|
|
|
|
table are for CPU exceptions.
|
2015-06-20 15:23:14 +02:00
|
|
|
|
|
|
|
The BSP must provide a valid default. This drives the size of the
|
|
|
|
vector table.
|
|
|
|
|
2019-11-01 10:24:07 +01:00
|
|
|
config RGF_NUM_BANKS
|
2018-08-14 16:19:20 +02:00
|
|
|
int "Number of General Purpose Register Banks"
|
2021-03-30 22:31:12 +02:00
|
|
|
depends on ARC_FIRQ
|
2021-10-04 12:13:53 +02:00
|
|
|
depends on NUM_IRQ_PRIO_LEVELS > 1
|
2016-10-07 19:29:11 +02:00
|
|
|
range 1 2
|
|
|
|
default 2
|
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
The ARC CPU can be configured to have more than one register
|
|
|
|
bank. If fast interrupts are supported (FIRQ), the 2nd
|
|
|
|
register bank, in the set, will be used by FIRQ interrupts.
|
|
|
|
If fast interrupts are supported but there is only 1
|
|
|
|
register bank, the fast interrupt handler must save
|
|
|
|
and restore general purpose registers.
|
2021-10-04 12:13:53 +02:00
|
|
|
NOTE: it's required to have more than one interrupt priority level
|
|
|
|
to use second register bank - otherwise all interrupts will use
|
|
|
|
same register bank. Such configuration isn't supported in software
|
|
|
|
and it is not beneficial from the performance point of view.
|
2016-10-07 19:29:11 +02:00
|
|
|
|
2017-11-29 09:55:18 +01:00
|
|
|
config ARC_FIRQ
|
2018-08-14 16:19:20 +02:00
|
|
|
bool "FIRQ enable"
|
2021-03-30 23:48:35 +02:00
|
|
|
depends on ISA_ARCV2
|
2021-10-04 12:13:53 +02:00
|
|
|
depends on NUM_IRQ_PRIO_LEVELS > 1
|
2022-10-28 17:50:05 +02:00
|
|
|
depends on !ARC_HAS_SECURE
|
2017-11-29 09:55:18 +01:00
|
|
|
default y
|
|
|
|
help
|
2018-01-06 13:41:34 +01:00
|
|
|
Fast interrupts are supported (FIRQ). If FIRQ enabled, for interrupts
|
|
|
|
with highest priority, status32 and pc will be saved in aux regs,
|
|
|
|
other regs will be saved according to the number of register bank;
|
|
|
|
If FIRQ is disabled, the handle of interrupts with highest priority
|
|
|
|
will be same with other interrupts.
|
2021-10-04 12:13:53 +02:00
|
|
|
NOTE: we don't allow the configuration with FIRQ enabled and only one
|
|
|
|
interrupt priority level (so all interrupts are FIRQ). Such
|
|
|
|
configuration isn't supported in software and it is not beneficial
|
|
|
|
from the performance point of view.
|
2017-11-29 09:55:18 +01:00
|
|
|
|
2019-09-25 09:58:14 +02:00
|
|
|
config ARC_FIRQ_STACK
|
2022-03-09 12:05:12 +01:00
|
|
|
bool "Separate firq stack"
|
2019-09-25 09:58:14 +02:00
|
|
|
depends on ARC_FIRQ && RGF_NUM_BANKS > 1
|
|
|
|
help
|
|
|
|
Use separate stack for FIRQ handing. When the fast irq is also a direct
|
|
|
|
irq, this will get the minimal interrupt latency.
|
|
|
|
|
|
|
|
config ARC_FIRQ_STACK_SIZE
|
|
|
|
int "FIRQ stack size"
|
|
|
|
depends on ARC_FIRQ_STACK
|
|
|
|
default 1024
|
|
|
|
help
|
|
|
|
The size of firq stack.
|
|
|
|
|
2019-12-21 06:32:09 +01:00
|
|
|
config ARC_HAS_STACK_CHECKING
|
2019-03-20 07:17:37 +01:00
|
|
|
bool "ARC has STACK_CHECKING"
|
2021-03-30 23:48:35 +02:00
|
|
|
depends on ISA_ARCV2
|
2019-03-20 07:17:37 +01:00
|
|
|
default y
|
|
|
|
help
|
|
|
|
ARC is configured with STACK_CHECKING which is a mechanism for
|
|
|
|
checking stack accesses and raising an exception when a stack
|
|
|
|
overflow or underflow is detected.
|
|
|
|
|
2019-11-01 10:24:07 +01:00
|
|
|
config ARC_CONNECT
|
2019-07-24 11:47:29 +02:00
|
|
|
bool "ARC has ARC connect"
|
|
|
|
select SCHED_IPI_SUPPORTED
|
|
|
|
help
|
|
|
|
ARC is configured with ARC CONNECT which is a hardware for connecting
|
|
|
|
multi cores.
|
|
|
|
|
2019-11-01 14:00:09 +01:00
|
|
|
config ARC_STACK_CHECKING
|
2019-03-20 07:17:37 +01:00
|
|
|
bool
|
2020-02-05 19:41:58 +01:00
|
|
|
select NO_UNUSED_STACK_INSPECTION
|
2019-03-20 07:17:37 +01:00
|
|
|
help
|
|
|
|
Use ARC STACK_CHECKING to do stack protection
|
|
|
|
|
2019-11-01 10:24:07 +01:00
|
|
|
config ARC_STACK_PROTECTION
|
2017-09-09 03:14:06 +02:00
|
|
|
bool
|
|
|
|
default y if HW_STACK_PROTECTION
|
2019-03-20 07:17:37 +01:00
|
|
|
select ARC_STACK_CHECKING if ARC_HAS_STACK_CHECKING
|
2020-04-18 05:42:36 +02:00
|
|
|
select MPU_STACK_GUARD if (!ARC_STACK_CHECKING && ARC_MPU && ARC_MPU_VER !=2)
|
2017-05-12 00:33:16 +02:00
|
|
|
select THREAD_STACK_INFO
|
2016-03-11 18:29:14 +01:00
|
|
|
help
|
2019-03-20 07:17:37 +01:00
|
|
|
This option enables either:
|
|
|
|
- The ARC stack checking, or
|
|
|
|
- the MPU-based stack guard
|
|
|
|
to cause a system fatal error
|
|
|
|
if the bounds of the current process stack are overflowed.
|
|
|
|
The two stack guard options are mutually exclusive. The
|
|
|
|
selection of the ARC stack checking is
|
|
|
|
prioritized over the MPU-based stack guard.
|
2016-03-11 18:29:14 +01:00
|
|
|
|
2019-11-01 10:24:07 +01:00
|
|
|
config ARC_USE_UNALIGNED_MEM_ACCESS
|
2022-03-09 12:05:12 +01:00
|
|
|
bool "Unaligned access in HW"
|
2019-06-04 08:57:27 +02:00
|
|
|
default y if CPU_ARCHS
|
|
|
|
depends on (CPU_ARCEM && !ARC_HAS_SECURE) || CPU_ARCHS
|
2019-07-17 00:10:39 +02:00
|
|
|
help
|
|
|
|
ARC EM cores w/o secure shield 2+2 mode support might be configured
|
|
|
|
to support unaligned memory access which is then disabled by default.
|
|
|
|
Enable unaligned access in hardware and make software to use it.
|
|
|
|
|
2024-01-19 12:53:53 +01:00
|
|
|
config ARC_CURRENT_THREAD_USE_NO_TLS
|
|
|
|
bool
|
|
|
|
select CURRENT_THREAD_USE_NO_TLS
|
|
|
|
default y if (RGF_NUM_BANKS > 1) || ("$(ZEPHYR_TOOLCHAIN_VARIANT)" = "arcmwdt")
|
|
|
|
help
|
|
|
|
Disable current Thread Local Storage for ARC. For cores with more then one
|
|
|
|
RGF_NUM_BANKS the parameter is disabled by-default because banks syncronization
|
|
|
|
requires significant time, and it slows down performance.
|
|
|
|
ARCMWDT works with tls pointer in different way then GCC. Optimized access to
|
|
|
|
TLS pointer via _current variable does not provide significant advantages
|
|
|
|
in case of MetaWare.
|
|
|
|
|
2017-02-13 18:36:32 +01:00
|
|
|
config GEN_ISR_TABLES
|
|
|
|
default y
|
|
|
|
|
|
|
|
config GEN_IRQ_START_VECTOR
|
|
|
|
default 16
|
|
|
|
|
2016-05-07 02:23:05 +02:00
|
|
|
config HARVARD
|
2018-08-14 16:19:20 +02:00
|
|
|
bool "Harvard Architecture"
|
2016-05-07 02:23:05 +02:00
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
The ARC CPU can be configured to have two busses;
|
|
|
|
one for instruction fetching and another that serves as a data bus.
|
boards: Update arc em_starterkit support from 2.2 to 2.3
Here are the main changes:
* board: Update EMSK onboard resources such as Button, Switch and LEDs
+ update soc.h for em7d, em9d, em11d
+ update board.h for em_starterkit board
* arc: Add floating point support and code density support
+ add kconfig configuration
+ add compiler options
+ add register definitions, marcos, assembly codes
+ fixes in existing codes and configurations.
* arc: Update detailed board configurations for cores of emsk 2.3
* script: Provide arc_debugger.sh for debugging em_starterkit board
+ make BOARD=em_starterkit debug
This will start openocd server for emsk, and arc gdb will connect
to this debug server, user can run `continue` command if user just
want to run the application, or other commands if debugging needed.
+ make BOARD=em_starterkit debugserver
This will start an openocd debugger server for emsk, and user can
connect to this debugserver using arc gdb and do what they want to.
+ make BOARD=em_starterkit flash
This will download the zephyr application elf file to emsk,
and run it.
Signed-off-by: Huaqi Fang <huaqi.fang@synopsys.com>
2017-05-17 09:18:51 +02:00
|
|
|
|
|
|
|
config CODE_DENSITY
|
2018-08-14 16:19:20 +02:00
|
|
|
bool "Code Density Option"
|
boards: Update arc em_starterkit support from 2.2 to 2.3
Here are the main changes:
* board: Update EMSK onboard resources such as Button, Switch and LEDs
+ update soc.h for em7d, em9d, em11d
+ update board.h for em_starterkit board
* arc: Add floating point support and code density support
+ add kconfig configuration
+ add compiler options
+ add register definitions, marcos, assembly codes
+ fixes in existing codes and configurations.
* arc: Update detailed board configurations for cores of emsk 2.3
* script: Provide arc_debugger.sh for debugging em_starterkit board
+ make BOARD=em_starterkit debug
This will start openocd server for emsk, and arc gdb will connect
to this debug server, user can run `continue` command if user just
want to run the application, or other commands if debugging needed.
+ make BOARD=em_starterkit debugserver
This will start an openocd debugger server for emsk, and user can
connect to this debugserver using arc gdb and do what they want to.
+ make BOARD=em_starterkit flash
This will download the zephyr application elf file to emsk,
and run it.
Signed-off-by: Huaqi Fang <huaqi.fang@synopsys.com>
2017-05-17 09:18:51 +02:00
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
Enable code density option to get better code density
|
boards: Update arc em_starterkit support from 2.2 to 2.3
Here are the main changes:
* board: Update EMSK onboard resources such as Button, Switch and LEDs
+ update soc.h for em7d, em9d, em11d
+ update board.h for em_starterkit board
* arc: Add floating point support and code density support
+ add kconfig configuration
+ add compiler options
+ add register definitions, marcos, assembly codes
+ fixes in existing codes and configurations.
* arc: Update detailed board configurations for cores of emsk 2.3
* script: Provide arc_debugger.sh for debugging em_starterkit board
+ make BOARD=em_starterkit debug
This will start openocd server for emsk, and arc gdb will connect
to this debug server, user can run `continue` command if user just
want to run the application, or other commands if debugging needed.
+ make BOARD=em_starterkit debugserver
This will start an openocd debugger server for emsk, and user can
connect to this debugserver using arc gdb and do what they want to.
+ make BOARD=em_starterkit flash
This will download the zephyr application elf file to emsk,
and run it.
Signed-off-by: Huaqi Fang <huaqi.fang@synopsys.com>
2017-05-17 09:18:51 +02:00
|
|
|
|
2019-07-30 13:53:30 +02:00
|
|
|
config ARC_HAS_ACCL_REGS
|
2022-08-23 12:33:27 +02:00
|
|
|
bool "Reg Pair ACCL:ACCH (FPU and/or MPY > 6 and/or DSP)"
|
|
|
|
default y if CPU_HS3X || CPU_HS4X || CPU_HS5X || CPU_HS6X
|
2019-07-30 13:53:30 +02:00
|
|
|
help
|
|
|
|
Depending on the configuration, CPU can contain accumulator reg-pair
|
|
|
|
(also referred to as r58:r59). These can also be used by gcc as GPR so
|
|
|
|
kernel needs to save/restore per process
|
|
|
|
|
2019-08-01 06:39:35 +02:00
|
|
|
config ARC_HAS_SECURE
|
|
|
|
bool "ARC has SecureShield"
|
2021-03-30 23:48:35 +02:00
|
|
|
depends on ISA_ARCV2
|
2019-08-01 06:39:35 +02:00
|
|
|
select CPU_HAS_TEE
|
|
|
|
select ARCH_HAS_TRUSTED_EXECUTION
|
|
|
|
help
|
|
|
|
This option is enabled when ARC core supports secure mode
|
|
|
|
|
|
|
|
config SJLI_TABLE_SIZE
|
|
|
|
int "SJLI table size"
|
|
|
|
depends on ARC_SECURE_FIRMWARE
|
|
|
|
default 8
|
|
|
|
help
|
|
|
|
The size of sjli (Secure Jump and Link Indexed) table. The
|
|
|
|
code in normal mode call secure services in secure mode through
|
|
|
|
sjli instruction.
|
|
|
|
|
|
|
|
config ARC_SECURE_FIRMWARE
|
2019-12-02 16:57:17 +01:00
|
|
|
bool "Generate Secure Firmware"
|
2019-08-01 06:39:35 +02:00
|
|
|
depends on ARC_HAS_SECURE
|
|
|
|
default y if TRUSTED_EXECUTION_SECURE
|
|
|
|
help
|
|
|
|
This option indicates that we are building a Zephyr image that
|
|
|
|
is intended to execute in secure mode. The option is only
|
|
|
|
applicable to ARC processors that implement the SecureShield.
|
|
|
|
|
|
|
|
This option enables Zephyr to include code that executes in
|
|
|
|
secure mode, as well as to exclude code that is designed to
|
|
|
|
execute only in normal mode.
|
|
|
|
|
|
|
|
Code executing in secure mode has access to both the secure
|
|
|
|
and normal resources of the ARC processors.
|
|
|
|
|
|
|
|
config ARC_NORMAL_FIRMWARE
|
2019-12-02 16:57:17 +01:00
|
|
|
bool "Generate Normal Firmware"
|
2019-08-01 06:39:35 +02:00
|
|
|
depends on !ARC_SECURE_FIRMWARE
|
|
|
|
depends on ARC_HAS_SECURE
|
|
|
|
default y if TRUSTED_EXECUTION_NONSECURE
|
|
|
|
help
|
|
|
|
This option indicates that we are building a Zephyr image that
|
|
|
|
is intended to execute in normal mode. Execution of this
|
|
|
|
image is triggered by secure firmware that executes in secure
|
|
|
|
mode. The option is only applicable to ARC processors that
|
|
|
|
implement the SecureShield.
|
|
|
|
|
|
|
|
This option enables Zephyr to include code that executes in
|
|
|
|
normal mode only, as well as to exclude code that is
|
|
|
|
designed to execute only in secure mode.
|
|
|
|
|
|
|
|
Code executing in normal mode has no access to secure
|
|
|
|
resources of the ARC processors, and, therefore, it shall avoid
|
|
|
|
accessing them.
|
|
|
|
|
2022-10-17 10:05:27 +02:00
|
|
|
source "arch/arc/core/dsp/Kconfig"
|
|
|
|
|
2017-08-15 06:20:42 +02:00
|
|
|
menu "ARC MPU Options"
|
|
|
|
depends on CPU_HAS_MPU
|
|
|
|
|
|
|
|
config ARC_MPU_ENABLE
|
2022-03-09 12:31:16 +01:00
|
|
|
bool "Memory Protection Unit (MPU)"
|
2017-08-15 06:20:42 +02:00
|
|
|
select ARC_MPU
|
|
|
|
help
|
|
|
|
Enable MPU
|
|
|
|
|
|
|
|
source "arch/arc/core/mpu/Kconfig"
|
|
|
|
|
|
|
|
endmenu
|
|
|
|
|
2020-12-02 15:44:49 +01:00
|
|
|
config DCACHE_LINE_SIZE
|
2016-11-04 22:48:23 +01:00
|
|
|
default 32
|
|
|
|
|
2019-09-26 15:40:42 +02:00
|
|
|
config ARC_EXCEPTION_STACK_SIZE
|
|
|
|
int "ARC exception handling stack size"
|
2021-07-28 18:37:39 +02:00
|
|
|
default 768 if !64BIT
|
|
|
|
default 2048 if 64BIT
|
2019-09-26 15:40:42 +02:00
|
|
|
help
|
|
|
|
Size in bytes of exception handling stack which is at the top of
|
|
|
|
interrupt stack to get smaller memory footprint because exception
|
|
|
|
is not frequent. To reduce the impact on interrupt handling,
|
|
|
|
especially nested interrupt, it cannot be too large.
|
|
|
|
|
2016-11-04 22:48:23 +01:00
|
|
|
endmenu
|
2015-06-20 15:23:14 +02:00
|
|
|
|
2022-08-23 12:33:27 +02:00
|
|
|
config ARC_EARLY_SOC_INIT
|
|
|
|
bool "Make early stage SoC-specific initialization"
|
|
|
|
help
|
|
|
|
Call SoC per-core setup code on early stage initialization
|
|
|
|
(before C runtime initialization). Setup code is called in form of
|
|
|
|
soc_early_asm_init_percpu assembler macro.
|
|
|
|
|
2021-04-07 20:04:31 +02:00
|
|
|
config MAIN_STACK_SIZE
|
|
|
|
default 4096 if 64BIT
|
|
|
|
|
2021-07-28 18:37:39 +02:00
|
|
|
config ISR_STACK_SIZE
|
|
|
|
default 4096 if 64BIT
|
|
|
|
|
|
|
|
config SYSTEM_WORKQUEUE_STACK_SIZE
|
|
|
|
default 4096 if 64BIT
|
|
|
|
|
|
|
|
config IDLE_STACK_SIZE
|
2021-04-07 20:04:31 +02:00
|
|
|
default 1024 if 64BIT
|
|
|
|
|
2021-07-28 18:37:39 +02:00
|
|
|
config IPM_CONSOLE_STACK_SIZE
|
|
|
|
default 2048 if 64BIT
|
|
|
|
|
2022-02-17 17:09:09 +01:00
|
|
|
config TEST_EXTRA_STACK_SIZE
|
2021-07-28 18:37:39 +02:00
|
|
|
default 2048 if 64BIT
|
|
|
|
|
2021-04-07 20:04:31 +02:00
|
|
|
config CMSIS_THREAD_MAX_STACK_SIZE
|
2021-07-28 18:37:39 +02:00
|
|
|
default 2048 if 64BIT
|
2021-04-07 20:04:31 +02:00
|
|
|
|
|
|
|
config CMSIS_V2_THREAD_MAX_STACK_SIZE
|
2021-07-28 18:37:39 +02:00
|
|
|
default 2048 if 64BIT
|
|
|
|
|
|
|
|
config CMSIS_V2_THREAD_DYNAMIC_STACK_SIZE
|
|
|
|
default 2048 if 64BIT
|
2022-09-14 22:23:15 +02:00
|
|
|
|
|
|
|
endmenu
|