工作队列

一、介绍

在中断处理中,经常用到工作队列,这样便能缩短中断处理时的时间

中断中通过调用schedule_work(work)来通知内核线程,然后中断结束后,再去继续执行work对应的func函数

二、示例

当中断来了,立马调用schedule_work(work),然后退出。中断结束后,内核便会调用_work对应的func函数,最后才来读取按键值,上报按键值,这样就大大缩短了中断处理时间

三、常用函数

1、INIT_WORK函数

1
INIT_WORK(work, func);

其中参数1是个work_struct结构体,参数2是个函数名,通过INIT_WORK将work_struct与一个函数建立起来.

其中work_struct结构体定义如下所示:

1
2
3
4
5
6
7
8
struct work_struct {
         atomic_long_t data;                      
         struct list_head entry;                    
         work_func_t func;                            //函数指针,指向func函数
#ifdef CONFIG_LOCKDEP
         struct lockdep_map lockdep_map;
#endif
};

2、schedule_work函数

1
schedule_work(work);

通知内核线程,在后续的时间里,系统将会自动调用work结构体对应的func函数。

3、cancel_work_sync函数。

1
bool cancel_work_sync(struct work_struct *work);

取消work结构体对应的func函数,一般在exit中使用

 

  

posted @   轻轻的吻  阅读(120)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示