/Zephyr-latest/drivers/timer/ |
D | Kconfig | 1 # Timer driver configuration options 10 menu "Timer drivers" 19 bool "Timer queries its hardware to find its frequency at runtime" 25 bool "Timer allowed to skew uptime clock during idle" 27 When true, the timer driver is not required to maintain a 46 Timer drivers should select this flag if they are capable of 66 source "drivers/timer/Kconfig.altera_avalon" 67 source "drivers/timer/Kconfig.ambiq" 68 source "drivers/timer/Kconfig.x86" 69 source "drivers/timer/Kconfig.arcv2" [all …]
|
D | silabs_sleeptimer_timer.c | 15 #include <zephyr/drivers/timer/system_timer.h> 22 /* Maximum time interval between timer interrupts (in hw_cycles) */ 36 /* Global timer state */ 42 bool initialized; /* Set to true when timer is initialized */ 43 sl_sleeptimer_timer_handle_t handle; /* Timer handle for system timer */ 50 struct sleeptimer_timer_data *timer = data; in sleeptimer_cb() local 53 uint32_t prev = atomic_get(&timer->last_count); in sleeptimer_cb() 57 uint32_t unannounced = pending / timer->cyc_per_tick; in sleeptimer_cb() 59 atomic_set(&timer->last_count, prev + unannounced * timer->cyc_per_tick); in sleeptimer_cb() 64 static void sleeptimer_clock_set_timeout(int32_t ticks, struct sleeptimer_timer_data *timer) in sleeptimer_clock_set_timeout() argument [all …]
|
D | Kconfig.x86 | 7 prompt "Default System Timer" 12 Select Default System Timer. 15 bool "HPET timer" 23 This option selects High Precision Event Timer (HPET) as a 24 system timer. 27 bool "Local APIC timer" 39 bool "Local APIC timer using TSC deadline mode" 44 Extremely simple timer driver based the local APIC TSC 55 bool "Local APIC timer using TSC time source" 65 timer frequency. [all …]
|
D | ite_it8xxx2_timer.c | 9 #include <zephyr/drivers/timer/system_timer.h> 17 LOG_MODULE_REGISTER(timer, LOG_LEVEL_ERR); 22 "ITE RTOS timer HW frequency is fixed at 32768Hz"); 24 /* Event timer configurations */ 28 /* Event timer max count is 512 sec (base on clock source 32768Hz) */ 31 /* Busy wait low timer configurations */ 36 /* Busy wait high timer configurations */ 40 /* Busy wait high timer max count is 71.58min (base on clock source 1MHz) */ 44 const int32_t z_sys_timer_irq_for_test = DT_IRQ_BY_IDX(DT_NODELABEL(timer), 5, irq); 49 * One shot timer configurations [all …]
|
D | Kconfig.xtensa | 7 bool "Xtensa timer support" 12 Enables a system timer driver for Xtensa based on the CCOUNT 16 int "System timer CCOMPAREn register index" 21 used for the system timer. Xtensa CPUs have hard-configured 22 interrupt priorities associated with each timer, and some of 24 need synchronization, like the timer subsystem!). In 25 general timer zero is guaranteed to be present and usable.
|
D | Kconfig.cortex_m_systick | 6 DT_CHOSEN_IDLE_TIMER := zephyr,cortex-m-idle-timer 9 bool "Cortex-M SYSTICK timer" 21 SYSTICK timer and provides the standard "system clock driver" interfaces. 31 bool "Cortex-M SYSTICK timer with sys_clock_cycle_get_64() support" 47 bool "Use an additional timer while entering IDLE" 53 There are chips e.g. STMFX family that use SysTick as a system timer, 55 another timer that is not stopped, but it has lower frequency e.g. 56 RTC, thus it can't be used as a main system timer. 58 Use the IDLE timer for timeout (wakeup) when the system is entering 61 The chosen IDLE timer node has to support setting alarm from the
|
/Zephyr-latest/subsys/portability/cmsis_rtos_v2/ |
D | timer.c | 14 static void zephyr_timer_wrapper(struct k_timer *timer); 26 static void zephyr_timer_wrapper(struct k_timer *timer) in zephyr_timer_wrapper() argument 30 cm_timer = CONTAINER_OF(timer, struct cv2_timer, z_timer); in zephyr_timer_wrapper() 35 * @brief Create a Timer 40 struct cv2_timer *timer; in osTimerNew() local 54 if (k_mem_slab_alloc(&cv2_timer_slab, (void **)&timer, K_MSEC(100)) == 0) { in osTimerNew() 55 (void)memset(timer, 0, sizeof(struct cv2_timer)); in osTimerNew() 60 timer->callback_function = func; in osTimerNew() 61 timer->arg = argument; in osTimerNew() 62 timer->type = type; in osTimerNew() [all …]
|
/Zephyr-latest/kernel/ |
D | timer.c | 23 * @brief Handle expiration of a kernel timer object. 25 * @param t Timeout used by the timer. 29 struct k_timer *timer = CONTAINER_OF(t, struct k_timer, timeout); in z_timer_expiration_handler() local 36 * this function. Usually, the timeout structure related to the timer in z_timer_expiration_handler() 39 * interrupts are locked again, a given timer gets restarted from an in z_timer_expiration_handler() 40 * interrupt context that has a priority higher than the system timer in z_timer_expiration_handler() 41 * interrupt. Then, the timeout structure for this timer will turn out in z_timer_expiration_handler() 42 * to be linked to the timeout list. And in such case, since the timer in z_timer_expiration_handler() 52 * if the timer is periodic, start it again; don't add _TICK_ALIGN in z_timer_expiration_handler() 55 if (!K_TIMEOUT_EQ(timer->period, K_NO_WAIT) && in z_timer_expiration_handler() [all …]
|
/Zephyr-latest/subsys/portability/cmsis_rtos_v1/ |
D | cmsis_timer.c | 14 static void zephyr_timer_wrapper(struct k_timer *timer); 27 static void zephyr_timer_wrapper(struct k_timer *timer) in zephyr_timer_wrapper() argument 31 cm_timer = CONTAINER_OF(timer, struct timer_obj, ztimer); in zephyr_timer_wrapper() 36 * @brief Create a Timer 41 struct timer_obj *timer; in osTimerCreate() local 51 if (k_mem_slab_alloc(&cmsis_timer_slab, (void **)&timer, K_MSEC(100)) == 0) { in osTimerCreate() 52 (void)memset(timer, 0, sizeof(struct timer_obj)); in osTimerCreate() 57 timer->callback_function = timer_def->ptimer; in osTimerCreate() 58 timer->arg = argument; in osTimerCreate() 59 timer->type = type; in osTimerCreate() [all …]
|
/Zephyr-latest/lib/posix/options/ |
D | timer.c | 39 struct timer_obj *timer; in zephyr_timer_wrapper() local 41 timer = (struct timer_obj *)ztimer; in zephyr_timer_wrapper() 43 if (timer->reload == 0U) { in zephyr_timer_wrapper() 44 timer->status = NOT_ACTIVE; in zephyr_timer_wrapper() 45 LOG_DBG("timer %p not active", timer); in zephyr_timer_wrapper() 48 if (timer->evp.sigev_notify == SIGEV_NONE) { in zephyr_timer_wrapper() 53 if (timer->evp.sigev_notify_function == NULL) { in zephyr_timer_wrapper() 58 LOG_DBG("calling sigev_notify_function %p", timer->evp.sigev_notify_function); in zephyr_timer_wrapper() 59 (timer->evp.sigev_notify_function)(timer->evp.sigev_value); in zephyr_timer_wrapper() 65 struct timer_obj *timer = (struct timer_obj *)arg; in zephyr_thread_wrapper() local [all …]
|
/Zephyr-latest/doc/kernel/services/timing/ |
D | timers.rst | 6 A :dfn:`timer` is a kernel object that measures the passage of time 7 using the kernel's system clock. When a timer's specified time limit 19 Any number of timers can be defined (limited only by available RAM). Each timer 22 A timer has the following key properties: 24 * A **duration** specifying the time interval before the timer 28 * A **period** specifying the time interval between all timer 31 ``K_FOREVER`` means that the timer is a one-shot timer that stops 32 after a single expiration. (For example then, if a timer is started 36 * An **expiry function** that is executed each time the timer expires. 40 * A **stop function** that is executed if the timer is stopped prematurely [all …]
|
/Zephyr-latest/subsys/usb/usb_c/ |
D | usbc_timer.h | 13 * @brief USB-C Timer Object 16 /** kernel timer */ 17 struct k_timer timer; member 20 /** flags to track timer status */ 25 * @brief Initialize a timer 27 * @param usbc_timer timer object 28 * @param timeout_ms timer timeout in ms 33 * @brief Start a timer 35 * @param usbc_timer timer object 40 * @brief Check if a timer has expired [all …]
|
D | usbc_timer.c | 9 /** Timer flag to track if timer was started */ 11 /** Timer flag to track if timer has expired */ 15 * @brief The timer function that's executed when the timer expires 17 static void usbc_timer_handler(struct k_timer *timer) in usbc_timer_handler() argument 19 struct usbc_timer_t *usbc_timer = k_timer_user_data_get(timer); in usbc_timer_handler() 26 k_timer_init(&usbc_timer->timer, usbc_timer_handler, NULL); in usbc_timer_init() 27 k_timer_user_data_set(&usbc_timer->timer, usbc_timer); in usbc_timer_init() 35 k_timer_start(&usbc_timer->timer, K_MSEC(usbc_timer->timeout_ms), K_NO_WAIT); in usbc_timer_start() 59 k_timer_stop(&usbc_timer->timer); in usbc_timer_stop()
|
/Zephyr-latest/modules/nrf_wifi/os/ |
D | timer.c | 8 * @brief File containing timer specific definitons for the 19 #include "timer.h" 23 struct timer_list *timer; in timer_expiry_function() local 25 timer = (struct timer_list *)CONTAINER_OF(work, struct timer_list, work.work); in timer_expiry_function() 27 timer->function(timer->data); in timer_expiry_function() 30 void init_timer(struct timer_list *timer) in init_timer() argument 32 k_work_init_delayable(&timer->work, timer_expiry_function); in init_timer() 35 void mod_timer(struct timer_list *timer, int msec) in mod_timer() argument 37 k_work_schedule(&timer->work, K_MSEC(msec)); in mod_timer() 40 void del_timer_sync(struct timer_list *timer) in del_timer_sync() argument [all …]
|
/Zephyr-latest/tests/subsys/portability/cmsis_rtos_v2/src/ |
D | timer.c | 29 TC_PRINT("oneshot_callback (Timer %d) = %d\n", in Timer1_Callback() 38 TC_PRINT("periodic_callback (Timer %d) = %d\n", in Timer2_Callback() 52 /* Create one-shot timer */ in ZTEST() 55 zassert_true(id1 != NULL, "error creating one-shot timer"); in ZTEST() 58 zassert_str_equal(timer_attr.name, name, "Error getting Timer name"); in ZTEST() 60 /* Stop the timer before start */ in ZTEST() 63 "error while stopping non-active timer"); in ZTEST() 67 zassert_true(status == osOK, "error starting one-shot timer"); in ZTEST() 69 zassert_equal(osTimerIsRunning(id1), 1, "Error: Timer not running"); in ZTEST() 71 /* Timer should fire only once if setup in one shot in ZTEST() [all …]
|
/Zephyr-latest/tests/kernel/timer/timer_api/src/ |
D | main.c | 43 * remaining time for a partially elapsed timer in ticks will be 52 static void duration_expire(struct k_timer *timer); 53 static void duration_stop(struct k_timer *timer); 55 /** TESTPOINT: init timer via K_TIMER_DEFINE */ 113 static void duration_expire(struct k_timer *timer) in duration_expire() argument 120 TIMER_ASSERT(interval_check(interval, DURATION), timer); in duration_expire() 122 TIMER_ASSERT(interval_check(interval, PERIOD), timer); in duration_expire() 126 k_timer_stop(timer); in duration_expire() 130 static void duration_stop(struct k_timer *timer) in duration_stop() argument 135 static void period0_expire(struct k_timer *timer) in period0_expire() argument [all …]
|
/Zephyr-latest/samples/drivers/counter/alarm/src/ |
D | main.c | 19 #define TIMER DT_NODELABEL(tc4) macro 21 #define TIMER DT_NODELABEL(tc0) macro 23 #define TIMER DT_NODELABEL(extrtc0) macro 25 #define TIMER DT_NODELABEL(rtc0) macro 27 #define TIMER DT_CHOSEN(counter) macro 29 #define TIMER DT_INST(0, st_stm32_counter) macro 31 #define TIMER DT_INST(0, st_stm32_rtc) macro 33 #define TIMER DT_NODELABEL(timer3) macro 35 #define TIMER DT_NODELABEL(counter0) macro 37 #define TIMER DT_INST(0, xlnx_xps_timer_1_00_a) macro [all …]
|
/Zephyr-latest/tests/subsys/portability/cmsis_rtos_v1/src/ |
D | timer.c | 28 TC_PRINT("oneshot_callback (Timer %d) = %d\n", in Timer1_Callback() 37 TC_PRINT("periodic_callback (Timer %d) = %d\n", in Timer2_Callback() 50 /* Create one-shot timer */ in ZTEST() 53 zassert_true(id1 != NULL, "error creating one-shot timer"); in ZTEST() 55 /* Stop the timer before start */ in ZTEST() 57 zassert_true(status == osErrorResource, "error while stopping non-active timer"); in ZTEST() 61 zassert_true(status == osOK, "error starting one-shot timer"); in ZTEST() 63 /* Timer should fire only once if setup in one shot in ZTEST() 69 "error setting up one-shot timer"); in ZTEST() 72 zassert_true(status == osOK, "error stopping one-shot timer"); in ZTEST() [all …]
|
/Zephyr-latest/drivers/counter/ |
D | counter_smartbond_timer.c | 28 #define COUNTER_DT_DEVICE(_idx) DEVICE_DT_GET_OR_NULL(DT_NODELABEL(timer##_idx)) 50 /* Register set for timer */ 51 TIMER2_Type *timer; member 53 /* Timer driven by DIVn if 1 or lp_clk if 0 */ 83 * a timer block will automatically be switched from DIVN to LP and vice versa. 98 switch ((uint32_t)config->timer) { in counter_smartbond_pdc_trigger_get() 99 case (uint32_t)TIMER: in counter_smartbond_pdc_trigger_get() 140 TIMER2_Type *timer = config->timer; in counter_smartbond_start() local 155 timer->TIMER2_CTRL_REG |= (TIMER2_TIMER2_CTRL_REG_TIM_CLK_EN_Msk | in counter_smartbond_start() 166 TIMER2_Type *timer = config->timer; in counter_smartbond_stop() local [all …]
|
D | counter_ll_stm32_timer.c | 26 /** Maximum number of timer channels. */ 29 /** Number of channels for timer by index. */ 105 TIM_TypeDef *timer; member 119 TIM_TypeDef *timer = config->timer; in counter_stm32_start() local 122 LL_TIM_EnableCounter(timer); in counter_stm32_start() 130 TIM_TypeDef *timer = config->timer; in counter_stm32_stop() local 133 LL_TIM_DisableCounter(timer); in counter_stm32_stop() 142 return LL_TIM_GetAutoReload(config->timer); in counter_stm32_get_top_value() 149 return LL_TIM_GetCounter(config->timer); in counter_stm32_read() 201 TIM_TypeDef *timer = config->timer; in counter_stm32_set_cc() local [all …]
|
D | dualtimer_cmsdk_apb.h | 16 /* Offset: 0x000 (R/W) Timer 1 Load */ 18 /* Offset: 0x004 (R/ ) Timer 1 Counter Current Value */ 20 /* Offset: 0x008 (R/W) Timer 1 Control */ 22 /* Offset: 0x00C ( /W) Timer 1 Interrupt Clear */ 24 /* Offset: 0x010 (R/ ) Timer 1 Raw Interrupt Status */ 26 /* Offset: 0x014 (R/ ) Timer 1 Masked Interrupt Status */ 32 /* Offset: 0x020 (R/W) Timer 2 Load */ 34 /* Offset: 0x024 (R/ ) Timer 2 Counter Current Value */ 36 /* Offset: 0x028 (R/W) Timer 2 Control */ 38 /* Offset: 0x02C ( /W) Timer 2 Interrupt Clear */ [all …]
|
/Zephyr-latest/drivers/pwm/ |
D | pwm_stm32.c | 79 /** Timer clock (Hz). */ 90 TIM_TypeDef *timer; member 101 /** Maximum number of timer channels : some stm32 soc have 6 else only 4 */ 131 /** Maximum number of complemented timer channels is ARRAY_SIZE(ch2ll_n)*/ 213 * Obtain timer clock speed. 215 * @param pclken Timer clock control subsystem. 216 * @param tim_clk Where computed timer clock will be stored. 267 * Up to a certain threshold value of APB{1,2} prescaler, timer clock in get_tim_clk() 269 * (2 if TIMPRE=0, 4 if TIMPRE=1). Above threshold, timer clock is set in get_tim_clk() 297 * If the APB prescaler equals 1, the timer clock frequencies in get_tim_clk() [all …]
|
D | pwm_gecko.c | 16 TIMER_TypeDef *timer; member 33 if (BUS_RegMaskedRead(&cfg->timer->CC[channel].CTRL, in pwm_gecko_set_cycles() 37 BUS_RegMaskedWrite(&cfg->timer->ROUTE, in pwm_gecko_set_cycles() 40 BUS_RegMaskedSet(&cfg->timer->ROUTE, 1 << channel); in pwm_gecko_set_cycles() 42 BUS_RegMaskedWrite(&cfg->timer->ROUTELOC0, in pwm_gecko_set_cycles() 46 BUS_RegMaskedSet(&cfg->timer->ROUTEPEN, 1 << channel); in pwm_gecko_set_cycles() 52 TIMER_InitCC(cfg->timer, channel, &compare_config); in pwm_gecko_set_cycles() 55 cfg->timer->CC[channel].CTRL |= (flags & PWM_POLARITY_INVERTED) ? in pwm_gecko_set_cycles() 58 TIMER_TopSet(cfg->timer, period_cycles); in pwm_gecko_set_cycles() 60 TIMER_CompareBufSet(cfg->timer, channel, pulse_cycles); in pwm_gecko_set_cycles() [all …]
|
/Zephyr-latest/dts/bindings/pwm/ |
D | espressif,esp32-mcpwm.yaml | 17 and asymmetric configuration. MCPWMxA and MCPWMxB will share the same timer, thus having the same 20 The driver currently always use the timer x for operator x. Timer 0 will use operator 0 for 22 Timer 1 will use operator 1 for PWM1A/B, and so on. 25 Channel 0 -> Timer 0, Operator 0, output PWM0A 26 Channel 1 -> Timer 0, Operator 0, output PWM0B 27 Channel 2 -> Timer 1, Operator 1, output PWM1A 28 Channel 3 -> Timer 1, Operator 1, output PWM1B 29 Channel 4 -> Timer 2, Operator 2, output PWM2A 30 Channel 5 -> Timer 2, Operator 2, output PWM2B 89 8 bit timer prescale for the global clock. [all …]
|
/Zephyr-latest/tests/kernel/timer/timer_monotonic/ |
D | testcase.yaml | 2 kernel.timer.monotonic: 5 - timer 9 kernel.timer.monotonic.apic.tsc: 12 - timer 18 kernel.timer.monotonic.icount_off: 22 - timer
|