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)




    
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章