mbed library sources. Supersedes mbed-src.

Dependents:   Nucleo_Hello_Encoder BLE_iBeaconScan AM1805_DEMO DISCO-F429ZI_ExportTemplate1 ... more

Committer:
AnnaBridge
Date:
Wed Feb 20 22:31:08 2019 +0000
Revision:
189:f392fc9709a3
mbed library release version 165

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AnnaBridge 189:f392fc9709a3 1 /**
AnnaBridge 189:f392fc9709a3 2 ******************************************************************************
AnnaBridge 189:f392fc9709a3 3 * @file stm32l4xx_hal_rtc_ex.h
AnnaBridge 189:f392fc9709a3 4 * @author MCD Application Team
AnnaBridge 189:f392fc9709a3 5 * @brief Header file of RTC HAL Extended module.
AnnaBridge 189:f392fc9709a3 6 ******************************************************************************
AnnaBridge 189:f392fc9709a3 7 * @attention
AnnaBridge 189:f392fc9709a3 8 *
AnnaBridge 189:f392fc9709a3 9 * <h2><center>&copy; COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
AnnaBridge 189:f392fc9709a3 10 *
AnnaBridge 189:f392fc9709a3 11 * Redistribution and use in source and binary forms, with or without modification,
AnnaBridge 189:f392fc9709a3 12 * are permitted provided that the following conditions are met:
AnnaBridge 189:f392fc9709a3 13 * 1. Redistributions of source code must retain the above copyright notice,
AnnaBridge 189:f392fc9709a3 14 * this list of conditions and the following disclaimer.
AnnaBridge 189:f392fc9709a3 15 * 2. Redistributions in binary form must reproduce the above copyright notice,
AnnaBridge 189:f392fc9709a3 16 * this list of conditions and the following disclaimer in the documentation
AnnaBridge 189:f392fc9709a3 17 * and/or other materials provided with the distribution.
AnnaBridge 189:f392fc9709a3 18 * 3. Neither the name of STMicroelectronics nor the names of its contributors
AnnaBridge 189:f392fc9709a3 19 * may be used to endorse or promote products derived from this software
AnnaBridge 189:f392fc9709a3 20 * without specific prior written permission.
AnnaBridge 189:f392fc9709a3 21 *
AnnaBridge 189:f392fc9709a3 22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AnnaBridge 189:f392fc9709a3 23 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
AnnaBridge 189:f392fc9709a3 24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
AnnaBridge 189:f392fc9709a3 25 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
AnnaBridge 189:f392fc9709a3 26 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
AnnaBridge 189:f392fc9709a3 27 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
AnnaBridge 189:f392fc9709a3 28 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
AnnaBridge 189:f392fc9709a3 29 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
AnnaBridge 189:f392fc9709a3 30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
AnnaBridge 189:f392fc9709a3 31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
AnnaBridge 189:f392fc9709a3 32 *
AnnaBridge 189:f392fc9709a3 33 ******************************************************************************
AnnaBridge 189:f392fc9709a3 34 */
AnnaBridge 189:f392fc9709a3 35
AnnaBridge 189:f392fc9709a3 36 /* Define to prevent recursive inclusion -------------------------------------*/
AnnaBridge 189:f392fc9709a3 37 #ifndef __STM32L4xx_HAL_RTC_EX_H
AnnaBridge 189:f392fc9709a3 38 #define __STM32L4xx_HAL_RTC_EX_H
AnnaBridge 189:f392fc9709a3 39
AnnaBridge 189:f392fc9709a3 40 #ifdef __cplusplus
AnnaBridge 189:f392fc9709a3 41 extern "C" {
AnnaBridge 189:f392fc9709a3 42 #endif
AnnaBridge 189:f392fc9709a3 43
AnnaBridge 189:f392fc9709a3 44 /* Includes ------------------------------------------------------------------*/
AnnaBridge 189:f392fc9709a3 45 #include "stm32l4xx_hal_def.h"
AnnaBridge 189:f392fc9709a3 46
AnnaBridge 189:f392fc9709a3 47 /** @addtogroup STM32L4xx_HAL_Driver
AnnaBridge 189:f392fc9709a3 48 * @{
AnnaBridge 189:f392fc9709a3 49 */
AnnaBridge 189:f392fc9709a3 50
AnnaBridge 189:f392fc9709a3 51 /** @addtogroup RTCEx
AnnaBridge 189:f392fc9709a3 52 * @{
AnnaBridge 189:f392fc9709a3 53 */
AnnaBridge 189:f392fc9709a3 54
AnnaBridge 189:f392fc9709a3 55 /* Exported types ------------------------------------------------------------*/
AnnaBridge 189:f392fc9709a3 56 /** @defgroup RTCEx_Exported_Types RTCEx Exported Types
AnnaBridge 189:f392fc9709a3 57 * @{
AnnaBridge 189:f392fc9709a3 58 */
AnnaBridge 189:f392fc9709a3 59 /**
AnnaBridge 189:f392fc9709a3 60 * @brief RTC Tamper structure definition
AnnaBridge 189:f392fc9709a3 61 */
AnnaBridge 189:f392fc9709a3 62 typedef struct
AnnaBridge 189:f392fc9709a3 63 {
AnnaBridge 189:f392fc9709a3 64 uint32_t Tamper; /*!< Specifies the Tamper Pin.
AnnaBridge 189:f392fc9709a3 65 This parameter can be a value of @ref RTCEx_Tamper_Pins_Definitions */
AnnaBridge 189:f392fc9709a3 66
AnnaBridge 189:f392fc9709a3 67 uint32_t Interrupt; /*!< Specifies the Tamper Interrupt.
AnnaBridge 189:f392fc9709a3 68 This parameter can be a value of @ref RTCEx_Tamper_Interrupt_Definitions */
AnnaBridge 189:f392fc9709a3 69
AnnaBridge 189:f392fc9709a3 70 uint32_t Trigger; /*!< Specifies the Tamper Trigger.
AnnaBridge 189:f392fc9709a3 71 This parameter can be a value of @ref RTCEx_Tamper_Trigger_Definitions */
AnnaBridge 189:f392fc9709a3 72
AnnaBridge 189:f392fc9709a3 73 uint32_t NoErase; /*!< Specifies the Tamper no erase mode.
AnnaBridge 189:f392fc9709a3 74 This parameter can be a value of @ref RTCEx_Tamper_EraseBackUp_Definitions */
AnnaBridge 189:f392fc9709a3 75
AnnaBridge 189:f392fc9709a3 76 uint32_t MaskFlag; /*!< Specifies the Tamper Flag masking.
AnnaBridge 189:f392fc9709a3 77 This parameter can be a value of @ref RTCEx_Tamper_MaskFlag_Definitions */
AnnaBridge 189:f392fc9709a3 78
AnnaBridge 189:f392fc9709a3 79 uint32_t Filter; /*!< Specifies the RTC Filter Tamper.
AnnaBridge 189:f392fc9709a3 80 This parameter can be a value of @ref RTCEx_Tamper_Filter_Definitions */
AnnaBridge 189:f392fc9709a3 81
AnnaBridge 189:f392fc9709a3 82 uint32_t SamplingFrequency; /*!< Specifies the sampling frequency.
AnnaBridge 189:f392fc9709a3 83 This parameter can be a value of @ref RTCEx_Tamper_Sampling_Frequencies_Definitions */
AnnaBridge 189:f392fc9709a3 84
AnnaBridge 189:f392fc9709a3 85 uint32_t PrechargeDuration; /*!< Specifies the Precharge Duration .
AnnaBridge 189:f392fc9709a3 86 This parameter can be a value of @ref RTCEx_Tamper_Pin_Precharge_Duration_Definitions */
AnnaBridge 189:f392fc9709a3 87
AnnaBridge 189:f392fc9709a3 88 uint32_t TamperPullUp; /*!< Specifies the Tamper PullUp .
AnnaBridge 189:f392fc9709a3 89 This parameter can be a value of @ref RTCEx_Tamper_Pull_UP_Definitions */
AnnaBridge 189:f392fc9709a3 90
AnnaBridge 189:f392fc9709a3 91 uint32_t TimeStampOnTamperDetection; /*!< Specifies the TimeStampOnTamperDetection.
AnnaBridge 189:f392fc9709a3 92 This parameter can be a value of @ref RTCEx_Tamper_TimeStampOnTamperDetection_Definitions */
AnnaBridge 189:f392fc9709a3 93 }RTC_TamperTypeDef;
AnnaBridge 189:f392fc9709a3 94
AnnaBridge 189:f392fc9709a3 95 /**
AnnaBridge 189:f392fc9709a3 96 * @}
AnnaBridge 189:f392fc9709a3 97 */
AnnaBridge 189:f392fc9709a3 98
AnnaBridge 189:f392fc9709a3 99 /* Exported constants --------------------------------------------------------*/
AnnaBridge 189:f392fc9709a3 100 /** @defgroup RTCEx_Exported_Constants RTCEx Exported Constants
AnnaBridge 189:f392fc9709a3 101 * @{
AnnaBridge 189:f392fc9709a3 102 */
AnnaBridge 189:f392fc9709a3 103
AnnaBridge 189:f392fc9709a3 104 /** @defgroup RTCEx_Output_selection_Definitions RTC Output Selection Definitions
AnnaBridge 189:f392fc9709a3 105 * @{
AnnaBridge 189:f392fc9709a3 106 */
AnnaBridge 189:f392fc9709a3 107 #define RTC_OUTPUT_DISABLE ((uint32_t)0x00000000)
AnnaBridge 189:f392fc9709a3 108 #define RTC_OUTPUT_ALARMA ((uint32_t)0x00200000)
AnnaBridge 189:f392fc9709a3 109 #define RTC_OUTPUT_ALARMB ((uint32_t)0x00400000)
AnnaBridge 189:f392fc9709a3 110 #define RTC_OUTPUT_WAKEUP ((uint32_t)0x00600000)
AnnaBridge 189:f392fc9709a3 111 /**
AnnaBridge 189:f392fc9709a3 112 * @}
AnnaBridge 189:f392fc9709a3 113 */
AnnaBridge 189:f392fc9709a3 114
AnnaBridge 189:f392fc9709a3 115 /** @defgroup RTCEx_Backup_Registers_Definitions RTC Backup Registers Definitions
AnnaBridge 189:f392fc9709a3 116 * @{
AnnaBridge 189:f392fc9709a3 117 */
AnnaBridge 189:f392fc9709a3 118 #define RTC_BKP_DR0 ((uint32_t)0x00000000)
AnnaBridge 189:f392fc9709a3 119 #define RTC_BKP_DR1 ((uint32_t)0x00000001)
AnnaBridge 189:f392fc9709a3 120 #define RTC_BKP_DR2 ((uint32_t)0x00000002)
AnnaBridge 189:f392fc9709a3 121 #define RTC_BKP_DR3 ((uint32_t)0x00000003)
AnnaBridge 189:f392fc9709a3 122 #define RTC_BKP_DR4 ((uint32_t)0x00000004)
AnnaBridge 189:f392fc9709a3 123 #define RTC_BKP_DR5 ((uint32_t)0x00000005)
AnnaBridge 189:f392fc9709a3 124 #define RTC_BKP_DR6 ((uint32_t)0x00000006)
AnnaBridge 189:f392fc9709a3 125 #define RTC_BKP_DR7 ((uint32_t)0x00000007)
AnnaBridge 189:f392fc9709a3 126 #define RTC_BKP_DR8 ((uint32_t)0x00000008)
AnnaBridge 189:f392fc9709a3 127 #define RTC_BKP_DR9 ((uint32_t)0x00000009)
AnnaBridge 189:f392fc9709a3 128 #define RTC_BKP_DR10 ((uint32_t)0x0000000A)
AnnaBridge 189:f392fc9709a3 129 #define RTC_BKP_DR11 ((uint32_t)0x0000000B)
AnnaBridge 189:f392fc9709a3 130 #define RTC_BKP_DR12 ((uint32_t)0x0000000C)
AnnaBridge 189:f392fc9709a3 131 #define RTC_BKP_DR13 ((uint32_t)0x0000000D)
AnnaBridge 189:f392fc9709a3 132 #define RTC_BKP_DR14 ((uint32_t)0x0000000E)
AnnaBridge 189:f392fc9709a3 133 #define RTC_BKP_DR15 ((uint32_t)0x0000000F)
AnnaBridge 189:f392fc9709a3 134 #define RTC_BKP_DR16 ((uint32_t)0x00000010)
AnnaBridge 189:f392fc9709a3 135 #define RTC_BKP_DR17 ((uint32_t)0x00000011)
AnnaBridge 189:f392fc9709a3 136 #define RTC_BKP_DR18 ((uint32_t)0x00000012)
AnnaBridge 189:f392fc9709a3 137 #define RTC_BKP_DR19 ((uint32_t)0x00000013)
AnnaBridge 189:f392fc9709a3 138 #define RTC_BKP_DR20 ((uint32_t)0x00000014)
AnnaBridge 189:f392fc9709a3 139 #define RTC_BKP_DR21 ((uint32_t)0x00000015)
AnnaBridge 189:f392fc9709a3 140 #define RTC_BKP_DR22 ((uint32_t)0x00000016)
AnnaBridge 189:f392fc9709a3 141 #define RTC_BKP_DR23 ((uint32_t)0x00000017)
AnnaBridge 189:f392fc9709a3 142 #define RTC_BKP_DR24 ((uint32_t)0x00000018)
AnnaBridge 189:f392fc9709a3 143 #define RTC_BKP_DR25 ((uint32_t)0x00000019)
AnnaBridge 189:f392fc9709a3 144 #define RTC_BKP_DR26 ((uint32_t)0x0000001A)
AnnaBridge 189:f392fc9709a3 145 #define RTC_BKP_DR27 ((uint32_t)0x0000001B)
AnnaBridge 189:f392fc9709a3 146 #define RTC_BKP_DR28 ((uint32_t)0x0000001C)
AnnaBridge 189:f392fc9709a3 147 #define RTC_BKP_DR29 ((uint32_t)0x0000001D)
AnnaBridge 189:f392fc9709a3 148 #define RTC_BKP_DR30 ((uint32_t)0x0000001E)
AnnaBridge 189:f392fc9709a3 149 #define RTC_BKP_DR31 ((uint32_t)0x0000001F)
AnnaBridge 189:f392fc9709a3 150 /**
AnnaBridge 189:f392fc9709a3 151 * @}
AnnaBridge 189:f392fc9709a3 152 */
AnnaBridge 189:f392fc9709a3 153
AnnaBridge 189:f392fc9709a3 154 /** @defgroup RTCEx_TimeStamp_Edges_definitions RTC TimeStamp Edges Definitions
AnnaBridge 189:f392fc9709a3 155 * @{
AnnaBridge 189:f392fc9709a3 156 */
AnnaBridge 189:f392fc9709a3 157 #define RTC_TIMESTAMPEDGE_RISING ((uint32_t)0x00000000)
AnnaBridge 189:f392fc9709a3 158 #define RTC_TIMESTAMPEDGE_FALLING ((uint32_t)0x00000008)
AnnaBridge 189:f392fc9709a3 159 /**
AnnaBridge 189:f392fc9709a3 160 * @}
AnnaBridge 189:f392fc9709a3 161 */
AnnaBridge 189:f392fc9709a3 162
AnnaBridge 189:f392fc9709a3 163 /** @defgroup RTCEx_TimeStamp_Pin_Selection RTC TimeStamp Pins Selection
AnnaBridge 189:f392fc9709a3 164 * @{
AnnaBridge 189:f392fc9709a3 165 */
AnnaBridge 189:f392fc9709a3 166 #define RTC_TIMESTAMPPIN_DEFAULT ((uint32_t)0x00000000)
AnnaBridge 189:f392fc9709a3 167 /**
AnnaBridge 189:f392fc9709a3 168 * @}
AnnaBridge 189:f392fc9709a3 169 */
AnnaBridge 189:f392fc9709a3 170
AnnaBridge 189:f392fc9709a3 171 /** @defgroup RTCEx_Tamper_Pins_Definitions RTC Tamper Pins Definitions
AnnaBridge 189:f392fc9709a3 172 * @{
AnnaBridge 189:f392fc9709a3 173 */
AnnaBridge 189:f392fc9709a3 174 #if defined(RTC_TAMPER1_SUPPORT)
AnnaBridge 189:f392fc9709a3 175 #define RTC_TAMPER_1 RTC_TAMPCR_TAMP1E
AnnaBridge 189:f392fc9709a3 176 #endif /* RTC_TAMPER1_SUPPORT */
AnnaBridge 189:f392fc9709a3 177 #define RTC_TAMPER_2 RTC_TAMPCR_TAMP2E
AnnaBridge 189:f392fc9709a3 178 #if defined(RTC_TAMPER3_SUPPORT)
AnnaBridge 189:f392fc9709a3 179 #define RTC_TAMPER_3 RTC_TAMPCR_TAMP3E
AnnaBridge 189:f392fc9709a3 180 #endif /* RTC_TAMPER3_SUPPORT */
AnnaBridge 189:f392fc9709a3 181 /**
AnnaBridge 189:f392fc9709a3 182 * @}
AnnaBridge 189:f392fc9709a3 183 */
AnnaBridge 189:f392fc9709a3 184
AnnaBridge 189:f392fc9709a3 185 /** @defgroup RTCEx_Tamper_Interrupt_Definitions RTC Tamper Interrupts Definitions
AnnaBridge 189:f392fc9709a3 186 * @{
AnnaBridge 189:f392fc9709a3 187 */
AnnaBridge 189:f392fc9709a3 188 #if defined(RTC_TAMPER1_SUPPORT)
AnnaBridge 189:f392fc9709a3 189 #define RTC_TAMPER1_INTERRUPT RTC_TAMPCR_TAMP1IE
AnnaBridge 189:f392fc9709a3 190 #endif /* RTC_TAMPER1_SUPPORT */
AnnaBridge 189:f392fc9709a3 191 #define RTC_TAMPER2_INTERRUPT RTC_TAMPCR_TAMP2IE
AnnaBridge 189:f392fc9709a3 192 #if defined(RTC_TAMPER3_SUPPORT)
AnnaBridge 189:f392fc9709a3 193 #define RTC_TAMPER3_INTERRUPT RTC_TAMPCR_TAMP3IE
AnnaBridge 189:f392fc9709a3 194 #endif /* RTC_TAMPER3_SUPPORT */
AnnaBridge 189:f392fc9709a3 195 #define RTC_ALL_TAMPER_INTERRUPT RTC_TAMPCR_TAMPIE
AnnaBridge 189:f392fc9709a3 196 /**
AnnaBridge 189:f392fc9709a3 197 * @}
AnnaBridge 189:f392fc9709a3 198 */
AnnaBridge 189:f392fc9709a3 199
AnnaBridge 189:f392fc9709a3 200 /** @defgroup RTCEx_Tamper_Trigger_Definitions RTC Tamper Triggers Definitions
AnnaBridge 189:f392fc9709a3 201 * @{
AnnaBridge 189:f392fc9709a3 202 */
AnnaBridge 189:f392fc9709a3 203 #define RTC_TAMPERTRIGGER_RISINGEDGE ((uint32_t)0x00000000)
AnnaBridge 189:f392fc9709a3 204 #define RTC_TAMPERTRIGGER_FALLINGEDGE ((uint32_t)0x00000002)
AnnaBridge 189:f392fc9709a3 205 #define RTC_TAMPERTRIGGER_LOWLEVEL RTC_TAMPERTRIGGER_RISINGEDGE
AnnaBridge 189:f392fc9709a3 206 #define RTC_TAMPERTRIGGER_HIGHLEVEL RTC_TAMPERTRIGGER_FALLINGEDGE
AnnaBridge 189:f392fc9709a3 207 /**
AnnaBridge 189:f392fc9709a3 208 * @}
AnnaBridge 189:f392fc9709a3 209 */
AnnaBridge 189:f392fc9709a3 210
AnnaBridge 189:f392fc9709a3 211 /** @defgroup RTCEx_Tamper_EraseBackUp_Definitions RTC Tamper EraseBackUp Definitions
AnnaBridge 189:f392fc9709a3 212 * @{
AnnaBridge 189:f392fc9709a3 213 */
AnnaBridge 189:f392fc9709a3 214 #define RTC_TAMPER_ERASE_BACKUP_ENABLE ((uint32_t)0x00000000)
AnnaBridge 189:f392fc9709a3 215 #define RTC_TAMPER_ERASE_BACKUP_DISABLE ((uint32_t)0x00020000)
AnnaBridge 189:f392fc9709a3 216 /**
AnnaBridge 189:f392fc9709a3 217 * @}
AnnaBridge 189:f392fc9709a3 218 */
AnnaBridge 189:f392fc9709a3 219
AnnaBridge 189:f392fc9709a3 220 /** @defgroup RTCEx_Tamper_MaskFlag_Definitions RTC Tamper Mask Flag Definitions
AnnaBridge 189:f392fc9709a3 221 * @{
AnnaBridge 189:f392fc9709a3 222 */
AnnaBridge 189:f392fc9709a3 223 #define RTC_TAMPERMASK_FLAG_DISABLE ((uint32_t)0x00000000)
AnnaBridge 189:f392fc9709a3 224 #define RTC_TAMPERMASK_FLAG_ENABLE ((uint32_t)0x00040000)
AnnaBridge 189:f392fc9709a3 225 /**
AnnaBridge 189:f392fc9709a3 226 * @}
AnnaBridge 189:f392fc9709a3 227 */
AnnaBridge 189:f392fc9709a3 228
AnnaBridge 189:f392fc9709a3 229 /** @defgroup RTCEx_Tamper_Filter_Definitions RTC Tamper Filter Definitions
AnnaBridge 189:f392fc9709a3 230 * @{
AnnaBridge 189:f392fc9709a3 231 */
AnnaBridge 189:f392fc9709a3 232 #define RTC_TAMPERFILTER_DISABLE ((uint32_t)0x00000000) /*!< Tamper filter is disabled */
AnnaBridge 189:f392fc9709a3 233
AnnaBridge 189:f392fc9709a3 234 #define RTC_TAMPERFILTER_2SAMPLE ((uint32_t)0x00000800) /*!< Tamper is activated after 2
AnnaBridge 189:f392fc9709a3 235 consecutive samples at the active level */
AnnaBridge 189:f392fc9709a3 236 #define RTC_TAMPERFILTER_4SAMPLE ((uint32_t)0x00001000) /*!< Tamper is activated after 4
AnnaBridge 189:f392fc9709a3 237 consecutive samples at the active level */
AnnaBridge 189:f392fc9709a3 238 #define RTC_TAMPERFILTER_8SAMPLE ((uint32_t)0x00001800) /*!< Tamper is activated after 8
AnnaBridge 189:f392fc9709a3 239 consecutive samples at the active level. */
AnnaBridge 189:f392fc9709a3 240 /**
AnnaBridge 189:f392fc9709a3 241 * @}
AnnaBridge 189:f392fc9709a3 242 */
AnnaBridge 189:f392fc9709a3 243
AnnaBridge 189:f392fc9709a3 244 /** @defgroup RTCEx_Tamper_Sampling_Frequencies_Definitions RTC Tamper Sampling Frequencies Definitions
AnnaBridge 189:f392fc9709a3 245 * @{
AnnaBridge 189:f392fc9709a3 246 */
AnnaBridge 189:f392fc9709a3 247 #define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV32768 ((uint32_t)0x00000000) /*!< Each of the tamper inputs are sampled
AnnaBridge 189:f392fc9709a3 248 with a frequency = RTCCLK / 32768 */
AnnaBridge 189:f392fc9709a3 249 #define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV16384 ((uint32_t)0x00000100) /*!< Each of the tamper inputs are sampled
AnnaBridge 189:f392fc9709a3 250 with a frequency = RTCCLK / 16384 */
AnnaBridge 189:f392fc9709a3 251 #define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV8192 ((uint32_t)0x00000200) /*!< Each of the tamper inputs are sampled
AnnaBridge 189:f392fc9709a3 252 with a frequency = RTCCLK / 8192 */
AnnaBridge 189:f392fc9709a3 253 #define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV4096 ((uint32_t)0x00000300) /*!< Each of the tamper inputs are sampled
AnnaBridge 189:f392fc9709a3 254 with a frequency = RTCCLK / 4096 */
AnnaBridge 189:f392fc9709a3 255 #define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV2048 ((uint32_t)0x00000400) /*!< Each of the tamper inputs are sampled
AnnaBridge 189:f392fc9709a3 256 with a frequency = RTCCLK / 2048 */
AnnaBridge 189:f392fc9709a3 257 #define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV1024 ((uint32_t)0x00000500) /*!< Each of the tamper inputs are sampled
AnnaBridge 189:f392fc9709a3 258 with a frequency = RTCCLK / 1024 */
AnnaBridge 189:f392fc9709a3 259 #define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV512 ((uint32_t)0x00000600) /*!< Each of the tamper inputs are sampled
AnnaBridge 189:f392fc9709a3 260 with a frequency = RTCCLK / 512 */
AnnaBridge 189:f392fc9709a3 261 #define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV256 ((uint32_t)0x00000700) /*!< Each of the tamper inputs are sampled
AnnaBridge 189:f392fc9709a3 262 with a frequency = RTCCLK / 256 */
AnnaBridge 189:f392fc9709a3 263 /**
AnnaBridge 189:f392fc9709a3 264 * @}
AnnaBridge 189:f392fc9709a3 265 */
AnnaBridge 189:f392fc9709a3 266
AnnaBridge 189:f392fc9709a3 267 /** @defgroup RTCEx_Tamper_Pin_Precharge_Duration_Definitions RTC Tamper Pin Precharge Duration Definitions
AnnaBridge 189:f392fc9709a3 268 * @{
AnnaBridge 189:f392fc9709a3 269 */
AnnaBridge 189:f392fc9709a3 270 #define RTC_TAMPERPRECHARGEDURATION_1RTCCLK ((uint32_t)0x00000000) /*!< Tamper pins are pre-charged before
AnnaBridge 189:f392fc9709a3 271 sampling during 1 RTCCLK cycle */
AnnaBridge 189:f392fc9709a3 272 #define RTC_TAMPERPRECHARGEDURATION_2RTCCLK ((uint32_t)0x00002000) /*!< Tamper pins are pre-charged before
AnnaBridge 189:f392fc9709a3 273 sampling during 2 RTCCLK cycles */
AnnaBridge 189:f392fc9709a3 274 #define RTC_TAMPERPRECHARGEDURATION_4RTCCLK ((uint32_t)0x00004000) /*!< Tamper pins are pre-charged before
AnnaBridge 189:f392fc9709a3 275 sampling during 4 RTCCLK cycles */
AnnaBridge 189:f392fc9709a3 276 #define RTC_TAMPERPRECHARGEDURATION_8RTCCLK ((uint32_t)0x00006000) /*!< Tamper pins are pre-charged before
AnnaBridge 189:f392fc9709a3 277 sampling during 8 RTCCLK cycles */
AnnaBridge 189:f392fc9709a3 278 /**
AnnaBridge 189:f392fc9709a3 279 * @}
AnnaBridge 189:f392fc9709a3 280 */
AnnaBridge 189:f392fc9709a3 281
AnnaBridge 189:f392fc9709a3 282 /** @defgroup RTCEx_Tamper_TimeStampOnTamperDetection_Definitions RTC Tamper TimeStamp On Tamper Detection Definitions
AnnaBridge 189:f392fc9709a3 283 * @{
AnnaBridge 189:f392fc9709a3 284 */
AnnaBridge 189:f392fc9709a3 285 #define RTC_TIMESTAMPONTAMPERDETECTION_ENABLE ((uint32_t)RTC_TAMPCR_TAMPTS) /*!< TimeStamp on Tamper Detection event saved */
AnnaBridge 189:f392fc9709a3 286 #define RTC_TIMESTAMPONTAMPERDETECTION_DISABLE ((uint32_t)0x00000000) /*!< TimeStamp on Tamper Detection event is not saved */
AnnaBridge 189:f392fc9709a3 287 /**
AnnaBridge 189:f392fc9709a3 288 * @}
AnnaBridge 189:f392fc9709a3 289 */
AnnaBridge 189:f392fc9709a3 290
AnnaBridge 189:f392fc9709a3 291 /** @defgroup RTCEx_Tamper_Pull_UP_Definitions RTC Tamper Pull Up Definitions
AnnaBridge 189:f392fc9709a3 292 * @{
AnnaBridge 189:f392fc9709a3 293 */
AnnaBridge 189:f392fc9709a3 294 #define RTC_TAMPER_PULLUP_ENABLE ((uint32_t)0x00000000) /*!< TimeStamp on Tamper Detection event saved */
AnnaBridge 189:f392fc9709a3 295 #define RTC_TAMPER_PULLUP_DISABLE ((uint32_t)RTC_TAMPCR_TAMPPUDIS) /*!< TimeStamp on Tamper Detection event is not saved */
AnnaBridge 189:f392fc9709a3 296 /**
AnnaBridge 189:f392fc9709a3 297 * @}
AnnaBridge 189:f392fc9709a3 298 */
AnnaBridge 189:f392fc9709a3 299
AnnaBridge 189:f392fc9709a3 300 /** @defgroup RTCEx_Wakeup_Timer_Definitions RTC Wakeup Timer Definitions
AnnaBridge 189:f392fc9709a3 301 * @{
AnnaBridge 189:f392fc9709a3 302 */
AnnaBridge 189:f392fc9709a3 303 #define RTC_WAKEUPCLOCK_RTCCLK_DIV16 ((uint32_t)0x00000000)
AnnaBridge 189:f392fc9709a3 304 #define RTC_WAKEUPCLOCK_RTCCLK_DIV8 ((uint32_t)0x00000001)
AnnaBridge 189:f392fc9709a3 305 #define RTC_WAKEUPCLOCK_RTCCLK_DIV4 ((uint32_t)0x00000002)
AnnaBridge 189:f392fc9709a3 306 #define RTC_WAKEUPCLOCK_RTCCLK_DIV2 ((uint32_t)0x00000003)
AnnaBridge 189:f392fc9709a3 307 #define RTC_WAKEUPCLOCK_CK_SPRE_16BITS ((uint32_t)0x00000004)
AnnaBridge 189:f392fc9709a3 308 #define RTC_WAKEUPCLOCK_CK_SPRE_17BITS ((uint32_t)0x00000006)
AnnaBridge 189:f392fc9709a3 309 /**
AnnaBridge 189:f392fc9709a3 310 * @}
AnnaBridge 189:f392fc9709a3 311 */
AnnaBridge 189:f392fc9709a3 312
AnnaBridge 189:f392fc9709a3 313 /** @defgroup RTCEx_Smooth_calib_period_Definitions RTC Smooth Calib Period Definitions
AnnaBridge 189:f392fc9709a3 314 * @{
AnnaBridge 189:f392fc9709a3 315 */
AnnaBridge 189:f392fc9709a3 316 #define RTC_SMOOTHCALIB_PERIOD_32SEC ((uint32_t)0x00000000) /*!< If RTCCLK = 32768 Hz, Smooth calibration
AnnaBridge 189:f392fc9709a3 317 period is 32s, else 2exp20 RTCCLK seconds */
AnnaBridge 189:f392fc9709a3 318 #define RTC_SMOOTHCALIB_PERIOD_16SEC ((uint32_t)0x00002000) /*!< If RTCCLK = 32768 Hz, Smooth calibration
AnnaBridge 189:f392fc9709a3 319 period is 16s, else 2exp19 RTCCLK seconds */
AnnaBridge 189:f392fc9709a3 320 #define RTC_SMOOTHCALIB_PERIOD_8SEC ((uint32_t)0x00004000) /*!< If RTCCLK = 32768 Hz, Smooth calibration
AnnaBridge 189:f392fc9709a3 321 period is 8s, else 2exp18 RTCCLK seconds */
AnnaBridge 189:f392fc9709a3 322 /**
AnnaBridge 189:f392fc9709a3 323 * @}
AnnaBridge 189:f392fc9709a3 324 */
AnnaBridge 189:f392fc9709a3 325
AnnaBridge 189:f392fc9709a3 326 /** @defgroup RTCEx_Smooth_calib_Plus_pulses_Definitions RTC Smooth Calib Plus Pulses Definitions
AnnaBridge 189:f392fc9709a3 327 * @{
AnnaBridge 189:f392fc9709a3 328 */
AnnaBridge 189:f392fc9709a3 329 #define RTC_SMOOTHCALIB_PLUSPULSES_SET ((uint32_t)0x00008000) /*!< The number of RTCCLK pulses added
AnnaBridge 189:f392fc9709a3 330 during a X -second window = Y - CALM[8:0]
AnnaBridge 189:f392fc9709a3 331 with Y = 512, 256, 128 when X = 32, 16, 8 */
AnnaBridge 189:f392fc9709a3 332 #define RTC_SMOOTHCALIB_PLUSPULSES_RESET ((uint32_t)0x00000000) /*!< The number of RTCCLK pulses subbstited
AnnaBridge 189:f392fc9709a3 333 during a 32-second window = CALM[8:0] */
AnnaBridge 189:f392fc9709a3 334 /**
AnnaBridge 189:f392fc9709a3 335 * @}
AnnaBridge 189:f392fc9709a3 336 */
AnnaBridge 189:f392fc9709a3 337
AnnaBridge 189:f392fc9709a3 338 /** @defgroup RTCEx_Calib_Output_selection_Definitions RTC Calib Output Selection Definitions
AnnaBridge 189:f392fc9709a3 339 * @{
AnnaBridge 189:f392fc9709a3 340 */
AnnaBridge 189:f392fc9709a3 341 #define RTC_CALIBOUTPUT_512HZ ((uint32_t)0x00000000)
AnnaBridge 189:f392fc9709a3 342 #define RTC_CALIBOUTPUT_1HZ ((uint32_t)0x00080000)
AnnaBridge 189:f392fc9709a3 343 /**
AnnaBridge 189:f392fc9709a3 344 * @}
AnnaBridge 189:f392fc9709a3 345 */
AnnaBridge 189:f392fc9709a3 346
AnnaBridge 189:f392fc9709a3 347 /** @defgroup RTCEx_Add_1_Second_Parameter_Definitions RTC Add 1 Second Parameter Definitions
AnnaBridge 189:f392fc9709a3 348 * @{
AnnaBridge 189:f392fc9709a3 349 */
AnnaBridge 189:f392fc9709a3 350 #define RTC_SHIFTADD1S_RESET ((uint32_t)0x00000000)
AnnaBridge 189:f392fc9709a3 351 #define RTC_SHIFTADD1S_SET ((uint32_t)0x80000000)
AnnaBridge 189:f392fc9709a3 352 /**
AnnaBridge 189:f392fc9709a3 353 * @}
AnnaBridge 189:f392fc9709a3 354 */
AnnaBridge 189:f392fc9709a3 355
AnnaBridge 189:f392fc9709a3 356 /**
AnnaBridge 189:f392fc9709a3 357 * @}
AnnaBridge 189:f392fc9709a3 358 */
AnnaBridge 189:f392fc9709a3 359
AnnaBridge 189:f392fc9709a3 360 /* Exported macros -----------------------------------------------------------*/
AnnaBridge 189:f392fc9709a3 361 /** @defgroup RTCEx_Exported_Macros RTCEx Exported Macros
AnnaBridge 189:f392fc9709a3 362 * @{
AnnaBridge 189:f392fc9709a3 363 */
AnnaBridge 189:f392fc9709a3 364
AnnaBridge 189:f392fc9709a3 365 /**
AnnaBridge 189:f392fc9709a3 366 * @brief Enable the RTC WakeUp Timer peripheral.
AnnaBridge 189:f392fc9709a3 367 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 368 * @retval None
AnnaBridge 189:f392fc9709a3 369 */
AnnaBridge 189:f392fc9709a3 370 #define __HAL_RTC_WAKEUPTIMER_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= (RTC_CR_WUTE))
AnnaBridge 189:f392fc9709a3 371
AnnaBridge 189:f392fc9709a3 372 /**
AnnaBridge 189:f392fc9709a3 373 * @brief Disable the RTC WakeUp Timer peripheral.
AnnaBridge 189:f392fc9709a3 374 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 375 * @retval None
AnnaBridge 189:f392fc9709a3 376 */
AnnaBridge 189:f392fc9709a3 377 #define __HAL_RTC_WAKEUPTIMER_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~(RTC_CR_WUTE))
AnnaBridge 189:f392fc9709a3 378
AnnaBridge 189:f392fc9709a3 379 /**
AnnaBridge 189:f392fc9709a3 380 * @brief Enable the RTC WakeUpTimer interrupt.
AnnaBridge 189:f392fc9709a3 381 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 382 * @param __INTERRUPT__: specifies the RTC WakeUpTimer interrupt sources to be enabled.
AnnaBridge 189:f392fc9709a3 383 * This parameter can be:
AnnaBridge 189:f392fc9709a3 384 * @arg RTC_IT_WUT: WakeUpTimer interrupt
AnnaBridge 189:f392fc9709a3 385 * @retval None
AnnaBridge 189:f392fc9709a3 386 */
AnnaBridge 189:f392fc9709a3 387 #define __HAL_RTC_WAKEUPTIMER_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR |= (__INTERRUPT__))
AnnaBridge 189:f392fc9709a3 388
AnnaBridge 189:f392fc9709a3 389 /**
AnnaBridge 189:f392fc9709a3 390 * @brief Disable the RTC WakeUpTimer interrupt.
AnnaBridge 189:f392fc9709a3 391 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 392 * @param __INTERRUPT__: specifies the RTC WakeUpTimer interrupt sources to be disabled.
AnnaBridge 189:f392fc9709a3 393 * This parameter can be:
AnnaBridge 189:f392fc9709a3 394 * @arg RTC_IT_WUT: WakeUpTimer interrupt
AnnaBridge 189:f392fc9709a3 395 * @retval None
AnnaBridge 189:f392fc9709a3 396 */
AnnaBridge 189:f392fc9709a3 397 #define __HAL_RTC_WAKEUPTIMER_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR &= ~(__INTERRUPT__))
AnnaBridge 189:f392fc9709a3 398
AnnaBridge 189:f392fc9709a3 399 /**
AnnaBridge 189:f392fc9709a3 400 * @brief Check whether the specified RTC WakeUpTimer interrupt has occurred or not.
AnnaBridge 189:f392fc9709a3 401 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 402 * @param __INTERRUPT__: specifies the RTC WakeUpTimer interrupt sources to check.
AnnaBridge 189:f392fc9709a3 403 * This parameter can be:
AnnaBridge 189:f392fc9709a3 404 * @arg RTC_IT_WUT: WakeUpTimer interrupt
AnnaBridge 189:f392fc9709a3 405 * @retval None
AnnaBridge 189:f392fc9709a3 406 */
AnnaBridge 189:f392fc9709a3 407 #define __HAL_RTC_WAKEUPTIMER_GET_IT(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->ISR) & ((__INTERRUPT__)>> 4)) != RESET) ? SET : RESET)
AnnaBridge 189:f392fc9709a3 408
AnnaBridge 189:f392fc9709a3 409 /**
AnnaBridge 189:f392fc9709a3 410 * @brief Check whether the specified RTC Wake Up timer interrupt is enabled or not.
AnnaBridge 189:f392fc9709a3 411 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 412 * @param __INTERRUPT__: specifies the RTC Wake Up timer interrupt sources to check.
AnnaBridge 189:f392fc9709a3 413 * This parameter can be:
AnnaBridge 189:f392fc9709a3 414 * @arg RTC_IT_WUT: WakeUpTimer interrupt
AnnaBridge 189:f392fc9709a3 415 * @retval None
AnnaBridge 189:f392fc9709a3 416 */
AnnaBridge 189:f392fc9709a3 417 #define __HAL_RTC_WAKEUPTIMER_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->CR) & (__INTERRUPT__)) != RESET) ? SET : RESET)
AnnaBridge 189:f392fc9709a3 418
AnnaBridge 189:f392fc9709a3 419 /**
AnnaBridge 189:f392fc9709a3 420 * @brief Get the selected RTC WakeUpTimer's flag status.
AnnaBridge 189:f392fc9709a3 421 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 422 * @param __FLAG__: specifies the RTC WakeUpTimer Flag is pending or not.
AnnaBridge 189:f392fc9709a3 423 * This parameter can be:
AnnaBridge 189:f392fc9709a3 424 * @arg RTC_FLAG_WUTF
AnnaBridge 189:f392fc9709a3 425 * @arg RTC_FLAG_WUTWF
AnnaBridge 189:f392fc9709a3 426 * @retval None
AnnaBridge 189:f392fc9709a3 427 */
AnnaBridge 189:f392fc9709a3 428 #define __HAL_RTC_WAKEUPTIMER_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & (__FLAG__)) != RESET) ? SET : RESET)
AnnaBridge 189:f392fc9709a3 429
AnnaBridge 189:f392fc9709a3 430 /**
AnnaBridge 189:f392fc9709a3 431 * @brief Clear the RTC Wake Up timer's pending flags.
AnnaBridge 189:f392fc9709a3 432 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 433 * @param __FLAG__: specifies the RTC WakeUpTimer Flag to clear.
AnnaBridge 189:f392fc9709a3 434 * This parameter can be:
AnnaBridge 189:f392fc9709a3 435 * @arg RTC_FLAG_WUTF
AnnaBridge 189:f392fc9709a3 436 * @retval None
AnnaBridge 189:f392fc9709a3 437 */
AnnaBridge 189:f392fc9709a3 438 #define __HAL_RTC_WAKEUPTIMER_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ISR) = (~((__FLAG__) | RTC_ISR_INIT)|((__HANDLE__)->Instance->ISR & RTC_ISR_INIT))
AnnaBridge 189:f392fc9709a3 439
AnnaBridge 189:f392fc9709a3 440 #if defined(RTC_TAMPER1_SUPPORT)
AnnaBridge 189:f392fc9709a3 441 /**
AnnaBridge 189:f392fc9709a3 442 * @brief Enable the RTC Tamper1 input detection.
AnnaBridge 189:f392fc9709a3 443 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 444 * @retval None
AnnaBridge 189:f392fc9709a3 445 */
AnnaBridge 189:f392fc9709a3 446 #define __HAL_RTC_TAMPER1_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->TAMPCR |= (RTC_TAMPCR_TAMP1E))
AnnaBridge 189:f392fc9709a3 447
AnnaBridge 189:f392fc9709a3 448 /**
AnnaBridge 189:f392fc9709a3 449 * @brief Disable the RTC Tamper1 input detection.
AnnaBridge 189:f392fc9709a3 450 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 451 * @retval None
AnnaBridge 189:f392fc9709a3 452 */
AnnaBridge 189:f392fc9709a3 453 #define __HAL_RTC_TAMPER1_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->TAMPCR &= ~(RTC_TAMPCR_TAMP1E))
AnnaBridge 189:f392fc9709a3 454 #endif /* RTC_TAMPER1_SUPPORT */
AnnaBridge 189:f392fc9709a3 455
AnnaBridge 189:f392fc9709a3 456 /**
AnnaBridge 189:f392fc9709a3 457 * @brief Enable the RTC Tamper2 input detection.
AnnaBridge 189:f392fc9709a3 458 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 459 * @retval None
AnnaBridge 189:f392fc9709a3 460 */
AnnaBridge 189:f392fc9709a3 461 #define __HAL_RTC_TAMPER2_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->TAMPCR |= (RTC_TAMPCR_TAMP2E))
AnnaBridge 189:f392fc9709a3 462
AnnaBridge 189:f392fc9709a3 463 /**
AnnaBridge 189:f392fc9709a3 464 * @brief Disable the RTC Tamper2 input detection.
AnnaBridge 189:f392fc9709a3 465 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 466 * @retval None
AnnaBridge 189:f392fc9709a3 467 */
AnnaBridge 189:f392fc9709a3 468 #define __HAL_RTC_TAMPER2_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->TAMPCR &= ~(RTC_TAMPCR_TAMP2E))
AnnaBridge 189:f392fc9709a3 469
AnnaBridge 189:f392fc9709a3 470 #if defined(RTC_TAMPER3_SUPPORT)
AnnaBridge 189:f392fc9709a3 471 /**
AnnaBridge 189:f392fc9709a3 472 * @brief Enable the RTC Tamper3 input detection.
AnnaBridge 189:f392fc9709a3 473 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 474 * @retval None
AnnaBridge 189:f392fc9709a3 475 */
AnnaBridge 189:f392fc9709a3 476 #define __HAL_RTC_TAMPER3_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->TAMPCR |= (RTC_TAMPCR_TAMP3E))
AnnaBridge 189:f392fc9709a3 477
AnnaBridge 189:f392fc9709a3 478 /**
AnnaBridge 189:f392fc9709a3 479 * @brief Disable the RTC Tamper3 input detection.
AnnaBridge 189:f392fc9709a3 480 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 481 * @retval None
AnnaBridge 189:f392fc9709a3 482 */
AnnaBridge 189:f392fc9709a3 483 #define __HAL_RTC_TAMPER3_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->TAMPCR &= ~(RTC_TAMPCR_TAMP3E))
AnnaBridge 189:f392fc9709a3 484 #endif /* RTC_TAMPER3_SUPPORT */
AnnaBridge 189:f392fc9709a3 485
AnnaBridge 189:f392fc9709a3 486 /**
AnnaBridge 189:f392fc9709a3 487 * @brief Enable the RTC Tamper interrupt.
AnnaBridge 189:f392fc9709a3 488 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 489 * @param __INTERRUPT__: specifies the RTC Tamper interrupt sources to be enabled.
AnnaBridge 189:f392fc9709a3 490 * This parameter can be any combination of the following values:
AnnaBridge 189:f392fc9709a3 491 * @arg RTC_IT_TAMP: All tampers interrupts
AnnaBridge 189:f392fc9709a3 492 * @arg RTC_IT_TAMP1: Tamper1 interrupt
AnnaBridge 189:f392fc9709a3 493 * @arg RTC_IT_TAMP2: Tamper2 interrupt
AnnaBridge 189:f392fc9709a3 494 * @arg RTC_IT_TAMP3: Tamper3 interrupt
AnnaBridge 189:f392fc9709a3 495 * @retval None
AnnaBridge 189:f392fc9709a3 496 */
AnnaBridge 189:f392fc9709a3 497 #define __HAL_RTC_TAMPER_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->TAMPCR |= (__INTERRUPT__))
AnnaBridge 189:f392fc9709a3 498
AnnaBridge 189:f392fc9709a3 499 /**
AnnaBridge 189:f392fc9709a3 500 * @brief Disable the RTC Tamper interrupt.
AnnaBridge 189:f392fc9709a3 501 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 502 * @param __INTERRUPT__: specifies the RTC Tamper interrupt sources to be disabled.
AnnaBridge 189:f392fc9709a3 503 * This parameter can be any combination of the following values:
AnnaBridge 189:f392fc9709a3 504 * @arg RTC_IT_TAMP: All tampers interrupts
AnnaBridge 189:f392fc9709a3 505 * @arg RTC_IT_TAMP1: Tamper1 interrupt
AnnaBridge 189:f392fc9709a3 506 * @arg RTC_IT_TAMP2: Tamper2 interrupt
AnnaBridge 189:f392fc9709a3 507 * @arg RTC_IT_TAMP3: Tamper3 interrupt
AnnaBridge 189:f392fc9709a3 508 * @retval None
AnnaBridge 189:f392fc9709a3 509 */
AnnaBridge 189:f392fc9709a3 510 #define __HAL_RTC_TAMPER_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->TAMPCR &= ~(__INTERRUPT__))
AnnaBridge 189:f392fc9709a3 511
AnnaBridge 189:f392fc9709a3 512 /**
AnnaBridge 189:f392fc9709a3 513 * @brief Check whether the specified RTC Tamper interrupt has occurred or not.
AnnaBridge 189:f392fc9709a3 514 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 515 * @param __INTERRUPT__: specifies the RTC Tamper interrupt to check.
AnnaBridge 189:f392fc9709a3 516 * This parameter can be:
AnnaBridge 189:f392fc9709a3 517 * @arg RTC_IT_TAMP1: Tamper1 interrupt
AnnaBridge 189:f392fc9709a3 518 * @arg RTC_IT_TAMP2: Tamper2 interrupt
AnnaBridge 189:f392fc9709a3 519 * @arg RTC_IT_TAMP3: Tamper3 interrupt
AnnaBridge 189:f392fc9709a3 520 * @retval None
AnnaBridge 189:f392fc9709a3 521 */
AnnaBridge 189:f392fc9709a3 522 #if defined(RTC_TAMPER1_SUPPORT) && defined(RTC_TAMPER3_SUPPORT)
AnnaBridge 189:f392fc9709a3 523 #define __HAL_RTC_TAMPER_GET_IT(__HANDLE__, __INTERRUPT__) (((__INTERRUPT__) == RTC_IT_TAMP1) ? (((((__HANDLE__)->Instance->ISR) & ((__INTERRUPT__)>> 3)) != RESET) ? SET : RESET) : \
AnnaBridge 189:f392fc9709a3 524 ((__INTERRUPT__) == RTC_IT_TAMP2) ? (((((__HANDLE__)->Instance->ISR) & ((__INTERRUPT__)>> 5)) != RESET) ? SET : RESET) : \
AnnaBridge 189:f392fc9709a3 525 (((((__HANDLE__)->Instance->ISR) & ((__INTERRUPT__)>> 7)) != RESET) ? SET : RESET))
AnnaBridge 189:f392fc9709a3 526 #else
AnnaBridge 189:f392fc9709a3 527 #define __HAL_RTC_TAMPER_GET_IT(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->ISR) & ((__INTERRUPT__)>> 5)) != RESET) ? SET : RESET)
AnnaBridge 189:f392fc9709a3 528 #endif /* RTC_TAMPER1_SUPPORT && RTC_TAMPER3_SUPPORT */
AnnaBridge 189:f392fc9709a3 529
AnnaBridge 189:f392fc9709a3 530 /**
AnnaBridge 189:f392fc9709a3 531 * @brief Check whether the specified RTC Tamper interrupt is enabled or not.
AnnaBridge 189:f392fc9709a3 532 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 533 * @param __INTERRUPT__: specifies the RTC Tamper interrupt source to check.
AnnaBridge 189:f392fc9709a3 534 * This parameter can be:
AnnaBridge 189:f392fc9709a3 535 * @arg RTC_IT_TAMP: All tampers interrupts
AnnaBridge 189:f392fc9709a3 536 * @arg RTC_IT_TAMP1: Tamper1 interrupt
AnnaBridge 189:f392fc9709a3 537 * @arg RTC_IT_TAMP2: Tamper2 interrupt
AnnaBridge 189:f392fc9709a3 538 * @arg RTC_IT_TAMP3: Tamper3 interrupt
AnnaBridge 189:f392fc9709a3 539 * @retval None
AnnaBridge 189:f392fc9709a3 540 */
AnnaBridge 189:f392fc9709a3 541 #define __HAL_RTC_TAMPER_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->TAMPCR) & (__INTERRUPT__)) != RESET) ? SET : RESET)
AnnaBridge 189:f392fc9709a3 542
AnnaBridge 189:f392fc9709a3 543 /**
AnnaBridge 189:f392fc9709a3 544 * @brief Get the selected RTC Tamper's flag status.
AnnaBridge 189:f392fc9709a3 545 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 546 * @param __FLAG__: specifies the RTC Tamper Flag is pending or not.
AnnaBridge 189:f392fc9709a3 547 * This parameter can be:
AnnaBridge 189:f392fc9709a3 548 * @arg RTC_FLAG_TAMP1F: Tamper1 flag
AnnaBridge 189:f392fc9709a3 549 * @arg RTC_FLAG_TAMP2F: Tamper2 flag
AnnaBridge 189:f392fc9709a3 550 * @arg RTC_FLAG_TAMP3F: Tamper3 flag
AnnaBridge 189:f392fc9709a3 551 * @retval None
AnnaBridge 189:f392fc9709a3 552 */
AnnaBridge 189:f392fc9709a3 553 #define __HAL_RTC_TAMPER_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & (__FLAG__)) != RESET) ? SET : RESET)
AnnaBridge 189:f392fc9709a3 554
AnnaBridge 189:f392fc9709a3 555 /**
AnnaBridge 189:f392fc9709a3 556 * @brief Clear the RTC Tamper's pending flags.
AnnaBridge 189:f392fc9709a3 557 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 558 * @param __FLAG__: specifies the RTC Tamper Flag sources to clear.
AnnaBridge 189:f392fc9709a3 559 * This parameter can be:
AnnaBridge 189:f392fc9709a3 560 * @arg RTC_FLAG_TAMP1F: Tamper1 flag
AnnaBridge 189:f392fc9709a3 561 * @arg RTC_FLAG_TAMP2F: Tamper2 flag
AnnaBridge 189:f392fc9709a3 562 * @arg RTC_FLAG_TAMP3F: Tamper3 flag
AnnaBridge 189:f392fc9709a3 563 * @retval None
AnnaBridge 189:f392fc9709a3 564 */
AnnaBridge 189:f392fc9709a3 565 #define __HAL_RTC_TAMPER_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ISR) = (~((__FLAG__) | RTC_ISR_INIT)|((__HANDLE__)->Instance->ISR & RTC_ISR_INIT))
AnnaBridge 189:f392fc9709a3 566
AnnaBridge 189:f392fc9709a3 567 /**
AnnaBridge 189:f392fc9709a3 568 * @brief Enable the RTC TimeStamp peripheral.
AnnaBridge 189:f392fc9709a3 569 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 570 * @retval None
AnnaBridge 189:f392fc9709a3 571 */
AnnaBridge 189:f392fc9709a3 572 #define __HAL_RTC_TIMESTAMP_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= (RTC_CR_TSE))
AnnaBridge 189:f392fc9709a3 573
AnnaBridge 189:f392fc9709a3 574 /**
AnnaBridge 189:f392fc9709a3 575 * @brief Disable the RTC TimeStamp peripheral.
AnnaBridge 189:f392fc9709a3 576 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 577 * @retval None
AnnaBridge 189:f392fc9709a3 578 */
AnnaBridge 189:f392fc9709a3 579 #define __HAL_RTC_TIMESTAMP_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~(RTC_CR_TSE))
AnnaBridge 189:f392fc9709a3 580
AnnaBridge 189:f392fc9709a3 581 /**
AnnaBridge 189:f392fc9709a3 582 * @brief Enable the RTC TimeStamp interrupt.
AnnaBridge 189:f392fc9709a3 583 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 584 * @param __INTERRUPT__: specifies the RTC TimeStamp interrupt source to be enabled.
AnnaBridge 189:f392fc9709a3 585 * This parameter can be:
AnnaBridge 189:f392fc9709a3 586 * @arg RTC_IT_TS: TimeStamp interrupt
AnnaBridge 189:f392fc9709a3 587 * @retval None
AnnaBridge 189:f392fc9709a3 588 */
AnnaBridge 189:f392fc9709a3 589 #define __HAL_RTC_TIMESTAMP_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR |= (__INTERRUPT__))
AnnaBridge 189:f392fc9709a3 590
AnnaBridge 189:f392fc9709a3 591 /**
AnnaBridge 189:f392fc9709a3 592 * @brief Disable the RTC TimeStamp interrupt.
AnnaBridge 189:f392fc9709a3 593 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 594 * @param __INTERRUPT__: specifies the RTC TimeStamp interrupt source to be disabled.
AnnaBridge 189:f392fc9709a3 595 * This parameter can be:
AnnaBridge 189:f392fc9709a3 596 * @arg RTC_IT_TS: TimeStamp interrupt
AnnaBridge 189:f392fc9709a3 597 * @retval None
AnnaBridge 189:f392fc9709a3 598 */
AnnaBridge 189:f392fc9709a3 599 #define __HAL_RTC_TIMESTAMP_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR &= ~(__INTERRUPT__))
AnnaBridge 189:f392fc9709a3 600
AnnaBridge 189:f392fc9709a3 601 /**
AnnaBridge 189:f392fc9709a3 602 * @brief Check whether the specified RTC TimeStamp interrupt has occurred or not.
AnnaBridge 189:f392fc9709a3 603 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 604 * @param __INTERRUPT__: specifies the RTC TimeStamp interrupt source to check.
AnnaBridge 189:f392fc9709a3 605 * This parameter can be:
AnnaBridge 189:f392fc9709a3 606 * @arg RTC_IT_TS: TimeStamp interrupt
AnnaBridge 189:f392fc9709a3 607 * @retval None
AnnaBridge 189:f392fc9709a3 608 */
AnnaBridge 189:f392fc9709a3 609 #define __HAL_RTC_TIMESTAMP_GET_IT(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->ISR) & ((__INTERRUPT__)>> 4)) != RESET) ? SET : RESET)
AnnaBridge 189:f392fc9709a3 610
AnnaBridge 189:f392fc9709a3 611 /**
AnnaBridge 189:f392fc9709a3 612 * @brief Check whether the specified RTC Time Stamp interrupt is enabled or not.
AnnaBridge 189:f392fc9709a3 613 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 614 * @param __INTERRUPT__: specifies the RTC Time Stamp interrupt source to check.
AnnaBridge 189:f392fc9709a3 615 * This parameter can be:
AnnaBridge 189:f392fc9709a3 616 * @arg RTC_IT_TS: TimeStamp interrupt
AnnaBridge 189:f392fc9709a3 617 * @retval None
AnnaBridge 189:f392fc9709a3 618 */
AnnaBridge 189:f392fc9709a3 619 #define __HAL_RTC_TIMESTAMP_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->CR) & (__INTERRUPT__)) != RESET) ? SET : RESET)
AnnaBridge 189:f392fc9709a3 620
AnnaBridge 189:f392fc9709a3 621 /**
AnnaBridge 189:f392fc9709a3 622 * @brief Get the selected RTC TimeStamp's flag status.
AnnaBridge 189:f392fc9709a3 623 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 624 * @param __FLAG__: specifies the RTC TimeStamp Flag is pending or not.
AnnaBridge 189:f392fc9709a3 625 * This parameter can be:
AnnaBridge 189:f392fc9709a3 626 * @arg RTC_FLAG_TSF
AnnaBridge 189:f392fc9709a3 627 * @arg RTC_FLAG_TSOVF
AnnaBridge 189:f392fc9709a3 628 * @retval None
AnnaBridge 189:f392fc9709a3 629 */
AnnaBridge 189:f392fc9709a3 630 #define __HAL_RTC_TIMESTAMP_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & (__FLAG__)) != RESET) ? SET : RESET)
AnnaBridge 189:f392fc9709a3 631
AnnaBridge 189:f392fc9709a3 632 /**
AnnaBridge 189:f392fc9709a3 633 * @brief Clear the RTC Time Stamp's pending flags.
AnnaBridge 189:f392fc9709a3 634 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 635 * @param __FLAG__: specifies the RTC Alarm Flag sources to clear.
AnnaBridge 189:f392fc9709a3 636 * This parameter can be:
AnnaBridge 189:f392fc9709a3 637 * @arg RTC_FLAG_TSF
AnnaBridge 189:f392fc9709a3 638 * @arg RTC_FLAG_TSOVF
AnnaBridge 189:f392fc9709a3 639 * @retval None
AnnaBridge 189:f392fc9709a3 640 */
AnnaBridge 189:f392fc9709a3 641 #define __HAL_RTC_TIMESTAMP_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ISR) = (~((__FLAG__) | RTC_ISR_INIT)|((__HANDLE__)->Instance->ISR & RTC_ISR_INIT))
AnnaBridge 189:f392fc9709a3 642
AnnaBridge 189:f392fc9709a3 643 /**
AnnaBridge 189:f392fc9709a3 644 * @brief Enable the RTC internal TimeStamp peripheral.
AnnaBridge 189:f392fc9709a3 645 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 646 * @retval None
AnnaBridge 189:f392fc9709a3 647 */
AnnaBridge 189:f392fc9709a3 648 #define __HAL_RTC_INTERNAL_TIMESTAMP_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= (RTC_CR_ITSE))
AnnaBridge 189:f392fc9709a3 649
AnnaBridge 189:f392fc9709a3 650 /**
AnnaBridge 189:f392fc9709a3 651 * @brief Disable the RTC internal TimeStamp peripheral.
AnnaBridge 189:f392fc9709a3 652 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 653 * @retval None
AnnaBridge 189:f392fc9709a3 654 */
AnnaBridge 189:f392fc9709a3 655 #define __HAL_RTC_INTERNAL_TIMESTAMP_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~(RTC_CR_ITSE))
AnnaBridge 189:f392fc9709a3 656
AnnaBridge 189:f392fc9709a3 657 /**
AnnaBridge 189:f392fc9709a3 658 * @brief Get the selected RTC Internal Time Stamp's flag status.
AnnaBridge 189:f392fc9709a3 659 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 660 * @param __FLAG__: specifies the RTC Internal Time Stamp Flag is pending or not.
AnnaBridge 189:f392fc9709a3 661 * This parameter can be:
AnnaBridge 189:f392fc9709a3 662 * @arg RTC_FLAG_ITSF
AnnaBridge 189:f392fc9709a3 663 * @retval None
AnnaBridge 189:f392fc9709a3 664 */
AnnaBridge 189:f392fc9709a3 665 #define __HAL_RTC_INTERNAL_TIMESTAMP_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & (__FLAG__)) != RESET) ? SET : RESET)
AnnaBridge 189:f392fc9709a3 666
AnnaBridge 189:f392fc9709a3 667 /**
AnnaBridge 189:f392fc9709a3 668 * @brief Clear the RTC Internal Time Stamp's pending flags.
AnnaBridge 189:f392fc9709a3 669 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 670 * @param __FLAG__: specifies the RTC Internal Time Stamp Flag source to clear.
AnnaBridge 189:f392fc9709a3 671 * This parameter can be:
AnnaBridge 189:f392fc9709a3 672 * @arg RTC_FLAG_ITSF
AnnaBridge 189:f392fc9709a3 673 * @retval None
AnnaBridge 189:f392fc9709a3 674 */
AnnaBridge 189:f392fc9709a3 675 #define __HAL_RTC_INTERNAL_TIMESTAMP_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ISR) = (~((__FLAG__) | RTC_ISR_INIT)|((__HANDLE__)->Instance->ISR & RTC_ISR_INIT))
AnnaBridge 189:f392fc9709a3 676
AnnaBridge 189:f392fc9709a3 677 /**
AnnaBridge 189:f392fc9709a3 678 * @brief Enable the RTC calibration output.
AnnaBridge 189:f392fc9709a3 679 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 680 * @retval None
AnnaBridge 189:f392fc9709a3 681 */
AnnaBridge 189:f392fc9709a3 682 #define __HAL_RTC_CALIBRATION_OUTPUT_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= (RTC_CR_COE))
AnnaBridge 189:f392fc9709a3 683
AnnaBridge 189:f392fc9709a3 684 /**
AnnaBridge 189:f392fc9709a3 685 * @brief Disable the calibration output.
AnnaBridge 189:f392fc9709a3 686 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 687 * @retval None
AnnaBridge 189:f392fc9709a3 688 */
AnnaBridge 189:f392fc9709a3 689 #define __HAL_RTC_CALIBRATION_OUTPUT_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~(RTC_CR_COE))
AnnaBridge 189:f392fc9709a3 690
AnnaBridge 189:f392fc9709a3 691 /**
AnnaBridge 189:f392fc9709a3 692 * @brief Enable the clock reference detection.
AnnaBridge 189:f392fc9709a3 693 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 694 * @retval None
AnnaBridge 189:f392fc9709a3 695 */
AnnaBridge 189:f392fc9709a3 696 #define __HAL_RTC_CLOCKREF_DETECTION_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= (RTC_CR_REFCKON))
AnnaBridge 189:f392fc9709a3 697
AnnaBridge 189:f392fc9709a3 698 /**
AnnaBridge 189:f392fc9709a3 699 * @brief Disable the clock reference detection.
AnnaBridge 189:f392fc9709a3 700 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 701 * @retval None
AnnaBridge 189:f392fc9709a3 702 */
AnnaBridge 189:f392fc9709a3 703 #define __HAL_RTC_CLOCKREF_DETECTION_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~(RTC_CR_REFCKON))
AnnaBridge 189:f392fc9709a3 704
AnnaBridge 189:f392fc9709a3 705 /**
AnnaBridge 189:f392fc9709a3 706 * @brief Get the selected RTC shift operation's flag status.
AnnaBridge 189:f392fc9709a3 707 * @param __HANDLE__: specifies the RTC handle.
AnnaBridge 189:f392fc9709a3 708 * @param __FLAG__: specifies the RTC shift operation Flag is pending or not.
AnnaBridge 189:f392fc9709a3 709 * This parameter can be:
AnnaBridge 189:f392fc9709a3 710 * @arg RTC_FLAG_SHPF
AnnaBridge 189:f392fc9709a3 711 * @retval None
AnnaBridge 189:f392fc9709a3 712 */
AnnaBridge 189:f392fc9709a3 713 #define __HAL_RTC_SHIFT_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & (__FLAG__)) != RESET) ? SET : RESET)
AnnaBridge 189:f392fc9709a3 714
AnnaBridge 189:f392fc9709a3 715 /**
AnnaBridge 189:f392fc9709a3 716 * @brief Enable interrupt on the RTC WakeUp Timer associated Exti line.
AnnaBridge 189:f392fc9709a3 717 * @retval None
AnnaBridge 189:f392fc9709a3 718 */
AnnaBridge 189:f392fc9709a3 719 #define __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_IT() (EXTI->IMR1 |= RTC_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 189:f392fc9709a3 720
AnnaBridge 189:f392fc9709a3 721 /**
AnnaBridge 189:f392fc9709a3 722 * @brief Disable interrupt on the RTC WakeUp Timer associated Exti line.
AnnaBridge 189:f392fc9709a3 723 * @retval None
AnnaBridge 189:f392fc9709a3 724 */
AnnaBridge 189:f392fc9709a3 725 #define __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_IT() (EXTI->IMR1 &= ~(RTC_EXTI_LINE_WAKEUPTIMER_EVENT))
AnnaBridge 189:f392fc9709a3 726
AnnaBridge 189:f392fc9709a3 727 /**
AnnaBridge 189:f392fc9709a3 728 * @brief Enable event on the RTC WakeUp Timer associated Exti line.
AnnaBridge 189:f392fc9709a3 729 * @retval None
AnnaBridge 189:f392fc9709a3 730 */
AnnaBridge 189:f392fc9709a3 731 #define __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_EVENT() (EXTI->EMR1 |= RTC_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 189:f392fc9709a3 732
AnnaBridge 189:f392fc9709a3 733 /**
AnnaBridge 189:f392fc9709a3 734 * @brief Disable event on the RTC WakeUp Timer associated Exti line.
AnnaBridge 189:f392fc9709a3 735 * @retval None
AnnaBridge 189:f392fc9709a3 736 */
AnnaBridge 189:f392fc9709a3 737 #define __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_EVENT() (EXTI->EMR1 &= ~(RTC_EXTI_LINE_WAKEUPTIMER_EVENT))
AnnaBridge 189:f392fc9709a3 738
AnnaBridge 189:f392fc9709a3 739 /**
AnnaBridge 189:f392fc9709a3 740 * @brief Enable falling edge trigger on the RTC WakeUp Timer associated Exti line.
AnnaBridge 189:f392fc9709a3 741 * @retval None
AnnaBridge 189:f392fc9709a3 742 */
AnnaBridge 189:f392fc9709a3 743 #define __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_FALLING_EDGE() (EXTI->FTSR1 |= RTC_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 189:f392fc9709a3 744
AnnaBridge 189:f392fc9709a3 745 /**
AnnaBridge 189:f392fc9709a3 746 * @brief Disable falling edge trigger on the RTC WakeUp Timer associated Exti line.
AnnaBridge 189:f392fc9709a3 747 * @retval None
AnnaBridge 189:f392fc9709a3 748 */
AnnaBridge 189:f392fc9709a3 749 #define __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_FALLING_EDGE() (EXTI->FTSR1 &= ~(RTC_EXTI_LINE_WAKEUPTIMER_EVENT))
AnnaBridge 189:f392fc9709a3 750
AnnaBridge 189:f392fc9709a3 751 /**
AnnaBridge 189:f392fc9709a3 752 * @brief Enable rising edge trigger on the RTC WakeUp Timer associated Exti line.
AnnaBridge 189:f392fc9709a3 753 * @retval None
AnnaBridge 189:f392fc9709a3 754 */
AnnaBridge 189:f392fc9709a3 755 #define __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_RISING_EDGE() (EXTI->RTSR1 |= RTC_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 189:f392fc9709a3 756
AnnaBridge 189:f392fc9709a3 757 /**
AnnaBridge 189:f392fc9709a3 758 * @brief Disable rising edge trigger on the RTC WakeUp Timer associated Exti line.
AnnaBridge 189:f392fc9709a3 759 * @retval None
AnnaBridge 189:f392fc9709a3 760 */
AnnaBridge 189:f392fc9709a3 761 #define __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_RISING_EDGE() (EXTI->RTSR1 &= ~(RTC_EXTI_LINE_WAKEUPTIMER_EVENT))
AnnaBridge 189:f392fc9709a3 762
AnnaBridge 189:f392fc9709a3 763 /**
AnnaBridge 189:f392fc9709a3 764 * @brief Enable rising & falling edge trigger on the RTC WakeUp Timer associated Exti line.
AnnaBridge 189:f392fc9709a3 765 * @retval None
AnnaBridge 189:f392fc9709a3 766 */
AnnaBridge 189:f392fc9709a3 767 #define __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_RISING_FALLING_EDGE() do { \
AnnaBridge 189:f392fc9709a3 768 __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_RISING_EDGE(); \
AnnaBridge 189:f392fc9709a3 769 __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_FALLING_EDGE(); \
AnnaBridge 189:f392fc9709a3 770 } while(0)
AnnaBridge 189:f392fc9709a3 771
AnnaBridge 189:f392fc9709a3 772 /**
AnnaBridge 189:f392fc9709a3 773 * @brief Disable rising & falling edge trigger on the RTC WakeUp Timer associated Exti line.
AnnaBridge 189:f392fc9709a3 774 * This parameter can be:
AnnaBridge 189:f392fc9709a3 775 * @retval None
AnnaBridge 189:f392fc9709a3 776 */
AnnaBridge 189:f392fc9709a3 777 #define __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_RISING_FALLING_EDGE() do { \
AnnaBridge 189:f392fc9709a3 778 __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_RISING_EDGE(); \
AnnaBridge 189:f392fc9709a3 779 __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_FALLING_EDGE(); \
AnnaBridge 189:f392fc9709a3 780 } while(0)
AnnaBridge 189:f392fc9709a3 781
AnnaBridge 189:f392fc9709a3 782 /**
AnnaBridge 189:f392fc9709a3 783 * @brief Check whether the RTC WakeUp Timer associated Exti line interrupt flag is set or not.
AnnaBridge 189:f392fc9709a3 784 * @retval Line Status.
AnnaBridge 189:f392fc9709a3 785 */
AnnaBridge 189:f392fc9709a3 786 #define __HAL_RTC_WAKEUPTIMER_EXTI_GET_FLAG() (EXTI->PR1 & RTC_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 189:f392fc9709a3 787
AnnaBridge 189:f392fc9709a3 788 /**
AnnaBridge 189:f392fc9709a3 789 * @brief Clear the RTC WakeUp Timer associated Exti line flag.
AnnaBridge 189:f392fc9709a3 790 * @retval None
AnnaBridge 189:f392fc9709a3 791 */
AnnaBridge 189:f392fc9709a3 792 #define __HAL_RTC_WAKEUPTIMER_EXTI_CLEAR_FLAG() (EXTI->PR1 = RTC_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 189:f392fc9709a3 793
AnnaBridge 189:f392fc9709a3 794 /**
AnnaBridge 189:f392fc9709a3 795 * @brief Generate a Software interrupt on the RTC WakeUp Timer associated Exti line.
AnnaBridge 189:f392fc9709a3 796 * @retval None
AnnaBridge 189:f392fc9709a3 797 */
AnnaBridge 189:f392fc9709a3 798 #define __HAL_RTC_WAKEUPTIMER_EXTI_GENERATE_SWIT() (EXTI->SWIER1 |= RTC_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 189:f392fc9709a3 799
AnnaBridge 189:f392fc9709a3 800 /**
AnnaBridge 189:f392fc9709a3 801 * @brief Enable interrupt on the RTC Tamper and Timestamp associated Exti line.
AnnaBridge 189:f392fc9709a3 802 * @retval None
AnnaBridge 189:f392fc9709a3 803 */
AnnaBridge 189:f392fc9709a3 804 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_IT() (EXTI->IMR1 |= RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT)
AnnaBridge 189:f392fc9709a3 805
AnnaBridge 189:f392fc9709a3 806 /**
AnnaBridge 189:f392fc9709a3 807 * @brief Disable interrupt on the RTC Tamper and Timestamp associated Exti line.
AnnaBridge 189:f392fc9709a3 808 * @retval None
AnnaBridge 189:f392fc9709a3 809 */
AnnaBridge 189:f392fc9709a3 810 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_IT() (EXTI->IMR1 &= ~(RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT))
AnnaBridge 189:f392fc9709a3 811
AnnaBridge 189:f392fc9709a3 812 /**
AnnaBridge 189:f392fc9709a3 813 * @brief Enable event on the RTC Tamper and Timestamp associated Exti line.
AnnaBridge 189:f392fc9709a3 814 * @retval None
AnnaBridge 189:f392fc9709a3 815 */
AnnaBridge 189:f392fc9709a3 816 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_EVENT() (EXTI->EMR1 |= RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT)
AnnaBridge 189:f392fc9709a3 817
AnnaBridge 189:f392fc9709a3 818 /**
AnnaBridge 189:f392fc9709a3 819 * @brief Disable event on the RTC Tamper and Timestamp associated Exti line.
AnnaBridge 189:f392fc9709a3 820 * @retval None
AnnaBridge 189:f392fc9709a3 821 */
AnnaBridge 189:f392fc9709a3 822 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_EVENT() (EXTI->EMR1 &= ~(RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT))
AnnaBridge 189:f392fc9709a3 823
AnnaBridge 189:f392fc9709a3 824 /**
AnnaBridge 189:f392fc9709a3 825 * @brief Enable falling edge trigger on the RTC Tamper and Timestamp associated Exti line.
AnnaBridge 189:f392fc9709a3 826 * @retval None
AnnaBridge 189:f392fc9709a3 827 */
AnnaBridge 189:f392fc9709a3 828 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_FALLING_EDGE() (EXTI->FTSR1 |= RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT)
AnnaBridge 189:f392fc9709a3 829
AnnaBridge 189:f392fc9709a3 830 /**
AnnaBridge 189:f392fc9709a3 831 * @brief Disable falling edge trigger on the RTC Tamper and Timestamp associated Exti line.
AnnaBridge 189:f392fc9709a3 832 * @retval None
AnnaBridge 189:f392fc9709a3 833 */
AnnaBridge 189:f392fc9709a3 834 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_FALLING_EDGE() (EXTI->FTSR1 &= ~(RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT))
AnnaBridge 189:f392fc9709a3 835
AnnaBridge 189:f392fc9709a3 836 /**
AnnaBridge 189:f392fc9709a3 837 * @brief Enable rising edge trigger on the RTC Tamper and Timestamp associated Exti line.
AnnaBridge 189:f392fc9709a3 838 * @retval None
AnnaBridge 189:f392fc9709a3 839 */
AnnaBridge 189:f392fc9709a3 840 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_RISING_EDGE() (EXTI->RTSR1 |= RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT)
AnnaBridge 189:f392fc9709a3 841
AnnaBridge 189:f392fc9709a3 842 /**
AnnaBridge 189:f392fc9709a3 843 * @brief Disable rising edge trigger on the RTC Tamper and Timestamp associated Exti line.
AnnaBridge 189:f392fc9709a3 844 * @retval None
AnnaBridge 189:f392fc9709a3 845 */
AnnaBridge 189:f392fc9709a3 846 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_RISING_EDGE() (EXTI->RTSR1 &= ~(RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT))
AnnaBridge 189:f392fc9709a3 847
AnnaBridge 189:f392fc9709a3 848 /**
AnnaBridge 189:f392fc9709a3 849 * @brief Enable rising & falling edge trigger on the RTC Tamper and Timestamp associated Exti line.
AnnaBridge 189:f392fc9709a3 850 * @retval None
AnnaBridge 189:f392fc9709a3 851 */
AnnaBridge 189:f392fc9709a3 852 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_RISING_FALLING_EDGE() do { \
AnnaBridge 189:f392fc9709a3 853 __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_RISING_EDGE(); \
AnnaBridge 189:f392fc9709a3 854 __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_FALLING_EDGE(); \
AnnaBridge 189:f392fc9709a3 855 } while(0)
AnnaBridge 189:f392fc9709a3 856
AnnaBridge 189:f392fc9709a3 857 /**
AnnaBridge 189:f392fc9709a3 858 * @brief Disable rising & falling edge trigger on the RTC Tamper and Timestamp associated Exti line.
AnnaBridge 189:f392fc9709a3 859 * This parameter can be:
AnnaBridge 189:f392fc9709a3 860 * @retval None
AnnaBridge 189:f392fc9709a3 861 */
AnnaBridge 189:f392fc9709a3 862 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_RISING_FALLING_EDGE() do { \
AnnaBridge 189:f392fc9709a3 863 __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_RISING_EDGE(); \
AnnaBridge 189:f392fc9709a3 864 __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_FALLING_EDGE(); \
AnnaBridge 189:f392fc9709a3 865 } while(0)
AnnaBridge 189:f392fc9709a3 866
AnnaBridge 189:f392fc9709a3 867 /**
AnnaBridge 189:f392fc9709a3 868 * @brief Check whether the RTC Tamper and Timestamp associated Exti line interrupt flag is set or not.
AnnaBridge 189:f392fc9709a3 869 * @retval Line Status.
AnnaBridge 189:f392fc9709a3 870 */
AnnaBridge 189:f392fc9709a3 871 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_GET_FLAG() (EXTI->PR1 & RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT)
AnnaBridge 189:f392fc9709a3 872
AnnaBridge 189:f392fc9709a3 873 /**
AnnaBridge 189:f392fc9709a3 874 * @brief Clear the RTC Tamper and Timestamp associated Exti line flag.
AnnaBridge 189:f392fc9709a3 875 * @retval None
AnnaBridge 189:f392fc9709a3 876 */
AnnaBridge 189:f392fc9709a3 877 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_CLEAR_FLAG() (EXTI->PR1 = RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT)
AnnaBridge 189:f392fc9709a3 878
AnnaBridge 189:f392fc9709a3 879 /**
AnnaBridge 189:f392fc9709a3 880 * @brief Generate a Software interrupt on the RTC Tamper and Timestamp associated Exti line
AnnaBridge 189:f392fc9709a3 881 * @retval None
AnnaBridge 189:f392fc9709a3 882 */
AnnaBridge 189:f392fc9709a3 883 #define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_GENERATE_SWIT() (EXTI->SWIER1 |= RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT)
AnnaBridge 189:f392fc9709a3 884
AnnaBridge 189:f392fc9709a3 885 /**
AnnaBridge 189:f392fc9709a3 886 * @}
AnnaBridge 189:f392fc9709a3 887 */
AnnaBridge 189:f392fc9709a3 888
AnnaBridge 189:f392fc9709a3 889 /* Exported functions --------------------------------------------------------*/
AnnaBridge 189:f392fc9709a3 890 /** @addtogroup RTCEx_Exported_Functions
AnnaBridge 189:f392fc9709a3 891 * @{
AnnaBridge 189:f392fc9709a3 892 */
AnnaBridge 189:f392fc9709a3 893
AnnaBridge 189:f392fc9709a3 894 /* RTC TimeStamp and Tamper functions *****************************************/
AnnaBridge 189:f392fc9709a3 895 /** @addtogroup RTCEx_Exported_Functions_Group1
AnnaBridge 189:f392fc9709a3 896 * @{
AnnaBridge 189:f392fc9709a3 897 */
AnnaBridge 189:f392fc9709a3 898 HAL_StatusTypeDef HAL_RTCEx_SetTimeStamp(RTC_HandleTypeDef *hrtc, uint32_t TimeStampEdge, uint32_t RTC_TimeStampPin);
AnnaBridge 189:f392fc9709a3 899 HAL_StatusTypeDef HAL_RTCEx_SetTimeStamp_IT(RTC_HandleTypeDef *hrtc, uint32_t TimeStampEdge, uint32_t RTC_TimeStampPin);
AnnaBridge 189:f392fc9709a3 900 HAL_StatusTypeDef HAL_RTCEx_DeactivateTimeStamp(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 901 HAL_StatusTypeDef HAL_RTCEx_SetInternalTimeStamp(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 902 HAL_StatusTypeDef HAL_RTCEx_DeactivateInternalTimeStamp(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 903 HAL_StatusTypeDef HAL_RTCEx_GetTimeStamp(RTC_HandleTypeDef *hrtc, RTC_TimeTypeDef *sTimeStamp, RTC_DateTypeDef *sTimeStampDate, uint32_t Format);
AnnaBridge 189:f392fc9709a3 904
AnnaBridge 189:f392fc9709a3 905 HAL_StatusTypeDef HAL_RTCEx_SetTamper(RTC_HandleTypeDef *hrtc, RTC_TamperTypeDef* sTamper);
AnnaBridge 189:f392fc9709a3 906 HAL_StatusTypeDef HAL_RTCEx_SetTamper_IT(RTC_HandleTypeDef *hrtc, RTC_TamperTypeDef* sTamper);
AnnaBridge 189:f392fc9709a3 907 HAL_StatusTypeDef HAL_RTCEx_DeactivateTamper(RTC_HandleTypeDef *hrtc, uint32_t Tamper);
AnnaBridge 189:f392fc9709a3 908 void HAL_RTCEx_TamperTimeStampIRQHandler(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 909
AnnaBridge 189:f392fc9709a3 910 #if defined(RTC_TAMPER1_SUPPORT)
AnnaBridge 189:f392fc9709a3 911 void HAL_RTCEx_Tamper1EventCallback(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 912 #endif /* RTC_TAMPER1_SUPPORT */
AnnaBridge 189:f392fc9709a3 913 void HAL_RTCEx_Tamper2EventCallback(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 914 #if defined(RTC_TAMPER3_SUPPORT)
AnnaBridge 189:f392fc9709a3 915 void HAL_RTCEx_Tamper3EventCallback(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 916 #endif /* RTC_TAMPER3_SUPPORT */
AnnaBridge 189:f392fc9709a3 917 void HAL_RTCEx_TimeStampEventCallback(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 918 HAL_StatusTypeDef HAL_RTCEx_PollForTimeStampEvent(RTC_HandleTypeDef *hrtc, uint32_t Timeout);
AnnaBridge 189:f392fc9709a3 919 #if defined(RTC_TAMPER1_SUPPORT)
AnnaBridge 189:f392fc9709a3 920 HAL_StatusTypeDef HAL_RTCEx_PollForTamper1Event(RTC_HandleTypeDef *hrtc, uint32_t Timeout);
AnnaBridge 189:f392fc9709a3 921 #endif /* RTC_TAMPER1_SUPPORT */
AnnaBridge 189:f392fc9709a3 922 HAL_StatusTypeDef HAL_RTCEx_PollForTamper2Event(RTC_HandleTypeDef *hrtc, uint32_t Timeout);
AnnaBridge 189:f392fc9709a3 923 #if defined(RTC_TAMPER3_SUPPORT)
AnnaBridge 189:f392fc9709a3 924 HAL_StatusTypeDef HAL_RTCEx_PollForTamper3Event(RTC_HandleTypeDef *hrtc, uint32_t Timeout);
AnnaBridge 189:f392fc9709a3 925 #endif /* RTC_TAMPER3_SUPPORT */
AnnaBridge 189:f392fc9709a3 926 /**
AnnaBridge 189:f392fc9709a3 927 * @}
AnnaBridge 189:f392fc9709a3 928 */
AnnaBridge 189:f392fc9709a3 929
AnnaBridge 189:f392fc9709a3 930 /* RTC Wake-up functions ******************************************************/
AnnaBridge 189:f392fc9709a3 931 /** @addtogroup RTCEx_Exported_Functions_Group2
AnnaBridge 189:f392fc9709a3 932 * @{
AnnaBridge 189:f392fc9709a3 933 */
AnnaBridge 189:f392fc9709a3 934 HAL_StatusTypeDef HAL_RTCEx_SetWakeUpTimer(RTC_HandleTypeDef *hrtc, uint32_t WakeUpCounter, uint32_t WakeUpClock);
AnnaBridge 189:f392fc9709a3 935 HAL_StatusTypeDef HAL_RTCEx_SetWakeUpTimer_IT(RTC_HandleTypeDef *hrtc, uint32_t WakeUpCounter, uint32_t WakeUpClock);
AnnaBridge 189:f392fc9709a3 936 uint32_t HAL_RTCEx_DeactivateWakeUpTimer(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 937 uint32_t HAL_RTCEx_GetWakeUpTimer(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 938 void HAL_RTCEx_WakeUpTimerIRQHandler(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 939 void HAL_RTCEx_WakeUpTimerEventCallback(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 940 HAL_StatusTypeDef HAL_RTCEx_PollForWakeUpTimerEvent(RTC_HandleTypeDef *hrtc, uint32_t Timeout);
AnnaBridge 189:f392fc9709a3 941 /**
AnnaBridge 189:f392fc9709a3 942 * @}
AnnaBridge 189:f392fc9709a3 943 */
AnnaBridge 189:f392fc9709a3 944
AnnaBridge 189:f392fc9709a3 945 /* Extended Control functions ************************************************/
AnnaBridge 189:f392fc9709a3 946 /** @addtogroup RTCEx_Exported_Functions_Group3
AnnaBridge 189:f392fc9709a3 947 * @{
AnnaBridge 189:f392fc9709a3 948 */
AnnaBridge 189:f392fc9709a3 949 void HAL_RTCEx_BKUPWrite(RTC_HandleTypeDef *hrtc, uint32_t BackupRegister, uint32_t Data);
AnnaBridge 189:f392fc9709a3 950 uint32_t HAL_RTCEx_BKUPRead(RTC_HandleTypeDef *hrtc, uint32_t BackupRegister);
AnnaBridge 189:f392fc9709a3 951
AnnaBridge 189:f392fc9709a3 952 HAL_StatusTypeDef HAL_RTCEx_SetSmoothCalib(RTC_HandleTypeDef *hrtc, uint32_t SmoothCalibPeriod, uint32_t SmoothCalibPlusPulses, uint32_t SmoothCalibMinusPulsesValue);
AnnaBridge 189:f392fc9709a3 953 HAL_StatusTypeDef HAL_RTCEx_SetSynchroShift(RTC_HandleTypeDef *hrtc, uint32_t ShiftAdd1S, uint32_t ShiftSubFS);
AnnaBridge 189:f392fc9709a3 954 HAL_StatusTypeDef HAL_RTCEx_SetCalibrationOutPut(RTC_HandleTypeDef *hrtc, uint32_t CalibOutput);
AnnaBridge 189:f392fc9709a3 955 HAL_StatusTypeDef HAL_RTCEx_DeactivateCalibrationOutPut(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 956 HAL_StatusTypeDef HAL_RTCEx_SetRefClock(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 957 HAL_StatusTypeDef HAL_RTCEx_DeactivateRefClock(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 958 HAL_StatusTypeDef HAL_RTCEx_EnableBypassShadow(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 959 HAL_StatusTypeDef HAL_RTCEx_DisableBypassShadow(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 960 /**
AnnaBridge 189:f392fc9709a3 961 * @}
AnnaBridge 189:f392fc9709a3 962 */
AnnaBridge 189:f392fc9709a3 963
AnnaBridge 189:f392fc9709a3 964 /* Extended RTC features functions *******************************************/
AnnaBridge 189:f392fc9709a3 965 /** @addtogroup RTCEx_Exported_Functions_Group4
AnnaBridge 189:f392fc9709a3 966 * @{
AnnaBridge 189:f392fc9709a3 967 */
AnnaBridge 189:f392fc9709a3 968 void HAL_RTCEx_AlarmBEventCallback(RTC_HandleTypeDef *hrtc);
AnnaBridge 189:f392fc9709a3 969 HAL_StatusTypeDef HAL_RTCEx_PollForAlarmBEvent(RTC_HandleTypeDef *hrtc, uint32_t Timeout);
AnnaBridge 189:f392fc9709a3 970 /**
AnnaBridge 189:f392fc9709a3 971 * @}
AnnaBridge 189:f392fc9709a3 972 */
AnnaBridge 189:f392fc9709a3 973
AnnaBridge 189:f392fc9709a3 974 /**
AnnaBridge 189:f392fc9709a3 975 * @}
AnnaBridge 189:f392fc9709a3 976 */
AnnaBridge 189:f392fc9709a3 977
AnnaBridge 189:f392fc9709a3 978 /* Private types -------------------------------------------------------------*/
AnnaBridge 189:f392fc9709a3 979 /* Private variables ---------------------------------------------------------*/
AnnaBridge 189:f392fc9709a3 980 /* Private constants ---------------------------------------------------------*/
AnnaBridge 189:f392fc9709a3 981 /** @defgroup RTCEx_Private_Constants RTCEx Private Constants
AnnaBridge 189:f392fc9709a3 982 * @{
AnnaBridge 189:f392fc9709a3 983 */
AnnaBridge 189:f392fc9709a3 984 #define RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT ((uint32_t)0x00080000) /*!< External interrupt line 19 Connected to the RTC Tamper and Time Stamp events */
AnnaBridge 189:f392fc9709a3 985 #define RTC_EXTI_LINE_WAKEUPTIMER_EVENT ((uint32_t)0x00100000) /*!< External interrupt line 20 Connected to the RTC Wakeup event */
AnnaBridge 189:f392fc9709a3 986
AnnaBridge 189:f392fc9709a3 987 /**
AnnaBridge 189:f392fc9709a3 988 * @}
AnnaBridge 189:f392fc9709a3 989 */
AnnaBridge 189:f392fc9709a3 990
AnnaBridge 189:f392fc9709a3 991 /* Private macros ------------------------------------------------------------*/
AnnaBridge 189:f392fc9709a3 992 /** @defgroup RTCEx_Private_Macros RTCEx Private Macros
AnnaBridge 189:f392fc9709a3 993 * @{
AnnaBridge 189:f392fc9709a3 994 */
AnnaBridge 189:f392fc9709a3 995
AnnaBridge 189:f392fc9709a3 996 /** @defgroup RTCEx_IS_RTC_Definitions Private macros to check input parameters
AnnaBridge 189:f392fc9709a3 997 * @{
AnnaBridge 189:f392fc9709a3 998 */
AnnaBridge 189:f392fc9709a3 999
AnnaBridge 189:f392fc9709a3 1000 #define IS_RTC_OUTPUT(OUTPUT) (((OUTPUT) == RTC_OUTPUT_DISABLE) || \
AnnaBridge 189:f392fc9709a3 1001 ((OUTPUT) == RTC_OUTPUT_ALARMA) || \
AnnaBridge 189:f392fc9709a3 1002 ((OUTPUT) == RTC_OUTPUT_ALARMB) || \
AnnaBridge 189:f392fc9709a3 1003 ((OUTPUT) == RTC_OUTPUT_WAKEUP))
AnnaBridge 189:f392fc9709a3 1004
AnnaBridge 189:f392fc9709a3 1005 #define IS_RTC_BKP(BKP) ((BKP) < (uint32_t) RTC_BKP_NUMBER)
AnnaBridge 189:f392fc9709a3 1006
AnnaBridge 189:f392fc9709a3 1007 #define IS_TIMESTAMP_EDGE(EDGE) (((EDGE) == RTC_TIMESTAMPEDGE_RISING) || \
AnnaBridge 189:f392fc9709a3 1008 ((EDGE) == RTC_TIMESTAMPEDGE_FALLING))
AnnaBridge 189:f392fc9709a3 1009
AnnaBridge 189:f392fc9709a3 1010 #define IS_RTC_TAMPER(TAMPER) ((((TAMPER) & (uint32_t)0xFFFFFFD6) == 0x00) && ((TAMPER) != (uint32_t)RESET))
AnnaBridge 189:f392fc9709a3 1011
AnnaBridge 189:f392fc9709a3 1012 #define IS_RTC_TAMPER_INTERRUPT(INTERRUPT) ((((INTERRUPT) & (uint32_t)0xFFB6FFFB) == 0x00) && ((INTERRUPT) != (uint32_t)RESET))
AnnaBridge 189:f392fc9709a3 1013
AnnaBridge 189:f392fc9709a3 1014 #define IS_RTC_TIMESTAMP_PIN(PIN) (((PIN) == RTC_TIMESTAMPPIN_DEFAULT))
AnnaBridge 189:f392fc9709a3 1015
AnnaBridge 189:f392fc9709a3 1016 #define IS_RTC_TAMPER_TRIGGER(TRIGGER) (((TRIGGER) == RTC_TAMPERTRIGGER_RISINGEDGE) || \
AnnaBridge 189:f392fc9709a3 1017 ((TRIGGER) == RTC_TAMPERTRIGGER_FALLINGEDGE) || \
AnnaBridge 189:f392fc9709a3 1018 ((TRIGGER) == RTC_TAMPERTRIGGER_LOWLEVEL) || \
AnnaBridge 189:f392fc9709a3 1019 ((TRIGGER) == RTC_TAMPERTRIGGER_HIGHLEVEL))
AnnaBridge 189:f392fc9709a3 1020
AnnaBridge 189:f392fc9709a3 1021 #define IS_RTC_TAMPER_ERASE_MODE(MODE) (((MODE) == RTC_TAMPER_ERASE_BACKUP_ENABLE) || \
AnnaBridge 189:f392fc9709a3 1022 ((MODE) == RTC_TAMPER_ERASE_BACKUP_DISABLE))
AnnaBridge 189:f392fc9709a3 1023
AnnaBridge 189:f392fc9709a3 1024 #define IS_RTC_TAMPER_MASKFLAG_STATE(STATE) (((STATE) == RTC_TAMPERMASK_FLAG_ENABLE) || \
AnnaBridge 189:f392fc9709a3 1025 ((STATE) == RTC_TAMPERMASK_FLAG_DISABLE))
AnnaBridge 189:f392fc9709a3 1026
AnnaBridge 189:f392fc9709a3 1027 #define IS_RTC_TAMPER_FILTER(FILTER) (((FILTER) == RTC_TAMPERFILTER_DISABLE) || \
AnnaBridge 189:f392fc9709a3 1028 ((FILTER) == RTC_TAMPERFILTER_2SAMPLE) || \
AnnaBridge 189:f392fc9709a3 1029 ((FILTER) == RTC_TAMPERFILTER_4SAMPLE) || \
AnnaBridge 189:f392fc9709a3 1030 ((FILTER) == RTC_TAMPERFILTER_8SAMPLE))
AnnaBridge 189:f392fc9709a3 1031
AnnaBridge 189:f392fc9709a3 1032 #define IS_RTC_TAMPER_SAMPLING_FREQ(FREQ) (((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV32768)|| \
AnnaBridge 189:f392fc9709a3 1033 ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV16384)|| \
AnnaBridge 189:f392fc9709a3 1034 ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV8192) || \
AnnaBridge 189:f392fc9709a3 1035 ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV4096) || \
AnnaBridge 189:f392fc9709a3 1036 ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV2048) || \
AnnaBridge 189:f392fc9709a3 1037 ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV1024) || \
AnnaBridge 189:f392fc9709a3 1038 ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV512) || \
AnnaBridge 189:f392fc9709a3 1039 ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV256))
AnnaBridge 189:f392fc9709a3 1040
AnnaBridge 189:f392fc9709a3 1041 #define IS_RTC_TAMPER_PRECHARGE_DURATION(DURATION) (((DURATION) == RTC_TAMPERPRECHARGEDURATION_1RTCCLK) || \
AnnaBridge 189:f392fc9709a3 1042 ((DURATION) == RTC_TAMPERPRECHARGEDURATION_2RTCCLK) || \
AnnaBridge 189:f392fc9709a3 1043 ((DURATION) == RTC_TAMPERPRECHARGEDURATION_4RTCCLK) || \
AnnaBridge 189:f392fc9709a3 1044 ((DURATION) == RTC_TAMPERPRECHARGEDURATION_8RTCCLK))
AnnaBridge 189:f392fc9709a3 1045
AnnaBridge 189:f392fc9709a3 1046 #define IS_RTC_TAMPER_TIMESTAMPONTAMPER_DETECTION(DETECTION) (((DETECTION) == RTC_TIMESTAMPONTAMPERDETECTION_ENABLE) || \
AnnaBridge 189:f392fc9709a3 1047 ((DETECTION) == RTC_TIMESTAMPONTAMPERDETECTION_DISABLE))
AnnaBridge 189:f392fc9709a3 1048
AnnaBridge 189:f392fc9709a3 1049 #define IS_RTC_TAMPER_PULLUP_STATE(STATE) (((STATE) == RTC_TAMPER_PULLUP_ENABLE) || \
AnnaBridge 189:f392fc9709a3 1050 ((STATE) == RTC_TAMPER_PULLUP_DISABLE))
AnnaBridge 189:f392fc9709a3 1051
AnnaBridge 189:f392fc9709a3 1052 #define IS_RTC_WAKEUP_CLOCK(CLOCK) (((CLOCK) == RTC_WAKEUPCLOCK_RTCCLK_DIV16) || \
AnnaBridge 189:f392fc9709a3 1053 ((CLOCK) == RTC_WAKEUPCLOCK_RTCCLK_DIV8) || \
AnnaBridge 189:f392fc9709a3 1054 ((CLOCK) == RTC_WAKEUPCLOCK_RTCCLK_DIV4) || \
AnnaBridge 189:f392fc9709a3 1055 ((CLOCK) == RTC_WAKEUPCLOCK_RTCCLK_DIV2) || \
AnnaBridge 189:f392fc9709a3 1056 ((CLOCK) == RTC_WAKEUPCLOCK_CK_SPRE_16BITS) || \
AnnaBridge 189:f392fc9709a3 1057 ((CLOCK) == RTC_WAKEUPCLOCK_CK_SPRE_17BITS))
AnnaBridge 189:f392fc9709a3 1058
AnnaBridge 189:f392fc9709a3 1059 #define IS_RTC_WAKEUP_COUNTER(COUNTER) ((COUNTER) <= 0xFFFF)
AnnaBridge 189:f392fc9709a3 1060
AnnaBridge 189:f392fc9709a3 1061 #define IS_RTC_SMOOTH_CALIB_PERIOD(PERIOD) (((PERIOD) == RTC_SMOOTHCALIB_PERIOD_32SEC) || \
AnnaBridge 189:f392fc9709a3 1062 ((PERIOD) == RTC_SMOOTHCALIB_PERIOD_16SEC) || \
AnnaBridge 189:f392fc9709a3 1063 ((PERIOD) == RTC_SMOOTHCALIB_PERIOD_8SEC))
AnnaBridge 189:f392fc9709a3 1064
AnnaBridge 189:f392fc9709a3 1065 #define IS_RTC_SMOOTH_CALIB_PLUS(PLUS) (((PLUS) == RTC_SMOOTHCALIB_PLUSPULSES_SET) || \
AnnaBridge 189:f392fc9709a3 1066 ((PLUS) == RTC_SMOOTHCALIB_PLUSPULSES_RESET))
AnnaBridge 189:f392fc9709a3 1067
AnnaBridge 189:f392fc9709a3 1068 #define IS_RTC_SMOOTH_CALIB_MINUS(VALUE) ((VALUE) <= 0x000001FF)
AnnaBridge 189:f392fc9709a3 1069
AnnaBridge 189:f392fc9709a3 1070 #define IS_RTC_SHIFT_ADD1S(SEL) (((SEL) == RTC_SHIFTADD1S_RESET) || \
AnnaBridge 189:f392fc9709a3 1071 ((SEL) == RTC_SHIFTADD1S_SET))
AnnaBridge 189:f392fc9709a3 1072
AnnaBridge 189:f392fc9709a3 1073 #define IS_RTC_SHIFT_SUBFS(FS) ((FS) <= 0x00007FFF)
AnnaBridge 189:f392fc9709a3 1074
AnnaBridge 189:f392fc9709a3 1075 #define IS_RTC_CALIB_OUTPUT(OUTPUT) (((OUTPUT) == RTC_CALIBOUTPUT_512HZ) || \
AnnaBridge 189:f392fc9709a3 1076 ((OUTPUT) == RTC_CALIBOUTPUT_1HZ))
AnnaBridge 189:f392fc9709a3 1077
AnnaBridge 189:f392fc9709a3 1078 /**
AnnaBridge 189:f392fc9709a3 1079 * @}
AnnaBridge 189:f392fc9709a3 1080 */
AnnaBridge 189:f392fc9709a3 1081
AnnaBridge 189:f392fc9709a3 1082 /**
AnnaBridge 189:f392fc9709a3 1083 * @}
AnnaBridge 189:f392fc9709a3 1084 */
AnnaBridge 189:f392fc9709a3 1085
AnnaBridge 189:f392fc9709a3 1086 /**
AnnaBridge 189:f392fc9709a3 1087 * @}
AnnaBridge 189:f392fc9709a3 1088 */
AnnaBridge 189:f392fc9709a3 1089
AnnaBridge 189:f392fc9709a3 1090 /**
AnnaBridge 189:f392fc9709a3 1091 * @}
AnnaBridge 189:f392fc9709a3 1092 */
AnnaBridge 189:f392fc9709a3 1093
AnnaBridge 189:f392fc9709a3 1094 #ifdef __cplusplus
AnnaBridge 189:f392fc9709a3 1095 }
AnnaBridge 189:f392fc9709a3 1096 #endif
AnnaBridge 189:f392fc9709a3 1097
AnnaBridge 189:f392fc9709a3 1098 #endif /* __STM32L4xx_HAL_RTC_EX_H */
AnnaBridge 189:f392fc9709a3 1099
AnnaBridge 189:f392fc9709a3 1100 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/