训练营PLSR题目
Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.
 
 
 
 
 
 

839 wiersze
29 KiB

  1. /**
  2. ******************************************************************************
  3. * @file stm32f4xx_ll_rtc.c
  4. * @author MCD Application Team
  5. * @brief RTC LL module driver.
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * Copyright (c) 2017 STMicroelectronics.
  10. * All rights reserved.
  11. *
  12. * This software is licensed under terms that can be found in the LICENSE file
  13. * in the root directory of this software component.
  14. * If no LICENSE file comes with this software, it is provided AS-IS.
  15. *
  16. ******************************************************************************
  17. */
  18. #if defined(USE_FULL_LL_DRIVER)
  19. /* Includes ------------------------------------------------------------------*/
  20. #include "stm32f4xx_ll_rtc.h"
  21. #include "stm32f4xx_ll_cortex.h"
  22. #ifdef USE_FULL_ASSERT
  23. #include "stm32_assert.h"
  24. #else
  25. #define assert_param(expr) ((void)0U)
  26. #endif
  27. /** @addtogroup STM32F4xx_LL_Driver
  28. * @{
  29. */
  30. #if defined(RTC)
  31. /** @addtogroup RTC_LL
  32. * @{
  33. */
  34. /* Private types -------------------------------------------------------------*/
  35. /* Private variables ---------------------------------------------------------*/
  36. /* Private constants ---------------------------------------------------------*/
  37. /** @addtogroup RTC_LL_Private_Constants
  38. * @{
  39. */
  40. /* Default values used for prescaler */
  41. #define RTC_ASYNCH_PRESC_DEFAULT 0x0000007FU
  42. #define RTC_SYNCH_PRESC_DEFAULT 0x000000FFU
  43. /* Values used for timeout */
  44. #define RTC_INITMODE_TIMEOUT 1000U /* 1s when tick set to 1ms */
  45. #define RTC_SYNCHRO_TIMEOUT 1000U /* 1s when tick set to 1ms */
  46. /**
  47. * @}
  48. */
  49. /* Private macros ------------------------------------------------------------*/
  50. /** @addtogroup RTC_LL_Private_Macros
  51. * @{
  52. */
  53. #define IS_LL_RTC_HOURFORMAT(__VALUE__) (((__VALUE__) == LL_RTC_HOURFORMAT_24HOUR) \
  54. || ((__VALUE__) == LL_RTC_HOURFORMAT_AMPM))
  55. #define IS_LL_RTC_ASYNCH_PREDIV(__VALUE__) ((__VALUE__) <= 0x7FU)
  56. #define IS_LL_RTC_SYNCH_PREDIV(__VALUE__) ((__VALUE__) <= 0x7FFFU)
  57. #define IS_LL_RTC_FORMAT(__VALUE__) (((__VALUE__) == LL_RTC_FORMAT_BIN) \
  58. || ((__VALUE__) == LL_RTC_FORMAT_BCD))
  59. #define IS_LL_RTC_TIME_FORMAT(__VALUE__) (((__VALUE__) == LL_RTC_TIME_FORMAT_AM_OR_24) \
  60. || ((__VALUE__) == LL_RTC_TIME_FORMAT_PM))
  61. #define IS_LL_RTC_HOUR12(__HOUR__) (((__HOUR__) > 0U) && ((__HOUR__) <= 12U))
  62. #define IS_LL_RTC_HOUR24(__HOUR__) ((__HOUR__) <= 23U)
  63. #define IS_LL_RTC_MINUTES(__MINUTES__) ((__MINUTES__) <= 59U)
  64. #define IS_LL_RTC_SECONDS(__SECONDS__) ((__SECONDS__) <= 59U)
  65. #define IS_LL_RTC_WEEKDAY(__VALUE__) (((__VALUE__) == LL_RTC_WEEKDAY_MONDAY) \
  66. || ((__VALUE__) == LL_RTC_WEEKDAY_TUESDAY) \
  67. || ((__VALUE__) == LL_RTC_WEEKDAY_WEDNESDAY) \
  68. || ((__VALUE__) == LL_RTC_WEEKDAY_THURSDAY) \
  69. || ((__VALUE__) == LL_RTC_WEEKDAY_FRIDAY) \
  70. || ((__VALUE__) == LL_RTC_WEEKDAY_SATURDAY) \
  71. || ((__VALUE__) == LL_RTC_WEEKDAY_SUNDAY))
  72. #define IS_LL_RTC_DAY(__DAY__) (((__DAY__) >= 1U) && ((__DAY__) <= 31U))
  73. #define IS_LL_RTC_MONTH(__MONTH__) (((__MONTH__) >= 1U) && ((__MONTH__) <= 12U))
  74. #define IS_LL_RTC_YEAR(__YEAR__) ((__YEAR__) <= 99U)
  75. #define IS_LL_RTC_ALMA_MASK(__VALUE__) (((__VALUE__) == LL_RTC_ALMA_MASK_NONE) \
  76. || ((__VALUE__) == LL_RTC_ALMA_MASK_DATEWEEKDAY) \
  77. || ((__VALUE__) == LL_RTC_ALMA_MASK_HOURS) \
  78. || ((__VALUE__) == LL_RTC_ALMA_MASK_MINUTES) \
  79. || ((__VALUE__) == LL_RTC_ALMA_MASK_SECONDS) \
  80. || ((__VALUE__) == LL_RTC_ALMA_MASK_ALL))
  81. #define IS_LL_RTC_ALMB_MASK(__VALUE__) (((__VALUE__) == LL_RTC_ALMB_MASK_NONE) \
  82. || ((__VALUE__) == LL_RTC_ALMB_MASK_DATEWEEKDAY) \
  83. || ((__VALUE__) == LL_RTC_ALMB_MASK_HOURS) \
  84. || ((__VALUE__) == LL_RTC_ALMB_MASK_MINUTES) \
  85. || ((__VALUE__) == LL_RTC_ALMB_MASK_SECONDS) \
  86. || ((__VALUE__) == LL_RTC_ALMB_MASK_ALL))
  87. #define IS_LL_RTC_ALMA_DATE_WEEKDAY_SEL(__SEL__) (((__SEL__) == LL_RTC_ALMA_DATEWEEKDAYSEL_DATE) || \
  88. ((__SEL__) == LL_RTC_ALMA_DATEWEEKDAYSEL_WEEKDAY))
  89. #define IS_LL_RTC_ALMB_DATE_WEEKDAY_SEL(__SEL__) (((__SEL__) == LL_RTC_ALMB_DATEWEEKDAYSEL_DATE) || \
  90. ((__SEL__) == LL_RTC_ALMB_DATEWEEKDAYSEL_WEEKDAY))
  91. /**
  92. * @}
  93. */
  94. /* Private function prototypes -----------------------------------------------*/
  95. /* Exported functions --------------------------------------------------------*/
  96. /** @addtogroup RTC_LL_Exported_Functions
  97. * @{
  98. */
  99. /** @addtogroup RTC_LL_EF_Init
  100. * @{
  101. */
  102. /**
  103. * @brief De-Initializes the RTC registers to their default reset values.
  104. * @note This function does not reset the RTC Clock source and RTC Backup Data
  105. * registers.
  106. * @param RTCx RTC Instance
  107. * @retval An ErrorStatus enumeration value:
  108. * - SUCCESS: RTC registers are de-initialized
  109. * - ERROR: RTC registers are not de-initialized
  110. */
  111. ErrorStatus LL_RTC_DeInit(RTC_TypeDef *RTCx)
  112. {
  113. ErrorStatus status = ERROR;
  114. /* Check the parameter */
  115. assert_param(IS_RTC_ALL_INSTANCE(RTCx));
  116. /* Disable the write protection for RTC registers */
  117. LL_RTC_DisableWriteProtection(RTCx);
  118. /* Set Initialization mode */
  119. if (LL_RTC_EnterInitMode(RTCx) != ERROR)
  120. {
  121. /* Reset TR, DR and CR registers */
  122. LL_RTC_WriteReg(RTCx, TR, 0x00000000U);
  123. LL_RTC_WriteReg(RTCx, WUTR, RTC_WUTR_WUT);
  124. LL_RTC_WriteReg(RTCx, DR, (RTC_DR_WDU_0 | RTC_DR_MU_0 | RTC_DR_DU_0));
  125. /* Reset All CR bits except CR[2:0] */
  126. LL_RTC_WriteReg(RTCx, CR, (LL_RTC_ReadReg(RTCx, CR) & RTC_CR_WUCKSEL));
  127. LL_RTC_WriteReg(RTCx, PRER, (RTC_PRER_PREDIV_A | RTC_SYNCH_PRESC_DEFAULT));
  128. LL_RTC_WriteReg(RTCx, ALRMAR, 0x00000000U);
  129. LL_RTC_WriteReg(RTCx, ALRMBR, 0x00000000U);
  130. LL_RTC_WriteReg(RTCx, CALR, 0x00000000U);
  131. LL_RTC_WriteReg(RTCx, SHIFTR, 0x00000000U);
  132. LL_RTC_WriteReg(RTCx, ALRMASSR, 0x00000000U);
  133. LL_RTC_WriteReg(RTCx, ALRMBSSR, 0x00000000U);
  134. /* Reset ISR register and exit initialization mode */
  135. LL_RTC_WriteReg(RTCx, ISR, 0x00000000U);
  136. /* Reset Tamper and alternate functions configuration register */
  137. LL_RTC_WriteReg(RTCx, TAFCR, 0x00000000U);
  138. /* Wait till the RTC RSF flag is set */
  139. status = LL_RTC_WaitForSynchro(RTCx);
  140. }
  141. /* Enable the write protection for RTC registers */
  142. LL_RTC_EnableWriteProtection(RTCx);
  143. return status;
  144. }
  145. /**
  146. * @brief Initializes the RTC registers according to the specified parameters
  147. * in RTC_InitStruct.
  148. * @param RTCx RTC Instance
  149. * @param RTC_InitStruct pointer to a @ref LL_RTC_InitTypeDef structure that contains
  150. * the configuration information for the RTC peripheral.
  151. * @note The RTC Prescaler register is write protected and can be written in
  152. * initialization mode only.
  153. * @retval An ErrorStatus enumeration value:
  154. * - SUCCESS: RTC registers are initialized
  155. * - ERROR: RTC registers are not initialized
  156. */
  157. ErrorStatus LL_RTC_Init(RTC_TypeDef *RTCx, LL_RTC_InitTypeDef *RTC_InitStruct)
  158. {
  159. ErrorStatus status = ERROR;
  160. /* Check the parameters */
  161. assert_param(IS_RTC_ALL_INSTANCE(RTCx));
  162. assert_param(IS_LL_RTC_HOURFORMAT(RTC_InitStruct->HourFormat));
  163. assert_param(IS_LL_RTC_ASYNCH_PREDIV(RTC_InitStruct->AsynchPrescaler));
  164. assert_param(IS_LL_RTC_SYNCH_PREDIV(RTC_InitStruct->SynchPrescaler));
  165. /* Disable the write protection for RTC registers */
  166. LL_RTC_DisableWriteProtection(RTCx);
  167. /* Set Initialization mode */
  168. if (LL_RTC_EnterInitMode(RTCx) != ERROR)
  169. {
  170. /* Set Hour Format */
  171. LL_RTC_SetHourFormat(RTCx, RTC_InitStruct->HourFormat);
  172. /* Configure Synchronous and Asynchronous prescaler factor */
  173. LL_RTC_SetSynchPrescaler(RTCx, RTC_InitStruct->SynchPrescaler);
  174. LL_RTC_SetAsynchPrescaler(RTCx, RTC_InitStruct->AsynchPrescaler);
  175. /* Exit Initialization mode */
  176. LL_RTC_DisableInitMode(RTCx);
  177. status = SUCCESS;
  178. }
  179. /* Enable the write protection for RTC registers */
  180. LL_RTC_EnableWriteProtection(RTCx);
  181. return status;
  182. }
  183. /**
  184. * @brief Set each @ref LL_RTC_InitTypeDef field to default value.
  185. * @param RTC_InitStruct pointer to a @ref LL_RTC_InitTypeDef structure which will be initialized.
  186. * @retval None
  187. */
  188. void LL_RTC_StructInit(LL_RTC_InitTypeDef *RTC_InitStruct)
  189. {
  190. /* Set RTC_InitStruct fields to default values */
  191. RTC_InitStruct->HourFormat = LL_RTC_HOURFORMAT_24HOUR;
  192. RTC_InitStruct->AsynchPrescaler = RTC_ASYNCH_PRESC_DEFAULT;
  193. RTC_InitStruct->SynchPrescaler = RTC_SYNCH_PRESC_DEFAULT;
  194. }
  195. /**
  196. * @brief Set the RTC current time.
  197. * @param RTCx RTC Instance
  198. * @param RTC_Format This parameter can be one of the following values:
  199. * @arg @ref LL_RTC_FORMAT_BIN
  200. * @arg @ref LL_RTC_FORMAT_BCD
  201. * @param RTC_TimeStruct pointer to a RTC_TimeTypeDef structure that contains
  202. * the time configuration information for the RTC.
  203. * @retval An ErrorStatus enumeration value:
  204. * - SUCCESS: RTC Time register is configured
  205. * - ERROR: RTC Time register is not configured
  206. */
  207. ErrorStatus LL_RTC_TIME_Init(RTC_TypeDef *RTCx, uint32_t RTC_Format, LL_RTC_TimeTypeDef *RTC_TimeStruct)
  208. {
  209. ErrorStatus status = ERROR;
  210. /* Check the parameters */
  211. assert_param(IS_RTC_ALL_INSTANCE(RTCx));
  212. assert_param(IS_LL_RTC_FORMAT(RTC_Format));
  213. if (RTC_Format == LL_RTC_FORMAT_BIN)
  214. {
  215. if (LL_RTC_GetHourFormat(RTCx) != LL_RTC_HOURFORMAT_24HOUR)
  216. {
  217. assert_param(IS_LL_RTC_HOUR12(RTC_TimeStruct->Hours));
  218. assert_param(IS_LL_RTC_TIME_FORMAT(RTC_TimeStruct->TimeFormat));
  219. }
  220. else
  221. {
  222. RTC_TimeStruct->TimeFormat = 0x00U;
  223. assert_param(IS_LL_RTC_HOUR24(RTC_TimeStruct->Hours));
  224. }
  225. assert_param(IS_LL_RTC_MINUTES(RTC_TimeStruct->Minutes));
  226. assert_param(IS_LL_RTC_SECONDS(RTC_TimeStruct->Seconds));
  227. }
  228. else
  229. {
  230. if (LL_RTC_GetHourFormat(RTCx) != LL_RTC_HOURFORMAT_24HOUR)
  231. {
  232. assert_param(IS_LL_RTC_HOUR12(__LL_RTC_CONVERT_BCD2BIN(RTC_TimeStruct->Hours)));
  233. assert_param(IS_LL_RTC_TIME_FORMAT(RTC_TimeStruct->TimeFormat));
  234. }
  235. else
  236. {
  237. RTC_TimeStruct->TimeFormat = 0x00U;
  238. assert_param(IS_LL_RTC_HOUR24(__LL_RTC_CONVERT_BCD2BIN(RTC_TimeStruct->Hours)));
  239. }
  240. assert_param(IS_LL_RTC_MINUTES(__LL_RTC_CONVERT_BCD2BIN(RTC_TimeStruct->Minutes)));
  241. assert_param(IS_LL_RTC_SECONDS(__LL_RTC_CONVERT_BCD2BIN(RTC_TimeStruct->Seconds)));
  242. }
  243. /* Disable the write protection for RTC registers */
  244. LL_RTC_DisableWriteProtection(RTCx);
  245. /* Set Initialization mode */
  246. if (LL_RTC_EnterInitMode(RTCx) != ERROR)
  247. {
  248. /* Check the input parameters format */
  249. if (RTC_Format != LL_RTC_FORMAT_BIN)
  250. {
  251. LL_RTC_TIME_Config(RTCx, RTC_TimeStruct->TimeFormat, RTC_TimeStruct->Hours,
  252. RTC_TimeStruct->Minutes, RTC_TimeStruct->Seconds);
  253. }
  254. else
  255. {
  256. LL_RTC_TIME_Config(RTCx, RTC_TimeStruct->TimeFormat, __LL_RTC_CONVERT_BIN2BCD(RTC_TimeStruct->Hours),
  257. __LL_RTC_CONVERT_BIN2BCD(RTC_TimeStruct->Minutes),
  258. __LL_RTC_CONVERT_BIN2BCD(RTC_TimeStruct->Seconds));
  259. }
  260. /* Exit Initialization mode */
  261. LL_RTC_DisableInitMode(RTCx);
  262. /* If RTC_CR_BYPSHAD bit = 0, wait for synchro else this check is not needed */
  263. if (LL_RTC_IsShadowRegBypassEnabled(RTCx) == 0U)
  264. {
  265. status = LL_RTC_WaitForSynchro(RTCx);
  266. }
  267. else
  268. {
  269. status = SUCCESS;
  270. }
  271. }
  272. /* Enable the write protection for RTC registers */
  273. LL_RTC_EnableWriteProtection(RTCx);
  274. return status;
  275. }
  276. /**
  277. * @brief Set each @ref LL_RTC_TimeTypeDef field to default value (Time = 00h:00min:00sec).
  278. * @param RTC_TimeStruct pointer to a @ref LL_RTC_TimeTypeDef structure which will be initialized.
  279. * @retval None
  280. */
  281. void LL_RTC_TIME_StructInit(LL_RTC_TimeTypeDef *RTC_TimeStruct)
  282. {
  283. /* Time = 00h:00min:00sec */
  284. RTC_TimeStruct->TimeFormat = LL_RTC_TIME_FORMAT_AM_OR_24;
  285. RTC_TimeStruct->Hours = 0U;
  286. RTC_TimeStruct->Minutes = 0U;
  287. RTC_TimeStruct->Seconds = 0U;
  288. }
  289. /**
  290. * @brief Set the RTC current date.
  291. * @param RTCx RTC Instance
  292. * @param RTC_Format This parameter can be one of the following values:
  293. * @arg @ref LL_RTC_FORMAT_BIN
  294. * @arg @ref LL_RTC_FORMAT_BCD
  295. * @param RTC_DateStruct pointer to a RTC_DateTypeDef structure that contains
  296. * the date configuration information for the RTC.
  297. * @retval An ErrorStatus enumeration value:
  298. * - SUCCESS: RTC Day register is configured
  299. * - ERROR: RTC Day register is not configured
  300. */
  301. ErrorStatus LL_RTC_DATE_Init(RTC_TypeDef *RTCx, uint32_t RTC_Format, LL_RTC_DateTypeDef *RTC_DateStruct)
  302. {
  303. ErrorStatus status = ERROR;
  304. /* Check the parameters */
  305. assert_param(IS_RTC_ALL_INSTANCE(RTCx));
  306. assert_param(IS_LL_RTC_FORMAT(RTC_Format));
  307. if ((RTC_Format == LL_RTC_FORMAT_BIN) && ((RTC_DateStruct->Month & 0x10U) == 0x10U))
  308. {
  309. RTC_DateStruct->Month = (uint8_t)(RTC_DateStruct->Month & (uint8_t)~(0x10U)) + 0x0AU;
  310. }
  311. if (RTC_Format == LL_RTC_FORMAT_BIN)
  312. {
  313. assert_param(IS_LL_RTC_YEAR(RTC_DateStruct->Year));
  314. assert_param(IS_LL_RTC_MONTH(RTC_DateStruct->Month));
  315. assert_param(IS_LL_RTC_DAY(RTC_DateStruct->Day));
  316. }
  317. else
  318. {
  319. assert_param(IS_LL_RTC_YEAR(__LL_RTC_CONVERT_BCD2BIN(RTC_DateStruct->Year)));
  320. assert_param(IS_LL_RTC_MONTH(__LL_RTC_CONVERT_BCD2BIN(RTC_DateStruct->Month)));
  321. assert_param(IS_LL_RTC_DAY(__LL_RTC_CONVERT_BCD2BIN(RTC_DateStruct->Day)));
  322. }
  323. assert_param(IS_LL_RTC_WEEKDAY(RTC_DateStruct->WeekDay));
  324. /* Disable the write protection for RTC registers */
  325. LL_RTC_DisableWriteProtection(RTCx);
  326. /* Set Initialization mode */
  327. if (LL_RTC_EnterInitMode(RTCx) != ERROR)
  328. {
  329. /* Check the input parameters format */
  330. if (RTC_Format != LL_RTC_FORMAT_BIN)
  331. {
  332. LL_RTC_DATE_Config(RTCx, RTC_DateStruct->WeekDay, RTC_DateStruct->Day, RTC_DateStruct->Month, RTC_DateStruct->Year);
  333. }
  334. else
  335. {
  336. LL_RTC_DATE_Config(RTCx, RTC_DateStruct->WeekDay, __LL_RTC_CONVERT_BIN2BCD(RTC_DateStruct->Day),
  337. __LL_RTC_CONVERT_BIN2BCD(RTC_DateStruct->Month), __LL_RTC_CONVERT_BIN2BCD(RTC_DateStruct->Year));
  338. }
  339. /* Exit Initialization mode */
  340. LL_RTC_DisableInitMode(RTCx);
  341. /* If RTC_CR_BYPSHAD bit = 0, wait for synchro else this check is not needed */
  342. if (LL_RTC_IsShadowRegBypassEnabled(RTCx) == 0U)
  343. {
  344. status = LL_RTC_WaitForSynchro(RTCx);
  345. }
  346. else
  347. {
  348. status = SUCCESS;
  349. }
  350. }
  351. /* Enable the write protection for RTC registers */
  352. LL_RTC_EnableWriteProtection(RTCx);
  353. return status;
  354. }
  355. /**
  356. * @brief Set each @ref LL_RTC_DateTypeDef field to default value (date = Monday, January 01 xx00)
  357. * @param RTC_DateStruct pointer to a @ref LL_RTC_DateTypeDef structure which will be initialized.
  358. * @retval None
  359. */
  360. void LL_RTC_DATE_StructInit(LL_RTC_DateTypeDef *RTC_DateStruct)
  361. {
  362. /* Monday, January 01 xx00 */
  363. RTC_DateStruct->WeekDay = LL_RTC_WEEKDAY_MONDAY;
  364. RTC_DateStruct->Day = 1U;
  365. RTC_DateStruct->Month = LL_RTC_MONTH_JANUARY;
  366. RTC_DateStruct->Year = 0U;
  367. }
  368. /**
  369. * @brief Set the RTC Alarm A.
  370. * @note The Alarm register can only be written when the corresponding Alarm
  371. * is disabled (Use @ref LL_RTC_ALMA_Disable function).
  372. * @param RTCx RTC Instance
  373. * @param RTC_Format This parameter can be one of the following values:
  374. * @arg @ref LL_RTC_FORMAT_BIN
  375. * @arg @ref LL_RTC_FORMAT_BCD
  376. * @param RTC_AlarmStruct pointer to a @ref LL_RTC_AlarmTypeDef structure that
  377. * contains the alarm configuration parameters.
  378. * @retval An ErrorStatus enumeration value:
  379. * - SUCCESS: ALARMA registers are configured
  380. * - ERROR: ALARMA registers are not configured
  381. */
  382. ErrorStatus LL_RTC_ALMA_Init(RTC_TypeDef *RTCx, uint32_t RTC_Format, LL_RTC_AlarmTypeDef *RTC_AlarmStruct)
  383. {
  384. /* Check the parameters */
  385. assert_param(IS_RTC_ALL_INSTANCE(RTCx));
  386. assert_param(IS_LL_RTC_FORMAT(RTC_Format));
  387. assert_param(IS_LL_RTC_ALMA_MASK(RTC_AlarmStruct->AlarmMask));
  388. assert_param(IS_LL_RTC_ALMA_DATE_WEEKDAY_SEL(RTC_AlarmStruct->AlarmDateWeekDaySel));
  389. if (RTC_Format == LL_RTC_FORMAT_BIN)
  390. {
  391. if (LL_RTC_GetHourFormat(RTCx) != LL_RTC_HOURFORMAT_24HOUR)
  392. {
  393. assert_param(IS_LL_RTC_HOUR12(RTC_AlarmStruct->AlarmTime.Hours));
  394. assert_param(IS_LL_RTC_TIME_FORMAT(RTC_AlarmStruct->AlarmTime.TimeFormat));
  395. }
  396. else
  397. {
  398. RTC_AlarmStruct->AlarmTime.TimeFormat = 0x00U;
  399. assert_param(IS_LL_RTC_HOUR24(RTC_AlarmStruct->AlarmTime.Hours));
  400. }
  401. assert_param(IS_LL_RTC_MINUTES(RTC_AlarmStruct->AlarmTime.Minutes));
  402. assert_param(IS_LL_RTC_SECONDS(RTC_AlarmStruct->AlarmTime.Seconds));
  403. if (RTC_AlarmStruct->AlarmDateWeekDaySel == LL_RTC_ALMA_DATEWEEKDAYSEL_DATE)
  404. {
  405. assert_param(IS_LL_RTC_DAY(RTC_AlarmStruct->AlarmDateWeekDay));
  406. }
  407. else
  408. {
  409. assert_param(IS_LL_RTC_WEEKDAY(RTC_AlarmStruct->AlarmDateWeekDay));
  410. }
  411. }
  412. else
  413. {
  414. if (LL_RTC_GetHourFormat(RTCx) != LL_RTC_HOURFORMAT_24HOUR)
  415. {
  416. assert_param(IS_LL_RTC_HOUR12(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmTime.Hours)));
  417. assert_param(IS_LL_RTC_TIME_FORMAT(RTC_AlarmStruct->AlarmTime.TimeFormat));
  418. }
  419. else
  420. {
  421. RTC_AlarmStruct->AlarmTime.TimeFormat = 0x00U;
  422. assert_param(IS_LL_RTC_HOUR24(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmTime.Hours)));
  423. }
  424. assert_param(IS_LL_RTC_MINUTES(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmTime.Minutes)));
  425. assert_param(IS_LL_RTC_SECONDS(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmTime.Seconds)));
  426. if (RTC_AlarmStruct->AlarmDateWeekDaySel == LL_RTC_ALMA_DATEWEEKDAYSEL_DATE)
  427. {
  428. assert_param(IS_LL_RTC_DAY(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmDateWeekDay)));
  429. }
  430. else
  431. {
  432. assert_param(IS_LL_RTC_WEEKDAY(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmDateWeekDay)));
  433. }
  434. }
  435. /* Disable the write protection for RTC registers */
  436. LL_RTC_DisableWriteProtection(RTCx);
  437. /* Select weekday selection */
  438. if (RTC_AlarmStruct->AlarmDateWeekDaySel == LL_RTC_ALMA_DATEWEEKDAYSEL_DATE)
  439. {
  440. /* Set the date for ALARM */
  441. LL_RTC_ALMA_DisableWeekday(RTCx);
  442. if (RTC_Format != LL_RTC_FORMAT_BIN)
  443. {
  444. LL_RTC_ALMA_SetDay(RTCx, RTC_AlarmStruct->AlarmDateWeekDay);
  445. }
  446. else
  447. {
  448. LL_RTC_ALMA_SetDay(RTCx, __LL_RTC_CONVERT_BIN2BCD(RTC_AlarmStruct->AlarmDateWeekDay));
  449. }
  450. }
  451. else
  452. {
  453. /* Set the week day for ALARM */
  454. LL_RTC_ALMA_EnableWeekday(RTCx);
  455. LL_RTC_ALMA_SetWeekDay(RTCx, RTC_AlarmStruct->AlarmDateWeekDay);
  456. }
  457. /* Configure the Alarm register */
  458. if (RTC_Format != LL_RTC_FORMAT_BIN)
  459. {
  460. LL_RTC_ALMA_ConfigTime(RTCx, RTC_AlarmStruct->AlarmTime.TimeFormat, RTC_AlarmStruct->AlarmTime.Hours,
  461. RTC_AlarmStruct->AlarmTime.Minutes, RTC_AlarmStruct->AlarmTime.Seconds);
  462. }
  463. else
  464. {
  465. LL_RTC_ALMA_ConfigTime(RTCx, RTC_AlarmStruct->AlarmTime.TimeFormat,
  466. __LL_RTC_CONVERT_BIN2BCD(RTC_AlarmStruct->AlarmTime.Hours),
  467. __LL_RTC_CONVERT_BIN2BCD(RTC_AlarmStruct->AlarmTime.Minutes),
  468. __LL_RTC_CONVERT_BIN2BCD(RTC_AlarmStruct->AlarmTime.Seconds));
  469. }
  470. /* Set ALARM mask */
  471. LL_RTC_ALMA_SetMask(RTCx, RTC_AlarmStruct->AlarmMask);
  472. /* Enable the write protection for RTC registers */
  473. LL_RTC_EnableWriteProtection(RTCx);
  474. return SUCCESS;
  475. }
  476. /**
  477. * @brief Set the RTC Alarm B.
  478. * @note The Alarm register can only be written when the corresponding Alarm
  479. * is disabled (@ref LL_RTC_ALMB_Disable function).
  480. * @param RTCx RTC Instance
  481. * @param RTC_Format This parameter can be one of the following values:
  482. * @arg @ref LL_RTC_FORMAT_BIN
  483. * @arg @ref LL_RTC_FORMAT_BCD
  484. * @param RTC_AlarmStruct pointer to a @ref LL_RTC_AlarmTypeDef structure that
  485. * contains the alarm configuration parameters.
  486. * @retval An ErrorStatus enumeration value:
  487. * - SUCCESS: ALARMB registers are configured
  488. * - ERROR: ALARMB registers are not configured
  489. */
  490. ErrorStatus LL_RTC_ALMB_Init(RTC_TypeDef *RTCx, uint32_t RTC_Format, LL_RTC_AlarmTypeDef *RTC_AlarmStruct)
  491. {
  492. /* Check the parameters */
  493. assert_param(IS_RTC_ALL_INSTANCE(RTCx));
  494. assert_param(IS_LL_RTC_FORMAT(RTC_Format));
  495. assert_param(IS_LL_RTC_ALMB_MASK(RTC_AlarmStruct->AlarmMask));
  496. assert_param(IS_LL_RTC_ALMB_DATE_WEEKDAY_SEL(RTC_AlarmStruct->AlarmDateWeekDaySel));
  497. if (RTC_Format == LL_RTC_FORMAT_BIN)
  498. {
  499. if (LL_RTC_GetHourFormat(RTCx) != LL_RTC_HOURFORMAT_24HOUR)
  500. {
  501. assert_param(IS_LL_RTC_HOUR12(RTC_AlarmStruct->AlarmTime.Hours));
  502. assert_param(IS_LL_RTC_TIME_FORMAT(RTC_AlarmStruct->AlarmTime.TimeFormat));
  503. }
  504. else
  505. {
  506. RTC_AlarmStruct->AlarmTime.TimeFormat = 0x00U;
  507. assert_param(IS_LL_RTC_HOUR24(RTC_AlarmStruct->AlarmTime.Hours));
  508. }
  509. assert_param(IS_LL_RTC_MINUTES(RTC_AlarmStruct->AlarmTime.Minutes));
  510. assert_param(IS_LL_RTC_SECONDS(RTC_AlarmStruct->AlarmTime.Seconds));
  511. if (RTC_AlarmStruct->AlarmDateWeekDaySel == LL_RTC_ALMB_DATEWEEKDAYSEL_DATE)
  512. {
  513. assert_param(IS_LL_RTC_DAY(RTC_AlarmStruct->AlarmDateWeekDay));
  514. }
  515. else
  516. {
  517. assert_param(IS_LL_RTC_WEEKDAY(RTC_AlarmStruct->AlarmDateWeekDay));
  518. }
  519. }
  520. else
  521. {
  522. if (LL_RTC_GetHourFormat(RTCx) != LL_RTC_HOURFORMAT_24HOUR)
  523. {
  524. assert_param(IS_LL_RTC_HOUR12(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmTime.Hours)));
  525. assert_param(IS_LL_RTC_TIME_FORMAT(RTC_AlarmStruct->AlarmTime.TimeFormat));
  526. }
  527. else
  528. {
  529. RTC_AlarmStruct->AlarmTime.TimeFormat = 0x00U;
  530. assert_param(IS_LL_RTC_HOUR24(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmTime.Hours)));
  531. }
  532. assert_param(IS_LL_RTC_MINUTES(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmTime.Minutes)));
  533. assert_param(IS_LL_RTC_SECONDS(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmTime.Seconds)));
  534. if (RTC_AlarmStruct->AlarmDateWeekDaySel == LL_RTC_ALMB_DATEWEEKDAYSEL_DATE)
  535. {
  536. assert_param(IS_LL_RTC_DAY(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmDateWeekDay)));
  537. }
  538. else
  539. {
  540. assert_param(IS_LL_RTC_WEEKDAY(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmDateWeekDay)));
  541. }
  542. }
  543. /* Disable the write protection for RTC registers */
  544. LL_RTC_DisableWriteProtection(RTCx);
  545. /* Select weekday selection */
  546. if (RTC_AlarmStruct->AlarmDateWeekDaySel == LL_RTC_ALMB_DATEWEEKDAYSEL_DATE)
  547. {
  548. /* Set the date for ALARM */
  549. LL_RTC_ALMB_DisableWeekday(RTCx);
  550. if (RTC_Format != LL_RTC_FORMAT_BIN)
  551. {
  552. LL_RTC_ALMB_SetDay(RTCx, RTC_AlarmStruct->AlarmDateWeekDay);
  553. }
  554. else
  555. {
  556. LL_RTC_ALMB_SetDay(RTCx, __LL_RTC_CONVERT_BIN2BCD(RTC_AlarmStruct->AlarmDateWeekDay));
  557. }
  558. }
  559. else
  560. {
  561. /* Set the week day for ALARM */
  562. LL_RTC_ALMB_EnableWeekday(RTCx);
  563. LL_RTC_ALMB_SetWeekDay(RTCx, RTC_AlarmStruct->AlarmDateWeekDay);
  564. }
  565. /* Configure the Alarm register */
  566. if (RTC_Format != LL_RTC_FORMAT_BIN)
  567. {
  568. LL_RTC_ALMB_ConfigTime(RTCx, RTC_AlarmStruct->AlarmTime.TimeFormat, RTC_AlarmStruct->AlarmTime.Hours,
  569. RTC_AlarmStruct->AlarmTime.Minutes, RTC_AlarmStruct->AlarmTime.Seconds);
  570. }
  571. else
  572. {
  573. LL_RTC_ALMB_ConfigTime(RTCx, RTC_AlarmStruct->AlarmTime.TimeFormat,
  574. __LL_RTC_CONVERT_BIN2BCD(RTC_AlarmStruct->AlarmTime.Hours),
  575. __LL_RTC_CONVERT_BIN2BCD(RTC_AlarmStruct->AlarmTime.Minutes),
  576. __LL_RTC_CONVERT_BIN2BCD(RTC_AlarmStruct->AlarmTime.Seconds));
  577. }
  578. /* Set ALARM mask */
  579. LL_RTC_ALMB_SetMask(RTCx, RTC_AlarmStruct->AlarmMask);
  580. /* Enable the write protection for RTC registers */
  581. LL_RTC_EnableWriteProtection(RTCx);
  582. return SUCCESS;
  583. }
  584. /**
  585. * @brief Set each @ref LL_RTC_AlarmTypeDef of ALARMA field to default value (Time = 00h:00mn:00sec /
  586. * Day = 1st day of the month/Mask = all fields are masked).
  587. * @param RTC_AlarmStruct pointer to a @ref LL_RTC_AlarmTypeDef structure which will be initialized.
  588. * @retval None
  589. */
  590. void LL_RTC_ALMA_StructInit(LL_RTC_AlarmTypeDef *RTC_AlarmStruct)
  591. {
  592. /* Alarm Time Settings : Time = 00h:00mn:00sec */
  593. RTC_AlarmStruct->AlarmTime.TimeFormat = LL_RTC_ALMA_TIME_FORMAT_AM;
  594. RTC_AlarmStruct->AlarmTime.Hours = 0U;
  595. RTC_AlarmStruct->AlarmTime.Minutes = 0U;
  596. RTC_AlarmStruct->AlarmTime.Seconds = 0U;
  597. /* Alarm Day Settings : Day = 1st day of the month */
  598. RTC_AlarmStruct->AlarmDateWeekDaySel = LL_RTC_ALMA_DATEWEEKDAYSEL_DATE;
  599. RTC_AlarmStruct->AlarmDateWeekDay = 1U;
  600. /* Alarm Masks Settings : Mask = all fields are not masked */
  601. RTC_AlarmStruct->AlarmMask = LL_RTC_ALMA_MASK_NONE;
  602. }
  603. /**
  604. * @brief Set each @ref LL_RTC_AlarmTypeDef of ALARMA field to default value (Time = 00h:00mn:00sec /
  605. * Day = 1st day of the month/Mask = all fields are masked).
  606. * @param RTC_AlarmStruct pointer to a @ref LL_RTC_AlarmTypeDef structure which will be initialized.
  607. * @retval None
  608. */
  609. void LL_RTC_ALMB_StructInit(LL_RTC_AlarmTypeDef *RTC_AlarmStruct)
  610. {
  611. /* Alarm Time Settings : Time = 00h:00mn:00sec */
  612. RTC_AlarmStruct->AlarmTime.TimeFormat = LL_RTC_ALMB_TIME_FORMAT_AM;
  613. RTC_AlarmStruct->AlarmTime.Hours = 0U;
  614. RTC_AlarmStruct->AlarmTime.Minutes = 0U;
  615. RTC_AlarmStruct->AlarmTime.Seconds = 0U;
  616. /* Alarm Day Settings : Day = 1st day of the month */
  617. RTC_AlarmStruct->AlarmDateWeekDaySel = LL_RTC_ALMB_DATEWEEKDAYSEL_DATE;
  618. RTC_AlarmStruct->AlarmDateWeekDay = 1U;
  619. /* Alarm Masks Settings : Mask = all fields are not masked */
  620. RTC_AlarmStruct->AlarmMask = LL_RTC_ALMB_MASK_NONE;
  621. }
  622. /**
  623. * @brief Enters the RTC Initialization mode.
  624. * @note The RTC Initialization mode is write protected, use the
  625. * @ref LL_RTC_DisableWriteProtection before calling this function.
  626. * @param RTCx RTC Instance
  627. * @retval An ErrorStatus enumeration value:
  628. * - SUCCESS: RTC is in Init mode
  629. * - ERROR: RTC is not in Init mode
  630. */
  631. ErrorStatus LL_RTC_EnterInitMode(RTC_TypeDef *RTCx)
  632. {
  633. __IO uint32_t timeout = RTC_INITMODE_TIMEOUT;
  634. ErrorStatus status = SUCCESS;
  635. uint32_t tmp = 0U;
  636. /* Check the parameter */
  637. assert_param(IS_RTC_ALL_INSTANCE(RTCx));
  638. /* Check if the Initialization mode is set */
  639. if (LL_RTC_IsActiveFlag_INIT(RTCx) == 0U)
  640. {
  641. /* Set the Initialization mode */
  642. LL_RTC_EnableInitMode(RTCx);
  643. /* Wait till RTC is in INIT state and if Time out is reached exit */
  644. tmp = LL_RTC_IsActiveFlag_INIT(RTCx);
  645. while ((timeout != 0U) && (tmp != 1U))
  646. {
  647. if (LL_SYSTICK_IsActiveCounterFlag() == 1U)
  648. {
  649. timeout --;
  650. }
  651. tmp = LL_RTC_IsActiveFlag_INIT(RTCx);
  652. if (timeout == 0U)
  653. {
  654. status = ERROR;
  655. }
  656. }
  657. }
  658. return status;
  659. }
  660. /**
  661. * @brief Exit the RTC Initialization mode.
  662. * @note When the initialization sequence is complete, the calendar restarts
  663. * counting after 4 RTCCLK cycles.
  664. * @note The RTC Initialization mode is write protected, use the
  665. * @ref LL_RTC_DisableWriteProtection before calling this function.
  666. * @param RTCx RTC Instance
  667. * @retval An ErrorStatus enumeration value:
  668. * - SUCCESS: RTC exited from in Init mode
  669. * - ERROR: Not applicable
  670. */
  671. ErrorStatus LL_RTC_ExitInitMode(RTC_TypeDef *RTCx)
  672. {
  673. /* Check the parameter */
  674. assert_param(IS_RTC_ALL_INSTANCE(RTCx));
  675. /* Disable initialization mode */
  676. LL_RTC_DisableInitMode(RTCx);
  677. return SUCCESS;
  678. }
  679. /**
  680. * @brief Waits until the RTC Time and Day registers (RTC_TR and RTC_DR) are
  681. * synchronized with RTC APB clock.
  682. * @note The RTC Resynchronization mode is write protected, use the
  683. * @ref LL_RTC_DisableWriteProtection before calling this function.
  684. * @note To read the calendar through the shadow registers after calendar
  685. * initialization, calendar update or after wakeup from low power modes
  686. * the software must first clear the RSF flag.
  687. * The software must then wait until it is set again before reading
  688. * the calendar, which means that the calendar registers have been
  689. * correctly copied into the RTC_TR and RTC_DR shadow registers.
  690. * @param RTCx RTC Instance
  691. * @retval An ErrorStatus enumeration value:
  692. * - SUCCESS: RTC registers are synchronised
  693. * - ERROR: RTC registers are not synchronised
  694. */
  695. ErrorStatus LL_RTC_WaitForSynchro(RTC_TypeDef *RTCx)
  696. {
  697. __IO uint32_t timeout = RTC_SYNCHRO_TIMEOUT;
  698. ErrorStatus status = SUCCESS;
  699. uint32_t tmp = 0U;
  700. /* Check the parameter */
  701. assert_param(IS_RTC_ALL_INSTANCE(RTCx));
  702. /* Clear RSF flag */
  703. LL_RTC_ClearFlag_RS(RTCx);
  704. /* Wait the registers to be synchronised */
  705. tmp = LL_RTC_IsActiveFlag_RS(RTCx);
  706. while ((timeout != 0U) && (tmp != 1U))
  707. {
  708. if (LL_SYSTICK_IsActiveCounterFlag() == 1U)
  709. {
  710. timeout--;
  711. }
  712. tmp = LL_RTC_IsActiveFlag_RS(RTCx);
  713. if (timeout == 0U)
  714. {
  715. status = ERROR;
  716. }
  717. }
  718. return (status);
  719. }
  720. /**
  721. * @}
  722. */
  723. /**
  724. * @}
  725. */
  726. /**
  727. * @}
  728. */
  729. #endif /* defined(RTC) */
  730. /**
  731. * @}
  732. */
  733. #endif /* USE_FULL_LL_DRIVER */