【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 中断服务函数里面去查找并运行的具体的外设中断服务函数。

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-05-05 03:04:02       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-05 03:04:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-05 03:04:02       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-05 03:04:02       20 阅读

热门阅读

  1. 如何学习 Unreal Engine

    2024-05-05 03:04:02       38 阅读
  2. 【Git命令】通过在线demo学习

    2024-05-05 03:04:02       12 阅读
  3. mysql 删除数据,导致存在表空间碎片的解决方法

    2024-05-05 03:04:02       10 阅读
  4. vue的action与mutation 的区别

    2024-05-05 03:04:02       11 阅读
  5. 深入了解WebP:下一代图像格式

    2024-05-05 03:04:02       7 阅读
  6. 40道Linux结业测试题,有解析,有答案

    2024-05-05 03:04:02       8 阅读
  7. python学习笔记----函数进阶(七)

    2024-05-05 03:04:02       13 阅读
  8. MySQL数据库—初识数据库 | DDL语句 | DML语句

    2024-05-05 03:04:02       9 阅读
  9. 【SHADER】Shader实例学习2:Loading Wheel

    2024-05-05 03:04:02       7 阅读