中断下半部_工作队列(work queue)

2024-02-10 16:08

本文主要是介绍中断下半部_工作队列(work queue),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1>work_queue:<linux/workqueue.h> __3.0.4
2>description:
中断下半部,在内核线程的进程上下文中执行推后的工作.
它是唯一能在进程上下文运行的中断下半部实现机制,也只有它才可以睡眠.
3>创建推后的工作:
DECLARE_WORK(const char *name, void (*func)(struct work_struct *work));
INIT_WORK(struct work_struct *work, void (*func)(struct work_struct *work));struct work_struct {atomic_long_t data;struct list_head entry;work_func_t func;                                                                                                                     
#ifdef CONFIG_LOCKDEPstruct lockdep_map lockdep_map;
#endif
};
typedef void (*work_func_t)(struct work_struct *work);
4>工作队列处理函数:
/* 除了不能访问用户空间,它的确比软中断和tasklet方便不少.* 只有系统调用陷入内核,用户空间的内存才会被映射.*/
void *func(struct work_struct *work);
5>调度(提交)工作:
/* 把创建好的工作提交到缺省的worker线程(每个cpu一个,event/cpuno.).* 有时把这种工作队列也叫共享队列,因为很多驱动程序都将推后执行的工作提交到默认worker线程.*/
int schedule_work(struct work_struct *work);
int schedule_delayed_work(struct delayed_work *work, unsigned long delay);
int schedule_on_each_cpu(work_func_t func);
6>刷新工作队列:
/* 实际上,它只是等待(睡眠),直到缺省工作队列上的工作被执行.* complete()实现.*/
void flush_scheduled_work(void);
/*等待指定的工作被执行*/
bool flush_work(struct work_struct *work);
bool flush_delayed_work(struct delayed_work *dwork);
7>取消工作:
bool cancel_delayed_work(struct delayed_work *work);
bool cancel_work_sync(struct work_struct *work);
bool cancel_delayed_work_sync(struct delayed_work *dwork);



8>创建一个新的workqueue和对应的worker线程(每个cpu一个).

/* 如果一个任务是处理器密集型和性能要求严格的* 那么可以选择创建自己的worker(工作者)线程* 当然,每个处理器一个.*/
struct workqueue_struct *create_workqueue(const char *name);/* struct workqueue_struct *alloc_workqueue(const char *name, unsigned int flags, int max_active);* the maximum number of execution contexts per cpu, up to 512.*/
9>调度(提交)队列
int queue_work(struct workqueue_struct *wq, struct work_struct *work);
int queue_delayed_work(struct workqueue_struct *wq, struct delayed_work *work, unsigned long delay);
10>刷新一个工作队列:
/* 等待(睡眠),直到指定队列上的工作被执行.* 事实上除了指定工作队列,它和flush_scheduled_work()没有区别.*/
void flush_workqueue(struct workqueue_struct *wq);
11>释放一个工作队列:
void destroy_workqueue(struct workqueue_struct *wq);


这篇关于中断下半部_工作队列(work queue)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/697537

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

spring AMQP代码生成rabbitmq的exchange and queue教程

《springAMQP代码生成rabbitmq的exchangeandqueue教程》使用SpringAMQP代码直接创建RabbitMQexchange和queue,并确保绑定关系自动成立,简... 目录spring AMQP代码生成rabbitmq的exchange and 编程queue执行结果总结s

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

setsid 命令工作原理和使用案例介绍

《setsid命令工作原理和使用案例介绍》setsid命令在Linux中创建独立会话,使进程脱离终端运行,适用于守护进程和后台任务,通过重定向输出和确保权限,可有效管理长时间运行的进程,本文给大家介... 目录setsid 命令介绍和使用案例基本介绍基本语法主要特点命令参数使用案例1. 在后台运行命令2.

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程

SpringBoot集成LiteFlow工作流引擎的完整指南

《SpringBoot集成LiteFlow工作流引擎的完整指南》LiteFlow作为一款国产轻量级规则引擎/流程引擎,以其零学习成本、高可扩展性和极致性能成为微服务架构下的理想选择,本文将详细讲解Sp... 目录一、LiteFlow核心优势二、SpringBoot集成实战三、高级特性应用1. 异步并行执行2

Spring @Scheduled注解及工作原理

《Spring@Scheduled注解及工作原理》Spring的@Scheduled注解用于标记定时任务,无需额外库,需配置@EnableScheduling,设置fixedRate、fixedDe... 目录1.@Scheduled注解定义2.配置 @Scheduled2.1 开启定时任务支持2.2 创建