de1f1dd164
Before, both uwTick and mp_hal_ticks_ms() were used as clock source. That assumes, that these two are synchronous and start with the same value, which may be not the case for all ports. If the lag between uwTick and mp_hal_ticks_ms() is larger than the timer interval, the timer would either rush up until the times are synchronous, or not start until uwTick wraps over. As suggested by @dpgeorge, MICROPY_SOFT_TIMER_TICKS_MS is now used in softtimer.c, which has to be defined in a port's mpconfigport.h with the variable that holds the SysTick counter. Note that it's not possible to switch everything in softtimer.c to use mp_hal_ticks_ms() because the logic in SysTick_Handler that schedules soft_timer_handler() uses (eg on mimxrt) the uwTick variable directly (named systick_ms there), and mp_hal_ticks_ms() uses a different source timer. Thus it is made fully configurable. |
||
---|---|---|
.. | ||
gchelper_generic.c | ||
gchelper_native.c | ||
gchelper_thumb1.s | ||
gchelper_thumb2.s | ||
gchelper.h | ||
interrupt_char.c | ||
interrupt_char.h | ||
mpirq.c | ||
mpirq.h | ||
pyexec.c | ||
pyexec.h | ||
semihosting.c | ||
semihosting.h | ||
softtimer.c | ||
softtimer.h | ||
stdout_helpers.c | ||
sys_stdio_mphal.c |