【ARMv8/v9 GIC 系列 4.2 -- GIC CPU Interface 详细介绍】

文章目录

    • GIC CPU Interface 介绍
      • CPU Interface 主要寄存器

GIC CPU Interface 介绍

A 系列处理器提供 5个管脚来实现中断,分别是:

  • nIRQ:物理普通中断
  • nFIQ:物理快速中断
  • nVIRQ:虚拟普通中断
  • nVFIQ:虚拟快速中断
  • vNMI 不可屏蔽中断

如下图所示:
在这里插入图片描述

图 1-1

其中虚拟中断是为了实现虚拟化而准备的,我们只看物理中断。

Core 提供给中断的物理管脚只有两个,中断会有成百上千个,GIC怎么把这些中断发送给core是一个问题。这时就需要 CPU interface了。CPU interface 将GIC发送的中断信息 通过IRQ/FIQ管脚发送给连接到 Core。

CPU interface 提供了以下的功能:

  • 将中断请求发送给core
  • 中断进行认可
  • 中断完成识别
  • 设置中断优先级屏蔽
  • 定义中断抢占策略
  • 决定当前处于pending状态最高优先级中断

在GICv3架构中,CPU interface被抽离出来,实现在core内部的, 如下图所示

在这里插入图片描述

图 1-2

GIC-600/GIC-700不包含CPU interface。这样做的好处是,可以减少中断响应的时间,并且减少系统总线的占用。对于众核SoC设计来说,其物理设计非常大,CPU interface 实现在core内部,也就意味着某些中断寄存器可以放在其内部,这样core就可以很快的访问到这些寄存器了。对于那些常用的寄存器,core不用跋山涉水的通过系统总线或片上网络去频繁访问GIC了。CPU interface与GIC之间,是通过专用的 AXI-stream 总线来传输信息的。
在这里插入图片描述

图 1-3

CPU Interface 主要寄存器

GIC-700 CPU接口包含多个控制和状态寄存器,用于配置和管理中断。以下是一些主要寄存器的简介:

  1. ICC_SRE_EL1/EL2/EL3(System Register Enable):用于控制系统寄存器接口与内存映射接口之间的选择。当启用系统寄存器接口时,可以通过系统寄存器访问GIC功能,而不是通过传统的内存映射方式。
  2. ICC_CTLR_EL1/EL3(CPU Interface Control Register):提供了控制CPU接口行为的配置选项,包含了如EOImode的设置,这影响了中断结束的信号方式。
  3. ICC_PMR_EL1(Priority Mask Register):定义了一个优先级阈值,只有高于此阈值的中断才能被送达给CPU。这允许操作系统或应用通过提高或降低该阈值来动态控制中断的处理。
  4. ICC_IAR0_EL1/ICC_IAR1_EL1(Interrupt Acknowledge Register):用于接收和确认当前待处理的最高优先级中断的ID,分别用于Group 0和Group 1的中断。
  5. ICC_EOIR0_EL1/ICC_EOIR1_EL1(End of Interrupt Register):用于表明一个中断已经被处理完成,分别用于结束Group 0和Group 1的中断。
  6. ICC_BPR0_EL1/ICC_BPR1_EL1(Binary Point Register):用于设置分组优先级的二进制点位置,决定了优先级字段的分组和子优先级的界限。
  7. ICC_IGRPEN0_EL1/ICC_IGRPEN1_EL1(Interrupt Group Enable Register):用于启用或禁用Group 0和Group 1中断的递送。

推荐阅读
https://www.sohu.com/a/771753252_121124377

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Hi3861 OpenHarmony嵌入式应用入门--LiteOS Mutex

CMSIS 2.0接口中的Mutex(互斥锁)是用于在多线程环境中保护共享资源的访问机制。Mutex(互斥锁)是一种特殊的信号量,用于确保同一时间只有一个线程可以访问特定的共享资源。 在嵌入式系统或多线程应用中,当多…

C语言常用标准头文件

头文件的基础概念 在C的系列语言程序中,头文件(通常扩展名为.h)被大量使用,它通常包含函数、变量、结构体等的声明和定义,以及一些宏定义和类型定义。头文件的主要作用是为了方便管理和重用代码,它可以被多…

3dsMax怎样让渲染效果更逼真出色?三套低中高参数设置

渲染是将精心构建的3D模型转化为逼真图像的关键步骤。但要获得令人惊叹的渲染效果,仅仅依赖默认设置是不够的。 实现在追求极致画面效果的同时,兼顾渲染速度和时间还需要进行一些调节设置,如何让渲染效果更加逼真? 一、全局照明与…

【Python】已解决:urllib模块设置代理ip

文章目录 一、分析问题背景二、可能出错的原因三、错误代码示例四、正确代码示例五、注意事项 已解决:urllib模块设置代理ip 一、分析问题背景 在使用Python的urllib模块进行网络请求时,有时我们需要通过代理服务器来发送请求,以达到隐藏真…

设计模式原则——单一职责原则(SPS)

设计模式原则 设计模式示例代码库地址: https://gitee.com/Jasonpupil/designPatterns 单一职责原则(SPS): 又称单一功能原则,面向对象五个基本原则(SOLID)之一原则定义:一个类应…

使用 ks 安装 mysql

https://www.kubesphere.io/zh/docs/v3.3/application-store/built-in-apps/mysql-app/ 准备工作 您需要启用 OpenPitrix 系统。如何启用? 动手实验 步骤 1:从应用商店部署 MySQL 在 demo-project 的概览页面,点击左上角的应用商店。找到 …

Linux-磁盘管理与文件系统

目录 一、磁盘结构 1、磁盘的物理结构 2、磁盘的数据结构 3、磁盘存储容量 4、接口类型 二、磁盘分区 1、磁盘的两种分区方式 1.1、MBR分区 1.2、GPT分区 三、查看硬盘的分区情况 1、Fdisk—查询磁盘设备 2、lsblk—以树形查看磁盘分区 3、blkid—查看磁盘的UUID …

ONLYOFFICE 桌面编辑器 8.1 发布:全新功能齐备的 PDF 编辑器、丰富的幻灯片版式

前言 在当前数字化迅速发展的时代,办公软件套件作为企业日常工作的核心工具,其功能的全面性和使用的便捷性直接影响着工作效率和团队协作的效果。在众多办公软件中,ONLYOFFICE凭借其卓越的性能和丰富的功能,备受用户青睐。近日&a…

基于Java少儿编程管理系统设计和实现(源码+LW+调试文档+讲解等)

💗博主介绍:✌全网粉丝10W,CSDN作者、博客专家、全栈领域优质创作者,博客之星、平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌💗 🌟文末获取源码数据库🌟 感兴趣的可以先收藏起来,…

手机照片怎么恢复?3个方法,从灾难中崛起

已经成为了我们随身携带的必备品。而在这些小巧玲珑的设备中,存储着我们大量的个人回忆和重要资料。其中,手机拍摄的照片更是承载着我们的欢笑、泪水、成长与经历,但它们会因为意外从此消失。 面对这样的困境,我们是否只能无奈接…

Linux基础 - 定时计划

目录 零. 简介 一. cron 二. crontab 三. cron和crontab的区别 四. 例子 零. 简介 在 Ubuntu 系统中可以使用 crontab 来设置定时计划任务。crontab 是 Linux 下的无图形界面的计划任务工具,它可以在无需人工干预的情况下运行作业。 一. cron 在 Ubuntu 系统…

[ARM-2D 专题]3. ##运算符

C语言的宏系统相当强大,它允许使用##符号来处理预处理期的文本替换。这种用法被称为标记连接(token pasting)操作,其结果是将两个标记紧紧地连接在一起,而省略掉它们之间的所有空格。在复杂的宏定义中,运用…

13 物理层介质及设备

物理层介质及设备 一、线缆的连接 (一)线序 ​ 线序: RJ-45连接头12345678568A绿白绿橙白蓝蓝白橙棕白棕568B橙白橙绿白蓝蓝白绿棕白棕 ​ 1、2发送,3、6接收 (二)线缆的应用 1.线缆的连接 ​ 标准…

边缘计算为企业解决数据问题,提升业务效率和竞争力-天拓四方

企业在当前数字化时代面临着一系列具体的问题和挑战,这些问题往往与数据处理、实时响应、安全性以及运营成本等方面密切相关。边缘计算作为一种新兴的计算模型,能够有效地帮助企业解决这些问题,提升业务效率和竞争力。 首先,企业…

业务架构交付物

背景 业务的核心元素、扩展元素以及它们的协同关系,业务架构和其他架构的关系等等已经有了不少认识,那么,通过对业务架构的还原和分析,到底能够得到什么业务架构的内容呢?它可以是一套流程框架体系,也可以…

el-dialog使用::v-deep()穿透设置样式不生效,解决办法亲测有效!

场景&#xff1a; <el-dialogv-model"dialogVisible"width"800px":before-close"beforeClose"append-to-body:close-on-click-modal"false"title"增加文档"><template #footer><div style"text-align:c…

电梯开关状态人员进出检测数据集VOC+YOLO格式2220张4类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;2220 标注数量(xml文件个数)&#xff1a;2220 标注数量(txt文件个数)&#xff1a;2220 标注…

YOLOv10(6):YOLOv10基于TensorRT的部署(基于INetworkDefinition)

1. 写在前面 我们在前面已经讲过很多关于YOLOv10的一些知识点&#xff0c;也简单理了一下如何训练自己的数据。 现在本篇文章主要是讲解一下如何在TensorRT中部署YOLOv10&#xff0c;相信经过这一步&#xff0c;各位小伙伴已经能够无限的接近于将YOLOv10产品化了。 另一个需要说…

C++学习合集

#整理到一块&#xff0c;方便查东西&#xff0c;顺便补充一些之前没有学习到的东西# 变量 char--1字节 short--2字节 int-4字节 long--4字节 long long(int)--8字节&#xff1b;准确来说变量的大小取决于编译器&#xff0c;1字节8个二进制位&#xff0c;其中最高位为符号位…

【系统架构设计师】五、计算机网络(概念|通信技术|网络技术)

目录 一、计算机网络概念 二、通信技术 三、网络技术 3.1 局域网(LAN) 3.1.1 局域网拓扑结构 3.1.2 局域网协议 3.2 无线局域网(WLAN) 3.3 广域网(WAN) 3.4 城域网&#xff08;MAN) 3.5 移动通信网 四、组网技术 4.1 OSI七层模型 4.1.1 交换机 4.1.2 路由器 4.2…