天天看点

Linux设备驱动之工作队列

工作队列与Tasklet相同点和不同点: 1、相同

工作队列与Tasklet都允许内核代码请求某个函数在将来的时间被调用

2、区别

(1)、tasklet运行在中断上下文,因此所有的tasklet代码都必须是原子的。而工作队列函数运行在一个特殊的内核进程上下文,  因此它们具有更好的灵活性。工作队列可以休眠。 (2)、Tasklet始终运行在被初始提交的同一处理器上,但这只是工作队列的默认方式。 (3)、内核代码可以请求工作队列函数的执行延迟给定的时间间隔

内核中使用struct workqueue_struct 来描述工作队列

  • 创建一个工作队列
struct workqueue_struct *create_workqueue(const char *name) struct workqueue_struct *create_singlethread_workqueue(const char *name)
  • 初始化一个任务
要向一个工作队列提交一个任务,需要填充一个work_struct结构, 宏编译时:
DECLARE_WORK(name, void(*func)(void *), void *data)
运行时:
INIT_WORK(struct work_struct *work, void(*func)(void *), void *data) PREPARE_WORK(struct work_struct *work, void(*func)(void *), void *data )
  • 将工作提交到工作队列
int queue_work(struct workqueue_struct*queue, struct work_struct *work) int queue_delayed_work(struct workqueue_struct*queue, struct work_struct *work, unsighed long delay)
  • 取消某个挂起的工作队列入口项
int cancel_delayed_work(struct work_struct *work) void flush_workqueue(struct workqueue_struct *queue)
  • 销毁工作队列
void destroy_workqueue(struct workqueue_struct *queue)

继续阅读