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 页的共享外设中断。

相关推荐
代码改变世界ctw9 天前
Armv8/Armv9架构从入门到精通-介绍
arm·trustzone·atf·tee·armv8·armv9·周贺贺
Wanliang Li1 个月前
Linux电源管理——CPU Hotplug 流程
linux·嵌入式硬件·嵌入式·armv8·电源管理·cpuhotplug
代码改变世界ctw1 个月前
如何学习Trustzone
安全·trustzone·atf·optee·tee·armv8·armv9
代码改变世界ctw5 个月前
【Arm Cortex-X925】 -【第四章】-时钟和复位
arm开发·armv8·armv9·cortex-r
代码改变世界ctw6 个月前
Armv8/Armv9架构的学习大纲-学习方法-自学路线-付费学习路线
arm·trustzone·soc·芯片·armv8·armv9·周贺贺
CyberSecurity_zhang6 个月前
Armv8-R内存模型详解
mcu·armv8·内存模型·r52·memory model
Liangtao`6 个月前
[GICv3] 3. 物理中断处理(Physical Interrupt Handling)
armv8·gic·中断控制器·gicv3
eeblacksmith8 个月前
ARM IHI0069F GIC architecture specification (8)
armv8·gicv3
eeblacksmith10 个月前
ARM IHI0069F GIC architecture specification (5)
armv8·gicv3