ARM GIC 通用中断控制器(2)

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架构寄存器手册。

  • 11
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值