资源描述:
《do_irq()分析及相关知识介绍》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、asmlinkageunsignedintdo_IRQ(strucept_regsregs) 1、 首先取得中断号,并且获取对应的irq_desc: intirq=regs.orig_eax&0xff; //highbitsusedinret_from_code intcpu=smp_processor_id();irq_desc_t*desc=irq_desc+irq;2、 对中断芯片(模块)应答:desc->handler->ack(irq);3、 修改它的状态(注:觉得这些状态只有在SMP下才有意义):
2、status=desc->status&~(IRQ_REPLAY
3、IRQ_WAITING);status
4、=IRQ_PENDING; /*we_want_tohandleit*/IRQ_REPLAY是指如果被禁止的中断号上又产生了中断,这个中断是不会被处理的,当这个中断号被允许产生中断时,会将这个未被处理的中断转为IRQ_REPLAY。IRQ_WAITING探测用,探测时会将所有没有挂处理函数的中断号上设置IRQ_WAITING,如果这个中断号上有中断产生,就把这个状态去掉,因此,我们就可以知道哪些中断引脚上产生过中断
5、了。IRQ_PENDING,IRQ_INPROGRESS是为了确保:(1)同一个中断号的处理程序不能重入;(2)不能丢失这个中断号的下一个处理程序。具体的说,当内核在运行某个中断号对应的处理程序(链)时,状态会设置成IRQ_INPROGRESS。如果……时,发现已经有一个实例在运行了,就将这下一个中断标注为IRQ_PENDING,然后返回。这个已在运行的实例结束的时候,会查看是否期间有同一中断发生了,是则再次执行一遍。这些状态的操作不是在什么情况下都必须的。多个CPU比较复杂,因为CPU由LocalAPIC,每个都有自己的中
6、断,但是它们可能调用同一个函数,比如时钟中断,每个CPU都可能产生,它们都会调用时钟中断处理函数。从I/OAPIC传过来的中断,如果是电平触发,也不会,因为在结束发出EOI前,这个引脚上是不接收中断信号。如果是边沿触发,要么是开中断,要么I/OAPIC选择不同的CPU,在这两种情况下,会有重入的可能。/* *IftheIRQisdisabledforwhateverreason,wecannot *usetheactionwehave. */ action=NULL;
7、 if(!(status&(IRQ_DISABLED
8、IRQ_INPROGRESS))){ action=desc->action; status&=~IRQ_PENDING; /*wecommittohandling*/ status
9、=IRQ_INPROGRESS; /*wearehandlingit*//*进入执行状态*/ } desc->status=status; /* *Ifther
10、eisnoIRQhandleroritwasdisabled,exitearly. SincewesetPENDING,ifanotherprocessorishandling adifferentinstanceofthissameirq,theotherprocessor willtakecareofit. */ if(!action) gotoout; /*要么该中断没有处理函数;要么被禁止运行(IRQ_DISA
11、BLE);要么有一个实例已经在运行了*/ /* *Edgetriggeredinterruptsneedtoremember *pendingevents. *Thisappliestoanyhwinterruptsthatallowasecond *instanceofthesameirqtoarrivewhileweareindo_IRQ *orinthehandler.Butthecodehereonlyhandlesthe_second_
12、 *instanceoftheirq,notthethirdorfourth.Soitismostly *usefulforirqhardwarethatdoesnotmaskcleanlyinan *SMPenvironment. */ f