Cortex-A7:ARM官方推荐的嵌套中断实现机制

2024-09-08 07:20

本文主要是介绍Cortex-A7:ARM官方推荐的嵌套中断实现机制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

0 参考资料

ARM Cortex-A(armV7)编程手册V4.0.pdf
ARM体系结构与编程第2版

1 前言

Cortex-M系列内核MCU中断硬件原生支持嵌套中断,开发者不需要为了实现嵌套中断而进行额外的工作。但在Cortex-A7中,硬件原生是不支持嵌套中断的,这从Cortex-A7中断向量表中仅为外部中断设置了一个中断向量可以看出。本文介绍ARM官方推荐使用的嵌套中断实现机制,以通过软件方式在Cortex-A7上实现中断嵌套。

2 ARM官方推荐的嵌套中断实现机制

2.1 概述

什么是中断嵌套?

中断嵌套是指中断系统正在执行一个中断服务时,有另一个优先级更高的中断提出中断请求,这时会暂时中止当前正在执行的级别较低的中断源的服务程序,去处理级别更高的中断源,待处理完毕,再返回到被中断了的中断服务程序继续执行的过程。

如何在Cortex-A7上实现嵌套中断?

Cortex-A7硬件原生不支持嵌套中断,按照ARM官方说法实现嵌套中断需要软件实现。

在Cortex-A7上实现嵌套中断的核心思想是什么?

在Cortex-A7上实现嵌套中断的核心思想就是在进入IRQ模式后保存一些必要的信息,然后切换到使能IRQ的特权模式(如系统模式),使得新的中断能够被CPU响应。为了方便操作,一般在进入main函数前就切换到特权模式,在进入IRQ模式后我们切换到同一种特权模式。

为什么不直接在IRQ模式下使能IRQ实现嵌套中断即可?

之所以不能直接在IRQ模式下使能IRQ有很多原因,其中最重要的一个就是因为在下一个IRQ中断到来时会保存错误的CPSR(当前程序状态寄存器)到SPSR_irq(IRQ模式下的程序状态保存寄存器)中,会将中断前的现场破坏掉。

上述问题可以通过下图描述:
在这里插入图片描述

2.2 嵌套中断实现步骤

说明:
进入main函数前就处于系统模式(特权模式),进入IRQ时同样切换到系统模式。

2.2.1 保存上下文

在使能IRQ之前,我们需要保存上下文。包括返回地址及SPSR_irq(IRQ模式下的程序状态保存寄存器)。

2.2.2 确定中断源并失能中断

确定中断源,并将中断失能,防止产生新的同样的中断(对于嵌套中断来说,只有比当前抢占优先级更高的中断才能抢占执行)。

2.2.3 切换到失能IRQ模式的系统模式

系统模式可以操作一些特殊寄存器。这时IRQ仍然处于失能状态。

2.2.4 将LR入栈然后再使能IRQ

为什么需要将LR入栈:
第一次进入IRQ模式前处于系统模式,LR保存的是系统模式下的程序返回地址。为了防止进入系统模式后使用BL指令(BL指令会将LR的值设置为子函数下一条指令地址)破坏LR的值,需要将LR入栈保护起来。否则LR的值被修改后,IRQ执行完毕后将无法返回中断打断位置的下一条指令位置。
将LR入栈之后,便可以使能IRQ,这时便处于使能IRQ的系统模式。

2.2.5 根据中断源执行相应的中断服务函数

这时IRQ已经使能,如果发生了更高抢占优先级的中断,应该抢占当前中断执行。

2.2.6 执行完中断服务函数后将LR出栈

在完成了中断服务函数后首先进入失能IRQ的系统模式,将入栈的LR出栈。

2.2.7 恢复到IRQ模式并返回到中断打断位置

进入失能IRQ的IRQ模式,到这里来嵌套中断的工作宣告结束,根据SPSR_irq(IRQ模式下的程序状态保存寄存器)恢复中断打断前的CPSR(当前程序状态寄存器),将保存在IRQ模式的LR的值写入PC,返回中断打断位置。

2.2.8 ARM官方示例汇编程序

IRQ_HandlerSUB lr, lr, #4SRSFD sp!, #0x1f 	@ use SRS to save LR_irq and SPSR_irq in one step onto the@ System mode stackCPS #0x1f 				@ Use CPS to switch to system modePUSH {r0-r3, r12} 		@S tore remaining AAPCS registers on the System mode stackAND r1, sp, #4 			@ Ensure stack is 8-byte aligned. Store adjustment and@ LR_sys to stackSUB sp, sp, r1PUSH {r1, lr}BL 						@ identify_and_clear_sourceCPSIE i 				@ Enable IRQ with CPSBL C_irq_handlerCPSID i 				@ Disable IRQ with CPSPOP {r1, lr} 			@ Restore LR_sysADD sp, sp, r1 			@ Unadjust stackPOP {r0-r3, r12} 		@ Restore AAPCS registersRFEFD sp! 				@ Return using RFE from the System mode stack.

3 总结

(1)为实现嵌套中断必须通过切换到特权模式实现,且在main函数之前就设置为相同的特权模式(如系统模式)。
(2)开发者需要自行根据中断抢占优先级决定触发的中断是否有资格运行。
(3)使用软件方式实现嵌套中断相比非嵌套中断处理方式会多不少指令,效率有所下降。
(4)开发者需要自行根据中断嵌套规则,决定新中断是否有资格抢占执行。
(5)相比于硬件原生支持嵌套中断,软件实现嵌套中断不但效率低下还非常容易出错。

这篇关于Cortex-A7:ARM官方推荐的嵌套中断实现机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147483

相关文章

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

PyQt6/PySide6中QTableView类的实现

《PyQt6/PySide6中QTableView类的实现》本文主要介绍了PyQt6/PySide6中QTableView类的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学... 目录1. 基本概念2. 创建 QTableView 实例3. QTableView 的常用属性和方法

PyQt6/PySide6中QTreeView类的实现

《PyQt6/PySide6中QTreeView类的实现》QTreeView是PyQt6或PySide6库中用于显示分层数据的控件,本文主要介绍了PyQt6/PySide6中QTreeView类的实现... 目录1. 基本概念2. 创建 QTreeView 实例3. QTreeView 的常用属性和方法属性

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

pandas中位数填充空值的实现示例

《pandas中位数填充空值的实现示例》中位数填充是一种简单而有效的方法,用于填充数据集中缺失的值,本文就来介绍一下pandas中位数填充空值的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是中位数填充?为什么选择中位数填充?示例数据结果分析完整代码总结在数据分析和机器学习过程中,处理缺失数

Golang HashMap实现原理解析

《GolangHashMap实现原理解析》HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作,:本文主要介绍GolangH... 目录HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

Java对象转换的实现方式汇总

《Java对象转换的实现方式汇总》:本文主要介绍Java对象转换的多种实现方式,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java对象转换的多种实现方式1. 手动映射(Manual Mapping)2. Builder模式3. 工具类辅助映

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服