2013-08-04 13:38:53 +00:00
|
|
|
/*
|
2015-01-11 13:56:55 +00:00
|
|
|
ChibiOS - Copyright (C) 2006..2015 Giovanni Di Sirio
|
2013-08-04 13:38:53 +00:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
/*
|
|
|
|
Concepts and parts of this file have been contributed by Uladzimir Pylinsky
|
|
|
|
aka barthess.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file STM32/RTCv2/rtc_lld.h
|
|
|
|
* @brief STM32L1xx/STM32F2xx/STM32F4xx RTC low level driver header.
|
|
|
|
*
|
|
|
|
* @addtogroup RTC
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _RTC_LLD_H_
|
|
|
|
#define _RTC_LLD_H_
|
|
|
|
|
|
|
|
#if HAL_USE_RTC || defined(__DOXYGEN__)
|
|
|
|
|
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver constants. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
2014-11-27 15:07:26 +00:00
|
|
|
/**
|
|
|
|
* @name Implementation capabilities
|
|
|
|
*/
|
2013-08-04 13:38:53 +00:00
|
|
|
/**
|
2014-06-13 12:08:53 +00:00
|
|
|
* @brief Callback support int the driver.
|
2013-08-04 13:38:53 +00:00
|
|
|
*/
|
2014-07-07 13:00:34 +00:00
|
|
|
#define RTC_SUPPORTS_CALLBACKS STM32_RTC_HAS_INTERRUPTS
|
2013-08-04 13:38:53 +00:00
|
|
|
|
2014-10-04 08:09:17 +00:00
|
|
|
/**
|
|
|
|
* @brief Number of alarms available.
|
|
|
|
*/
|
|
|
|
#define RTC_ALARMS STM32_RTC_NUM_ALARMS
|
|
|
|
|
2014-11-27 15:07:26 +00:00
|
|
|
/**
|
|
|
|
* @brief Presence of a local persistent storage.
|
|
|
|
*/
|
2014-12-23 11:48:01 +00:00
|
|
|
#define RTC_HAS_STORAGE FALSE
|
2014-11-27 15:07:26 +00:00
|
|
|
/** @} */
|
|
|
|
|
2013-08-04 13:38:53 +00:00
|
|
|
/**
|
2014-07-06 13:18:12 +00:00
|
|
|
* @brief RTC PRER register initializer.
|
2013-08-04 13:38:53 +00:00
|
|
|
*/
|
2014-07-07 13:00:34 +00:00
|
|
|
#define RTC_PRER(a, s) ((((a) - 1) << 16) | ((s) - 1))
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Alarm helper macros
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define RTC_ALRM_MSK4 (1U << 31)
|
|
|
|
#define RTC_ALRM_WDSEL (1U << 30)
|
|
|
|
#define RTC_ALRM_DT(n) ((n) << 28)
|
|
|
|
#define RTC_ALRM_DU(n) ((n) << 24)
|
|
|
|
#define RTC_ALRM_MSK3 (1U << 23)
|
|
|
|
#define RTC_ALRM_HT(n) ((n) << 20)
|
|
|
|
#define RTC_ALRM_HU(n) ((n) << 16)
|
|
|
|
#define RTC_ALRM_MSK2 (1U << 15)
|
|
|
|
#define RTC_ALRM_MNT(n) ((n) << 12)
|
|
|
|
#define RTC_ALRM_MNU(n) ((n) << 8)
|
|
|
|
#define RTC_ALRM_MSK1 (1U << 7)
|
|
|
|
#define RTC_ALRM_ST(n) ((n) << 4)
|
|
|
|
#define RTC_ALRM_SU(n) ((n) << 0)
|
|
|
|
/** @} */
|
2013-08-04 13:38:53 +00:00
|
|
|
|
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver pre-compile time settings. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
2014-06-13 12:08:53 +00:00
|
|
|
/**
|
|
|
|
* @name Configuration options
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @brief RTC PRES register initialization.
|
|
|
|
* @note The default is calculated for a 32768Hz clock.
|
|
|
|
*/
|
2014-07-06 13:18:12 +00:00
|
|
|
#if !defined(STM32_RTC_PRESA_VALUE) || defined(__DOXYGEN__)
|
|
|
|
#define STM32_RTC_PRESA_VALUE 32
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief RTC PRESS divider initialization.
|
|
|
|
* @note The default is calculated for a 32768Hz clock.
|
|
|
|
*/
|
|
|
|
#if !defined(STM32_RTC_PRESS_VALUE) || defined(__DOXYGEN__)
|
|
|
|
#define STM32_RTC_PRESS_VALUE 1024
|
2014-06-13 12:08:53 +00:00
|
|
|
#endif
|
2014-07-06 13:18:12 +00:00
|
|
|
/** @} */
|
2014-06-13 12:08:53 +00:00
|
|
|
|
2013-08-04 13:38:53 +00:00
|
|
|
/*===========================================================================*/
|
|
|
|
/* Derived constants and error checks. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
|
|
|
#if HAL_USE_RTC && !STM32_HAS_RTC
|
|
|
|
#error "RTC not present in the selected device"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !(STM32_RTCSEL == STM32_RTCSEL_LSE) && \
|
|
|
|
!(STM32_RTCSEL == STM32_RTCSEL_LSI) && \
|
|
|
|
!(STM32_RTCSEL == STM32_RTCSEL_HSEDIV)
|
|
|
|
#error "invalid source selected for RTC clock"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if STM32_PCLK1 < (STM32_RTCCLK * 7)
|
2014-06-13 12:08:53 +00:00
|
|
|
#error "STM32_PCLK1 frequency is too low"
|
2013-08-04 13:38:53 +00:00
|
|
|
#endif
|
|
|
|
|
2014-07-06 13:18:12 +00:00
|
|
|
/**
|
|
|
|
* @brief Initialization for the RTC_PRER register.
|
|
|
|
*/
|
|
|
|
#define STM32_RTC_PRER_BITS RTC_PRER(STM32_RTC_PRESA_VALUE, \
|
|
|
|
STM32_RTC_PRESS_VALUE)
|
|
|
|
|
2013-08-04 13:38:53 +00:00
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver data structures and types. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
2014-11-27 15:07:26 +00:00
|
|
|
/**
|
|
|
|
* @brief FileStream specific methods.
|
|
|
|
*/
|
|
|
|
#define _rtc_driver_methods \
|
|
|
|
_file_stream_methods
|
|
|
|
|
2014-07-07 13:00:34 +00:00
|
|
|
/**
|
|
|
|
* @brief Type of an RTC alarm number.
|
|
|
|
*/
|
|
|
|
typedef uint32_t rtcalarm_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Type of a structure representing an RTC alarm time stamp.
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
/**
|
|
|
|
* @brief Type of an alarm as encoded in RTC ALRMxR registers.
|
|
|
|
*/
|
|
|
|
uint32_t alrmr;
|
|
|
|
} RTCAlarm;
|
|
|
|
|
|
|
|
#if STM32_RTC_HAS_PERIODIC_WAKEUPS
|
|
|
|
/**
|
|
|
|
* @brief Type of a wakeup as encoded in RTC WUTR register.
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
/**
|
|
|
|
* @brief Wakeup as encoded in RTC WUTR register.
|
|
|
|
* @note ((WUTR == 0) || (WUCKSEL == 3)) are a forbidden combination.
|
|
|
|
*/
|
|
|
|
uint32_t wutr;
|
|
|
|
} RTCWakeup;
|
|
|
|
#endif
|
|
|
|
|
2014-11-27 15:07:26 +00:00
|
|
|
#if RTC_HAS_STORAGE || defined(__DOXYGEN__)
|
|
|
|
/**
|
|
|
|
* @extends FileStream
|
|
|
|
*
|
|
|
|
* @brief @p RTCDriver virtual methods table.
|
|
|
|
*/
|
|
|
|
struct RTCDriverVMT {
|
|
|
|
_rtc_driver_methods
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2013-08-04 13:38:53 +00:00
|
|
|
/**
|
|
|
|
* @brief Structure representing an RTC driver.
|
|
|
|
*/
|
2014-06-13 12:08:53 +00:00
|
|
|
struct RTCDriver {
|
2014-11-27 15:07:26 +00:00
|
|
|
#if RTC_HAS_STORAGE || defined(__DOXYGEN__)
|
|
|
|
/**
|
|
|
|
* @brief Virtual Methods Table.
|
|
|
|
*/
|
|
|
|
const struct RTCDriverVMT *vmt;
|
|
|
|
#endif
|
|
|
|
/* End of the mandatory fields.*/
|
2013-08-04 13:38:53 +00:00
|
|
|
/**
|
2014-07-07 13:00:34 +00:00
|
|
|
* @brief Pointer to the RTC registers block.
|
2013-08-04 13:38:53 +00:00
|
|
|
*/
|
2014-06-13 12:08:53 +00:00
|
|
|
RTC_TypeDef *rtc;
|
2013-08-04 13:38:53 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver macros. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
|
|
|
/*===========================================================================*/
|
|
|
|
/* External declarations. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
|
|
|
#if !defined(__DOXYGEN__)
|
|
|
|
extern RTCDriver RTCD1;
|
2014-11-27 15:07:26 +00:00
|
|
|
#if RTC_HAS_STORAGE
|
|
|
|
extern struct RTCDriverVMT _rtc_lld_vmt;
|
|
|
|
#endif
|
2013-08-04 13:38:53 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
void rtc_lld_init(void);
|
2014-06-13 12:08:53 +00:00
|
|
|
void rtc_lld_set_time(RTCDriver *rtcp, const RTCDateTime *timespec);
|
|
|
|
void rtc_lld_get_time(RTCDriver *rtcp, RTCDateTime *timespec);
|
2014-10-04 08:09:17 +00:00
|
|
|
#if RTC_ALARMS > 0
|
2013-08-04 13:38:53 +00:00
|
|
|
void rtc_lld_set_alarm(RTCDriver *rtcp,
|
|
|
|
rtcalarm_t alarm,
|
|
|
|
const RTCAlarm *alarmspec);
|
|
|
|
void rtc_lld_get_alarm(RTCDriver *rtcp,
|
|
|
|
rtcalarm_t alarm,
|
|
|
|
RTCAlarm *alarmspec);
|
2014-06-13 12:08:53 +00:00
|
|
|
#endif
|
2014-07-07 13:00:34 +00:00
|
|
|
#if STM32_RTC_HAS_PERIODIC_WAKEUPS
|
|
|
|
void rtcSTM32SetPeriodicWakeup(RTCDriver *rtcp, const RTCWakeup *wakeupspec);
|
|
|
|
void rtcSTM32GetPeriodicWakeup(RTCDriver *rtcp, RTCWakeup *wakeupspec);
|
|
|
|
#endif /* STM32_RTC_HAS_PERIODIC_WAKEUPS */
|
2013-08-04 13:38:53 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* HAL_USE_RTC */
|
|
|
|
|
|
|
|
#endif /* _RTC_LLD_H_ */
|
|
|
|
|
|
|
|
/** @} */
|