从零开始理解Linux中断架构(19)--中断线程化irq_thread

        前面一节讲到的中断流处理流程是在hard_irq 流程上,工作在中断堆栈上。还有一种情况是使用中断线程的情形。request_threaded_irq参数中有两个处理函数handler,thread_fn是有区别的。handler主中断处理例程,运行hard_irq 流程上。而如果驱动程序填写thread_fn了,系统就会建立一个内核线程来运行thread_fn,这个中断处理函数运行在thread堆栈上。这个就是你在ps 可以看到诸如此类:

  649 root         0 SW   [irq/19-gpio-key]

   650 root         0 SW   [irq/18-gpio-key]

   编译时如果定义了CONFIG_IRQ_FORCED_THREADING,参数irqflags不包含IRQF_NO_THREAD中断Action都将强制线程化处理。

        所谓的中断线程化就是设备注册的主handler也会运行在内核线程上,此时的中断的irqaction->handler指向了irq_default_primary_handler,他不会做任何处理,只是以IRQ_WAKE_THREAD返回,以便后续代码唤醒对应的irq_thread线程。

        中断线程的运行框架如下:

irq_thread@kernel\irq\manage.c
__irq_wake_thread@kernel\irq\handle.c

从零开始理解Linux中断架构(19)--中断线程化irq_thread_第1张图片

你可能感兴趣的:(Linux中断系统,linux,中断线程化)