[ARM异常]-ARMV8-aarch64 异常(中断)是如何跳转到向量表的
生活随笔
收集整理的這篇文章主要介紹了
[ARM异常]-ARMV8-aarch64 异常(中断)是如何跳转到向量表的
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
快速鏈接:
.
👉👉👉 個人博客筆記導讀目錄(全部) 👈👈👈
先看一張框圖,在中斷產生之后,PC將跳轉到VBAR + 中斷offset處,例如圖中藍色部分
那么有三個基地址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)
選好了基地址后,再選偏移? 我們看到向量表中有四行,那么選哪一行呢?
由Vector offsets from vector table base address表來決定的
- 如果發生異常并不會導致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
有關中斷的Mask,由下面一張表決定(Physical interrupt target and masking when both EL3 and EL2 are implemented)
總結
以上是生活随笔為你收集整理的[ARM异常]-ARMV8-aarch64 异常(中断)是如何跳转到向量表的的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python:将json数据写入到exc
- 下一篇: [hypervisor]-ARMV8的h