工作队列与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)
本文探讨了工作队列与Tasklet之间的相似性和差异性。两者均可安排函数在未来执行,但工作队列提供更灵活的上下文并支持休眠,而Tasklet则在中断上下文中运行且不允许休眠。此外,文章还详细介绍了工作队列的基本操作,包括创建、提交任务、取消任务及销毁等。

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



