ARM中断处理的研究

ARM中断处理的研究,第1张

 

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

  1 系统中断处理简介

  ARM处理器的中断主要有两种:IRQ普通中断和FIQ快速中断。快速中断本质上与普通中断没有太大的差别,它们在处理机制上有许多相同的地方。IRQ中断是最频繁的也是最为影响系统性能的,所以对它的研究与处理也就最有价值。

  下面简要地介绍一下IRQ异常发生时ARM处理器的工作过程。在IRQ中断发生时,ARM处理器的硬件会自动执行以下工作:

  ①将被中断任务模式的CPSR值保存到IRQ模式中的SPSR寄存器中;

  ②将被中断任务模式的PC值保存到IRQ模式中的LR寄存器中;

  ③将模式自动切换到IRQ模式,并将CPSR中的bit7位置1禁止后继IRQ中断的发生;

  ④PC被赋予0xl8的地址值,程序将从0xl8片开始执行。结合图1,可以更好地理解ARM中断处理机制的工作过程。

  

ARM中断处理的研究,IRQ中断处理寄存器保存示意图,第2张

 

  2 普通中断处理

  有些ARM嵌入式系统可能对中断的要求比较低,即发生中断后首先查询相应的中断源,然后进行中断服务,最后从中断服务程序中返回到被中断处继续运行程序。如何在这种简单应用中保证安全又高效地处理中断呢?“安全”就意味着中断发生时上下文被完好保存不被破坏,“高效”就是说保存尽可能少的寄存器(当然是建立在安全的基础上的)。由图1可知,在普通中断处理中,中断服务就可以在IRQ模式中运行。根据ATPCS的调用规则,在子程序调用中ARM编译器保存了R4~R11寄存器,因此就没有必要再次保存。那么剩下的寄存器就必须予以保存,防止从中断服务程序返回后被破坏。可以用汇编语言和C语言书写处理代码。

  首先假设初始化代码中已正确建立了IRQ堆栈。

  

ARM中断处理的研究,程序,第3张

 

  <所有已使能中断的查询与服务>

  ;将同时发生的中断全部服务,以提高效率

  LDMFD SP!,{R0-R3,R12,R14} ;恢复上下文

  在上述保存上下文中没有必要保存SPSR。因在非嵌套的中断处理程序中,它不会被任何顺序的中断所破坏。

  如果用C语言来书写该处理程序,可以使用关键字一IRQ来说明,以告诉编译器实现如下的 *** 作:

  ①保存.ATPCS规定的被破坏的寄存器;

  ②保存其他中断处理程序中用到的寄存器;

  ③同时将(LR-4)赋予程序计数器PC,实现中断程序的返回并且恢复CPSR寄存器的内容。

  普通中断处理的C语言程序可以按如下格式编写:

  

ARM中断处理的研究,程序,第4张

 

  可见,无论是用C语言还是汇编语言来编写,它们的工作原理都是一样的。图2给出了普通中断处理过程中,ARM寄存器的保存示意图(虚线是压栈保存,实线是d栈恢复)。图中与程序处理的步骤相对应,可以帮助理解处理器上下文的保存过程。

  

ARM中断处理的研究,普通中断处理过程,第5张

 

  

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/dianzi/2713400.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-08-17
下一篇 2022-08-17

发表评论

登录后才能评论

评论列表(0条)

保存