📄 stm8l15x_rtc.c
字号:
/* Time = 00h:00min:00sec*/
RTC_TimeStruct->RTC_H12 = RTC_H12_AM;
RTC_TimeStruct->RTC_Hours = 0;
RTC_TimeStruct->RTC_Minutes = 0;
RTC_TimeStruct->RTC_Seconds = 0;
}
/**
* @brief Gets the RTC current Time.
* @note To read the Calendar after wake up from low power mode, user software
* must first check that the RSF flag is set in RTC_ISR1, using
* RTC_WaitForSynchro() function, which means that the Calendar registers
* have been correctly copied into the shadow registers (RTC_TRx and RTC_DRx).
* @param RTC_Format: specifies the format of the returned parameters.
* This parameter can be one of the @ref RTC_Format_TypeDef enumeration.
* @param RTC_TimeStruct: pointer to a @ref RTC_TimeTypeDef structure that
* will contain the returned current time configuration.
* @retval None
*/
void RTC_GetTime(RTC_Format_TypeDef RTC_Format,
RTC_TimeTypeDef* RTC_TimeStruct)
{
uint8_t tmpreg = 0;
/* Check the parameters */
assert_param(IS_RTC_FORMAT(RTC_Format));
/* Fill the structure fields with the read parameters */
/* Get RTC seconds */
RTC_TimeStruct->RTC_Seconds = RTC->TR1;
/* Get RTC Minutes */
RTC_TimeStruct->RTC_Minutes = RTC->TR2;
/* Get the RTC_TR3 register */
tmpreg = (uint8_t)RTC->TR3;
/* Read DR3 register to unfreeze calender registers */
(void) (RTC->DR3) ;
/* Get RTC Hours */
RTC_TimeStruct->RTC_Hours = (uint8_t)(tmpreg & (uint8_t)~(RTC_TR3_PM));
/* Get RTC H12 state */
RTC_TimeStruct->RTC_H12 = (RTC_H12_TypeDef)(tmpreg & RTC_TR3_PM);
/* Check the input parameters format */
if (RTC_Format == RTC_Format_BIN)
{
/* Convert the structure parameters to Binary format */
RTC_TimeStruct->RTC_Hours = (uint8_t)Bcd2ToByte(RTC_TimeStruct->RTC_Hours);
RTC_TimeStruct->RTC_Minutes = (uint8_t)Bcd2ToByte(RTC_TimeStruct->RTC_Minutes);
RTC_TimeStruct->RTC_Seconds = (uint8_t)Bcd2ToByte(RTC_TimeStruct->RTC_Seconds);
}
}
/**
* @brief Gets the RTC current Calendar Subseconds value.
* @note To read the Calendar after wake up from low power mode, user software
* must first check that the RSF flag is set in RTC_ISR1, using
* RTC_WaitForSynchro() function, which means that the Calendar registers
* have been correctly copied into the shadow registers (RTC_TRx and RTC_DRx).
* @param None
* @retval RTC current Calendar Subseconds value.
*/
uint16_t RTC_GetSubSecond(void)
{
uint8_t ssrhreg = 0, ssrlreg = 0;
uint16_t ssrreg = 0;
/* Get subseconds values from the correspondent registers*/
ssrhreg = RTC->SSRH;
ssrlreg = RTC->SSRL;
/* Read DR3 register to unfreeze calender registers */
(void) (RTC->DR3);
ssrreg = (uint16_t)((uint16_t)((uint16_t)ssrhreg << 8) | (uint16_t)(ssrlreg));
return (uint16_t)(ssrreg);
}
/**
* @brief Set the RTC current date.
* @note After updating the Calendar, this routine clears the RSF flag and waits
* until it is set again (using RTC_WaitForSynchro() function) , which means
* that the Calendar registers have been correctly copied into the RTC_TRx
* and RTC_DRx shadow registers.
* @param RTC_Format: specifies the format of the entered parameters.
* This parameter can be one of the @ref RTC_Format_TypeDef enumeration.
* @param RTC_DateStruct: pointer to a @ref RTC_TimeTypeDef structure that
* contains the date configuration information for the RTC.
* @retval An ErrorStatus enumeration value:
* - SUCCESS: RTC Date register is configured
* - ERROR: RTC Date register is not configured
*/
ErrorStatus RTC_SetDate(RTC_Format_TypeDef RTC_Format,
RTC_DateTypeDef* RTC_DateStruct)
{
ErrorStatus status = ERROR;
if ((RTC_Format == RTC_Format_BIN) && ((RTC_DateStruct->RTC_Month & TEN_VALUE_BCD) == TEN_VALUE_BCD))
{
RTC_DateStruct->RTC_Month = (RTC_Month_TypeDef)((RTC_DateStruct->RTC_Month & (uint8_t)~(TEN_VALUE_BCD)) + TEN_VALUE_BIN);
}
/* Check the parameters */
assert_param(IS_RTC_FORMAT(RTC_Format));
if (RTC_Format == RTC_Format_BIN)
{
assert_param(IS_RTC_YEAR(RTC_DateStruct->RTC_Year));
assert_param(IS_RTC_MONTH_MIN(RTC_DateStruct->RTC_Month));
assert_param(IS_RTC_MONTH_MAX(RTC_DateStruct->RTC_Month));
assert_param(IS_RTC_DATE_MIN(RTC_DateStruct->RTC_Date));
assert_param(IS_RTC_DATE_MAX(RTC_DateStruct->RTC_Date));
}
else
{
assert_param(IS_RTC_YEAR(Bcd2ToByte(RTC_DateStruct->RTC_Year)));
assert_param(IS_RTC_MONTH_MAX(Bcd2ToByte((uint8_t)RTC_DateStruct->RTC_Month)));
assert_param(IS_RTC_MONTH_MIN(Bcd2ToByte((uint8_t)RTC_DateStruct->RTC_Month)));
assert_param(IS_RTC_DATE_MIN(Bcd2ToByte((uint8_t)RTC_DateStruct->RTC_Date)));
assert_param(IS_RTC_DATE_MAX(Bcd2ToByte((uint8_t)RTC_DateStruct->RTC_Date)));
}
assert_param(IS_RTC_WEEKDAY(RTC_DateStruct->RTC_WeekDay));
/* Disable the write protection for RTC registers */
RTC->WPR = 0xCA;
RTC->WPR = 0x53;
/* Set Initialization mode */
if (RTC_EnterInitMode() == ERROR)
{
status = ERROR;
/* Enable the write protection for RTC registers */
RTC->WPR = 0xFF;
}
else
{
(void)(RTC->TR1);
/* Set the RTC_DR registers */
/* Check the input parameters format */
if (RTC_Format != RTC_Format_BIN)
{
RTC->DR1 = (uint8_t)(RTC_DateStruct->RTC_Date);
RTC->DR2 = (uint8_t)((RTC_DateStruct->RTC_Month) | (uint8_t)((RTC_DateStruct->RTC_WeekDay) << 5));
RTC->DR3 = (uint8_t)((RTC_DateStruct->RTC_Year));
}
else
{
RTC->DR1 = (uint8_t)(ByteToBcd2 ((uint8_t)RTC_DateStruct->RTC_Date));
RTC->DR2 = (uint8_t)((ByteToBcd2((uint8_t)RTC_DateStruct->RTC_Month)) | (uint8_t)((RTC_DateStruct->RTC_WeekDay) << 5));
RTC->DR3 = (uint8_t)(ByteToBcd2((uint8_t)RTC_DateStruct->RTC_Year));
}
/* Exit Initialization mode */
RTC->ISR1 &= (uint8_t)~RTC_ISR1_INIT;
/* Enable the write protection for RTC registers */
RTC->WPR = 0xFF;
/* if RTC_CR1_BYPSHAD bit = 0, wait for synchro else this check is not needed */
if ((RTC->CR1 & RTC_CR1_BYPSHAD) == RESET)
{
if (RTC_WaitForSynchro() == ERROR)
{
status = ERROR;
}
else
{
status = SUCCESS;
}
}
else
{
status = SUCCESS;
}
}
return (ErrorStatus)status;
}
/**
* @brief Fills each RTC_DateStruct member with its default value
* (Monday 01 January xx00).
* @param RTC_DateStruct: pointer to a @ref RTC_DateTypeDef structure which will be
* initialized.
* @retval None
*/
void RTC_DateStructInit(RTC_DateTypeDef* RTC_DateStruct)
{
/* * (Monday 01 January xx00)*/
RTC_DateStruct->RTC_WeekDay = RTC_Weekday_Monday;
RTC_DateStruct->RTC_Date = 1;
RTC_DateStruct->RTC_Month = RTC_Month_January;
RTC_DateStruct->RTC_Year = 0;
}
/**
* @brief Get the RTC current date.
* @note To read the Calendar after wake up from low power mode, user software
* must first check that the RSF flag is set in RTC_ISR1, using
* RTC_WaitForSynchro() function, which means that the Calendar registers
* have been correctly copied into the shadow registers (RTC_TRx and RTC_DRx).
* @param RTC_Format: specifies the format of the returned parameters.
* This parameter can be one of the @ref RTC_Format_TypeDef enumeration.
* @param RTC_DateStruct: pointer to a @ref RTC_DateTypeDef structure that
* will contain the returned current Date configuration.
* @retval None
*/
void RTC_GetDate(RTC_Format_TypeDef RTC_Format,
RTC_DateTypeDef* RTC_DateStruct)
{
uint8_t tmpreg = 0;
/* Check the parameters */
assert_param(IS_RTC_FORMAT(RTC_Format));
/* Fill the structure fields with the read parameters */
(void) (RTC->TR1) ;
RTC_DateStruct->RTC_Date = (uint8_t)(RTC->DR1);
tmpreg = (uint8_t)RTC->DR2;
RTC_DateStruct->RTC_Year = (uint8_t)(RTC->DR3);
RTC_DateStruct->RTC_Month = (RTC_Month_TypeDef)(tmpreg & (uint8_t)(RTC_DR2_MT | RTC_DR2_MU));
RTC_DateStruct->RTC_WeekDay = (RTC_Weekday_TypeDef)((uint8_t)((uint8_t)tmpreg & (uint8_t)(RTC_DR2_WDU)) >> (uint8_t)5);
/* Check the input parameters format */
if (RTC_Format == RTC_Format_BIN)
{
/* Convert the structure parameters to Binary format */
RTC_DateStruct->RTC_Year = (uint8_t)Bcd2ToByte((uint8_t)RTC_DateStruct->RTC_Year);
RTC_DateStruct->RTC_Month = (RTC_Month_TypeDef)Bcd2ToByte((uint8_t)RTC_DateStruct->RTC_Month);
RTC_DateStruct->RTC_Date = (uint8_t)(Bcd2ToByte((uint8_t)RTC_DateStruct->RTC_Date));
}
}
/**
* @}
*/
/** @defgroup RTC_Group3 Alarms configuration functions
* @brief Alarms (Alarm A and Alarm B) configuration functions
*
@verbatim
===============================================================================
Alarms (Alarm A and Alarm B) configuration functions
===============================================================================
This section provide functions allowing to program and read the RTC Alarms.
@endverbatim
* @{
*/
/**
* @brief Sets the RTC Alarm configuration.
* @note Before configuring the Alarm settings, the Alarm Unit must be disabled
* (if enabled) using RTC_AlarmCmd(DISABLE) function.
* @param RTC_Format: specifies the format of the entered parameters.
* This parameter can be one of the @ref RTC_Format_TypeDef enumeration.
* @param RTC_AlarmStruct: pointer to a @ref RTC_AlarmTypeDef structure that
* contains the Alarm configuration information for the RTC.
* @retval None.
*/
void RTC_SetAlarm(RTC_Format_TypeDef RTC_Format,
RTC_AlarmTypeDef* RTC_AlarmStruct)
{
uint8_t tmpreg1 = 0;
uint8_t tmpreg2 = 0;
uint8_t tmpreg3 = 0;
uint8_t tmpreg4 = 0;
/* Check the parameters */
assert_param(IS_RTC_ALARM_MASK(RTC_AlarmStruct->RTC_AlarmMask));
assert_param(IS_RTC_FORMAT(RTC_Format));
assert_param(IS_RTC_H12(RTC_AlarmStruct->RTC_AlarmTime.RTC_H12));
assert_param(IS_RTC_ALARM_DATEWEEKDAY_SEL(RTC_AlarmStruct->RTC_AlarmDateWeekDaySel));
if (RTC_Format == RTC_Format_BIN)
{
/* Check Hour Format (24h or 12h)*/
if ((RTC->CR1 & RTC_CR1_FMT) != RESET)
{
assert_param(IS_RTC_HOUR12_MAX(RTC_AlarmStruct->RTC_AlarmTime.RTC_Hours));
assert_param(IS_RTC_HOUR12_MIN(RTC_AlarmStruct->RTC_AlarmTime.RTC_Hours));
}
else
{
assert_param(IS_RTC_HOUR24(RTC_AlarmStruct->RTC_AlarmTime.RTC_Hours));
}
assert_param(IS_RTC_MINUTES(RTC_AlarmStruct->RTC_AlarmTime.RTC_Minutes));
assert_param(IS_RTC_SECONDS(RTC_AlarmStruct->RTC_AlarmTime.RTC_Seconds));
}
else
{
/* Check Hour Format (24h or 12h)*/
if ((RTC->CR1 & RTC_CR1_FMT) != RESET)
{
assert_param(IS_RTC_HOUR12_MAX(Bcd2ToByte(RTC_AlarmStruct->RTC_AlarmTime.RTC_Hours)));
assert_param(IS_RTC_HOUR12_MIN(Bcd2ToByte(RTC_AlarmStruct->RTC_AlarmTime.RTC_Hours)));
}
else
{
assert_param(IS_RTC_HOUR24(Bcd2ToByte(RTC_AlarmStruct->RTC_AlarmTime.RTC_Hours)));
}
assert_param(IS_RTC_MINUTES(Bcd2ToByte(RTC_AlarmStruct->RTC_AlarmTime.RTC_Minutes)));
assert_param(IS_RTC_SECONDS(Bcd2ToByte(RTC_AlarmStruct->RTC_AlarmTime.RTC_Seconds)));
}
/* if Date/Weekday field is not masked */
if ((RTC_AlarmStruct->RTC_AlarmMask & RTC_AlarmMask_DateWeekDay) == RESET )
{
if (RTC_AlarmStruct->RTC_AlarmDateWeekDaySel == RTC_AlarmDateWeekDaySel_WeekDay)
{
assert_param(IS_RTC_WEEKDAY(RTC_AlarmStruct->RTC_AlarmDateWeekDay));
}
else
{
assert_param(IS_RTC_DATE_MIN(RTC_AlarmStruct->RTC_AlarmDateWeekDay));
assert_param(IS_RTC_DATE_MAX(RTC_AlarmStruct->RTC_AlarmDateWeekDay));
}
}
/* Disable the write protection for RTC registers */
RTC->WPR = 0xCA;
RTC->WPR = 0x53;
/* Check the input parameters format & Configure the Alarm register */
if (RTC_Format != RTC_Format_BIN)
{
tmpreg1 = (uint8_t)((uint8_t)(RTC_AlarmStruct->RTC_AlarmTime.RTC_Seconds) | \
(uint8_t)((uint8_t)(RTC_AlarmStruct->RTC_AlarmMask) & (uint8_t)RTC_ALRMAR1_MSK1));
tmpreg2 = (uint8_t)((uint8_t)(RTC_AlarmStruct->RTC_AlarmTime.RTC_Minutes) | \
(uint8_t)((uint8_t)(RTC_AlarmStruct->RTC_AlarmMask << 1) & (uint8_t)RTC_ALRMAR2_MSK2));
tmpreg3 = (uint8_t)((uint8_t)((uint8_t)(RTC_AlarmStruct->RTC_AlarmTime.RTC_Hours) | \
(uint8_t)(RTC_AlarmStruct->RTC_AlarmTime.RTC_H12)) | \
(uint8_t)((uint8_t)(RTC_AlarmStruct->RTC_AlarmMask << 2) & (uint8_t)RTC_ALRMAR3_MSK3));
tmpreg4 = (uint8_t)((uint8_t)((uint8_t)(RTC_AlarmStruct->RTC_AlarmDateWeekDay) | \
(uint8_t)(RTC_AlarmStruct->RTC_AlarmDateWeekDaySel)) | \
(uint8_t)((uint8_t)(RTC_AlarmStruct->RTC_AlarmMask << 3) & (uint8_t)RTC_ALRMAR4_MSK4));
}
else
{
tmpreg1 = (uint8_t)((ByteToBcd2(RTC_AlarmStruct->RTC_AlarmTime.RTC_Seconds)) | \
(uint8_t)(RTC_AlarmStruct->RTC_AlarmMask & RTC_ALRMAR1_MSK1));
tmpreg2 = (uint8_t)((ByteToBcd2(RTC_AlarmStruct->RTC_AlarmTime.RTC_Minutes)) | \
(uint8_t)((uint8_t)(RTC_AlarmStruct->RTC_AlarmMask << 1) & (uint8_t)RTC_ALRMAR2_MSK2));
tmpreg3 = (uint8_t)((uint8_t)((ByteToBcd2(RTC_AlarmStruct->RTC_AlarmTime.RTC_Hours)) | \
(uint8_t)(RTC_AlarmStruct->RTC_AlarmTime.RTC_H12)) | \
(uint8_t)((uint8_t)(RTC_AlarmStruct->RTC_AlarmMask << 2) & (uint8_t)RTC_ALRMAR3_MSK3));
tmpreg4 = (uint8_t)((uint8_t)((ByteToBcd2(RTC_AlarmStruct->RTC_AlarmDateWeekDay)) | \
(uint8_t)(RTC_AlarmStruct->RTC_AlarmDateWeekDaySel)) | \
(uint8_t)((uint8_t)(RTC_AlarmStruct->RTC_AlarmMask << 3) & (uint8_t)(RTC_ALRMAR4_MSK4)));
}
/* Configure the Alarm register */
RTC->ALRMAR1 = tmpreg1;
RTC->ALRMAR2 = tmpreg2;
RTC->ALRMAR3 = tmpreg3;
RTC->ALRMAR4 = tmpreg4;
/* Enable the write protection for RTC registers */
RTC->WPR = 0xFF;
}
/**
* @brief Fills each RTC_AlarmStruct member with its default value
* (Time = 00h:00mn:00sec / Date = 1st day of the month/Mask =
* all fields are masked).
* @param RTC_AlarmStruct: pointer to a @ref RTC_AlarmTypeDef structure which
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -