因此在進入STOPMODE之前,需要做:
1、將N.C的GPIO統一配置為IPU/IPD;
2、檢查一些Signal的輸入Active是High/Low,相應進行配置為IPD/IPU,即避免在內部上/下拉電阻上消耗電流,而且該電流理論值為VCC/R = 3/40 =75uA;
3、如果外部晶振不使用,必須將GPIO配置為IPU/IPD/PPLow,不允許配置為floating,否則會消耗極大的電流 200uA+;
4*、加入進入STOPMODE前,不允許將PWR的CLK關閉,這部分牽涉低功耗模式,實際測試關閉能用,也能喚醒,但是電流會增加10uA+;
5、配置GPIO為輸出時,根據輸出的常態選擇上拉/下拉,如閑置輸出為0,則配置為下拉,輸出閑置為1,則配置上拉;
6、另外特別說明的是->從Stopmode喚醒后,系統會自動切換到HSI,如果進入前使用的是外部晶振/PLL(PLL的clksource = HSI/HSE)因此必須調用System_Init(),對RCC重新初始化,否則喚醒后主頻發生改變,會影響系統;
調試經驗分享:
經常在移植新的產品方案時,都會遇到待機電流不能一步到位,需要測試、調試的過程,在此分享一個土辦法。
1、在調用EnterStopmode前,將GPIO的所有配置寄存器printf,比對GPIO的初始化表,看是否在進入STOP前,在其他地方對GPIO配置做了改動;
調試過程告訴我,基本都是在進入stopmode時,其他的GPIO被另外配置錯誤導致;
2、在調用EnterStopmode前,將GPIO的所有配置全部重新配置一次,也可以快速的檢驗是否是這個環節出問題。