2015-05-20 18:40:39 +02:00
|
|
|
# Kconfig - kernel configuration options
|
|
|
|
|
|
|
|
#
|
|
|
|
# Copyright (c) 2014-2015 Wind River Systems, Inc.
|
|
|
|
#
|
2015-10-06 18:00:37 +02:00
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
2015-05-20 18:40:39 +02:00
|
|
|
#
|
2015-10-06 18:00:37 +02:00
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
2015-05-20 18:40:39 +02:00
|
|
|
#
|
2015-10-06 18:00:37 +02:00
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
2015-05-20 18:40:39 +02:00
|
|
|
#
|
|
|
|
|
2015-03-11 19:44:14 +01:00
|
|
|
|
|
|
|
menu "General Kernel Options"
|
|
|
|
|
|
|
|
config SYS_CLOCK_TICKS_PER_SEC
|
|
|
|
int
|
|
|
|
prompt "System tick frequency (in ticks/second)"
|
|
|
|
default 100
|
|
|
|
help
|
|
|
|
This option specifies the frequency of the system clock in Hz.
|
|
|
|
|
|
|
|
config SYS_CLOCK_HW_CYCLES_PER_SEC
|
2015-07-22 22:22:25 +02:00
|
|
|
int "System clock's h/w timer frequency"
|
2015-03-11 19:44:14 +01:00
|
|
|
help
|
2015-07-22 22:22:25 +02:00
|
|
|
This option specifies the frequency of the hardware timer used for the
|
2016-08-18 01:33:08 +02:00
|
|
|
system clock (in Hz). This option is set by the board's Kconfig file
|
2015-07-22 22:22:25 +02:00
|
|
|
and the user should generally avoid modifying it via the menu configuration.
|
2015-03-11 19:44:14 +01:00
|
|
|
|
2016-05-25 01:17:13 +02:00
|
|
|
config SYS_CLOCK_EXISTS
|
2015-05-05 17:12:02 +02:00
|
|
|
bool
|
|
|
|
# omit prompt to signify a "hidden" option
|
2015-05-15 13:43:52 +02:00
|
|
|
default y
|
2016-03-25 22:30:50 +01:00
|
|
|
default n if (SYS_CLOCK_TICKS_PER_SEC = 0)
|
2015-05-05 17:12:02 +02:00
|
|
|
help
|
|
|
|
This option specifies that the kernel lacks timer support.
|
|
|
|
|
2016-05-25 01:17:13 +02:00
|
|
|
config INIT_STACKS
|
2015-05-05 17:12:02 +02:00
|
|
|
bool
|
|
|
|
prompt "Initialize stack areas"
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
This option instructs the kernel to initialize stack areas with a
|
|
|
|
known value (0xaa) before they are first used, so that the high
|
|
|
|
water mark can be easily determined. This applies to the stack areas
|
2015-08-12 21:37:58 +02:00
|
|
|
for both tasks and fibers, as well as for the microkernel server's command
|
2015-05-05 17:12:02 +02:00
|
|
|
stack.
|
|
|
|
|
2016-05-25 01:17:13 +02:00
|
|
|
config XIP
|
2015-03-11 19:44:14 +01:00
|
|
|
bool
|
|
|
|
prompt "Execute in place"
|
|
|
|
help
|
|
|
|
This option allows the kernel to operate with its text and read-only
|
2016-08-18 01:33:08 +02:00
|
|
|
sections residing in ROM (or similar read-only memory). Not all boards
|
2015-03-11 19:44:14 +01:00
|
|
|
support this option so it must be used with care; you must also
|
|
|
|
supply a linker command file when building your image. Enabling this
|
|
|
|
option increases both the code and data footprint of the image.
|
|
|
|
|
2015-08-27 22:07:36 +02:00
|
|
|
config RING_BUFFER
|
|
|
|
bool
|
|
|
|
prompt "Enable ring buffers"
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
Enable usage of ring buffers. Similar to nanokernel FIFOs but manage
|
|
|
|
their own buffer memory and can store arbitrary data. For optimal
|
|
|
|
performance, use buffer sizes that are a power of 2.
|
|
|
|
|
2016-05-25 01:17:13 +02:00
|
|
|
config THREAD_MONITOR
|
2016-03-09 22:57:41 +01:00
|
|
|
bool
|
2016-12-17 18:19:51 +01:00
|
|
|
prompt "Thread monitoring [EXPERIMENTAL]"
|
2016-03-09 22:57:41 +01:00
|
|
|
default n
|
|
|
|
help
|
2016-12-17 18:19:51 +01:00
|
|
|
This option instructs the kernel to maintain a list of all threads
|
|
|
|
(excluding those that have not yet started or have already
|
|
|
|
terminated).
|
2016-03-09 22:57:41 +01:00
|
|
|
|
2016-09-09 17:20:23 +02:00
|
|
|
config KERNEL_INIT_PRIORITY_OBJECTS
|
|
|
|
int
|
|
|
|
prompt "Kernel objects initialization priority"
|
|
|
|
default 30
|
|
|
|
help
|
|
|
|
Kernel objects use this priority for initialization. This
|
|
|
|
priority needs to be higher than minimal default initialization
|
|
|
|
priority.
|
|
|
|
|
2015-10-26 20:56:02 +01:00
|
|
|
config KERNEL_INIT_PRIORITY_DEFAULT
|
|
|
|
int
|
|
|
|
prompt "Default init priority"
|
2016-03-28 23:05:33 +02:00
|
|
|
default 40
|
2015-10-26 20:56:02 +01:00
|
|
|
help
|
|
|
|
Defaut minimal init priority for each init level.
|
|
|
|
|
|
|
|
config KERNEL_INIT_PRIORITY_DEVICE
|
|
|
|
int
|
|
|
|
prompt "Default init priority for device drivers"
|
2016-03-28 23:05:33 +02:00
|
|
|
default 50
|
2015-10-26 20:56:02 +01:00
|
|
|
help
|
|
|
|
Device driver, that depends on common components, such as
|
|
|
|
interrupt controller, but does not depend on other devices,
|
|
|
|
uses this init priority.
|
2015-09-29 16:08:58 +02:00
|
|
|
|
2016-10-07 19:03:51 +02:00
|
|
|
config APPLICATION_INIT_PRIORITY
|
|
|
|
int
|
|
|
|
prompt "Default init priority for application level drivers"
|
|
|
|
default 90
|
|
|
|
help
|
|
|
|
This priority level is for end-user drivers such as sensors and display
|
|
|
|
which have no inward dependencies.
|
|
|
|
|
2015-08-11 20:33:26 +02:00
|
|
|
|
2015-03-11 19:44:14 +01:00
|
|
|
menu "Security Options"
|
|
|
|
|
|
|
|
config STACK_CANARIES
|
|
|
|
bool
|
2015-09-29 16:08:58 +02:00
|
|
|
prompt "Compiler stack canaries"
|
2015-03-11 19:44:14 +01:00
|
|
|
default n
|
|
|
|
help
|
2015-09-29 16:08:58 +02:00
|
|
|
This option enables compiler stack canaries support kernel functions.
|
2015-03-11 19:44:14 +01:00
|
|
|
|
|
|
|
If stack canaries are supported by the compiler, it will emit
|
|
|
|
extra code that inserts a canary value into the stack frame when
|
|
|
|
a function is entered and validates this value upon exit.
|
|
|
|
Stack corruption (such as that caused by buffer overflow) results
|
|
|
|
in a fatal error condition for the running entity.
|
|
|
|
Enabling this option can result in a significant increase
|
|
|
|
in footprint and an associated decrease in performance.
|
|
|
|
|
|
|
|
If stack canaries are not supported by the compiler, enabling this
|
|
|
|
option has no effect.
|
|
|
|
endmenu
|
|
|
|
|
|
|
|
endmenu
|
2016-03-14 00:53:30 +01:00
|
|
|
|
2016-09-03 01:19:17 +02:00
|
|
|
source "kernel/unified/Kconfig"
|
2016-03-15 03:35:14 +01:00
|
|
|
|
2016-03-14 00:53:30 +01:00
|
|
|
menu "Power Management"
|
2016-03-19 00:43:40 +01:00
|
|
|
config SYS_POWER_MANAGEMENT
|
2015-10-05 22:26:52 +02:00
|
|
|
bool
|
2016-03-19 00:43:40 +01:00
|
|
|
prompt "Power management"
|
2015-10-05 22:26:52 +02:00
|
|
|
default n
|
|
|
|
help
|
2016-08-18 01:33:08 +02:00
|
|
|
This option enables the board to implement extra power management
|
2016-03-19 00:43:40 +01:00
|
|
|
policies whenever the kernel becomes idle. The kernel informs the
|
|
|
|
power management subsystem of the number of ticks until the next kernel
|
|
|
|
timer is due to expire.
|
2015-10-05 22:26:52 +02:00
|
|
|
|
2016-03-19 00:43:40 +01:00
|
|
|
menu "Power Management Features"
|
|
|
|
depends on SYS_POWER_MANAGEMENT
|
2015-10-05 22:26:52 +02:00
|
|
|
|
2016-05-25 01:17:13 +02:00
|
|
|
config SYS_POWER_LOW_POWER_STATE
|
2015-10-05 22:26:52 +02:00
|
|
|
bool
|
2016-03-19 00:43:40 +01:00
|
|
|
prompt "Low power state"
|
2015-10-05 22:26:52 +02:00
|
|
|
default n
|
2016-12-11 11:59:18 +01:00
|
|
|
depends on SYS_POWER_MANAGEMENT && SYS_POWER_LOW_POWER_STATE_SUPPORTED
|
2015-10-05 22:26:52 +02:00
|
|
|
help
|
2016-03-19 00:43:40 +01:00
|
|
|
This option enables the kernel to interface with a power manager
|
|
|
|
application. This permits the system to enter a custom CPU low power
|
|
|
|
state when the kernel becomes idle. The low power state could be any of
|
|
|
|
the CPU low power states supported by the processor. Generally the one
|
|
|
|
saving most power.
|
|
|
|
|
2016-05-25 01:17:13 +02:00
|
|
|
config SYS_POWER_DEEP_SLEEP
|
2016-03-19 00:43:40 +01:00
|
|
|
bool
|
|
|
|
prompt "Deep sleep state"
|
|
|
|
default n
|
2016-12-11 11:59:18 +01:00
|
|
|
depends on SYS_POWER_MANAGEMENT && SYS_POWER_DEEP_SLEEP_SUPPORTED
|
2016-03-19 00:43:40 +01:00
|
|
|
help
|
|
|
|
This option enables the kernel to interface with a power manager
|
|
|
|
application. This permits the system to enter a Deep sleep state
|
|
|
|
supported by the SOC where the system clock is turned off while RAM is
|
|
|
|
retained. This state would be entered when the kernel becomes idle for
|
|
|
|
extended periods and would have a high wake latency. Resume would be
|
|
|
|
from the reset vector same as cold boot. The interface allows
|
|
|
|
restoration of states that were saved at the time of suspend.
|
|
|
|
|
|
|
|
config DEVICE_POWER_MANAGEMENT
|
|
|
|
bool
|
|
|
|
prompt "Device power management"
|
|
|
|
default n
|
2016-12-11 11:59:18 +01:00
|
|
|
depends on SYS_POWER_MANAGEMENT
|
2016-03-19 00:43:40 +01:00
|
|
|
help
|
|
|
|
This option enables the device power management interface. The
|
|
|
|
interface consists of hook functions implemented by device drivers
|
|
|
|
that get called by the power manager application when the system
|
|
|
|
is going to suspend state or resuming from suspend state. This allows
|
|
|
|
device drivers to do any necessary power management operations
|
|
|
|
like turning off device clocks and peripherals. The device drivers
|
|
|
|
may also save and restore states in these hook functions.
|
2015-10-05 22:26:52 +02:00
|
|
|
|
2015-03-11 19:44:14 +01:00
|
|
|
config TICKLESS_IDLE
|
|
|
|
bool
|
|
|
|
prompt "Tickless idle"
|
2016-12-17 18:12:35 +01:00
|
|
|
default y if TICKLESS_IDLE_SUPPORTED
|
2015-03-11 19:44:14 +01:00
|
|
|
help
|
|
|
|
This option suppresses periodic system clock interrupts whenever the
|
|
|
|
kernel becomes idle. This permits the system to remain in a power
|
|
|
|
saving state for extended periods without having to wake up to
|
|
|
|
service each tick as it occurs.
|
|
|
|
|
|
|
|
config TICKLESS_IDLE_THRESH
|
|
|
|
int
|
|
|
|
prompt "Tickless idle threshold"
|
|
|
|
default 3
|
2015-10-05 17:15:03 +02:00
|
|
|
depends on TICKLESS_IDLE
|
2015-03-11 19:44:14 +01:00
|
|
|
help
|
2015-10-05 22:26:52 +02:00
|
|
|
This option enables clock interrupt suppression when the kernel idles
|
2015-03-11 19:44:14 +01:00
|
|
|
for only a short period of time. It specifies the minimum number of
|
|
|
|
ticks that must occur before the next kernel timer expires in order
|
|
|
|
for suppression to happen.
|
|
|
|
|
2015-10-05 22:26:52 +02:00
|
|
|
endmenu
|
|
|
|
|
2016-06-14 22:36:55 +02:00
|
|
|
config MDEF
|
|
|
|
bool
|
|
|
|
prompt "Use MDEF files for statically configured kernel objects"
|
2016-12-17 16:25:17 +01:00
|
|
|
default y
|
2016-06-14 22:36:55 +02:00
|
|
|
help
|
|
|
|
Using an MDEF file can help the startup time of the application since
|
|
|
|
the objects it lists are statically allocated and initialized, and may
|
|
|
|
also reduce code size if no subsystem uses the initialization routines.
|
|
|
|
|
|
|
|
Disabling this option can reduce the compilation time slightly.
|
|
|
|
|
2016-12-17 16:25:17 +01:00
|
|
|
In doubt, select 'y'.
|
2016-06-14 22:36:55 +02:00
|
|
|
|
2016-03-14 00:53:30 +01:00
|
|
|
endmenu
|
2016-12-17 18:18:10 +01:00
|
|
|
|
|
|
|
source "kernel/Kconfig.event_logger"
|