local_bh_enable_ip local_bh_enable | | ------------------- irq_exit | | netif_rx_ni _local_bh_enable_ip invoke_softirq | | | ----------------------------------------- | | run_ksoftirqd <----- wakeup_softirqd do_softirq() / | / | / __do_softirq()
可以看到,软中断处理时机主要有:
1. 网络数据包到来时,即函数netif_rx_ni被调用时。
2. 硬中断处理完时,即函数irq_exit调用时。
3. 一些开启关闭软中断时,关键是开启软中断时,检查是否有未处理的软中断,有的话也进行处理。如上面的local_bh_enable。