专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
关于keil C语言内联汇编不能达到预期目的的问题
2019-07-14 18:42
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
9875
7
1290
本人在学习STM睡眠模式时,使用__WFI() 这句能达到进入睡眠模式后,任意中断能唤醒并接着执行下面的程序,但是使用原子例程中的
__asm void WFI_SET(void)
{
WFI;
}
这个函数,能进入睡眠模式,但是当任意中断触发时,只能进入中断处理中断服务程序中的内容,不能接着执行主程序下面的程序。
求大神解答,两种方式为何会出现这种差别?
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
7条回答
南山南北海北
2019-07-15 11:25
void Sys_LowPower(u8 var)
{
RCC->APB1ENR |= 1<<28; //使能电源时钟
/*
SCB->SCR |= 0<<4; //SETONPEND 置位,它就会不错过任何一个事件,在发生事件时一定把处理器唤醒
SCB->SCR |= 0<<2; //SLEEPDEEP位清零表示睡眠,置位表示深度睡眠()
SCB->SCR |= 0<<1; //SLEEPONEXIT位清零,直接进入睡眠模式,置位,从最低优先级的中断退出后才进入
*/
switch(var)
{
case 0:{ break; } //WFI进入睡眠模式,M3内核停止工作
case 1:{ //PDDS+LPDS+SLEEPDEEP+WFI进入停机模式,除了SRAM,其他都断电
SCB->SCR |= 1<<2; //使能SLEEPDEEP位 (SYS->CTRL)
PWR->CR |= 1<<0; //LPDS置位,深度睡眠下的低功耗
PWR->CR |= 0<<1; //PDDS置位(你妹的,坑了我一大早上,这个位是让CPU进入深度睡眠时进入待机模式,原来的程序是置位)
break;
}
case 2:{ //PDDS+SLEEPDEEP+WFI进入待机模式,全部断电,备份的寄存器和待机电路维持供电
SCB->SCR |= 1<<2; //使能SLEEPDEEP位 (SYS->CTRL)
PWR->CR|=1<<1; //PDDS置位(这里才需要置位,进入待机模式)
//唤醒使用的是WKUP,若需要其他方式唤醒,需重新配置
PWR->CR |= 1<<2; //清除Wake-up 标志
PWR->CSR |= 1<<8; //WKUP引脚用于将CPU从待机模式唤醒
break;
}
}
// WFI_SET(); //执行WFI指令,使用这种方式的内嵌汇编,睡眠模式下不能接着执行程序
__WFI(); //
我说的就是这两句有区别,WFI_SET()是原子例程里面的,__WFI()是侧面cm3.h里面的
SCB->SCR &= ~(1<<2); //失能SLEEPDEEP位 (SYS->CTRL)
}
加载中...
查看其它7个回答
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
{
RCC->APB1ENR |= 1<<28; //使能电源时钟
/*
SCB->SCR |= 0<<4; //SETONPEND 置位,它就会不错过任何一个事件,在发生事件时一定把处理器唤醒
SCB->SCR |= 0<<2; //SLEEPDEEP位清零表示睡眠,置位表示深度睡眠()
SCB->SCR |= 0<<1; //SLEEPONEXIT位清零,直接进入睡眠模式,置位,从最低优先级的中断退出后才进入
*/
switch(var)
{
case 0:{ break; } //WFI进入睡眠模式,M3内核停止工作
case 1:{ //PDDS+LPDS+SLEEPDEEP+WFI进入停机模式,除了SRAM,其他都断电
SCB->SCR |= 1<<2; //使能SLEEPDEEP位 (SYS->CTRL)
PWR->CR |= 1<<0; //LPDS置位,深度睡眠下的低功耗
PWR->CR |= 0<<1; //PDDS置位(你妹的,坑了我一大早上,这个位是让CPU进入深度睡眠时进入待机模式,原来的程序是置位)
break;
}
case 2:{ //PDDS+SLEEPDEEP+WFI进入待机模式,全部断电,备份的寄存器和待机电路维持供电
SCB->SCR |= 1<<2; //使能SLEEPDEEP位 (SYS->CTRL)
PWR->CR|=1<<1; //PDDS置位(这里才需要置位,进入待机模式)
//唤醒使用的是WKUP,若需要其他方式唤醒,需重新配置
PWR->CR |= 1<<2; //清除Wake-up 标志
PWR->CSR |= 1<<8; //WKUP引脚用于将CPU从待机模式唤醒
break;
}
}
// WFI_SET(); //执行WFI指令,使用这种方式的内嵌汇编,睡眠模式下不能接着执行程序
__WFI(); //我说的就是这两句有区别,WFI_SET()是原子例程里面的,__WFI()是侧面cm3.h里面的
SCB->SCR &= ~(1<<2); //失能SLEEPDEEP位 (SYS->CTRL)
}
一周热门 更多>