当产生一个中断时,会进入中断处理程序。 但中断处理程序必须快速、异步、简单的对硬件做出迅速响应并完成那些时间要求很严格的操作。 因此,对于那些其他的、对时间要求相对宽松的任务,就应该推后到中断被激活以后再去运行。 这样,整个中断处理流程就被分为了两个部分: 下半部的任务主要是执行与中断相关的工作,这些工作没有被中断服务程序本身完成。 下半部并不需要指明一个确切时间,只要把这些任务推迟一点,让它们在系统不太繁忙并且中断恢复后执行就可以了。 上半部和下半部的主要区别: 上半部指的是中断处理程序,下半部则指的是一些虽然与中断有相关性但是可以延后执行的任务。 上半部中断不能被相同类型的中断打断,而下半部依然可以被中断打断。 通常下半部在中断处理程序一返回就会马上运行。 上半部分简单快速,执行的时候禁止一些或者全部中断。 下半部分稍后执行,而且执行期间可以响应所有的中断。 每个软中断由 在 数组的成员数由 新增一个软中断时,需要在文件 软中断使用的几个要点: 相关接口 即注册对应类型的处理函数到全局数组 实际上即以软中断类型 这也是同一类型软中断可以在多个 以一个按键驱动的中断处理为例,将按键驱动的中断处理分成上下两部分: 软中断的注册,在驱动的入口函数,注册软中断: 添加的枚举常量: 可以看到,使用软中断是需要修改内核,添加一个枚举的,有些繁琐。 所以,通常我们不建议擅自增加软中断的数量,如果需要新的软中断,尽可能把它们实现为基于软中断的 tasklet是利用软中断实现的一种下半部机制。 那是用软中断还是 选择到底是用软中断还是 1、编写 2、声明 3、调度 登记 以按键中断驱动为例: 先使用 两个要点: 工作队列的相关接口函数: 在使用上,工作队列与
什么是中断下半部

Linux中,对中断下半部的实现主要有三种:
softirq
softirq即软中断,代码位于kernel/softirq.c文件中;softirq_action结构表示:
softirq.c中定义了一个软中断向量数组softirq_vec:static struct softirq_action softirq_vec[NR_SOFTIRQS] __cacheline_aligned_in_smp;
enum
{
HI_SOFTIRQ=0, /*用于高优先级的tasklet*/
TIMER_SOFTIRQ, /*用于定时器的下半部*/
NET_TX_SOFTIRQ, /*用于网络层发包*/
NET_RX_SOFTIRQ, /*用于网络层收报*/
BLOCK_SOFTIRQ,
BLOCK_IOPOLL_SOFTIRQ,
TASKLET_SOFTIRQ, /*用于低优先级的tasklet*/
SCHED_SOFTIRQ,
HRTIMER_SOFTIRQ,
RCU_SOFTIRQ, /* Preferable RCU should always be the last softirq */
NR_SOFTIRQS
};NR_SOFTIRQS决定,是一个枚举常量。include/linux/interrupt.h 中添加一个枚举常量。
void open_softirq(int nr, void (*action)(struct softirq_action *))
softirq_vec中。void raise_softirq(unsigned int nr)
nr作为偏移量会置位irq_stat[cpu_id]的成员变量__softirq_pending.__softirq_pending字段中的每一个bit,对应着某一个软中断,某个bit被置位,说明有相应的软中断等待处理。cpu上并行运行的根本原因。
软中断实例



tasklet形式。
tasklet
tasklet好呢?tasklet其实很简单:
tasklet。就像我们在前面看到的,软中断资源有限,也麻烦,而且软中断的使用者屈指可数。它只在那些执行频率很高和连续性要求很高的情况下才需要。tasklet效果都不错,而且它们还非常容易使用。
tasklet使用
tasklet的使用步骤如下:tasklet处理函数(下半部)void my_tasklet_fun (unsigned long data)
tasklet//静态
DECLARE_TASKLET(my_tasklet,my_tasklet_fun,data);
//动态
Struct tasklet_struct xxx;
tasklet_init(&xxx,tasklet_handler,dev)
tasklettasklet_schedule(&my_tasklet);
my_tasklet, 然后允许系统在合适的时间调度它。
tasklet实例

DECLARE_TASKLET静态声明一个tasklet,指定其下半部函数为btn_tasklet_func,在中断服务函数(上半部)获取按键值后,调用tasklet_schedule调度。
work queue
work queue即工作队列,也是中断下半部的一种。Work queue将下半部工作推迟给一个内核线程去执行 ——work 总是运行于进程上下文.
work queues。否则使用softirq或tasklets.Work queues适用于需要分配大量的内存,获得一个信号量,或者执行阻塞的I/O的情况.
tasklet是类似的:
0
0
相关文章
Linux内存使用查看_free与vmstat说明
Linux异常登录怎么查_登录日志审计方法
Linux时间不同步问题_时间漂移分析
Linux Socket缓冲区优化_缓冲区参数调整
Linux集中日志方案设计_日志集中化架构
相关标签:
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。
16
2026.03.11
本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。
23
2026.03.10
本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。
75
2026.03.09
本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。
95
2026.03.06
本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。
218
2026.03.05
本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。
420
2026.03.04
2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!
168
2026.03.04
本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。
222
2026.03.03
本专题围绕 C++ 在高性能网络服务开发中的应用展开,深入讲解 Socket 编程、多路复用机制、Reactor 模型设计原理以及线程池协作策略。内容涵盖 epoll 实现机制、内存管理优化、连接管理策略与高并发场景下的性能调优方法。通过构建高并发网络服务器实战案例,帮助开发者掌握 C++ 在底层系统与网络通信领域的核心技术。
33
2026.03.03
热门下载
相关下载
精品课程

