mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
sys/ztimer: auto_init react to possibly missing ztimer_periph_timer
This commit is contained in:
parent
b2bcfabcfb
commit
594fe83843
@ -67,13 +67,7 @@
|
||||
|
||||
/* Step 0: define available ztimer-periphery by activated modules */
|
||||
|
||||
/* #if CONFIG_ZTIMER_USEC_TYPE_PERIPH_TIMER
|
||||
* replaces #if MODULE_ZTIMER_PERIPH_TIMER
|
||||
* the ztimer_periph_timer is always available
|
||||
* having an (1) config defined in ztimer/config.h
|
||||
*/
|
||||
|
||||
#if CONFIG_ZTIMER_USEC_TYPE_PERIPH_TIMER
|
||||
#if MODULE_ZTIMER_PERIPH_TIMER
|
||||
# define ZTIMER_TIMER _ztimer_periph_timer
|
||||
# define ZTIMER_TIMER_CLK _ztimer_periph_timer.super
|
||||
# define ZTIMER_TIMER_FREQ CONFIG_ZTIMER_USEC_BASE_FREQ
|
||||
@ -99,10 +93,13 @@
|
||||
/* ZTIMER_USEC always uses the basic timer
|
||||
* basic timer is available on all boards */
|
||||
#if MODULE_ZTIMER_USEC
|
||||
# ifdef ZTIMER_TIMER
|
||||
# define ZTIMER_USEC_TIMER 1
|
||||
# ifndef INIT_ZTIMER_TIMER
|
||||
# define INIT_ZTIMER_TIMER 1
|
||||
# endif
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/* ZTIMER_MSEC prefers ZTIMER_RTT (ztimer_periph_rtt)
|
||||
* if it is available and runs at a frequency > 1kHz
|
||||
@ -116,7 +113,7 @@
|
||||
# if ZTIMER_RTT_FREQ != FREQ_1KHZ
|
||||
# define ZTIMER_MSEC_CONVERT_LOWER_FREQ ZTIMER_RTT_FREQ
|
||||
# endif
|
||||
# else
|
||||
# elif defined(ZTIMER_TIMER)
|
||||
# define ZTIMER_MSEC_TIMER 1
|
||||
# ifndef INIT_ZTIMER_TIMER
|
||||
# define INIT_ZTIMER_TIMER 1
|
||||
@ -135,13 +132,12 @@
|
||||
# define INIT_ZTIMER_RTT 1
|
||||
# endif
|
||||
# define ZTIMER_SEC_CONVERT_LOWER_FREQ ZTIMER_RTT_FREQ
|
||||
# else
|
||||
# ifdef ZTIMER_RTC
|
||||
# elif defined(ZTIMER_RTC)
|
||||
# define ZTIMER_SEC_RTC
|
||||
# ifndef INIT_ZTIMER_RTC
|
||||
# define INIT_ZTIMER_RTC 1
|
||||
# endif
|
||||
# else
|
||||
# elif defined(ZTIMER_TIMER)
|
||||
# define ZTIMER_SEC_TIMER
|
||||
# ifndef INIT_ZTIMER_TIMER
|
||||
# define INIT_ZTIMER_TIMER 1
|
||||
@ -149,7 +145,6 @@
|
||||
# define ZTIMER_SEC_CONVERT_LOWER_FREQ ZTIMER_TIMER_FREQ
|
||||
# endif
|
||||
#endif
|
||||
#endif
|
||||
|
||||
/* Step 2: setup static memory for used ztimer-periphery */
|
||||
|
||||
@ -170,7 +165,7 @@ static ztimer_periph_rtc_t ZTIMER_RTC;
|
||||
/* Step 3: setup constants for ztimers and memory for converters */
|
||||
|
||||
#if MODULE_ZTIMER_USEC
|
||||
# ifdef ZTIMER_TIMER
|
||||
# ifdef ZTIMER_USEC_TIMER
|
||||
ztimer_clock_t *const ZTIMER_USEC_BASE = &ZTIMER_TIMER_CLK;
|
||||
# else
|
||||
# error No suitable ZTIMER_USEC config. Basic timer configuration missing?
|
||||
@ -249,7 +244,7 @@ void ztimer_init(void)
|
||||
#if INIT_ZTIMER_TIMER
|
||||
LOG_DEBUG(
|
||||
"ztimer_init(): ZTIMER_TIMER using periph timer %u, freq %lu, width %u\n",
|
||||
CONFIG_ZTIMER_USEC_DEV, CONFIG_ZTIMER_USEC_BASE_FREQ,
|
||||
CONFIG_ZTIMER_USEC_DEV, ZTIMER_TIMER_FREQ,
|
||||
CONFIG_ZTIMER_USEC_WIDTH);
|
||||
ztimer_periph_timer_init(&ZTIMER_TIMER, CONFIG_ZTIMER_USEC_DEV,
|
||||
ZTIMER_TIMER_FREQ, WIDTH_TO_MAXVAL(CONFIG_ZTIMER_USEC_WIDTH));
|
||||
|
Loading…
Reference in New Issue
Block a user