/* * Copyright (C) 2014 Thomas Eichinger * * 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. */ /** * @defgroup driver_periph_rtc RTC * @ingroup driver_periph * @brief Low-level RTC (Real Time Clock) peripheral driver * * @note * The values used for setting and getting the time/alarm should * conform to the `struct tm` specification. * Compare: http://pubs.opengroup.org/onlinepubs/7908799/xsh/time.h.html * * @{ * @file * @brief Low-level RTC peripheral driver interface definitions * * @author Thomas Eichinger */ #ifndef __RTC_H #define __RTC_H #include #include "periph_conf.h" #ifdef __cplusplus extern "C" { #endif /* guard file in case no RTC device was specified */ #if RTC_NUMOF /** * @brief Signature for alarm Callback * * @param[in] arg optional argument to put the callback in the right context */ typedef void(*rtc_alarm_cb_t)(void *arg); /** * @brief Initialize RTC module */ void rtc_init(void); /** * @brief Set RTC to given time. * * @param[in] time Pointer to the struct holding the time to set. * * @return 0 for success * @return -1 an error occurred */ int rtc_set_time(struct tm *time); /** * @brief Get current RTC time. * * @param[out] time Pointer to the struct to write the time to. * * @return 0 for success * @return -1 an error occurred */ int rtc_get_time(struct tm *time); /** * @brief Set an alarm for RTC to the specified value. * * @note Any already set alarm will be overwritten. * * @param[in] time 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. * * @return 0 for success * @return -2 invalid `time` parameter * @return -1 other errors */ int rtc_set_alarm(struct tm *time, rtc_alarm_cb_t cb, void *arg); /** * @brief Gets the current alarm setting * * @param[out] time Pointer to structure to receive alarm time * * @return 0 for success * @return -1 an error occurred */ int rtc_get_alarm(struct tm *time); /** * @brief Clear any set alarm, do nothing if nothing set */ void rtc_clear_alarm(void); /** * @brief Turns the RTC hardware module on */ void rtc_poweron(void); /** * @brief Turns the RTC hardware module off */ void rtc_poweroff(void); #endif /* RTC_NUMOF */ #ifdef __cplusplus } #endif #endif /* __RTC_H */ /** @} */