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

相关文章

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

java父子线程之间实现共享传递数据

《java父子线程之间实现共享传递数据》本文介绍了Java中父子线程间共享传递数据的几种方法,包括ThreadLocal变量、并发集合和内存队列或消息队列,并提醒注意并发安全问题... 目录通过 ThreadLocal 变量共享数据通过并发集合共享数据通过内存队列或消息队列共享数据注意并发安全问题总结在 J