博客
关于我
Linux 内核处理中断全过程解析
阅读量:683 次
发布时间:2019-03-15

本文共 960 字,大约阅读时间需要 3 分钟。

中断:现代 CPU 工作方式的核心机制

中断是现代 CPU 工作方式中至关重要的机制。它允许 CPU 在执行程序时暂停当前任务,立即响应某些事件或条件。例如,当你在键盘上敲击键盘时,CPU会被中断以便读取输入。这一过程速度极快,以至于用户通常不会察觉。

中断请求(IRQ)的定义

中断请求(IRQ)是由可编程中断控制器(PIC)发起的信号,目的是中断 CPU 并执行中断服务程序(ISR)。中断服务程序是一个小型程序,处理具体事件,其操作取决于中断的触发原因。正在运行的进程会在中断服务程序执行期间被暂停。

过去,中断控制器(PIC)独立处理中断请求,负责多个硬件设备的中断事件。然而,现代 CPU 内置了高级可编程中断控制器(APIC),每个核心都有自己的 APIC,独立管理中断请求。

中断类型

中断可以根据其来源分为三种类型。

硬件中断

当硬件设备准备好提供数据时(如键盘按键或网络数据包到达),设备会发送中断请求(IRQ)。内核预先注册的中断服务程序(ISR)会被调用处理相关事件。

软件中断

软件中断通过计时器实现,确保不同任务(如视频播放)能够同步运行。计时器会周期性地触发中断,管理任务的执行。

异常

异常(Exception)是 CPU 在执行指令时遇到不可恢复错误时触发的中断。例如,除零错误或缺页错误会导致中断。异常可以进一步分为错误(可修复)、陷阱(用于调试)和终止(严重错误,终止进程)。

异常的细分

  • 错误:系统可以纠正的异常,例如缺页错误。CPU会暂停执行,加载需要的页,然后恢复程序运行。
  • 陷阱:用于调试,允许调试器读取变量值。例如,设置断点时会触发陷阱。
  • 终止:由硬件错误或值不一致引起,最严重的中断,终止进程。
  • 动手实践

    中断请求(IRQ)按优先级排序(0为最高优先级)。前32个中断由 CPU 管理,后续中断由 APIC 处理。中断描述表(IDT)记录中断请求和 ISR 的映射关系。要查看已注册的中断,可以执行命令:

    cat /proc/interrupts

    这将显示中断向量号、发生次数、硬件来源等信息。

    总结

    中断是硬件、驱动和软件协同工作的基础。Linux 内核确保了中断处理的高效,用户通常察觉不到其存在。深入了解中断机制,可以参考《Linux Inside》和内核教程仓库。

    转载地址:http://antmz.baihongyu.com/

    你可能感兴趣的文章
    nginx配置域名和ip同时访问、开放多端口
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    Nginx配置文件nginx.conf中文详解(总结)
    查看>>
    Nginx配置负载均衡到后台网关集群
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>