親測實驗,stm32待機模式和停機模式喚醒程序的區別,以及喚醒后程序入口


這兩天研究了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);

RTC_SetAlarm(RTC_GetCounter()+4);  //設置4S后鬧鍾喚醒
RTC_ITConfig(RTC_IT_ALR, ENABLE);//使能鬧鍾中斷. 
RTC_WaitForLastTask();//等待上一次寫RTC任務完成

Standby();             //進入待機(停機)狀態
}
}

}


void Standby()
{
RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR , ENABLE);//開電源管理時鍾PWR_Regulator_LowPower

PWR_WakeUpPinCmd(ENABLE);//使能喚醒引腳,默認PA0

         PWR_EnterSTANDBYMode();//進入待機
          //PWR_EnterSTOPMode(PWR_Regulator_ON, PWR_STOPEntry_WFI|PWR_STOPEntry_WFE);//進入停機
}


進入的待機模式和停機模式很簡單,基本一樣。那么問題來了。

主要問題有:

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
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM