基于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

相关文章推荐

基于mini2440 的 bootloader 设计 ---- 4、CPU核心初始化

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

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

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

基于mini2440 的 bootloader 设计 ---- 1、 准备工作

今天开始着手设计一个简单的bootloader,为此预计会有一系列关于bootloader和arm知识的文章出现了。本篇文章主要为以后的编码工作做一些铺垫,介绍一下开发板情况以及即将实现的bootlo...

基于mini2440 的 bootloader 设计 ---- 3、ARM指令学习

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

基于mini2440 的 bootloader 设计 ---- 6、C程序运行环境搭建

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

定时器中断---那些年我们一起玩mini2440(arm9)裸机

(时钟体系) 时钟概念: ★时钟脉冲:一个按一定电压幅度,一定时间间隔连续发出的脉冲信号;   ★时钟频率:在单位时间(如:1秒)内产生的时钟秒冲数; 时钟的作用: 时钟信号是时序逻辑的基...

按键中断---那些年我们一起玩mini2440(arm9)裸机

ARM中断控制系统 按键驱动程序设计 一.Arm中断控制系统 1.查询方式 程序不断地查询设备的状态,并做出相应的反应。该方式实现比较简单,常用在比较单一的系统中,比如:一个温控系统中可以实用...

Mini2440 bootloader

  • 2012-11-02 13:11
  • 31KB
  • 下载

mini2440简易bootloader源码

  • 2014-05-23 13:02
  • 21KB
  • 下载

mini2440bootloader的移植

最近由于学习的需要,准备开始深入的学习linux驱动开发,然而,自学是一个很痛苦的过程,刚起步,就被bootloader的一直给卡住了,然后各种百度,下面是整理的一些学习的心得,拿出来与大家分享分享。...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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