• 中断处理流程深度剖析


    1、中断概念

    cpu在工作的过程中,进程需要与外设进行交互,交互的方式包括“轮询方式”,“中断方式”。

    a、轮询方式:cpu不断地查询设备的状态。cpu利用率很低,不适合多任务的系统。

    b、中断方式:cpu在告知硬件开始一项工作后,就去做别的事去了,当硬件完成了该项工作后,向cpu发送一个信号,告知CPU它已经完成了这项工作。

    2、中断生命周期

     中断信号产生(中断源)--->中断信号过滤(中断控制器)--->中断信号处理(CPU)

    3、中断源

    在中断的生命周期中,中断源的作用是负责产生中断信号。

    a、s3c2440支持60个中断源。

    ,还包括一些子中断源等等

    b、s3c6410

    支持64个中断源

    等等

    4、中断过滤

    2440的过滤图

    这里选择串口0的子中断发送tx0为例:当tx0发送数据后,会产生中断到SUBSRCPND,该SUBSRCPND寄存器的每一位对应一个子中断,对应中断产生,相应位置一。通过SUBMASK来进行过滤,它也是每一位对应一个子中断,当对应位置一,则屏蔽掉该位的中断;如果没有屏蔽,则它会把SRCPND对应的为置一,还要通过MASK寄存器进行过滤,它的每一位对应一个中断源(而非子中断源);该寄存器对应位为一则屏蔽掉。如果没有屏蔽,则可以交给处理器来处理了,但是什么时候交,还有一个优先级的判断;因为在同一时刻可能产生多个中断,各个中断的优先级不一样;选择最优的中断交给处理器处理。mode用来设置到底是快速中断还是普通中断;

    当信号交给cpu后,由cpu来处理了,cpu进行中断处理有两种方式:非向量方式(2440)、向量方式(6410/210)。

    对于2440的非向量方式

    中断程序总入口(唯一的入口)-->保存环境-->判断中断源-->调用对应中断源的中断处理程序-->恢复环境。

    对于6410/210的中断处理

    当中断产生时CPU直接跳转到用户设置好的中断处理程序处-->保存环境-->设备的中断处理-->恢复环境。

  • 相关阅读:
    Falsy Bouncer(算法)
    Check for Palindromes(算法)
    ecshop 修改模板可输出php代码
    ecshop显示所有分类树栏目
    ecshop首页调用评论及图片
    ECSHOP 商品评论条件修改——购买过该商品且只能评价一次(购买多少次能评价多少次)
    PS4破解
    Spring BeanFactory与FactoryBean的区别及其各自的详细介绍于用法
    Java中类方法与实例方法的区别
    Java中类及方法的加载顺序
  • 原文地址:https://www.cnblogs.com/gary-guo/p/5596552.html
Copyright © 2020-2023  润新知