mxgsgtc 发表于 2016-09-10 19:43

中断执行流程疑问

大家都知道,linux中断流程是
一.当来了一个中断时: do_irq()-->irq_desc.handle_irq--->ISR(驱动程序员来完成)
二.irq_desc.handle_irq这个函数是在linux内核刚开始启动初始化时赋值,可以是handle_edge_irq(用来处理边沿触发)或者handle_level_irq(用来处理电平触发)
问题:
前提:
   假设平台对某一个中断号A初始化为边沿触发,那么中断A到来的流程:
      A--->do_irq()-->handle_edge_irq()--->ISR
问题:
   如果编写驱动时,在ISR中调用函数irq_set_type(),让中断A的触发方式变为电平触发,
①那么当中断A来时的处理流程还是A--->do_irq()--->handle_edge_irq()-->ISR吗?还是
A--->do_irq()-->handle_level_irq()--->ISR?
②如果是A--->do_irq()-->handle_level_irq()--->ISR这个流程,在源码中我并没有发现
irq_desc.handle_irq什么时候被赋值成handle_level_irq()
求大神指点

mournjust 发表于 2016-09-12 18:17

irq_set_type调用irq_set_handler_locked来设置handler。

chengxta 发表于 2016-09-14 00:29

handle_level_irq和handle_edge_irq是High Level中断处理函数,表示两种不同的中断处理方式;
电平触发型中断在有效电平下会持续触发中断,所以需要在中断处理函数中先关闭中断,调用handle_irq_event以后再打开中断,也就是说同一个中断源不会打扰到中断处理函数的执行,中断不会嵌套;
边沿触发型中断会被锁存在硬件的pending寄存器中,可以通过应答方式重新使能,在第一个中断处理过程,仍然可以触发第二个中断,允许中断嵌套;
GPIO中断控制器通常是为所有GPIO中断对应的irq_desc结构设置统一的High Level中断处理函数,具体使用哪个应该看平台和中断控制器的能力吧;
而中断的触发类型是由irq_chip结构的irq_set_type成员设置;

mxgsgtc 发表于 2016-09-14 12:00

mournjust 发表于 2016-09-12 18:17
irq_set_type调用irq_set_handler_locked来设置handler。

非常感谢!
页: [1]
查看完整版本: 中断执行流程疑问