你的浏览器版本过低,可能导致网站不能正常访问!为了你能正常使用网站功能,请使用这些浏览器。
举报
qinyunti 发表于 2019-6-24 16:51 确实有缺陷,理论上HALT之前要应该能禁止中断,HALT指令能自动使能中断
zh874176706 发表于 2017-6-20 11:18 这没区别呀,在else与halt之间照样可以产生中断。导致中断产生的标志位不能被主循环处理就进入休眠。 ...
zh874176706 发表于 2017-6-15 07:29 不知道如何解决这种临界点bug
ic界中lol打的最好的 发表于 2017-6-15 09:28 不是呀,只有当f_sleep=1 才执行halt(),进入中断f_sleep=0了,返回后执行halt()然后继续判断,发现f_s ...
zh874176706 发表于 2017-6-15 21:49 halt()是休眠指令
Inc_brza 发表于 2017-6-16 09:18 这根hal指令本身有啥关系~
zcl201207 发表于 2017-6-19 19:59 你有这种担心,那就改成这样啊: if(sleep==0) {
zcl201207 发表于 2017-6-20 20:41 是你想多了。。。 如果你觉得这个地方很重要,那么就用汇编啊,过滤你觉得多余的指令。。。 ...
经过实测HALT指令确实可以自动使能中断,HALT指令没问题。
在使用HALT指令前要关闭中断,避免HALT前产生中断破坏逻辑。
我的一个使用情况,之前版本
gHaltWakeFlag=0;
GPIOC->CR2 |= (uint8_t)((uint8_t)1<<4); /*PC4 使能输入中断 */
__asm("HALT");
存在一定概率使能引脚中断配置之后,HALT指令之前马上进入中断,
而我的中断服务函数是进入中断后关闭引脚中断设置标志,唤醒后去查询该标志。
INTERRUPT_HANDLER(EXTI_PORTC_IRQHandler, 5)
{
/*关闭中断*/
GPIOC->CR2 &= (uint8_t)(~(uint8_t)((uint8_t)1<<4)); /*PC4 不使能输入中断*/
gHaltWakeFlag=1;
}
存在一定概率HALT之前又进入中断服务函数关闭了引脚中断,导致无法唤醒。
修改后如下:
__disable_interrupt();
gHaltWakeFlag=0;
GPIOC->CR2 |= (uint8_t)((uint8_t)1<<4); /*PC4 使能输入中断 */
__asm("HALT");
保证了HALT之前不会产生中断,而HALT指令会自动使能中断允许唤醒
是你想多了。。。
如果你觉得这个地方很重要,那么就用汇编啊,过滤你觉得多余的指令。。。
为了避免HALT指令前进入中断破坏逻辑,可以将临界段先关中断保护__diabale_interrupt();
HALT指令会自动使能中断,允许外部中断唤醒。
halt()是休眠指令
应该是根据f_sleep来判断的,所谓休眠就是f_sleep=1持续一段时间,否则 一休眠就醒不来了
我的意思是就算在halt()指令与上一条指令之间发生中断也不能让单片机休眠,如何做到。
if(sleep==0)
{
xxxx;
}else
{
halt();
}
这没区别呀,在else与halt之间照样可以产生中断。导致中断产生的标志位不能被主循环处理就进入休眠。
也许只能用汇编解决这个问题了,所以我觉得这是stm8的一个缺陷
也许只能用汇编解决这个问题了,所以我觉得这是stm8的一个缺陷。