中断的概念
CPU在处理过程中,经常需要同外部设备进行交互,交互的方式由“轮询方式”“中断方式”

轮询方式:

方式:在同外设进行交互的过程中,CPU每隔一定的时间状态就去查询相关的状态位,所以在交互期间CPU几乎没有干任何事情,仅仅就是是 在一直等待查询,等待查询。

特点:不断查询设备状态,实现方式简单,但是CPU,利用率较低

中断方式:

方式:CPU告知硬件做某件事情 后就去做其他事情,当硬件完成相应的工作后,向CPU发送某个消息。表示已经完成相应的工作。

2440总共有60个中断:

组中断

子中断

中断过程分析:

一:中断生命周期

二:中断源

中断源分为“一般中断源”和“含有子中断源”

三:中断过滤

中断过滤主要依靠掩码寄存器(mask),通过设置相应的位起到过滤中断信号的作用(凡是需要的中断信号,就将其在mask中对应的位设置为0,反之设置为1)

注意:对于mask 寄存器中的EINT4_7总共有4个中断源,但是却用一个为来控制,所以为了分别控制每一个中断源,就需要对EINTMSK 这个寄存器。

四:中断模式
中断模式将分为irq和firq

注意:所谓firq即为将中段信号中具有vip特权的中断信号,优先处理

五:中断处理

(1)判断中断源:

在arm 中有一个寄存器叫INTOFFSET,在其中对于每一个中断都有唯一的编码,读取INTOFFSET中的值,然后惊醒判断。

(2)对不同的中断码,做不同的操作。

六:开中断

在进行核心初始化的过程中,是将中断关闭的,中断控制寄存器为与程序状态寄存器中的(cpsr),因此想要使用中断,就需要开中断。

七:清中断

SUBSRCPND:

中断状态寄存器(个人觉得应该叫这个名字),一旦有中断相应,就会

SRCPND :         对其中中断相对应的位做出置1的操作,如果不将其清零,则下个中

断将不会响应。

INTPND:

注意:这两个寄存器有点特殊,对其置0,是往里面写入1

八:改变cpu工作模式

在核心初始化的过程中,将cpu初始化为了SVC模式,然而在处理一般中断的时候需要将cpu调整为IRQ模式。尤其是对应的复用寄存器,只有在改变处理器是模式后才能发挥其相应的功能。(这里尤其指sp指针)

interrupt_control的更多相关文章

随机推荐

  1. summernote 文本编辑器使用时,选择上传图片、链接、录像时,弹出的对话框被遮挡住

    更多内容推荐微信公众号,欢迎关注: 即问题如下链接内的情况: http://bbs.csdn.net/topics/392004332 这个一般属于CSS中样式出现了问题,可以在点开的时候,F12查看 ...

  2. UNIX环境高级编程 第16章 网络IPC:套接字

    上一章(15章)中介绍了UNIX系统所提供的多种经典进程间通信机制(IPC):管道PIPE.命名管道FIFO.消息队列Message Queue.信号量Semaphore.共享内存Shared Mem ...

  3. 【FCS NOI2018】福建省冬摸鱼笔记 day3

    第三天. 计算几何,讲师:叶芃(péng). dalao们日常不记笔记.@ghostfly233说他都知道了,就盼着自适应辛普森积分. 我计算几何基础不好……然而还是没怎么讲实现,感觉没听什么东西进去 ...

  4. nand flash 的oob 及坏块管理

    0.NAND的操作管理方式      NAND FLASH的管理方式:以三星FLASH为例,一片Nand flash为一个设备(device),1 (Device) = xxxx (Blocks),1 ...

  5. Html.DropDownListFor() 二级联动 ($.getJSON)

    Control: public ActionResult GetPositionName(int parentid) //发布新职位页面中的根据职位类别,获取职位名称 { List<Catego ...

  6. bzoj 1083 繁忙的都市

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1083 题解: 在bzoj里能遇到如此如此水的题真是不容易…… 乍一看好像有点吓人,其实是一 ...

  7. centos7 部署镜像仓库 harbor

    =============================================== 2018/4/16_第2次修改                       ccb_warlock 更新 ...

  8. linux查看内存、CPU占用资源最多的进程

    [内存占用] #利用ps命令,默认使用ps参数会显示的结果 ps -aux USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND root 1 ...

  9. ExtJs的Reader

    ExtJs的Reader Reader : 主要用于将proxy数据代理读取的数据按照不同的规则进行解析,讲解析好的数据保存到Modle中 结构图 Ext.data.reader.Reader 读取器 ...

  10. java基础45 IO流技术(输入字符流/缓冲输入字符流)

    一.输入字符流 1.1.输入字符流体系 ------| Reader:输入字符流的基类(抽象类)  ----------| FileReader:向指定文件读取数据的输入字符流(把硬盘上的数据读取到程 ...