ARM IHI0069F GIC architecture specification (3)

1.2 术语
本手册中的架构描述使用与 Armv8 架构相同的术语。 有关此术语的更多信息,请参阅 Arm® 架构参考手册 Armv8 A 部分的介绍,了解 Armv8-A 架构配置文件。
此外,在适当的情况下使用 AArch64 系统寄存器名称,而不是同时列出 AArch32 和 AArch64 系统寄存器名称。 AArch64 寄存器名称上的 ELx 后缀表示可以访问寄存器的最低异常级别。 
各个 AArch64 系统寄存器描述包含对提供相同功能的 AArch32 系统寄存器的引用。
以下部分定义了本手册中使用的架构术语:
• 中断类型。
• 第1-21 页的中断状态。
• 第1-21 页的处理中断的模型。
• 第1-22 页的附加条款。

1.2.1 中断类型

实现GIC架构的设备可以控制外设中断。 外设中断通常由发送到 GIC 的物理信号来断言。 GIC架构定义了以下类型的外设中断:
局部特定外设中断 (LPI)
LPI 是一个目标外设中断,它被路由到关联层次结构中的特定 PE:
• 在启用两种安全状态的系统中,LPI 始终是非安全组 1 中断。
• LPI 具有边沿触发行为。
• LPI 可以使用ITS 进行路由。
• LPI 没有活动状态,因此不需要显式停用。
• LPI 始终是基于消息的中断。
有关详细信息,请参阅第 5-78 页的 LPI。

私有外设中断 (PPI)
这是一个针对单个特定PE的外设中断,不同的PE可以使用相同的中断号来指示不同的事件:
• PPI 可以是组0 中断、安全组1 中断或非安全组1 中断。
• PPI 可以支持边沿触发或电平敏感行为。
• PPI 绝不会使用ITS 进行路由。
• PPI 处于活动状态,因此需要显式停用。

注:
通常,期望 PPI 由每个 PE 上同一中断源的不同实例使用,从而允许将公共中断号用于 PE 特定事件,例如
来自私有定时器的中断。

共享外设中断 (SPI)
这是一个外设中断,分发器可以将其路由到可以处理中断的指定 PE,或者路由到系统中已配置为接受此类中断的一组 PE 之一的 PE:
• SPI 可以是组0 中断、安全组1 中断或非安全组1 中断。
• SPI 可以支持边沿触发或电平敏感行为。
• SPI 绝不会使用ITS 进行路由。
• SPI 具有活动状态,因此需要显式停用。
有关详细信息,请参阅第 4-56 页的共享外设中断。 有关分发器的更多信息,请参阅第 3 章 GIC 分区。

软件生成中断 (SGI)
SGI 通常用于处理器间通信,并通过写入 GIC 中的 SGI 寄存器来生成:
• SGI 可以是组0 中断、安全组1 中断或非安全组1 中断。
• SGI 具有边沿触发行为。
• SGI 绝不会使用ITS 进行路由。
• SGI 具有活动状态,因此需要显式停用。
有关详细信息,请参阅第 4-55 页的软件生成的中断。
边沿触发的中断具有以下属性:
• 在检测到中断信号的上升沿时将其置位,然后无论信号状态如何,它都会保持置位状态,直到软件确认中断为止。
有关边沿触发的基于消息的中断的信息,请参阅基于消息的中断。
电平敏感的中断具有以下属性:
• 当中断信号电平有效时,它被置为有效;当中断信号电平不有效时,它被置为无效。
• 它被软件明确地置为无效。

1.2.2 中断状态
以下状态适用于 GIC 和连接的 PE 之间的每个接口:
     不活跃
         未激活或未决的中断。
     待办的
         被识别为在硬件中断言或由软件生成的中断,并等待目标 PE 处理。
     积极的
         已被 PE 确认并正在处理的中断,因此同一中断的另一个断言不会作为中断呈现给 PE,直到初始中断不再处于活动状态。
         LPI 没有活动状态,并在被 PE 确认后转换为非活动状态。
     有效和待处理
         一种中断,在中断的一次断言后处于活动状态,并在后续断言后处于挂起状态。
         LPI 没有活动和挂起状态,并在被 PE 确认后转换为非活动状态。
GIC 维护每个支持的中断的状态。 状态机定义了中断状态之间可能的转换,以及对于每种中断类型,导致转换的条件。 有关详细信息,请参阅第 4-51 页的中断处理状态机。

1.2.3 处理中断的模型

在多处理器实现中,存在以下用于处理中断的模型:
定向分销模式
     该模型适用于所有 PPI 和所有 LPI。 它还适用于:
     • 非传统操作期间的SPI,如果GICD_IROUTER<n>.Interrupt_Routing_Mode == 0。
     • 在传统操作期间,当 GICD_CTLR.ARE_* == 0 时,如果相应 GICD_ITARGETSR<n> 字段中只有一位 == 1。
     由软件指定的目标PE接收中断。
目标列表模型
     该模型仅适用于 SGI。 多个PE独立接收中断。 当 PE 确认中断时,仅该 PE 的中断挂起状态被清除。 中断对于每个 PE 独立地保持待处理状态,直到它被 PE 确认为止。
N 型号中的 1 个
     该模型仅适用于 SPI。 该中断针对一组指定的 PE,并且仅在该组中的一个 PE 上进行。 接受中断的 PE 以实现定义的方式选择。 该架构对可选择的 PE 进行了限制,请参阅第 4-63 页的启用中断分配。
     注
     • Arm GIC 架构保证仅向目标PE 集中列出的一个PE 提供N 中的1 中断。
     • 如果中断不是最高优先级中断,或者中断被ICC_PMR_EL1 屏蔽或在PE 内,则可能会向PE 提供N 中的1 中断。 请参阅第 4-46 页的中断生命周期。
     对于传统操作期间的 SPI,当目标寄存器中指定了多个目标 PE 时,适用此模型。
     如果多个 PE 可以处理中断,则硬件实现一种机制来确定哪个 PE 激活中断。

1.2.4 更多术语
本手册中使用了以下更多术语:

空闲优先级
     在 GICv3 中,空闲优先级 0xFF 是当该接口上没有活动中断时从 CPU 接口上的 ICC_RPR_EL1 读取的运行优先级。 在传统操作期间,从 GICC_RPR 读取的空闲优先级是由实现定义的,如 GICv2 中一样。


中断标识符(INTID)
     唯一标识具有关联事件及其源的中断的数字空间。 然后该中断被路由到一个或多个PE进行处理。 PPI 和 SGI 中断号是每个 PE 本地的。 SPI 和 LPI 具有物理域的全局中断号。 有关详细信息,请参阅第 2-31 页的 INTID。


中断路由基础设施 (IRI)
     分销商、再分销商以及(可选)一个或多个 ITS。 有关详细信息,请参阅第 3-38 页的 GIC 逻辑组件。


基于消息的中断
     基于消息的中断是由于对指定地址的存储器写访问而被置位的中断。 物理中断可以转换为基于消息的中断。 基于消息的中断可以支持电平敏感或边沿触发的行为,尽管 LPI 始终是边沿触发的。
     GICv3 支持两种基于消息的中断机制:
     • 一种用于通信SPI 的机制,其中分配的地址保存在分发器中。 在这种情况下,基于消息的中断可以是电平敏感的或边沿触发的。
     • 一种用于传送LPI 的机制,其中所分配的地址保存在ITS 中(如果实施了ITS),或者保存在再分发器中。
     Arm 建议使用 LPI 在支持 PCIe 的系统中提供对 MSI 和 MSI-X 功能的支持。 有关详细信息,请参阅第 5 章局部特定外设中断和 ITS。 GICv3 还包括使用基于消息的中断对信号 SPI 的架构支持,请参阅第 4-56 页的共享外设中断。

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

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

相关文章

位运算算法

文章目录 预备知识判断字符是否唯⼀丢失的数字两整数之和只出现⼀次的数字只出现⼀次的数字II消失的两个数字 预备知识 给一个数n,确定它的二进制表示中的第x位是0还是1 (n>>(x-1)) & 1 1 true是1,false是0 将一个数n的二进制表示的第x位修改成1 n | (1<<(x-1…

vmare17 安装不可启动的iso镜像系统

由于要测试一个软件&#xff0c;要安装一个Windows11_InsiderPreview_Client_x64_zh-cn_26058.iso 于是在虚拟机里捣鼓一下。但是这个iso好像不能直接启动 这样就无法直接安装了&#xff0c;怎么办呢&#xff0c;可以先用个pe系统引导进去&#xff0c;再在PE系统里安装这个iso…

实验4 词向量训练

必做题: 数据准备:数据集包含100个文件,每个文件里面有多个从维基百科上爬取的内容,每一条以字典形式保存,分为id,url,title,text四个字段,使用text字段的文本训练词向量。读取‘text’字段的文本,并使用jieba进行分词。使用Gensim工具训练词向量,训练方法为Skip-gr…

【链表】Leetcode 23. 合并 K 个升序链表【困难】

合并 K 个升序链表 给你一个链表数组&#xff0c;每个链表都已经按升序排列。 请你将所有链表合并到一个升序链表中&#xff0c;返回合并后的链表。 示例 1&#xff1a; 输入&#xff1a;lists [[1,4,5],[1,3,4],[2,6]] 输出&#xff1a;[1,1,2,3,4,4,5,6] 解释&#xff1…

【免费】如何考取《鲸鸿动能广告初级优化师》认证(详细教程)

鲸鸿动能广告初级优化师认证考试PC网址 初级&#xff1a;鲸鸿动能广告初级优化师认证-华为开发者学堂 (huawei.com) 注&#xff1a;免费认证&#xff0c;里面包含免费的课程&#xff0c;浏览器用Edge。 文章目录 鲸鸿动能广告初级优化师认证考试网址 前言 一、备考流程 二…

元素和节点

节点操作和事件 今日目标&#xff1a; 节点的概念和分类 节点的创建&#xff0c;插入&#xff0c;替换&#xff0c;删除操作 事件三要素 常用事件类型 0.回顾 # 1. 获取元素的尺寸 offset一套 dom.offsetWidth: 内容 内边距 边框 dom.offsetHeightclient一套 dom.clie…

软考 网络工程师 每日学习打卡 2024/3/21

学习内容 第8章 网络安全 本章主要讲解网络安全方面的基础知识和应用技术。针对考试应该掌握诸如数据加密、报文认 证、数字签名等基本理论&#xff0c;在此基础上深入理解网络安全协议的工作原理&#xff0c;并能够针对具体的 网络系统设计和实现简单的安全解决方案。 本章共有…

C语言经典例题(5) --- 交换数组、统计二进制、交换变量、菱形、字符串左旋

文章目录 1.交换数组2.统计二进制中1的个数3.交换两个变量(不创建临时变量)4.打印菱形5.字符串左旋 1.交换数组 将数组A中的内容和数组B中的内容进行交换。(数组大小一样) #include <stdio.h>void swap(int arr1[],int arr2[], int sz) {int tmp 0;for (int i 0;i &l…

python云上水果超市的设计与实现flask-django-php-nodejs

伴随着我国社会的发展&#xff0c;人民生活质量日益提高。于是对云上水果超市进行规范而严格是十分有必要的&#xff0c;所以许许多多的信息管理系统应运而生。此时单靠人力应对这些事务就显得有些力不从心了。所以本论文将设计一套云上水果超市&#xff0c;帮助商家进行商品信…

如何为您的网站压缩图像

今天碰到一个客户反馈&#xff0c;他在hostease购买了虚拟主机&#xff0c;创建的WordPress站点图片比较多&#xff0c;后来访问网站&#xff0c;页面上大量的图片加载时间较长&#xff0c;咨询网站图像如何压缩。我们为用户提供网站图像压缩&#xff0c;用户很快完成了设置。在…

【Pt】新建项目时的设置

新建项目时需要在如下界面做一些设置。 一、模板与文件 模板通常选择“PBR - Metallic Roughness Alpha-blend” 文件可以选择fbx&#xff0c;abc&#xff0c;obj等格式的三维模型文件 二、项目设置 2.1 文件分辨率 指的是在软件中的预览效果&#xff0c;分辨率越高预览效果…

使用npm创建一个全局的cli命令,就像vue-cli一样

我们用过vue-cli等工具包&#xff0c;全局安装之后&#xff0c;我们可以直接使用vue create等命令&#xff0c;实际上能够这样使用的原因&#xff0c;就是使用了package.json里面的bin字段注册命令。接下来就以一个脚本文件为例子为大家演示一下bin是如何发挥作用的。 创建项目…

跳过mysql权限验证来修改密码-GPT纯享版

1.打开 MySQL 的配置文件&#xff0c;通常是 my.ini 或 my.cnf。 2.找到 [mysqld] 部分&#xff0c;如果没有则添加。 3.在 [mysqld] 部分中添加一行&#xff1a;skip-grant-tables&#xff0c;这个选项告诉 MySQL 服务器跳过权限验证&#xff0c;允许任何用户连接而不需要密码…

OpenCV基于阈值的分割技术详细介绍

OpenCV 提供了基于阈值的分割技术&#xff0c;这是一种简单且常用的图像分割方法&#xff0c;其基本思想是根据像素的灰度值将图像分为不同的区域。下面详细介绍了 OpenCV 中基于阈值的分割技术&#xff1a; 全局阈值分割&#xff08;Global Thresholding&#xff09;&#xff…

java数据结构与算法基础-----排序------堆排序

java数据结构与算法刷题目录&#xff08;剑指Offer、LeetCode、ACM&#xff09;-----主目录-----持续更新(进不去说明我没写完)&#xff1a;https://blog.csdn.net/grd_java/article/details/123063846 文章目录 堆排序是利用堆&#xff08;数据结构&#xff09;设计的排序算法…

基于SSM+Jsp+Mysql的KTV点歌系统

基于SSMJspMysql的KTV点歌系统 基于SSMJspMysql的KTV点歌系统的设计与实现 开发语言&#xff1a;Java框架&#xff1a;ssm技术&#xff1a;JSPJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工…

SRC中的一些信息收集姿势

前言 前前后后挖了四个月的EDUSRC&#xff0c;顺利从路人甲升到了网络安全专家&#xff0c;从提交的内容来看大部分还是以中低危为主&#xff0c;主打的就是弱口令和未授权。 在这过程中还是比较浮躁的&#xff0c;因此接下来的时间还是要好好沉淀一下自身的技术&#xff0c;学…

undo log

从这篇「执行一条 SQL 查询语句&#xff0c;期间发生了什么&#xff1f; (opens new window)」中&#xff0c;我们知道了一条查询语句经历的过程&#xff0c;这属于「读」一条记录的过程&#xff0c;如下图&#xff1a; 那么&#xff0c;执行一条 update 语句&#xff0c;期间发…

Unix环境高级编程-学习-07-多线程之互斥锁

目录 一、自由抒发 二、函数介绍 1、pthread_mutex_init &#xff08;1&#xff09;声明 &#xff08;2&#xff09;作用 &#xff08;3&#xff09;参数 &#xff08;4&#xff09;返回值 &#xff08;5&#xff09;注意点 &#xff08;6&#xff09;宏 2、pthread_mut…

【大数据】四、HDFS 基础操作

IDE 连接 在本地电脑上解压 hadoop.tar.gz&#xff0c;配置环境变量 之后 去github 上 把 winutil.exe 和 hadoop.dll 下载到 hadoop 的bin 文件夹下 再修改 etc/hadoop-env.cmd 中的 JDK 路径 我们使用 IDEA 打开一个 JAVA Maven项目&#xff0c;进行测试 注意&#xff0…