最近学习ucos的移植代码。看到开关中断处。有点问题
首先ucos支持三种开关中断方式
下面是pc移植的代码(ucos官方)
#define OS_CRITICAL_METHOD 2
#if OS_CRITICAL_METHOD == 1
#define OS_ENTER_CRITICAL() asm CLI /* Disable interrupts */
#define OS_EXIT_CRITICAL() asm STI /* Enable interrupts */
#endif
#if OS_CRITICAL_METHOD == 2
#define OS_ENTER_CRITICAL() asm {PUSHF; CLI} /* Disable interrupts */
#define OS_EXIT_CRITICAL() asm POPF /* Enable interrupts */
#endif
#if OS_CRITICAL_METHOD == 3
#define OS_ENTER_CRITICAL() (cpu_sr = OSCPUSaveSR()) /* Disable interrupts */
#define OS_EXIT_CRITICAL() (OSCPURestoreSR(cpu_sr)) /* Enable interrupts */
第一种方式最简单,就不再说了。
问题是后面两种方式,这两种方式都是为了解决如下情况,逻辑一样,只是一个存到栈,一个存到变量cpu_sr中了
1.OS_ENTER_CRITICAL()
2.。。。。。。。。。。。代码
3. OS_ENTER_CRITICAL()
4. 。。。。。。。。用户代码
5. OS_EXIT_CRITICAL()
6.。。。。。。。。。。代码
7.OS_EXIT_CRITICAL()
如果这种情况用 第一种方式不能保证 1-7行中断都是关着的,因为第5行调用了开中断指令
所以用后两种方式就很好的解决了这个问题
!!!!!!!
这才有我的问题。问题处在(比如第二种方式)
#if OS_CRITICAL_METHOD == 2
#define OS_ENTER_CRITICAL() asm {PUSHF; CLI} /* Disable interrupts */
#define OS_EXIT_CRITICAL() asm POPF /* Enable interrupts */
这样的话 pushf实现了保存状态标志,在退出 关中断的时候popf出栈恢复 标志寄存器内容
但是pushf不仅会将中断允许标志压入栈,同时会将其他标志,比如ZF。OF压入。那么问题就来了。调用popf恢复的中断状态标志就变成了代码第 3行执行处的标志状态了。。。。。。。。。
里面的ZF OF等标志也会恢复到了第三行的状态,正常的话那么第6行以后的代码执行应该用第5行执行后的状态标志,但是因为pushf popf的调用,那么ZF OF等的标志只是第三行的标志态。。。。岂不是执行程序就不对了
想了很久,很纠结,希望高手指教
QQ:1183557534,有知道的请回帖或联系我
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
一周热门 更多>