【第22期】观点:IT 行业加班,到底有没有价值?

基于mini2440 的 bootloader 设计 ---- 9、中断初始化

原创 2015年11月17日 17:05:51
      

开发环境:

               电脑系统:RedHat Enterprise Linux6   kernel version : linux-2.6.32

               交叉工具链:arm-linux-xxx4.3.2 

               开发板版本:mini2440 S3C2440处理器  64M SDRAM   256M nand flash

      本文将介绍S3c2440芯片的中断系统。为了测试中断功能,笔者使用了一个外部中断----按键。

一、背景知识

     中断的概念这里就不再赘述了。2440 CPU 共支持60个中断源,分为IRQ和FIQ,或者分为外部中断和内部中断,还可以分为有子中断的中断和没有子中断的中断。所谓的子中断,就如一个串口中断,它又分为读中断和写中断。当一个中断源来临的时候,需要经过一个筛选器,通过筛选器的中断源才能中断CPU核,让CPU处理它的请求。这么一个筛选器如下图所示:


       其中中断源有两条路径,这其实就是由有子中断和没子中断引起的。当中断源来临时,会在SRCPND寄存器将相应的位置1(SRCPN寄存器的每一位都代表着一个或者一类中断,当该位被置1时说明该中断来临),这时如果该中断被打开了,就可以到达中断优先级判断,经过优先级判断以后就可以将INTPND寄存器的相应位置1。当CPU发现INTPND的某一位被置1时,CPU就会查找中断号,然后响应该中断,转去处理相应的中断子程序。因此要初始化中断,其实就是将相应的中断打开,然后在适当的时候读取中断号判断中断类型,并提供中断子程序。

    中断的处理还涉及到一个很重要的话题:环境保护和回恢复。事实上,在中断源通过了筛选器,并成功中断CPU以后,CPU的PC指针就指向一个固定的地址---异常向量表的一项,并且CPU 的工作模式就进入irq 或者fiq模式。为了让CPU处理完中断子程序后能够成功返回,需要将刚进入中断模式下时的寄存器保存起来。当完成中断处理后将这些寄存器恢复,就能够继续中断前的工作。因此在异常向量表里,该地址完成的事就三件:保护环境、跳转到中断处理程序、恢复环境。恢复环境时将CPU也一并恢复,这样就能直接回到中断前的地方继续执行。

二、代码实现

       从代码的角度来看,要完成中断的初始化可以按照如下步骤:

       开启中断-->保护环境-->跳转到中断总入口-->恢复环境。

其中在中断总入口中完成:判断中断源-->调用相应的中断处理函数

按照这一流程,笔者实现了相应的外部中断,并通过按键测试到中断成功。

     实现代码位于:点击打开链接

      












版权声明:本文为博主原创文章,转载请注明出处:http://blog.csdn.net/u013819957 举报

相关文章推荐

u-boot-2009.08 移植 mini2440-64M

1 . 了解u-boot主要的目录结构和启动流程,如下图。       u-boot的 stage1代码通常放在cpu/xxxx/ start.S文件中,他用汇编语言写成;    ...

linux 内核移植和根文件系统的制作

好文推荐: linux 内核移植和根文件系统的制作 转载于凌阳教育:http://www.cnblogs.com/hnrainll/archive/2011/06/09/2076214.html 原文作者 : Leo Chin <a href="http://www.cnb

程序员升职加薪指南!还缺一个“证”!

CSDN出品,立即查看!

基于mini2440 的 bootloader 设计 ---- 8、NandFlash 初始化

开发环境:                电脑系统:RedHat Enterprise Linux6   kernel version : linux-2.6.32            ...

S3C2440 SDRAM内存驱动

++++++++++++++++++++++++++++++++++++++++++ 本文系本站原创,欢迎转载! 转载请注明出处:</span

基于mini2440 的 bootloader 设计 ---- 5、内存初始化

开发环境:                电脑系统:RedHat Enterprise Linux6   kernel version : linux-2.6.32                ...
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)