前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Linux BSP实战课(中断篇):中断控制器的硬件实现

Linux BSP实战课(中断篇):中断控制器的硬件实现

作者头像
刘盼
发布2024-04-15 16:13:33
1750
发布2024-04-15 16:13:33
举报
文章被收录于专栏:人人都是极客人人都是极客

中断在系统中的作用

中断机制在处理器中扮演着一个至关重要的角色,它是处理器异步响应外围设备请求的核心方式。从技术的深层次来看,中断是处理器在正常运行过程中,因外部或内部事件(如外围设备的输入/输出请求、异常错误等)而暂时中断当前执行的程序,转而执行特定的中断服务程序(Interrupt Service Routine, ISR)的过程。

在操作系统的上下文中,中断处理是外围设备管理的基石。外围设备如硬盘、键盘、鼠标等,它们的工作通常是异步的,即它们不会按照处理器执行指令的线性顺序来请求服务。中断机制允许处理器在这些设备需要服务时,能够立即响应,而不必等待处理器完成当前任务。这种异步处理的能力极大地提高了系统的响应性和效率。

此外,中断机制还在系统调度和核间交互中发挥着不可或缺的作用。系统调度是操作系统根据一定的策略选择下一个要执行的进程或线程的过程。当中断发生时,处理器可能会根据中断的类型和优先级来决定是否切换当前执行的上下文,从而实现任务的快速切换和调度。而在多核或多处理器的系统中,中断也是核间通信和同步的重要手段,它可以帮助不同的处理器核心之间传递信息、协调工作。

这里对中断在系统中的介绍会包括硬件原理、中断驱动解析、上半部与下半部、以及softirq, tasklet, workqueue等机制。

中断控制器 GIC 硬件原理

GIC,Generic Interrupt Controller。是ARM公司提供的一个通用的中断控制器。主要作用为: 接受硬件中断信号,并经过一定处理后,分发给对应的CPU进行处理。

当前GIC 有四个版本,GIC v1~v4, 本文主要介绍GIC v3控制器。

GIC v3中断类别

GICv3定义了以下中断类型:

  • SGI (Software Generated Interrupt):软件触发的中断。软件可以通过写 GICD_SGIR 寄存器来触发一个中断事件,一般用于核间通信,内核中的 IPI:inter-processor interrupts 就是基于 SGI。
  • PPI (Private Peripheral Interrupt):私有外设中断。这是每个核心私有的中断。PPI会送达到指定的CPU上,应用场景有CPU本地时钟。
  • SPI (Shared Peripheral Interrupt):公用的外部设备中断,也定义为共享中断。中断产生后,可以分发到某一个CPU上。比如按键触发一个中断,手机触摸屏触发的中断。
  • LPI (Locality-specific Peripheral Interrupt):LPI 是 GICv3 中的新特性,它们在很多方面与其他类型的中断不同。LPI 始终是基于消息的中断,它们的配置保存在表中而不是寄存器。比如 PCIe 的 MSI/MSI-x 中断。

中断类型

硬件中断号

SGI

0-15

PPI

16-31

SPI

32-1019

reserved

......

LPI

8192-MAX

本文参与?腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2024-04-14,如有侵权请联系?cloudcommunity@tencent.com 删除

本文分享自 人人都是极客 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 中断在系统中的作用
  • 中断控制器 GIC 硬件原理
    • GIC v3中断类别
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
    http://www.vxiaotou.com