ARMV8-aarch64 异常(中断)是如何跳转到向量表的

先看一张框图,在中断产生之后,PC将跳转到VBAR + 中断offset处,例如图中蓝色部分
ARMV8-aarch64 异常(中断)是如何跳转到向量表的

那么有三个基地址VBAR_EL1、VBAR_EL3、VBAR_EL1(secure),到底是使用哪一个呢?
由Routing when both EL3 and EL2 are implemented 表来决定,中断routing到了EL1则使用VBAR_EL1,routing到了EL3则使用VBAR_EL3,routing到了secure EL1则使用VBAR_EL1(secure)
ARMV8-aarch64 异常(中断)是如何跳转到向量表的
选好了基地址后,再选偏移? 我们看到向量表中有四行,那么选哪一行呢?
由Vector offsets from vector table base address表来决定的
ARMV8-aarch64 异常(中断)是如何跳转到向量表的

  • 如果发生异常并不会导致exception level切换,并且使用的栈指针是SP_EL0,那么使用第一组异常向量表。
  • 如果发生异常并不会导致exception level切换,并且使用的栈指针是SP_EL1/2/3,那么使用第二组异常向量表。
  • 如果发生异常会导致exception level切换,并且比目的exception level低一级的exception
    level运行在AARCH64模式,那么使用第三组异常向量表。
  • 如果发生异常会导致exception level切换,并且比目的exception level低一级的exception
    level运行在AARCH32模式,那么使用第四组异常向量表。

选好中断向量表中的某一行之后,那么具体选哪一个偏移呢?
会根据中断的类型来决定,如果是irq和fiq会根据当前PE的状态和中断的配置属性,来决定是IRQ或FIQ
ARMV8-aarch64 异常(中断)是如何跳转到向量表的

有关中断的Mask,由下面一张表决定(Physical interrupt target and masking when both EL3 and EL2 are implemented)

ARMV8-aarch64 异常(中断)是如何跳转到向量表的ARMV8-aarch64 异常(中断)是如何跳转到向量表的