中断返回时resume_kernel中的疑问,请指教。
entry_32.S问题是:
testl $X86_EFLAGS_IF,PT_EFLAGS(%esp) # interrupts off (exception path) ?
这句,看注释的意思应该是:当检测到EFLAGS中IF标记清零时(即表示关中断时),表示是exception path,按我的理解:中断走中断门,进入中断时会自动关中断(清IF标记);而异常应该走陷阱门,应不会自动关中断,所以,这里好像说反了?求解。。。
ENTRY(resume_kernel)
/*
* 前面已经关了中断了,这次再关的原因是,还有其它流程会自己跳转
* 到这里,比如system_call
*/
DISABLE_INTERRUPTS(CLBR_ANY)
/*判断是否可以抢占*/
cmpl $0,TI_preempt_count(%ebp) # non-zero preempt_count ?
/*抢占计数非0,不能抢占,则不产生调度,直接恢复上下文*/
jnz restore_all
/*可以抢占,则需要调度*/
need_resched:
/*判断need_resched是否被设置*/
movl TI_flags(%ebp), %ecx # need_resched set ?
testb $_TIF_NEED_RESCHED, %cl
/*没设置need_resched,则不需要调度,直接恢复上下文*/
jz restore_all
/*
*判断发生中断时(因为PT_EFLAGS(%esp)中保存的是进入中断时的EFLAGS值,这是由CPU硬件自动压栈的,中断走中断门,会自动关中断,异常走陷阱门,不自动关中断)是否关中断了,如果关了,表示是异常上下文?(应该是中断吧),则直接恢复上下文。
*/
testl $X86_EFLAGS_IF,PT_EFLAGS(%esp) # interrupts off (exception path) ?
jz restore_all
/*如果没关中断,表示为中断上下文?则调用preempt_schedule_irq,进行调度*/
call preempt_schedule_irq
jmp need_resched
END(resume_kernel) 最近大家都休息么?呵呵,帮忙解惑下~
页:
[1]