1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

cpu: do not auto-select ztimer_periph_rtt for sam0, fe310

The sam0 rtt busy loops for 180us every time an alarm is set or
the counter is read, this propagates and leads to timing errors
on ztimer_msec that are higher than > +-1msec.

The same goes for fe310.
This commit is contained in:
Francisco Molina 2021-12-14 18:43:53 +01:00
parent ab0e118d10
commit 5e47fc7e22
4 changed files with 14 additions and 0 deletions

View File

@ -21,6 +21,7 @@ config CPU_FAM_FE310
select MODULE_PERIPH_PLIC if TEST_KCONFIG select MODULE_PERIPH_PLIC if TEST_KCONFIG
select MODULE_PERIPH_CORETIMER if MODULE_PERIPH_TIMER && HAS_PERIPH_CORETIMER select MODULE_PERIPH_CORETIMER if MODULE_PERIPH_TIMER && HAS_PERIPH_CORETIMER
select MODULE_PERIPH_RTT if MODULE_PERIPH_RTC && HAS_PERIPH_RTT select MODULE_PERIPH_RTT if MODULE_PERIPH_RTC && HAS_PERIPH_RTT
select MODULE_ZTIMER_NO_PERIPH_RTT if TEST_KCONFIG && MODULE_ZTIMER
config CPU_MODEL_FE310_G000 config CPU_MODEL_FE310_G000
bool bool

View File

@ -26,6 +26,7 @@ config CPU_COMMON_SAM0
select HAS_PERIPH_WDT_CB select HAS_PERIPH_WDT_CB
select HAS_PERIPH_WDT_WARNING_PERIOD select HAS_PERIPH_WDT_WARNING_PERIOD
select HAVE_SHARED_PERIPH_RTT_PERIPH_RTC select HAVE_SHARED_PERIPH_RTT_PERIPH_RTC
select MODULE_ZTIMER_NO_PERIPH_RTT if TEST_KCONFIG && MODULE_ZTIMER
if CPU_COMMON_SAM0 if CPU_COMMON_SAM0

View File

@ -12,6 +12,7 @@ config CPU_FAM_SAM3
select HAS_CPU_SAM3 select HAS_CPU_SAM3
select HAS_PERIPH_CPUID select HAS_PERIPH_CPUID
select HAS_PERIPH_HWRNG select HAS_PERIPH_HWRNG
select MODULE_ZTIMER_NO_PERIPH_RTT if TEST_KCONFIG && MODULE_ZTIMER
## CPU Models ## CPU Models
config CPU_MODEL_SAM3X8E config CPU_MODEL_SAM3X8E

View File

@ -78,6 +78,17 @@ ifneq (,$(filter ztimer_usec,$(USEMODULE)))
USEMODULE += ztimer_periph_timer USEMODULE += ztimer_periph_timer
endif endif
# NOTE: select the module here and not in the CPU so that order of inclusion
# does not have periph_rtt selected earlier that it should be while at the same
# time avoiding the module 'ztimer-no_periph_rtt' being included unecesarily.
# The sam0 rtt busy loops for 180us every time an alarm is set or
# the counter is read, this propagates and leads to timing errors
# on ztimer_msec that are higher than > +-1msec.
# The same goes for the fe310 rtt.
ifneq (,$(filter sam% fe310,$(CPU)))
USEMODULE += ztimer_no_periph_rtt
endif
ifneq (,$(filter ztimer_msec ztimer_sec,$(USEMODULE))) ifneq (,$(filter ztimer_msec ztimer_sec,$(USEMODULE)))
USEMODULE += ztimer USEMODULE += ztimer
ifeq (,$(filter ztimer_no_periph_rtt,$(USEMODULE))) ifeq (,$(filter ztimer_no_periph_rtt,$(USEMODULE)))