假设你有一段代码用于休眠
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执行外,内存中其他所有指令都得不到执行.内核除中断和异常处理外都挂掉了,应用层也挂掉了.