鱼弦:公众号【红尘灯塔】,优快云博客专家、内容合伙人、新星导师、全栈领域优质创作者 、51CTO(Top红人+专家博主) 、github开源爱好者(go-zero源码二次开发、游戏后端架构 https://github.com/Peakchen)
Linux 驱动开发 - 内核共享工作队列
介绍
内核共享工作队列是一种机制,允许驱动程序将耗时的任务委派给内核线程池来执行。这有助于提高驱动程序的响应能力和效率,同时避免内核死锁。本指南介绍了如何在 Linux 驱动程序中使用内核共享工作队列。
原理详解
内核共享工作队列的工作原理如下:
- **创建工作队列:**驱动程序使用
create_singlethread_workqueue()
函数创建一个工作队列。工作队列是一个内核线程池,负责执行任务。 - **初始化工作:**驱动程序使用
INIT_WORK()
或INIT_DELAYED_WORK()
宏初始化一个工作结构。工作结构包含要执行的任务以及其他相关信息。 - **将工作排入队列:**驱动程序使用
queue_work()
函数将工作排入队列。这会将工作添加到工作队列,等待内核线程执行。 - **执行工作:**内核线程从工作队列中获取工作并执行