本文共 810 字,大约阅读时间需要 2 分钟。
由于在中断中不能进行阻塞型操作,而有时候需要在中断时读取某些内存单元或寄存器的值,此时可以考虑利用工作队列来实现。
工作队列的定义:
工作队列是将操作延期的一种手段。因为他们是通过守护进程在用户上下文执行,函数可以睡眠任意长的时间,这与内核无关。替换了之前的kevented机制。
工作队列的使用:
使用工作队列,主要有以下三个步骤:
1 实现工作任务处理函数
2 创建并初始化工作任务
3 将工作任务添加到某工作队列中,等待系统调度
注意:
内核创建了一个标准的工作队列events,内核的各个部分若无必要创建独立的工作队列,可直接使用该工作队列。内核为该标准队列提供了两个api:
<kernel/workqueue.c>
int schedule_work(struct work_struct *work)
int schedule_delayed_work(struct work_struct *dwork, unsigned long delay)
1 定义工作任务处理函数:
static void func(struct work_struct *work){......}
2 创建并初始化工作任务
可采用两种方式创建并初始化工作任务:
1) 先创建工作任务,后绑定处理函数:
struct work_struct xxx_wq;//创建工作任务......
在模块初始化的时候:
INIT_WORK(&xxx_wq,func);//初始化工作任务,工作任务需要执行的是函数func......
2) 创建工作任务的同时初始化:
DECLARE_WORK(xxx_wq, func);
3 在中断处理函数中将工作任务添加到工作队列,等待系统调度
schedule_work(&xxx_wq);//将工作任务xxx_wq添加到标准工作队列events中,中断处理完成之后可以立即执行func......
转载地址:http://cqbqi.baihongyu.com/