免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1719 | 回复: 0
打印 上一主题 下一主题

中断处理函数内的休眠的简单解释 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-11-30 11:49 |只看该作者 |倒序浏览
假设你有一段代码用于休眠

int count = 0x00FFFFFF;
while(count--);

情况一.中断处理前半段的休眠

1.内核在此处是关中断执行的,所以任何的可屏蔽中断都得不到响应.
缺页异常??CPU一直在你的while里正常执行,所以缺页异常是不存在的,因为没有触发的条件
除0异常??CPU一直在你的while里正常执行,哪来的除0异常,也是没有触发的条件
调度??CPU一直在你的while里正常执行,怎么能去执行其他地址的指令而产生调度
想想有什么异常可以导致CPU重新跳转到新的指令地址去执行??

2.除非有一个硬件外设可以突发产生一个不可屏蔽中断,并且优先级比你正在执行的中断高.
假设这种情况真的产生了,CPU的确跳转到这个新的中断处理函数去执行,但因为这次中断的产生是在内核中的,所以堆栈并不发生切换,使用的仍然是内核堆栈.在这个中断返回以后,仍然回到你的这段休眠代码,最终等这个while循环结束以后,你的中断返回了,才会继续到其他地址执行(中断进入前的地址)

3.如果你的休眠是while(1);那除了上述2可以得到CPU执行外,内存中其他所有指令都得不到执行.内核挂掉了.

情况二.中断处理后半段的休眠(bh)

1.内核在此处是开中断执行的,所以任何中断和异常都可以打断这段代码的执行,但执行的情况跟上述情况一的2类似.

2.如果你的休眠是while(1);那除了所有中断可以得到CPU执行外,内存中其他所有指令都得不到执行.内核除中断和异常处理外都挂掉了,应用层也挂掉了.

[ 本帖最后由 readkernel 于 2009-11-30 12:01 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP