blob: deccbcca135faea16a749a19d6a0b9aced6cba83 [file] [log] [blame]
Ulf Magnussonbd6e0442019-11-01 13:45:29 +01001# General architecture configuration options
Juan Manuel Cruzd15251f2015-05-20 11:40:39 -05002
Juan Manuel Cruzd15251f2015-05-20 11:40:39 -05003# Copyright (c) 2014-2015 Wind River Systems, Inc.
4# Copyright (c) 2015 Intel Corporation
Mazen NEIFER1cded672017-01-13 12:14:33 +01005# Copyright (c) 2016 Cadence Design Systems, Inc.
David B. Kinderac74d8b2017-01-18 17:01:01 -08006# SPDX-License-Identifier: Apache-2.0
Juan Manuel Cruzd15251f2015-05-20 11:40:39 -05007
Ulf Magnussonec3eff52018-07-30 10:57:47 +02008# Include these first so that any properties (e.g. defaults) below can be
Anas Nashiff2cb20c2019-06-18 14:45:40 -04009# overridden (by defining symbols in multiple locations)
Ulf Magnussonec3eff52018-07-30 10:57:47 +020010
Ulf Magnussond0e87522018-09-05 12:58:05 +020011# Note: $ARCH might be a glob pattern
Klaus Petersenc66cb762018-11-15 10:37:46 +010012source "$(ARCH_DIR)/$(ARCH)/Kconfig"
Ulf Magnussonec3eff52018-07-30 10:57:47 +020013
Ulf Magnussonc5839f82020-02-06 18:26:14 +010014# Architecture symbols
15#
16# Should be 'select'ed by low-level symbols like SOC_SERIES_* or, lacking that,
17# by SOC_*.
Anas Nashif77ba3c32015-10-09 06:20:52 -040018
19config ARC
Ulf Magnussonc5839f82020-02-06 18:26:14 +010020 bool
Ulf Magnussonde42aea2020-02-07 00:48:22 +010021 select ARCH_IS_SET
Kumar Gala311e6b92018-03-14 19:16:40 -050022 select HAS_DTS
Anas Nashifce595102020-08-02 10:45:10 -040023 imply XIP
Daniel Leungc7704d82020-10-30 10:21:40 -070024 select ARCH_HAS_THREAD_LOCAL_STORAGE
Ulf Magnussonc5839f82020-02-06 18:26:14 +010025 help
26 ARC architecture
Anas Nashif77ba3c32015-10-09 06:20:52 -040027
28config ARM
Ulf Magnussonc5839f82020-02-06 18:26:14 +010029 bool
Ulf Magnussonde42aea2020-02-07 00:48:22 +010030 select ARCH_IS_SET
Daniel Leung181d0732020-08-18 12:55:08 -070031 select ARCH_SUPPORTS_COREDUMP if CPU_CORTEX_M
Kumar Gala37f91132018-11-03 07:19:18 -050032 select HAS_DTS
Andrew Boie28be7932020-03-11 10:56:19 -070033 # FIXME: current state of the code for all ARM requires this, but
34 # is really only necessary for Cortex-M with ARM MPU!
Carlo Caione3539c2f2021-03-25 11:56:15 +010035 select GEN_PRIV_STACKS
Bradley Bolenc0dd5942021-10-29 19:24:17 -040036 select ARCH_HAS_THREAD_LOCAL_STORAGE if CPU_AARCH32_CORTEX_R || CPU_CORTEX_M
Ulf Magnussonc5839f82020-02-06 18:26:14 +010037 help
38 ARM architecture
Anas Nashif77ba3c32015-10-09 06:20:52 -040039
Carlo Caione3539c2f2021-03-25 11:56:15 +010040config ARM64
41 bool
42 select ARCH_IS_SET
43 select 64BIT
44 select HAS_DTS
45 select HAS_ARM_SMCCC
46 select ARCH_HAS_THREAD_LOCAL_STORAGE
47 select USE_SWITCH
48 select USE_SWITCH_SUPPORTED
Nicolas Pitrebd941bc2022-03-11 21:29:06 -050049 select IRQ_OFFLOAD_NESTED if IRQ_OFFLOAD
Carlo Caione3539c2f2021-03-25 11:56:15 +010050 help
51 ARM64 (AArch64) architecture
52
Antony Pavlov03699982020-12-01 13:29:58 +030053config MIPS
54 bool
55 select ARCH_IS_SET
56 select ATOMIC_OPERATIONS_C
57 select HAS_DTS
58 help
59 MIPS architecture
60
Martin Åberg07160fa2020-10-16 20:53:59 +020061config SPARC
62 bool
63 select ARCH_IS_SET
Morten Priessa0dd44c2021-04-21 15:15:26 +020064 select HAS_DTS
Martin Åberg07160fa2020-10-16 20:53:59 +020065 select USE_SWITCH
66 select USE_SWITCH_SUPPORTED
67 select BIG_ENDIAN
68 select ATOMIC_OPERATIONS_BUILTIN if SPARC_CASA
69 select ATOMIC_OPERATIONS_C if !SPARC_CASA
Martin Åbergfeae3242020-10-27 12:31:41 +010070 select ARCH_HAS_THREAD_LOCAL_STORAGE
Martin Åberg83f733c2021-02-16 15:38:58 +010071 select ARCH_HAS_EXTRA_EXCEPTION_INFO
Martin Åberg07160fa2020-10-16 20:53:59 +020072 help
73 SPARC architecture
74
Anas Nashif77ba3c32015-10-09 06:20:52 -040075config X86
Ulf Magnussonc5839f82020-02-06 18:26:14 +010076 bool
Ulf Magnussonde42aea2020-02-07 00:48:22 +010077 select ARCH_IS_SET
Andrew Boie6a1474e2016-07-15 13:15:00 -070078 select ATOMIC_OPERATIONS_BUILTIN
Kumar Gala37f91132018-11-03 07:19:18 -050079 select HAS_DTS
Daniel Leung8fbb14e2020-08-13 19:18:52 -070080 select ARCH_SUPPORTS_COREDUMP
Andrew Boieff294e02020-06-12 16:50:16 -070081 select CPU_HAS_MMU
Andrew Boied2a72272020-10-27 11:27:37 -070082 select ARCH_MEM_DOMAIN_DATA if USERSPACE && !X86_COMMON_PAGE_TABLE
Andrew Boie00f71b02020-08-25 17:02:38 -070083 select ARCH_MEM_DOMAIN_SYNCHRONOUS_API if USERSPACE
Flavio Ceolin5408f312020-05-21 16:55:28 -070084 select ARCH_HAS_GDBSTUB if !X86_64
Anas Nashif5dec2352020-08-27 23:07:01 -040085 select ARCH_HAS_TIMING_FUNCTIONS
Daniel Leung4b383922020-09-29 15:32:35 -070086 select ARCH_HAS_THREAD_LOCAL_STORAGE
Andrew Boieed220642020-12-09 10:37:52 -080087 select ARCH_HAS_DEMAND_PAGING
Andy Ross73453a32022-02-14 14:30:34 -080088 select IRQ_OFFLOAD_NESTED if IRQ_OFFLOAD
Daniel Leung1eba3542021-03-31 14:51:58 -070089 select NEED_LIBC_MEM_PARTITION if USERSPACE && TIMING_FUNCTIONS \
90 && !BOARD_HAS_TIMING_FUNCTIONS \
91 && !SOC_HAS_TIMING_FUNCTIONS
Ulf Magnussonc5839f82020-02-06 18:26:14 +010092 help
93 x86 architecture
Anas Nashif77ba3c32015-10-09 06:20:52 -040094
Andrew Boie94338952016-04-21 14:47:09 -070095config NIOS2
Ulf Magnussonc5839f82020-02-06 18:26:14 +010096 bool
Ulf Magnussonde42aea2020-02-07 00:48:22 +010097 select ARCH_IS_SET
Andrew Boie6a1474e2016-07-15 13:15:00 -070098 select ATOMIC_OPERATIONS_C
Kumar Gala37f91132018-11-03 07:19:18 -050099 select HAS_DTS
Anas Nashifce595102020-08-02 10:45:10 -0400100 imply XIP
Anas Nashif150c82c2020-08-27 23:16:48 -0400101 select ARCH_HAS_TIMING_FUNCTIONS
Ulf Magnussonc5839f82020-02-06 18:26:14 +0100102 help
103 Nios II Gen 2 architecture
Andrew Boie94338952016-04-21 14:47:09 -0700104
Nicolas Pitre1f4b5dd2019-07-17 13:17:05 -0400105config RISCV
Ulf Magnussonc5839f82020-02-06 18:26:14 +0100106 bool
Ulf Magnussonde42aea2020-02-07 00:48:22 +0100107 select ARCH_IS_SET
Kumar Gala8ded3fb2018-11-02 13:29:59 -0500108 select HAS_DTS
Mark Holden1a697cc2021-11-12 13:21:43 -0800109 select ARCH_SUPPORTS_COREDUMP
Daniel Leung8a79ce12020-10-02 13:09:32 -0700110 select ARCH_HAS_THREAD_LOCAL_STORAGE
Nicolas Pitredf852a02022-03-14 14:51:04 -0400111 select IRQ_OFFLOAD_NESTED if IRQ_OFFLOAD
Ederson de Souza2aab2362022-01-05 14:33:11 -0800112 select SCHED_IPI_SUPPORTED if SMP
Anas Nashifce595102020-08-02 10:45:10 -0400113 imply XIP
Ulf Magnussonc5839f82020-02-06 18:26:14 +0100114 help
115 RISCV architecture
Jean-Paul Etiennecd83e852017-01-11 00:24:30 +0100116
Mazen NEIFER1cded672017-01-13 12:14:33 +0100117config XTENSA
Ulf Magnussonc5839f82020-02-06 18:26:14 +0100118 bool
Ulf Magnussonde42aea2020-02-07 00:48:22 +0100119 select ARCH_IS_SET
Kumar Gala31503a82019-02-01 07:52:05 -0600120 select HAS_DTS
Andrew Boie6fd6b7e2019-08-13 14:02:29 -0700121 select USE_SWITCH
122 select USE_SWITCH_SUPPORTED
Andy Ross73453a32022-02-14 14:30:34 -0800123 select IRQ_OFFLOAD_NESTED if IRQ_OFFLOAD
Daniel Leung64e99df2021-04-01 11:35:31 -0700124 imply ATOMIC_OPERATIONS_ARCH
Ulf Magnussonc5839f82020-02-06 18:26:14 +0100125 help
126 Xtensa architecture
Mazen NEIFER1cded672017-01-13 12:14:33 +0100127
Alberto Escolar Piedras76f764412017-10-03 16:31:55 +0200128config ARCH_POSIX
Ulf Magnussonc5839f82020-02-06 18:26:14 +0100129 bool
Ulf Magnussonde42aea2020-02-07 00:48:22 +0100130 select ARCH_IS_SET
Kumar Galacd889022020-04-03 14:08:58 -0500131 select HAS_DTS
Alberto Escolar Piedras76f764412017-10-03 16:31:55 +0200132 select ATOMIC_OPERATIONS_BUILTIN
133 select ARCH_HAS_CUSTOM_SWAP_TO_MAIN
134 select ARCH_HAS_CUSTOM_BUSY_WAIT
135 select ARCH_HAS_THREAD_ABORT
136 select NATIVE_APPLICATION
Alberto Escolar Piedras2cd70e62019-02-03 13:04:17 +0100137 select HAS_COVERAGE_SUPPORT
Ulf Magnussonc5839f82020-02-06 18:26:14 +0100138 help
139 POSIX (native) architecture
Anas Nashif46f66f42017-09-08 21:14:06 -0400140
Ulf Magnussonde42aea2020-02-07 00:48:22 +0100141config ARCH_IS_SET
142 bool
143 help
144 Helper symbol to detect SoCs forgetting to select one of the arch
145 symbols above. See the top-level CMakeLists.txt.
146
Anas Nashif46f66f42017-09-08 21:14:06 -0400147menu "General Architecture Options"
148
Anas Nashif8e386702018-09-17 09:56:20 -0500149module = ARCH
150module-str = arch
151source "subsys/logging/Kconfig.template.log_config"
152
153module = MPU
154module-str = mpu
155source "subsys/logging/Kconfig.template.log_config"
156
Yasushi SHOJI6fc0d772018-10-09 18:59:16 +0900157config BIG_ENDIAN
Ulf Magnusson975de212019-11-01 10:24:07 +0100158 bool
159 help
160 This option tells the build system that the target system is big-endian.
161 Little-endian architecture is the default and should leave this option
162 unselected. This option is selected by arch/$ARCH/Kconfig,
163 soc/**/Kconfig, or boards/**/Kconfig and the user should generally avoid
164 modifying it. The option is used to select linker script OUTPUT_FORMAT
165 and command line option for gen_isr_tables.py.
Yasushi SHOJI6fc0d772018-10-09 18:59:16 +0900166
Nicolas Pitre9bd9b752019-05-17 15:15:24 -0400167config 64BIT
168 bool
169 help
170 This option tells the build system that the target system is
171 using a 64-bit address space, meaning that pointer and long types
172 are 64 bits wide. This option is selected by arch/$ARCH/Kconfig,
173 soc/**/Kconfig, or boards/**/Kconfig and the user should generally
174 avoid modifying it.
175
Kumar Gala8ce0cf02019-08-28 09:29:26 -0500176# Workaround for not being able to have commas in macro arguments
177DT_CHOSEN_Z_SRAM := zephyr,sram
178
Kumar Galace7ed182018-12-07 10:35:04 -0600179config SRAM_SIZE
180 int "SRAM Size in kB"
Kumar Gala22e74492019-10-23 15:15:59 -0500181 default $(dt_chosen_reg_size_int,$(DT_CHOSEN_Z_SRAM),0,K)
Kumar Galace7ed182018-12-07 10:35:04 -0600182 help
Ulf Magnussondef1f0e2019-12-26 16:08:19 +0100183 The SRAM size in kB. The default value comes from /chosen/zephyr,sram in
184 devicetree. The user should generally avoid changing it via menuconfig or
185 in configuration files.
Kumar Galace7ed182018-12-07 10:35:04 -0600186
187config SRAM_BASE_ADDRESS
188 hex "SRAM Base Address"
Kumar Gala22e74492019-10-23 15:15:59 -0500189 default $(dt_chosen_reg_addr_hex,$(DT_CHOSEN_Z_SRAM))
Kumar Galace7ed182018-12-07 10:35:04 -0600190 help
Ulf Magnussondef1f0e2019-12-26 16:08:19 +0100191 The SRAM base address. The default value comes from from
192 /chosen/zephyr,sram in devicetree. The user should generally avoid
193 changing it via menuconfig or in configuration files.
194
Carlo Caione3539c2f2021-03-25 11:56:15 +0100195if ARC || ARM || ARM64 || NIOS2 || X86
Kumar Galace7ed182018-12-07 10:35:04 -0600196
Kumar Gala8ce0cf02019-08-28 09:29:26 -0500197# Workaround for not being able to have commas in macro arguments
198DT_CHOSEN_Z_FLASH := zephyr,flash
199
Kumar Galace7ed182018-12-07 10:35:04 -0600200config FLASH_SIZE
201 int "Flash Size in kB"
Carlo Caione3539c2f2021-03-25 11:56:15 +0100202 default $(dt_chosen_reg_size_int,$(DT_CHOSEN_Z_FLASH),0,K) if (XIP && (ARM ||ARM64)) || !ARM
Kumar Galace7ed182018-12-07 10:35:04 -0600203 help
204 This option specifies the size of the flash in kB. It is normally set by
205 the board's defconfig file and the user should generally avoid modifying
206 it via the menu configuration.
207
208config FLASH_BASE_ADDRESS
209 hex "Flash Base Address"
Carlo Caione3539c2f2021-03-25 11:56:15 +0100210 default $(dt_chosen_reg_addr_hex,$(DT_CHOSEN_Z_FLASH)) if (XIP && (ARM || ARM64)) || !ARM
Kumar Galace7ed182018-12-07 10:35:04 -0600211 help
Ioannis Glaropoulos0348c532019-02-12 15:16:16 +0100212 This option specifies the base address of the flash on the board. It is
Kumar Galace7ed182018-12-07 10:35:04 -0600213 normally set by the board's defconfig file and the user should generally
214 avoid modifying it via the menu configuration.
215
Carlo Caione3539c2f2021-03-25 11:56:15 +0100216endif # ARM || ARM64 || ARC || NIOS2 || X86
Kumar Galace7ed182018-12-07 10:35:04 -0600217
Ioannis Glaropoulos1cc66cf2018-10-12 09:27:28 +0200218if ARCH_HAS_TRUSTED_EXECUTION
219
220config TRUSTED_EXECUTION_SECURE
221 bool "Trusted Execution: Secure firmware image"
222 help
223 Select this option to enable building a Secure firmware
224 image for a platform that supports Trusted Execution. A
225 Secure firmware image will execute in Secure state. It may
226 allow the CPU to execute in Non-Secure (Normal) state.
227 Therefore, a Secure firmware image shall be able to
228 configure security attributions of CPU resources (memory
229 areas, peripherals, interrupts, etc.) as well as to handle
230 faults, related to security violations. It may optionally
231 allow certain functions to be called from the Non-Secure
232 (Normal) domain.
233
234config TRUSTED_EXECUTION_NONSECURE
235 depends on !TRUSTED_EXECUTION_SECURE
236 bool "Trusted Execution: Non-Secure firmware image"
237 help
238 Select this option to enable building a Non-Secure
239 firmware image for a platform that supports Trusted
240 Execution. A Non-Secure firmware image will execute
241 in Non-Secure (Normal) state. Therefore, it shall not
242 access CPU resources (memory areas, peripherals,
243 interrupts etc.) belonging to the Secure domain.
244
245endif # ARCH_HAS_TRUSTED_EXECUTION
246
Anas Nashif46f66f42017-09-08 21:14:06 -0400247config HW_STACK_PROTECTION
248 bool "Hardware Stack Protection"
249 depends on ARCH_HAS_STACK_PROTECTION
250 help
Anas Nashif429c2a42017-12-13 10:08:21 -0500251 Select this option to enable hardware-based platform features to
252 catch stack overflows when the system is running in privileged
253 mode. If CONFIG_USERSPACE is not enabled, the system is always
254 running in privileged mode.
Andrew Boie2a8684f2017-11-06 11:42:54 -0800255
Anas Nashif429c2a42017-12-13 10:08:21 -0500256 Note that this does not necessarily prevent corruption and assertions
257 about the overall system state when a fault is triggered cannot be
258 made.
Anas Nashif46f66f42017-09-08 21:14:06 -0400259
Andrew Boie9f70c7b2017-09-11 10:34:49 -0700260config USERSPACE
Andrew Boie53b52042019-01-18 11:41:06 -0800261 bool "User mode threads"
Andrew Boie9f70c7b2017-09-11 10:34:49 -0700262 depends on ARCH_HAS_USERSPACE
Anas Nashif22b95a22019-11-24 11:28:38 -0500263 depends on RUNTIME_ERROR_CHECKS
Andrew Boie5a58ad52020-11-05 14:30:20 -0800264 depends on SRAM_REGION_PERMISSIONS
Carlo Caioned7708802020-11-12 14:44:14 +0100265 select THREAD_STACK_INFO
Andrew Boie9f70c7b2017-09-11 10:34:49 -0700266 help
Anas Nashif429c2a42017-12-13 10:08:21 -0500267 When enabled, threads may be created or dropped down to user mode,
268 which has significantly restricted permissions and must interact
269 with the kernel via system calls. See Zephyr documentation for more
Dominik Ermel86a12522021-07-15 10:08:48 +0000270 details about this feature.
Andrew Boie9f70c7b2017-09-11 10:34:49 -0700271
Anas Nashif429c2a42017-12-13 10:08:21 -0500272 If a user thread overflows its stack, this will be caught and the
273 kernel itself will be shielded from harm. Enabling this option
274 may or may not catch stack overflows when the system is in
275 privileged mode or handling a system call; to ensure these are always
276 caught, enable CONFIG_HW_STACK_PROTECTION.
Andrew Boie2a8684f2017-11-06 11:42:54 -0800277
Chunlin Han18560a02018-02-01 01:19:49 -0600278config PRIVILEGED_STACK_SIZE
279 int "Size of privileged stack"
Andrew Boie606e6072019-03-28 16:48:43 -0700280 default 1024
Chunlin Han18560a02018-02-01 01:19:49 -0600281 depends on ARCH_HAS_USERSPACE
282 help
Anas Nashif89492332018-02-15 07:36:16 -0600283 This option sets the privileged stack region size that will be used
284 in addition to the user mode thread stack. During normal execution,
285 this region will be inaccessible from user mode. During system calls,
Andrew Boie28be7932020-03-11 10:56:19 -0700286 this region will be utilized by the system call. This value must be
287 a multiple of the minimum stack alignment.
Anas Nashifeb299782018-10-07 11:41:18 -0400288
289config KOBJECT_TEXT_AREA
Daniel Leung11171692021-03-18 14:00:07 -0700290 int "Size of kobject text area"
Adithya Baglody71e90f92018-08-29 16:44:16 +0530291 default 512 if COVERAGE_GCOV
Sebastian Bøeefc6d0a2019-03-15 10:54:06 +0100292 default 512 if NO_OPTIMIZATIONS
Alexandre Mergnat4b976192020-10-29 19:20:06 +0100293 default 512 if STACK_CANARIES && RISCV
Andrew Boie794d3822019-02-20 14:49:36 -0800294 default 256
Anas Nashifeb299782018-10-07 11:41:18 -0400295 depends on ARCH_HAS_USERSPACE
296 help
297 Size of kernel object text area. Used in linker script.
298
Daniel Leung11171692021-03-18 14:00:07 -0700299config KOBJECT_DATA_AREA_RESERVE_EXTRA_PERCENT
300 int "Reserve extra kobject data area (in percentage)"
301 default 100
302 depends on ARCH_HAS_USERSPACE
303 help
304 Multiplication factor used to calculate the size of placeholder to
305 reserve space for kobject metadata hash table. The hash table is
306 generated via gperf is highly dependent on the absolute addresses of
307 kobjects which might change between prebuilts. To reserve enough
308 space for the hash table during final linking passes to keep
309 kobjects in same place, the size of reserved space is calculated
310 from the first prebuilt plus additional space calculated with
311 this percentage (of the kobject data area in first prebuilt).
312
313config KOBJECT_RODATA_AREA_EXTRA_BYTES
314 int "Reserve extra bytes for kobject rodata area"
315 default 16
316 depends on ARCH_HAS_USERSPACE
317 help
318 Reserve a few more bytes for the RODATA region for kobject metadata.
319 This is to account for the uncertainty of tables generated by gperf.
320
Andrew Boie28be7932020-03-11 10:56:19 -0700321config GEN_PRIV_STACKS
322 bool
323 help
324 Selected if the architecture requires that privilege elevation stacks
325 be allocated in a separate memory area. This is typical of arches
326 whose MPUs require regions to be power-of-two aligned/sized.
327
328 FIXME: This should be removed and replaced with checks against
329 CONFIG_MPU_REQUIRES_POWER_OF_TWO_ALIGNMENT, but both ARM and ARC
330 changes will be necessary for this.
331
Andrew Boiea9679152018-03-06 13:17:57 -0800332config STACK_GROWS_UP
333 bool "Stack grows towards higher memory addresses"
Andrew Boiea9679152018-03-06 13:17:57 -0800334 help
335 Select this option if the architecture has upward growing thread
336 stacks. This is not common.
337
Andrew Boieefc5fe02020-02-05 10:41:58 -0800338config NO_UNUSED_STACK_INSPECTION
339 bool
340 help
341 Selected if the architecture will generate a fault if unused stack
342 memory is examined, which is the region between the current stack
343 pointer and the deepest available address in the current stack
344 region.
345
Andrew Boie9f70c7b2017-09-11 10:34:49 -0700346config MAX_THREAD_BYTES
347 int "Bytes to use when tracking object thread permissions"
348 default 2
349 depends on USERSPACE
350 help
Anas Nashif429c2a42017-12-13 10:08:21 -0500351 Every kernel object will have an associated bitfield to store
352 thread permissions for that object. This controls the size of the
353 bitfield (in bytes) and imposes a limit on how many threads can
354 be created in the system.
Andrew Boie9f70c7b2017-09-11 10:34:49 -0700355
Andrew Boie31bdfc02017-11-08 16:38:03 -0800356config DYNAMIC_OBJECTS
Andrew Boie97bf0012018-04-24 17:01:37 -0700357 bool "Allow kernel objects to be allocated at runtime"
Andrew Boie31bdfc02017-11-08 16:38:03 -0800358 depends on USERSPACE
Andrew Boie31bdfc02017-11-08 16:38:03 -0800359 help
Ulf Magnusson975de212019-11-01 10:24:07 +0100360 Enabling this option allows for kernel objects to be requested from
361 the calling thread's resource pool, at a slight cost in performance
362 due to the supplemental run-time tables required to validate such
363 objects.
Andrew Boie97bf0012018-04-24 17:01:37 -0700364
Ulf Magnusson975de212019-11-01 10:24:07 +0100365 Objects allocated in this way can be freed with a supervisor-only
366 API call, or when the number of references to that object drops to
367 zero.
Andrew Boie31bdfc02017-11-08 16:38:03 -0800368
Aurelien Jarno6fd16912018-11-07 23:40:43 +0100369config NOCACHE_MEMORY
370 bool "Support for uncached memory"
Ulf Magnusson378d6b12020-02-09 22:26:07 +0100371 depends on ARCH_HAS_NOCACHE_MEMORY_SUPPORT
Aurelien Jarno6fd16912018-11-07 23:40:43 +0100372 help
373 Add a "nocache" read-write memory section that is configured to
374 not be cached. This memory section can be used to perform DMA
375 transfers when cache coherence issues are not optimal or can not
376 be solved using cache maintenance operations.
377
Anas Nashif8379b7b2017-09-09 08:39:38 -0400378menu "Interrupt Configuration"
Ulf Magnusson41713242019-12-21 08:17:02 +0100379
Andrew Boieff6cce62018-10-30 16:53:56 -0700380config DYNAMIC_INTERRUPTS
Gerard Marull-Paretas95fb0de2022-03-09 12:05:12 +0100381 bool "Installation of IRQs at runtime"
Andrew Boieff6cce62018-10-30 16:53:56 -0700382 help
383 Enable installation of interrupts at runtime, which will move some
384 interrupt-related data structures to RAM instead of ROM, and
385 on some architectures increase code size.
386
Anas Nashif8379b7b2017-09-09 08:39:38 -0400387config GEN_ISR_TABLES
Ulf Magnusson8cf8db32018-08-14 16:19:20 +0200388 bool "Use generated IRQ tables"
Anas Nashif8379b7b2017-09-09 08:39:38 -0400389 help
Anas Nashif429c2a42017-12-13 10:08:21 -0500390 This option controls whether a platform uses the gen_isr_tables
391 script to generate its interrupt tables. This mechanism will create
392 an appropriate hardware vector table and/or software IRQ table.
Anas Nashif8379b7b2017-09-09 08:39:38 -0400393
394config GEN_IRQ_VECTOR_TABLE
Ulf Magnusson8cf8db32018-08-14 16:19:20 +0200395 bool "Generate an interrupt vector table"
Anas Nashif8379b7b2017-09-09 08:39:38 -0400396 default y
397 depends on GEN_ISR_TABLES
398 help
Anas Nashif429c2a42017-12-13 10:08:21 -0500399 This option controls whether a platform using gen_isr_tables
400 needs an interrupt vector table created. Only disable this if the
401 platform does not use a vector table at all, or requires the vector
402 table to be in a format that is not an array of function pointers
403 indexed by IRQ line. In the latter case, the vector table must be
404 supplied by the application or architecture code.
Anas Nashif8379b7b2017-09-09 08:39:38 -0400405
406config GEN_SW_ISR_TABLE
Ulf Magnusson8cf8db32018-08-14 16:19:20 +0200407 bool "Generate a software ISR table"
Anas Nashif8379b7b2017-09-09 08:39:38 -0400408 default y
409 depends on GEN_ISR_TABLES
410 help
Anas Nashif429c2a42017-12-13 10:08:21 -0500411 This option controls whether a platform using gen_isr_tables
412 needs a software ISR table table created. This is an array of struct
413 _isr_table_entry containing the interrupt service routine and supplied
414 parameter.
Anas Nashif8379b7b2017-09-09 08:39:38 -0400415
Yasushi SHOJI51bc0a02019-06-20 18:28:37 +0900416config ARCH_SW_ISR_TABLE_ALIGN
417 int "Alignment size of a software ISR table"
418 default 0
419 depends on GEN_SW_ISR_TABLE
420 help
421 This option controls alignment size of generated
422 _sw_isr_table. Some architecture needs a software ISR table
423 to be aligned to architecture specific size. The default
424 size is 0 for no alignment.
425
Anas Nashif8379b7b2017-09-09 08:39:38 -0400426config GEN_IRQ_START_VECTOR
427 int
428 default 0
429 depends on GEN_ISR_TABLES
430 help
Anas Nashif429c2a42017-12-13 10:08:21 -0500431 On some architectures, part of the vector table may be reserved for
432 system exceptions and is declared separately from the tables
433 created by gen_isr_tables.py. When creating these tables, this value
434 will be subtracted from CONFIG_NUM_IRQS to properly size them.
435 This is a hidden option which needs to be set per architecture and
436 left alone.
Anas Nashif8379b7b2017-09-09 08:39:38 -0400437
Anas Nashifa372eae2017-11-23 12:05:55 -0500438config IRQ_OFFLOAD
Gerard Marull-Paretas95fb0de2022-03-09 12:05:12 +0100439 bool "IRQ offload"
Andrew Boiebeba1e02019-11-07 10:33:09 -0800440 depends on TEST
Anas Nashifa372eae2017-11-23 12:05:55 -0500441 help
442 Enable irq_offload() API which allows functions to be synchronously
Andrew Boiebeba1e02019-11-07 10:33:09 -0800443 run in interrupt context. Only useful for test cases that need
444 to validate the correctness of kernel objects in IRQ context.
Anas Nashifa372eae2017-11-23 12:05:55 -0500445
Andy Ross73453a32022-02-14 14:30:34 -0800446config IRQ_OFFLOAD_NESTED
447 bool "irq_offload() supports nested IRQs"
448 depends on IRQ_OFFLOAD
449 help
450 When set by the arch layer, indicates that irq_offload() may
451 legally be called in interrupt context to cause a
452 synchronous nested interrupt on the current CPU. Not all
453 hardware is capable.
Chris Coleman99a268f2020-08-28 09:02:20 -0400454
455config EXTRA_EXCEPTION_INFO
456 bool "Collect extra exception info"
457 depends on ARCH_HAS_EXTRA_EXCEPTION_INFO
458 help
459 This option enables the collection of extra information, such as
460 register state, when a fault occurs. This information can be useful
461 to collect for post-mortem analysis and debug of issues.
462
Anas Nashif8379b7b2017-09-09 08:39:38 -0400463endmenu # Interrupt configuration
464
Ioannis Glaropoulos20a98482020-10-21 15:48:41 +0200465config INIT_ARCH_HW_AT_BOOT
466 bool "Initialize internal architecture state at boot"
467 depends on ARCH_SUPPORTS_ARCH_HW_INIT
468 help
469 This option instructs Zephyr to force the initialization
470 of the internal architectural state (for example ARCH-level
471 HW registers and system control blocks) during boot to
472 the reset values as specified by the corresponding
473 architecture manual. The option is useful when the Zephyr
474 firmware image is chain-loaded, for example, by a debugger
475 or a bootloader, and we need to guarantee that the internal
476 states of the architecture core blocks are restored to the
477 reset values (as specified by the architecture).
478
479 Note: the functionality is architecture-specific. For the
480 implementation details refer to each architecture where
481 this feature is supported.
482
Anas Nashif46f66f42017-09-08 21:14:06 -0400483endmenu
484
Anas Nashif8379b7b2017-09-09 08:39:38 -0400485#
486# Architecture Capabilities
487#
Ulf Magnusson41713242019-12-21 08:17:02 +0100488
Ioannis Glaropoulos40842422021-05-19 17:45:25 +0200489config ARCH_HAS_SINGLE_THREAD_SUPPORT
490 bool
491
Anas Nashif5dec2352020-08-27 23:07:01 -0400492config ARCH_HAS_TIMING_FUNCTIONS
493 bool
494
Ioannis Glaropoulos1cc66cf2018-10-12 09:27:28 +0200495config ARCH_HAS_TRUSTED_EXECUTION
496 bool
497
Anas Nashif46f66f42017-09-08 21:14:06 -0400498config ARCH_HAS_STACK_PROTECTION
499 bool
500
Andrew Boie9f70c7b2017-09-11 10:34:49 -0700501config ARCH_HAS_USERSPACE
502 bool
503
Leandro Pereirab007b642017-10-17 17:01:48 -0700504config ARCH_HAS_EXECUTABLE_PAGE_BIT
505 bool
506
Aurelien Jarno6fd16912018-11-07 23:40:43 +0100507config ARCH_HAS_NOCACHE_MEMORY_SUPPORT
508 bool
509
Aurelien Jarno992f29a2019-02-10 11:05:51 +0100510config ARCH_HAS_RAMFUNC_SUPPORT
511 bool
512
Ioannis Glaropoulosf0306082019-10-17 19:13:12 +0200513config ARCH_HAS_NESTED_EXCEPTION_DETECTION
514 bool
515
Daniel Leung49206a82020-08-07 10:47:37 -0700516config ARCH_SUPPORTS_COREDUMP
517 bool
518
Ioannis Glaropoulos20a98482020-10-21 15:48:41 +0200519config ARCH_SUPPORTS_ARCH_HW_INIT
520 bool
521
Chris Coleman99a268f2020-08-28 09:02:20 -0400522config ARCH_HAS_EXTRA_EXCEPTION_INFO
523 bool
524
Flavio Ceolin5408f312020-05-21 16:55:28 -0700525config ARCH_HAS_GDBSTUB
526 bool
527
Andy Rossf6d32ab2020-05-13 15:34:04 +0000528config ARCH_HAS_COHERENCE
529 bool
530 help
531 When selected, the architecture supports the
532 arch_mem_coherent() API and can link into incoherent/cached
533 memory using the ".cached" linker section.
534
Daniel Leung240beb42020-09-28 11:03:52 -0700535config ARCH_HAS_THREAD_LOCAL_STORAGE
536 bool
537
Ramesh Thomasbb19e6f2016-03-18 16:43:40 -0700538#
Anas Nashiff4ddb622017-12-05 09:07:39 -0500539# Other architecture related options
540#
541
542config ARCH_HAS_THREAD_ABORT
543 bool
544
Ulf Magnusson41713242019-12-21 08:17:02 +0100545#
546# Hidden CPU family configs
Anas Nashif9c1da0d2017-11-23 17:43:54 -0500547#
548
Ioannis Glaropoulos1cc66cf2018-10-12 09:27:28 +0200549config CPU_HAS_TEE
550 bool
551 help
552 This option is enabled when the CPU has support for Trusted
553 Execution Environment (e.g. when it has a security attribution
554 unit).
555
Stephanos Ioannidisbc8524e2019-10-09 00:52:18 +0900556config CPU_HAS_DCLS
557 bool
558 help
559 This option is enabled when the processor hardware is configured in
560 Dual-redundant Core Lock-step (DCLS) topology.
561
Anas Nashif9c1da0d2017-11-23 17:43:54 -0500562config CPU_HAS_FPU
563 bool
Anas Nashif9c1da0d2017-11-23 17:43:54 -0500564 help
565 This option is enabled when the CPU has hardware floating point
566 unit.
567
Corey Whartonc8f7cd52020-04-14 11:06:23 -0700568config CPU_HAS_FPU_DOUBLE_PRECISION
569 bool
570 select CPU_HAS_FPU
571 help
572 When enabled, this indicates that the CPU has a double floating point
573 precision unit.
574
Anas Nashif9c1da0d2017-11-23 17:43:54 -0500575config CPU_HAS_MPU
576 bool
Anas Nashif9c1da0d2017-11-23 17:43:54 -0500577 help
578 This option is enabled when the CPU has a Memory Protection Unit (MPU).
579
Andrew Boieff294e02020-06-12 16:50:16 -0700580config CPU_HAS_MMU
581 bool
582 help
583 This hidden option is selected when the CPU has a Memory Management Unit
584 (MMU).
Andrew Boie5a58ad52020-11-05 14:30:20 -0800585
Andrew Boie56a9e7b2020-11-16 11:30:35 -0800586config ARCH_HAS_DEMAND_PAGING
587 bool
588 help
589 This hidden configuration should be selected by the architecture if
590 demand paging is supported.
591
Andrew Boie73a3e052020-11-18 13:11:56 -0800592config ARCH_HAS_RESERVED_PAGE_FRAMES
593 bool
594 help
595 This hidden configuration should be selected by the architecture if
596 certain RAM page frames need to be marked as reserved and never used for
597 memory mappings. The architecture will need to implement
598 arch_reserved_pages_update().
599
Andrew Boie14c5d1f2021-01-23 14:08:12 -0800600config ARCH_MAPS_ALL_RAM
601 bool
602 help
603 This hidden option is selected by the architecture to inform the kernel
604 that all RAM is mapped at boot, and not just the bounds of the Zephyr image.
605 If RAM starts at 0x0, the first page must remain un-mapped to catch NULL
606 pointer dereferences. With this enabled, the kernel will not assume that
607 virtual memory addresses past the kernel image are available for mappings,
608 but instead takes into account an entire RAM mapping instead.
609
610 This is typically set by architectures which need direct access to all memory.
611 It is the architecture's responsibility to mark reserved memory regions
612 as such in arch_reserved_pages_update().
613
614 Although the kernel will not disturb this RAM mapping by re-mapping the associated
615 virtual addresses elsewhere, this is limited to only management of the
616 virtual address space. The kernel's page frame ontology will not consider
617 this mapping at all; non-kernel pages will be considered free (unless marked
618 as reserved) and Z_PAGE_FRAME_MAPPED will not be set.
619
Andrew Boie5a58ad52020-11-05 14:30:20 -0800620menuconfig MPU
Gerard Marull-Paretas95fb0de2022-03-09 12:05:12 +0100621 bool "MPU features"
Andrew Boie5a58ad52020-11-05 14:30:20 -0800622 depends on CPU_HAS_MPU
Ioannis Glaropoulos39bf24a2018-11-27 15:45:36 +0100623 help
Andrew Boie5a58ad52020-11-05 14:30:20 -0800624 This option, when enabled, indicates to the core kernel that an MPU
625 is enabled.
Ioannis Glaropoulos39bf24a2018-11-27 15:45:36 +0100626
Andrew Boie5a58ad52020-11-05 14:30:20 -0800627if MPU
Andy Grosse8860fe2018-02-01 01:12:32 -0600628config MPU_REQUIRES_POWER_OF_TWO_ALIGNMENT
629 bool
Andy Grosse8860fe2018-02-01 01:12:32 -0600630 help
Anas Nashif89492332018-02-15 07:36:16 -0600631 This option is enabled when the MPU requires a power of two alignment
632 and size for MPU regions.
Andy Grosse8860fe2018-02-01 01:12:32 -0600633
Ioannis Glaropoulosafa78192018-09-25 14:05:56 +0200634config MPU_REQUIRES_NON_OVERLAPPING_REGIONS
635 bool
Ioannis Glaropoulosafa78192018-09-25 14:05:56 +0200636 help
637 This option is enabled when the MPU requires the active (i.e. enabled)
638 MPU regions to be non-overlapping with each other.
Andy Grosse8860fe2018-02-01 01:12:32 -0600639
Ioannis Glaropoulos6d789512019-10-24 15:17:09 +0200640config MPU_GAP_FILLING
641 bool "Force MPU to be filling in background memory regions"
642 depends on MPU_REQUIRES_NON_OVERLAPPING_REGIONS
Ioannis Glaropoulos98201222019-11-11 12:46:31 +0100643 default y if !USERSPACE
Ioannis Glaropoulos6d789512019-10-24 15:17:09 +0200644 help
645 This Kconfig option instructs the MPU driver to enforce
646 a full kernel SRAM partitioning, when it programs the
647 dynamic MPU regions (user thread stack, PRIV stack guard
648 and application memory domains) during context-switch. We
649 allow this to be a configurable option, in order to be able
650 to switch the option off and have an increased number of MPU
651 regions available for application memory domain programming.
652
653 Notes:
654 An increased number of MPU regions should only be required,
Ioannis Glaropoulos98201222019-11-11 12:46:31 +0100655 when building with USERSPACE support. As a result, when we
656 build without USERSPACE support, gap filling should always
657 be required.
Ioannis Glaropoulos6d789512019-10-24 15:17:09 +0200658
659 When the option is switched off, access to memory areas not
660 covered by explicit MPU regions is restricted to privileged
661 code on an ARCH-specific basis. Refer to ARCH-specific
662 documentation for more information on how this option is
663 used.
664
Andrew Boie5a58ad52020-11-05 14:30:20 -0800665endif # MPU
666
667config SRAM_REGION_PERMISSIONS
668 bool "Assign appropriate permissions to kernel areas in SRAM"
669 depends on MMU || MPU
670 default y
671 help
672 This option indicates that memory protection hardware
673 is present, enabled, and regions have been configured at boot for memory
674 ranges within the kernel image.
675
676 If this option is turned on, certain areas of the kernel image will
677 have the following access policies applied for all threads, including
678 supervisor threads:
679
680 1) All program text will be have read-only, execute memory permission
681 2) All read-only data will have read-only permission, and execution
682 disabled if the hardware supports it.
683 3) All other RAM addresses will have read-write permission, and
684 execution disabled if the hardware supports it.
685
686 Options such as USERSPACE or HW_STACK_PROTECTION may additionally
687 impose additional policies on the memory map, which may be global
688 or local to the current running thread.
689
690 This option may consume additional memory to satisfy memory protection
691 hardware alignment constraints.
692
693 If this option is disabled, the entire kernel will have default memory
694 access permissions set, typically read/write/execute. It may be desirable
695 to turn this off on MMU systems which are using the MMU for demand
696 paging, do not need memory protection, and would rather not use up
697 RAM for the alignment between regions.
698
Stephanos Ioannidis4f4e85c2020-04-24 14:06:37 +0900699menu "Floating Point Options"
700
701config FPU
Gerard Marull-Paretas95fb0de2022-03-09 12:05:12 +0100702 bool "Floating point unit (FPU)"
Sebastian Bøe7201a1b2018-12-27 16:13:25 +0100703 depends on CPU_HAS_FPU
Anas Nashif9c1da0d2017-11-23 17:43:54 -0500704 help
Stephanos Ioannidis4f4e85c2020-04-24 14:06:37 +0900705 This option enables the hardware Floating Point Unit (FPU), in order to
706 support using the floating point registers and instructions.
Anas Nashif9c1da0d2017-11-23 17:43:54 -0500707
Stephanos Ioannidis4f4e85c2020-04-24 14:06:37 +0900708 When this option is enabled, by default, threads may use the floating
709 point registers only in an exclusive manner, and this usually means that
710 only one thread may perform floating point operations.
711
712 If it is necessary for multiple threads to perform concurrent floating
713 point operations, the "FPU register sharing" option must be enabled to
714 preserve the floating point registers across context switches.
715
716 Note that this option cannot be selected for the platforms that do not
717 include a hardware floating point unit; the floating point support for
718 those platforms is dependent on the availability of the toolchain-
719 provided software floating point library.
Anas Nashif9c1da0d2017-11-23 17:43:54 -0500720
Stephanos Ioannidisaaf93202020-05-03 18:03:19 +0900721config FPU_SHARING
Stephanos Ioannidis4f4e85c2020-04-24 14:06:37 +0900722 bool "FPU register sharing"
Ioannis Glaropoulos86c1b572021-01-27 14:24:59 +0100723 depends on FPU && MULTITHREADING
Anas Nashif9c1da0d2017-11-23 17:43:54 -0500724 help
Stephanos Ioannidis4f4e85c2020-04-24 14:06:37 +0900725 This option enables preservation of the hardware floating point registers
726 across context switches to allow multiple threads to perform concurrent
727 floating point operations.
728
Nicolas Pitre949ef7c2021-04-07 21:41:06 -0400729 Note that some compiler configurations may activate a floating point
730 context by generating FP instructions for any thread, and that
731 context must be preserved when switching such threads in and out.
732 The developers can still disable the FP sharing mode in their
733 application projects, and switch to Unshared FP registers mode,
734 if it is guaranteed that the image code does not generate FP
735 instructions outside the single thread context that is allowed
736 to do so.
Ioannis Glaropoulos86c1b572021-01-27 14:24:59 +0100737
Stephanos Ioannidis4f4e85c2020-04-24 14:06:37 +0900738endmenu
Anas Nashif9c1da0d2017-11-23 17:43:54 -0500739
Carlo Caione923b3be2020-12-02 13:05:37 +0100740menu "Cache Options"
741
Carlo Caione20f59c82020-12-03 10:49:00 +0100742config CACHE_MANAGEMENT
Gerard Marull-Paretas95fb0de2022-03-09 12:05:12 +0100743 bool "Cache management features"
Carlo Caione923b3be2020-12-02 13:05:37 +0100744 help
Carlo Caione20f59c82020-12-03 10:49:00 +0100745 This links in the cache management functions (for d-cache and i-cache
746 where possible).
Carlo Caione923b3be2020-12-02 13:05:37 +0100747
Carlo Caionee77c8412020-12-02 12:38:58 +0100748config DCACHE_LINE_SIZE_DETECT
749 bool "Detect d-cache line size at runtime"
750 depends on CACHE_MANAGEMENT
751 help
752 This option enables querying some architecture-specific hardware for
753 finding the d-cache line size at the expense of taking more memory and
754 code and a slightly increased boot time.
755
756 If the CPU's d-cache line size is known in advance, disable this option and
757 manually enter the value for DCACHE_LINE_SIZE or set it in the DT
758 using the 'd-cache-line-size' property.
759
760config DCACHE_LINE_SIZE
761 int "d-cache line size" if !DCACHE_LINE_SIZE_DETECT
762 depends on CACHE_MANAGEMENT
763 default 0
764 help
765 Size in bytes of a CPU d-cache line. If this is set to 0 the value is
766 obtained from the 'd-cache-line-size' DT property instead if present.
767
768
769 Detect automatically at runtime by selecting DCACHE_LINE_SIZE_DETECT.
770
771config ICACHE_LINE_SIZE_DETECT
772 bool "Detect i-cache line size at runtime"
773 depends on CACHE_MANAGEMENT
774 help
775 This option enables querying some architecture-specific hardware for
776 finding the i-cache line size at the expense of taking more memory and
777 code and a slightly increased boot time.
778
779 If the CPU's i-cache line size is known in advance, disable this option and
780 manually enter the value for ICACHE_LINE_SIZE or set it in the DT
781 using the 'i-cache-line-size' property.
782
783config ICACHE_LINE_SIZE
784 int "i-cache line size" if !ICACHE_LINE_SIZE_DETECT
785 depends on CACHE_MANAGEMENT
786 default 0
787 help
788 Size in bytes of a CPU i-cache line. If this is set to 0 the value is
789 obtained from the 'i-cache-line-size' DT property instead if present.
790
791 Detect automatically at runtime by selecting ICACHE_LINE_SIZE_DETECT.
792
Dylan Hungb61ea622021-07-13 15:20:47 +0800793choice CACHE_TYPE
Carlo Caionee2333262021-04-28 10:38:27 +0200794 prompt "Cache type"
795 depends on CACHE_MANAGEMENT
796 default HAS_ARCH_CACHE
797
798config HAS_ARCH_CACHE
799 bool "Integrated cache controller"
800 help
Nazar Kazakovf483b1b2022-03-16 21:07:43 +0000801 "Integrated on-core cache controller"
Carlo Caionee2333262021-04-28 10:38:27 +0200802
803config HAS_EXTERNAL_CACHE
804 bool "External cache controller"
805 help
806 "External cache controller or cache management system"
807
808endchoice
809
Carlo Caione923b3be2020-12-02 13:05:37 +0100810endmenu
811
Anas Nashif77ba3c32015-10-09 06:20:52 -0400812config ARCH
813 string
814 help
Anas Nashif429c2a42017-12-13 10:08:21 -0500815 System architecture string.
Anas Nashif77ba3c32015-10-09 06:20:52 -0400816
817config SOC
Anas Nashifa02c34e2016-03-31 08:07:42 -0400818 string
819 help
Anas Nashif57444372018-09-03 15:44:13 -0500820 SoC name which can be found under soc/<arch>/<soc name>.
Anas Nashif429c2a42017-12-13 10:08:21 -0500821 This option holds the directory name used by the build system to locate
Marti Bolivar5ec7ed82018-11-21 14:42:47 -0500822 the correct linker and header files for the SoC.
Anas Nashifa02c34e2016-03-31 08:07:42 -0400823
824config SOC_SERIES
825 string
826 help
Anas Nashif57444372018-09-03 15:44:13 -0500827 SoC series name which can be found under soc/<arch>/<family>/<series>.
Anas Nashif429c2a42017-12-13 10:08:21 -0500828 This option holds the directory name used by the build system to locate
829 the correct linker and header files.
Anas Nashifa02c34e2016-03-31 08:07:42 -0400830
831config SOC_FAMILY
832 string
833 help
Anas Nashif57444372018-09-03 15:44:13 -0500834 SoC family name which can be found under soc/<arch>/<family>.
Anas Nashif429c2a42017-12-13 10:08:21 -0500835 This option holds the directory name used by the build system to locate
836 the correct linker and header files.
Anas Nashif66233112015-11-29 19:47:21 -0500837
Anas Nashif2d762242015-12-07 20:20:25 -0500838config BOARD
839 string
840 help
Anas Nashif429c2a42017-12-13 10:08:21 -0500841 This option holds the name of the board and is used to locate the files
842 related to the board in the source tree (under boards/).
843 The Board is the first location where we search for a linker.ld file,
844 if not found we look for the linker file in
Anas Nashif57444372018-09-03 15:44:13 -0500845 soc/<arch>/<family>/<series>
Daniel Leung783b2072021-04-23 20:52:38 -0700846
847config TOOLCHAIN_HAS_BUILTIN_FFS
848 bool
849 default y if !(64BIT && RISCV)
850 help
851 Hidden option to signal that toolchain has __builtin_ffs*().