工作队列

摘要:
1、 本文介绍了中断处理中经常使用工作队列,这可以缩短中断处理的时间_work通知内核线程,然后在中断后继续执行与工作对应的func函数。2.示例当中断发生时,立即调用日程安排_工作,然后退出。

一、介绍

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

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

二、示例

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

三、常用函数

1、INIT_WORK函数

INIT_WORK(work, func);

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

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

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函数

schedule_work(work);

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

3、cancel_work_sync函数。

bool cancel_work_sync(struct work_struct *work);

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

 

  

免责声明:内容来源于网络,仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇HTTP基础11--web(3)【原创】Linux中断子系统(四)-Workqueue下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

C++使用OLE高速读写EXCEL的源码

写了不少blog,也码了一点点文字,不知道为啥,被大家看的比较多几篇文章却总有那篇《C++读写EXCEL文件方式比较 》。 小小伤心一下,我blog里面写的很认真的文字还有几篇,这篇大概是最随意的文章。个人估计这是SEO的作用导致的。 另外,由于文中提到了可以加快OLE读取的EXCEL的速度,总有一些哥们找我要代码。 好吧,好吧,把代码放出来,因为我原来也...

Nodejs事件引擎libuv源码剖析之:高效线程池(threadpool)的实现

     声明:本文为原创博文,转载请注明出处。      Nodejs编程是全异步的,这就意味着我们不必每次都阻塞等待该次操作的结果,而事件完成(就绪)时会主动回调通知我们。在网络编程中,一般都是基于Reactor线程模型的变种,无论其怎么演化,其核心组件都包含了Reactor实例(提供事件注册、注销、通知功能)、多路复用器(由操作系统提供,比如kque...

mtd-utils交叉编译安装

一、获取源码并解压 存储于/home/zhangyi/work/psoc_ltp/tools-ltp-ddt中,解压后的源码存于上一层目录。 1.mtd-utils-2.0.0 wget ftp://ftp.infradead.org/pub/mtd-utils/mtd-utils-2.0.0.tar.bz2 tar -jxvf mtd-utils-2.0...

python之线程与线程池

# 进程是资源分配的最小单位,线程是CPU调度的最小单位.每一个进程中至少有一个线程。 # 传统的不确切使用线程的程序称为只含有一个线程或单线程程序,而可以使用线程的程序被称为多线程程序,在程序中使用一个线程的方法 # 被称为多线程 # 线程的模块: # thread >> 实现线程的低级接口 # threading>>>...

Centos下堡垒机Jumpserver V3.0环境部署完整记录(2)-配置篇

前面已经介绍了Jumpserver V3.0的安装,基于这篇安装文档,下面说下Jumpserver安装后的的功能使用: 一、jumpserver的启动 Jumpserver的启动和重启 [root@test-vm001 install]# /opt/jumpserver/service.sh start/restart 二、按照Jumpserver部署过...

kafka springboot (或 springcloud ) 整合

狂创客圈 经典图书 : 《Netty Zookeeper Redis 高并发实战》 面试必备 + 面试必备 + 面试必备 【博客园总入口 】 疯狂创客圈 经典图书 : 《SpringCloud、Nginx高并发核心编程》 大厂必备 + 大厂必备 + 大厂必备 【博客园总入口 】 入大厂+涨工资必备: 高并发【 亿级流量IM实战】 实战系列 【 Sprin...