STM32L431 RTC日期无法获取的问题
背景
公司某产品,已量产上百台,在这批量产的设备中发现,上位机连接设备后无法获取设备数据,设备系统运行秒闪LED不闪,但是Debug串口有相应数据输出。
系统内部使用了低功耗模式,故未启用看门狗,初始怀疑是系统跑飞,但串口有相应信息输出。
排查
通过Debug可知,上位机在获取设备数据之前会修改系统日期与时间,通过查看内部RTC寄存器可知时间与日期确实被修改,但是在后续的读取中发现,系统的时间确实已被修改,但系统的日期并未修改成功。
由于上位机的时间被设备上未修改前的时间(系统默认时间比较小)还小,导致设备的时间被往回调,这个导致系统每秒的节拍无法产生(每百毫秒系统都会就比较当前时间与前一刻时间进行比较)。
原因
获取MCU RTC时间与日期的地方,如下图
通过查看所调用两个函数的源码,发现在函数LL_RTC_GetDate
中的note
强调,需要先获取时间后获取日期才能保证时间与日期之间的一致性
系统内部使用了低功耗模式,故未启用看门狗,初始怀疑是系统跑飞,但串口有相应信息输出。
解决
修改函数`LL_RTC_GetDateTime`,先读时间再读日期即可解决。