你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

关于停机模式唤醒的问题

[复制链接]
miracle533 提问时间:2018-3-3 09:37 /
阅读主题, 点击返回1楼
收藏 评论28 发布时间:2018-3-3 09:37
28个回答
miracle533 回答时间:2018-3-3 11:50:11
换成407试了一下还是不行,下面是进入停机的函数
void Sys_Enter_Standby(void)
{               
  while(WK_UP==0);                        //等待WK_UP按键松开(在有RTC中断时,必须等WK_UP松开再进入待机)
        printf("停机");
  delay_ms(50);
        RCC_AHB1PeriphResetCmd(0X04FF,ENABLE);//复位所有IO口
       
        RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);//使能PWR时钟                 
         
        PWR_BackupAccessCmd(ENABLE);//后备区域访问使能

        RTC_ITConfig(RTC_IT_TS|RTC_IT_WUT|RTC_IT_ALRB|RTC_IT_ALRA,DISABLE);//关闭RTC相关中断,可能在RTC实验打开了。
        RTC_ClearITPendingBit(RTC_IT_TS|RTC_IT_WUT|RTC_IT_ALRB|RTC_IT_ALRA);//清楚RTC相关中断标志位。

        EXTI_ClearITPendingBit(EXTI_Line0);
        EXTI_ClearITPendingBit(EXTI_Line13);       
//        PWR_ClearFlag(PWR_FLAG_WU);//清除Wake-up 标志
//       
//        PWR_WakeUpPinCmd(ENABLE);//设置WKUP用于唤醒
       
//        PWR_EnterSTANDBYMode();        //进入待机模式
       
        PWR_EnterSTOPMode(PWR_Regulator_ON,PWR_STOPEntry_WFI);
       
        SystemInit();        
         
}
回答时间:2018-3-3 13:32:00
resetIO时钟以后,重新设置IO时钟,并且配置外部中断。我没有看到IO口状态的配置和外部中断的配置。
miracle533 回答时间:2018-3-3 14:12:37
安 发表于 2018-3-3 13:32
resetIO时钟以后,重新设置IO时钟,并且配置外部中断。我没有看到IO口状态的配置和外部中断的配置。 ...

按键的配置:
void KEY_Init(void)
{       
  GPIO_InitTypeDef  GPIO_InitStructure;

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; //KEY0 KEY1 KEY2对应引脚
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;//普通输入模式
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100M
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
  GPIO_Init(GPIOE, &GPIO_InitStructure);//初始化GPIOE2,3,4


  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_13; //KEY0 KEY1 KEY2对应引脚
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;//普通输入模式
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100M
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
  GPIO_Init(GPIOC, &GPIO_InitStructure);//初始化GPIOE2,3,4
}

外部中断的配置
void EXTI_Configuration(void)
{
        EXTI_InitTypeDef EXTI_InitStructure;
       
        SYSCFG_EXTILineConfig(EXTI_PortSourceGPIOE, EXTI_PinSource0);
        SYSCFG_EXTILineConfig(EXTI_PortSourceGPIOC, EXTI_PinSource13);

        EXTI_InitStructure.EXTI_Line=EXTI_Line0;                       
        EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;                        
        EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;                   
        EXTI_InitStructure.EXTI_LineCmd = ENABLE;                        
        EXTI_Init(&EXTI_InitStructure);       
       
       
        EXTI_InitStructure.EXTI_Line=EXTI_Line13;                        
        EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;                      
        EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;            
        EXTI_InitStructure.EXTI_LineCmd = ENABLE;                        
        EXTI_Init(&EXTI_InitStructure);       
}
miracle533 回答时间:2018-3-3 14:21:47
这两个中断单独进入中断函数都是可以的,就是不能够唤醒,所以我怀疑要么是上面的void Sys_Enter_Standby()函数错了,要么就是硬件问题了。。
回答时间:2018-3-3 15:02:07
进入STOP模式之前,重新配置一下对应IO时钟、中断配置。
miracle533 回答时间:2018-3-3 15:11:29
安 发表于 2018-3-3 15:02
进入STOP模式之前,重新配置一下对应IO时钟、中断配置。


void Sys_Enter_Standby(void)   
{               
       
        SystemInit();

        RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR,ENABLE);        /* 84MHZ*/
               

        RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_SYSCFG, ENABLE);


        RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOC | RCC_AHB1Periph_GPIOE | RCC_AHB1Periph_GPIOD | RCC_AHB1Periph_GPIOA, ENABLE);               

        KEY_Init();   //这个是配置按键IO口的函数
        EXTI_Configuration();        //这个是配置中断的函数
                       
        printf("停机,重新配置");
  delay_ms(50);
        RCC_AHB1PeriphResetCmd(0X04FF,ENABLE);//复位所有IO口
       
//        RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);//使能PWR时钟                 
         
//        PWR_BackupAccessCmd(ENABLE);//后备区域访问使能

        RTC_ITConfig(RTC_IT_TS|RTC_IT_WUT|RTC_IT_ALRB|RTC_IT_ALRA,DISABLE);//关闭RTC相关中断,可能在RTC实验打开了。
        RTC_ClearITPendingBit(RTC_IT_TS|RTC_IT_WUT|RTC_IT_ALRB|RTC_IT_ALRA);//清楚RTC相关中断标志位。

        EXTI_ClearITPendingBit(EXTI_Line0);
        EXTI_ClearITPendingBit(EXTI_Line13);
        EXTI_ClearITPendingBit(EXTI_Line2);       
       
//        PWR_ClearFlag(PWR_FLAG_WU);//清除Wake-up 标志
//       
//        PWR_WakeUpPinCmd(ENABLE);//设置WKUP用于唤醒
       
//        PWR_EnterSTANDBYMode();        //进入待机模式
       
        PWR_EnterSTOPMode(PWR_Regulator_ON,PWR_STOPEntry_WFI);
       
        SystemInit();        
         
}
miracle533 回答时间:2018-3-3 15:12:55
是这个意思吗,,我这么配置了还是不行
回答时间:2018-3-3 15:26:15
配置放在 RCC_AHB1PeriphResetCmd(0X04FF,ENABLE);后面。
miracle533 回答时间:2018-3-3 15:30:40
安 发表于 2018-3-3 15:26
配置放在 RCC_AHB1PeriphResetCmd(0X04FF,ENABLE);后面。

还是不能唤醒。。
void Sys_Enter_Standby(void)
{               

  while(WK_UP==0);                        //等待WK_UP按键松开(在有RTC中断时,必须等WK_UP松开再进入待机)
        printf("停机,重新配置");
  delay_ms(50);
        RCC_AHB1PeriphResetCmd(0X04FF,ENABLE);//复位所有IO口
       
        SystemInit();

        RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR,ENABLE);        /* 84MHZ*/
               
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_SYSCFG, ENABLE);/* 168MHZ */

        RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOC | RCC_AHB1Periph_GPIOE | RCC_AHB1Periph_GPIOD | RCC_AHB1Periph_GPIOA, ENABLE);               

        KEY_Init();            /* 按键配置 */
        EXTI_Configuration();        /* 外部中断配置 */
       
//RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);//使能PWR时钟                 

        RTC_ITConfig(RTC_IT_TS|RTC_IT_WUT|RTC_IT_ALRB|RTC_IT_ALRA,DISABLE);//关闭RTC相关中断,可能在RTC实验打开了。
        RTC_ClearITPendingBit(RTC_IT_TS|RTC_IT_WUT|RTC_IT_ALRB|RTC_IT_ALRA);//清楚RTC相关中断标志位。

        EXTI_ClearITPendingBit(EXTI_Line0);
        EXTI_ClearITPendingBit(EXTI_Line13);
        EXTI_ClearITPendingBit(EXTI_Line2);       
                       
        PWR_EnterSTOPMode(PWR_Regulator_ON,PWR_STOPEntry_WFI);                 
}
回答时间:2018-3-3 15:45:48
我是如下配置,可以的:
/* Configure PC13 pin as input floating */
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_13;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  GPIO_Init(GPIOC, &GPIO_InitStructure);

  /* Connect EXTI Line13 to PC13 pin */
  SYSCFG_EXTILineConfig(EXTI_PortSourceGPIOC, EXTI_PinSource13);
  /* EXTI configuration *********************************************************/
  EXTI_ClearITPendingBit(EXTI_Line13);
  EXTI_InitStructure.EXTI_Line = EXTI_Line13;
  EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
  EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising_Falling;
  EXTI_InitStructure.EXTI_LineCmd = ENABLE;
  EXTI_Init(&EXTI_InitStructure);  
  /* Enable the RTC Alarm Interrupt */
        Std_NVIC_SetPriority(EXTI15_10_IRQn, 0, 0);
  EXTI_ClearITPendingBit(EXTI_Line13);

所属标签

相似问题

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32Cube扩展软件包
意法半导体边缘AI套件
ST - 理想汽车豪华SUV案例
ST意法半导体智能家居案例
STM32 ARM Cortex 32位微控制器
关注我们
st-img 微信公众号
st-img 手机版