ARM中断控制专用寄存器及部分解答_第1页
ARM中断控制专用寄存器及部分解答_第2页
ARM中断控制专用寄存器及部分解答_第3页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、ARMfr断控制专用寄存器及部分解答2007-12-1922:05寄存器地址读/写描述复位值SRCPND源挂起寄存器4A000000R/W0=中断没有发出请求;1=中断源发出中断请求00000000INTMOD中断模式寄存器4A000004R/W0=IRQ模式1=FIQ模式00000000INTMSK中断屏蔽寄行器4A000008R/W0=允许响应中断;1=中断请求被屏敝FFFFFFFFINTPND中断挂起寄存器4A000010R/W0=未发生中断请求1=中断源发出中断请求00000000PRIORITY中断优先权寄存器4A00000CR/WIRG优先级控制寄存器7F、中断控制寄存器位SRCP

2、NDBit描述复位值INT_ADC31模数转换中断位0INT_RTC30实时时钟中断位0INT_SPI129SPI1中断位0INT_UART028申口0中断0INT_IIC27IIC0INT_USBH26USEOL0INT_USBD25USBS备0保留24保留0INT_UART123申口1中断0INT_SPI022SPI0中断INT_SDI21INT_DMA320INT_DMA219INT_DMA118INT_DMA017INT_LCD16INT_UART21511INT_TIMER414INT_TIMER313INT_TIMER212INT_TIMER111INT_TIMER010INT_W

3、DT9INT_TICK8nBATT_FLT7保留6EINT8_235EINT4_74EINT33EINT22EINT11EINT00s2440IOP->rEINTPEND=0x200;/EINT9(0b001000000000)s2440IOP->rEINTMASK&=0x200;s2440IOP->rEINTPEND=0x100;/EINT9s2440IOP->rEINTMASK&=0x100;所以EINT11=0X800即0b100000000000估计,呵呵下面我将讲解每个寄存器在一个中断处理流程中所扮演的角色SRCPNDSUBSRCPND两个寄存

4、器在功能上是相同的,它们是中断源引脚寄存器,在一个中断异常处理流程中,中断信号传进中断异常处理模块后首先遇到的就是SRCPND/SUBSRCPNW个寄存器的作用是用丁标示出哪个中断请求被触发。SRCPN曲有效位为32,SUBSRCPND有效位为11,它们中的每一位分别代表一个中断源。SRCPND主中断源引脚寄存器,SUBSRCPNDgU中断源引脚寄存器。这里列举出SRCPND各个位信息:每个位的初始值皆为0。假设现在系统触发了TIMER叫断,则第10bit将被置1,代表TIMER0中断被触发,该中断请求即将被处理(若该中断没有被屏蔽的话)。SUBSRCPNW与SRCPNDR,这里就不多讲了。I

5、NTMOtW存器有效位为32位,每一位与SRCPND各位相对应,它的作用是指定该位相应的中断源处理模式(IRQ还是FIQ)。若某位为0,则该位相对应的中断按IRQ模式处理,为1则以FIQ模式进行处理,该寄存器初始化值为0x00000000,即所有中断皆以IRQ模式进行处理。(详细请参考s3c2410操作手册)。INTMSK/INTSUBMS惭存器为中断屏蔽寄存器,INTMSkttJ主中断屏蔽寄存器,INTSUBMSK副中断屏蔽寄存器。INTMS&效位为32,INTSUBMSK效位为11,这两个寄存器各个位与SRCPN®SUBSRCPND别对应。它们的作用是决定该位相应的中断请

6、求是否被处理。若某位被设置为1,则该位相对应的中断产生后将被忽略(CPM处理该中断请求),设置为0则对其进行处理。这两个寄存器初始化后的值是OxFFFFFFF侪日0x7FF,既默认情况下所有的中断都是被屏蔽的。至知前为止我们总共讲解了SRCPNDINTMODINTMSKSUBSRCPNDNTSUBMSK五个寄存器,在继续讲解PRIORITY寄存器之前我们先来看一张图。先弄活楚一点,现在要讨论的是一个中断优先级的判断问题。为什么会有中断有先级的问题呢?我们知道CPUK个时刻只能对一个中断源进行中断处理,如果现在有3个中断同时发生了,那CPL®按什么顺序处理这个3个中断呢?这正是引入优先

7、级判断的原因所在,通过优先级判断,CPU以按某种顺序逐个处理中断请求。3sc2410的优先级判断分为两级。如上图所示,SRCPN有存器对应的32个中断源总共被分为6个组,每个组由一个ARBITER05)寄存器对其进行管理。中断必须先由所届组的ARBITER(05)进行第一次优先级判断(第一级判断)后再发往ARBITER6S行最终的判断(第二级判断)。ARBITER(05)这六个组的优先级已经固定,我们无法改变,也就是说由ARBITERS制的该组中断优先级最高(该组产生的中断进行第一级判断后永远会以REQ啊ARBITER敛递过去)其次是ARBITER1,ARBITER2,ARBITER4,ARB

8、ITER4,ARBITER5我们能够控制的是某个组里面各个中断的优先级顺序。怎么控制?通过PRIORITY寄存器进行控制:以下是PRIORITY存器各个位的参数表从表上我们可以知道PRIORITY寄存器内部各个位被分为两种类型,一种是ARB_MODE一种为ARB_SELARB_MODE型有5组对应ARBITER26),ARB_SEL类型刁7组对应ARBITER(06)。现在我将以ARBITER小例,讲解中断组与PRIORITY寄存器中ARB_SEL,ARB_MODB、h的相互关系。首先我们看到ARBITER临存器管理的该组中断里包括了6个中断,分别是INT_TIMER0INT_TIMER1IN

9、T_TIMER2INT_TIMER3INT_TIMER4INT_UART2她们的默认中断扁号分别为REQ0REQ1REQ2REQ3REQ4REQ5灸们先看PRIORITY寄存器中的ARB_SEL2该参数由两个位组成,初始值为00。从该表可以看出00定义了一个顺序0-1-2-3-4-5,这个顺序就是这组中断组的优先级排列,这个顺序指明了以中断请求号为0(REQ0的INT_TIMER0M有最高的中断优先级,其次是INT_TIMER1INT_TIMER2。假设现在ARB_SEL2勺值被我们设置为01。则一个新应先级次序将沈使用,01对应的优先级次序为0-2-3-4-1-5,从中可以看出优先级最高和最

10、低的中断请求和之前没有变化,但本来处于第2优先级的INT_TIMER1中断现在变成了第5优先级。从ARB_SEL2被设置为00,01,10,11各个祐所出现的情况我们可以看出,除最高和最低布优先级不变以外,其他各个中断的优先级其实是在做一个旋转排列(rotate)。为了达到对各个中断平等对待这一目标,我们可以让优先级次序在每个中断请求被处理完之后自动进行一次旋转,如何自动让它旋转呢?我们可以通过ARB_MODE2达到这个目的,该参数只有1个bit,置1代表开启对应中断组的优先级次序旋转,0则为关闭。事实上当该位置为1之后,每处里完某个组的一个中断后,该组的ARB_SE便递增在1(达到11后恢复

11、为00)。现在我们另ARB_MODE2=1ARB_SEL2=00则当前ARBITER优先级顺序万0-1-2-3-4-5,假设现在该组的1号中断请求INT_TIMER1ffi2号中断请求INT_TIMER欲同时触发,CPU艮据优先级判断后决定面巴INT_TIMER1中断向ARBITER超行发送(在ARBITER敝第最终优先级判断),接着亓向ARBITER皎送INT_TIMER源断。请注意,在INT_TIMER做处理完毕后,该组中段的优先级次序被自动做了一次旋转,旋转后ARBITERS优先级顺序变为0-2-3-4-1-5。假设之后某个时刻该组的INT_TIMER仙INT_TIMER2乂被同时触发,

12、则此时CPK先处理的会是INT_TIMER2若我们另ARB_MODE2=0则改组的中断优先级次序在任何情况下都不做任何改变,除非我们人为地重新设置了ARB_SEL2勺值。呼。好累。终于说完了麻烦的优先级-_-继续。INTPND寄存器可能是整个中断处理过程中我们要特别注意的一个寄存器了,他的操作比较特别,怎么特别?请听我慢慢道来.:先看一下该寄存器各位详细功能列表正如你所见的,INTPND寄存器与SRCPN晚得一模一样,但他们在中断异常处理中却扮演着不同的角色,如果说SRCPND中断信号进入中断处理模块后所经过的第一个场所的话,那么INTPND则是中断信号在中断处理模块里经历的最后一个寄存器。它

13、的每个位对应一个中断请求,若该位被置1,则表示相应的中断请求被触发,描述到这里你可能会发现它不仅和SRCPND得一模一样,就连功能都一样,其实不然,他们在功能上有着重大的区别。SRCPNft中断源引脚寄存器,某个位被置1表示相应的中断被触发,但我们知道在同一时刻内系统可以触发若十个中断,只要中断被触发了,SRCPN曲相应位便被置1,也就是说SRCPND在同一时刻可以有若十位同时被置1,然而INTPND则不同,他在某一时刻只能有1个位被置1,INTPND某个位被置1(该位对应的中断在所有已触发的中断里具有最高优先级且该中断没有被屏蔽),则表示CPU即将或已经在对该位相应的中断进行处理。于是我们可

14、以有一个总结:SRCPN说明了有什么中断被触发了,INTPN吨明了CPUffl将或已经在对某一个中断进行处理。特别注意:每当某一个中断被处理完之后,我们必须手动地把SRCPND/SUBSRCPND,INTPND寄存器中与该中断相应的位由1设置为0,冈Q才我说INTPND勺操作很特别,它的特别之处就在于对当我们要把该寄存器中某个值为1的位设置为0时,我们不是往该位置0,而是往该位置1。假设SRCPND=0x00000003INTPND=0x0000000,1该值说明当前0号中断和1号中断被触发,但当前正在被处理的是0号中断,处理完毕后我们应该这样设置INTPND和SRCPNDSRCPND=0x0

15、0000002/位0被置为0INTPND=0x00000001/位0被置为0(方法是往该位写入1)另一种直接的方法:INTPND=INTPNDINTOFFSET?存器的功能则很简单,它的作用只是用于表明哪个中断正在被处理。下面是该寄存器各位详细功能歹0表若当前int_timer(M触发了,贝U该寄存器的值为10,以此类推现在我把整个中断流程用一个图加以说明attach21/attach以上这个图活楚地说明了一个中断异常处理流程。下面我用INT_TIMER0,INT_TIMER2ffiINT_UART0E个中断完整地介绍一次中断异常处理。首兄我们得做几个假设:假设1:这三个中断的屏蔽被取消。假设

16、2:PRIORITY寄存器中ARB_MODE2ARB_MODES为0,既不进行优先级的自动旋转排序,任何时候ARBITER2ARBITER&空制的中断组优先级次序分别为0-1-2-3-4-5和1-2-3-4。假设3:这三个中断皆为IRQ类型。假设4:这三个中断同时被触发。INT_TIMER0,INT_TIMER瞽日INT_UART(E个中断被同时触发,此时三个中断信号流向SRCPND咨器,使该寄存器中的第10位,12位,28位被置为1,中断信号继续向前流经INTMASK寄存器,这三个中断都没有被屏蔽,于是信号进一步流经INTMOD备存器,这三个中断皆为IRQ类型,故中断信号继续向前流向

17、PRIORITY寄存器,经过优先级判断,INT_TIMER叫断信号使INTPND寄存器的第10位置1(INT_TIMER耽先级最高),亍匕时INTOFFSEK存器的值为10,CPU转向相应的中断服务例程进行处理。处理完毕后,我们的程序将INTPNDSRCPND的第10置为0,至此INT_TIMER叶断处理完毕。此时SRCPNDJ第12位,28位仍为1(这两个中断请求关被处理),故他们会继续被CPU已刚才描述的方式进行处理。中断异常处理就先讲到这吧:SRCPN®EINTPENDfK是寄存器,这里对他们两个都活中断这里要详细参见CPU册当外部有一个中断时候,SRCPNte应的位就会被置1

18、。通常时候是0,管理硬件的。INTPND当处理中断了,就把相应的位置1。处理内部中断。当向1写1时会使该位活0EINTPEN配处理外部中断,与INTPN赤似,因为在SRCPND可见,外部中断47和8-23是共享一个SRCPN的中断。所以用EINTPENDfE做区别SRCPN也可以用那位是1向哪位写1来¥青0的方式,类彳以INTPND=INTPND;如果INTPND或EINTPEN出活0的话那么处理器会一直认为会有中断相应中断活理应该再中断函数刚进入的时候做,如果放在后面的话那么如果中断程序有错误而导致退出那么会导致没有活理中断我们用的是非抢占式的sema_init()up()down_interruptible()信号章这些是对信号量的处理查找华恒关于中断的实验手册可见源待决寄存器SRCPNDSRCPN所存器是32位的。如果中断源产生了中断请求,那么相应位设为

温馨提示

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

评论

0/150

提交评论