• 中断控制系统


    1.NVIC全称为Nested Vectored Interrupt Controller,是Cortex-M处理器中的中断控制器。它用于管理外部和内部中断,并按照一定的优先级处理和响应中断请求。在Cortex-M处理器中,NVIC是实现优先级中断的关键组件之一。

    2.MPU:内存管理单元。

    3.调试内核,可以控制内核进行暂停和运行。

    4.中断函数:是由外部事件,或者硬件调用的。不同的外设有不同的中断,对应不同的位。

    这个图上面的中断,从上到下,优先级依次降低,当好几个中断事件同时发生的时候,先执行中断级高的中断。

    中断还能嵌套,多个中断运行。

    中断有抢占优先级和响应优先级两个。

    中断通道有一个使能位,控制着通道打开和关闭。

     单片机的中断分为抢占优先级和响应优先级(子优先级),中断时首先由抢占优先级决定产生哪个中断。

          抢占优先级的级别高于响应优先级。而数值越小所代表的优先级就越高。

          高的抢占式优先级可以打断低的抢占式优先级,故名抢占;而在抢占式优先级相同的情况下,响应优先级越高,同时发生则先响应它,但是不能打断低响应优先级,响应表达的是响应速度。

            在解释一下这里的两点:第一,如果两个中断的抢占优先级和响应优先级都是一样的话,则看哪个中断先发生就先执行;第二,高优先级的抢占优先级是可以打断正在进行的低抢占优先级中断的。而抢占优先级相同的中断,高优先级的响应优先级不可以打断低响应优先级的中断。
            结合实例说明一下:假定设置中断优先级组为 2,然后设置中断 3(RTC_WKUP 中断)的抢占优先级为 2,响应优先级为 1。中断 6(外部中断 0)的抢占优先级为 3,响应优先级为 0。中断 7(外部中断 1)的抢占优先级为 2,响应优先级为 0。那么这 3 个中断的优先级顺序为:中断 7>中断 3>中断 6。

    5.异常;是来自于CPU内部的。

  • 相关阅读:
    CLAHE 算法学习 matlab
    ubuntu与cuda
    数据可视化分析之新技能——魔数图
    【Python第三方包】实现自动化(pyautogui包)
    Spring Boot项目整合swagger进行接口测试
    数字化赋能光伏产业链供应链畅通,搭建光伏行业供应链系统加速企业转型升级
    国科大移动互联网考试资料(2023+2020+2018真题+答案)
    BOM与DOM--记录
    TRex学习之旅三
    IDL学习:语法基础-程序控制
  • 原文地址:https://blog.csdn.net/qq_53909405/article/details/132618691