为了提升内核的响应速度,中断处理往往会分成上半部和下半部来执行。
上半部在中断处理函数中处理少量事物并激活下半部,一般通过tasklet 或 workqueue 来实现。
workqueue 参考:
void workqueue_func(struct work_struct *work) // 下半部执行函数
{
printk("workqueue bottom half\n");
}
DECLARE_WORK(mywork, workqueue_func); //声明workqueue
static irqreturn_t my_interrupt(int irq, void *dummy) //中断处理函数
{
printk("workqueue top half\n");
schedule_work(&mywork); //调度执行 workqueue_func
return IRQ_HANDLED;
}
tasklet 参考:
void tasklet_func(unsigned long data) //下半部执行函数
{
printk("tasklet bottom half\n");
}
DECLARE_TASKLET(mytasklet, tasklet_func, 0); //声明tasklet函数
static irqreturn_t my_interrupt(int irq, void *dummy) //中断执行函数
{
printk("tasklet top half\n");
tasklet_schedule(&mytasklet); //激活执行tasklet_func
return IRQ_HANDLED;
}

本文深入探讨了中断处理的优化策略,即通过将处理过程分为上半部和下半部来提高内核响应速度。上半部负责快速响应中断信号,下半部则在适当时候执行更复杂的工作,通过tasklet和workqueue机制实现。
911

被折叠的 条评论
为什么被折叠?



