Linux设备驱动之工作队列

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

工作队列与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)




    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值