【Linux-I.MX6ULL裸机学习】中断向量表

代码来自于正点原子阿尔法Linux开发板光盘


比如在中断向量表中规定了:在某个地址0x80000A对应着某个中断服务函数,那么在产生这个中断时,就会从0x80000A这个地址去读取中断服务函数,并执行。

如果想改变这个地址,也就是要设置地址偏移。具体要做的:需要修改SCB的 VTOR 寄存器为新的中断向量表起始地址。

ARM-A7 的中断向量表:

你可能会问了:啊?!我的那些外设所需要的外部中断就只有"IRQ interrupt"这一个中断吗?这够吗?

诶别急啊,Cortex-A 内核 CPU 的所有外部中断都属于这个 IRQ 中断,当任意一个外部中断发生的时候都会触发 IRQ 中断。在 IRQ 中断服务函数里面就可以读取指定的寄存器来判断发生的具体中断是什么。这些外部中断和 IRQ 中断的关系如下图:

Cortex-A7 中断系统

  1. 中断向量表
    Cortex-A 中断向量表它有8个中断,其中重点关注 IRQ。Cortex-A 的中断向量表需要用户自己去定义(见下图)。

  2. 中断向量偏移
    我们的裸机例程都是从 0x87800000开始的,因此要设置向量偏移。
  3. GIC 中断控制器
    同NVIC(stm32的中断控制器)一样,GIC 用于管理 Cortex-A 的中断。GIC提供了开关中断,设置中断优先级。
  4. IMX6U 中断号
  5. 中断服务函数的编写
    一个是IRQ 中断服务函数的编写,另一个就是在 IRQ 中断服务函数里面去查找并运行的具体的外设中断服务函数。
相关推荐
xiaoxiaoxiaolll40 分钟前
期刊速递 | 《Light Sci. Appl.》超宽带光热电机理研究,推动碳纳米管传感器在制药质控中的实际应用
人工智能·学习
励志码农2 小时前
JavaWeb 30 天入门:第二十三天 —— 监听器(Listener)
java·开发语言·spring boot·学习·servlet
DisonTangor2 小时前
字节开源 OneReward: 通过多任务人类偏好学习实现统一掩模引导的图像生成
学习·ai作画·开源·aigc
黎宇幻生3 小时前
Java全栈学习笔记33
java·笔记·学习
2501_926227943 小时前
.Net程序员就业现状以及学习路线图(五)
学习·.net
奔跑吧 android4 小时前
【linux kernel 常用数据结构和设计模式】【数据结构 2】【通过一个案例属性list、hlist、rbtree、xarray数据结构使用】
linux·数据结构·list·kernel·rbtree·hlist·xarray
朗迹 - 张伟4 小时前
Golang安装笔记
开发语言·笔记·golang
NiKo_W5 小时前
Linux 文件系统与基础指令
linux·开发语言·指令
Darkwanderor7 小时前
Linux 的权限详解
linux
siy23337 小时前
[c语言日记] 数组的一种死法和两种用法
c语言·开发语言·笔记·学习·链表