驱动基石之_tasklet中断下半部_工作队列_中断线程化处理

2023-11-11 00:36

本文主要是介绍驱动基石之_tasklet中断下半部_工作队列_中断线程化处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

tasklet中断下半部

linux的中断分为两个部分:

1.中断上半部:在中断上半部期间,不允许被其他中断打断,直到中断上半部的服务函数执行完。

2.中断下半部:中断下半部,在执行中断下半部服务函数的期间,能被其它更高优先级别的中断打断。

使用流程

1.创建一个strcuct timer_list类型的变量,我把这个变量定义在结构体使是因为我这里使用的了两个按键,我把按键看成一个对象,把需要的属性封装成一个结构体,方便后续的操作。
在这里插入图片描述2.初始化这个变量。在这里插入图片描述
3.调度 tasklet (把 tasklet 放入链表,并且设置它的 TASKLET_STATE_SCHED 状态为1)
在这里插入图片描述
4.删除
在这里插入图片描述

工作队列

使用tasklet中断下半部时,在执行中断服务函数期间,app的其它线程得不到执行,如果中断执行时间过长,这样会影响程序,这时候我们就需要让下半中断变成一个线程,让其它线程也够被调度,这时候工作队列就满足我们的需求。

在内核中,我们并不需要自己去创建线程,可以使用“工作队列”(workqueue)。内核初始化工作队列是,就为它创建了内核线程。以后我们要使用“工作队列”,只需要把“工作”放入“工作队列中”,对应的内核线程就会取出“工作”,执行里面的函数。

使用流程

1.创建一个struct work_struct 类型的变量,把它放结构体里。(面向对象编程)
在这里插入图片描述
2.初始化work_struct 结构体
在这里插入图片描述
3.使用 work (调用 schedule_work 时,就会把 work_struct 结构体放入队列中,并唤醒对应的内核线程。内核线程就会从队列里把 work_struct 结构体取出来,执行
里面的函数)在这里插入图片描述

中断线程化处理

使用工作队列的时候,在单cpu核板子里,因为只有一个内核线程,如果创建了多个struct work_struct,并且 其中对应的线程处理函数都要执行,但是只有一个内核线程,这时这些线程处理函数只能排队,一个一个执行,不能并发的执行,为了解决这一问题,就要对中断进行线程化处理。为每一个中断创建自己的线程,来执行需要时间较长的程序。

使用流程

1.定义一下线程处理函数
在这里插入图片描述
2.调用request_threaded_irq 为对应的中断,注册中断上半部函数(可以不定义)和线程处理函数。当发送对应中断时,会先去执行中断上半部函数(没有的话,内核会默认提供irq_default_primary_handler函数),然后执行线程处理函数。
在这里插入图片描述
注意,自己定义的中断上部函数里,返回值一定要改为IRQ_WAKE_THREAD,否则不会执行线程处理函数。
在这里插入图片描述

3.注销中断

在这里插入图片描述

这篇关于驱动基石之_tasklet中断下半部_工作队列_中断线程化处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ

Redis延迟队列的实现示例

《Redis延迟队列的实现示例》Redis延迟队列是一种使用Redis实现的消息队列,本文主要介绍了Redis延迟队列的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、什么是 Redis 延迟队列二、实现原理三、Java 代码示例四、注意事项五、使用 Redi

Python视频处理库VidGear使用小结

《Python视频处理库VidGear使用小结》VidGear是一个高性能的Python视频处理库,本文主要介绍了Python视频处理库VidGear使用小结,文中通过示例代码介绍的非常详细,对大家的... 目录一、VidGear的安装二、VidGear的主要功能三、VidGear的使用示例四、VidGea

Python结合requests和Cheerio处理网页内容的操作步骤

《Python结合requests和Cheerio处理网页内容的操作步骤》Python因其简洁明了的语法和强大的库支持,成为了编写爬虫程序的首选语言之一,requests库是Python中用于发送HT... 目录一、前言二、环境搭建三、requests库的基本使用四、Cheerio库的基本使用五、结合req

使用Python处理CSV和Excel文件的操作方法

《使用Python处理CSV和Excel文件的操作方法》在数据分析、自动化和日常开发中,CSV和Excel文件是非常常见的数据存储格式,ython提供了强大的工具来读取、编辑和保存这两种文件,满足从基... 目录1. CSV 文件概述和处理方法1.1 CSV 文件格式的基本介绍1.2 使用 python 内

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初