ARM GIC 通用中断控制器
本小结介绍一下 SGI。
SGI
SGI (Software Generated Interrupt) 的意思是软件触发中断,通常 IPI (Inter-Processor Interrupt) 核间中断就是通过 SGI 实现的。
软中断,顾名思义,它不是由硬件触发的,而是软件通过写中断控制器的某个寄存器触发的。使用的场景通常是一个 CPU 向另一个 CPU 触发中断,想要和其它CPU通信之类的。
1. GICv2
在GICv2里,是通过写分发器的寄存器 GICD_SGIR
产生的。
其中,TargetListFilter
决定分发器是如何处理 SGI 请求的,是转发给特定的目标CPU?还是转发给除了自己的CPU?还是至发给自己?
如果 TargetListFilter=0b00
,那么就是要转发给指定的CPU,可以指定多个。CPUTargetList[7:0]
有8位,对应CPU接口,想发给哪个哪位就置1。
SGIINTID
就是 SGI 中断号,刚好是4位,对应SGI中断号是 0-15。
2. GICv3
GICv3中,PE通过写下面这些寄存器触发中断。这些寄存器属于CPU接口系统寄存器。
ICC_SGI1R_EL1
Interrupt Controller Software Generated Interrupt Group 1 Register
ICC_SGI1R_EL1
为当前安全状态生成Group 1 SGIs。
这部分我还不是很了解,之后有机会补上。
备注:图片来自ARM GIC相关的手册、ARMv8-A架构寄存器手册。