基于IMX6ULLmini的linux裸机开发系列七:中断处理流程

这篇具有很好参考价值的文章主要介绍了基于IMX6ULLmini的linux裸机开发系列七:中断处理流程。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

中断上下文

cpu通过内核寄存器来运行指令并进行数据的读写处理的,它在进入中断前一个时刻的具体值,称为中断上下文

中断上下文是指CPU在进入中断之前保存的寄存器状态和其他相关信息。当CPU接收到中断请求时,它会保存当前正在执行的指令的状态,并将寄存器的值切换到一个特定的上下文中,以便处理中断。(保护现场)

中断上下文包括了CPU寄存器的值、程序计数器(PC)的值、堆栈指针(SP)的值,以及其他与中断处理相关的状态信息。这些信息被保存在内存中的特定位置,通常称为中断向量表或中断描述符表。

当中断处理程序完成后,CPU会从中断上下文中恢复之前的寄存器状态,继续执行被中断的程序或任务。这种上下文切换的过程称为中断处理过程

具体流程

  • 初始化 IRQ 模式栈指针:在进入中断之前,需要为 IRQ 模式分配一个栈空间,并将栈指针初始化到该空间。

  • 进入 IRQ 模式:CPU 切换到 IRQ 模式,以便执行中断处理程序。

  • CPSR 寄存器:保存当前运行状态的 CPSR 寄存器的值,以便在中断处理完成后恢复。

  • 保存现场:将当前正在执行的指令的上下文保存到栈中。这包括保存通用寄存器、保存 LR(链接寄存器,保存返回地址)、保存 SPSR(保存当前程序状态寄存器)等。

  • 获取中断编号:读取中断控制器(GIC)相关寄存器中的值,以获取触发中断的编号。

  • 读取 GIC 基地址和 GICC 基地址:从系统配置中获取 GIC(中断控制器)的基地址和 GICC(GIC CPU Interface)的基地址。

  • GICC_IAR 寄存器:读取 GICC_IAR 寄存器,该寄存器保存着最高优先级中断的编号。

  • 执行中断处理函数:根据中断编号,在 IRQ 中断服务表中找到对应的中断处理函数,并执行该函数。

  • 还原现场:从栈中恢复之前保存的现场信息,包括恢复通用寄存器、恢复 LR、恢复 SPSR 等。

  • 返回原程序:根据之前保存的返回地址,从中断处理程序返回到原来被中断的程序继续执行。

cpsr寄存器

基于IMX6ULLmini的linux裸机开发系列七:中断处理流程,linux,运维,服务器

  • bit31:负数标记位

  • bit30:零标志位

  • ...

  • M[4:0]:运行模式控制位

    • 10000:User 模式

    • 10001:FIQ 模式

    • 10010:IRQ 模式

    • 10011:SVC模式

    • 10111:Abort模式

    • 11011:Undef模式

    • 11111:System模式

    • 10110:Monitor模式

    • 11010:Hyp模式

mrs <Rt>,cpsr //读cpsr
msr cpsr,<Rt> //写cpsr
cps #xx //写立即数到cpsr中的M[4:0]
基于IMX6ULLmini的linux裸机开发系列七:中断处理流程,linux,运维,服务器

GICC基地址

4.1.3 CPU interface register ma (GIC官方手册)

三级流水线

  • 取指令(pc)

  • 译指令

  • 执行指令

  • 基于IMX6ULLmini的linux裸机开发系列七:中断处理流程,linux,运维,服务器

lr = pc = 当前执行指令+8
当前执行指令的下一条:lr-4

基于IMX6ULLmini的linux裸机开发系列七:中断处理流程,linux,运维,服务器

基于IMX6ULLmini的linux裸机开发系列七:中断处理流程,linux,运维,服务器

arm:PC=当前执行指令地址+8_armpc+8_aoXiaMi的博客-CSDN博客

这里还看不太懂,先继续学算了文章来源地址https://www.toymoban.com/news/detail-660104.html

到了这里,关于基于IMX6ULLmini的linux裸机开发系列七:中断处理流程的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 嵌入式linux项目之智能仓储(基于正点原子IMX6ULL开发板)

    提示:该项目根据华清远见智能仓储项目改版,将他的A9开发板换成了自己的IMX6ULL开发板。同时等我将该项目整个流程完成之后,会为大家附上适配正点原子linux开发板的全部代码 (代码资料和视频教程私聊) 视频教程 相应课程配套源码 本人其他项目链接基于linux的智能仓储项

    2024年01月16日
    浏览(89)
  • IMX6ULL裸机篇之I2C协议

    I2C 是最常用的通信接口,众多的传感器都会提供 I2C 接口来和主控相连。 比如摄像头、 加速度计、触摸屏等。 I.MX6U-ALPHA开发板 使用 I2C1 接口连接了一个距离传感器 AP3216C ,本章我们就来学习如何使用 I.MX6U 的 I2C 接口来驱动 AP3216C ,读取 AP3216C 的传感器数据。 I2C 是很常见的

    2024年02月08日
    浏览(80)
  • IMX6ULL裸机篇之RTC实验-时间错误问题

    我这里用的开发板上芯片是 IMX6ULL,但是,由于恩智浦提供的 IMX6ULL芯片的参考手册关于 RTC章节的不全面。所以,实际在开发时使用了 《IMX6UL参考手册》。 对参考手册的理解如下: LPSRTCMR 寄存器 与 LPSRTCLR 寄存器是存时间的两个寄存器。即用两个寄存器来存时间。 读取SRTC的

    2024年02月06日
    浏览(51)
  • IMX6ULL裸机篇之DDR3参数配置分析

    上一篇博文进行了 DDR参数的初始化,通过一个 execl表进行配置,生成脚本文件。文章网址如下: IMX6ULL裸机篇之DDR3初始化_凌雪舞的博客-CSDN博客 本文对 DDR的参数配置进行详细的说明。即对 \\\"Register Configuration\\\"页面参数的配置 进行说明。 开发板上的DDR3L 内存芯片型号是 NT5CC

    2024年02月05日
    浏览(39)
  • IMX6ULL裸机篇之中断实验-通用中断驱动说明二

    本文是 IMX6ULL 裸机篇---中断实验 。旨在用 C 语言编写一套简单的中断驱动框架代码。 在 start.S 文件中,我们在中断服务函数 IRQ_Handler 中调用了 C 函数 system_irqhandler 来处 理具体的中断。 本实验会认识中断控制器: GIC控制器。 I.MX6U(Cortex-A)的中断控制器,关于 GIC 的详细内容

    2023年04月24日
    浏览(57)
  • 【IMX6ULL驱动开发学习】02.IMX6ULL烧写Linux系统

    由于我买的是正点原子的IMX6ULL阿尔法开发板,但是我是看韦东山老师视频学习的驱动 所以这里我烧录的方法是按照韦东山老师的课程来的 这里给出烧写Linux系统用到的工具 链接:https://pan.baidu.com/s/1bD-xxn3K8xQAVkJSaJmTzQ 提取码:af6w 下载解压后,可以看到烧写工具 烧写Linux系统

    2024年02月13日
    浏览(59)
  • 基于IMX6ULL的智能车载终端项目(代码开源)_imx6ull 开源 linux 项目 车载终端

    1.4 车载终端:杂项功能 车载终端是一个非常复杂且常用的装置,随着电车与自动驾驶技术的不断升级迭代,需求也与日俱增!我们往往需要在终端上附加许许多多其他的功能,比如:智能家居联动、车内环境监测、天气预报与网上浏览等! 作者强调:考虑到篇幅有限,作者

    2024年04月08日
    浏览(54)
  • 【IMX6ULL驱动开发学习】11.Linux之SPI驱动

    参考:驱动程序开发:SPI设备驱动_spi驱动_邓家文007的博客-CSDN博客 目录 一、SPI驱动简介 1.1 SPI架构概述 1.2 SPI适配器(控制器)数据结构 1.2 SPI设备数据结构 1.3 SIP设备驱动 1.4 接口函数  二、SPI驱动模板 SPI驱动框架和I2C驱动框架是十分相似的,不同的是因为SPI是通过片选引

    2024年02月11日
    浏览(54)
  • 【IMX6ULL驱动开发学习】12.Linux驱动之设备树

    承接上一篇博客 【IMX6ULL驱动开发学习】11.驱动设计之面向对象_分层思想(学习设备树过渡部分) 代码获取: https://gitee.com/chenshao777/imx6-ull_-drivers 我后面将三个层合并了(实际上只有前两层),合并成一个dev_drv.c了,暂时没有加GPIO操作,只是个框架 合并前的代码在 11.butt

    2024年02月13日
    浏览(47)
  • 【基于IMX6ULL开发板开机摄像头的自启动】

    这里简述项目相关背景: 最近在准备暑期实习和秋招,准备一个Camera项目,涉及调试内核、优化开机——从启动到获取第一帧图像的时间,硬件平台为 正点原子IMX6ULL开发板 ,摄像头为 OV5640 ,内核基于正点原子出厂linux源码,根文件系统暂时选择正点原子出厂文件系统 首先

    2024年02月08日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包