首页 > 其他分享 >GICV3(转载)

GICV3(转载)

时间:2024-03-05 23:23:46浏览次数:31  
标签:EL1 优先级 secure 中断 GICV3 寄存器 转载 pending

本文转载:【GIC】一文看懂GICv3   1 GIC基本功能 1.1 GICv3概述         由于SOC中外设及与其相关的中断数量众多,且各中断又有多种不同的配置方式,为了减轻CPU的负担,现代处理器中断的配置和管理一般都通过中断控制器实现。         GIC是arm公司推出可与cortex-A和cortex-R处理器配合使用的中断控制器,当前一共有4个版本,分别为GICv1–GIv4。GICv3是基于armv8的SOC设计中应用较为广泛的一种中断控制器,GICv4与GICv3的功能基本相同,只是为了提高虚拟化的性能,增加了直接注入虚拟中断的能力。   0 图1 SOC中GICv3的连接关系图     图1是GICv3在SOC中的连接关系图,它为CPU处理所有连接到其上的中断。包括管理所有的中断源、中断行为、中断分组以及中断路由方式等,同时还提供相应的寄存器接口用于软件对这些行为的控制。         外设或软件触发中断后,GICv3根据中断配置信息,将其路由到特定cpu的IRQ或FIQ中断线上。CPU接收到中断后执行必要的上下文保存后,跳转到中断异常入口,并执行相应的中断处理流程。 1.2 GICv3组件         为了实现中断的配置、接收、仲裁和路由功能,GICv3设计了如图2所示的不同组件,它包含了SPI、PPI、SGI和LPI四种中断类型,以及distributor、redistributor、ITS和cpu interface四大组件。   0 图2 GICv3逻辑框图 其中各中断类型的特点如下:1 SPI中断(shared peripheral interrupt)  该类型中断不与特定的cpu绑定,可以根据affinity配置被路由到任意cpu或一组特定的cpu上。如一般的外设中断都是通过SPI方式连接的。 2 PPI中断(private peripheral interrupt)  该类型中断是每个处理器私有的,即一个特定的中断只会被路由到特定的处理器上。且其同一个中断号在每个处理器上都可以有不同的中断,如对于一个拥有两个PE的smp系统,中断号16的PPI中断可以分别被注册为PE0和PE1的私有中断,它们可以被独立触发并被特定的PE独立处理。 3 SGI中断(software generated interrupt)  该类型中断并没有实际的物理连线,而是由软件通过写寄存器方式触发,它只支持边沿触发。通常用于处理器之间的通信,如linux内核电源管理模块中调用的ipi中断就是通过SGI实现的 4 LPI中断(Locality-specific Peripheral Interrupt)  该类型中断是一种基于消息的中断,外设不需要通过硬件中断线连接到GIC上, 而可以向特定地址写入消息来触发中断。典型的应用为PCIe的MSI和MSI-X中断。LPI中断有一些其特有的属性,如只支持non secure group1分组、只支持边沿触发、可以选择使用或不使用ITS路由,以及没有active状态,也不需要显式的deactivation操作。 1.3 GICv3的中断属性 在GICv3中,不同中断类型具有不同的中断号范围,其定义如下:

中断类型 中断号 说明
SGI 0 - 15  
PPI 16 – 31  
SPI 32 - 1019  
特殊中断号 1020 - 1023  
保留中断号 1024 - 1055  
扩展PPI 1056 -1119 GICv3.1版本后才支持
保留中断号 1120 - 4095  
扩展SPI 4096 - 5119 GICv3.1版本后才支持
保留中断号 5120 - 8191  
LPI 8192 - 最大支持的中断号由实现确定
  由中断号标识的中断具有不同的属性,这些属性可以通过配置GICv3的寄存器实现。如常见属性的配置选项如下:
属性 可配置值 说明
中断使能 使能、失能  
触发方式 边沿触发、电平触发  
优先级 最小32个,最大256个  
亲和性 根据affinity值设置  
中断分组 Group0、secure group1、non-secure group1  
1.4 GICv3的中断生命周期 当中断配置完成后中断即可被触发,GIC中断的触发和处理流程如下:   0  图3 中断处理流程         中断由外设或软件触发以后,distributor和redistributor将根据中断的分组、优先级等配置信息将其分发到特定的cpu interface,并以irq或fiq的方式发送给对应的PE。此时中断处于pending状态,PE上的软件可以通过读取ICC_IAR0_EL1 / ICC_IAR1_EL1寄存器应答该中断,中断被应答后将会变为active状态。中断处理完成后,软件可以写寄存器ICC_EOIR0_EL1 / ICC_EOIR1_EL1以执行中断的优先级下降和deactive操作。中断deactive之后,将会变为inactive状态。  实际上除了上面的情形之外,当中断被应答之后且未处理完成之前,可能还会再次被触发,此时其会处于active and pending状态。其处理状态机如下图:   0   图4 中断状态机转换关系图 各个中断状态的含义如下:(1)inactive   中断未被触发,或者已经被cpu处理完成了 (2)pending   中断已经被硬件触发或软件产生(SGI),但cpu还没有应答中断 (3)activecpu已经应答并正在处理中断 (4)active and pendingcpu已经应答中断并正在处理中断,此时又有新的中断被触发了 1.5 GICv3的其它功能         GICv3为中断的security状态和虚拟化提供了支持。通过中断分组的方式其支持在不同的security状态下中断可以分别以FIQ或IRQ方式触发。与运行在EL2下的hypervisor配合,GICv3还为vPE提供了虚拟中断管理功能。   在多处理器系统中,GICv3还根据中断路由方式的不同支持以下三种中断处理模型:
中断处理模型 特点
targeted distribution模型 该模型下中断触发时只有指定的target PE会接收到中断1 所有的PPI、LPI都采用该模型2 在GICD_IROUTER.Interrupt_Routing_Mode配置为0时,SPI也采用该模型
targeted list模型 该模型下多个PE可以独立接收到中断,当一个PE应答中断后,只有该PE自身的中断pending状态被清除,而其它PE上的中断除非被该PE应答,否则依然会处于pending状态。1 该模型只能被用于SGI中断类型
1 of N模型 中断可以被路由到一组PE上,但只会被发送到其中的一个PE上。1 该模型只能被用于SPI中断类型
1.6 GICv3的编程模型         GIC可被分为几个不同的组件,且每个组件都会支持一个或多个编程接口,这些接口又可分为内存映射型寄存器接口和系统寄存器接口两类。其中Distributor、Redistributor和ITS为内存映射型寄存器接口,而CPU interface则是系统寄存器接口。在GICv3中不同组件的寄存器都以特定的前缀命名,各组件的命名可参考下图5:   0  图5 GIC各组件寄存器命名 2 GIC-v3组件介绍 2.1 Distributor组件 Distributor主要包含两部分功能:(1)作为编程接口可以通过GICD寄存器,对中断控制器的一些全局属性以及SPI类型中断的属性进行配置(2)中断触发时根据寄存器设定的中断分组、优先级以及亲和性等配置,将SPI和SGI中断路由到特定的redistributor和cpu interface上。 以下将分别描述Distributor可以执行的重要中断属性设置。 2.1.1 中断使能配置         GICv3可以设置特定中断号对应的中断是否被使能,若未设置使能状态则该中断不会被发送到CPU interface。中断的使能可以通过GICD_ISENABLER寄存器设置(n为0 - 32),中断的失能可以使用GICD_ICENABLER寄存器设置,这两个寄存器都为32 bit寄存器,每个中断使用一个bit控制其使能 / 失能状态。其寄存器定义如下:   0  2.1.2 中断触发方式配置         中断的触发方式可分为边沿触发(上升沿、下降沿)和电平触发(高电平、低电平),两种触发方式的行为有所不同。
触发方式 特点
边沿触发 在检测到上升沿或下降沿后触发中断,此后中断会一直处于触发状态,直到软件应答该中断为止
电平触发 在检测到特定电平后触发中断,电平变化或软件应答都能deassert该中断
        SPI的中断触发方式可用GICD_ICFGR寄存器设置(n为0 - 63),它是一个32bit寄存器,用两个bit表示一个中断的触发方式,其中bit0为保留位,bit1位0表示电平触发,为1表示边沿触发。其寄存器定义如下:   0 2.1.3 中断优先级配置           GICv3的中断优先级可用一个8bit的值表示,因此最多可包含256个优先级,实际的优先级数目是由实现确定的,含有两个security状态的系统最少需要32个中断优先级,含有一个security状态的系统最少需要16个中断优先级。GICv3的中断优先级值越小,则优先级越高。中断优先级的取值范围如下图:   0   在smp系统中每个PE可以支持不同的优先级bit,其可以通过ICC_CTLR_EL1.PRIbits和ICC_CTLR_EL3.PRIbits获取。        GICv3会确保unmasked且已使能的最高优先级pending中断会被发送给目标PE,但若有多个相同优先级的中断处于pending状态,则哪个中断被发送是由实现确定的。GICv3还可以将中断优先级分组,以将其分为组优先级和子优先级。当组优先级相等的中断正在处理时,即使有子优先级更高的中断被触发也不会发生中断抢占。若多个组优先级相等的中断都处于待处理的pending状态,则子优先级更高的中断会被优先处理。寄存器ICC_BPR0_EL1、ICC_BPR1_EL1用于设置优先级分组。(组优先级 > 子优先级)        GICv3中断优先级可以通过GICD_IPRIORITYR寄存器设置(n为0 - 254),它是一个32bit的寄存器,其定义如下:   0   当前active中断的优先级可通过ICC_RPR_EL1 、ICC_AP0R_EL1(group 0)或ICC_AP1R_EL1(group 1)寄存器读取,ICC_RPR_EL1寄存器的定义如下:   0 该寄存器返回的优先级为当前PE上处于active状态中断的组优先级。   ICC_AP0R_EL1寄存器定的义如下:   0   2.1.4 中断亲和性配置         SPI类型中断使用affinity值和路由模式信息来配置中断的亲和性,ARMv8中affinity层次结构的定义如下图,其可被配置为4个或3个affinity等级,对于每个PE可通过读MPIDR寄存器获取其对应的affinity值。   0 图6 armv8的affinity层次结构           SPI的中断亲和性可通过GICD_CTRL的ARE_S、ARE_NS和GICD_IROUTER寄存器配置,其中GICD_CTRL的ARE_S、ARE_NS分别用于使能secure和non secure状态下亲和性路由功能。在相应使能位设置后,实际的中断路由模式由以下GICD_IROUTER寄存器设置(n为32 - 1019):   0  其中bit 31用于设置中断路由模式,其取值如下:0:该中断被路由到aff0 – aff3指定的PE上1:该中断可被路由到partition node上的任意PE上   2.1.5 中断分组配置         为了支持ARMv8异常模型和security模型的中断处理,GICv3引入了中断分组机制。GICv3的中断可以分为以下三个group:
中断group 中断处理方式
Group0中断 该中断应该被EL3处理
Secure group1中断 该中断应该被secure EL1或secure EL2(使用secure虚拟化)处理
Non secure group1中断 该中断应该被non secure EL1或non secure EL2(使用non secure虚拟化)处理
        GICv3可以触发两种中断信号IRQ和FIQ,对中断分组的目的就是使不同group的中断,在不同状态下可分别被路由到IRQ或FIQ上,在AARCH64状态下,中断的路由方式如下:   0         SPI中断group可通过GICD_IGROUPR和GICD_IGRPMODR寄存器配置(n为0 - 31),PPI和SGI的中断group可通过GICR_IGROUPR0和GICR_IGRPMODR0寄存器配置。下面以SPI的配置为例,GICD_IGROUPR是32bit寄存器,其与GICD_CTRL.DS配合,每个bit用于控制一个中断的group。其寄存器定义如下:   0
GICD_IGROUPR对应bit值 GICD_CTRL.DS值 中断分组
0 0 Secure中断
0 1 Group 0中断
1 0 Non secure group 1中断
1 1 Group 1中断
GICD_IGRPMODR寄存器也是每个bit控制一个中断,且当GICD_CTRL.DS等于0时,其与GICD_IGROUPR共同用于确定一个中断的group类型,其组合方式如下:   0         GICv3只能将中断以IRQ或FIQ信号的方式转发给CPU,要达到上表所示的不同group中断能被特定异常等级处理,还需要CPU的配合。在armv8中SCR_EL3寄存器是用于控制security相关配置的,其各bit的定义如下图:   0  其中IRQ和FIQ用于配置中断触发时会被路由到CPU的哪个异常等级和security状态,它们的定义如下: 0 (1)若将FIQ位配置为0,且当前执行状态低于EL3时,则FIQ不会被路由到EL3,而路由到第一个可以处理该中断的异常等级FEL(2)若将FIQ配置为1,则运行于任何执行状态时,FIQ都会被路由到EL3 而IRQ的配置方式与FIQ类似。综合上面分析,结合GIC和CPU的配置,ARMv8的中断将有以下几种路由方式: 1 secure EL1中断(1)当前执行在secure EL1,则触发方式为IRQ  由于secure EL1中断需要在secure EL1中处理,故只要将SCR.IRQ设置为0即可将它路由到FEL(2)当前执行在non secure EL1,则触发方式为FIQ  同样,由于它需要被secure EL1处理,而EL3具有中断转发功能,因此可以将中断先路由到EL3,然后由EL3转发给secure EL1。故可以将SCR.FIQ设置为1(3)当前执行在EL3,则触发方式为FIQ  此时,FIQ需要被设置为1,中断被路由到EL3,然后转发给secure EL1 2 non secure EL1中断(1)当前执行在secure EL1,则触发方式为FIQ  由于中断希望被non secure EL1处理,因此中断可以先路由到EL3,然后转发到non secure EL1。因此SCR.FIQ设置为1(2)当前执行在non secure EL1,则触发方式为IRQ  此时,中断被当前EL处理即可,故SCR.IRQ需设置为0(3)当前执行在EL3,则触发方式为FIQ  此时,FIQ需要被设置为1,中断被路由到EL3,然后转发给non secure EL1 3 EL3中断(1)当前执行在secure EL1,则触发方式为FIQ  将SCR.FIQ设置为1,以使中断路由到EL3(2)当前执行在non secure EL1,则触发方式为FIQ  将SCR.FIQ设置为1,以使中断路由到EL3(3)当前执行在EL3,则触发方式为FIQ  将SCR.FIQ设置为1,以使中断路由到EL3   根据上面的几种情况,即可知道异常等级切换时只要将SCR.FIQ和SCR.IRQ值按下表设置,及可正确地配置中断路由关系:
异常等级 SCR.IRQ SCR.FIQ
Secure EL1 0 1
Non secure EL1 0 1
EL3 1 1
2.1.6 中断控制器的security支持 ARMv8支持四个异常等级和两种security状态。GICv3各中断分组可以独立控制是否使能,也可以控制non secure状态下是否可以访问group 0中断的寄存器。它是通过GICD_CTRL寄存器控制的,其寄存器定义如下:   0          其中EnableGrp0、EnableGrp1NS和EnableGrp1S分别用于控制group0、non secure group1和secure group1中断的使能。DS用于控制non secure状态是否能访问group0中断的寄存器,以及中断是否能支持两个secure状态,当DS值为0时GICv3支持两个security状态以及三个中断group,当DS值为0时GICv3只支持一个security状态以及最多两个中断group。   2.1.7 中断状态控制         GICv3支持通过软件控制中断的状态,如将某个中断设置为pending状态、active状态或清除其pending、active状态。它可以通过配置以下几个寄存器实现:
寄存器 功能
GICD_SETSPI_NSR 设置特定的non secure中断的pending状态,若该中断当前为inactive状态,则转换为pending状态。若当前为pending状态,则转换为pending and active状态
GICD_CLRSPI_NSR 清除特定non secure中断的pending状态
GICD_SETSPI_SR 设置特定的secure中断的pending状态,若该中断当前为inactive状态,则转换为pending状态。若当前为pending状态,则转换为pending and active状态
GICD_CLRSPI_SR 清除特定secure中断的pending状态
GICD_ISPENDR 设置一个或一组中断为pending状态,若该中断当前为inactive状态,则转换为pending状态。若当前为pending状态,则转换为pending and active状态。该寄存器的每一个bit代表一个中断号
GICD_ICPENDR 清除一个或一组中断为pending状态,该寄存器的每一个bit代表一个中断号
GICD_ISACTIVER 设置一个或一组中断为active状态,若该中断当前不处于active状态,则转换为active状态。若当前为active状态,则该操作被忽略。该寄存器的每一个bit代表一个中断号
GICD_ICACTIVER 清除一个或一组中断为active状态,该寄存器的每一个bit代表一个中断号
其寄存器的定义分别如下: 0   0  2.2 Redistributor组件 Redistributor位于Distributor和CPU interface之间,它也包含如下两部分功能: (1)作为编程接口可以通过GICR寄存器,对PPI和SGI类型中断的属性进行配置,以设定其中断触发类型、中断使能以及中断优先级等配置。同时,其还包含了电源管理、LPI中断管理功能 (2)将最高优先级的pending中断发送到其对应的CPU interface上  与SPI中断属性在distributor中不同,PPI和SGI的中断属性设置位于redistributor中。如中断使能、优先级、触发方式、分组一种中断状态转换等,由于这些设置除了寄存器不同之外,与SPI的设置方式类似,因此这部分寄存器只选取少部分做示例说明。 2.2.1 最高优先级pending中断发生改变的条件 (1)先前的最高优先级中断已经被应答 (2)先前的最高优先级中断被更高优先级中断抢占 (3)先前最高优先级中断被移除 (4)中断使能状态被修改 (5)该PE不再处理中断,如进入睡眠状态等               2.2.2 PPI和SGI的中断使能配置         PPI和SGI中断的使能可以通过GICR_ISENABLER0寄存器设置,中断的失能可以使用GICR_ICENABLER0寄存器设置,这两个寄存器都为32 bit寄存器,每个中断使用一个bit控制其使能 / 失能状态。其寄存器定义如下:   0  2.2.3 PPI和SGI的中断优先级配置   PPI和SGI的中断优先级可通过GICR_IPRIORITYR设置(n为0 - 7),其寄存器定义如下: 0  2.2.4 LPI管理功能         由于LPI支持的中断数量较多,若这些中断的配置寄存器都使用GIC内部寄存器则需要的寄存器空间很大,因此GICv3通过将其配置信息保存在内存的方式以节约寄存器空间使用。这些表包括LPI配置表、LPI pending状态表、虚拟LPI配置表和虚拟LPI状态表。在GIC初始化时需要为这些配置表分配内存,并将内存基地址设置到相应寄存器,从而将该段内存的管理转交给GICv3。其寄存器定义分别如下:   0  以上定义中物理地址需要执行一定的对齐操作,其它的bit会被用于定义一些该段内存属性信息,如cache,share的属性等。          除了设置配置表基地址外,Redistributor还实现了改变LPI中断状态的寄存器,如设置LPI pending状态和清除LPI pending状态寄存器,其定义如下: 0 2.2.5 电源管理功能         在GICv3中CPU interface和PE必须位于同一个power domain,而redistributor不需要跟它们处于同一个power domain。因此,在CPU interface和PE电源关闭且GIC处于上电的情况下(distributor、redistributor、ITS),则GIC需要维护与该PE之间接口的状态。它可以通过如下流程完成: (1)在CPU和PE下电之前,软件需要将redistributor和cpu interface之间的接口设置为静默(quiescent)模式。它可以通过将GICR_WAKER.ProcessorSleep设置为1实现。并且轮询GICR_WAKER.ChildrenAsleep的状态,当该值也被设置为1时设置完成。 (2)在CPU和PE上电之后,软件需要将GICR_WAKER.ProcessorSleep设置为0,且轮询GICR_WAKER.ChildrenAsleep的状态,直到该值为0时推出静默模式。 相应的寄存器定义如下:   0       2.3 CPU interface组件         CPU interface可用于物理中断、虚拟中断处理,以及可为hypervisor提供虚拟机控制接口。包括SGI中断产生、PPI、SGI的优先级设置,最高pending优先级读取以及应答、deactivate、完成操作执行等。 2.3.1 中断使能配置         CPU interface可以使能或关闭某一group中断,在CPU interface中一共有三个寄存器用于配置中断的使能: (1)ICC_IGRPEN0_EL1:它用于控制是否使能group 0中断   0 (2)ICC_IGRPEN1_EL3:它用于控制group 1中断的使能,其中bit 0用于控制non secure group 0的使能,bit 1用于控制secure group 1的使能   0 (3)ICC_IGRPEN1_EL1:它用于控制当前secure状态下group 1中断使能。该寄存器其实只是ICC_IGRPEN1_EL3寄存器的别名,即在non secure状态下其与ICC_IGRPEN1_EL3的bit 0等价,在secure状态下其与ICC_IGRPEN1_EL3的bit 1等价。

2.3.2 中断的状态转换         中断的状态转换包括中断应答、中断deactivate以及中断完成操作。其中中断应答通过读取ICC_IAR0_EL1(group 0)和ICC_IAR1_EL1(group 1)寄存器完成,寄存器定义如下:   0    只有当前异常等级和security状态下的EOImode为1时,才需要执行deactivate操作。否则只要执行完成操作即可。中断完成操作通过向寄存器ICC_EOIR0_EL1(group 0)或ICC_EOIR1_EL1(group 1)写入中断ID实现,该操作之后CPU将又可以响应新的中断。   0     2.3.3 最高优先级pending中断获取 当前PE上最高优先级pending中断可分别通过读取ICC_HPPIR0和ICC_HPPIR1寄存器获取。其中ICC_HPPIR0的寄存器定义如下:   0     2.3.4 SGI中断产生         SGI是由软件通过写CPU interface寄存器触发的,其需要设置的内容包括中断号,中断需要被发送的目的PE。根据不同的security状态和中断group其可分别通过ICC_SGI0R_EL1、ICC_SGI1R_EL1和 ICC_ASGI1R_EL1寄存器产生,其对应关系如下表:
寄存器 中断类型
ICC_SGI0R_EL1 Secure group 0中断
ICC_SGI1R_EL1 当前security状态的group 1中断
ICC_ASGI1R_EL1 非当前security状态的group 1中断
 这三个寄存器的定义类似,以ICC_SGI0R_EL1为例其定义如下:   0 其中IRM指定中断路由模型,当其为0时中断被路由到affinity指定的PE list上,否则会被发送给系统中除自身之外的其他PE。TargetList指定中断将要被发送的PE组,它与aff0的定义相匹配。   2.4 ITS组件 ITS的作用是将一个来自device的输入eventID转换为LPI中断号,并确定该中断将被发送的目的PE。它通过device table、interrupt translate table、collection table和vPE table这几张转换表实现中断号的转换。这些表的关系如下图:   0     2.4.1 Device table Device table提供了一组device table entry(DTE),其中每个DTE为指向特定deviceID相关的中断转换表(ITT)基地址。其转换关系如下:   0   2.4.2 中断转换表 每个连接到ITS上且含有多个event的设备,都拥有一张ITT表。对于物理中断和虚拟中断ITE分别提供了两种类型的映射,对于物理中断其映射关系如下:(1)eventID到中断ID的映射 (2)eventID到ICID的映射,其中ICID又指向collection表 对于虚拟中断其映射关系如下:(1)eventID到虚拟中断ID的映射 (2)eventID到vPE表的映射,vPE表包含了虚拟PE number(vPEID)   2.4.3 Collection表 Collection表提供了ICID到目的redistributor寄存器基地址的映射。对于每个ITS只有一个collection表,它可被保存在寄存器或内存中。CT entry的定义如下:   0     2.4.4 vPE表 vPE表提供了vPEID到目的redistributor和虚拟LPI pending表基地址之间的映射。它提供了ITS中所有相关vPE的信息,其定义如下:   0     2.4.5 ITS命令接口 ITS使用命令队列的方式处理相关命令,命令队列的结构如下图:   0         如图所示它是通过三个寄存器GITS_CBASER、GITS_CREADR和GITS_CWRITER控制队列运行的。其中寄存器GITS_CBASER用于指定ITS命令队列基地址的物理地址,寄存器GITS_CWRITER由软件控制用于向命令队列中断写入ITS命令,GITS_CREADR由ITS控制读取并处理队列中的命令。该队列是循环缓冲区,因此当读写指针达到队列尾后可回绕回队列头继续执行相应操作。   3 虚拟中断处理 GICv3提供了对虚拟化的支持,在虚拟化环境中虚拟机可以支持以下特性:(1)vPE可以被配置为接收虚拟group 0中断和虚拟group 1中断 (2)虚拟group 0中断使用vFIQ信号发送给non secure 1的vPE (3)虚拟group 1中断使用vIRQ信号发送给non secure 1的vPE (4)vPE可以像处理物理中断一样处理虚拟中断   中断虚拟化需要GICv3和hypervisor上的软件共同配合。支持虚拟化之后,EL3或EL2将物理中断配置为路由到EL2,EL2上的hypervisor捕获到中断以后根据中断的类型,分别执行不同的处理。这些中断包含以下两类:(1)本身就发送给hypervisor的中断。这类中断如由系统产生的中断、或维护虚拟机的中断。它们由虚拟机按照普通的物理中断处理即可。 (2)需要被发送给vPE的中断。虚拟机接收到这种类型中断后,若接收中断的vPE正在运行,则会通过GICv3将其按照虚拟中断的方式注入到特定vPE的list register中。否则虚拟机将中断信息暂存到内存中,并在合适的时机执行实际的虚拟中断注入。虚拟中断注入包括将特定vPE的虚拟中断ID设置为pending状态,并设置与其相关的物理中断信息 3.1 虚拟中断的注入和处理  虚拟中断注入后,GICv3将会选择list register中最高优先级的pending虚拟中断,并以vIRQ或vFIQ的形式发送给vPE,此后vPE就可以将其使用与物理中断相同的方式处理,包括应答中断、优先级降低以及deactivate操作等。若虚拟中断与物理中断关联,则当其处理完成后,相应的物理中断也会被deactivate。   由于list register的数量有限,为了确保vPE接收到的是最高优先级的pending中断。虚拟机需要为每个vPE维护一个pending中断优先级列表,并且其优先级最高的一组pending中断会被注入到list register中。若pending中断超过list register的数量,虚拟机将剩余的pending中断信息保存在内存中,并在此后按优先级顺序恢复注入到list register中。List register相当于所有active、pending中断的cache。   3.2 虚拟中断类型 Hypervisor的虚拟机维护中断包含以下几种类型: (1)当list register中不含有pending中断时,发出中断信号以允许hypervisor向其load pending中断。或当list寄存器为空或将为空时,发出中断以允许hypervisor向其load保存在内存中的pending中断 (2)当接收到一个不再list register中的中断的EOI命令时(该中断信息可能被保存在内存中),向hypervisor发出中断 (3)enable和disable虚拟中断group,需要向hypervisor发送中断以可能需要改变list register的内容 由于list register保存了部分vPE的上下文,因此当虚拟机将一个vPE切换为另一个vPE时,也需要切换相应list register的内容。   3.3 虚拟中断与物理中断的关联 Hypervisor可以向vPE注入两种类型的中断: (1)与物理中断关联的虚拟中断,如某一个由特定VM拥有的外设中断。 (2)由hypervisor通过软件产生,而与物理中断无关的虚拟中断,如hypervisor用于模拟虚拟外设的中断。 为了支持以上两种模式,GIC list register支持与物理中断关联的虚拟中断。 (1)hypervisor配置ICC_CTRL_EL1.EOImode = 1 (2)当vPE相关的物理中断被发送到PE时,由hypervisor接收并应答,此时物理中断处于active状态。 (3)hypervisor将虚拟中断插入目的vPE的pending中断列表。若hypervisor希望执行该中断的优先级下降,则执行一个EOI操作,但不要deactivate该中断 (4)当该虚拟中断能够被vPE处理时,hypervisor将该pending中断写到LR寄存器中,并且将ICH_LR_EL2.HW设置为1,以表示该虚拟中断是与物理中断关联的。此时,与其关联的物理中断ID也会被保存在相同的list register中 (5)vPE运行并处理该虚拟中断,当vPE处理完成该中断后,deactivate虚拟中断后,物理中断也会被deactivate。   4 LPI中断处理 LPI是基于消息的中断,它可以有两种触发方式: (1)使用ITS将device ID和event ID转换为LPI的中断ID (2)通过写GICR_SETLPIR寄存器直接将LPI中断号转发到redistributor上 下面分别是包含ITS和不包含ITS的LPI系统架构图:   0   0   4.1 LPI配置表 若一个redistributor含有对LPI的支持,则其需要包含以下两张LPI中断信息表: (1)LPI配置表:该表用于配置LPI中断的优先级和使能位。它由redistributor的GICR_PROPBASER寄存器指定。其每个中断号在表中的定义如下:   0 (2)LPI pending表:该表用于指示LPI中断的pending中断号。它由redistributor的GICR_PENDBASER寄存器指定     这两张表的size取决于系统支持的LPI中断数量,它由GICR_PROPBASER.IDBits域指定 GICv4提供了对虚拟LPI的支持,其也提供了两张类似的表GICR_VPROPBASER和GICR_VPENDBASER,以支持虚拟LPI中断的配置和pending状态管理.

标签:EL1,优先级,secure,中断,GICV3,寄存器,转载,pending
From: https://www.cnblogs.com/lethe1203/p/18055530

相关文章

  • 百度&高德地图小区景点边界轮廓实现(转载)
    经常的我们在使用地图功能时,会发现在选择一个小区或者一个热门景点的时候,地图上面会给出其边界轮廓,能够方便我们知道其范围大小,有时候在我们使用地图组件的时候,也会面临着类似的需求。比如在地图上面标识出一个商场范围内的热力图,一个热门景点的游览情况等。那么,我们该如何利用地......
  • Oracle 表空间和数据文件遇到的坑 (转载于 微信公众号 JieKeXu DBA之路)
    转载链接https://mp.weixin.qq.com/s/IKF_KrWkxZ5BJS-OacYWUw前言本文适用于普通的标准的8k块大小的Oracle企业版数据库,10g、11g、19c均可适用,但对于ODA,一体机可能有所区别,请慎重使用1.db_files的坑记录一下年前遇到的一个关于表空间扩容的小问题,大家都知道对于Oracle......
  • 转载,win11删除隐藏的蓝牙设备。
     解决方案打开设备管理器:将鼠标移动到windosw11左下角开始按钮处点击右键并点击设备管理器。显示隐藏的设备:进入设备管理器后,点击最上面一行查看,选择显示隐藏的设备卸载旧的蓝牙驱动或设备:找到目前未启用的蓝牙设备或驱动(点击显示隐藏的设备后新出现的设备,一般颜色相较正......
  • 【转载】如何转发博客园中的文章
    原文1、在要转载的博客上点击右键,选择“审查元素”(F12)。2、按CTRL+F,搜索cnblogs_post_body,找到后,右键点击该DIV,选择:复制——复制outerHTML。3、打开自己的博客,新加随笔,点击“HTML”按钮,把刚才复制的内容粘贴进来。确定。完成。4、注明转载来源。 ......
  • [转载] 跟我一起写Makefile
    目录简介概述关于程序的编译和链接makefile介绍makefile的规则一个示例make是如何工作的makefile中使用变量让make自动推导makefile的另一种风格清空目录的规则Makefile里有什么?Makefile的文件名包含其它Makefile环境变量MAKEFILESmake的工作方式书写规则规则举例规则的语法在规......
  • How to Create a Wimboot Installation of Windows 8.1(转载)
    HowtoCreateaWimbootInstallationofWindows8.1Introduction:HowtoCreateaWimbootInstallationofWindows8.1IntroductionEverwonderhowcomputermanufacturerscanfita20GBinstallationofWindowsontoa16GBdrive?Itisnowpossiblewith......
  • Nginx添加开源防火墙(waf)防护(转载)
    项目背景介绍需求产生由于原生态的Nginx的一些安全防护功能有限,就研究能不能自己编写一个WAF,参考Kindle大神的ngx_lua_waf,自己尝试写一个了,使用两天时间,边学Lua,边写。不过不是安全专业,只实现了一些比较简单的功能:功能列表:支持IP白名单和黑名单功能,直接将黑名单的IP访问拒绝。......
  • Nginx安全防火墙配置,保护网站不受恶意攻击(转载)
    nginx安全防火墙配置,保护网站不受恶意攻击引言:在当今互联网时代,网站面临着各种安全威胁,如恶意攻击、入侵等。为了保护网站的数据和用户隐私,我们需要采取一系列措施来加强网站的安全性。Nginx是一个高性能的Web服务器,在安全方面也提供了丰富的功能,我们可以通过Nginx的防火墙配置来......
  • C#GDI高效绘图(转载)
    汇总利用双缓冲技术在C#中实现GDI高效绘图 双缓冲是将图片在显示到DC前,现在要内存建一个DC,也就是用于存储这张图片的内存区,然后在将这部分update到你要显示的地方这样,可以防止画面抖动很大这样和你说吧,如果要实现你要的效果,你必须用指针访问内存比如,把程序声明成unsaf......
  • CSDN以及博客园如何转载别人的文章
    1、找到要转载的文章,用chrome浏览器打开,右键选择检查2、在chrome中下方的框里找到对应的内容,html脚本中找到对应的节点(article_content),选中节点,网页上被选中内容会被高亮显示,然后右键菜单选中Copy–>CopyouterHTML3、进入直接的博客主界面,选择”写博客“,直接将chrome......