• 中断控制系统


    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内部的。

  • 相关阅读:
    PTA 7-82 三个整数排序
    入门指南:网站UI原型设计的简单方法
    java实验报告6:异常处理程序设计
    Flink Java 之 window(滚动, 滑动, 计数, 会话)
    linux系统adb调试工具
    【云原生进阶之PaaS中间件】第一章Redis-1.4过期策略
    AES和Rijndael的区别
    opencv可以有多有趣
    C++异常和断言
    基于springboot在线考试报名系统毕业设计源码031706
  • 原文地址:https://blog.csdn.net/qq_53909405/article/details/132618691