Home
last modified time | relevance | path

Searched full:timer (Results 1 – 25 of 1552) sorted by relevance

12345678910>>...63

/Zephyr-latest/drivers/timer/
DKconfig1 # 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 …]
Dsilabs_sleeptimer_timer.c15 #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 …]
DKconfig.x867 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 …]
Dite_it8xxx2_timer.c9 #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 …]
DKconfig.xtensa7 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.
DKconfig.cortex_m_systick6 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/
Dtimer.c14 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/
Dtimer.c23 * @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/
Dcmsis_timer.c14 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/
Dtimer.c39 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/
Dtimers.rst6 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/
Dusbc_timer.h13 * @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 …]
Dusbc_timer.c9 /** 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/
Dtimer.c8 * @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/
Dtimer.c29 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/
Dmain.c43 * 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/
Dmain.c19 #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/
Dtimer.c28 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/
Dcounter_smartbond_timer.c28 #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 …]
Dcounter_ll_stm32_timer.c26 /** 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 …]
Ddualtimer_cmsdk_apb.h16 /* 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/
Dpwm_stm32.c79 /** 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 …]
Dpwm_gecko.c16 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/
Despressif,esp32-mcpwm.yaml17 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/
Dtestcase.yaml2 kernel.timer.monotonic:
5 - timer
9 kernel.timer.monotonic.apic.tsc:
12 - timer
18 kernel.timer.monotonic.icount_off:
22 - timer

12345678910>>...63