這兩天研究了stm32的低功耗知識,低功耗裡主要研究的是stm32的待機模式和停機模式
。讓微控制器進入的待機模式和停機模式比較容易,實驗中通過設定中斷口pa1來響應待機和停機模式。
voidexti1_irqhandler(void)}}
void standby()
進入的待機模式和停機模式很簡單,基本一樣。那麼問題來了。
主要問題有:
1:如何對他們進行喚醒?
2:喚醒的鬧鐘中斷能否執行?
2:喚醒後的程式入口在哪?
通過各種實驗和查資料,得到了如下結論:(本實驗通過設定rtc_setalarm(rtc_getcounter()+4); 為設定4s後進行鬧鐘喚醒,並開啟鬧鐘中斷,手冊中可以查到鬧鐘中斷能產生喚醒,故用鬧鐘中斷進行實驗)
先研究待機模式下的喚醒,在鬧鐘中斷函式如下:
voidrtcalarm_irqhandler(void)
gpio_writebit(gpioa, gpio_pin_5, 0);//
led指示}}
實驗結果:pa5的led不指示,並且從其他led燈的指示可以知道程式又重新開始執行。也就是被復位。
因此待機模式下的喚醒結論如下:
1:喚醒形式直接產生鬧鐘中斷就能喚醒。
2:喚醒後不會進入鬧鐘中斷函式
3:喚醒後程式復位,重新執行
再研究停機模式下的喚醒,停機模式喚醒和待機喚醒差別很大,開始還以為兩者相同,停機喚醒相對複雜些,中途除錯了很長時間,才明白了停機喚醒的過程,貼上鬧鐘中斷程式如下:
char wakeflag=0;
voidrtcalarm_irqhandler(void)
systeminit();//重要,由於停機下對所有時鐘關閉,所以喚醒需要重新配置時鐘!!
wakeflag=!wakeflag;
gpio_writebit(gpioa, gpio_pin_5, wakeflag);//led
燈指示}
}相比待機的鬧鐘中斷是不複雜了很多,停機模式下的喚醒的中斷函式需要注意這兩點(能得到這兩點,耗費了大量時間,終於還是搞定了,嗨皮!!):
1:重要,對於程式可能產生的標誌位必須的清除乾淨,不清除會出現喚醒失靈現象!!
2:重要,由於停機下對所有時鐘關閉,所以喚醒需要重新配置時鐘!!
實驗現象:led可以產生開通與關斷的效果。並且從其他led的指示可以看到程式沒有被復位,而是繼續原來執行。
因此停機模式下的喚醒結論如下:
1:喚醒形式產生鬧鐘中斷不一定就喚醒,需要對任何可能的標誌位清楚,並且時鐘要重新配置。
2:喚醒後進入鬧鐘中斷函式
3:喚醒後程式進入鬧鐘中斷函式,然後再進入原來停機的位置繼續執行。沒有復位,微控制器暫存器裡的各種變數值仍然保留!!
stm32晶元休眠模式 stm32實現待機喚醒
stm32的低功耗模式有3種 1 睡眠模式 cm3核心停止,外設仍然執行 2 停機模式 所有時鐘都停止 3 待機模式 1.8v核心電源關閉 進入待機模式的方法,以及設定wk up引腳用於把stm32從待機模式喚醒的方法 一般步驟如下 1 設定sleepdeep位 scb scr的第二位 2 使能電源...
STM32的停機模式與喚醒
這個星期弄停機模式,下面是 hal init systemclock config mx gpio init mx dma init mx adc init mx lpuart1 uart init mx usart1 uart init mx rtc init workfinished 0 工作沒...
stm32晶元休眠模式 STM32最小系統簡單介紹
stm32是一款高效能,低功耗,低成本的嵌入式arm晶元,其家族產品大致劃分如圖 stm32型號說明,以stm32f103zet6晶元為例 stm32 f103ze t6arm cortex m核心32位微控制器 晶元系列 增強型席系列 引腳數,fash容量 封裝型別 工作溫度範圍 引腳數取值說明 ...