50 lines
1.8 KiB
C
50 lines
1.8 KiB
C
|
/*
|
||
|
* Copyright (c) 2024 STMicroelectronics
|
||
|
*
|
||
|
* SPDX-License-Identifier: Apache-2.0
|
||
|
*/
|
||
|
|
||
|
#ifndef ZEPHYR_DRIVERS_RTC_RTC_LL_STM32_H_
|
||
|
#define ZEPHYR_DRIVERS_RTC_RTC_LL_STM32_H_
|
||
|
|
||
|
#ifdef CONFIG_RTC_ALARM
|
||
|
|
||
|
/* STM32 RTC alarms, A & B, LL masks are equal */
|
||
|
#define RTC_STM32_ALRM_MASK_ALL LL_RTC_ALMA_MASK_ALL
|
||
|
#define RTC_STM32_ALRM_MASK_SECONDS LL_RTC_ALMA_MASK_SECONDS
|
||
|
#define RTC_STM32_ALRM_MASK_MINUTES LL_RTC_ALMA_MASK_MINUTES
|
||
|
#define RTC_STM32_ALRM_MASK_HOURS LL_RTC_ALMA_MASK_HOURS
|
||
|
#define RTC_STM32_ALRM_MASK_DATEWEEKDAY LL_RTC_ALMA_MASK_DATEWEEKDAY
|
||
|
|
||
|
#define RTC_STM32_ALRM_DATEWEEKDAYSEL_WEEKDAY LL_RTC_ALMA_DATEWEEKDAYSEL_WEEKDAY
|
||
|
#define RTC_STM32_ALRM_DATEWEEKDAYSEL_DATE LL_RTC_ALMA_DATEWEEKDAYSEL_DATE
|
||
|
|
||
|
static inline void ll_func_exti_enable_rtc_alarm_it(uint32_t exti_line)
|
||
|
{
|
||
|
#if defined(CONFIG_SOC_SERIES_STM32H7X) && defined(CONFIG_CPU_CORTEX_M4)
|
||
|
LL_C2_EXTI_EnableIT_0_31(exti_line);
|
||
|
LL_EXTI_EnableRisingTrig_0_31(exti_line);
|
||
|
#elif defined(CONFIG_SOC_SERIES_STM32U5X) || defined(CONFIG_SOC_SERIES_STM32WBAX)
|
||
|
/* in STM32U5 & STM32WBAX series, RTC Alarm event is not routed to EXTI */
|
||
|
#else
|
||
|
LL_EXTI_EnableIT_0_31(exti_line);
|
||
|
LL_EXTI_EnableRisingTrig_0_31(exti_line);
|
||
|
#endif /* CONFIG_SOC_SERIES_STM32H7X and CONFIG_CPU_CORTEX_M4 */
|
||
|
}
|
||
|
|
||
|
static inline void ll_func_exti_clear_rtc_alarm_flag(uint32_t exti_line)
|
||
|
{
|
||
|
#if defined(CONFIG_SOC_SERIES_STM32H7X) && defined(CONFIG_CPU_CORTEX_M4)
|
||
|
LL_C2_EXTI_ClearFlag_0_31(exti_line);
|
||
|
#elif defined(CONFIG_SOC_SERIES_STM32U5X) || defined(CONFIG_SOC_SERIES_STM32WBAX)
|
||
|
/* in STM32U5 & STM32WBAX series, RTC Alarm event is not routed to EXTI */
|
||
|
#elif DT_HAS_COMPAT_STATUS_OKAY(st_stm32g0_exti)
|
||
|
LL_EXTI_ClearRisingFlag_0_31(exti_line);
|
||
|
#else
|
||
|
LL_EXTI_ClearFlag_0_31(exti_line);
|
||
|
#endif /* CONFIG_SOC_SERIES_STM32H7X and CONFIG_CPU_CORTEX_M4 */
|
||
|
}
|
||
|
#endif /* CONFIG_RTC_ALARM */
|
||
|
|
||
|
#endif /* ZEPHYR_DRIVERS_RTC_RTC_LL_STM32_H_ */
|