因此在進入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的所有配置全部重新配置一次,也可以快速的檢驗是否是這個環節出問題。
以上轉自:http://www.51hei.com/mcu/2758.html
參考:http://bbs.21ic.com/icview-558242-1-1.html
具體要點為:
1、所有IO管腳,如果高阻狀態端口是高電平,就設成上拉輸入,如果高阻狀態是低電平,設成下拉輸入,如果高阻是中間狀態,設成模擬輸入。這個很多人都提到過,必須的。作為輸出口就免了,待機你想輸出個什么東西,一定要輸,硬件上加上下拉就可以了
2、兩個晶振輸入腳要remap成普通IO!!!使用內部晶振。
3、pwr的時鍾要使能,即RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);這個也相當重要
4、關閉jtag口,並設成普通IO;
5、注意助焊膏的質量!!!注意電路板層之間是否進水!!!!
掌握這幾項要點,再設中斷什么的都行,整個世界清靜了!!!完全低能耗。
有些誤導的地方,下面2點對於STANDBY模式不是必需的:
2、兩個晶振輸入腳要remap成普通IO!!!使用內部晶振。
4、關閉jtag口,並設成普通IO;