From 244b437a0d21ce9e62bb52ef3bebe09c19c63617 Mon Sep 17 00:00:00 2001 From: Johan Lafon Date: Tue, 12 Sep 2023 11:34:07 +0200 Subject: [PATCH] drivers: rtc: stm32: disable calibration for STM32F2 and some STM32L1 STM32F2 and STM32L1 Cat. 1 only provide the coarse calibration feature which is not supported by the code yet. Signed-off-by: Johan Lafon --- drivers/rtc/rtc_ll_stm32.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/drivers/rtc/rtc_ll_stm32.c b/drivers/rtc/rtc_ll_stm32.c index 3b4673da71..047fde9188 100644 --- a/drivers/rtc/rtc_ll_stm32.c +++ b/drivers/rtc/rtc_ll_stm32.c @@ -298,6 +298,8 @@ static int rtc_stm32_get_time(const struct device *dev, struct rtc_time *timeptr } #ifdef CONFIG_RTC_CALIBRATION +#if !defined(CONFIG_SOC_SERIES_STM32F2X) && \ + !(defined(CONFIG_SOC_SERIES_STM32L1X) && !defined(RTC_SMOOTHCALIB_SUPPORT)) static int rtc_stm32_set_calibration(const struct device *dev, int32_t calibration) { ARG_UNUSED(dev); @@ -362,6 +364,7 @@ static int rtc_stm32_get_calibration(const struct device *dev, int32_t *calibrat return 0; } +#endif #endif /* CONFIG_RTC_CALIBRATION */ struct rtc_driver_api rtc_stm32_driver_api = { @@ -370,8 +373,13 @@ struct rtc_driver_api rtc_stm32_driver_api = { /* RTC_ALARM not supported */ /* RTC_UPDATE not supported */ #ifdef CONFIG_RTC_CALIBRATION +#if !defined(CONFIG_SOC_SERIES_STM32F2X) && \ + !(defined(CONFIG_SOC_SERIES_STM32L1X) && !defined(RTC_SMOOTHCALIB_SUPPORT)) .set_calibration = rtc_stm32_set_calibration, .get_calibration = rtc_stm32_get_calibration, +#else +#error RTC calibration for devices without smooth calibration feature is not supported yet +#endif #endif /* CONFIG_RTC_CALIBRATION */ };