1、中断优先级寄存器每8bit一个中断,但是那些bit有效则是有硬件设计时决定,通过查询ICC_CTLR_EL1/3.PRIbits,具体描述查看4.8.2 priority grouping
2、GICD_IPRIORITYR<n> 中的寄存器存放的是spi寄存器,sgi、ppi寄存器的优先级在gicr_ipriority<n>
3、gicr_ipriority<n>每核都有可以独立配置
4、gic提供了安全和非安全两种基址去访问优优先级设置寄存器。
- 安全态访问任何中断的中断优先级寄存器,其值与真实寄存器中的值一致
- 非安全态读Non-secure Group 1 interrupt的优先级的值,为真实8bit值左移一位地位补0;
- 非安全态写Non-secure Group 1 interrupt的优先级的值,为写入的优先级值右移1位,高位补1;
- 硬件这种做法的目的,我任务是为了保证group 0的中断优先级>安全group1>非安全group1;
5、非安全态无法设置中断屏蔽寄存器ICC_PMR在0x00-0x7f之间,只能设置大于等于0x80
6、中断抢占再gic模块中的条件是,将要抢占的中中断优先级高于当前正在运行的中断优先级(icc_rpr,runing
priority register).通过软件和硬件中Process State、PSATE、Exception级别的I或F位的值和中断路由控制,PE是否通过中断来响应中断。
问题:非安全态读取安全中断相关的寄存器是什么现象?