一个纠结很长时间问题,schedule 中断,睡眠
一直有个问题困惑就是linux内核里到底中断,调度和睡眠的关系?基本上把论坛帖子和网上的各种回答都看了一遍,还是没有明确结果,这里先声明共识,避免被喷linux中断上下文肯定不可以睡眠
我的困惑是
1.如果我在软中断里调用sleep,内核会有什么表现,linux是怎么样处理的,2.6内核里schedule函数已经去掉了是否在中断上下文的检查
针对次,我做了个实验,在软中断直接调用schedule让出处理器,内核完全可以正常运行,然后,我又换成msleep休眠1ms,这个时候,内核hand住了,我想请各位谈谈自己的看法,hang住的地方是**的时候,将进程加入队的函数
2.有人说中断切换回去就回不来,我觉得完全可以调度被中断打断的进程,因为中断上下文借用被打断进程内核栈
3.linux里在软中断结束后会返回汇编代码,在里面如果有优先级更高的进程就执行schedule,我想说,这个时间点上下文寄存器没有出栈,应该还是中断上下文吧,为什么在这schedule就可以,我在软中断里就不行,只是时间点提前一些,有什么区别么,这两个世界点 msleep的实现是基于schedule_timeout,后者依赖于timer(并且是stack上的timer),本身又是软中断,出问题的可能性更大一些吧。
估计跟softirq使用独立的stack有关系?
PS,怎么判断hang在wake_up的? 我个人觉得在中断里面也不能切换。由于中断控制器的流程,ACK/DONE等等应答操作。这些相关代码是通用的,每一个irq 的handler只是其中的service 的一部分。
如果在中断中切换,这个流程就不完整,或者说这个流程需要太久的时间。 可以参考本人博客中的文章
页:
[1]