当前位置:首页 > 单片机 > 单片机
[导读]在深度睡眠模式,除了BOD模块和看门狗振荡器的时钟可以继续工作,其它所有的时钟都会停止工作。可以通过PDSLEEPCFG寄存器来配置在深度睡眠模式期间BOD模块和看门狗振荡器是否需要工作。在深度睡眠模式,消除了flash、

在深度睡眠模式,除了BOD模块和看门狗振荡器的时钟可以继续工作,其它所有的时钟都会停止工作。可以通过PDSLEEPCFG寄存器来配置在深度睡眠模式期间BOD模块和看门狗振荡器是否需要工作。

在深度睡眠模式,消除了flash、所有模拟外设、处理器自身、存储器、相关控制器和内部总线的功耗。处理器的状态和寄存器、外设的寄存器、内部SRAM的数据和单片机引脚的电平保持不变。

在深度睡眠模式,看门狗振荡器是唯一可以工作的时钟源。当需要定时器定时唤醒单片机的时候,可以开启看门狗时钟。其它的时钟,诸如系统振荡器、IRC和PLL都会掉电。如果需要看门狗振荡器工作,它的时钟必须设置到最小值,即把WDTOSCCTRL寄存器中的FREQSEL位设置为0001。

当需要定时器唤醒单片机,可以在SYSAHBCLKCTRL寄存器中开启看门狗振荡器和一个通用定时器。

1.怎样进入深度睡眠模式

执行以下步骤进入深度睡眠模式

1. 设置PCON寄存器的DPDEN位为0;

2. 配置PDSLEEPCFG寄存器

a) 如果需要定时器唤醒单片机,在PDRUNCFG寄存器中,把看门狗的时钟打开,然后在MAINCLKSEL把主时钟源选择为看门狗振荡器时钟;

b) 如果不需要定时器唤醒单片机,在PDRUNCFG寄存器中,把看门狗的时钟关闭,把IRC的时钟打开,在MAINCLKSEL寄存器中选择IRC时钟为主时钟源;

3. 配置PDAWAKECFG寄存器;

4. 如果使用外部引脚来唤醒单片机,配置STARTAPRP0,STARTERP0,STARTRSRP0CLR寄存器,初始化外部唤醒引脚,并用NVIC开启该引脚的中断。

5. 在SYSAHBCLKCTRL寄存器中,关闭所有的外设模块。如果用到WDT和定时器,则开启这两的时钟。

6. 设置SCR寄存器中的SLEEPDEEP位为1;

7. 执行WFI指令。

2.进入深度睡眠模式后,如何唤醒单片机

1. 复位

2. 定时器匹配输出引脚唤醒

3. 外部引脚逻辑信号

深度睡眠模式的外部唤醒引脚一共有13个,分别是P0.0~P0.11和P1.0。可以通过配置具体由哪个引脚唤醒,上升沿或下降沿唤醒。可以通过外部信号唤醒,也可以通过单片机自身定时器的匹配输出引脚电平变化功能来实现。当使用定时器匹配引脚时,只能是在P0.1 、P0.8~P0.11引脚上,因为只有这几个引脚有定时器匹配输出功能。

3.示例程序

为了很容易的看到效果,这里用流水灯的运行和停止运行来观察是否进入睡眠模式。开始流水灯执行,过一会儿,进入睡眠模式后,流水灯停止流水。

新建一个工程,结构如下图所示:

在main.c函数中,输入以下代码:

#include"lpc11xx.h"#include"pmu.h"#defineLED1_ONLPC_GPIO1->DATA&=~(1<<0)#defineLED1_OFFLPC_GPIO1->DATA|=(1<<0)#defineLED2_ONLPC_GPIO1->DATA&=~(1<<1)#defineLED2_OFFLPC_GPIO1->DATA|=(1<<1)/***********************************//*函数名称:延时函数*//***********************************/voiddelay(){uint16_ti,j;for(i=0;i<5000;i++)for(j=0;j<200;j++);}/***********************************//*函数名称:LED灯初始化*//***********************************/voidled_init(){LPC_SYSCON->SYSAHBCLKCTRL|=(1<<16);//使能IOCON时钟LPC_IOCON->R_PIO1_0&=~0x07;LPC_IOCON->R_PIO1_0|=0x01;//把P1.0脚设置为GPIOLPC_IOCON->R_PIO1_1&=~0x07;LPC_IOCON->R_PIO1_1|=0x01;//把P1.1脚设置为GPIOLPC_SYSCON->SYSAHBCLKCTRL&=~(1<<16);//禁能IOCON时钟LPC_GPIO1->DIR|=(1<<0);//把P1.0设置为输出引脚LPC_GPIO1->DATA|=(1<<0);//把P1.0设置为高电平LPC_GPIO1->DIR|=(1<<1);//把P1.1设置为输出引脚LPC_GPIO1->DATA|=(1<<1);//把P1.1设置为高电平}/***********************************//*函数名称:主函数*//***********************************/intmain(){uint8_tcnt=0;led_init();while(1){delay();LED1_ON;LED2_OFF;delay();LED1_OFF;LED2_ON;cnt++;if(cnt>20){cnt=0;Entry_Deep_Sleep();}}}

第35行,main函数开始看起。

第37行,定义了一个变量,用来计数。

第38行,初始化led。(关于初始化led的部分,请看第三章内容)

第39行,进入while循环。LED1和LED2将交替闪烁,知道cnt计数到20。

第51行,执行进入深度睡眠模式函数。

在pmu.h文件中,输入以下代码:

#ifndef__LPC11XX_PMU_H#define__LPC11XX_PMU_HexternvoidEntry_Deep_Sleep(void);#endif

在pmu.c文件中,输入以下代码:

#include"lpc11xx.h"#include"pmu.h"voidEntry_Deep_Sleep(void){//step1LPC_PMU->PCON&=~(1<<1);//DPDEN=0;选择sleep/deep-sleep模式//step2LPC_SYSCON->MAINCLKSEL=0x0;/*SelectIRC*/LPC_SYSCON->MAINCLKUEN=0x01;/*UpdateMCLKClockSource*/LPC_SYSCON->MAINCLKUEN=0x00;/*ToggleUpdateRegister*/LPC_SYSCON->MAINCLKUEN=0x01;while(!(LPC_SYSCON->MAINCLKUEN&0x01));/*WaitUntilUpdated*///step3LPC_SYSCON->PDAWAKECFG&=~(1<<5);//SYSOSC_PD唤醒后系统振荡器上电LPC_SYSCON->PDAWAKECFG&=~(1<<7);//SYSPLL_PD唤醒后PLL上电//step4LPC_SYSCON->STARTRSRP0CLR|=(1<<7);//RESETP0.7LPC_SYSCON->STARTAPRP0&=~(1<<7);//配置P0.7脚为唤醒引脚LPC_SYSCON->STARTERP0|=(1<<7);//EnableP0.7脚作为唤醒引脚NVIC_EnableIRQ(WAKEUP7_IRQn);//step5LPC_SYSCON->SYSAHBCLKCTRL=0x01f;//关闭所有外设模块//step6SCB->SCR|=(1<<2);//SLEEPDEEP=1;选择deep_sleep模式//step7__wfi();//写wfi指令进入低功耗模式}voidWAKEUP_IRQHandler(void){//时钟配置LPC_SYSCON->MAINCLKSEL=0x3;/*SelectPLLClockOutput*/LPC_SYSCON->MAINCLKUEN=0x01;/*UpdateMCLKClockSource*/LPC_SYSCON->MAINCLKUEN=0x00;/*ToggleUpdateRegister*/LPC_SYSCON->MAINCLKUEN=0x01;while(!(LPC_SYSCON->MAINCLKUEN&0x01));/*WaitUntilUpdated*///清唤醒标志LPC_SYSCON->STARTRSRP0CLR|=(1<<7);//RESETP0.7LPC_PMU->PCON&=~(1<<8);//SLEEPFLAG标志位清零LPC_SYSCON->SYSAHBCLKCTRL|=(1<<6);//GPIO上电}

在pmu.c文件中,定义了两个函数:

Entry_Deep_Sleep()函数的功能是进入深度睡眠模式。

WAKUP_IRQHandler()是唤醒引脚的中断处理函数。

Entry_Deep_Sleep()函数里面的代

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

中断方式串口接收数据新建一个工程,结构如下图所示:在main.c文件中,输入以下代码:#include “lpc11xx.h”#include “uart.h”uint8_t rec_buf;void UART_IRQH...

关键字: Cortex lpc1114 mo uart 串口中断 收发数据

LPC_IOCON->R_PIO1_0 &= ~0x07;LPC_IOCON->R_PIO1_0 |= 0x02;上面是设置P1.0为AD1的语句。P1.0低三位是引脚功能选择位,所以配置低三位就可以...

关键字: lpc1114 引脚功能 设置

LPC1114内部一共有4个定时器,2个32位定时器,2个16位定时器,使用方式都一样,只是要注意使用16位定时器时,寄存器的值不要超出65535。给它们分别取名称为CT16B0、CT16B1、CT32B0、CT32B1...

关键字: lpc1114 通用定时器

你还在为如何给LPC1114主控的电路板留程序下载接口而烦恼吗?下面瑞生(Ration)以自己曾经做过的项目为例给大家分享一下吧!1.LPC1114如何下载程序?这个当然是你必须要知道的问题。LPC1114一共2种下载方...

关键字: lpc1114 程序下载接口

#include\"ds18b20.h\"uint8_ttemp_sign;voiddelay_ds(uint16_tzz){uint8_txx;uint16_tyy;for(xx=0;xx

关键字: 18b20 lpc1114 测量温度

某同学:你好,看了基础篇SysClk、GPIO、UART的例程,在用到IOCON模块,UART模块在SYSAHBCLKCTRL寄存器中都需要相应时钟允许位置1,IOCON使能,在设置完后又禁能,UART使用时只使能,不用...

关键字: lpc1114 iocon 模块时钟

32位的单片机内部各种数据寄存器和控制寄存器都是32位的,同理,8位单片机内部的数据和控制寄存器都是8位的。例如:AT89C51单片机的“中断控制寄存器”IE定义如下图所示:bit7bit6bit5bit4bit3bit...

关键字: ARM Cortex lpc1114 m0 寄存器配置

新建一个工程,结构如下图所示:timer.h文件和timer.c文件用上一节的。在timer.h中增加两个变量和两个函数的声明,如下所示:#ifndef __NXPLPC11xx_TIME_H__#define __NX...

关键字: lpc1114 pwm 通用定时器

LPC1114的中断,由中断控制模块NVIC控制。一共32个中断,每个中断的优先级可编程为 0~3 四种级别。级别越高对应的优先级越低。因此,级别0 是最高的中断优先级。设置中断优先级的函数,CMISIS已经写好,并嵌入...

关键字: cortex-m0 lpc1114 中断优先级

LPC1114有一个串口,具备标准9针串口的所有功能引脚:RXD、TXD、RTS、CTS、DTR、DSR、DCD、IR一般情况下,我们只用到RXD和TXD。在这一章,只对RXD和TXD的使用做介绍。可以用于程序下载。可以...

关键字: Cortex lpc1114 m0 串口 收发数据 uart查询
关闭
关闭