Lines Matching +full:pll +full:- +full:lock +full:- +full:timeout +full:- +full:ms

3  * SPDX-License-Identifier: Apache-2.0
10 #include <zephyr/dt-bindings/interrupt-controller/ite-intc.h>
19 #define COUNT_1US (EC_FREQ / USEC_PER_SEC - 1)
53 * timer2 only one shot to wake up chip and change pll.
61 #define MS_TO_COUNT(hz, ms) ((hz) * (ms) / 1000) argument
76 static struct k_spinlock lock; variable
109 * We are here because we have completed changing PLL sequence, in timer_5ms_one_shot_isr()
117 * changing PLL sequence.
135 timer2_reg->ET2PSR = EXT_PSR_32P768K; in timer_5ms_one_shot()
141 hw_cnt = MS_TO_COUNT(32768, 5/*ms*/); in timer_5ms_one_shot()
142 timer2_reg->ET2CNTLH2R = (uint8_t)((hw_cnt >> 16) & 0xff); in timer_5ms_one_shot()
143 timer2_reg->ET2CNTLHR = (uint8_t)((hw_cnt >> 8) & 0xff); in timer_5ms_one_shot()
144 timer2_reg->ET2CNTLLR = (uint8_t)(hw_cnt & 0xff); in timer_5ms_one_shot()
160 usec_to_wait--; in arch_busy_wait()
163 if ((IT8XXX2_EXT_CNTOX(BUSY_WAIT_H_TIMER) - start) >= usec_to_wait) { in arch_busy_wait()
172 /* Enable and re-start event timer */ in evt_timer_enable()
191 uint32_t dticks = (~(IT8XXX2_EXT_CNTOX(FREE_RUN_TIMER)) - in evt_timer_isr()
214 * TODO: to increment 32-bit "top half" here for software 64-bit in free_run_timer_overflow_isr()
226 /* Always return for non-tickless kernel system */ in sys_clock_set_timeout()
231 k_spinlock_key_t key = k_spin_lock(&lock); in sys_clock_set_timeout()
238 * If kernel doesn't have a timeout: in sys_clock_set_timeout()
242 * 2.CONFIG_SYSTEM_CLOCK_SLOPPY_IDLE = n (schedule timeout as far in sys_clock_set_timeout()
246 k_spin_unlock(&lock, key); in sys_clock_set_timeout()
265 dcycles = next_cycs - now; in sys_clock_set_timeout()
270 /* Set event timer 24-bit count */ in sys_clock_set_timeout()
279 k_spin_unlock(&lock, key); in sys_clock_set_timeout()
281 LOG_DBG("timeout is 0x%x, set hw count 0x%x", ticks, hw_cnt); in sys_clock_set_timeout()
287 /* Always return 0 for non-tickless kernel system */ in sys_clock_elapsed()
292 k_spinlock_key_t key = k_spin_lock(&lock); in sys_clock_elapsed()
297 uint32_t dticks = (~(IT8XXX2_EXT_CNTOX(FREE_RUN_TIMER)) - in sys_clock_elapsed()
301 k_spin_unlock(&lock, key); in sys_clock_elapsed()
325 uint32_t ms, in timer_init() argument
335 hw_cnt = ms; in timer_init()
338 hw_cnt = MS_TO_COUNT(32768, ms); in timer_init()
340 hw_cnt = MS_TO_COUNT(1024, ms); in timer_init()
342 hw_cnt = MS_TO_COUNT(32, ms); in timer_init()
344 hw_cnt = MS_TO_COUNT(EC_FREQ, ms); in timer_init()
347 return -1; in timer_init()
353 return -1; in timer_init()
357 /* Enable and re-start external timer x */ in timer_init()
379 /* Enable and re-start external timer x */ in timer_init()
398 /* Enable 32-bit free run timer overflow interrupt */ in sys_clock_driver_init()
401 /* Set 32-bit timer4 for free run*/ in sys_clock_driver_init()
411 /* Set 24-bit timer3 for timeout event */ in sys_clock_driver_init()
435 /* Set 32-bit timer6 to count-- every 1us */ in sys_clock_driver_init()
446 * Set 24-bit timer5 to overflow every 1us in sys_clock_driver_init()
449 * and timer5 will automatically re-start counting down in sys_clock_driver_init()