Linux 中断处理与内核线程化——以触摸屏中断为例

文章目录

  • [1 什么是中断?](#1 什么是中断?)
  • [2 传统的中断处理模型](#2 传统的中断处理模型)
  • [3 内核线程与用户进程](#3 内核线程与用户进程)
  • [4 中断线程化的理念](#4 中断线程化的理念)
  • [5 `devm_request_threaded_irq` 与 `request_irq` 的比较](#5 devm_request_threaded_irqrequest_irq 的比较)
  • [6 触摸屏驱动中的中断线程化](#6 触摸屏驱动中的中断线程化)
  • 参考链接
  • 封面

本文探讨了 Linux 中断处理的传统模型与中断线程化的理念,以及在触摸屏驱动中为何使用线程化的中断处理。

1 什么是中断?

中断(Interrupt)是硬件设备用来通知处理器发生某个事件的机制。当设备产生中断时,处理器会暂停当前正在执行的任务,转而执行与该中断相关的中断处理程序(Interrupt Handler)。

触摸屏与中断:

  • 触摸屏设备通常使用中断机制来报告触摸事件。例如,当用户手指触摸屏幕时,触摸屏控制器会发出中断信号,通知处理器读取触摸点的坐标信息。

2 传统的中断处理模型

在传统的中断处理模型中,中断处理程序分为上半部 (Top Half)和下半部(Bottom Half):

  • 上半部:这是在中断发生时立即执行的部分,处理最紧急的任务,如确认中断源、清除中断标志等。上半部的执行时间应该尽量短,以便快速恢复系统的正常运行。

  • 下半部:用于处理那些不需要立即完成的任务,如数据传输、复杂计算等。虽然下半部可以延迟执行,但它仍然比普通进程有更高的优先级,可能会影响系统的实时性能。

问题:

  • 如果中断非常频繁,处理器可能会花大量时间在上下半部处理中,导致系统中其他任务得不到及时处理。

3 内核线程与用户进程

在操作系统中,执行任务的实体可以分为内核线程用户进程

  • 内核线程(Kernel Thread):运行在内核空间,专门用于内核任务,如驱动程序的后台处理、系统资源管理等。内核线程不涉及用户空间的地址转换,执行效率更高。

  • 用户进程(User Process):运行在用户空间,通常是用户启动的应用程序。它们通过系统调用与内核交互来完成任务,但执行优先级通常低于内核线程。

4 中断线程化的理念

为了减少频繁中断对系统性能的影响,Linux 内核引入了中断线程化(Threaded Interrupts)的概念。

  • 中断线程化:通过将中断的下半部处理放入内核线程中,使中断处理程序成为一个可调度的线程。这些中断处理线程与普通进程一样,由操作系统调度器管理,可以被赋予不同的优先级。

优势:

  • 优先级控制:中断线程可以设置不同的优先级,甚至低于某些重要的用户进程。这样可以保证系统中更重要的任务优先执行,而不会因为频繁的中断处理而被延迟。
  • 公平竞争:线程化后的中断处理程序与普通进程一起竞争 CPU 资源,减轻中断对系统实时性的影响。

5 devm_request_threaded_irqrequest_irq 的比较

在 Linux 中,有两种常见的中断注册函数:

  • request_irq:用于注册一个中断处理程序。当中断发生时,立即调用该处理程序。
  • devm_request_threaded_irq:除了注册中断处理程序外,还支持中断线程化,并具有自动资源管理的功能。

为什么选择 devm_request_threaded_irq

  • 当中断处理比较耗时或非关键时,可以通过 devm_request_threaded_irq 将中断处理线程化,以减少对系统整体性能的影响。
  • devm_ 系列函数还具有自动资源管理功能,确保在设备卸载时,系统自动释放相关资源,避免资源泄漏。

6 触摸屏驱动中的中断线程化

触摸屏设备的中断处理通常需要读取触摸点的坐标信息,这个过程可能涉及较慢的 I2C 通信(通常最大速度为 400KHz)。如果触摸事件频繁发生,处理器可能会花费大量时间处理触摸中断,影响系统的其他任务。

中断线程化的应用场景:

  • 对于触摸屏这样的设备,触摸事件通常不是最高优先级的任务。因此,可以将触摸中断处理线程化,降低其优先级,确保系统中其他更重要的任务(如音视频处理)能够优先执行。

实例:

  • Linux 内核中的一些触摸屏驱动(如 goodix.cmms114.c 等)就是通过 devm_request_threaded_irq 实现中断线程化的。

参考链接

封面

由 DALL-E-3 生成

相关推荐
凤凰战士芭比Q1 分钟前
Jenkins(部署、基础项目)
运维·servlet·jenkins
小猪佩奇TONY9 分钟前
Linux 内核学习(13) --- linux 内核并发与竞态
linux·服务器·学习
倔强的石头1069 分钟前
Linux 进程深度解析(四):环境变量 —— 进程的“环境 DNA”
linux·运维·服务器
牛奶咖啡1310 分钟前
在Linux中搭建本地yum/dnf仓库
linux·搭建yum/dnf本地仓库·添加rpm文件到yum仓库·添加rpm文件到dnf仓库·生成仓库索引·测试本地搭建的yum仓库·搭建http服务并开启目录浏览
大聪明-PLUS11 分钟前
优雅的操作系统开发:用现代 C++ 编写操作系统内核(不使用宏)。第一部分——HAL 为王。
linux·嵌入式·arm·smarc
沈健_算法小生11 分钟前
Jenkins权限控制实现
运维·jenkins
Wpa.wk20 分钟前
自动化测试-自动化测试用例流程设计
运维·经验分享·自动化·测试用例·测试流程·测试流程设计
sunflower_level222 分钟前
【ssh key】登陆云服务器,github的安全密码
服务器·ssh·github
qq_4557608529 分钟前
Docker - 镜像
linux·运维·docker
苹果醋332 分钟前
java设计模式之责任链模式
java·运维·spring boot·mysql·nginx