STM32在STOP模式下带看门狗使用RTC定时唤醒

2019-12-14 12:40发布

本帖最后由 lusson 于 2014-5-30 10:07 编辑

STM32F407,使用了狗立看门狗,测试低功耗模式。

STOP模式,用systick唤不醒,所以得改用RTC唤醒,目前设置在256ms唤醒一次,唤醒后跑一遍必要的程序后重新进入STOP。LSI给RTC提供时钟,看门狗设置2S溢出,关SYSTICK,除了需要的2个输出IO,其他全部设置在IN 下拉模式,目前电流是在300uA,唤醒后把KEY输入重新配置为输入上拉,再读取KEY。所有未使用IO线唤醒模式

硬件如下:
电池:单芯锂电池
充电:BQ24073
升压:TPS63000  (输出3.3V)
LDO:XC6206-3.0   (待机时供电)

-----------------------------------
注意几点:
  1.网上说的IO设置在AIN最小并不真实,应该设置在IN模式并且下拉(一定要下拉,不下拉功耗增加非常多)  AIN时在1mA,IN下拉时目前在300uA

主要程序如下:
RTC设置程序:
  1. static void RTC_Configuration(void)
  2. {
  3.     RTC_InitTypeDef RTC_InitStructure;
  4.        
  5.   /*Enable PWR and BKP clocks */
  6.         RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);
  7.   /*Allow access to BKP Domain */
  8.         PWR_BackupAccessCmd(ENABLE);
  9.   /*Enable LSI */
  10.         RCC_HSICmd(ENABLE);
  11.           /*Wait till LSI is ready */
  12.         while (RCC_GetFlagStatus(RCC_FLAG_LSIRDY) == RESET);
  13.   /*Select LSI as RTC Clock Source */
  14.         RCC_RTCCLKConfig(RCC_RTCCLKSource_LSI);
  15.   /*Enable RTC Clock */
  16.         RCC_RTCCLKCmd(ENABLE);
  17.   /*Wait for RTC registers synchronization */
  18.         RTC_WaitForSynchro();

  19.         /*RTC Init */
  20.         RTC_InitStructure.RTC_HourFormat= RTC_HourFormat_24;   //24 hour format
  21.         //32768/ (1 + 0x7F) = 32768 /128 = 256Hz,
  22.         //256/ (1 + 63) = 4Hz, This is the calender frequecy~
  23.         RTC_InitStructure.RTC_SynchPrediv= 63;
  24.         RTC_InitStructure.RTC_AsynchPrediv= 0x7F;
  25.         RTC_Init(&RTC_InitStructure);

  26.         /*NVIC configuration */
  27.         RTC_NVIC_Configuration();

  28.         RTC_WakeUpCmd(DISABLE);     //important
  29.         //Configure the RTC WakeUp Clock source: CK_SPRE (1Hz)
  30.         RTC_WakeUpClockConfig(RTC_WakeUpClock_CK_SPRE_16bits);
  31.         RTC_SetWakeUpCounter(0x0);
  32.         RTC_WakeUpCmd(ENABLE);
  33.         RTC_ClearITPendingBit(RTC_IT_WUT);
  34.         RTC_ITConfig(RTC_IT_WUT,ENABLE);
  35. }
复制代码
  

RTC中断及中断配置程序
  1. void RTC_WKUP_IRQHandler(void)
  2. {
  3.         RTC_ClearITPendingBit(RTC_IT_WUT);
  4.         EXTI_ClearITPendingBit(EXTI_Line22);
  5. }

  6. static void RTC_NVIC_Configuration(void)
  7. {
  8.         NVIC_InitTypeDef NVIC_InitStructure;
  9.         EXTI_InitTypeDef EXTI_InitStructure;

  10.         /*EXTI Configuration */
  11.         EXTI_ClearITPendingBit(EXTI_Line22);
  12.         EXTI_InitStructure.EXTI_Line= EXTI_Line22;
  13.         EXTI_InitStructure.EXTI_Mode= EXTI_Mode_Interrupt;
  14.         EXTI_InitStructure.EXTI_Trigger= EXTI_Trigger_Rising;
  15.         EXTI_InitStructure.EXTI_LineCmd= ENABLE;
  16.         EXTI_Init(&EXTI_InitStructure);
  17.         /*Configure one bit for preemption priority */
  18.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
  19.         /*Enable the RTC Interrupt */
  20.         NVIC_InitStructure.NVIC_IRQChannel = RTC_WKUP_IRQn;
  21.         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
  22.         NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
  23.         NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  24.         NVIC_Init(&NVIC_InitStructure);
  25. }
复制代码

主程序(break表示检测到POWER长押,开机,往下走到正常速度的程序):
  1.                         RTC_Configuration();
  2.                         PWR_FlashPowerDownCmd(ENABLE);
  3.                     while(1){
  4.                                 key_slowtimer_task(SLOW_SLOT_TIME/SLOT_TIME);
  5.                                 key_long_task();
  6.                                 key_decode();
  7.                                 power_long_task();
  8.                                 wdt_long_task();
  9.                                 if ( power_ctrl_status_get() == 1 ){
  10.                                         RCC_RTCCLKCmd(DISABLE);
  11.                                         break;
  12.                                 }
  13.                                 applihand_enter_low_power();
  14.                                 PWR_FlashPowerDownCmd(ENABLE);
  15.                                 PWR_EnterSTOPMode(PWR_Regulator_LowPower, PWR_STOPEntry_WFI);
  16.                                 applihand_wake_power();
  17.                         }
复制代码
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
4条回答
lusson
1楼-- · 2019-12-14 14:18
如果要做低功耗模式在设计外围的时候需要注意一些地方
首先是除MCU以外的外围电源需要单独控制,我这里是使用TPS63000给外围3.3V供电,同时串个肖特基后提供给MCU,MCU待机的LDO串肖特基到MCU,在正常工作时LDO串的肖特基截止(LDO为3V)

IO上拉电阻的选择,如果对外的IO需要上拉电阻,最好把上拉电阻的电源接到外围的电源侧,这样在待机时上拉电阻没电不消耗电流。
不是必要的情况下,输出保持为低。

比如我这里外接了一个SD卡读卡器IC。正常时把这个IC复位,复位电平为低电平,但检测到USB插入时需要把RST拉高。如果未插入USB时也把RST拉高的话,因为这个IC没有VBUS,所以RST会对外消耗电流。
bingxiin8
2楼-- · 2019-12-14 15:22
 精彩回答 2  元偷偷看……
WERWER
3楼-- · 2019-12-14 20:34
我想请问一下 用RTC闹钟中断去唤醒低功耗的STOP模式 是不是一定要配置对应的外部中断17啊?
蚍蜉窝
4楼-- · 2019-12-14 22:27
是一种低功耗的思路,有参考的价值

一周热门 更多>