ARM Cortex-A学习(1):GIC(通用中断控制器)详解

news2025/2/9 0:12:26

文章目录

  • 1 Cortex-A核中断
    • 1.1 处理器模式
    • 1.2 IRQ模式
  • 2 GIC的操作
    • 2.1 CPU Interface
    • 2.2 Distributor

GIC(通用中断控制器, Generic Interrupt Controller)是一种用于处理中断的硬件组件,它的主要功能是协调和管理系统中的中断请求,确保它们被正确地传递给相应的处理器核心。

1 Cortex-A核中断

1.1 处理器模式

这里以Cortex-A9为例,先来看一下处理器的几种模式:

操作模式描述
User是应用程序运行的基本模式。这是一个非特权模式,对系统资源有限制的访问。
System提供对系统资源的完全访问权限。只能从下面列出的某个异常模式转入。
Supervisor在处理器执行监控SVC时进入,也会在复位或上电时进入。
Abort试图访问非法内存位置时进入
Undefined试图执行未实现的指令时进入
IRQ响应中断请求
FIQ响应快速中断请求

处理器首次上电或复位时,处于Supervisor模式。该模式是特权模式,允许使用所有处理器指令和操作。从Supervisor模式可以切换到User模式。User模式是唯一的非特权模式,某些类型的处理器操作和指令是被禁止的。在实际应用中,Supervisor模式通常在处理器执行操作系统等代码时使用,而正常的软件代码可能在User模式下运行,从而为系统地关键资源提供一定程度的保护。

处理器的操作模式由处理器状态寄存器CPSR指示和更改,如下图所示:

在这里插入图片描述

要修改CPSR的内容,处理器必须处于特权模式。如下图所示,为Cortex-A9处理器中的通用寄存器。

在这里插入图片描述

  • User模式中,有16个寄存器:R0R15,以及CPSR

  • 图中没有System模式,但这些寄存器在System模式中也可用

  • FIQ模式外的所有模式中,R0R12,以及R15都是通用的。而对于R13R14来说,不同的模式都有自己独有的R13R14

  • CPSR寄存器对所有模式都是通用的,但从一种模式切换到另一种模式时,CPSR的当前内容会被复制到新模式的保存处理器状态寄存器(SPSR)中

注意,本文不对FIQ模式进行深入讨论,它有独有的R8R12寄存器。

1.2 IRQ模式

Cortex-A9处理器在接收到来自GICIRQ信号时,会进入上面所说的IRQ模式。软件上配置中断的步骤如下:

  1. 禁用IRQ中断:将CPSR中的IRQ禁用位置为1。
  2. 配置GIC:与GIC连接的每个I/O外设的中断都由唯一的中断ID标识。
  3. 配置每个I/O外设:以便它们可以向GIC发送IRQ中断请求。
  4. 启用IRQ中断:将CPSR中的IRQ禁用位设置为0。

2 GIC的操作

GIC架构分为两个主要部分,称为CPU接口(CPU Interface)和分发器(Distributor)。CPU接口负责将Distributor接收到的IRQ请求发送到Cortex-A处理器(若有双核则可以发给两个)。而Distributor从I/O外设接收IRQ中断信号。

在这里插入图片描述

2.1 CPU Interface

CPU接口用于向Cortex-A核发送中断请求(IRQ)信号。如果有多核的话,每个核都有一个CPU接口。每个CPU接口中的相关寄存器如下所示:

在这里插入图片描述

  • ICCICR(CPU Interface Control Register):用于使能/禁用从CPU接口到相应Cortex-A核的中断转发
  • ICCPMR(Interrupt Priority Mask Register ):设置由CPU接口发送到Cortex-A核的中断的优先级阈值,优先级低于这个值的中断将被屏蔽
  • ICCIAR(The Interrupt Acknowledge Register):包含引起中断的I/O外设的中断ID。当处理器从GIC接收到IRQ信号时,程序员可通过在中断处理程序中读取ICCIAR以确定哪个I/O外设引起了中断。
  • ICCEOIR(End of Interrupt Register):在完成IRQ中断处理后,处理器必须清除此中断的标志位。我们只要将对应的中断ID写入这个寄存器即可清除中断标志位。

2.2 Distributor

GIC中的分配器可以处理255个中断源。再来回看一下这个图:

在这里插入图片描述

  • SPIs(共享外设中断,shared peripheral interrupts):中断ID范围为32到255,最多连接到224个I/O外设的IRQ信号,这些中断源是两个CPU接口共享的。
  • PPIs(私有外设中断,private peripherals interrupts):中断ID范围为0到31。
    • SGI(软件生成中断,software generated interrupts):是一种特殊的私有中断,通过写入GIC特定寄存器来生成;0到15的中断ID用于SGI。这里不对SGI做详细讨论。

分配器的相关寄存器如下图所示:

在这里插入图片描述

  • ICDDCR(分配器控制寄存器,Distributor Control Register):用于使能/禁用分配器

  • ICDISERn(中断集使能寄存器,Interrupt Set Enable Registers):用于使能从分配器到CPU接口的每个中断的转发。由于中断不止32个,所以这里有多个ICDISER寄存器,每个寄存器包括32个中断ID

  • ICDISERn(中断清除使能寄存器,Interrupt Clear Enable Registers):用于禁用每个中断,写入1将禁用将相应中断转发到CPU接口

  • ICDIPRn(中断优先级寄存器,Interrupt Priority Registers):设置中断的优先级。每个中断ID的优先级字段占据1字节

  • ICDIPTRn(中断处理器目标寄存器,Interrupt Processor Targets Registers):指定每个中断应转发到哪个CPU接口。每个中断ID占1字节(有的版本最多有8个Cortex-A核),设置为1表示选择该CPU。

    • 假设系统中有两个内核(1和2),若将图中的CPUs,offset0设置为11,表示中断ID为0的中断将发送到内核1和内核2中。
  • ICDICFRn(中断配置寄存器,Interrupt Configuration Registers):用于指定每个中断在GIC中是应作为电平触发还是边沿触发。

    • 电平触发:中断信号在保持为高或低电平时触发,电平翻转时,如从1变为0,表示中断结束
    • 边沿触发:当中断信号产生一个上升或下降沿时触发
    • 每个中断ID有两位用来配置电平或边沿触发,其中LSB没用到,当MSB为1时表示边沿触发,0表示电平触发
    • 当I/O外设产生电平触发的IRQ信号时,如果中断尚未从分配器转发到CPU接口,则可以取消这个信号;然而,一旦在分配器中采样了边沿触发的IRQ信号,就不能取消这个信号。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1335970.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

前端项目重构的深度思考和复盘

摘要: 项目重构是每一家稳定发展的互联企业的必经之路, 就像一个产品的诞生, 会经历产品试错和产品迭代 一样, 随着业务或新技术的不断发展, 已有架构已无法满足更多业务扩展的需求, 所以只有通过重构来让产品“进化”, 才能跟上飞速发展的时代浪潮. 技术因素 早期…

【http】缓存协议

✨ 专栏介绍 在当今互联网时代,计算机网络已经成为了人们生活和工作中不可或缺的一部分。而要实现计算机之间的通信和数据传输,就需要依靠各种网络协议来进行规范和约束。无论是浏览网页、发送电子邮件还是进行在线交流,都离不开各种各样的网…

使用pytorch神经网络拟合计算模型

一. 内容简介 python调用百度翻译api,将中文论文翻译英文,并保留部分格式 二. 软件环境 2.1vsCode 2.2Anaconda version: conda 22.9.0 2.3数据文件 链接:https://pan.baidu.com/s/1csJOoErGyx77MW_FImVKjg?pwd1234 三.主要流程 3.…

@click 默认传递原生的事件对象

项目场景 [Day1] <template><div id"app"><h1>小黑记事本</h1><button click"handleClick">www</button><div class"head"><!-- 按键&#xff08;回车&#xff09;按下&#xff0c;出发add事件&…

MyBatis见解4

10.MyBatis的动态SQL 10.5.trim标签 trim标签可以代替where标签、set标签 mapper //修改public void updateByUser2(User user);<update id"updateByUser2" parameterType"User">update user<!-- 增加SET前缀&#xff0c;忽略&#xff0c;后缀…

uniapp创建/运行/发布项目

1、产生背景----跨平台应用框架 在移动端各大App盛行的时代&#xff0c;App之间的竞争也更加激烈&#xff0c;他们执着于让一个应用可以做多个事情 所以就应运而生了小程序&#xff0c;微信小程序、支付宝小程序、抖音小程序等等基于App本身的内嵌类程序。 但是各大App他不可…

解决ELement-UI三级联动数据不回显

目录 一.处理数据时使用this.$set方法来动态地设置实例中的属性&#xff0c;以确保其响应式。 二.检查数据格式是否正确 三.绑定v-if 确保每次执行 四.完整代码 一.处理数据时使用this.$set方法来动态地设置实例中的属性&#xff0c;以确保其响应式。 二.检查数据格式是否正确…

通过three.js玩转车展项目

1.项目搭建 1.1 创建文件夹 mkdir 文件名1.2 初始化package.json npm init -y1.3 安装打包工具并配置相关依赖 npm i parcel -d在package.json中打包路径和指令 1.4 安装three.js npm i three -d2.项目搭建 2.1 新建index.html&#xff0c;并再index.html引入car.js,在…

分类预测 | Matlab实现SCSO-SVM基于沙猫群优化算法优化支持向量机的多变量分类预测【23年新算法】

分类预测 | Matlab实现SCSO-SVM基于沙猫群优化算法优化支持向量机的多变量分类预测【23年新算法】 目录 分类预测 | Matlab实现SCSO-SVM基于沙猫群优化算法优化支持向量机的多变量分类预测【23年新算法】分类效果基本描述程序设计参考资料 分类效果 基本描述 1.Matlab实现SCSO-…

MySQL递归公用表表达式

&#x1f607;作者介绍&#xff1a;一个有梦想、有理想、有目标的&#xff0c;且渴望能够学有所成的追梦人。 &#x1f386;学习格言&#xff1a;不读书的人,思想就会停止。——狄德罗 ⛪️个人主页&#xff1a;进入博主主页 &#x1f5fc;专栏系列&#xff1a;MySQL知识 &…

asp.net core 教程

asp.net core 教程 写在前面新建项目Get和PostGETPOST MVC-模型控制视图如何通俗理解MVC代码实例 API模型&#xff08;前后端分离&#xff09;前端代码后端代码 文件配置优先级优先级顺序 从数据库读取配置文件数据缓存 写在前面 学了快一年多的C#了&#xff01; 我最开始学的…

XxlJob 常见的报错

XxlJob 启动日志报错&#xff1a; 报错一&#xff1a; ERROR c.x.job.core.util.XxlJobRemotingUtil - Connection refused: connect java.net.ConnectException: Connection refused: connect 解决方法&#xff1a; 要启动的类是 XxlJobAdminApplication &#xff0c;而不是…

【论文阅读】MCANet: Medical Image Segmentation with Multi-Scale Cross-Axis Attention

文章目录 摘要创新点总结实现效果总结 摘要 链接&#xff1a;https://arxiv.org/abs/2312.08866 医学图像分割是医学图像处理和计算机视觉领域的关键挑战之一。由于病变区域或器官的大小和形状各异&#xff0c;有效地捕捉多尺度信息和建立像素间的长距离依赖性至关重要。本文提…

SpringBoot Event,事件驱动轻松实现业务解耦

什么是事件驱动 Spring 官方文档AWS Event Driven 简单来说事件驱动是一种行为型设计模式&#xff0c;通过建立一对多的依赖关系&#xff0c;使得当一个对象的状态发生变化时&#xff0c;所有依赖它的对象都能自动接收通知并更新。即将自身耦合的行为进行拆分&#xff0c;使拆…

vscode括号颜色突然变成白色的了,怎么解决

更新版本后发现vscode的各种括号都变成了白色&#xff0c;由于分色括号已经使用习惯&#xff0c;突然变成白色非常不舒服&#xff0c;尝试多次后&#xff0c;为大家提供一下几种解决方式&#xff0c;希望能帮到同样受到此种困惑的你&#xff1a; 第一种&#xff1a; 首先打开…

TYN-02A-Ⅱ 太阳能警示灯

应用范围: 可安装在电线杆&#xff0c;路灯&#xff0c;围挡&#xff0c;交 通护栏及各种杆式固体等场所起警示作用。 产品特点&#xff1a; 采用进口PS材质; 光控无开关&#xff0c;白天不闪&#xff0c;昏暗环境自动闪烁&#xff0c;无需手动操作&#xff0c;省时省事; …

blender使用faceit绑定自己的表情动作

blender使用faceit绑定自己的表情控制模型 faceit是个神器&#xff0c;来记录一下如何让表情动起来保持相对位置头部分离&#xff0c;方便后续绑定faceitfaceit的注册rig生成地标Animate可以修正表情烘培之前记得保存使用Faceit的整个流程 faceit是个神器&#xff0c;来记录一下…

test-03-java 单元测试框架 testNG 入门介绍 junit/junit5/testNG 详细对比

拓展阅读 test-01-java 单元测试框架 junit 入门介绍 test-02-java 单元测试框架 junit5 入门介绍 test-03-java 单元测试框架 testNG 入门介绍 junit/junit5/testNG 详细对比 test assert-01-Google Truth 断言 test 系统学习-03-TestNG Spock testng 入门使用教程 开源…

Oracle 学习(2)

过滤和排序数据 where条件过滤 日期格式 查询10号部门的员工信息&#xff1a;SQL> select * from emp where deptno10 查询”KING”的信息&#xff1a;SQL> select * from emp where ename KiNg 未选定行。 注意&#xff1a;字符串大小写敏感。 SQL> selec…

【论文笔记】3D Gaussian Splatting for Real-Time Radiance Field Rendering

原文链接&#xff1a;https://arxiv.org/abs/2308.04079 1. 引言 网孔和点是最常见的3D场景表达&#xff0c;因其是显式的且适合基于GPU/CUDA的快速栅格化。神经辐射场&#xff08;NeRF&#xff09;则建立连续的场景表达便于优化&#xff0c;但渲染时的随机采样耗时且引入噪声…