mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
207 lines
5.4 KiB
C
207 lines
5.4 KiB
C
/*
|
|
* Copyright (C) 2020 Inria
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
* Public License v2.1. See the file LICENSE in the top level directory for more
|
|
* details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup sys_ztimer
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief ztimer default configuration
|
|
*
|
|
*
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
*/
|
|
|
|
#ifndef ZTIMER_CONFIG_H
|
|
#define ZTIMER_CONFIG_H
|
|
|
|
#include "board.h"
|
|
#include "periph_conf.h"
|
|
|
|
#include "ztimer.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/*
|
|
* @brief Use periph_timer as the base timer for ZTIMER_USEC
|
|
*/
|
|
#define CONFIG_ZTIMER_USEC_TYPE_PERIPH_TIMER (1)
|
|
|
|
/* for ZTIMER_USEC, use xtimer configuration if available and no ztimer
|
|
* specific configuration is set. */
|
|
#if CONFIG_ZTIMER_USEC_TYPE_PERIPH_TIMER
|
|
# ifndef CONFIG_ZTIMER_USEC_DEV
|
|
# ifdef XTIMER_DEV
|
|
# define CONFIG_ZTIMER_USEC_DEV XTIMER_DEV
|
|
# endif
|
|
# endif
|
|
# ifndef CONFIG_ZTIMER_USEC_BASE_FREQ
|
|
# ifdef XTIMER_HZ
|
|
# define CONFIG_ZTIMER_USEC_BASE_FREQ XTIMER_HZ
|
|
# endif
|
|
# endif
|
|
# ifndef CONFIG_ZTIMER_USEC_WIDTH
|
|
# ifdef XTIMER_WIDTH
|
|
# define CONFIG_ZTIMER_USEC_WIDTH XTIMER_WIDTH
|
|
# endif
|
|
# endif
|
|
#endif
|
|
|
|
/**
|
|
* @brief Default timer device for ZTIMER_USEC
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_USEC_DEV
|
|
#define CONFIG_ZTIMER_USEC_DEV (TIMER_DEV(0))
|
|
#endif
|
|
|
|
/**
|
|
* @brief Default width of ZTIMER_LPTIMER
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_LPTIMER_WIDTH
|
|
#define CONFIG_ZTIMER_LPTIMER_WIDTH (32)
|
|
#endif
|
|
|
|
/**
|
|
* @brief ZTIMER_USEC optimal minimum value for ztimer_set()
|
|
*
|
|
* When scheduling an ISR every timer will be set to:
|
|
* max(CONFIG_ZTIMER_USEC_MIN, value).
|
|
*
|
|
* This value only applies if the counter object used for ZTIMER_USEC is
|
|
* periph_timer. This is supposed to be defined per-device in e.g., board.h.
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_USEC_MIN
|
|
#define CONFIG_ZTIMER_USEC_MIN (10)
|
|
#endif
|
|
|
|
/**
|
|
@brief ZTIMER_USEC counter object width
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_USEC_WIDTH
|
|
# if (TIMER_0_MAX_VALUE) == 0xffff
|
|
# define CONFIG_ZTIMER_USEC_WIDTH (16)
|
|
# elif (TIMER_0_MAX_VALUE) == 0xffffffUL
|
|
# define CONFIG_ZTIMER_USEC_WIDTH (24)
|
|
# else
|
|
# define CONFIG_ZTIMER_USEC_WIDTH (32)
|
|
# endif
|
|
#endif
|
|
|
|
/**
|
|
* @brief The frequency of ZTIMER_USEC_BASE (base ztimer for ZTIMER_USEC)
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_USEC_BASE_FREQ
|
|
#define CONFIG_ZTIMER_USEC_BASE_FREQ (1000000LU)
|
|
#endif
|
|
|
|
/**
|
|
* @brief The frequency of ZTIMER_MSEC_BASE (base ztimer for ZTIMER_MSEC)
|
|
*/
|
|
#ifdef MODULE_ZTIMER_PERIPH_RTT
|
|
# define CONFIG_ZTIMER_MSEC_BASE_FREQ (RTT_FREQUENCY)
|
|
# else
|
|
# define CONFIG_ZTIMER_MSEC_BASE_FREQ (CONFIG_ZTIMER_USEC_BASE_FREQ)
|
|
#endif /* MODULE_ZTIMER_PERIPH_RTT */
|
|
|
|
/**
|
|
* @brief The minimum pm mode required for ZTIMER_TIMER to run.
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_TIMER_BLOCK_PM_MODE
|
|
# ifdef CONFIG_ZTIMER_USEC_REQUIRED_PM_MODE
|
|
# define CONFIG_ZTIMER_TIMER_BLOCK_PM_MODE CONFIG_ZTIMER_USEC_REQUIRED_PM_MODE
|
|
# else
|
|
# define CONFIG_ZTIMER_TIMER_BLOCK_PM_MODE ZTIMER_CLOCK_NO_REQUIRED_PM_MODE
|
|
# endif
|
|
#endif
|
|
|
|
/**
|
|
* @brief The minimum pm mode required for ZTIMER_LPTIMER to run
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_LPTIMER_BLOCK_PM_MODE
|
|
# define CONFIG_ZTIMER_LPTIMER_BLOCK_PM_MODE ZTIMER_CLOCK_NO_REQUIRED_PM_MODE
|
|
#endif
|
|
|
|
/**
|
|
* @brief The minimum pm mode required for ZTIMER_RTT to run
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_RTT_BLOCK_PM_MODE
|
|
# ifdef CONFIG_ZTIMER_MSEC_REQUIRED_PM_MODE
|
|
# define CONFIG_ZTIMER_RTT_BLOCK_PM_MODE CONFIG_ZTIMER_MSEC_REQUIRED_PM_MODE
|
|
# else
|
|
# define CONFIG_ZTIMER_RTT_BLOCK_PM_MODE ZTIMER_CLOCK_NO_REQUIRED_PM_MODE
|
|
# endif
|
|
#endif
|
|
|
|
/**
|
|
* @brief The minimum pm mode required for ZTIMER_RTC to run
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_RTC_BLOCK_PM_MODE
|
|
# ifdef CONFIG_ZTIMER_SEC_REQUIRED_PM_MODE
|
|
# define CONFIG_ZTIMER_RTC_BLOCK_PM_MODE CONFIG_ZTIMER_SEC_REQUIRED_PM_MODE
|
|
# else
|
|
# define CONFIG_ZTIMER_RTC_BLOCK_PM_MODE ZTIMER_CLOCK_NO_REQUIRED_PM_MODE
|
|
# endif
|
|
#endif
|
|
|
|
/**
|
|
* @brief An offset for ZTIMER_USEC allowing to compensate for the offset
|
|
* introduced by turning on the underlying peripheral.
|
|
*
|
|
* @note This value can be measured with the
|
|
* `tests/ztimer_ondemand_benchmark` tool.
|
|
*
|
|
* This value should be configured in the board.h.
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_USEC_ADJUST_CLOCK_START
|
|
#define CONFIG_ZTIMER_USEC_ADJUST_CLOCK_START 0
|
|
#endif
|
|
|
|
/**
|
|
* @brief An offset for ZTIMER_USEC allowing to compensate for the offset
|
|
* of @ref ztimer_set(). It can be measured with @ref ztimer_overhead_set()
|
|
*
|
|
* This value should be configured in the board.h.
|
|
*
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_USEC_ADJUST_SET
|
|
#define CONFIG_ZTIMER_USEC_ADJUST_SET 0
|
|
#endif
|
|
|
|
/**
|
|
* @brief An offset for ZTIMER_USEC allowing to compentsate for the offset
|
|
* of @ref ztimer_sleep().
|
|
*
|
|
* @note As internally @ref ztimer_sleep() uses @ref ztimer_set()
|
|
* @ref CONFIG_ZTIMER_USEC_ADJUST_SET should be tuned before.
|
|
*
|
|
* This value should be configured in the board.h.
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_USEC_ADJUST_SLEEP
|
|
#define CONFIG_ZTIMER_USEC_ADJUST_SLEEP 0
|
|
#endif
|
|
|
|
/**
|
|
* @brief Some MCUs clocks need some warm-up time during which timing is
|
|
* inaccurate. This can be a hindrance when using the @ref
|
|
* pseudomodule_ztimer_auto_adjust module.
|
|
*
|
|
* @warning This value will increase the boards start-up time
|
|
*/
|
|
#ifndef CONFIG_ZTIMER_AUTO_ADJUST_SETTLE
|
|
#define CONFIG_ZTIMER_AUTO_ADJUST_SETTLE 0
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* ZTIMER_CONFIG_H */
|
|
/** @} */
|