這兩天研究了STM32的低功耗知識,低功耗裏主要研究的是STM32的待機模式和停機模式。讓單片機進入的待機模式和停機模式比較容易,實驗中經過設置中斷口PA1來響應待機和停機模式。函數
void EXTI1_IRQHandler(void)
{
if(!GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_1))
{
delay_ms(10);
while(!GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_1));
if(GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_1))
{
EXTI_ClearITPendingBit(EXTI_Line1);spa
RTC_SetAlarm(RTC_GetCounter()+4); //設置4S後鬧鐘喚醒
RTC_ITConfig(RTC_IT_ALR, ENABLE);//使能鬧鐘中斷.
RTC_WaitForLastTask();//等待上一次寫RTC任務完成.net
Standby(); //進入待機(停機)狀態
}
}調試
}blog
void Standby()
{
RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR , ENABLE);//開電源管理時鐘PWR_Regulator_LowPowerip
PWR_WakeUpPinCmd(ENABLE);//使能喚醒引腳,默認PA0it
PWR_EnterSTANDBYMode();//進入待機
//PWR_EnterSTOPMode(PWR_Regulator_ON, PWR_STOPEntry_WFI|PWR_STOPEntry_WFE);//進入停機
}ast
進入的待機模式和停機模式很簡單,基本同樣。那麼問題來了。變量
主要問題有:配置
1:如何對他們進行喚醒?
2:喚醒的鬧鐘中斷可否執行?
2:喚醒後的程序入口在哪?
經過各類實驗和查資料,獲得了以下結論:(本實驗經過設定RTC_SetAlarm(RTC_GetCounter()+4); 爲設置4S後進行鬧鐘喚醒,並開啓鬧鐘中斷,手冊中能夠查到鬧鐘中斷能產生喚醒,故用鬧鐘中斷進行實驗)
先研究待機模式下的喚醒,在鬧鐘中斷函數以下:
void RTCAlarm_IRQHandler(void)
{
if(RTC_GetFlagStatus(RTC_IT_ALR))
{
RTC_ClearITPendingBit(RTC_IT_ALR);
RTC_WaitForLastTask();
EXTI_ClearITPendingBit(EXTI_Line17);
if(PWR_GetFlagStatus(PWR_FLAG_WU) != RESET)
{
PWR_ClearFlag(PWR_FLAG_WU);
}
GPIO_WriteBit(GPIOA, GPIO_Pin_5, 0);//LED指示
}
}
實驗結果:PA5的LED不指示,而且從其餘LED燈的指示能夠知道程序又從新開始運行。也就是被複位。
所以待機模式下的喚醒結論以下:
1:喚醒形式直接產生鬧鐘中斷就能喚醒。
2:喚醒後不會進入鬧鐘中斷函數
3:喚醒後程序復位,從新執行
再研究停機模式下的喚醒,停機模式喚醒和待機喚醒差異很大,開始還覺得二者相同,停機喚醒相對複雜些,中途調試了很長時間,才明白了停機喚醒的過程,貼上鬧鐘中斷程序以下:
char Wakeflag=0;
void RTCAlarm_IRQHandler(void)
{
if(RTC_GetFlagStatus(RTC_IT_ALR))
{
EXTI_ClearITPendingBit(EXTI_Line17);
RTC_ClearITPendingBit(RTC_IT_ALR);
RTC_WaitForLastTask();
EXTI_ClearITPendingBit(EXTI_Line7);
EXTI_ClearITPendingBit(EXTI_Line1);//對於程序可能產生的標誌位必須的清除乾淨,不清除會出現喚醒失靈現象!!
if(PWR_GetFlagStatus(PWR_FLAG_WU) != RESET)
{
PWR_ClearFlag(PWR_FLAG_WU);//通常沒用
}
SystemInit();//重要,因爲停機下對全部時鐘關閉,因此喚醒須要從新配置時鐘!!
Wakeflag=!Wakeflag;
GPIO_WriteBit(GPIOA, GPIO_Pin_5, Wakeflag);//LED燈指示
}
}
相比待機的鬧鐘中斷是不復雜了不少,停機模式下的喚醒的中斷函數須要注意這兩點(能獲得這兩點,耗費了大量時間,終於仍是搞定了,嗨皮!!):
1:重要,對於程序可能產生的標誌位必須的清除乾淨,不清除會出現喚醒失靈現象!!
2:重要,因爲停機下對全部時鐘關閉,因此喚醒須要從新配置時鐘!!
實驗現象:LED能夠產生開通與關斷的效果。而且從其餘LED的指示能夠看到程序沒有被複位,而是繼續原來運行。
所以停機模式下的喚醒結論以下:
1:喚醒形式產生鬧鐘中斷不必定就喚醒,須要對任何可能的標誌位清楚,而且時鐘要從新配置。
2:喚醒後進入鬧鐘中斷函數
3:喚醒後程序進入鬧鐘中斷函數,而後再進入原來停機的位置繼續運行。沒有復位,單片機寄存器裏的各類變量值仍然保留!!
---------------------
做者:ludaoyi123
來源:CSDN
原文:https://blog.csdn.net/ludaoyi88/article/details/50834303