arm 体系架构-异常中断与恢复

一、定义

(1)针对SoC来说,发生复位、软中断、中断、快速中断、取指令异常、数据异常等,我们都统一叫异常。所以说:中断其实是异常的一种。

(2)异常的定义就是突发事件,打断了CPU的正常常规业务,CPU不得不跳转到异常向量表中去执行异常处理程序;中断是异常的一种,一般特指SoC内的内部外设产生的打断SoC常规业务,或者外部中断(SoC的GPIO引脚传回来的中断)。

理解函数调用与异常的区别

二、异常发生时arm核处理流程

arm定义好了异常向量表,定义了各种异常发送时跳转的函数。

在发生中断时先保存现场,再去处理中断,最后恢复现场。

1、保存现场(硬件自动完成):就是保存所有寄存器的值;当发生中断的瞬间,栈会自动保存无需保护的寄存器,如图:

将这些寄存器保存在栈中。

注意:上图中"LR"保存的是正常函数调用的返回地址,"返回地址"保存的是中断处理完成后的返回地址。

2、调用处理函数(硬件跳转):发生中断,C函数会保证不会破坏 R4 至 R11

3、恢复现场:硬件恢复上图保存的寄存器值。

ref:

相关推荐
点灯小铭1 小时前
基于单片机的智能家居智能雨水自动关窗控制系统设计
单片机·嵌入式硬件·毕业设计·智能家居·课程设计·期末大作业
点灯小铭1 小时前
基于单片机的电加热炉智能温度与液位PID控制系统设计
单片机·嵌入式硬件·毕业设计·课程设计·期末大作业
aHais_5 小时前
REGMAP使用方法杂项
linux·单片机
kanhao1005 小时前
FRAM MCU 市场格局与 MSP430 的统治地位分析
单片机·嵌入式硬件
犽戾武5 小时前
Quest:视频 + 元数据 + 可点击目标(与RK进行UDP通信)
单片机·嵌入式硬件
济6176 小时前
ARM Linux 驱动开发篇--嵌入式 Linux LED 驱动开发实验(2)--Linux 下 LED 灯驱动开发代码编写-- Ubuntu20.04
linux·arm开发·驱动开发
BackCatK Chen14 小时前
第15篇:TMC2240闭环控制软件实现|编码器数据融合+丢步修正(保姆级)
嵌入式硬件·闭环控制·tmc2240·stm32实战·编码器数据融合·丢步修正·定位精度优化
隔壁大炮15 小时前
I2C通信协议
单片机·嵌入式硬件·铁头山羊
凌晨7点16 小时前
DSP学习F28004x数据手册:第13章-ADC
单片机·嵌入式硬件·学习
非鱼䲆鱻䲜18 小时前
淘晶驰串口屏使用波形图控件,接收单片机或者串口助手数据生成图像的区别
单片机·嵌入式·串口屏