2019-11-01 13:45:29 +01:00
|
|
|
# Timer driver configuration options
|
2015-05-20 18:40:39 +02:00
|
|
|
|
|
|
|
# Copyright (c) 2014-2015 Wind River Systems, Inc.
|
2017-01-24 22:03:19 +01:00
|
|
|
# Copyright (c) 2016 Cadence Design Systems, Inc.
|
2019-06-17 06:40:55 +02:00
|
|
|
# Copyright (c) 2019 Intel Corp.
|
2017-01-19 02:01:01 +01:00
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
2015-06-05 20:01:57 +02:00
|
|
|
|
|
|
|
menu "Timer Drivers"
|
|
|
|
|
2019-06-17 06:40:55 +02:00
|
|
|
menuconfig APIC_TIMER
|
|
|
|
bool "New local APIC timer"
|
|
|
|
depends on X86
|
|
|
|
depends on LOAPIC
|
|
|
|
select TICKLESS_CAPABLE
|
|
|
|
help
|
2021-05-05 19:37:39 +02:00
|
|
|
Use the x86 local APIC in one-shot mode as the system time
|
|
|
|
source. NOTE: this probably isn't what you want except on
|
|
|
|
older or idiosyncratic hardware (or environments like qemu
|
|
|
|
without complete APIC emulation). Modern hardware will work
|
|
|
|
better with CONFIG_APIC_TSC_DEADLINE_TIMER.
|
2019-06-17 06:40:55 +02:00
|
|
|
|
|
|
|
if APIC_TIMER
|
|
|
|
|
|
|
|
config APIC_TIMER_IRQ
|
|
|
|
int "Local APIC timer IRQ"
|
|
|
|
default 24
|
|
|
|
help
|
|
|
|
This option specifies the IRQ used by the local APIC timer.
|
2021-05-05 19:37:39 +02:00
|
|
|
Note: this MUST be set to the index immediately after the
|
|
|
|
last IO-APIC IRQ (the timer is the first entry in the APIC
|
|
|
|
local vector table). This footgun is not intended to be
|
|
|
|
user-configurable and almost certainly should be managed via
|
|
|
|
a different mechanism.
|
2019-06-17 06:40:55 +02:00
|
|
|
|
|
|
|
config APIC_TIMER_TSC
|
2021-03-12 18:46:52 +01:00
|
|
|
bool "Use invariant TSC for sys_clock_cycle_get_32()"
|
2019-06-17 06:40:55 +02:00
|
|
|
help
|
|
|
|
If your CPU supports invariant TSC, and you know the ratio of the
|
|
|
|
TSC frequency to CONFIG_SYS_CLOCK_HW_CYCLES_PER_SEC (the local APIC
|
|
|
|
timer frequency), then enable this for a much faster and more
|
2021-03-12 18:46:52 +01:00
|
|
|
accurate sys_clock_cycle_get_32().
|
2019-06-17 06:40:55 +02:00
|
|
|
|
|
|
|
if APIC_TIMER_TSC
|
|
|
|
|
|
|
|
config APIC_TIMER_TSC_N
|
|
|
|
int "TSC to local APIC timer frequency multiplier (N)"
|
|
|
|
default 1
|
|
|
|
|
|
|
|
config APIC_TIMER_TSC_M
|
|
|
|
int "TSC to local APIC timer frequency divisor (M)"
|
|
|
|
default 1
|
|
|
|
|
|
|
|
endif # APIC_TIMER_TSC
|
|
|
|
|
|
|
|
endif # APIC_TIMER
|
|
|
|
|
2021-05-05 19:37:39 +02:00
|
|
|
config APIC_TSC_DEADLINE_TIMER
|
|
|
|
bool "Even newer APIC timer using TSC deadline mode"
|
|
|
|
depends on X86
|
|
|
|
select LOAPIC
|
|
|
|
select TICKLESS_CAPABLE
|
|
|
|
help
|
|
|
|
Extremely simple timer driver based the local APIC TSC
|
|
|
|
deadline capability. The use of a free-running 64 bit
|
|
|
|
counter with comparator eliminates almost all edge cases
|
|
|
|
from the handling, and the near-instruction-cycle resolution
|
|
|
|
permits effectively unlimited precision where needed (the
|
|
|
|
limit becomes the CPU time taken to execute the timing
|
|
|
|
logic). SMP-safe and very fast, this should be the obvious
|
|
|
|
choice for any x86 device with invariant TSC and TSC
|
|
|
|
deadline capability.
|
|
|
|
|
2021-06-10 16:56:08 +02:00
|
|
|
config APIC_TIMER_IRQ_PRIORITY
|
|
|
|
int "Local APIC timer interrupt priority"
|
|
|
|
depends on APIC_TIMER || APIC_TSC_DEADLINE_TIMER
|
|
|
|
default 4
|
|
|
|
help
|
|
|
|
This option specifies the interrupt priority used by the
|
|
|
|
local APIC timer.
|
|
|
|
|
2019-10-22 01:04:04 +02:00
|
|
|
config HPET_TIMER
|
2015-06-05 20:01:57 +02:00
|
|
|
bool "HPET timer"
|
2019-10-24 21:57:57 +02:00
|
|
|
depends on X86
|
arch/x86_64: New architecture added
This patch adds a x86_64 architecture and qemu_x86_64 board to Zephyr.
Only the basic architecture support needed to run 64 bit code is
added; no drivers are added, though a low-level console exists and is
wired to printk().
The support is built on top of a "X86 underkernel" layer, which can be
built in isolation as a unit test on a Linux host.
Limitations:
+ Right now the SDK lacks an x86_64 toolchain. The build will fall
back to a host toolchain if it finds no cross compiler defined,
which is tested to work on gcc 8.2.1 right now.
+ No x87/SSE/AVX usage is allowed. This is a stronger limitation than
other architectures where the instructions work from one thread even
if the context switch code doesn't support it. We are passing
-no-sse to prevent gcc from automatically generating SSE
instructions for non-floating-point purposes, which has the side
effect of changing the ABI. Future work to handle the FPU registers
will need to be combined with an "application" ABI distinct from the
kernel one (or just to require USERSPACE).
+ Paging is enabled (it has to be in long mode), but is a 1:1 mapping
of all memory. No MMU/USERSPACE support yet.
+ We are building with -mno-red-zone for stack size reasons, but this
is a valuable optimization. Enabling it requires automatic stack
switching, which requires a TSS, which means it has to happen after
MMU support.
+ The OS runs in 64 bit mode, but for compatibility reasons is
compiled to the 32 bit "X32" ABI. So while the full 64 bit
registers and instruction set are available, C pointers are 32 bits
long and Zephyr is constrained to run in the bottom 4G of memory.
Signed-off-by: Andy Ross <andrew.j.ross@intel.com>
2018-08-19 21:24:48 +02:00
|
|
|
select IOAPIC if X86
|
|
|
|
select LOAPIC if X86
|
2021-05-20 01:42:58 +02:00
|
|
|
imply TIMER_READS_ITS_FREQUENCY_AT_RUNTIME
|
2018-10-12 19:11:17 +02:00
|
|
|
select TICKLESS_CAPABLE
|
2015-06-05 20:01:57 +02:00
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
This option selects High Precision Event Timer (HPET) as a
|
|
|
|
system timer.
|
2015-06-05 20:01:57 +02:00
|
|
|
|
2019-01-19 13:36:29 +01:00
|
|
|
menuconfig ARCV2_TIMER
|
2015-06-20 15:28:13 +02:00
|
|
|
bool "ARC Timer"
|
|
|
|
default y
|
|
|
|
depends on ARC
|
2018-11-22 10:55:27 +01:00
|
|
|
select TICKLESS_CAPABLE
|
2015-06-20 15:28:13 +02:00
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
This module implements a kernel device driver for the ARCv2 processor timer 0
|
|
|
|
and provides the standard "system clock driver" interfaces.
|
2015-06-20 15:28:13 +02:00
|
|
|
|
2016-08-16 19:58:40 +02:00
|
|
|
config ARCV2_TIMER_IRQ_PRIORITY
|
|
|
|
int "ARC timer interrupt priority"
|
|
|
|
default 0
|
|
|
|
depends on ARCV2_TIMER
|
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
This option specifies the IRQ priority used by the ARC timer. Lower
|
|
|
|
values have higher priority.
|
2016-08-16 19:58:40 +02:00
|
|
|
|
2019-10-27 17:12:58 +01:00
|
|
|
config ARM_ARCH_TIMER
|
|
|
|
bool "ARM architected timer"
|
|
|
|
depends on GIC
|
2020-11-09 08:49:21 +01:00
|
|
|
select ARCH_HAS_CUSTOM_BUSY_WAIT
|
2019-10-27 17:12:58 +01:00
|
|
|
select TICKLESS_CAPABLE
|
|
|
|
help
|
|
|
|
This module implements a kernel device driver for the ARM architected
|
|
|
|
timer which provides per-cpu timers attached to a GIC to deliver its
|
|
|
|
per-processor interrupts via PPIs.
|
|
|
|
|
2020-09-08 19:51:54 +02:00
|
|
|
DT_COMPAT_ARM_V6M_SYSTICK := arm,armv6m-systick
|
|
|
|
DT_COMPAT_ARM_V7M_SYSTICK := arm,armv7m-systick
|
|
|
|
DT_COMPAT_ARM_V8M_SYSTICK := arm,armv8m-systick
|
2021-02-13 22:07:37 +01:00
|
|
|
DT_COMPAT_ARM_V8_1M_SYSTICK := arm,armv8.1m-systick
|
2020-09-08 19:51:54 +02:00
|
|
|
|
2015-08-04 15:51:13 +02:00
|
|
|
config CORTEX_M_SYSTICK
|
|
|
|
bool "Cortex-M SYSTICK timer"
|
2019-04-05 12:47:43 +02:00
|
|
|
depends on CPU_CORTEX_M_HAS_SYSTICK
|
2020-09-08 19:51:54 +02:00
|
|
|
default $(dt_compat_enabled,$(DT_COMPAT_ARM_V6M_SYSTICK)) || \
|
|
|
|
$(dt_compat_enabled,$(DT_COMPAT_ARM_V7M_SYSTICK)) || \
|
2021-02-13 22:07:37 +01:00
|
|
|
$(dt_compat_enabled,$(DT_COMPAT_ARM_V8M_SYSTICK)) || \
|
|
|
|
$(dt_compat_enabled,$(DT_COMPAT_ARM_V8_1M_SYSTICK))
|
2018-10-12 15:58:21 +02:00
|
|
|
select TICKLESS_CAPABLE
|
2015-06-24 17:39:57 +02:00
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
This module implements a kernel device driver for the Cortex-M processor
|
|
|
|
SYSTICK timer and provides the standard "system clock driver" interfaces.
|
2015-06-24 17:39:57 +02:00
|
|
|
|
2016-06-21 19:51:46 +02:00
|
|
|
config ALTERA_AVALON_TIMER
|
|
|
|
bool "Altera Avalon Interval Timer"
|
2016-04-21 23:47:09 +02:00
|
|
|
default y
|
|
|
|
depends on NIOS2
|
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
This module implements a kernel device driver for the Altera Avalon
|
|
|
|
Interval Timer as described in the Embedded IP documentation, for use
|
|
|
|
with Nios II and possibly other Altera soft CPUs. It provides the
|
|
|
|
standard "system clock driver" interfaces.
|
2016-04-21 23:47:09 +02:00
|
|
|
|
2020-09-09 05:39:37 +02:00
|
|
|
config ITE_IT8XXX2_TIMER
|
|
|
|
bool "ITE it8xxx2 timer driver"
|
|
|
|
depends on SOC_IT8XXX2
|
2021-01-22 04:10:39 +01:00
|
|
|
select TICKLESS_CAPABLE
|
2020-09-09 05:39:37 +02:00
|
|
|
help
|
|
|
|
This module implements a kernel device driver for the ITE it8xxx2
|
|
|
|
HW timer model
|
|
|
|
|
2016-11-22 17:03:32 +01:00
|
|
|
config NRF_RTC_TIMER
|
|
|
|
bool "nRF Real Time Counter (NRF_RTC1) Timer"
|
2019-02-21 15:53:29 +01:00
|
|
|
depends on CLOCK_CONTROL
|
|
|
|
depends on SOC_COMPATIBLE_NRF
|
2018-10-15 18:04:21 +02:00
|
|
|
select TICKLESS_CAPABLE
|
2020-12-10 17:55:57 +01:00
|
|
|
select NRF_HW_RTC1_RESERVED
|
2016-11-22 17:03:32 +01:00
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
This module implements a kernel device driver for the nRF Real Time
|
|
|
|
Counter NRF_RTC1 and provides the standard "system clock driver"
|
|
|
|
interfaces.
|
2016-11-22 17:03:32 +01:00
|
|
|
|
2020-08-04 13:56:21 +02:00
|
|
|
if NRF_RTC_TIMER
|
|
|
|
|
2020-11-04 11:57:38 +01:00
|
|
|
config NRF_RTC_TIMER_USER_CHAN_COUNT
|
|
|
|
int "Additional channels that can be used"
|
|
|
|
default 0
|
|
|
|
help
|
|
|
|
Use nrf_rtc_timer.h API. Driver is not managing allocation of channels.
|
|
|
|
|
2020-08-04 13:56:21 +02:00
|
|
|
choice
|
|
|
|
prompt "Clock startup policy"
|
|
|
|
default SYSTEM_CLOCK_WAIT_FOR_STABILITY
|
|
|
|
|
|
|
|
config SYSTEM_CLOCK_NO_WAIT
|
|
|
|
bool "No wait"
|
|
|
|
help
|
|
|
|
System clock source is initiated but does not wait for clock readiness.
|
|
|
|
When this option is picked, system clock may not be ready when code relying
|
|
|
|
on kernel API is executed. Requested timeouts will be prolonged by the
|
|
|
|
remaining startup time.
|
|
|
|
|
|
|
|
config SYSTEM_CLOCK_WAIT_FOR_AVAILABILITY
|
|
|
|
bool "Wait for availability"
|
|
|
|
help
|
|
|
|
System clock source initialization waits until clock is available. In some
|
|
|
|
systems, clock initially runs from less accurate source which has faster
|
|
|
|
startup time and then seamlessly switches to the target clock source when
|
|
|
|
it is ready. When this option is picked, system clock is available after
|
|
|
|
system clock driver initialization but it may be less accurate. Option is
|
|
|
|
equivalent to waiting for stability if clock source does not have
|
|
|
|
intermediate state.
|
|
|
|
|
|
|
|
config SYSTEM_CLOCK_WAIT_FOR_STABILITY
|
|
|
|
bool "Wait for stability"
|
|
|
|
help
|
|
|
|
System clock source initialization waits until clock is stable. When this
|
|
|
|
option is picked, system clock is available and stable after system clock
|
|
|
|
driver initialization.
|
|
|
|
|
|
|
|
endchoice
|
|
|
|
|
|
|
|
endif # NRF_RTC_TIMER
|
|
|
|
|
2019-11-08 10:17:08 +01:00
|
|
|
source "drivers/timer/Kconfig.stm32_lptim"
|
|
|
|
|
2017-01-24 01:03:56 +01:00
|
|
|
config RISCV_MACHINE_TIMER
|
|
|
|
bool "RISCV Machine Timer"
|
2017-03-14 22:14:52 +01:00
|
|
|
depends on SOC_FAMILY_RISCV_PRIVILEGE
|
2018-10-18 19:17:48 +02:00
|
|
|
select TICKLESS_CAPABLE
|
2017-01-11 00:24:31 +01:00
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
This module implements a kernel device driver for the generic RISCV machine
|
|
|
|
timer driver. It provides the standard "system clock driver" interfaces.
|
2017-01-11 00:24:31 +01:00
|
|
|
|
2018-11-25 10:40:57 +01:00
|
|
|
config RV32M1_LPTMR_TIMER
|
|
|
|
bool "RV32M1 LPTMR system timer driver"
|
|
|
|
default y
|
|
|
|
depends on SOC_OPENISA_RV32M1_RISCV32
|
2018-11-25 10:41:38 +01:00
|
|
|
depends on RV32M1_INTMUX
|
2018-11-25 10:40:57 +01:00
|
|
|
help
|
|
|
|
This module implements a kernel device driver for using the LPTMR
|
|
|
|
peripheral as the system clock. It provides the standard "system clock
|
|
|
|
driver" interfaces.
|
|
|
|
|
2019-03-28 14:40:03 +01:00
|
|
|
config LITEX_TIMER
|
|
|
|
bool "LiteX Timer"
|
|
|
|
default y
|
|
|
|
depends on SOC_RISCV32_LITEX_VEXRISCV
|
|
|
|
help
|
|
|
|
This module implements a kernel device driver for LiteX Timer.
|
|
|
|
|
2017-12-21 14:14:19 +01:00
|
|
|
config NATIVE_POSIX_TIMER
|
|
|
|
bool "(POSIX) native_posix timer driver"
|
|
|
|
default y
|
|
|
|
depends on BOARD_NATIVE_POSIX
|
2019-07-12 16:09:03 +02:00
|
|
|
select TICKLESS_CAPABLE
|
2017-12-21 14:14:19 +01:00
|
|
|
help
|
2018-01-06 13:41:34 +01:00
|
|
|
This module implements a kernel device driver for the native_posix HW timer
|
|
|
|
model
|
2017-12-21 14:14:19 +01:00
|
|
|
|
2017-01-25 13:00:08 +01:00
|
|
|
config XTENSA_TIMER
|
|
|
|
bool "Xtensa timer support"
|
|
|
|
depends on XTENSA
|
|
|
|
default y
|
2018-10-23 18:08:58 +02:00
|
|
|
select TICKLESS_CAPABLE
|
2017-01-25 13:00:08 +01:00
|
|
|
help
|
2018-10-23 18:08:58 +02:00
|
|
|
Enables a system timer driver for Xtensa based on the CCOUNT
|
|
|
|
and CCOMPARE special registers.
|
2017-01-25 13:00:08 +01:00
|
|
|
|
2021-04-13 00:39:04 +02:00
|
|
|
config ESP32C3_SYS_TIMER
|
|
|
|
bool "ESP32C3 sys-timer support"
|
|
|
|
depends on SOC_ESP32C3
|
|
|
|
default y
|
2021-07-27 02:35:48 +02:00
|
|
|
select TICKLESS_CAPABLE
|
2021-04-13 00:39:04 +02:00
|
|
|
help
|
2021-06-14 16:19:33 +02:00
|
|
|
This option enables the system timer driver for the Espressif ESP32C3
|
2021-04-13 00:39:04 +02:00
|
|
|
and provides the standard "system clock driver" interface.
|
|
|
|
|
2018-10-23 18:08:58 +02:00
|
|
|
config XTENSA_TIMER_ID
|
|
|
|
int "System timer CCOMPAREn register index"
|
2017-01-25 13:00:08 +01:00
|
|
|
default 1
|
2018-10-23 18:08:58 +02:00
|
|
|
depends on XTENSA_TIMER
|
2017-01-25 13:00:08 +01:00
|
|
|
help
|
2018-10-23 18:08:58 +02:00
|
|
|
Index of the CCOMPARE register (and associated interrupt)
|
|
|
|
used for the system timer. Xtensa CPUs have hard-configured
|
|
|
|
interrupt priorities associated with each timer, and some of
|
|
|
|
them can be unmaskable (and thus not usable by OS code that
|
|
|
|
need synchronization, like the timer subsystem!). Choose
|
|
|
|
carefully. Generally you want the timer with the highest
|
|
|
|
priority maskable interrupt.
|
2017-01-25 13:00:08 +01:00
|
|
|
|
2018-11-05 10:17:49 +01:00
|
|
|
config SAM0_RTC_TIMER
|
|
|
|
bool "Atmel SAM0 series RTC timer"
|
|
|
|
depends on SOC_FAMILY_SAM0
|
|
|
|
select TICKLESS_CAPABLE
|
|
|
|
help
|
|
|
|
This module implements a kernel device driver for the Atmel SAM0
|
|
|
|
series Real Time Counter and provides the standard "system clock
|
|
|
|
driver" interfaces.
|
|
|
|
|
2019-06-12 21:22:43 +02:00
|
|
|
config MCHP_XEC_RTOS_TIMER
|
|
|
|
bool "Microchip XEC series RTOS timer"
|
|
|
|
depends on SOC_FAMILY_MEC
|
|
|
|
select TICKLESS_CAPABLE
|
|
|
|
help
|
|
|
|
This module implements a kernel device driver for the Microchip
|
|
|
|
XEC series RTOS timer and provides the standard "system clock
|
|
|
|
driver" interfaces.
|
|
|
|
|
2019-08-20 18:58:04 +02:00
|
|
|
config CC13X2_CC26X2_RTC_TIMER
|
|
|
|
bool "TI SimpleLink CC13x2/CC26x2 RTC timer"
|
|
|
|
depends on SOC_SERIES_CC13X2_CC26X2
|
|
|
|
select TICKLESS_CAPABLE
|
|
|
|
help
|
|
|
|
This module implements a kernel device driver for the TI SimpleLink
|
|
|
|
CC13X2_CC26X2 series Real Time Counter and provides the standard
|
|
|
|
"system clock driver" interfaces.
|
|
|
|
|
2021-04-22 07:40:51 +02:00
|
|
|
config RCAR_CMT_TIMER
|
|
|
|
bool "Renesas RCar cmt timer"
|
|
|
|
default y
|
|
|
|
depends on SOC_SERIES_RCAR_GEN3
|
|
|
|
help
|
|
|
|
This module implements a kernel device driver for the Renesas RCAR
|
|
|
|
platform provides the standard "system clock driver" interfaces.
|
|
|
|
If unchecked, no timer will be used.
|
|
|
|
|
2018-11-18 08:28:49 +01:00
|
|
|
config XLNX_PSTTC_TIMER
|
|
|
|
bool "Xilinx PS ttc timer support"
|
|
|
|
default y
|
|
|
|
depends on SOC_XILINX_ZYNQMP
|
2020-03-18 05:47:19 +01:00
|
|
|
select TICKLESS_CAPABLE
|
2018-11-18 08:28:49 +01:00
|
|
|
help
|
|
|
|
This module implements a kernel device driver for the Xilinx ZynqMP
|
|
|
|
platform provides the standard "system clock driver" interfaces.
|
|
|
|
If unchecked, no timer will be used.
|
|
|
|
|
|
|
|
config XLNX_PSTTC_TIMER_INDEX
|
|
|
|
int "Xilinx PS ttc timer index"
|
|
|
|
range 0 3
|
|
|
|
default 0
|
|
|
|
depends on XLNX_PSTTC_TIMER
|
|
|
|
help
|
|
|
|
This is the index of TTC timer picked to provide system clock.
|
|
|
|
|
2020-01-07 07:31:41 +01:00
|
|
|
config CAVS_TIMER
|
|
|
|
bool "CAVS DSP Wall Clock Timer on Intel SoC"
|
|
|
|
depends on CAVS_ICTL
|
|
|
|
select TICKLESS_CAPABLE
|
|
|
|
help
|
|
|
|
The DSP wall clock timer is a timer driven directly by
|
|
|
|
external oscillator and is external to the CPU core(s).
|
|
|
|
It is not as fast as the internal core clock, but provides
|
|
|
|
a common and synchronized counter for all CPU cores (which
|
|
|
|
is useful for SMP).
|
|
|
|
|
2020-10-16 20:58:37 +02:00
|
|
|
config LEON_GPTIMER
|
|
|
|
bool "LEON timer"
|
|
|
|
depends on SOC_SPARC_LEON
|
|
|
|
select DYNAMIC_INTERRUPTS
|
|
|
|
help
|
|
|
|
This module implements a kernel device driver for the GRLIB
|
|
|
|
GPTIMER which is common in LEON systems.
|
|
|
|
|
2020-12-04 06:57:20 +01:00
|
|
|
config NPCX_ITIM_TIMER
|
|
|
|
bool "Nuvoton NPCX series internal 64/32-bit timers"
|
|
|
|
default y
|
|
|
|
depends on SOC_FAMILY_NPCX
|
|
|
|
select TICKLESS_CAPABLE
|
|
|
|
help
|
|
|
|
This module implements a kernel device driver for the Nuvoton NPCX
|
|
|
|
series internal 64/32-bit timers and provides the standard "system
|
|
|
|
clock driver" interfaces.
|
|
|
|
|
2015-09-28 20:24:50 +02:00
|
|
|
config SYSTEM_CLOCK_DISABLE
|
|
|
|
bool "API to disable system clock"
|
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
This option enables the sys_clock_disable() API in the kernel. It is
|
|
|
|
needed by some subsystems (which will automatically select it), but is
|
|
|
|
rarely needed by applications.
|
2015-09-28 20:24:50 +02:00
|
|
|
|
2015-11-20 22:26:25 +01:00
|
|
|
config TIMER_READS_ITS_FREQUENCY_AT_RUNTIME
|
|
|
|
bool "Timer queries its hardware to find its frequency at runtime"
|
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
The drivers select this option automatically when needed. Do not modify
|
|
|
|
this unless you have a very good reason for it.
|
2016-01-04 14:48:50 +01:00
|
|
|
|
2019-06-25 19:09:45 +02:00
|
|
|
config SYSTEM_CLOCK_SLOPPY_IDLE
|
|
|
|
bool "Timer allowed to skew uptime clock during idle"
|
|
|
|
help
|
|
|
|
When true, the timer driver is not required to maintain a
|
|
|
|
correct system uptime count when the system enters idle.
|
|
|
|
Some platforms may take advantage of this to reduce the
|
|
|
|
overhead from regular interrupts required to handle counter
|
|
|
|
wraparound conditions.
|
|
|
|
|
2016-01-04 14:48:50 +01:00
|
|
|
config SYSTEM_CLOCK_INIT_PRIORITY
|
|
|
|
int "System clock driver initialization priority"
|
|
|
|
default 0
|
|
|
|
help
|
2017-12-13 16:08:21 +01:00
|
|
|
This options can be used to set a specific initialization priority
|
|
|
|
value for the system clock driver. As driver initialization might need
|
|
|
|
the clock to be running already, you should let the default value as it
|
|
|
|
is (0).
|
2017-12-21 14:14:19 +01:00
|
|
|
|
2021-01-06 21:16:55 +01:00
|
|
|
# Hidden option to be selected by individual SoC.
|
2018-10-12 15:58:21 +02:00
|
|
|
config TICKLESS_CAPABLE
|
2021-01-06 21:16:55 +01:00
|
|
|
bool
|
2018-10-12 15:58:21 +02:00
|
|
|
help
|
|
|
|
Timer drivers should select this flag if they are capable of
|
|
|
|
supporting tickless operation. That is, a call to
|
2021-02-25 21:33:15 +01:00
|
|
|
sys_clock_set_timeout() with a number of ticks greater than
|
2018-10-12 15:58:21 +02:00
|
|
|
one should be expected not to produce a call to
|
2021-02-25 21:33:15 +01:00
|
|
|
sys_clock_announce() (really, not to produce an interrupt at
|
2018-10-12 15:58:21 +02:00
|
|
|
all) until the specified expiration.
|
|
|
|
|
2021-03-01 17:57:23 +01:00
|
|
|
DT_COMPAT_NXP_OS_TIMER := nxp,os-timer
|
|
|
|
|
|
|
|
config MCUX_OS_TIMER
|
|
|
|
bool "MCUX OS Event timer"
|
|
|
|
depends on HAS_MCUX_OS_TIMER
|
|
|
|
default $(dt_compat_enabled,$(DT_COMPAT_NXP_OS_TIMER))
|
|
|
|
select TICKLESS_CAPABLE
|
|
|
|
help
|
|
|
|
This module implements a kernel device driver for the NXP OS
|
|
|
|
event timer and provides the standard "system clock driver" interfaces.
|
|
|
|
|
2021-07-07 20:50:43 +02:00
|
|
|
config MCUX_LPTMR_TIMER
|
|
|
|
bool "MCUX LPTMR timer"
|
|
|
|
depends on HAS_MCUX_LPTMR && !COUNTER_MCUX_LPTMR
|
|
|
|
help
|
|
|
|
This module implements a kernel device driver for the NXP MCUX Low
|
|
|
|
Power Timer (LPTMR) and provides the standard "system clock driver"
|
|
|
|
interfaces.
|
|
|
|
|
2015-06-05 20:01:57 +02:00
|
|
|
endmenu
|