STM32L0系列的芯片提供了一系列的低功耗的外设,比如使用32.768KHz外部晶振,驱动低功耗串口可以采集最高9600波特率的串口,而且在停止和低功耗运行模式下均不丢数据。低功耗的计数器,RTC等外设资源,设备平均功耗可以控制50ua以内,目前经我手做的几个项目,设备的整机的平均功耗均在50ua以内。
这一次做Lora低功耗透传DTU,差点将我一世英明葬送。
1.设备整机功耗不到30ua,低功耗串口,低功耗计数器,片内EEprom一起使用,居然串口丢数,而且丢数很多,坑人不浅,硬件有问题的可能性几乎不存在,因为电路只有几个串口。
2.修正策略,第一步,调整中断优先级,低功耗L0系列的芯片的中断只有四级可以调整。调整后有所改善,但没有根除问题;
3.再次增加策略,减少中断中处理的时间,将中断调用的函数,全部去掉,不再在中断中调用任何函数,有改善问题依然存在;
4.关闭所有除串口外的中断,测试一段时间,问题根除,没有出现丢数现象,但是这种模式我的设备无法工作,仍需继续找出问题的根源;
5.经过多段时间的排查,片内EEProm的操作,是导致丢数的一大原因,运行过程中存储数据的逻辑进行调整,问题改善很多,还存在部分问题;
6.之后排查中断时发现,低功耗计数器是影响串口丢数的另外一个重要原因;
按照上述步骤解决完问题后,发现设备不丢数,唯一的遗憾是设备的功耗有30ua增加到了50ua,勉强能够接受,事情也算可以告一段落了。