第二十八期-ARM64体系的异常与中断(2)

本文深入介绍了ARM64体系中通用中断控制器GICv3的工作原理,包括GICv3的硬件架构、中断类型以及中断处理流程。GICv3作为处理器和外设中断之间的桥梁,支持LPI、PPI、SPI和SGI四种中断类型,其处理流程包括中断生成、分发、传递和激活等阶段。
摘要由CSDN通过智能技术生成

作者:罗宇哲,中国科学院软件研究所智能软件研究中心

上一期中我们介绍了ARM64体系的异常,这一期我们将介绍ARM64体系中通用中断控制器(General Interrupt Controller,GIC)的中断处理流程。

一、GICv3简介[1]

中断是外设给处理器传递信息的一种方式,外设中断相对于处理器通常是异步的。ARM64体系中外设中断是通过通用中断控制器转发给处理器的。通用中断控制器是支持和管理中断的硬件部件,它提供了用于管理中断源、中断行为和将中断路由至一个或多个处理器的寄存器。GICv3(General Interrupt Controller Version 3)支持ARMv8-A 架构,其硬件架构定义了:

  • 处理中断的硬件规范,这些中断发生在连接到GIC的处理器上;
  • 中断控制器的用户编程接口,该接口既适应单处理器又适应多处理器;

对于每一个处理器,GIC描述了系统内的不同中断是如何产生外部中断请求(IRQ)和快速中断请求(FIQ)的,而ARMv8-A异常模型(Exception Model)则描述了处理器是如何处理这些IRQ和FIQ中断请求的。

GIC用于处理外设中断,外设中断表现为发送给GIC的信号。GIC定义了四种外设中断:

  • Locality-specific Peripheral Interrupt (LPI):一种基于消息的边沿中断[2](硬件中有边沿触发和电平触发的概念,电平触发是在高或低电平保持的时间内触发,而边沿触发是由高到低或由低到高这一瞬间触发 [3];
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值