humjb_1983 发表于 2014-12-24 15:29

中断返回时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)

humjb_1983 发表于 2014-12-29 09:02

最近大家都休息么?呵呵,帮忙解惑下~
页: [1]
查看完整版本: 中断返回时resume_kernel中的疑问,请指教。