arm64的异常向量表vectors中设置了各种异常的入口,目前有效的异常入口有两个同步异常el0_sync,el1_sync和两个异步异常el0_irq,el1_irq,其他异常入口暂时都invalid。中断属于异步异常,所以本文重点关注el0_irq和el1_irq。
通过上图,我们可以看出中断的处理分为三个部分,保护现场,中断处理,恢复现场。其中el0_irq和el1_irq的具体实现略有不同,但处理流程大致是相同的。接下来我们以el0_irq为例对上面三个步骤进行梳理。
将CPU寄存器按照pt_regs结构体的定义将第一现场保存到栈上。
如上图,大概主要有如下三个动作:
在处理之前我们先看下什么叫做中断栈。
中断栈用来保存中断的上下文。
主要分三步: