2014-08-21 20:30:48 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Thomas Eichinger <thomas.eichinger@fu-berlin.de>
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
2014-10-25 15:37:04 +02:00
|
|
|
|
2014-08-21 20:30:48 +02:00
|
|
|
/**
|
2015-11-19 15:54:52 +01:00
|
|
|
* @defgroup drivers_periph_rtt RTT
|
|
|
|
* @ingroup drivers_periph
|
2014-12-04 10:03:15 +01:00
|
|
|
* @brief Low-level RTT (Real Time Timer) peripheral driver
|
2014-08-21 20:30:48 +02:00
|
|
|
*
|
2018-12-06 10:04:04 +01:00
|
|
|
* # (Low-) Power Implications
|
|
|
|
*
|
|
|
|
* After the RTT has been initialized (i.e. after calling rtt_init()), the RTT
|
|
|
|
* should be powered on and running. The RTT can then be powered off manually
|
|
|
|
* at a later point in time by calling the rtt_poweroff() function. When the RTT
|
|
|
|
* is powered back on using the rtt_poweron() function, it **should**
|
|
|
|
* transparently continue its previously configured operation.
|
|
|
|
*
|
|
|
|
* On many CPUs, certain power states might need to be blocked in rtt_init(), so
|
|
|
|
* that it is ensured that the RTT will function properly while it is enabled.
|
|
|
|
*
|
2014-12-04 10:03:15 +01:00
|
|
|
* @{
|
2014-10-25 15:37:04 +02:00
|
|
|
* @file
|
2014-08-21 20:30:48 +02:00
|
|
|
* @brief Low-level RTT (Real Time Timer) peripheral driver interface
|
|
|
|
* definitions
|
|
|
|
*
|
|
|
|
* @author Thomas Eichinger <thomas.eichinger@fu-berlin.de>
|
2014-11-07 12:11:50 +01:00
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
2014-08-21 20:30:48 +02:00
|
|
|
*/
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#ifndef PERIPH_RTT_H
|
|
|
|
#define PERIPH_RTT_H
|
2014-08-21 20:30:48 +02:00
|
|
|
|
2018-09-07 14:54:23 +02:00
|
|
|
#include <stdint.h>
|
|
|
|
|
2014-08-21 20:30:48 +02:00
|
|
|
#include "periph_conf.h"
|
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-04-23 19:01:36 +02:00
|
|
|
/**
|
|
|
|
* @def RTT_FREQUENCY
|
|
|
|
*
|
|
|
|
* @brief The desired frequency for the RTT
|
|
|
|
*/
|
|
|
|
#ifdef DOXYGEN
|
|
|
|
#define RTT_FREQUENCY
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @def RTT_MAX_VALUE
|
|
|
|
*
|
|
|
|
* @brief The maximum value for the RTT counter, must be (2^n - 1)
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#ifdef DOXYGEN
|
|
|
|
#define RTT_MAX_VALUE
|
|
|
|
#endif
|
|
|
|
|
2020-06-11 09:30:25 +02:00
|
|
|
/**
|
|
|
|
* @def RTT_MIN_OFFSET
|
|
|
|
*
|
|
|
|
* @brief The minimum offset to correctly set an rtt callback.
|
|
|
|
*
|
|
|
|
* If the callback is taking into account rtt_get_counter() then the rtt
|
|
|
|
* might advance right between the call to rtt_get_counter() and
|
|
|
|
* rtt_set_alarm(). If that happens with val==1, the alarm would be
|
|
|
|
* set to the current time, which would then underflow. To avoid this,
|
|
|
|
* the alarm should be set at least two ticks in the future.
|
|
|
|
*
|
|
|
|
* This value can vary depending on the platform.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#ifndef RTT_MIN_OFFSET
|
|
|
|
#define RTT_MIN_OFFSET (2U)
|
|
|
|
#endif
|
|
|
|
|
2020-03-13 13:27:53 +01:00
|
|
|
/* Allow mock-RTT for unit tests */
|
|
|
|
#ifdef MOCK_RTT_FREQUENCY
|
2020-07-21 15:21:07 +02:00
|
|
|
#undef RTT_FREQUENCY
|
2020-03-13 13:27:53 +01:00
|
|
|
#define RTT_FREQUENCY MOCK_RTT_FREQUENCY
|
|
|
|
#else
|
2020-07-21 15:21:07 +02:00
|
|
|
#ifndef RTT_FREQUENCY
|
2020-04-23 18:58:11 +02:00
|
|
|
#warning "RTT_FREQUENCY undefined. Set RTT_FREQUENCY to the number of ticks " \
|
2015-06-08 15:47:31 +02:00
|
|
|
"per second for the current architecture."
|
|
|
|
#endif
|
2020-03-13 13:27:53 +01:00
|
|
|
#endif
|
2015-06-08 15:47:31 +02:00
|
|
|
|
2020-04-23 18:58:11 +02:00
|
|
|
/* Allow mock-RTT for unit tests */
|
|
|
|
#ifdef MOCK_RTT_MAX_VALUE
|
2020-07-21 15:21:07 +02:00
|
|
|
#undef RTT_MAX_VALUE
|
2020-04-23 18:58:11 +02:00
|
|
|
#define RTT_MAX_VALUE MOCK_RTT_MAX_VALUE
|
|
|
|
#else
|
2020-07-21 15:21:07 +02:00
|
|
|
#ifndef RTT_MAX_VALUE
|
2020-04-23 18:58:11 +02:00
|
|
|
#warning "RTT_MAX_VALUE is undefined. Set RTT_MAX_VALUE to the maximum value " \
|
|
|
|
"for the RTT counter, ensure it is (2^n - 1)."
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2015-06-08 15:47:31 +02:00
|
|
|
/**
|
|
|
|
* @brief Convert microseconds to rtt ticks
|
2015-09-22 16:59:05 +02:00
|
|
|
* @param[in] us number of microseconds
|
|
|
|
* @return rtt ticks
|
2015-06-08 15:47:31 +02:00
|
|
|
*/
|
2020-11-11 16:55:17 +01:00
|
|
|
#define RTT_US_TO_TICKS(us) (RTT_SEC_TO_TICKS(us) / 1000000UL)
|
2015-06-08 15:47:31 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convert milliseconds to rtt ticks
|
2015-09-22 16:59:05 +02:00
|
|
|
* @param[in] ms number of milliseconds
|
|
|
|
* @return rtt ticks
|
2015-06-08 15:47:31 +02:00
|
|
|
*/
|
2020-11-11 16:55:17 +01:00
|
|
|
#define RTT_MS_TO_TICKS(ms) (RTT_SEC_TO_TICKS(ms) / 1000UL)
|
2015-06-08 15:47:31 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convert seconds to rtt ticks
|
2015-09-22 16:59:05 +02:00
|
|
|
* @param[in] sec number of seconds
|
|
|
|
* @return rtt ticks
|
2015-06-08 15:47:31 +02:00
|
|
|
*/
|
2020-11-11 16:55:17 +01:00
|
|
|
#define RTT_SEC_TO_TICKS(sec) (sec * RTT_FREQUENCY)
|
2015-06-08 15:47:31 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convert minutes to rtt ticks
|
2015-09-22 16:59:05 +02:00
|
|
|
* @param[in] min number of minutes
|
|
|
|
* @return rtt ticks
|
2015-06-08 15:47:31 +02:00
|
|
|
*/
|
2020-11-11 16:55:17 +01:00
|
|
|
#define RTT_MIN_TO_TICKS(min) (RTT_SEC_TO_TICKS((min) * 60))
|
2015-06-08 15:47:31 +02:00
|
|
|
|
2015-09-22 16:59:05 +02:00
|
|
|
/**
|
|
|
|
* @brief Convert rtt ticks to microseconds
|
|
|
|
* @param[in] ticks rtt ticks
|
|
|
|
* @return number of microseconds
|
|
|
|
*/
|
2020-11-11 16:55:17 +01:00
|
|
|
#define RTT_TICKS_TO_US(ticks) ((uint64_t)(ticks) * 1000000UL / RTT_FREQUENCY)
|
2015-09-22 16:59:05 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convert rtt ticks to milliseconds
|
|
|
|
* @param[in] ticks rtt ticks
|
|
|
|
* @return number of milliseconds
|
|
|
|
*/
|
|
|
|
#define RTT_TICKS_TO_MS(ticks) (RTT_TICKS_TO_US(ticks) / 1000)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convert rtt ticks to seconds
|
|
|
|
* @param[in] ticks rtt ticks
|
|
|
|
* @return number of seconds
|
|
|
|
*/
|
|
|
|
#define RTT_TICKS_TO_SEC(ticks) (RTT_TICKS_TO_MS(ticks) / 1000)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convert rtt ticks to minutes
|
|
|
|
* @param[in] ticks rtt ticks
|
|
|
|
* @return number of minutes
|
|
|
|
*/
|
|
|
|
#define RTT_TICKS_TO_MIN(ticks) (RTT_TICKS_TO_SEC(ticks) / 60)
|
|
|
|
|
2014-08-21 20:30:48 +02:00
|
|
|
/**
|
2014-11-19 16:55:52 +01:00
|
|
|
* @brief Signature for the alarm callback
|
2014-08-21 20:30:48 +02:00
|
|
|
*
|
2014-11-19 16:55:52 +01:00
|
|
|
* @param[in] arg Optional argument which is passed to the
|
|
|
|
* callback
|
2014-08-21 20:30:48 +02:00
|
|
|
*/
|
2014-11-07 12:11:50 +01:00
|
|
|
typedef void(*rtt_cb_t)(void *arg);
|
2014-08-21 20:30:48 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize RTT module
|
|
|
|
*/
|
|
|
|
void rtt_init(void);
|
|
|
|
|
2014-11-07 12:11:50 +01:00
|
|
|
/**
|
|
|
|
* @brief Set a callback for the counter overflow event
|
|
|
|
*
|
|
|
|
* @param[in] cb Callback to execute on overflow
|
|
|
|
* @param[in] arg Argument passed to the callback
|
|
|
|
*/
|
|
|
|
void rtt_set_overflow_cb(rtt_cb_t cb, void *arg);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Clear the overflow callback
|
|
|
|
*/
|
|
|
|
void rtt_clear_overflow_cb(void);
|
|
|
|
|
2014-08-21 20:30:48 +02:00
|
|
|
/**
|
|
|
|
* @brief Get the current RTT counter.
|
|
|
|
*
|
2014-11-19 16:55:52 +01:00
|
|
|
* @return Current value of the RTT counter
|
2014-08-21 20:30:48 +02:00
|
|
|
*/
|
|
|
|
uint32_t rtt_get_counter(void);
|
|
|
|
|
|
|
|
/**
|
2021-03-03 17:05:35 +01:00
|
|
|
* @brief Set the RTT counter to a specified value.
|
2014-08-21 20:30:48 +02:00
|
|
|
*
|
|
|
|
* @param[in] counter The value to set the RTT to.
|
2021-03-03 17:05:35 +01:00
|
|
|
*
|
|
|
|
* @note This function is only provided when the feature `periph_rtt_set_counter` is provided
|
2014-08-21 20:30:48 +02:00
|
|
|
*/
|
|
|
|
void rtt_set_counter(uint32_t counter);
|
|
|
|
|
|
|
|
/**
|
2020-01-13 15:18:16 +01:00
|
|
|
* @brief Set an alarm for RTT to the specified absolute target time.
|
2014-08-21 20:30:48 +02:00
|
|
|
*
|
2014-11-19 16:55:52 +01:00
|
|
|
* @param[in] alarm The value to trigger an alarm when hit
|
|
|
|
* @param[in] cb Callback executed when alarm is hit
|
|
|
|
* @param[in] arg Argument passed to callback when alarm is hit
|
2014-08-21 20:30:48 +02:00
|
|
|
*/
|
2014-11-07 12:11:50 +01:00
|
|
|
void rtt_set_alarm(uint32_t alarm, rtt_cb_t cb, void *arg);
|
2014-08-21 20:30:48 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the value of a set alarm.
|
|
|
|
*
|
2014-11-19 16:55:52 +01:00
|
|
|
* If no alarm is set, the return value is arbitrary.
|
2014-08-21 20:30:48 +02:00
|
|
|
*
|
2014-11-19 16:55:52 +01:00
|
|
|
* @return Value the alarm is set to
|
2014-08-21 20:30:48 +02:00
|
|
|
*/
|
|
|
|
uint32_t rtt_get_alarm(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Clear any set alarm, do nothing if nothing set
|
|
|
|
*/
|
|
|
|
void rtt_clear_alarm(void);
|
|
|
|
|
|
|
|
/**
|
2014-11-19 16:55:52 +01:00
|
|
|
* @brief Turn the RTT hardware module on
|
2014-08-21 20:30:48 +02:00
|
|
|
*/
|
|
|
|
void rtt_poweron(void);
|
|
|
|
|
|
|
|
/**
|
2014-11-19 16:55:52 +01:00
|
|
|
* @brief Turn the RTT hardware module off
|
2014-08-21 20:30:48 +02:00
|
|
|
*/
|
|
|
|
void rtt_poweroff(void);
|
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#endif /* PERIPH_RTT_H */
|
2014-08-21 20:30:48 +02:00
|
|
|
/** @} */
|