1 概述

1.1什么是中断

   中断通常被定义为一个事件,该事件能够改变处理器执行指令的顺序。这样的事件与 CPU 芯片内外部硬件电路产生的电信号相对应。
    中断分为同步中断和异步中断。
    同步中断——同步中断是当指令执行时由 控制单元产生的,之所以称为同步,是因为只有在一条指令终止执行后 CPU 才会发出中断
    异步中断——异步中 断是由其他硬件设备依照 CPU 时钟信号随机 产生的。
    通常我们所说的中断指的是异步中断,我们将同步中断称为异常。(异常是由程序的错误产生的,或者是由内核必须处理的异常条件产生的)

1.2 中断的作用

   跟据中断的定义,我们可以通过中断使处理器转而去优先运行正常控制流之外的代码。
    当 个中断信号达到肘, CPU 必须停止它当前正在傲的事情,并且切换到一个另一个活动。为了做到这 ~-就要在内核态堆钱保存程序计数器的当前值 (ftn eip cs存器的内容) ,并把与中断类型相关的 个地址放进程序计数量.

1.3 中断的约束

    中断处理是由内核执行的最敏感的任务之一,因为它必须满足下列约束:
    1)中断应该被尽可能快地处理完。
    2)中断处理程序必须编成使相应的内核控制路径能以嵌套的方式执行。
    3)内核在处理一个中断时,可接受新的中断。但存在一个临界区,中断必须被禁止。
    出于1)和3)的约束,中断的设计一般将中断处理程序分为两部分执行(即上半部和下半部函数)。上半部为中断被禁止的临界区,执行关键而紧急的任务,如把接收到的帧拷贝到输入队列,以便下半部函数执行时能进行处理。

1.4 中断的嵌套执行

    中断的约束第二点指明,中断处理程序必须编写成使响应的内核控制路径能够以嵌套的方式执行。
允许内核控制路径嵌套执行必须付出代价,那就是中断处理程序必须永不阻塞,换句话说,中断处理程序运行期间不能发生进程切换一个中断处理既可以抢占其他的中断处理程序.也可以抢占异常处理程序。相反,异常处理程序从不抢占中断处理程序。在内核态能触发的唯一异常就是刚刚描述的缺页异常.但是,中断处理程序从不执行可以导致缺页(因此意味着进程切换)的操作.
    基于以下两个主要原因. Linux交错执行内核控制路径:
    1)为了提高可编程中断控制器和设备控制器的吞吐量.假定设备控制器在一条IRQ线上产生了一个信号.PIC把这个信号转换成一个外部中断,然后PIC和设备控制器保持阻塞,一直到PIC从CPU处接收到一条应答信息.由于内核控制路径的交错执行,内核即使正在处理前一个中断,也能发送应答.
    2)为了实现一种没有优先级的中断模型。因为每个中断处理程序都可以被另一个中断处理程序延缓.因此,在硬件设备之闽没必要建立预定义优先级。这就简化了内核代码,提高了内核的可移植性。
    在多处理器系统上.几个内核控制路径可以并发执行.此外,与异常相关的内核控制路径可以开始在一个CPU上执行,并且由于进程切换而移往另一个CPU上执行.

2 中断分类

中断:
  • 可屏蔽中断    ——I/O设备发出的所有中断请求(lRQ)都产生可屏蔽中断
  • 不可屏蔽中断——只有几个危急事件(如硬件故障)才引起非屏融中断。非屏蔽中断总是由CPU辨认
异常:
  • 处理器异常——当CPU执行指令时探测到的一个反常条件所产生的异常.(故障、陷阱、异常中止)
  • 编程异常    ——在编程者发出请求时发生.是由int或int3指令触发

3 中断与IRQ

    每个能够发出中断请求的硬件设备控制器都有一条名为IRQ(lnterrupt ReQuest) 的输出线。所有现有的IRQ线都与一个名为可编程中断控制器(PIC)的硬件电路的输入引脚相连。
可编程中断控制器的功能:
1)监视IRQ线,检查产生的信号(raised signal).如果有条或两条以上的IRQ线上产生信号,就选择引脚编号较小的IRQ线.(现在的高级可编程中断控制器APIC,通过重定向和中断向量优先级决定中断的优先级。
2) 如果某个IRQ线上产生了引发信号:
        a.  把接收到的引发信号转换成对应的向量.
        b. 把这个向量存放在中断控制器的一个I/O端口,从而允许CPU通过数据总线读此向量。
        c.  把引发信号发送到处理器的INTR引脚,则产生一个中断
        d.  等待,直到CPU通过把这个中断信号写进可编程中断控制器的一个I/O端口来确认它,当这种情况发生肘,清INTR线.    
3)返回到第1 步。
    IRQ线从0开始编号(IRQ0),与中断向量一一对应。其中IRQn 对应的是中断向量n+32,(即IRQ0对应的是中断向量32)。可通过可编程中断控制器修改映射关系。
    
    

中断详解(一)——基本概念相关推荐

  1. IPv6技术详解:基本概念、应用现状、技术实践(上篇)

    本文来自微信技术架构部的原创技术分享. 1.前言 普及IPV6喊了多少年了,连苹果的APP上架App Store也早已强制IPV6的支持,然并卵,因为历史遗留问题,即使在IPV4地址如果饥荒的情况下, ...

  2. linux内核中断详解

    linux内核中断详解 1.中断的硬件触发流程 外设:如果外设有操作或者有数据可用,那么就会产生一个电信号,这个电信号发送给中断控制器. 中断控制器:中断控制器接收到外设发来的电信号以后,进行进一步的 ...

  3. IPv6技术详解:基本概念、应用现状、技术实践(上篇)(转)

    最近在搞IPV6的项目,百度搜了下,这个还是写的很清楚,转载下, 原文是这里,https://www.cnblogs.com/imstudy/p/9056334.html 严禁转载,请告知 本文来自微 ...

  4. RDMA技术详解——RDMA常见概念

    Fabric A local-area RDMA network is usually referred to as a fabric. 所谓Fabric,就是支持RDMA的局域网(LAN). CA( ...

  5. 51单片机中断详解(上)

    一.中断的概念 中断发生 CPU在处理某一事件A时,发生了另一事件B请求CPU迅速去处理 中断响应和中断服务 CPU暂时中断当前的工作,转去处理事件B 中断返回 待CPU将事件B处理完毕后,再回到原来 ...

  6. STM32开发 -- 外部中断详解

    如需转载请注明出处:https://blog.csdn.net/qq_29350001/article/details/87376865 在讲三轴加速度计的时候,提到外部中断.接下来就看看中断为什么这 ...

  7. Bitmap详解(上)常用概念和常用API

    前言: 图片的操作我相信大家都操作过,在算法层面大家往往都是把图片转成MAT矩阵处理的,而Android 开发层面大多数都是bitmap位图操作.接下来我将分算法层面以及android层面来讲解一下图 ...

  8. Java多线程详解(基本概念)

    嗨喽-小伙伴们我来啦, 从本章开始,我们就要开始介绍Java中一个非常重要的概念-----多线程.线程化思想是计算机领域的重要思想,有了线程,咱编写的程序才能更为高效准确地运行起来. 首先,咱来了解一 ...

  9. 【STM32学习笔记】(13)——外部中断详解

    EXTI 简介         EXTI(External interrupt/event controller)-外部中断/事件控制器,管理了控制器的 20 个中断/事件线.每个输入线可以独立地配置 ...

  10. php中 act什么意思,剑网三act是什么意思?详解丐帮act概念

    巴士招募<剑网3>写手,视频解说,游戏高手,漫画达人等等一系列的玩家!无门槛没有要求!如果你也喜欢写作,想把你的心情和游戏故事分享给大家,欢迎前来投稿!一经采用即有众多丰厚奖励作为感谢!如 ...

最新文章

  1. 今天被TensorFlowLite刷屏了吧,偏要再发一遍
  2. python爬取百度百科表格_第一个python爬虫(python3爬取百度百科1000个页面)
  3. 响应式布局方法的方法
  4. python3文件的编码类型是什么_Python3编码类型有哪些?怎么转换?
  5. Java不是true值不变_Java语言中String a=a;String b=a; 为什么 a==b 值为 true?
  6. java云题库测试使用说明 0917
  7. python必须连网开发吗_Python以太坊开发节点和网络选择
  8. Oracle基本函数即字段拆分
  9. zoj 3581 A Simple Test 模拟题
  10. SSL ×××和IPSec的主要区别
  11. 直播http-flv原理
  12. (21)tar打包命令详解
  13. 电磁场仿真原理——5. 有限元法(FEM)
  14. Linux-shell篇之while用法
  15. 分享一些程序员接私活、兼职的平台
  16. C# 操作Word书签(一)插入、删除书签
  17. Linux命令简写与全称
  18. javaFX 调用虚拟键盘
  19. HashMap存储自定义类型键值: 重写HashCode和equals方法
  20. Android模拟机设置中文输入法(拼音、手写、笔画等)

热门文章

  1. 对模拟器虚假设备识别能力提升15%!每日清理大师App集成系统完整性检测
  2. JavaScript---分支与循环
  3. 玉树地震(为玉树同胞祈福!)
  4. rdp远程连接windows和linux,详解 Linux 和 Windows 间的远程桌面访问
  5. hbuilder php语法验证,HBuilderX语法校验、eslint实时校验自动修复功能配置
  6. Nginx之12火眼金睛 - (状态监控 日志分析)
  7. mysql 字段移动平均值_MYSQL简单移动平均值计算
  8. mysql主键怎么做更新操作_更新MySQL主键
  9. 游戏蓝牙耳机什么牌子好?电竞耳机品牌排行榜
  10. python字典基础应用:制作一个披萨点餐流程