基于ARM异常中断处理的方法解析

发布者:脑力舞者最新更新时间:2020-08-08 来源: elecfans关键字:ARM  异常中断  处理方法 手机看文章 扫描二维码
随时随地手机看文章

介绍一种简洁、高效、灵活的ARM异常中断处理方法。

在ARM中,由于所有的中断都使用同一个异常中断入口地址,即0x00000018。因此需要在异常中断处理程序中根据相应的中断号调用对应的中断服务函数。


一般有两种处理方式:

1. 在汇编中保存现场,然后调用C语言编写的中断处理程序,任务处理完成之后,再返回到汇编中恢复现场,并返回到断点。其中C语言编写的中断处理程序,通过switch语句对INTOFFSET进行判断,然后散转执行对应的服务函数。

基于ARM异常中断处理的方法解析

IMPORT IRQ_EXCEPTION

0x00000018 LDR PC,=IRQ_ENTRY

IRQ_ENTRY

STMFD SP!,{R0-R8,LR}

BL IRQ_EXCEPTION

LDMFD SP!,{R0-R8,LR}

SUBS PC,LR,#4

void IRQ_EXCEPTION()

{

switch(INTOFFSET)

{

case 0:

break;

case 1:

break;

}

}

缺点:1)所有的中断处理函数都必须在这个C文件中定义。

2)中断处理函数不能再程序执行过程中被更换。

3)由于不知道中断处理函数用到了哪些寄存器,因此保护现场时,需要把可能用到的所有工作寄存器

都保护起来。再加上C语言中的判断,这些步骤都会增加中断响应时间。

2. 使用关键字__irq来定义每个中断处理函数,由编译器来插入保护现场及中断返回的代码,由于编译器知道此函数用到了哪些寄存器,因此它只保护被用到的寄存器。接下来的问题是,当产生中断时,如何直接调用对应的中断处理函数?


一般会在内存中分配32*4个存储单元,存放每个中断处理函数的首地址,在汇编中,直接根据INTOFFSET从中断处理函数向量表中取出对应的函数首地址送给PC,直接调用对应的中断处理函数。C语言中需要借用函数指针将中断处理函数首地址写入到中断处理函数向量表里的对应位置上。


IRQ_HandlerStart EQU 0x33FFFF00

0x00000018 LDR PC,=IRQ_ENTRY

………… ………………………………

IRQ_ENTRY

SUB SP,SP,#4 ;为存放中断处理函数首地址留出空间

STMFD SP!,{R0,R1,R2} ;保护下面的算法用到的工作寄存器

LDR R0,=INTOFFSET

LDR R1,[R0] ;取出中断号

LDR R2,=IRQ_HandlerStart

ADD R0,R2,R1,LSL #2 ;计算中断号对应的中断处理函数在向量表中的位置

LDR R1,[R0] ;取出对应的中断处理函数首地址

STR R1,[SP,#12] ;存储到刚才预留的空间里

LDMFD SP!,{R0,R1,R2,PC} ;出栈,数据从左向右恢复,最后将中断处理函数首地址给PC

#define ISR_StartAddr 0x33FFFF00

#define pISR_EINT0 (*(unsigned *)(ISR_StartAddr+0*4))

#define pISR_UART0 (*(unsigned *)(ISR_StartAddr+28*4))

void IniTISR()

{

pISR_EINT0 = EINT0_Handler;

pISR_TIMER0 = UART0_Handler;

}

void __irq EINT0_Handler()

{

………………

}

void __irq UART0_Handler()

{

………………

}

缺点:1)要保证汇编与C中定义的中断处理函数向量表的首地址相同

2)要定义很多个函数指针,编写起来比较麻烦

我们可以将中断处理函数向量表看成一个具有32个成员的数组,每个成员都是函数指针,指向的是无形参、无返回值的中断处理函数。我们可以在汇编中用SPACE关键字来定义这个函数指针数组变量,并为其分配空间。 在C语言中只需要用extern申明下它是外部定义的即可。

0x00000018 LDR PC,=IRQ_ENTRY

………… ………………………………

IRQ_ENTRY

SUB SP,SP,#4 ;为存放中断处理函数首地址留出空间

STMFD SP!,{R0,R1,R2} ;保护下面的算法用到的工作寄存器

LDR R0,=INTOFFSET

LDR R1,[R0] ;取出中断号

LDR R2,=INTVECTOR ;获取函数指针数组首地址

ADD R0,R2,R1,LSL #2 ;计算中断号对应的中断处理函数在向量表中的位置

LDR R1,[R0] ;取出对应的中断处理函数首地址

STR R1,[SP,#12] ;存储到刚才预留的空间里

LDMFD SP!,{R0,R1,R2,PC} ;出栈,数据从左向右恢复,最后将中断处理函数首地址给PC

AREA INTVECT,DATA

INTVECTOR SPACE 32*4

为了将此函数指针数组变量分配到内存中,需要在分散加载文件中指定这个段的执行域在内存空间

VECT_REGION 0x33FFFF00

{

StartUp.o(INTVECT)

}

typedef void __irq (*INTFUNC)(void); //函数指针类型重定义,

extern INTFUNC INTVECTOR[32];

void InitiISR()

{

INTVECTOR[0] = EINT0_Handler;

INTVECTOR[28] = UART0_Handler;

}

void __irq EINT0_Handler()

{

………………

}

void __irq UART0_Handler()

{

………………

}

特点:1)只需要在分散加载文件中对这个中断处理函数向量表的首地址指定一次,避免出错。

2)使用函数指针数组,省略多个函数指针的定义。

3)在程序执行过程中,可以通过修改函数指针数组里的内容更换中断处理函数。

4)可以再定义一个中断注册函数,提高程序的灵活性。

void ISR_Register(INT8U num,INT32U addr)

{

INTVECTOR[num] = addr;

}

以上提到的变量都可以只放在interrupt.c中,不同的中断处理函数可以在不同的文件中编写,它们只需要调用ISR_Register即可。这样可以提高程序的结构化。

另外,还可以将中断号用#define定义一下,以提高程序的可读性,如下:

#define INT_TIMER0 10

#define INT_UART0 28

#define INT_RTC 30

INTVECTOR[INT_UART0] = UART0_Handler;

INTVECTOR[INT_RTC] = RTC_Handler;

关键字:ARM  异常中断  处理方法 引用地址:基于ARM异常中断处理的方法解析

上一篇:单片机与ARM谁更实用
下一篇:导弹电液伺服机构原理仿真装置的软硬件设计与实现

推荐阅读最新更新时间:2024-11-05 20:14

痞子衡嵌入式:ARM Cortex-M文件那些事(0)- 文件关联
本篇是文件系列第一篇,本系列文章会逐一介绍ARM Cortex-M开发过程中(以IAR集成开发环境为例,其他开发环境可触类旁通)所要接触的8种主要文件类型:源文件、链接文件、工程文件、可重定向文件、映射文件、可执行文件、反汇编文件、镜像文件。 在介绍具体各文件之前有必要先让大家对各文件之间的关联有一个初步了解,下面三张图很好的诠释了8种文件之间的关联: 编译阶段: 链接阶段: 下载阶段:
[单片机]
痞子衡嵌入式:<font color='red'>ARM</font> Cortex-M文件那些事(0)- 文件关联
ARM推Android开发工具,旨在降低电池能耗
据Engadget报道,因Android设备多半采用ARM芯片,为解决电池耗电问题,ARM亲历亲为,推出Android开发工具包。 随着Development Studio 5 Community Edition的发布,该公司已扩大其开发套件的范围,不只针对Linux,也针对谷歌基于Linux的移动操作系统Android。DS - 5不仅优化应用程序的性能,也对电池效率做了很大改进;使用ARM芯片运行Android,尽量提升电池使用时间。 ARM声称DS-5生成的代码比Java快四倍,且集成了标准的Android SDK以及Eclipse IDE。
[单片机]
<font color='red'>ARM</font>推Android开发工具,旨在降低电池能耗
基于ARM的微伏信号在线监测系统设计
1 引言 在线监测系统中,待测信号幅值在50μV左右,而背景噪声幅值在50mV以上,用一般的采集和测量系统无法准确检测该信号。针对被背景噪声覆盖的微小信号,采用滤波降噪和差分放大手段,提高信噪比,保证待测信号能被准确采集;采用基于ARM核的32位微处理芯片S3C44B0X和基于μClinux操作系统的嵌入式图形用户界面MicroWindows,完成实时显示测量结果和实现故障自动报警,同时具有体积小、功耗低、操作灵活的特点,为实现微伏信号在线监测功能提供了一种良好的解决方案。 2 系统硬件设计 整个微伏信号在线监测系统硬件主要分为两个部分,即前置放大电路和基于ARM的数据采集与显示电路。 2.1 前置放大电路 待测信
[单片机]
基于<font color='red'>ARM</font>的微伏信号在线监测系统设计
ARM7与FPGA相结合的应用
  ARM7与FPGA相结合在工业控制和故障检测中的应用   工业控制中往往需要完成多通道故障检测及多通道命令控制(这种多任务设置非常普遍),单独的CPU芯片由于其外部控制接口数量有限而难以直接完成多路检控任务,故利用ARM芯片与FPGA相结合来扩展检控通道是一个非常好的选择。这里介绍用Atmel公司ARM7处理器(AT91FR40162)和ALTERA公司的低成本FPGA芯片(cyclone2)结合使用完成多通道检控任务的一种实现方法。    各部分功能简介   图1为此系统的结构连接框图。如图所示,ARM芯片与FPGA芯片之间通过数据总线、地址总线及读写控制线相连,而与终端PC则通过串口通信;FPGA与目标设备通过命令控
[嵌入式]
ARM】微处理器工作模式
收获 SPACE 和 DCD 的区别在于: SPACE 申请一片内存空间(以字节为单位申请),但不赋初值 DCD 申请一个字(32bit)的内存空间,并赋初值 对于 32 位的 ARM,一个字为 32 bit = 4 Byte 代码中的 UsrStackSpace SPACE USR_STACK_LEGTH*4 这里的 ∗4*4∗4 就是由于 SPACE 是以字节为单位分配空间,而我们需要的是以字为单位的堆栈空间 对于代码中的 StackUsr DCD UsrStackSpace+(USR_STACK_LEGTH-1)*4 可以这样理解: UsrStackSpace 是标号,相当于地址,
[单片机]
【<font color='red'>ARM</font>】微<font color='red'>处理</font>器工作模式
基于ARM7TDMI的SoC语音处理系统的设计
摘要:基于ARM7TDMI的SoC片内AC97模块和片外CODEC-UCB1400,采用ITU-T的G.721算法设计语音处理系统;提出一种基于低端RISC核的语音系统设计方案。该方案结合SoC的片内eSRAM模块进行性能优化;通过在流片后的实际样机上验证,编码速率为19.88 KB/s,解码速率为22.68 KB/s,达到了语音实时性要求。 关键词:ARM7TDMI G.721 双Buffer机制 eSRAM优化 引 言   随着微电子和计算机技术的高速发展,许多嵌入式应用系统应运而生。其中,各种语音处理系统不断被开发出来,在各行业得到广泛应用,如语音报站器、自动解说装置、采访录音笔等,为人类的生产、生活提供了极大的便利。
[应用]
ARM收购Allinea解决服务器兼容问题
ARM一直都存在一个难题——它纵横智能机和平板市场却始终无法攻克服务器和超级计算机市场。当然ARM服务器贬值部分原因是很多应用无法与芯片协同作用。 但ARM已经收购了Allinea软件,希望解决部分软件兼容的问题。Allinea提供软件开发,调试和移植工具,让人们针对基于ARM的服务器和超级计算机更轻松地写入应用。 ARM开发解决方案小组总经理,Javier Orensanz称该次收购将“为数以千计的开发人员提供使用超级计算机的渠道,并且随着软件移植到新的基于ARM的系统上,使我们更好地了解正在解决的问题。” 这些开发工具在深度学习系统中还将用于ARM芯片,因为这些系统都需要大规模服务器部署用于分析。ARM的竞争压力将
[单片机]
ch32和gd32哪个好用?
Ch32和Gd32是两个比较常见的芯片系列,都是基于ARM Cortex-M3内核设计的,因此具有类似的特点和性能。在选择使用哪个芯片时,需要根据具体的项目需求和开发难度加以考虑。 首先,我们来简单介绍一下这两个芯片系列的特点。Ch32是中国厂商江苏长鹰半导体公司生产的一款芯片,可以实现信号的高速处理和计算机视觉应用,广泛应用于机器人、智能家居、智能驾驶等领域。Gd32则是由中国厂商北京兆易创新科技有限公司生产的芯片,主要应用于工控、嵌入式、智能家居、智能穿戴等领域。 在开发难度方面,刚开始学习嵌入式开发的初学者可能会觉得Gd32更加好用,因为它有完善的开发工具链和丰富的文档资料,对于初学者来说更加友好。Ch32的开发工具链和文档
[单片机]
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
随便看看

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved