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:
parent
ab0e118d10
commit
5e47fc7e22
@ -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
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -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)))
|
||||||
|
Loading…
Reference in New Issue
Block a user