嵌入式ARM中断处理的安全性与高效性研究

上传人:xins****2008 文档编号:231371476 上传时间:2023-09-02 格式:PPTX 页数:24 大小:685.75KB
收藏 版权申诉 举报 下载
嵌入式ARM中断处理的安全性与高效性研究_第1页
第1页 / 共24页
嵌入式ARM中断处理的安全性与高效性研究_第2页
第2页 / 共24页
嵌入式ARM中断处理的安全性与高效性研究_第3页
第3页 / 共24页
资源描述:

《嵌入式ARM中断处理的安全性与高效性研究》由会员分享,可在线阅读,更多相关《嵌入式ARM中断处理的安全性与高效性研究(24页珍藏版)》请在装配图网上搜索。

1、千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org嵌入式嵌入式ARMARM中断处理的安全性中断处理的安全性与高效性研究与高效性研究引引 言言 1 1 系统中断处理简介系统中断处理简介2 2 普通中断处理普通中断处理3 3 任务切换任务切换4 4 可重入性中断可重入性中断5 5 基于优先级的可重入中断基于优先级的可重入中断结结束束语语千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org在嵌

2、入式系统中常用的RISC处理器是ARM核,它具有体积小、功耗低、成本低、性价比高的特点。然而,不管是哪种型号的arm处理器,也无论该嵌入式系统中是否有操作系统,中断处理,特别是IRQ中断,始终是必须的,而中断处理的核心问题是上下文的保存。能否安全而又高效地保存上下文,将影响一个嵌入式系统的性能与稳定。笔者对arm处理器的普通中断处理、任务切换中断处理、可重人中断处理和基于优先级的可重人性中断处理的上下文保存技术进行分析与总结。为保证理论的正确性,核心的程序代码都经过了实验的检测。引言引言千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain

3、.org www.mobiletrain.orgarm处理器的中断主要有两种:IRQ普通中断和FIQ快速中断。快速中断本质上与普通中断没有太大的差别,它们在处理机制上有许多相同的地方。IRQ中断是最频繁的也是最为影响系统性能的,所以对它的研究与处理也就最有价值。下面简要地介绍一下IRQ异常发生时ARM处理器的工作过程。在IRQ中断发生时,arm处理器的硬件会自动执行以下工作:将被中断任务模式的CPSR值保存到IRQ模式中的SPSR寄存器中;将被中断任务模式的PC值保存到IRQ模式中的LR寄存器中;将模式自动切换到IRQ模式,并将CPSR中的bit7位置1禁止后继IRQ中断的发生;PC被赋予0

4、xl8的地址值,程序将从0 xl8片开始执行。结合图1,可以更好地理解arm中断处理机制的工作过程。1 1嵌入式嵌入式ARMARM开发教程之开发教程之系统中断处理简介系统中断处理简介千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org有些arm嵌入式系统可能对中断的要求比较低,即发生中断后首先查询相

5、应的中断源,然后进行中断服务,最后从中断服务程序中返回到被中断处继续运行程序。如何在这种简单应用中保证安全又高效地处理中断呢?“安全”就意味着中断发生时上下文被完好保存不被破坏,“高效”就是说保存尽可能少的寄存器(当然是建立在安全的基础上的)。由图1可知,在普通中断处理中,中断服务就可以在IRQ模式中运行。根据ATPCS的调用规则,在子程序调用中arm编译器保存了R4R11寄存器,因此就没有必要再次保存。那么剩下的寄存器就必须予以保存,防止从中断服务程序返回后被破坏。可以用汇编语言和C语言书写处理代码。首先假设初始化代码中已正确建立了IRQ堆栈。2 2嵌入式嵌入式ARMARM开发教程之开发教程

6、之普通中断处理普通中断处理千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org;将同时发生的中断全部服务,以提高效率LDMFD SP!,R0-R3,R12,R14;恢复上下文在上述保存上下文中没有必要保存SPSR。因在非嵌套的中断处理程序中,它不会被任何顺序的中断所破坏。嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org如果用C语言来书写该处理程序

7、,可以使用关键字一IRQ来说明,以告诉编译器实现如下的操作:保存ATPCS规定的被破坏的寄存器;保存其他中断处理程序中用到的寄存器;同时将(LR-4)赋予程序计数器PC,实现中断程序的返回并且恢复CPSR寄存器的内容。嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org普通中断处理的C语言程序可以按如下格式编写:嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtr

8、ain.org www.mobiletrain.org可见,无论是用C语言还是汇编语言来编写,它们的工作原理都是一样的。图2给出了普通中断处理过程中,arm寄存器的保存示意图(虚线是压栈保存,实线是弹栈恢复)。图中与程序处理的步骤相对应,可以帮助理解处理器上下文的保存过程。嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org有操作系统的嵌入式系统中,中断的发生要求保存全部寄存器的内容到任务的栈中,它不是基于安全的考虑是因为可能中断会导致任务的切换。任务

9、切换发生时所有任务的寄存器的值都要保存到该任务的栈中。下个任务的上下文将从该任务栈中得以恢复到处理器的寄存器中。下面就本问题作出分析并给出实现的程序代码。从图1中断处理寄存器的保存可知,中断发生后任务的CPSR和PC两寄存器的值在IRQ模式的SPSR和LR中,所以不能简单地切换到任务运行的模式中,否则被中断任务返回时的CPSR和PC将不可见(因为它们保存在IRQ模式的专用寄存器中,在其他模式中无法操作)。此时,可以考虑设置一些变量区作为媒介,将其予以转存到任务运行模式的栈中去。下面假设任务切换是在SVC模式中运行的。结合上面的分析,可以有图3所示的保存任务切换的示意图(虚线是压栈保存,实线是弹

10、栈恢复;LR_Frame和SPSR_Frame是变量区)。3 3嵌入式嵌入式ARMARM开发教程开发教程任务切换任务切换千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org结合图3任务切换中断处理中的步骤,可以用汇编语言写出相对应的中断处理程序:嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3

11、G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org如果希望在处理中断时仍能响应其他中断请求以此来缩短中断延时,就必须设计可重人性中断。可重入性中断是处理多个中断的一种方法,但它也同时带来新的问题。在IRQ中断模式中,如果直接重新允许了IRQ中断,此时因为执行一条BL指令而将子程序返回的地址保存在LR_irq中,

12、而在此间中断发生了。新来的中断会将其返回地址装入LR_irq中,此时旧中断子程序的返回地址必将被覆盖从而导致系统紊乱。此种情形是无法通过将LR_irq压栈来解决的,如程序语句:4 4嵌入式嵌入式ARMARM开发教程开发教程可重入性中断可重入性中断千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org但

13、是仍不能排除在保存LR之前中断发生的可能性。要解决上述LR_irq被破坏的问题,就必须切换处理器的模式,常见的是切换到SVC处理模式。在SVC模式中,通过BL调用子程序时会将返回地址保存在LR_SVC之中。此时新中断发生(因为它会将返回地址保存到LR_irq而不是LR_SVC),不会破坏旧中断中子程序返回地址了。有了基于上述的原理分析再来编写可重入性中断的代码就思路清晰了。但是为了保证处理的高效性,尽可能地及早允许中断以缩短延时,在保存完LR_irq和SPSR_irq后,就马上切换到SVC模式中并重新允许中断,如图4所示(虚线是压栈保存,实线是弹栈恢复)。嵌入式嵌入式ARMARM开发教程开发教

14、程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org结合图4中的处理步骤,可以比较清晰地写出可重入中断处理的汇编语言程序:嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobil

15、etrain.org在上面的可重人中断中可能发生这种情形,某高优先级中断在中断服务程序中因为重新允许了中断请求而被另一低优先级中断所打断,于是高优先级中断不得不等到低优先级中断完毕后方可继续运行。这样一来,高优先级中断服务的延迟将更加增大。为了减少上述高优先级中断的延迟,特别引入了基于优先级的可重人性中断。它的原则是:在中断服务程序中只允许高于本中断的其他中断源予以请求中断,因此一个高优先级的中断将比一个低优先级的中断优先得到服务,这是大多数嵌入式系统中所必需的。采取的方法是,当某优先级中断发生时,在其中断处理程序中可以使用屏蔽位将低于或等于该优先级的中断予以屏蔽。特别需要注意的是,在退出本中

16、断时要恢复原中断寄存器的值。在此假设有这样几个中断寄存器(其实arm的很多处理器都有此类的中断控制寄存器):IRQMask,中断源屏蔽寄存器;IRQStatus,中断标志寄存器;IRQClear,清除中断标志寄存器。同时假设中断的优先级是从高位(bit31)到低位(bitO)递减的,那么首先可以预定义如下的屏蔽变量值:5 5嵌入式嵌入式ARMARM开发教程开发教程基于优先级的可重入中断基于优先级的可重入中断千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org嵌入式嵌入式ARMARM开发教程开

17、发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org本程序的上下文保存与可重人中断处理基本相同。增加的部分在于中断屏蔽码的查询与设置,相应的处理步骤可以参考图4。嵌入式嵌入式ARMARM开发教程开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org本文重点研究了ARM处理器在多种中断处理中上下文保存的安全与高效性,结合处理器结构图和程序代码分析了各种中断的处理方案。对arm处理器具有通用价值而不受不同厂商硬件的局限。文中涉及的程序源代码都在ADSl2开发环境和SEP4020开发评估板上测试过。实验证明此中断处理技术是安全高效的。结束语结束语

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!