1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

cpu/stm32/rtc: add support for STM32G0

This commit is contained in:
Benjamin Valentin 2024-02-04 19:36:00 +01:00
parent 22dbbf4a07
commit 895a6f87ed

View File

@ -49,6 +49,11 @@
#define EXTI_REG_FTSR (EXTI->FTSR1) #define EXTI_REG_FTSR (EXTI->FTSR1)
#define EXTI_REG_PR (EXTI->PR1) #define EXTI_REG_PR (EXTI->PR1)
#define EXTI_REG_IMR (EXTI->IMR1) #define EXTI_REG_IMR (EXTI->IMR1)
#elif defined(CPU_FAM_STM32G0)
#define EXTI_REG_RTSR (EXTI->RTSR1)
#define EXTI_REG_FTSR (EXTI->FTSR1)
#define EXTI_REG_PR (EXTI->RPR1)
#define EXTI_REG_IMR (EXTI->IMR1)
#elif defined(CPU_FAM_STM32L5) #elif defined(CPU_FAM_STM32L5)
#define EXTI_REG_IMR (EXTI->IMR1) #define EXTI_REG_IMR (EXTI->IMR1)
#else #else
@ -59,9 +64,10 @@
#endif #endif
/* map some RTC register names and bitfield */ /* map some RTC register names and bitfield */
#if defined(CPU_FAM_STM32G4) #if defined(CPU_FAM_STM32G4) || defined(CPU_FAM_STM32G0)
#define RTC_REG_ISR RTC->ICSR #define RTC_REG_ISR RTC->ICSR
#define RTC_REG_SR RTC->SR
#define RTC_REG_SCR RTC->SCR
#define RTC_ISR_RSF RTC_ICSR_RSF #define RTC_ISR_RSF RTC_ICSR_RSF
#define RTC_ISR_INIT RTC_ICSR_INIT #define RTC_ISR_INIT RTC_ICSR_INIT
#define RTC_ISR_INITF RTC_ICSR_INITF #define RTC_ISR_INITF RTC_ICSR_INITF
@ -83,6 +89,9 @@
defined(CPU_FAM_STM32L5) defined(CPU_FAM_STM32L5)
#define IRQN (RTC_IRQn) #define IRQN (RTC_IRQn)
#define ISR_NAME isr_rtc #define ISR_NAME isr_rtc
#elif defined(CPU_FAM_STM32G0)
#define IRQN (RTC_TAMP_IRQn)
#define ISR_NAME isr_rtc_tamp
#else #else
#define IRQN (RTC_Alarm_IRQn) #define IRQN (RTC_Alarm_IRQn)
#define ISR_NAME isr_rtc_alarm #define ISR_NAME isr_rtc_alarm
@ -101,6 +110,11 @@
#define EXTI_FTSR_BIT (EXTI_FTSR1_FT17) #define EXTI_FTSR_BIT (EXTI_FTSR1_FT17)
#define EXTI_RTSR_BIT (EXTI_RTSR1_RT17) #define EXTI_RTSR_BIT (EXTI_RTSR1_RT17)
#define EXTI_PR_BIT (EXTI_PR1_PIF17) #define EXTI_PR_BIT (EXTI_PR1_PIF17)
#elif defined(CPU_FAM_STM32G0)
#define EXTI_IMR_BIT (EXTI_IMR1_IM11)
#define EXTI_FTSR_BIT (EXTI_FTSR1_FT11)
#define EXTI_RTSR_BIT (EXTI_RTSR1_RT11)
#define EXTI_PR_BIT (EXTI_RPR1_RPIF11)
#else #else
#if defined(CPU_FAM_STM32L0) #if defined(CPU_FAM_STM32L0)
#define EXTI_IMR_BIT (EXTI_IMR_IM17) #define EXTI_IMR_BIT (EXTI_IMR_IM17)
@ -252,9 +266,11 @@ void rtc_init(void)
/* select input clock and enable the RTC */ /* select input clock and enable the RTC */
stmclk_dbp_unlock(); stmclk_dbp_unlock();
#if defined(CPU_FAM_STM32L5) #if defined(CPU_FAM_STM32L5)
periph_clk_en(APB1, RCC_APB1ENR1_RTCAPBEN); periph_clk_en(APB1, RCC_APB1ENR1_RTCAPBEN);
#endif #elif defined(CPU_FAM_STM32G0)
periph_clk_en(APB1, RCC_APBENR1_RTCAPBEN);
#endif
EN_REG &= ~(CLKSEL_MASK); EN_REG &= ~(CLKSEL_MASK);
#if IS_ACTIVE(CONFIG_BOARD_HAS_LSE) #if IS_ACTIVE(CONFIG_BOARD_HAS_LSE)
EN_REG |= (CLKSEL_LSE | EN_BIT); EN_REG |= (CLKSEL_LSE | EN_BIT);
@ -398,7 +414,7 @@ void rtc_poweroff(void)
void ISR_NAME(void) void ISR_NAME(void)
{ {
#if !defined(CPU_FAM_STM32L5) #if !defined(CPU_FAM_STM32L5) && !defined(CPU_FAM_STM32G0)
if (RTC_REG_ISR & RTC_ISR_ALRAF) { if (RTC_REG_ISR & RTC_ISR_ALRAF) {
if (isr_ctx.cb != NULL) { if (isr_ctx.cb != NULL) {
isr_ctx.cb(isr_ctx.arg); isr_ctx.cb(isr_ctx.arg);