讨论一下ARM7单片机上的中断控制器。

[复制链接]
 楼主| andrewpei 发表于 2007-10-17 16:14 | 显示全部楼层 |阅读模式
<br />最近对比研究了三个大厂的ARM7单片机,发现它们在中断控制器的设计上有两种不同的作法:<br /><br />一种是ST半导体和ATMEL的作法,它们没有采用ARM公司的中断控制器IP设计(编号是PL190),好象是都用了另外同一种设计。STR71x系列的EIC与SAM7上的AIC非常相似,都用了所谓的硬件堆栈来实现中断嵌套,以减少单片机在中断嵌套中的软件开销,只是嵌套的次层不同。<br /><br />另一种是NXP的LPC2000系列。它采用了ARM公司的标准IP设计,名为VIC,ARM公司的设计IP文档号为PL190。这种设计没有实现什么硬件栈结构。<br /><br />&nbsp;<br /><br />我对采用硬件栈的这种设计持保留态度,认为它在中断嵌套的实际应用中,没有太多的实用意义,是个“**肋”。原因在于:<br /><br />1、对于中断嵌套,最重要的是保留在前次中断处理程序中,被新中断所打断的原PC值和处理器当时的状态。而EIC的和AIC的这个硬件栈却是在硬件栈中保存无关痛痒的上一个中断优先级值和中断源编号。这种堆栈根本不会减少CPU核在中断嵌套中的用来将LR值和SPSR压栈的软件开销。<br /><br />2、纵观几大厂的ARM7单片机,我发现:作为ARM7核在MCU中的设计使用,ST半导体STR71xF系列的EIC和ATMEL公司SAM7系列实现了硬件栈,但是作为面市时间较晚的LPC2000,NXP并没有再去实现什么硬件堆栈。<br />这是不对我上述判断的一个佐证呢?<br /><br />由于没有用ATMEL或ST半导体的ARM单片机做过实际项目,以上只是个人的一点分析。提请熟悉ATMEL公司或ST半导体公司产品的达人们评论!<br /><br />谢谢<br />
dld2 发表于 2007-10-17 16:26 | 显示全部楼层

深奥

  
pengkewei 发表于 2007-10-17 22:37 | 显示全部楼层

搬个板凳听课

  
平常人 发表于 2007-10-17 22:57 | 显示全部楼层

LZ说的中断控制器还没有看过,有时间研究研究,但是另有个

但是有个问题想请LZ一并考虑,当允许中断嵌套以后,如何解决低优先级的事件不会中断高优先级的事件(中断)处理,同时允许高优先级的事件中断低优先级事件的处理程序。
zusen 发表于 2007-10-18 08:50 | 显示全部楼层

楼上,不知这样行不行

进入低优先级后,置自己为最高优先级,退出前还原,嘿嘿
 楼主| andrewpei 发表于 2007-10-18 09:15 | 显示全部楼层

回:楼上平常人

ARM公司的专家曾经出版过一本经典的ARM编程书,中文的译版叫做《ARM嵌入式系统开发-软件设计与优化》,由北航出版,其中第9章是专门讨论异常与中断编程的专题,可供讨论参考。<br /><br />楼上兄台提到的问题,我想可以简单地回答如下:中断控制器(interrupt&nbsp;controller)的作用,就是分担CPU核对中断管理的软件开销工作:如,确定中断源,对产生的中断源进行分析,按优先级排序,等等。<br /><br /><br />以下我们分三种情况讨论:<br /><br />1、当有多个中断同时产生时,中断控制器会对这多个中断源进行优先级序,并将其中优先级最高的中断ISR的地址提交给CPU核,提交的方式是将该中断ISR地址存储在控制器单元中的Interrupt&nbsp;Vector&nbsp;Address寄存器内,供CPU读取。这样,低优先级的任务决不会在中断源的仲裁中胜出。<br /><br />2、如果CPU正在响应一个高优先级中断,那么在完成中断服务后,它需要以写操作中断控制器中的某一个寄存器的方式来通知中断控制器它已经完成了ISR服务,中断控制器这时才会再次对悬挂在它管理范围内的低优先级中断源重新排序仲裁,提交新的高优先级中断给CPU。假如CPU核没有完成中断服务,中断控制器就得不到CPU的这个ISR完成通知信号,也就不会仲裁未处理的那些低优先级中断源。这样的话,低优先级的中断就不会打断高优先级中断服务了。<br /><br />3、如果CPU正在响应一个优先级别较低的中断时,这时来了一个优先级别较高的中断源信号进入中断控制器,中断控制器这时会将nIRQ信号再次拉低激活,通知CPU需要立即中止当前正在处理的低优先级中断,进行高优先级的中断响应。而未处理完的低优先级中断服务的程序状态和处理器状态都需要保存,以便将来返回时继续完成处理工作,这些都需要CPU来执行并保存到内存中去,这就是所谓中断嵌套的软件开销。<br /><br />这就是中断控制器的作用:<br />1、对CPU核的外部中断源进行排序促裁,决定何时,提交哪一个中断源给CPU;<br />2、提交对应中断源的ISR地址提供给CPU,让CPU进行相应的中断服务。<br /><br />最后我们可以讨论硬件堆栈了:通常意义上来讲,硬件堆栈的作用就是由硬件完成对被打断中断服务的状态保存。由于硬件资源非常有限,所以硬件堆栈的深度一般都是很少的,ATMEL的SAM7是8级深度,ST半导体的STR71xF是16级深度。但是令人奇怪的是:这两种MCU的硬件堆栈并不具备保存程序状态的功能,而是去保存对编程用户没有什么用处的中断源编号和中断优先级数。如果我们对比一下TI的C2000系列DSP控制器,就会发现C2000系列的硬件堆栈确确实实是在保存被中止ISR程序的返回地址,是可以减少DSP内核在中断嵌套中的软件开销的,这就可以看出来这两种硬件堆栈功能上的差别了,就会发现我指的ATMEL和ST半导体的MCU中那种令人无法理解的硬件堆栈设计。<br /><br />谢谢!打字真累!
HWM 发表于 2007-10-18 09:41 | 显示全部楼层

在RISC中好象一般不配备带硬件优先级处理的中断系统,

特殊情况除外。
dld2 发表于 2007-10-18 10:02 | 显示全部楼层

看看,长知识

系统里有嵌套的中断,想想就头大。<br />要求ISR尽可能短,基本就满足应用要求了吧。
平常人 发表于 2007-10-19 18:50 | 显示全部楼层

答案是:因为ARM7的内核中没有中断控制器

先简单地说一下5楼的方法,你的方法适用于没有嵌套,“进入低优先级后,置自己为最高优先级”,那么比它优先级高的中断不就进不来了,还谈什么嵌套?<br /><br />LZ的问题关键是为什么中断控制器不保存中断服务的返回地址和CPU的状态,其实这个问题的答案很简单:LZ有没有注意到ARM公司没有把中断控制器集成在核心中,中断控制器是各个半导体公司自己加上去的,ARM7的核心只提供两条信号线允许核心外部的中断申请,即IRQ和FIQ;中断服务的返回地址和CPU的状态都在核心内部,各家半导体公司谁也不能修改ARM7的核心,自然在中断控制器中不能访问到这些信息了,不能得到这些信息又如何能够在中断控制器中保存它们呢?<br /><br />再多说一句,ARM7核心本身并不支持中断嵌套,因为对于ARM7核心只有两个中断源,自然不用谈嵌套了。
wishcom 发表于 2007-10-19 23:22 | 显示全部楼层

ARM7的中断优先级可以使用软件模拟出来的

参考“ARM体系结构与编程”
avr32 发表于 2007-10-20 00:02 | 显示全部楼层

[ZT] ATMEL精妙的IRQ中断处理过程——牛X

ATMEL精妙的IRQ中断处理过程——牛X&nbsp;<br /><br />从栈地址开始,栈顶为AT91SAM7S64的16K片内RAM尽头0x00204000<br />IRQ_STACK_SIZE&nbsp;=&nbsp;3*8*4<br />FIQ_STACK_SIZE&nbsp;=&nbsp;0x004<br />ABT_STACK_SIZE&nbsp;=&nbsp;0x004<br />UND_STACK_SIZE&nbsp;=&nbsp;0x004<br />SVC_STACK_SIZE&nbsp;=&nbsp;0x800<br />SYS_STACK_SIZE&nbsp;=&nbsp;0x400<br /><br />irq栈为什么用3*8*4=96B呢?因为irq最多8级嵌套,ARM字长4B,而3,是由于每次进栈均破坏了3个寄存器r0、spsr、lr,所以需要压栈保存的也就是3。计算十分精准,没有一个字浪费,这是AT第一牛X的地方。<br /><br />当irq发生时,下列操作处理器自动完成:<br />1。r14(irq)=返回地址<br />2。spsr(irq)=cpsr(中断发生前的模式)<br />3。改cpsr,成模式为irq,禁止irq中断。<br />4。设pc,跳转到0x00000018去<br /><br />下面看中断0x00000018指向的irq_handle代码:<br /><br />;因为要继续调用函数,lr会被冲掉,所以压irq栈<br />sub&nbsp;lr,lr,#4<br />stmfd&nbsp;sp!,{lr}<br /><br />;将r0和spsr压irq栈,因为下面用到r0,spsr<br />mrs&nbsp;r14,spsr<br />stmfd&nbsp;sp!,{r0,r14}<br /><br />;写IVR,支持保护模式,普通模式无效<br />;释放NIRQ,清除保护模式下中断源<br />ldr&nbsp;r14,=AT91C_BASE_AIC<br />ldr&nbsp;r0,[r14,#AIC_IVR]<br />str&nbsp;r14,[r14,&nbsp;#AIC_IVR]<br /><br />;允许中断嵌套,由irq模式切换入svc模式<br />msr&nbsp;cpsr_c,&nbsp;#ARM_MODE_SVC<br /><br />;保存scratch和被使用到的寄存器、lr入svc堆栈<br />stmfd&nbsp;sp!,&nbsp;{r1-r3,&nbsp;r12,&nbsp;r14}<br /><br />;跳转到AIC_IVR指向的中断服务程序地址<br />mov&nbsp;r14,pc<br />bx&nbsp;r0<br /><br />;恢复scratch、被用到的寄存器、lr<br />ldmia&nbsp;sp!,{r1-r3,&nbsp;r12,&nbsp;r14}<br /><br />;禁止irq中断嵌套,由svc切换到irq模式。<br />msr&nbsp;cpsr_c,#I_BIT&nbsp;|&nbsp;ARM_MODE_IRQ<br /><br />;写AIC_EOICR<br />ldr&nbsp;r14,=AT91C_BASE_AIC<br />str&nbsp;r14,[r14,&nbsp;#AIC_EOICR]<br /><br />;恢复spsr、r0<br />ldmia&nbsp;sp!,{r0,&nbsp;r14}<br />msr&nbsp;spsr_cxsf,&nbsp;r14<br /><br />;中断返回<br />ldmia&nbsp;sp!,&nbsp;{pc}^<br /><br />以上就是全部,让我惊叹的是如上做法支持了中断嵌套,想了想,自己以前搞的东西还真是全部回避回去了,也就是说,以前各个中断并没有优先级区分,进了中断就关门i-&gtI。中断服务程序执行完了再打开,优点是简单明了,缺点是中断服务程序必须迅速处理完.<br /><br />&nbsp;<br />&nbsp;<br /> <br /> 相关链接:<a href='http://bbs.21ic.com/club/bbs/list.asp?boardid=48&t=2581607&tp=ATMEL%u7CBE%u5999%u7684IRQ%u4E2D%u65AD%u5904%u7406%u8FC7%u7A0B%u2014%u2014%u725BX'>http://bbs.21ic.com/club/bbs/list.asp?boardid=48&t=2581607&tp=ATMEL%u7CBE%u5999%u7684IRQ%u4E2D%u65AD%u5904%u7406%u8FC7%u7A0B%u2014%u2014%u725BX</a>
hq_y 发表于 2007-10-20 09:03 | 显示全部楼层

强贴留名,做个记号

  
lpf336 发表于 2007-10-20 17:57 | 显示全部楼层

学习

  
huangqi412 发表于 2007-10-21 18:02 | 显示全部楼层

板凳听课

  
linminjun 发表于 2007-10-22 19:11 | 显示全部楼层

九楼的高见

九楼的高见,学习了
hpy013 发表于 2007-10-23 12:59 | 显示全部楼层

讨论得有深度。

不错,学习了。
ayb_ice 发表于 2007-10-24 16:49 | 显示全部楼层

《ARM嵌入式系统开发-软件设计与优化》不错

我也买了一本。。。<br />ARM要是能象51那样直接中断嵌套就好了。。。
caiwenbin 发表于 2007-10-25 20:16 | 显示全部楼层

板凳听课

  
gumanzhou 发表于 2007-10-28 22:23 | 显示全部楼层

18楼的兄弟~~

建议你看一下<br />easy2131&nbsp;开发板的中断嵌套,再看这个就简单多了……<br />那里有实验,应该有相关的文档<br /><br />或者2200也有好像<br />
zhoushihua 发表于 2007-10-29 19:41 | 显示全部楼层

新手

来看看
您需要登录后才可以回帖 登录 | 注册

本版积分规则

9

主题

51

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部