【WB32库开发】第17章 (三)低功耗电源控制——待机模式

本节使用固件库例程PWR中的PWR_STANDBY工程,讲解如何配置WB32进入待机模式。

17.5 待机模式实验

本例程演示如何进入和退出低功耗STANDBY模式:

本例程初始点亮LED1,等待一段时间后启用WKUP管脚并进入低功耗STANDBY模式;

进入STANDBY模式后,管脚状态丢失,LED1熄灭;

然后可以通过按下与WKUP管脚连接的按键或按下复位按键以退出STANDBY模式;

退出STANDBY模式程序重头运行,重复上述过程。

17.5.1 预处理文件、宏定义与函数声明

#include "wb32f10x.h"

void delay(uint32_t n)
{
  while(n--);
}

从此处可以看出,待机模式与前两个低功耗模式的不同之处,没有使用到任何的中断来进行唤醒;

17.5.2 main函数

为了简化实验,需要将main 函数中使用的GPIO引脚从PB14更改为PC13,此举可以通过板载LED灯观察实验现象;

int main(void)
{
  /* 使能GPIOC时钟 */
  RCC_APB1PeriphClockCmd(RCC_APB1Periph_BMX1 |RCC_APB1Periph_GPIOB |RCC_APB1Periph_GPIOC, ENABLE);
	
  GPIO_Init(GPIOC, GPIO_Pin_13, GPIO_MODE_OUT |GPIO_OTYPE_PP |GPIO_PUPD_NOPULL |GPIO_SPEED_HIGH);
  GPIO_ResetBits(GPIOC, GPIO_Pin_13);   // 点亮板载LED

  delay(80000000);

  /* 使能 WKUP 引脚,WB32的WKUP引脚为PA0 */
  PWR_WakeUpPinCmd(ENABLE);

  /* 进入待机模式 */
  PWR_EnterSTANDBYMode();

  while (1)
  {
    /* 板载LED闪烁 */
	GPIO_ToggleBits(GPIOC, GPIO_Pin_13);
    delay(8000000);
  }
}

从主函数的结构和前两次的实验结果来看,预计本次实验整体过程和结果应为:

1)初始化PC13,使用GPIO_ResetBits()函数将PC13置为低电平,点亮板载LED;

2)经过延时后,进入待机模式;

3)将PA0(WKUP)接入板载3.3V后,程序进入循环,板载LED灯不断闪烁。

接下来就看一看实验结果是否如预计的一样。

17.6 实验结果

程序编译后烧录到开发板上,按下复位按键后可以看到板载LED灯点亮,经过延时时间后进入待机模式,板载LED熄灭;

将PA0接入板载3.3V后板载LED重新点亮,但经过延时时间后再次熄灭。

***注意***这与我们预测的结果不同,这是因为:

当WB32进入待机模式时,内核停止,片上外设也停止,内核寄存器、内存的数据会丢失;除了复位引脚、RTC_AF1引脚和WKUP引脚,其他I/O口均工作在高阻态;

当WB32从待机模式被唤起后,相当于芯片被复位,在软件上的表现就是从头开始执行代码;

因此在本例程中就可以看到如上的实验结果。

17.7 总结

本章的内容还差一节,不过关于低功耗的三种模式讲到这里就已经结束了;

WB32有三种低功耗模式可以使用,这三种模式中,睡眠模式和停止模式可以在WB32进入后保存寄存器中的信息,供WB32在唤醒后继续按顺序执行程序,而待机模式被唤醒时只能重头执行程序;

WB32提供的这三个低功耗方式能够满足对功耗有极高要求的项目方案,也希望大家在未来使用设计属于自己的项目时能够灵活应用。

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值